[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
This typing allows much more flexibility in naming files. HTTP/1.0 servers can now send back content-type headers in response to a request, and not have the client second-guess it based on file extensions. HTML files can now be named `something.png' (not a great idea, but possible).
6.1 Adding MIME types based on file extensions | How to map file extensions onto MIME types (e.g., `.png -> image/png)'. | |
6.2 Specifying Viewers | How to specify external and internal viewers for files that Emacs/W3 cannot handle natively. |
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
For some protocols however, it is still necessary to guess the content of a file based on the file extension. This type of guess-work should only be needed when accessing files via FTP, local file access, or old HTTP/0.9 servers.
Instead of specifying how to view things twice, once based on
content-type and once based on the file extension, it is easier to map
file extensions to MIME content-types. The variable that controls this
is mm-mime-extensions
.
This variable is an assoc list of file extensions and the corresponding MIME content-type. A sample entry looks like: `(".movie" . "video/x-sgi-movie")' This makes all files that end in `.movie' (`foo.movie' and `bar.movie') be interpreted as SGI animation files. If a content-type is defined for the document, then this is over-ridden. Regular expressions can NOT be used.
Both Mosaic and the NCSA HTTP daemon rely on a separate file for mapping
file extensions to MIME types. Instead of having the users of Emacs/W3
duplicate this in lisp, this file can be parsed using the
url-parse-mimetypes
function. This function is called each time
w3 is loaded. It tries to locate mimetype files in several places. If
the environment variable MIMETYPES
is nonempty, then this is
assumed to specify a UNIX-like path of mimetype files (this is a colon
separated string of pathnames). If the MIMETYPES
environment
variable is empty, then Emacs/W3 looks for these files:
Each line contains information for one HTTP type. These types resemble MIME types. To add new ones, use subtypes beginning with x-, such as application/x-myprogram. Lines beginning with # are comment lines, and suitably ignored. Each line consists of:
type/subtype ext1 ext2 ... extn
type/subtype is the MIME-like type of the document. ext* is any number of space-separated filename extensions which correspond to the MIME type.
[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
Not all files look as they should when parsed as an HTML document (whitespace is stripped, paragraphs are reformatted, and lots of little changes that make the document look unrecognizable). Files may be passed to external programs or Emacs Lisp functions to be viewed.
Not all files can be viewed accurately from within an Emacs session (PNG files for example, or audio files). For this reason, the user can specify file "viewers" based on MIME content-types. This is done with a standard mailcap file. See section E. Mailcap Files.
As an alternative, the function mm-add-mailcap-entry
can also be
used from an appropriate hook. See section 11.5 Hooks. This functions takes three
arguments, the major type ("image"), the minor type ("png"), and
an assoc list of information about the viewer. Please see the URL
documentation for more specific information on what this assoc list
should look like.
[ << ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |