From e3721db120f8d2317efea6c7ccda2ca8db211c3e Mon Sep 17 00:00:00 2001 From: Stefan Monnier Date: Mon, 17 Apr 2000 11:45:39 +0000 Subject: [PATCH] (texinfo-mode-syntax-table): Add \n as comment-end. (texinfo-font-lock-syntactic-keywords): New var. (texinfo-font-lock-keywords): Remove comment regexp. (texinfo-insert-block): New function. (texinfo-mode-map): Add C-c C-o -> texinfo-insert-block. (texinfo-mode): Use define-derived-mode. Tweak comment-start-skip and font-lock-defaults. Use regexp-opt for outline-regexp. (texinfo-environments): New var. (texinfo-environment-regexp): Use regexp-opt and texinfo-environments. --- lisp/ChangeLog | 29 ++++++++ lisp/textmodes/texinfo.el | 145 ++++++++++++++++++++++---------------- 2 files changed, 112 insertions(+), 62 deletions(-) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index ef216574bfc..94c39233232 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,32 @@ +2000-04-17 Stefan Monnier + + * textmodes/texinfo.el (texinfo-mode-syntax-table): Add \n as comment-end. + (texinfo-font-lock-syntactic-keywords): New var. + (texinfo-font-lock-keywords): Remove comment regexp. + (texinfo-insert-block): New function. + (texinfo-mode-map): Add C-c C-o -> texinfo-insert-block. + (texinfo-mode): Use define-derived-mode. + Tweak comment-start-skip and font-lock-defaults. + Use regexp-opt for outline-regexp. + (texinfo-environments): New var. + (texinfo-environment-regexp): Use regexp-opt and texinfo-environments. + + * textmodes/ispell.el (ispell-menu-map-needed): Check that ispell-process + is bound since this might be eval'd before ispell is loaded. + (ispell-message): Use a tiny bit less magic and a bit more hard data + to figure out what kind of sc-cite-regexp to use. + + * emacs-lisp/regexp-opt.el (regexp-opt-depth): Fix the regexp. + + * calendar/diary-lib.el (fancy-diary-display, mark-diary-entries) + (insert-cyclic-diary-entry): Unquote the lambda. + + * gud.el (gud-jdb-build-source-files-list): Fix typo. + + * files.el (backup-enable-predicate): Unquote the lambda. + + * cus-edit.el (custom-face, face): Unquote the lambda. + 2000-04-15 Vinicius Jose Latorre * ps-print.el: Check for line-beginning-position definition. diff --git a/lisp/textmodes/texinfo.el b/lisp/textmodes/texinfo.el index e4c53619c75..bf1a523ec0e 100644 --- a/lisp/textmodes/texinfo.el +++ b/lisp/textmodes/texinfo.el @@ -258,6 +258,7 @@ chapter." (modify-syntax-entry ?\] ")[" texinfo-mode-syntax-table) (modify-syntax-entry ?{ "(}" texinfo-mode-syntax-table) (modify-syntax-entry ?} "){" texinfo-mode-syntax-table) + (modify-syntax-entry ?\n ">" texinfo-mode-syntax-table) (modify-syntax-entry ?\' "w" texinfo-mode-syntax-table)) ;; Written by Wolfgang Bangerth @@ -269,10 +270,13 @@ chapter." "Imenu generic expression for TexInfo mode. See `imenu-generic-expression'.") +(defvar texinfo-font-lock-syntactic-keywords + '(("\\(@\\)c\\(omment\\)?\\>" (1 '(11)))) + "Syntactic keywords to catch comment delimiters in `texinfo-mode'.") + (defvar texinfo-font-lock-keywords - '(;; All but the first 2 had an OVERRIDE of t. + '(;; All but the first had an OVERRIDE of t. ;; It didn't seem to be any better, and it's slower--simon. - ("^\\(@c\\|@comment\\)\\>.*" . font-lock-comment-face) ;comments ;; Robert J. Chassell says remove this line. ;;("\\$\\([^$]*\\)\\$" 1 font-lock-string-face t) ("@\\([a-zA-Z]+\\|[^ \t\n]\\)" 1 font-lock-keyword-face) ;commands @@ -350,6 +354,10 @@ chapter." ;; bindings for `texnfo-tex.el' (texinfo-define-common-keys texinfo-mode-map) + ;; Bindings from `tex-mode.el' + ;; This should still use " when inside @example and @code + ;;(define-key texinfo-mode-map "\"" 'tex-insert-quote) + ;; bindings for `makeinfo.el' (define-key texinfo-mode-map "\C-c\C-m\C-k" 'kill-compilation) (define-key texinfo-mode-map "\C-c\C-m\C-l" @@ -377,7 +385,7 @@ chapter." (define-key texinfo-mode-map "\C-c{" 'texinfo-insert-braces) ;; bindings for inserting strings - + (define-key texinfo-mode-map "\C-c\C-o" 'texinfo-insert-block) (define-key texinfo-mode-map "\C-c\C-c\C-d" 'texinfo-start-menu-description) (define-key texinfo-mode-map "\C-c\C-cv" 'texinfo-insert-@var) @@ -396,13 +404,15 @@ chapter." ;;; Texinfo mode +;; Also defined in texnfo-upd.el but copied here to avoid having +;; to require texnfo-upd.el. (defvar texinfo-chapter-level-regexp "chapter\\|unnumbered \\|appendix \\|majorheading\\|chapheading" "Regular expression matching Texinfo chapter-level headings. This does not match `@node' and does not match the `@top' command.") ;;;###autoload -(defun texinfo-mode () +(define-derived-mode texinfo-mode text-mode "Texinfo" "Major mode for editing Texinfo files. It has these extra commands: @@ -466,14 +476,8 @@ Top node, is accompanied by some kind of section line, such as an If the file has a `top' node, it must be called `top' or `Top' and be the first node in the file. -Entering Texinfo mode calls the value of text-mode-hook, and then the -value of texinfo-mode-hook." - (interactive) - (text-mode) - (setq mode-name "Texinfo") - (setq major-mode 'texinfo-mode) - (use-local-map texinfo-mode-map) - (set-syntax-table texinfo-mode-syntax-table) +Entering Texinfo mode calls the value of `text-mode-hook', and then the +value of `texinfo-mode-hook'." (make-local-variable 'page-delimiter) (setq page-delimiter (concat @@ -496,19 +500,21 @@ value of texinfo-mode-hook." (make-local-variable 'comment-start) (setq comment-start "@c ") (make-local-variable 'comment-start-skip) - (setq comment-start-skip "@c +") + (setq comment-start-skip "@c +\\|@comment +") (make-local-variable 'words-include-escapes) (setq words-include-escapes t) (make-local-variable 'imenu-generic-expression) (setq imenu-generic-expression texinfo-imenu-generic-expression) (setq imenu-case-fold-search nil) (make-local-variable 'font-lock-defaults) - (setq font-lock-defaults '(texinfo-font-lock-keywords t)) + (setq font-lock-defaults + '(texinfo-font-lock-keywords nil nil nil nil + (font-lock-syntactic-keywords + . texinfo-font-lock-syntactic-keywords))) + (set (make-local-variable 'parse-sexp-lookup-properties) t) (make-local-variable 'outline-regexp) (setq outline-regexp - (concat "@\\(" - (mapconcat 'car texinfo-section-list "\\>\\|") - "\\>\\)")) + (concat "@" (regexp-opt (mapcar 'car texinfo-section-list) t) "\\>")) (make-local-variable 'outline-level) (setq outline-level 'texinfo-outline-level) (make-local-variable 'tex-start-of-header) @@ -518,59 +524,74 @@ value of texinfo-mode-hook." (make-local-variable 'tex-first-line-header-regexp) (setq tex-first-line-header-regexp "^\\\\input") (make-local-variable 'tex-trailer) - (setq tex-trailer "@bye\n") - (run-hooks 'text-mode-hook 'texinfo-mode-hook)) + (setq tex-trailer "@bye\n")) ;;; Insert string commands -;; Keep as concatinated lists for ease of maintenance +(defconst texinfo-environments + '("cartouche" + "defcv" + "deffn" + "defivar" + "defmac" + "defmethod" + "defop" + "defopt" + "defspec" + "deftp" + "deftypefn" + "deftypefun" + "deftypevar" + "deftypevr" + "defun" + "defvar" + "defvr" + "description" + "display" + "enumerate" + "example" + "flushleft" + "flushright" + "format" + "ftable" + "group" + "ifclear" + "ifset" + "ifhtml" + "ifinfo" + "ifnothtml" + "ifnotinfo" + "ifnottex" + "iftex" + "ignore" + "itemize" + "lisp" + "macro" + "multitable" + "quotation" + "smalldisplay" + "smallexample" + "smallformat" + "smalllisp" + "table" + "tex" + "titlepage" + "vtable") + "List of TeXinfo environments.") + +;; Keep as concatenated lists for ease of maintenance (defconst texinfo-environment-regexp - (concat - "^@\\(" - (mapconcat 'identity - '("cartouche" - "display" - "end" - "enumerate" - "example" - "deffn" - "defun" - "defmac" - "defspec" - "defva?r" - "defopt" - "deftypefu?n" - "deftypeva?r" - "defcv" - "defivar" - "defop" - "defmethod" - "deftp" - "f?table" - "flushleft" - "flushright" - "format" - "group" - "ifhtml" - "ifinfo" - "iftex" - "ignore" - "itemize" - "lisp" - "macro" - "multitable" - "quotation" - "smalldisplay" - "smallexample" - "smallformat" - "smalllisp" - "tex") - "\\|") - "\\)") + (concat "^@" (regexp-opt (cons "end" texinfo-environments) t) "\\>") "Regexp for environment-like TexInfo list commands. Subexpression 1 is what goes into the corresponding `@end' statement.") +(define-skeleton texinfo-insert-block + "Create a matching pair @ .. @end at point. +Puts point on a blank line between them." + (completing-read "Block name: " (mapcar 'list texinfo-environments)) + "@" str \n _ \n "@end " str \n) + ;; The following texinfo-insert-@end command not only inserts a SPC ;; after the @end, but tries to find out what belongs there. It is ;; not very smart: it does not understand nested lists.