Mercurial > hg > xemacs-beta
diff lisp/w3/w3-vars.el @ 70:131b0175ea99 r20-0b30
Import from CVS: tag r20-0b30
author | cvs |
---|---|
date | Mon, 13 Aug 2007 09:02:59 +0200 |
parents | 6a22abad6937 |
children | 1ce6082ce73f |
line wrap: on
line diff
--- a/lisp/w3/w3-vars.el Mon Aug 13 09:00:04 2007 +0200 +++ b/lisp/w3/w3-vars.el Mon Aug 13 09:02:59 2007 +0200 @@ -1,14 +1,13 @@ ;;; w3-vars.el,v --- All variable definitions for emacs-w3 ;; Author: wmperry -;; Created: 1997/03/26 20:12:26 -;; Version: 1.116 +;; Created: 1996/08/29 04:09:40 +;; Version: 1.18 ;; Keywords: comm, help, hypermedia ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; Copyright (c) 1993 - 1996 by William M. Perry (wmperry@cs.indiana.edu) -;;; Copyright (c) 1996, 1997 Free Software Foundation, Inc. ;;; -;;; This file is part of GNU Emacs. +;;; This file is not part of GNU Emacs, but the same permissions apply. ;;; ;;; GNU Emacs is free software; you can redistribute it and/or modify ;;; it under the terms of the GNU General Public License as published by @@ -21,19 +20,15 @@ ;;; GNU General Public License for more details. ;;; ;;; You should have received a copy of the GNU General Public License -;;; along with GNU Emacs; see the file COPYING. If not, write to the -;;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, -;;; Boston, MA 02111-1307, USA. +;;; along with GNU Emacs; see the file COPYING. If not, write to +;;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; Variable definitions for w3 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; - -(require 'w3-cus) ; Grab everything that is customized - (defconst w3-version-number - (let ((x "p3.0.75")) + (let ((x "p3.0.12")) (if (string-match "State:[ \t\n]+.\\([^ \t\n]+\\)" x) (setq x (substring x (match-beginning 1) (match-end 1))) (setq x (substring x 1))) @@ -41,7 +36,7 @@ (function (lambda (x) (if (= x ?-) "." (char-to-string x)))) x "")) "Version # of w3-mode.") -(defconst w3-version-date (let ((x "1997/03/26 20:12:26")) +(defconst w3-version-date (let ((x "1996/08/29 04:09:40")) (if (string-match "Date: \\([^ \t\n]+\\)" x) (substring x (match-beginning 1) (match-end 1)) x)) @@ -54,16 +49,294 @@ ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; General configuration variables ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-annotation-mode 'html-mode + "*A symbol specifying the major mode to enter when doing annotations.") + +(defvar w3-annotation-position 'bottom + "*A symbol specifying where personal annotations should appear in a buffer. +Can be one of the symbols 'top or 'bottom. If the symbol is eq to 'top, then +the annotations will appear at the top of the buffer. If 'bottom, will appear +at the end of the buffer.") + +(defvar w3-auto-image-alt t + "*Whether emacs-w3 should create an alt attribute for an image that +is missing it. +If nil, emacs-w3 will not automatically create an ALT attribute. +If t, the alt attribute will be [IMAGE(nameofimage)] +If a string, it should be a string suitable for running through format, + with only one %s, which will be replaced with just the filename of the + graphic that is not loaded.") + +(defvar w3-configuration-directory "~/.w3/" + "*Where emacs-w3 can find its configuration files") + +(defvar w3-debug-html nil "*Whether to gripe about bad HTML or not.") + +(defvar w3-debug-buffer "*HTML Debug*" + "*Name of buffer to store debugging information in.") + +(defvar w3-default-configuration-file nil + "*Where per-user customizations of w3 are kept.") + +(defvar w3-default-action 'w3-prepare-buffer + "*A lisp symbol specifying what action to take for files with +extensions that are not mapped to a MIME type in `mm-mime-extensions'. +This is useful in case you ever run across files with weird extensions +\(.foo, .README, .READMEFIRST, etc). This should not be required +anymore. + +Possible values: any lisp symbol. Should be a function that takes no +arguments. The return value does not matter, it is ignored. Some examples +are: + +Action Value +---------------------------------------------- +Parse as HTML 'w3-prepare-buffer +View as text 'indented-text-mode") + +(defvar w3-default-homepage nil + "*The url to open at startup. It can be any valid URL. This will +default to the environment variable WWW_HOME if you do not set it in +your .emacs file. If WWW_HOME is undefined, then it will default to +the hypertext documentation for W3 at Indiana University.") + +(defvar w3-default-stylesheet nil + "*The filename of the users default stylesheet.") + +(defvar w3-do-blinking nil + "*Whether emacs-w3 should display blinking text.") + +(defvar w3-do-incremental-display nil + "*Whether to do incremental display of pages or not.") + +(defvar w3-documents-menu-file nil + "*Where the Mosaic documents-menu file is located. This is a file +that has extra menus for the 'Navigate' menu. This should be in the same +format as the Mosaic extra documents.menu.") + (defvar w3-dump-to-disk nil "*If non-nil, all W3 pages loaded will be dumped to disk.") -(defvar w3-fetch-with-default t - "*Whether `w3-fetch' should determine a good starting URL as a default.") +(defvar w3-echo-link 'url + "Whether to display the URL of a link when tabbing through links. +Possible values are: + + url == show the url of the target in the minibuffer + text == show the text of the link in the minibuffer + nil == show nothing") + +(defvar w3-horizontal-rule-char ?- + "*The character to use to create a horizontal rule. +Must be the character's code, not a string. This character is +replicated across the screen to create a division.") + +(defvar w3-hotlist-file nil + "*Hotlist filename. +This should be the name of a file that is stored in either +NCSA's Mosaic/X or Netscape/X format. It is used to keep a listing +of commonly accessed URL's without having to go through 20 levels of +menus to get to them.") + +(defvar w3-html2latex-args "-s -" + "*Args to pass `w3-html2latex-prog'. This should send the LaTeX source +to standard output.") + +(defvar w3-html2latex-prog "html2latex" + "*Program to convert html to latex.") + +(defvar w3-icon-directory "http://cs.indiana.edu/elisp/w3/icons/" + "*Where to find standard icons. Must end in a /!") + +(defvar w3-icon-format 'xbm + "*What file extension icons end in. This is a symbol, string, or nil. +If nil, then no file extension is used.") + +(defvar w3-indent-level 4 + "*Default # of spaces to indent instead of using TABs. This is +necessary to preserve tabs in PRE segments yet still get smaller +indentation for lists, etc.") + +(defvar w3-keep-old-buffers t + "*Whether to keep old buffers around when following links.") + +(defvar w3-latex-docstyle "{article}" + "*The documentstyle to use when printing/mailing converted HTML +files in LaTeX. Good defaults are: +{article}, [psfig,twocolumn]{article}, etc.") + +(defvar w3-link-info-display-function nil + "*A function to call to get extra information about a link and +include it in a buffer. Will be placed after the link and any other +delimiters.") + +(defvar w3-mail-command 'mail + "*This function will be called whenever w3 needs to send mail. It should +enter a mail-mode-like buffer in the current window. +`w3-mail-other-window-command' will be used if w3-mutable-windows is t. +The commands `mail-to' and `mail-subject' should still work in this +buffer, and it should use mail-header-separator if possible.") + +(defvar w3-mail-other-window-command 'mail-other-window + "*This function will be called whenever w3 needs to send mail in +another window. It should enter a mail-mode-like buffer in a +different window. The commands `mail-to' and `mail-subject' should still +work in this buffer, and it should use mail-header-separator if +possible.") + +(defvar w3-max-inlined-image-size nil + "*The maximum byte size of a file to transfer as an inlined image. +If an image is being retrieved and exceeds this size, then it will be +cancelled. This works best on HTTP/1.0 servers that send a +Content-length header, otherwise the image is retrieved up until the +max number of bytes is retrieved, then killed.") + +(defvar w3-max-menu-length 35 + "*The maximum length of a pulldown menu before it will be split into +smaller chunks, with the first part as a submenu, followed by the rest +of the menu.") + +(defvar w3-max-menu-width 40 "*The maximum width of a pulldown menu choice.") + +(defvar w3-modeline-format + '(" " ("W3" + (w3-netscape-emulation-minor-mode + " (NS)") + (w3-lynx-emulation-minor-mode + " (Lynx)") + ": " + (40 (-40 "%b")) + " " + (w3-current-isindex "[Searchable] ") + "%p" " " global-mode-string)) + "*The modeline format string when in w3 mode") + +(defvar w3-mule-attribute 'underline + "*How to highlight items in Mule (Multi-Linugual Emacs).") + +(defvar w3-mutable-windows nil + "*Controls how new WWW documents are displayed. If this is set to +non-nil and pop-up-windows is non-nil, then new buffers will be shown +in another window. If either is nil, then it will replace the document +in the current window.") + +(defvar w3-netscape-configuration-file nil + "*A Netscape-for-X style configuration file. This file will only be read if +and only if `w3-use-netscape-configuration-file' is non-nil.") + +(defvar w3-netscape-compatible-comments t + "*Whether to honor netscape-style <! > comments. +Ye gods I wish I could turn this off by default.") + +(defvar w3-notify 'semibully + "*Selects the behavior when w3 page is ready. +This variable may have one of the following values: + +newframe -- put the w3 page in its own frame +bully -- make the w3 page the current buffer and only window +semibully -- make the w3 page the current buffer in the same window +aggressive -- make the w3 page the current buffer in the other window +friendly -- display w3page in other window but don't make current +polite -- don't display w3 page, but prints message when ready (beeps) +quiet -- like `polite', but don't beep +meek -- make no indication that page is ready + +Any other value of `w3-notify' is equivalent to `meek'.") + +(defvar w3-personal-annotation-directory nil + "*Directory where w3 looks for personal annotations. +This is a directory that should hold the personal annotations stored in +a Mosaic-compatible format.") + +(defvar w3-ppmtoxbm-command "ppmtopgm | pgmtopbm | pbmtoxbm" + "*The command used to convert from the portable-pixmap graphics format +to an x bitmap. This will only ever be used if XEmacs doesn't have support +for XPM.") + +(defvar w3-ppmtoxpm-command "ppmtoxpm" + "*The command used to convert from the portable-pixmap graphics format +to XPM. The XPM _MUST_ be in version 3 format.") + +(defvar w3-print-command "lpr -h -d" + "*Print command for dvi files. +This is usually lpr -h -d to send it to a postscript printer, but you can set +it up so that it is any command that takes a dvi file as its last argument.") + +(defvar w3-reuse-buffers 'reuse + "What to do when following a link will re-fetch a document that has +already been fetched into a W3 buffer. Possible values are: nil, +'yes, and 'no. Nil means ask the user if we should reuse the buffer. + A value of 'yes means assume the user wants us to reuse the buffer. +A value of 'no means assume the user wants us to re-fetch the document. + +This will also accept: +'no 'never 'reload ==> always reload +'yes 'reuse 'always ==> always reuse +'ask nil ==> always ask") + +(defvar w3-right-border 2 + "*Amount of space to leave on right margin of WWW buffers. +This amount is subtracted from (window-width) for each new WWW buffer +and used as the new fill-column.") + +(defvar w3-maximum-line-length nil + "*Maximum length of a line. If nil, then lines can extend all the way to +the window margin. If a number, the smaller of this and +(- (window-width) w3-right-border) is used.") + +(defvar w3-right-justify-address t + "*Whether to make address fields right justified, like Arena.") + +(defvar w3-show-headers nil + "*This is a list of regexps that match HTTP/1.0 headers to show at +the end of a buffer. All the headers being matched against will be +in lowercase. All matching headers will be inserted at the end of the +buffer in a <UL> list.") + +(defvar w3-show-status t + "*Whether to show a running total of bytes transferred. Can cause a +large hit if using a remote X display over a slow link, or a terminal +with a slow modem.") + +(defvar w3-starting-documents + '(("Internet Starting Points" "http://www.ncsa.uiuc.edu/SDG/Software/Mosaic/StartingPoints/NetworkStartingPoints.html") + ("Internet Resources Meta-index" "http://www.ncsa.uiuc.edu/SDG/Software/Mosaic/MetaIndex.html") + ("NCSA's What's New" "http://www.ncsa.uiuc.edu/SDG/Software/Mosaic/Docs/whats-new.html")) + "*An assoc list of titles and URLs for quick access. These are just +defaults so that new users have somewhere to go.") + +(defvar w3-temporary-directory "/tmp" "*Where temporary files go.") (defvar w3-track-last-buffer nil "*Whether to track the last w3 buffer to automatically switch to with M-x w3.") +(defvar w3-track-mouse t + "*Whether to track the mouse and message the url under the mouse.") + +(defvar w3-use-forms-index t + "*Non-nil means translate <ISINDEX> tags into a hypertext form. +A single text entry box will be drawn where the ISINDEX tag appears. +If t, the isindex handling will be the same as Mosaic for X.") + +(defvar w3-use-html2latex nil + "*This controls how HTML is converted into LaTeX for printing or mailing. +If nil, the w3-convert-html-to-latex function is used instead of the +html2latex in a subprocess. The lisp function gives slightly better +formatting in my biased opinion.") + +(defvar w3-use-netscape-configuration-file nil + "*Whether to use a netscape configuration file to determine things like +home pages, link colors, etc. If non-nil, then `w3-netscape-configuration-file' +is read in at startup.") + +(defvar w3-honor-stylesheets t + "*Whether to let a document specify a CSS stylesheet.") + +(defvar w3-user-colors-take-precedence nil + "*Whether to let a document define certain colors about itself. +Like foreground and background colors and pixmaps, color of links and +visited links, etc.") + (defvar w3-gc-cons-threshold-multiplier 1 "Amount to temporarily multiply gc-cons-threshold by when parsing HTML. Setting this to a number greater than 1 will result in less frequent @@ -73,6 +346,17 @@ in later garbage collections taking more time.") ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;;; Hook Variables +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-load-hook nil "*Hooks to be run after loading w3.") +(defvar w3-mode-hook nil "*Hooks to be run after entering w3-mode.") +(defvar w3-file-prepare-hook nil + "*Hooks to be run before preparing a buffer.") +(defvar w3-file-done-hook nil "*Hooks to be run after preparing a buffer.") +(defvar w3-source-file-hook nil + "*Hooks to be run after getting document source.") + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; Figure out what flavor of emacs we are running ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (defvar w3-running-xemacs (string-match "XEmacs\\|Lucid" emacs-version) @@ -83,8 +367,149 @@ "*In FSF v19 emacs?") ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;;; Link delimiting +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-delimit-emphasis 'guess + "*Whether to use characters at the start and end of each bold/italic +region. Obsolete variable (almost) - all this should be specified by the +default stylesheet.") + +(defvar w3-link-start-delimiter '("[[" . "{{") + "*Put this at front of link if w3-delimit-links is t.") + +(defvar w3-link-end-delimiter '("]]" . "}}") + "*Put this at end of link if w3-delimit-links is t.") + +(defvar w3-delimit-links 'guess + "*Put brackets around links? If this variable is eq to 'linkname, then +it will put the link # in brackets after the link text. If it is nil, then +it will not put anything. If it is non-nil and not eq to 'linkname, then +it will put [[ & ]] around the entire text of the link. Is initially set +to be t iff in normal emacs. Nil if in XEmacs or lucid emacs, since links +should be in different colors/fonts.") + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;;; Graphics parsing stuff +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-graphics-always-show-entities t + "*Set to t to always show graphic entities, regardless of the value of +w3-delay-image-loads. Useful if you keep the entities locally and aren't +worried about the transfer time on something that small.") + +(defvar w3-graphics-list nil + "*List of graphics already read in.") + +(defvar w3-delay-image-loads nil + "*Delay loading images for w3 or not?") + +(defvar w3-delayed-images nil + "*A buffer-local variable holding positions and urls of images within +the buffer.") + +(defvar w3-image-mappings + '( + ("image/x-xbitmap" . xbm) + ("image/xbitmap" . xbm) + ("image/xbm" . xbm) + ("image/jpeg" . jpeg) + ("image/gif" . gif) + ("image/png" . png) + ("image/x-fax" . g3fax) + ("image/x-raster" . rast) + ("image/windowdump" . xwd) + ("image/x-icon" . icon) + ("image/portable-graymap" . pgm) + ("image/portable-pixmap" . ppm) + ("image/x-pixmap" . xpm) + ("image/x-xpixmap" . xpm) + ("image/pict" . pict) + ("image/x-rgb" . sgi) + ("image/x-sgi" . sgi) + ("image/x-macpaint" . macpt) + ("image/x-targa" . tga) + ("image/tiff" . tiff) + ) "*How to map MIME types to image types for the `image' package.") + +(defvar w3-color-use-reducing 'guess + "*Whether to use ppmquant/ppmdither to do color reducing for inlined images. +If you are using a 24bit display, you should set this to nil.") + +(defvar w3-color-max-red 4 + "*Max # of red cells to allocate for inlined images.") + +(defvar w3-color-max-green 4 + "*Max # of green cells to allocate for inlined images.") + +(defvar w3-color-max-blue 4 + "*Max # of blue cells to allocate for inlined images.") + +(defvar w3-color-filter 'ppmdither + "*How to do color reducing on inlined images. +This should be a symbol, either ppmdither or ppmquant. +This variable only has any meaning if w3-color-use-reducing is non-nil. +Possible values are: + +ppmquant :== Use the ppmquant program to reduce colors. The product + of w3-color-max-[red|green|blue] is used as the maximum + number of colors. +ppmdither :== Use the ppmdither program to reduce colors. + +any string :== Use this string as the filter. No interpretation of it + is done at all. Example is: + ppmquant -fs -map ~/pixmaps/colormap.ppm") + +(defvar w3-ppmdither-is-buggy t + "*The ppmdither which comes with pbmplus/netpbm releases through +1mar1994 at least ignores the 'maxval' in its input. This can cause +trouble viewing black-and-white gifs. If this variable is set, a +(harmless) 'pnmdepth 255' step is inserted to work around this bug. +You can test your ppmdither by doing + ppmmake white 100 100 | pnmdepth 1 | ppmdither | pnmdepth 255 | ppmhist +If the output has a single line like this: + 255 255 255 255 10000 +then it's safe to set this variable to nil.") + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;;; How to look up styles +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-style-tags-assoc + '( + (b . ("*" . "*")) + (address . ("*" . "*")) + (byline . ("_" . "_")) + (cite . ("_" . "_")) + (cmd . ("*" . "*")) + (dfn . ("*" . "*")) + (em . ("~" . "~")) + (i . ("~" . "~")) + (q . ("\"" . "\"")) + (removed . ("" . "")) + (s . ("" . "")) + (strong . ("*" . "*")) + (sub . ("" . "")) + (sup . ("" . "")) + (u . ("_" . "_")) + ) + "*An assoc list of emphasis tags and their corresponding +begin and end characters.") + +(defvar w3-header-chars-assoc + '( + (h1 . (?* ?* w3-upcase-region)) + (h2 . (?* ?* w3-upcase-region)) + (h3 . (?- ?- w3-upcase-region)) + (h4 . (nil ?= nil)) + (h5 . (nil ?= nil)) + (h6 . (nil ?: nil))) + "*An assoc list of header tags and a list of formatting instructions. +This list consists of 3 items - the first item is no longer used. The +second item is the character to insert after the header. A <BR> is +inserted before and after this string. And the third is a function to +call on the region between the start and end of the header. This will +be called with 2 arguments, the buffer positions of the start and end +of the headers.") + ;; Store the database of HTML general entities. -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (defvar w3-html-entities '( (excl . 33) @@ -315,21 +740,32 @@ If there is a 3rd item in the list, it is the alternative text to use for the image.") +(defvar w3-list-chars-assoc + '( + (ul . ("o" "*" "+" ">")) + (ol . ("." ")" "]" ":")) + (dl . ("o" "*" "+" ">"))) + "An assoc list of characters to put at the front of list items. It is +keyed on the type of list, followed by a list of items. Each item should +be placed in the nth position of the list, where n is the nesting level it +should be used for. n starts at 1.") + ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; Menu definitions ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-navigate-menu nil) (defvar w3-popup-menu '("Emacs-W3 Commands" - ["Back" w3-history-backward (car (w3-history-find-url-internal (url-view-url t)))] - ["Forward" w3-history-forward (cdr (w3-history-find-url-internal (url-view-url t)))] + ["Back" w3-backward-in-history t] + ["Forward" w3-forward-in-history t] "---" - ["Reload" (w3-reload-document) t] - ["Show Images" (w3-load-delayed-images) w3-delayed-images] - "---" - ["Add bookmark" (w3-hotlist-add-document nil) t] + ["Add annotation" w3-annotation-add t] ) "The shorter popup menu.") +(defvar w3-documentation-root "http://www.cs.indiana.edu/elisp/w3/docs/" + "*Where the w3 documentation lives. This MUST end in a slash.") + (defvar w3-graphlink-menu '(("Open this Image (%s)" . w3-fetch) ("Save this Image As..." . w3-download-url) @@ -343,7 +779,7 @@ (defvar w3-hyperlink-menu '(("Open this Link (%s)" . w3-fetch) - ("Add Bookmark for this Link" . w3-hotlist-add-document-at-point) + ("Add Bookmark for this Link" . w3-hotlist-add-document) ("New Window with this Link" . w3-fetch-other-frame) ("Save Link As..." . w3-download-url) ("Copy this Link Location to Clipboard" . w3-save-url) @@ -357,34 +793,64 @@ ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; Variables internal to W3, you should not change any of these ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -(defvar w3-graphics-list nil - "*List of graphics already read in.") - -(defvar w3-delayed-images nil - "*A buffer-local variable holding positions and urls of images within -the buffer.") - -(defvar w3-frameset-structure nil - "Frameset structure, heap of '(frameset ({cols|rows} \"<dimensions>\")) and '(<frame name> <href>)") - -(defvar w3-frame-name nil - "Frame name") - -(defvar w3-base-target nil - "Base target name") - -(defvar w3-target-window-distances nil - "Target window distances") - (defvar w3-form-radio-elements nil "Internal variable - do not touch!") (defvar w3-form-elements nil "Internal variable - do not touch!") +(defvar w3-invisible-href-list nil + "A list of 'invisible' graphic links in the current buffer.") + +(defconst w3-state-locator-variable + '( + :align + :background + :center + :depth + :figalt + :figdata + :fillcol + :form + :formnum + :header-start + :href + :link-args + :image + :lists + :map + :name + :needspace + :next-break + :nofill + :nowrap + :optarg + :options + :pre-start + :select + :secret + :table + :text-mangler + :title + :link-title + :w3-graphic + :zone + :label-text + :seen-this-url + ) + "A list of all the various state kept in the drawing engine. +This is used by the `w3-get-state' and `w3-put-state' macros.") + +(defvar w3-state-vector + (make-vector (1+ (length w3-state-locator-variable)) nil) + "Various state shit kept by emacs-w3.") + (defvar w3-user-stylesheet nil "The global stylesheet for this user.") (defvar w3-current-stylesheet nil "The stylesheet for this document.") +(defvar w3-base-alist nil + "An assoc list of named BASE tags in the current document.") + (defvar w3-blinking-buffs nil "A list of buffers with blinking text in them. This is used to optimize when we change a face so the entire display @@ -395,26 +861,70 @@ "An internal variable for the new display engine that specifies the last character position that was correctly filled.") +(defvar w3-last-tag nil + "An internal variable for the new display engine that specifies the +last tag processed.") + +(defvar w3-table-info nil + "An internal variable for the new display engine for keeping table data +during the pre-pass parsing.") + +(defvar w3-current-formatter nil + "Current formatter function.") + +(defvar w3-draw-buffer nil + "Where we are currently drawing into. This _must_ be a buffer object +when it is referenced.") + (defvar w3-active-faces nil "The list of active faces.") (defvar w3-active-voices nil "The list of active voices.") +(defvar w3-netscape-variable-mappings + '(("PRINT_COLOR" . ps-print-color-p) + ("DITHER_IMAGES" . w3-color-use-reducing) + ("SOCKS_HOST" . url-socks-host) + ("ORGANIZATION" . url-user-organization) + ("EMAIL_ADDRESS" . url-personal-mail-address) + ("REAL_NAME" . url-user-real-name) + ("NEWSGROUP_DESCRIPTIONS" . url-show-newsgroup-descriptions) + ("NNTPSERVER" . url-news-server) + ("AUTOLOAD_IMAGES" . w3-delay-image-loads) + ("HOME_DOCUMENT" . w3-default-homepage) + ("UNDERLINE_LINKS" . w3-underline-links) + ("TMPDIR" . url-temporary-directory)) + "A mapping from netscape configuration file options to w3 variables.") + +(defvar w3-acceptable-protocols-alist + '(("Gopher" . "gopher") + ("TN3270 (IBM Mainframe emulation)" . "tn3270") + ("Interactive Telnet Session" . "telnet") + ("Local file or file over ftp" . "file") + ("File on an http server" . "http") + ("Usenet newsgroup/article" . "news") + ("Mail session" . "mailto")) + "An assoc list of descriptive labels and the corresponding URL stub.") + +(defvar w3-annotation-marker "<ncsa-annotation-format-1>") +(defvar w3-annotation-minor-mode nil "Whether we are in the minor mode.") (defconst w3-bug-address "wmperry@cs.indiana.edu" "Address of current maintainer, where to send bug reports.") (defvar w3-continuation '(url-uncompress url-clean-text) "List of functions to call to process a document completely.") +(defvar w3-current-annotation nil "URL of document we are annotating...") (defvar w3-current-isindex nil "Is the current document a searchable index?") (defvar w3-current-last-buffer nil "Last W3 buffer seen before this one.") -(defvar w3-current-links nil "An assoc list of <link> tags for this doc.") -(defvar w3-current-metainfo nil "An assoc list of <meta> tags for this doc.") +(defvar w3-current-links nil "An assoc list of <LINK> tags for this doc.") (defvar w3-current-source nil "Source of current document.") (defvar w3-current-parse nil "Parsed version of current document.") (defconst w3-default-continuation '(url-uncompress url-clean-text) "Default action to start with - cleans text and uncompresses if necessary.") +(defvar w3-editing-annotation nil "Are we editing an annotation or not?") (defvar w3-find-this-link nil "Link to go to within a document.") (defvar w3-hidden-forms nil "List of hidden form areas and their info.") (defvar w3-hotlist nil "Default hotlist.") (defvar w3-icon-path-cache nil "Cache of where we found icons for entities.") (defvar w3-last-buffer nil "The last W3 buffer visited.") +(defvar w3-personal-annotations nil "Assoc list of personal annotations.") (defvar w3-print-next nil "Should we latex & print the next doc?") (defvar w3-roman-characters "ivxLCDMVX" "Roman numerals.") (defvar w3-setup-done nil "Have we been through setup code yet?") @@ -432,6 +942,12 @@ ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; buffer-local variables to keep around when going into w3-mode ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-e19-hotlist-menu nil + "A menu for hotlists.") + +(defvar w3-e19-links-menu nil + "A buffer-local menu for links.") + (defvar w3-id-positions nil "Internal use only.") (defvar w3-imagemaps nil "Internal use only.") @@ -445,31 +961,47 @@ w3-form-elements url-current-callback-func url-current-content-length + url-current-file url-current-mime-encoding url-current-mime-headers url-current-mime-type url-current-mime-viewer - url-current-object + url-current-port url-current-referer + url-current-server + url-current-type + url-current-user + w3-e19-links-menu w3-current-parse + w3-current-annotation w3-current-isindex w3-current-last-buffer w3-current-links - w3-current-metainfo w3-current-source w3-delayed-images w3-hidden-forms + w3-invisible-href-list + w3-state-vector w3-current-stylesheet w3-form-labels w3-id-positions w3-imagemaps - w3-base-target - w3-target-window-distances - w3-frameset-structure ) "A list of variables that should be preserved when entering w3-mode.") ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;;; Syntax stuff +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +(defvar w3-parse-args-syntax-table + (copy-syntax-table emacs-lisp-mode-syntax-table) + "A syntax table for parsing sgml attributes.") + +(modify-syntax-entry ?' "\"" w3-parse-args-syntax-table) +(modify-syntax-entry ?` "\"" w3-parse-args-syntax-table) +(modify-syntax-entry ?< "(>" w3-parse-args-syntax-table) +(modify-syntax-entry ?> ")<" w3-parse-args-syntax-table) + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; Emulation stuff ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (defvar w3-netscape-emulation-minor-mode nil @@ -490,10 +1022,17 @@ (lambda (var) (if (boundp var) (make-variable-buffer-local var)))) w3-persistent-variables) - +(make-variable-buffer-local 'w3-state-vector) +(make-variable-buffer-local 'w3-current-stylesheet) +(make-variable-buffer-local 'w3-base-alist) +(make-variable-buffer-local 'w3-annotation-minor-mode) +(make-variable-buffer-local 'w3-last-tag) (make-variable-buffer-local 'w3-last-fill-pos) -(make-variable-buffer-local 'w3-frame-name) +(make-variable-buffer-local 'w3-table-info) +(make-variable-buffer-local 'w3-draw-buffer) +(make-variable-buffer-local 'w3-current-formatter) (make-variable-buffer-local 'w3-active-faces) +(make-variable-buffer-local 'w3-default-style) (make-variable-buffer-local 'w3-netscape-emulation-minor-mode) (make-variable-buffer-local 'w3-lynx-emulation-minor-mode) (make-variable-buffer-local 'w3-last-search-item) @@ -503,6 +1042,8 @@ ;;; Keymap definitions ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (defvar w3-mode-map (make-keymap) "Keymap to use in w3-mode.") +(defvar w3-annotation-minor-mode-map (make-keymap) "Keymap for annotation.") + (suppress-keymap w3-mode-map) (define-key w3-mode-map "h" (make-sparse-keymap)) @@ -519,16 +1060,20 @@ (define-key w3-mode-map "hI" 'w3-hotlist-add-document-at-point) (define-key w3-mode-map "hR" 'w3-hotlist-refresh) -(define-key w3-mode-map "HF" 'w3-history-forward) -(define-key w3-mode-map "HB" 'w3-history-backward) +(define-key w3-mode-map "ai" 'w3-annotation-add) +(define-key w3-mode-map "ad" 'w3-delete-personal-annotation) +(define-key w3-mode-map "ae" 'w3-annotation-edit) + +(define-key w3-mode-map "HF" 'w3-forward-in-history) +(define-key w3-mode-map "HB" 'w3-backward-in-history) (define-key w3-mode-map "Hv" 'w3-show-history-list) (define-key w3-mode-map " " 'w3-scroll-up) (define-key w3-mode-map "<" 'beginning-of-buffer) (define-key w3-mode-map ">" 'end-of-buffer) (define-key w3-mode-map "?" 'w3-help) -(define-key w3-mode-map "B" 'w3-history-backward) -(define-key w3-mode-map "F" 'w3-history-forward) +(define-key w3-mode-map "B" 'w3-backward-in-history) +(define-key w3-mode-map "F" 'w3-forward-in-history) (define-key w3-mode-map "G" 'w3-show-graphics) (define-key w3-mode-map "I" 'w3-popup-info) (define-key w3-mode-map "K" 'w3-save-this-url) @@ -543,20 +1088,20 @@ (define-key w3-mode-map "\C-c\C-v" 'w3-version) (define-key w3-mode-map "\C-o" 'w3-fetch) (define-key w3-mode-map "\M-M" 'w3-mail-document-under-point) +(define-key w3-mode-map "\M-\C-i" 'w3-insert-this-url) (define-key w3-mode-map "\M-m" 'w3-mail-current-document) -(define-key w3-mode-map "\M-s" 'w3-save-as) +(define-key w3-mode-map "\M-s" 'w3-search) (define-key w3-mode-map "\M-\r" 'w3-follow-inlined-image) (define-key w3-mode-map "\r" 'w3-widget-button-press) -(define-key w3-mode-map "\n" 'w3-widget-button-press) -(define-key w3-mode-map "b" 'w3-widget-backward) +(define-key w3-mode-map "b" 'widget-backward) (define-key w3-mode-map "c" 'w3-mail-document-author) -(define-key w3-mode-map "f" 'w3-widget-forward) +(define-key w3-mode-map "f" 'widget-forward) (define-key w3-mode-map "g" 'w3-reload-document) (define-key w3-mode-map "i" 'w3-document-information) (define-key w3-mode-map "k" 'w3-save-url) (define-key w3-mode-map "l" 'w3-goto-last-buffer) (define-key w3-mode-map "m" 'w3-complete-link) -(define-key w3-mode-map "n" 'w3-widget-forward) +(define-key w3-mode-map "n" 'widget-forward) (define-key w3-mode-map "o" 'w3-open-local) (define-key w3-mode-map "p" 'w3-print-this-url) (define-key w3-mode-map "q" 'w3-quit) @@ -571,13 +1116,18 @@ (define-key w3-mode-map [(control meta t)] 'url-list-processes) ;; Widget navigation -(define-key w3-mode-map [tab] 'w3-widget-forward) -(define-key w3-mode-map "\t" 'w3-widget-forward) -(define-key w3-mode-map "\M-\t" 'w3-widget-backward) -(define-key w3-mode-map [backtab] 'w3-widget-backward) -(define-key w3-mode-map [(shift tab)] 'w3-widget-backward) -(define-key w3-mode-map [(meta tab)] 'w3-widget-backward) +(define-key w3-mode-map "\t" 'widget-forward) +(define-key w3-mode-map [(shift tab)] 'widget-backward) +(define-key w3-annotation-minor-mode-map "\C-c\C-c" + 'w3-personal-annotation-finish) + +;;; This is so we can use a consistent method of checking for mule support +;;; Emacs-based mule uses (boundp 'MULE), but XEmacs-based mule uses +;;; (featurep 'mule) - I choose to use the latter. + +(if (boundp 'MULE) + (provide 'mule)) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; Keyword definitions ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;