Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Fetching contributors…

Cannot retrieve contributors at this time

362 lines (353 sloc) 23.248 kb
;;; -*- Mode: LISP; Syntax: COMMON-LISP; Package: HUNCHENTOOT; Base: 10 -*-
;;; Copyright (c) 2004-2010, Dr. Edmund Weitz. All rights reserved.
;;; Redistribution and use in source and binary forms, with or without
;;; modification, are permitted provided that the following conditions
;;; are met:
;;; * Redistributions of source code must retain the above copyright
;;; notice, this list of conditions and the following disclaimer.
;;; * Redistributions in binary form must reproduce the above
;;; copyright notice, this list of conditions and the following
;;; disclaimer in the documentation and/or other materials
;;; provided with the distribution.
;;; THIS SOFTWARE IS PROVIDED BY THE AUTHOR 'AS IS' AND ANY EXPRESSED
;;; OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
;;; WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
;;; ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
;;; DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
;;; DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
;;; GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
;;; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
;;; WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
;;; NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
;;; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
(in-package :hunchentoot)
(defparameter *mime-type-list* '(("application/andrew-inset" "ez")
("application/cu-seeme" "cu")
("application/dsptype" "tsp")
("application/futuresplash" "spl")
("application/hta" "hta")
("application/java-archive" "jar")
("application/java-serialized-object" "ser")
("application/java-vm" "class")
("application/mac-binhex40" "hqx")
("application/mac-compactpro" "cpt")
("application/mathematica" "nb")
("application/msaccess" "mdb")
("application/msword" "doc" "dot")
("application/octet-stream" "bin")
("application/oda" "oda")
("application/ogg" "ogg")
("application/pdf" "pdf")
("application/pgp-keys" "key")
("application/pgp-signature" "pgp")
("application/pics-rules" "prf")
("application/postscript" "ps" "ai" "eps")
("application/rar" "rar")
("application/rdf+xml" "rdf")
("application/rss+xml" "rss")
("application/smil" "smi" "smil")
("application/wordperfect" "wpd")
("application/wordperfect5.1" "wp5")
("application/xhtml+xml" "xhtml" "xht")
("application/xml" "fo" "xml" "xsl")
("application/zip" "zip")
("application/vnd.cinderella" "cdy")
("application/vnd.mozilla.xul+xml" "xul")
("application/vnd.ms-excel" "xls" "xlb" "xlt")
("application/vnd.ms-pki.seccat" "cat")
("application/vnd.ms-pki.stl" "stl")
("application/vnd.ms-powerpoint" "ppt" "pps")
("application/vnd.oasis.opendocument.chart" "odc")
("application/vnd.oasis.opendocument.database" "odb")
("application/vnd.oasis.opendocument.formula" "odf")
("application/vnd.oasis.opendocument.graphics" "odg")
("application/vnd.oasis.opendocument.graphics-template" "otg")
("application/vnd.oasis.opendocument.image" "odi")
("application/vnd.oasis.opendocument.presentation" "odp")
("application/vnd.oasis.opendocument.presentation-template" "otp")
("application/vnd.oasis.opendocument.spreadsheet" "ods")
("application/vnd.oasis.opendocument.spreadsheet-template" "ots")
("application/vnd.oasis.opendocument.text" "odt")
("application/vnd.oasis.opendocument.text-master" "odm")
("application/vnd.oasis.opendocument.text-template" "ott")
("application/vnd.oasis.opendocument.text-web" "oth")
("application/vnd.rim.cod" "cod")
("application/vnd.smaf" "mmf")
("application/vnd.stardivision.calc" "sdc")
("application/vnd.stardivision.draw" "sda")
("application/vnd.stardivision.impress" "sdd" "sdp")
("application/vnd.stardivision.math" "smf")
("application/vnd.stardivision.writer" "sdw" "vor")
("application/vnd.stardivision.writer-global" "sgl")
("application/vnd.sun.xml.calc" "sxc")
("application/vnd.sun.xml.calc.template" "stc")
("application/vnd.sun.xml.draw" "sxd")
("application/vnd.sun.xml.draw.template" "std")
("application/vnd.sun.xml.impress" "sxi")
("application/vnd.sun.xml.impress.template" "sti")
("application/vnd.sun.xml.math" "sxm")
("application/vnd.sun.xml.writer" "sxw")
("application/vnd.sun.xml.writer.global" "sxg")
("application/vnd.sun.xml.writer.template" "stw")
("application/vnd.symbian.install" "sis")
("application/vnd.visio" "vsd")
("application/vnd.wap.wbxml" "wbxml")
("application/vnd.wap.wmlc" "wmlc")
("application/vnd.wap.wmlscriptc" "wmlsc")
("application/x-123" "wk")
("application/x-abiword" "abw")
("application/x-apple-diskimage" "dmg")
("application/x-bcpio" "bcpio")
("application/x-bittorrent" "torrent")
("application/x-cdf" "cdf")
("application/x-cdlink" "vcd")
("application/x-chess-pgn" "pgn")
("application/x-cpio" "cpio")
("application/x-csh" "csh")
("application/x-debian-package" "deb" "udeb")
("application/x-director" "dcr" "dir" "dxr")
("application/x-dms" "dms")
("application/x-doom" "wad")
("application/x-dvi" "dvi")
("application/x-flac" "flac")
("application/x-font" "pfa" "pfb" "gsf" "pcf")
("application/x-freemind" "mm")
("application/x-futuresplash" "spl")
("application/x-gnumeric" "gnumeric")
("application/x-go-sgf" "sgf")
("application/x-graphing-calculator" "gcf")
("application/x-gtar" "gtar" "tgz" "taz")
("application/x-hdf" "hdf")
("application/x-httpd-php" "phtml" "pht" "php")
("application/x-httpd-php-source" "phps")
("application/x-httpd-php3" "php3")
("application/x-httpd-php3-preprocessed" "php3p")
("application/x-httpd-php4" "php4")
("application/x-ica" "ica")
("application/x-internet-signup" "ins" "isp")
("application/x-iphone" "iii")
("application/x-iso9660-image" "iso")
("application/x-java-jnlp-file" "jnlp")
("application/x-javascript" "js")
("application/x-jmol" "jmz")
("application/x-kchart" "chrt")
("application/x-killustrator" "kil")
("application/x-koan" "skp" "skd" "skt" "skm")
("application/x-kpresenter" "kpr" "kpt")
("application/x-kspread" "ksp")
("application/x-kword" "kwd" "kwt")
("application/x-latex" "latex")
("application/x-lha" "lha")
("application/x-lzh" "lzh")
("application/x-lzx" "lzx")
("application/x-maker" "frm" "maker" "frame" "fm" "fb" "book" "fbdoc")
("application/x-mif" "mif")
("application/x-ms-wmd" "wmd")
("application/x-ms-wmz" "wmz")
("application/x-msdos-program" "com" "exe" "bat" "dll")
("application/x-msi" "msi")
("application/x-netcdf" "nc")
("application/x-ns-proxy-autoconfig" "pac")
("application/x-nwc" "nwc")
("application/x-object" "o")
("application/x-oz-application" "oza")
("application/x-pkcs7-certreqresp" "p7r")
("application/x-pkcs7-crl" "crl")
("application/x-python-code" "pyc" "pyo")
("application/x-quicktimeplayer" "qtl")
("application/x-redhat-package-manager" "rpm")
("application/x-sh" "sh")
("application/x-shar" "shar")
("application/x-shockwave-flash" "swf" "swfl")
("application/x-stuffit" "sit")
("application/x-sv4cpio" "sv4cpio")
("application/x-sv4crc" "sv4crc")
("application/x-tar" "tar")
("application/x-tcl" "tcl")
("application/x-tex-gf" "gf")
("application/x-tex-pk" "pk")
("application/x-texinfo" "texinfo" "texi")
("application/x-trash" "~%" "" "bak" "old" "sik")
("application/x-troff" "tt" "r" "roff")
("application/x-troff-man" "man")
("application/x-troff-me" "me")
("application/x-troff-ms" "ms")
("application/x-ustar" "ustar")
("application/x-wais-source" "src")
("application/x-wingz" "wz")
("application/x-x509-ca-cert" "crt")
("application/x-xcf" "xcf")
("application/x-xfig" "fig")
("application/x-xpinstall" "xpi")
("audio/basic" "au" "snd")
("audio/midi" "mid" "midi" "kar")
("audio/mpeg" "mpga" "mpega" "mp2" "mp3" "m4a")
("audio/mpegurl" "m3u")
("audio/prs.sid" "sid")
("audio/x-aiff" "aif" "aiff" "aifc")
("audio/x-gsm" "gsm")
("audio/x-mpegurl" "m3u")
("audio/x-ms-wma" "wma")
("audio/x-ms-wax" "wax")
("audio/x-pn-realaudio" "ra" "rm" "ram")
("audio/x-realaudio" "ra")
("audio/x-scpls" "pls")
("audio/x-sd2" "sd2")
("audio/x-wav" "wav")
("chemical/x-alchemy" "alc")
("chemical/x-cache" "cac" "cache")
("chemical/x-cache-csf" "csf")
("chemical/x-cactvs-binary" "cbin" "cascii" "ctab")
("chemical/x-cdx" "cdx")
("chemical/x-cerius" "cer")
("chemical/x-chem3d" "c3d")
("chemical/x-chemdraw" "chm")
("chemical/x-cif" "cif")
("chemical/x-cmdf" "cmdf")
("chemical/x-cml" "cml")
("chemical/x-compass" "cpa")
("chemical/x-crossfire" "bsd")
("chemical/x-csml" "csml" "csm")
("chemical/x-ctx" "ctx")
("chemical/x-cxf" "cxf" "cef")
("chemical/x-embl-dl-nucleotide" "emb" "embl")
("chemical/x-galactic-spc" "spc")
("chemical/x-gamess-input" "inp" "gam" "gamin")
("chemical/x-gaussian-checkpoint" "fch" "fchk")
("chemical/x-gaussian-cube" "cub")
("chemical/x-gaussian-input" "gau" "gjc" "gjf")
("chemical/x-gaussian-log" "gal")
("chemical/x-gcg8-sequence" "gcg")
("chemical/x-genbank" "gen")
("chemical/x-hin" "hin")
("chemical/x-isostar" "istr" "ist")
("chemical/x-jcamp-dx" "jdx" "dx")
("chemical/x-kinemage" "kin")
("chemical/x-macmolecule" "mcm")
("chemical/x-macromodel-input" "mmd" "mmod")
("chemical/x-mdl-molfile" "mol")
("chemical/x-mdl-rdfile" "rd")
("chemical/x-mdl-rxnfile" "rxn")
("chemical/x-mdl-sdfile" "sd" "sdf")
("chemical/x-mdl-tgf" "tgf")
("chemical/x-mmcif" "mcif")
("chemical/x-mol2" "mol2")
("chemical/x-molconn-Z" "b")
("chemical/x-mopac-graph" "gpt")
("chemical/x-mopac-input" "mop" "mopcrt" "mpc" "dat" "zmt")
("chemical/x-mopac-out" "moo")
("chemical/x-mopac-vib" "mvb")
("chemical/x-ncbi-asn1" "asn")
("chemical/x-ncbi-asn1-ascii" "prt" "ent")
("chemical/x-ncbi-asn1-binary" "val" "aso")
("chemical/x-ncbi-asn1-spec" "asn")
("chemical/x-pdb" "pdb" "ent")
("chemical/x-rosdal" "ros")
("chemical/x-swissprot" "sw")
("chemical/x-vamas-iso14976" "vms")
("chemical/x-vmd" "vmd")
("chemical/x-xtel" "xtel")
("chemical/x-xyz" "xyz")
("image/gif" "gif")
("image/ief" "ief")
("image/jpeg" "jpeg" "jpg" "jpe")
("image/pcx" "pcx")
("image/png" "png")
("image/svg+xml" "svg" "svgz")
("image/tiff" "tiff" "tif")
("image/vnd.djvu" "djvu" "djv")
("image/vnd.wap.wbmp" "wbmp")
("image/x-cmu-raster" "ras")
("image/x-coreldraw" "cdr")
("image/x-coreldrawpattern" "pat")
("image/x-coreldrawtemplate" "cdt")
("image/x-corelphotopaint" "cpt")
("image/x-icon" "ico")
("image/x-jg" "art")
("image/x-jng" "jng")
("image/x-ms-bmp" "bmp")
("image/x-photoshop" "psd")
("image/x-portable-anymap" "pnm")
("image/x-portable-bitmap" "pbm")
("image/x-portable-graymap" "pgm")
("image/x-portable-pixmap" "ppm")
("image/x-rgb" "rgb")
("image/x-xbitmap" "xbm")
("image/x-xpixmap" "xpm")
("image/x-xwindowdump" "xwd")
("model/iges" "igs" "iges")
("model/mesh" "msh" "mesh" "silo")
("model/vrml" "wrl" "vrml")
("text/calendar" "ics" "icz")
("text/comma-separated-values" "csv")
("text/css" "css")
("text/h323" "323")
("text/html" "html" "htm" "shtml")
("text/iuls" "uls")
("text/mathml" "mml")
("text/plain" "asc" "txt" "text" "diff" "pot")
("text/richtext" "rtx")
("text/rtf" "rtf")
("text/scriptlet" "sct" "wsc")
("text/texmacs" "tm" "ts")
("text/tab-separated-values" "tsv")
("text/vnd.sun.j2me.app-descriptor" "jad")
("text/vnd.wap.wml" "wml")
("text/vnd.wap.wmlscript" "wmls")
("text/x-bibtex" "bib")
("text/x-boo" "boo")
("text/x-c++hdr" "h++" "hpp" "hxx" "hh")
("text/x-c++src" "c++" "cpp" "cxx" "cc")
("text/x-chdr" "h")
("text/x-component" "htc")
("text/x-csh" "csh")
("text/x-csrc" "c")
("text/x-dsrc" "d")
("text/x-haskell" "hs")
("text/x-java" "java")
("text/javascript" "js")
("text/x-literate-haskell" "lhs")
("text/x-moc" "moc")
("text/x-pascal" "pp" "as")
("text/x-pcs-gcd" "gcd")
("text/x-perl" "pl" "pm")
("text/x-python" "py")
("text/x-setext" "etx")
("text/x-sh" "sh")
("text/x-tcl" "tcl" "tk")
("text/x-tex" "tex" "ltx" "sty" "cls")
("text/x-vcalendar" "vcs")
("text/x-vcard" "vcf")
("video/dl" "dl")
("video/dv" "dif" "dv")
("video/fli" "fli")
("video/gl" "gl")
("video/mpeg" "mpeg" "mpg" "mpe")
("video/mp4" "mp4")
("video/quicktime" "qt" "mov")
("video/vnd.mpegurl" "mxu")
("video/x-la-asf" "lsf" "lsx")
("video/x-mng" "mng")
("video/x-ms-asf" "asf" "asx")
("video/x-ms-wm" "wm")
("video/x-ms-wmv" "wmv")
("video/x-ms-wmx" "wmx")
("video/x-ms-wvx" "wvx")
("video/x-msvideo" "avi")
("video/x-sgi-movie" "movie")
("x-conference/x-cooltalk" "ice")
("x-world/x-vrml" "vrm" "vrml" "wrl"))
"An alist where the cars are MIME types and the cdrs are list
of file suffixes for the corresponding type.")
(defparameter *mime-type-hash*
(let ((hash (make-hash-table :test #'equalp)))
(loop for (type . suffixes) in *mime-type-list* do
(loop for suffix in suffixes do
(setf (gethash suffix hash) type)))
hash)
"A hash table which maps file suffixes to MIME types.")
(defun mime-type (pathspec)
"Given a pathname designator PATHSPEC returns the MIME type
\(as a string) corresponding to the suffix of the file denoted by
PATHSPEC \(or NIL)."
(gethash (pathname-type pathspec) *mime-type-hash*))
Jump to Line
Something went wrong with that request. Please try again.