summaryrefslogtreecommitdiff
path: root/lisp/emacs-lisp/lisp-mode.el
diff options
context:
space:
mode:
authorJoão Távora <joaotavora@gmail.com>2020-04-19 21:15:48 +0100
committerJoão Távora <joaotavora@gmail.com>2020-04-19 21:15:48 +0100
commite95703c2db48d5f5ce465e2cf2b9a3165f8ecb2b (patch)
treeff8ca05ee56abf38f8c84eb3635f7698a15313ba /lisp/emacs-lisp/lisp-mode.el
parentda59c5e579f08297a873d453ae42b168cce021b2 (diff)
downloademacs-e95703c2db48d5f5ce465e2cf2b9a3165f8ecb2b.tar.gz
Don't mess with lisp-mode-variables
* doc/lispref/modes.texi (Example Major Modes): Update example to match reality. * lisp/chistory.el (command-history-mode): Revert previous change. * lisp/help-fns.el (describe-variable): Revert previous change. * lisp/emacs-lisp/lisp-mode.el (lisp-mode-variables): Rvert previous change. (lisp-data-mode): Use full form of lisp-mode-variables for clarity. (lisp-mode): Simplify. * lisp/emacs-lisp/pp.el (pp-to-string): Revert previous change. * lisp/progmodes/elisp-mode.el (emacs-lisp-mode): Case sensitive font-lock keywords. * lisp/progmodes/inf-lisp.el (inferior-lisp-mode): Revert previous change.
Diffstat (limited to 'lisp/emacs-lisp/lisp-mode.el')
-rw-r--r--lisp/emacs-lisp/lisp-mode.el36
1 files changed, 22 insertions, 14 deletions
diff --git a/lisp/emacs-lisp/lisp-mode.el b/lisp/emacs-lisp/lisp-mode.el
index 13263f2fb50..30cf7d72c3e 100644
--- a/lisp/emacs-lisp/lisp-mode.el
+++ b/lisp/emacs-lisp/lisp-mode.el
@@ -611,10 +611,17 @@ Value for `adaptive-fill-function'."
;; a single docstring. Let's fix it here.
(if (looking-at "\\s-+\"[^\n\"]+\"\\s-*$") ""))
-(defun lisp-mode-variables (&rest ignored)
+;; Maybe this should be discouraged/obsoleted and users should be
+;; encouraged to use `lisp-data-mode` instead.
+(defun lisp-mode-variables (&optional lisp-syntax keywords-case-insensitive
+ elisp)
"Common initialization routine for lisp modes.
-Any number of parameters is accepted and ignored."
- (set-syntax-table lisp-mode-syntax-table)
+The LISP-SYNTAX argument is used by code in inf-lisp.el and is
+\(uselessly) passed from pp.el, chistory.el, gnus-kill.el and
+score-mode.el. KEYWORDS-CASE-INSENSITIVE non-nil means that for
+font-lock keywords will not be case sensitive."
+ (when lisp-syntax
+ (set-syntax-table lisp-mode-syntax-table))
(setq-local paragraph-ignore-fill-prefix t)
(setq-local fill-paragraph-function 'lisp-fill-paragraph)
(setq-local adaptive-fill-function #'lisp-adaptive-fill)
@@ -638,11 +645,17 @@ Any number of parameters is accepted and ignored."
(setq-local multibyte-syntax-as-symbol t)
;; (setq-local syntax-begin-function 'beginning-of-defun) ;;Bug#16247.
(setq font-lock-defaults
- (list nil nil nil nil nil
- '(font-lock-mark-block-function . mark-defun)
- '(font-lock-extra-managed-props help-echo)
- '(font-lock-syntactic-face-function
- . lisp-font-lock-syntactic-face-function)))
+ `(,(if elisp '(lisp-el-font-lock-keywords
+ lisp-el-font-lock-keywords-1
+ lisp-el-font-lock-keywords-2)
+ '(lisp-cl-font-lock-keywords
+ lisp-cl-font-lock-keywords-1
+ lisp-cl-font-lock-keywords-2))
+ nil ,keywords-case-insensitive nil nil
+ (font-lock-mark-block-function . mark-defun)
+ (font-lock-extra-managed-props help-echo)
+ (font-lock-syntactic-face-function
+ . lisp-font-lock-syntactic-face-function)))
(setq-local prettify-symbols-alist lisp-prettify-symbols-alist)
(setq-local electric-pair-skip-whitespace 'chomp)
(setq-local electric-pair-open-newline-between-pairs nil))
@@ -651,7 +664,7 @@ Any number of parameters is accepted and ignored."
(define-derived-mode lisp-data-mode prog-mode "Lisp-Data"
"Major mode for buffers holding data written in Lisp syntax."
:group 'lisp
- (lisp-mode-variables)
+ (lisp-mode-variables t t nil)
(setq-local electric-quote-string t)
(setq imenu-case-fold-search nil))
@@ -743,11 +756,6 @@ Blank lines separate paragraphs. Semicolons start comments.
\\{lisp-mode-map}
Note that `run-lisp' may be used either to start an inferior Lisp job
or to switch back to an existing one."
- (setf
- (nth 0 font-lock-defaults) '(lisp-cl-font-lock-keywords
- lisp-cl-font-lock-keywords-1
- lisp-cl-font-lock-keywords-2)
- (nth 2 font-lock-defaults) t)
(setq-local lisp-indent-function 'common-lisp-indent-function)
(setq-local find-tag-default-function 'lisp-find-tag-default)
(setq-local comment-start-skip