;;; cfml-helper-mode.el --- Major mode for composing cfml files.
;;; mostly html-helper-mode.el
;;; v 3.0.4jolly
;; Mantainer : Gian Uberto "Saint" Lauri
;; *
;; * works only from DEI, Padova.
;; http://www.gest.unipd.it/~saint/
;; Original Author: Nelson Minar
;; Original version Maintainer: Nelson Minar
;; Changes by by: Gian Uberto Lauri , *
;; * works only from DEI, Padova.
;; Credits : Larry Smith and Tony Graham for the ASP/PHP matching regexp
;; prototype.
;; Stan Lanning for the defadvice code that prevents indenting
;; of , for the defadvice code that leaves the cursor
;; where it is during narrowing to script code, enhancments to
;; the scripting narrowing
;; Charles Curley for the commentary of tempo.el behaviour
;; Samir Barjoud for giving me the luser cap when I didn't notice
;; that *ALL* I needed to write cfml-helper-match-asp-php was in
;; font-lock.el.
;; Theodore A. Jump for fixing fold tags in this source (after I
;; broke them
;; David J. Biesack for suggesting a good version checking.
;; URL: http://www.gest.unipd.it/~saint/cfml-helper-mode.el.gz
;; Created: 01 Feb 1994
;; $Id: cfml-helper-mode.el,v 3.0.4jolly 1998/08/06 18:53:03 nelson Exp $
;; Keywords: HTML major-mode
;; LCD Archive Entry:
;; cfml-helper-mode|Gian Uberto Lauri|address@bogus.example.com|
;; Major mode for editing HTML.|
;; 26-Oct-99|Version 3.?.?|http://www.gest.unipd.it/~saint/cfml-helper-mode.el.gz
;; Copyright (C) 1994 Nelson Minar
;; Copyright (C) 1995 Nelson Minar and Ulrik Dickow
;; Copyright (C) 1999 Nelson Minar, Ulrik Dickow and Gian Uberto Lauri
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; 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, 675 Massachusettes Ave,
;; Cambridge, MA 02139, USA.
;;{{{ Commentary
;; Installation:
;; Add this line in your .emacs:
;; (autoload 'cfml-helper-mode "cfml-helper-mode" "Yay HTML" t)
;; To invoke cfml-helper-mode automatically on .html files, do this:
;; (setq auto-mode-alist (cons '("\\.html$" . cfml-helper-mode) auto-mode-alist))
;; To invoke cfml-helper-mode automatically on .asp files, do this:
;; (setq auto-mode-alist (cons '("\\.asp$" . cfml-helper-mode) auto-mode-alist))
;; To invoke cfml-helper-mode automatically on .phtml files, do this:
;; (setq auto-mode-alist (cons '("\\.phtml$" . cfml-helper-mode) auto-mode-alist))
;;
;; This mode requires another lisp file, tempo.el. This can be
;; retrieved from ftp://ftp.lysator.liu.se/pub/emacs/tempo.el
;; Xemacs users need to have auc-menu installed.
;; Emacs 18 users need to have auc-menu and add-hook installed.
;; If your OS has broken 14 character filenames
;; this mode will also work with the name "html-mode.el".
;; Configuration:
;; see the "user variables" section, or the documentation on configuration
;; in http://www.santafe.edu/~nelson/tools/. There are variables you want to
;; configure, particularly cfml-helper-address-string and
;; cfml-helper-use-expert-menu
;; See also: http://www.gest.unipd.it/~saint/hth.html for further details
;; regarding server code support.
;; Description:
;; cfml-helper-mode makes it easier to write HTML documents. This mode
;; handles inserting HTML codes in a variety of ways (keybindings, menus,
;; completion in the buffer). It also supports indentation, timestamps,
;; skeletons for new documents, hilit19 patterns, and a variety of other
;; things. For the full skinny, see the HTML documentation that comes
;; with the package or is at http://www.santafe.edu/~nelson/tools/
;; Thank yous:
;; David Kågedal for the tempo code which
;; forms the core of the HTML insertion, as well as the HTML+ tag.
;; Marc Hedlund for general encouragement and
;; many helpful suggestions, especially with HTML/2.0 compliance
;; and form design.
;; Ulrik Dickow for the font-lock code
;; Denis Howe for writing browse-url.
;; Magnus Homann and Jamshid Afshar
;; for timestamp suggestions.
;; Everyone who sent me a version of menus (16 in all!)
;; Marc Andreessen for writing the original html-mode
;; The newest version of cfml-helper-mode should always be available from
;; http://www.gest.unipd.it/~saint/hth.html
;; Changes moved to hhm-changelog
;; This code was writting using folding.el, a wonderful folding editor
;; minor mode for emacs. That's what the strange {{{ comments are for.
;;}}}
;;{{{ Code:
(defconst cfml-helper-mode-version
(progn
(let ((revs "$Revision: 3.0.4jolly$")
(lastchar 0))
; revs is a string of single byte characters
(set 'lastchar (1- (string-width revs)))
(substring revs 11 lastchar))))
;;{{{ user variables
;;{{{ defcustoms
(defgroup cfml-helper nil
"Customizing cfml-helper-mode"
:group 'languages
:group 'hypermedia
:group 'local)
(defgroup cfml-helper-faces nil
"Customizing cfml-helper-mode custom faces"
:group 'cfml-helper
:group 'faces)
;; Default distribution doesn't include visual-basic-mode
(defcustom cfml-helper-mode-uses-visual-basic nil
"Non nil to require visual-basic-mode"
:type 'boolean
:initialize 'custom-initialize-default
:group 'cfml-helper
:require 'cfml-helper-mode)
;; Default distribution doesn't include jde
;;
;; Suggestion by :
;; Jari Aalto
;;
;; I think that people that have installed JDE, use it, so
;; it would be logical to preset this automatically using
;; `locate-library'
(defcustom cfml-helper-mode-uses-JDE (locate-library "jde")
"No nil to use jde instead of java-mode"
:type 'boolean
:initialize 'custom-initialize-default
:group 'cfml-helper
:require 'cfml-helper-mode)
(defcustom cfml-helper-mode-uses-bold-italic nil
"Non nil to use the bold-italic font (if your font supports it)"
:type 'boolean
:initialize 'custom-initialize-default
:group 'cfml-helper
:require 'cfml-helper-mode)
(defcustom cfml-helper-mode-uses-KG-style nil
"Non nil to make Emacs consider PHP/ASP code blocks beginning in the first column"
:type 'boolean
:initialize 'custom-initialize-default
:group 'cfml-helper
:require 'cfml-helper-mode)
(defcustom cfml-helper-mode-global-JSP-not-ASP t
"Non nil to make Emacs consider <% %> blocks as JSP (global default behaviour)"
:type 'boolean
:initialize 'custom-initialize-default
:group 'cfml-helper
:require 'cfml-helper-mode)
(defcustom cfml-helper-mode-insert-attributes-always nil
"non nil to make Emacs insert empty tag attributes when tempo-interactive is nil"
:type 'boolean
:initialize 'custom-initialize-default
:group 'cfml-helper
:require 'cfml-helper-mode)
;;}}}
;;{{{ defvars...
(defvar cfml-helper-mode-local-JSP-not-ASP
cfml-helper-mode-global-JSP-not-ASP
"Non nil to make Emacs consider <% %> blocks as JSP (buffer local behaviour)")
(defvar cfml-helper-mode-run-the-mode t "When t, make the local variables, else skip")
;; Visual basic mode is not in the standard distribution, so I let the user
;; override cfml-helper-mode-uses-visual-basic with a nil value.
(cond (cfml-helper-mode-uses-visual-basic (require 'visual-basic-mode)))
(cond (cfml-helper-mode-uses-JDE (require 'jde)))
(require 'cc-mode)
(require 'cl)
;; Set this to be whatever signature you want on the bottom of your pages.
(defvar cfml-helper-address-string ""
"*The default author string of each file.")
;; Features; these are all good to have on. (see also tempo.el)
(defvar cfml-helper-use-expert-menu t
"*If not nil, then use the full HTML menu.")
(defvar cfml-helper-do-write-file-hooks t
"*If not nil, then modify `local-write-file-hooks' to do timestamps.")
(defvar cfml-helper-build-new-buffer t
"*If not nil, then insert `cfml-helper-new-buffer-strings' for new
buffers.")
;; variables to configure (these defaults are reasonable.)
(defvar cfml-helper-htmldtd-version "\n"
"*Version of HTML DTD you're using.")
(defvar cfml-helper-user-menu nil
"*Extra items to put in the HTML expert menu.
The value of this symbol is appended to the beginning of the expert
menu that is handed off to easymenu for definition. It should be a
list of vectors or lists which themselves are vectors (for submenus).")
(defvar cfml-helper-basic-offset 2
"*Basic indentation size used for list indentation")
;; Wed Jan 10 09:35:53 2001 Saint
;;
;; fixing indentation
;;(defvar cfml-helper-item-continue-indent 2
;; "*Indentation of lines that follow a
item.
;;Default is 2, the length of things like \"
\" and \"
\".")
(defvar cfml-helper-never-indent nil
"*If not nil, the indentation code for cfml-helper is turned off.")
;; hooks (see also tempo.el)
;; On prompts... Charles Curley (http://w3.trib.com/~ccurley/): It took
;; some time to figure this out... The (p "prompt: ") and (r "prompt:
;; ") entries indicate where the prompting mode should prompt for a
;; field in the tag. (p ) indicates a parameter, such as the color of a
;; tag. (r ) indicates a region, where the text to be surrounded
;; by the tag should go, such as the text to be turned that color. The
;; difference is this: when prompting mode is turned off and the user
;; is surrounding a region with the tag, the (r ) (region) parameter
;; indicates where the surrounded region will go. The first (p )
;; (parameter) is where the cursor will go, ready to input the first
;; parameter to the tag.
;; So when you have prompting on, and use the font with color and size
;; tag, put the cursor where you want the modified text to go. Start
;; inserting the tag. You will be prompted for the color, the size, and
;; then the text to display that way. When you have prompting turned
;; off, and don't have a region blocked, insert the font tag, and the
;; cursor will be at the the first parameter. Then tab over to the
;; space between the two parts of the tag, and type in your text. If
;; you have region blocked, C-u followed by the tag will surround the
;; region with the tag. The blocked region goes into the (r )
;; parameter. Then the cursor is placed at the first (p ) location,
;; ready for you to type in a parameter, such as the color of the text.
(defvar cfml-helper-mode-hook nil
"*Hook run when cfml-helper-mode is started.")
(defvar cfml-helper-load-hook nil
"*Hook run when cfml-helper-mode is loaded.")
(defvar cfml-helper-timestamp-hook 'cfml-helper-default-insert-timestamp
"*Hook called for timestamp insertion.
Override this for your own timestamp styles.")
;; strings you might want to change
(defvar cfml-helper-new-buffer-template
'(cfml-helper-htmldtd-version
" \n"
"" p "\n\n\n"
"\n"
"
" p "
\n\n"
p
"\n\n\n"
"" cfml-helper-address-string "\n"
cfml-helper-timestamp-start
cfml-helper-timestamp-end
"\n \n")
"*Template for new buffers.
Inserted by `cfml-helper-insert-new-buffer-strings' if
`cfml-helper-build-new-buffer' is set to t")
(defvar cfml-helper-new-ASP-buffer-template
'("<%@ LANGUAGE=\"" p "\" %>\n"
" \n"
"<%\n\n%>\n"
"\n"
"<% ' %>\n"
"\n\n")
"*Template for new ASP buffers.
Inserted by `cfml-helper-insert-new-ASP-buffer-strings' if
`cfml-helper-build-new-buffer' is set to t")
(defvar cfml-helper-new-PHP-buffer-template
'(" \n"
" PHP\n\n?>"
"\n"
" /* " cfml-helper-timestamp-start "\n\n"
cfml-helper-timestamp-end
" */ ?>\n"
"\n\n"
)
"*Template for new PHP buffers.
Inserted by `cfml-helper-insert-new-PHP-buffer-strings' if
`cfml-helper-build-new-buffer' is set to t")
;; Someone has some better idea ?
(defvar cfml-helper-new-JSP-buffer-template
'(" \n"
"<%\n\n%>\n"
"\n"
"<% ' %>\n"
"\n\n")
"*Template for new JSP buffers.
Inserted by `cfml-helper-insert-new-ASP-buffer-strings' if
`cfml-helper-build-new-buffer' is set to t")
(defvar cfml-helper-timestamp-start " "
"*Start delimiter for timestamps.
Everything between `cfml-helper-timestamp-start' and
`cfml-helper-timestamp-end' will be deleted and replaced with the output
of the functions `cfml-helper-timestamp-hook' if
`cfml-helper-do-write-file-hooks' is t")
(defvar cfml-helper-timestamp-end ""
"*End delimiter for timestamps.
Everything between `cfml-helper-timestamp-start' and
`cfml-helper-timestamp-end' will be deleted and replaced with the output
of the function `cfml-helper-insert-timestamp' if
`cfml-helper-do-write-file-hooks' is t")
;; control over what types of tags to load. By default, we load all the
;; ones we know of.
(defvar cfml-helper-types-to-install
'(anchor list header logical phys textel entity image table head form
script)
"*List of tag types to install when cfml-helper-mode is first loaded.
If you want to not install some type of tag, override this variable.
Order is significant: menus go in this order.")
;; emacs18 detection.
(defvar cfml-helper-emacs18
(and (boundp 'emacs-version)
(or (and (boundp 'epoch::version) epoch::version)
(string-lessp emacs-version "19")))
"I'll do minimal emacs18 support, grumble.")
;;}}} end of defvars
;;}}} end of user variables
;;{{{ Prologue
(require 'tempo) ;essential part of cfml-helper-mode
(condition-case nil ;menu support, standard in emacs19
(require 'auc-menu) ;add-on for XEmacs. *why* does this
(error (require 'easymenu))) ;package have to have two names?
;; Wed Mar 28 09:55:29 2001 Saint
;;
;; Placing here (require 'psgml-html ) after a suggestion from Graham
;; Gough who explored the faces problem with XEmacs (many thanks)
(if (string-match "XEmacs\\|Lucid" (emacs-version))
;; This will initialize cfml-helper-bold-face
(require 'psgml-html))
(require 'font-lock)
;;}}}
;;{{{ cfml-helper-mode-syntax-table and cfml-helper-mode-abbrev-table
;; emacs doesn't seem to be able to really handle SGML like syntax. In
;; particular, comments are a loss.
;; We do try this, though: give < and > matching semantics
(defvar cfml-helper-mode-syntax-table nil
"Syntax table for cfml-helper.")
(if cfml-helper-mode-syntax-table
()
(setq cfml-helper-mode-syntax-table (make-syntax-table
text-mode-syntax-table))
(modify-syntax-entry ?< "(> " cfml-helper-mode-syntax-table)
(modify-syntax-entry ?> ")< " cfml-helper-mode-syntax-table)
(modify-syntax-entry ?\" ". " cfml-helper-mode-syntax-table)
(modify-syntax-entry ?\\ ". " cfml-helper-mode-syntax-table)
(modify-syntax-entry ?' "w " cfml-helper-mode-syntax-table))
(defvar cfml-helper-mode-abbrev-table nil
"Abbrev table used while in cfml-helper-mode.")
(define-abbrev-table 'cfml-helper-mode-abbrev-table ())
;;}}}
;;{{{ type based keymap and menu variable and function setup
;; Our basic keymap.
(defvar cfml-helper-mode-map (make-sparse-keymap)
"Keymap for cfml-helper")
(defvar cfml-helper-mode-menu nil
"Menu for cfml-helper. Clobbered and rebuilt by
`cfml-helper-install-menu'")
;; cfml-helper-mode has a concept of "type" of tags. Each type is a
;; list of tags that all go together in one keymap and one menu.
;; Types can be added to the system after cfml-helper has been loaded,
;; briefly by doing cfml-helper-add-type-to-alist, then
;; cfml-helper-install-type, then cfml-helper-add-tag (for each tag)
;; then cfml-helper-rebuild-menu. See the mode documentation for more detail.
(defconst cfml-helper-type-alist nil
"Alist: type of tag -> keymap, keybinding, menu, menu string.
Add to this with `cfml-helper-add-type-to-alist'.")
(defun cfml-helper-keymap-for (type)
"Accessor function for alist: for type, return keymap or nil"
(nth 0 (cdr-safe (assq type cfml-helper-type-alist))))
(defun cfml-helper-key-for (type)
"Accessor function for alist: for type, return keybinding or nil"
(nth 1 (cdr-safe (assq type cfml-helper-type-alist))))
(defun cfml-helper-menu-for (type)
"Accessor function for alist: for type, return menu or nil"
(nth 2 (cdr-safe (assq type cfml-helper-type-alist))))
(defun cfml-helper-menu-string-for (type)
"Accessor function for alist: for type, return menustring or nil"
(nth 3 (cdr-safe (assq type cfml-helper-type-alist))))
(defun cfml-helper-normalized-menu-for (type)
"Helper function for building menus from submenus: add on string to menu."
(cons (cfml-helper-menu-string-for type)
(eval (cfml-helper-menu-for type))))
(defun cfml-helper-add-type-to-alist (type)
"Add a type specification to the alist.
The spec goes (type . (keymap-symbol keyprefix menu-symbol menu-string)).
See code for an example."
(setq cfml-helper-type-alist (cons type cfml-helper-type-alist)))
;; Here are the types provided by cfml-helper-mode.
(mapcar 'cfml-helper-add-type-to-alist
'((entity . (nil nil cfml-helper-entity-menu "Insert Character Entities"))
(textel . (nil nil cfml-helper-textel-menu "Insert Text Elements"))
(head . (cfml-helper-head-map "\C-c\C-h"
cfml-helper-head-menu
"Insert Structural Elements"))
(header . (cfml-helper-header-map "\C-c\M-h"
cfml-helper-header-menu
"Insert Headers"))
(anchor . (cfml-helper-anchor-map "\C-c\C-a"
cfml-helper-anchor-menu
"Insert Hyperlinks"))
(logical . (cfml-helper-logical-map "\C-c\M-l"
cfml-helper-logical-menu
"Insert Logical Styles"))
(phys . (cfml-helper-phys-map "\C-c\C-p"
cfml-helper-phys-menu
"Insert Physical Styles"))
(list . (cfml-helper-list-map "\C-c\C-l"
cfml-helper-list-menu
"Insert List Elements"))
(form . (cfml-helper-form-map "\C-c\C-f"
cfml-helper-form-menu
"Insert Form Elements"))
(image . (cfml-helper-image-map "\C-c\C-i"
cfml-helper-image-menu
"Insert Inlined Images"))
(table . (cfml-helper-table-map "\C-c\C-t"
cfml-helper-table-menu
"Insert Tables"))
(script . (cfml-helper-script-map "\C-c\C-s"
cfml-helper-script-menu
"Insert Scripts"))
))
;; Once cfml-helper-mde is aware of a type, it can then install the
;; type: arrange for keybindings, menus, etc.
(defconst cfml-helper-installed-types nil
"The types that have been installed (used when building menus).
There is no support for removing a type once it has been installed.")
;; For easy ASP/JSP switch
(defun cfml-helper-use-JSP-this-buffer ()
(interactive)
(setq cfml-helper-mode-local-JSP-not-ASP t)
(setq mode-name "HTML/JSP helper")
(setq major-mode 'jsp-cfml-helper-mode))
(defun cfml-helper-use-ASP-this-buffer ()
(interactive)
(cond (cfml-helper-mode-uses-visual-basic
(setq cfml-helper-mode-local-JSP-not-ASP nil)
(setq mode-name "HTML/ASP helper")
(setq major-mode 'asp-cfml-helper-mode))
(t (error "Visual basic mode required for ASP"))))
(defun cfml-helper-install-type (type)
"Install a new tag type: add it to the keymap, menu structures, etc.
For this to work, the type must first have been added to the list of types
with cfml-helper-add-type-to-alist."
(setq cfml-helper-installed-types (cons type cfml-helper-installed-types))
(let ((keymap (cfml-helper-keymap-for type))
(key (cfml-helper-key-for type))
(menu (cfml-helper-menu-for type))
(menu-string (cfml-helper-menu-string-for type)))
(and key
(progn
(set keymap nil)
(define-prefix-command keymap)
(if cfml-helper-emacs18
(progn
(set keymap (make-sparse-keymap))
(define-key cfml-helper-mode-map key (eval keymap)))
(define-key cfml-helper-mode-map key keymap))))
(and menu
(progn
(set menu nil)))))
;; install the default types.
(mapcar 'cfml-helper-install-type cfml-helper-types-to-install)
;; special mode keys
(mapcar
(function (lambda (l) (define-key cfml-helper-mode-map (car l) (nth 1 l))))
'(("\M-\C-f" tempo-forward-mark)
("\M-\C-b" tempo-backward-mark)
("\M-\t" tempo-complete-tag)))
;; Extra commands that HTML helper supports that aren't insertions
(defvar cfml-helper-mode-functions-map nil
"Keymap for extra HTML mode functions")
(define-prefix-command 'cfml-helper-mode-functions-map)
(define-key cfml-helper-mode-map "\C-c\C-z"
'cfml-helper-mode-functions-map)
(define-key cfml-helper-mode-functions-map "t"
'cfml-helper-insert-timestamp-delimiter-at-point)
(define-key cfml-helper-mode-functions-map "a"
'html-script-narrow-to-asp)
(define-key cfml-helper-mode-functions-map "p"
'html-script-narrow-to-php)
(define-key cfml-helper-mode-functions-map "b"
'html-script-narrow-to-vbscript)
(define-key cfml-helper-mode-functions-map "j"
'html-script-narrow-to-javascript)
;; indentation keys - only rebind these if the user wants indentation
(if cfml-helper-never-indent
()
(define-key cfml-helper-mode-map "\t" 'cfml-helper-indent-command)
(define-key cfml-helper-mode-map "\C-m" 'newline-and-indent))
;; browse url stuff
(if (fboundp 'browse-url-of-file)
(define-key cfml-helper-mode-functions-map "v" 'browse-url-of-file))
;; Fri Jan 12 18:30:32 2001 Saint
;;
;; Jack Vinson supplies this code to handle the case when
;; browse-url-browser-function is a list and not a function (it can be
;; a list, says its documentation)
;;
;; Replacing :
;; (if (and (boundp 'browse-url-browser-function)
;; (fboundp browse-url-browser-function))
;; (define-key cfml-helper-mode-functions-map "u"
;; browse-url-browser-function))
(if (boundp 'browse-url-browser-function)
(let ((bf browse-url-browser-function)
re)
(while (consp bf)
(setq re (car (car bf))
bf (if (string-match re "http")
(cdr (car bf)) ; The function
(cdr bf)))) ; More pairs
(or bf (error "No browser in browse-url-browser-function for general URL's"))
(fboundp bf)
(define-key cfml-helper-mode-functions-map "u" bf)
))
;;}}}
;;{{{ cfml-helper-add-tag function for building basic tags
(defvar cfml-helper-tempo-tags nil
"List of tags used in completion.")
;; this while loop is awfully Cish
;; isn't there an emacs lisp function to do this?
(defun cfml-helper-string-to-symbol (input-string)
"Given a string, downcase it and replace spaces with -.
We use this to turn menu entries into good symbols for functions.
It's not entirely successful, but fortunately emacs lisp is forgiving."
(let* ((s (copy-sequence input-string))
(l (1- (length s))))
(while (> l 0)
(if (char-equal (aref s l) ?\ )
(aset s l ?\-))
(setq l (1- l)))
(concat "html-" (downcase s))))
(defun cfml-helper-add-tag (l)
"Add a new tag to cfml-helper-mode.
Builds a tempo-template for the tag and puts it into the
appropriate keymap if a key is requested. Format:
`(cfml-helper-add-tag '(type keybinding completion-tag menu-name template doc)'"
(let* ((type (car l))
(keymap (cfml-helper-keymap-for type))
(menu (cfml-helper-menu-for type))
(key (nth 1 l))
(completer (nth 2 l))
(name (nth 3 l))
(tag (nth 4 l))
(doc (nth 5 l))
(command (if (string-equal completer "function")
(nth 4 l)
(tempo-define-template (cfml-helper-string-to-symbol name)
tag completer doc
'cfml-helper-tempo-tags))))
(if (null (memq type cfml-helper-installed-types)) ;type loaded?
t ;no, do nothing.
(if (stringp key) ;bind key somewhere?
(if keymap ;special keymap?
(define-key (eval keymap) key command) ;t: bind to prefix
(define-key cfml-helper-mode-map key command));nil: bind to global
t)
(if menu ;is there a menu?
(set menu ;good, cons it in
(cons (vector name command t) (eval menu))))
)))
;; for backwards compatability
(fset 'cfml-helper-add-cookie 'cfml-helper-add-tag)
;;}}}
;;{{{ most of the HTML tags
(defun cfml-helper-insert-or-wipe (string)
"Propmts for the value of an optional attribute named STRING and
inserts it in the current buffer. Inserts nothing if the users replies
with a null string."
(cond ((and (stringp string)
tempo-interactive)
(let ((val (read-from-minibuffer (concat string " :"))))
(cond ((> (string-width val) 0)
(insert-string (concat " " string "=\"" val "\"" )))
)))
;; just to tell that there's something weird in the calling
;; code... But behaves like a no op if tempo-interactive is
;; nil
(tempo-interactive
(error (concat "Wrong type argument: stringp, " string)))
;; Wed Mar 28 10:06:24 2001 Saint
;;
;; To insert empty attributes if
;; cfml-helper-mode-insert-attributes-always is non nil
((and (stringp string)
cfml-helper-mode-insert-attributes-always)
(insert-string (concat " " string "=\"\"" )))
))
;; These tags are an attempt to be HTML/2.0 compliant, with the exception
;; of container