mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2024-12-27 10:54:40 +00:00
Functionality for font-lock-beginning-of-syntax-function to be used by font-lock-fontify-region when calculating the cache state. Also wrap value of buffer-file-truename to guard against clash detection. Also add scheme-font-lock-keywords.
This commit is contained in:
parent
4a789a5143
commit
d46c21ecae
@ -82,13 +82,10 @@
|
||||
(defvar font-lock-reference-face 'font-lock-reference-face
|
||||
"Face to use for references.")
|
||||
|
||||
(defvar font-lock-no-comments nil
|
||||
"Non-nil means Font Lock should not fontify comments or strings.")
|
||||
|
||||
(make-variable-buffer-local 'font-lock-keywords)
|
||||
(defvar font-lock-keywords nil
|
||||
"*The keywords to highlight.
|
||||
Elements should be of the form:
|
||||
"*A list of the keywords to highlight.
|
||||
Each element should be of the form:
|
||||
|
||||
MATCHER
|
||||
(MATCHER . MATCH)
|
||||
@ -119,60 +116,100 @@ the wrong pattern can dramatically slow things down!")
|
||||
The value should look like the `cdr' of an item in `font-lock-defaults-alist'.")
|
||||
|
||||
(defvar font-lock-defaults-alist
|
||||
(let ((tex-mode-defaults '(tex-font-lock-keywords nil nil ((?$ . "\""))))
|
||||
(let (
|
||||
;; For C and Lisp modes we use `beginning-of-defun', rather than nil,
|
||||
;; for SYNTAX-BEGIN. Thus the calculation of the cache is faster but
|
||||
;; not infallible, so we risk mis-fontification. --sm
|
||||
(c-mode-defaults
|
||||
'((c-font-lock-keywords c-font-lock-keywords-1 c-font-lock-keywords-2)
|
||||
nil nil ((?_ . "w"))))
|
||||
nil nil ((?\_ . "w")) beginning-of-defun))
|
||||
(c++-mode-defaults
|
||||
'((c++-font-lock-keywords c++-font-lock-keywords-1
|
||||
c++-font-lock-keywords-2)
|
||||
nil nil ((?_ . "w"))))
|
||||
nil nil ((?\_ . "w")) beginning-of-defun))
|
||||
(lisp-mode-defaults
|
||||
'((lisp-font-lock-keywords lisp-font-lock-keywords-1
|
||||
lisp-font-lock-keywords-2)
|
||||
nil nil ((?: . "w") (?- . "w") (?* . "w")))))
|
||||
nil nil ((?\: . "w") (?\- . "w") (?\* . "w"))
|
||||
beginning-of-defun))
|
||||
(scheme-mode-defaults
|
||||
'(scheme-font-lock-keywords
|
||||
nil nil ((?\: . "w") (?\- . "w") (?\* . "w") (?\/ . "w"))
|
||||
beginning-of-defun))
|
||||
;; For TeX modes we could use `backward-paragraph' for the same reason.
|
||||
(tex-mode-defaults '(tex-font-lock-keywords nil nil ((?\$ . "\""))))
|
||||
)
|
||||
(list
|
||||
(cons 'bibtex-mode tex-mode-defaults)
|
||||
(cons 'c++-c-mode c-mode-defaults)
|
||||
(cons 'c++-mode c++-mode-defaults)
|
||||
(cons 'c-mode c-mode-defaults)
|
||||
(cons 'emacs-lisp-mode lisp-mode-defaults)
|
||||
(cons 'latex-mode tex-mode-defaults)
|
||||
(cons 'lisp-mode lisp-mode-defaults)
|
||||
(cons 'plain-tex-mode tex-mode-defaults)
|
||||
(cons 'scheme-mode lisp-mode-defaults)
|
||||
(cons 'slitex-mode tex-mode-defaults)
|
||||
(cons 'tex-mode tex-mode-defaults)))
|
||||
(cons 'bibtex-mode tex-mode-defaults)
|
||||
(cons 'c++-c-mode c-mode-defaults)
|
||||
(cons 'c++-mode c++-mode-defaults)
|
||||
(cons 'c-mode c-mode-defaults)
|
||||
(cons 'emacs-lisp-mode lisp-mode-defaults)
|
||||
(cons 'inferior-scheme-mode scheme-mode-defaults)
|
||||
(cons 'latex-mode tex-mode-defaults)
|
||||
(cons 'lisp-mode lisp-mode-defaults)
|
||||
(cons 'lisp-interaction-mode lisp-mode-defaults)
|
||||
(cons 'plain-tex-mode tex-mode-defaults)
|
||||
(cons 'scheme-mode scheme-mode-defaults)
|
||||
(cons 'scheme-interaction-mode scheme-mode-defaults)
|
||||
(cons 'slitex-mode tex-mode-defaults)
|
||||
(cons 'tex-mode tex-mode-defaults)))
|
||||
"*Alist of default major mode and Font Lock defaults.
|
||||
Each item should be a list of the form:
|
||||
(MAJOR-MODE . (FONT-LOCK-KEYWORDS KEYWORDS-ONLY CASE-FOLD FONT-LOCK-SYNTAX))
|
||||
where MAJOR-MODE is a symbol, and FONT-LOCK-KEYWORDS may be a symbol or a list
|
||||
of symbols. If KEYWORDS-ONLY is non-nil, syntactic fontification (strings and
|
||||
|
||||
(MAJOR-MODE . (KEYWORDS KEYWORDS-ONLY CASE-FOLD SYNTAX-ALIST SYNTAX-BEGIN))
|
||||
|
||||
where MAJOR-MODE is a symbol, and KEYWORDS may be a symbol or a list of
|
||||
symbols. If KEYWORDS-ONLY is non-nil, syntactic fontification (strings and
|
||||
comments) is not performed. If CASE-FOLD is non-nil, the case of the keywords
|
||||
is ignored when fontifying. FONT-LOCK-SYNTAX should be a list of cons pairs of
|
||||
the form (CHAR . STRING), it is used to set the local Font Lock syntax table
|
||||
for keyword fontification.")
|
||||
is ignored when fontifying. If SYNTAX-ALIST is non-nil, it should be a list of
|
||||
cons pairs of the form (CHAR . STRING) used to set the local Font Lock syntax
|
||||
table for keyword and syntactic fontification. (See `modify-syntax-entry'.)
|
||||
|
||||
SYNTAX-BEGIN should be a function, it is called with no args to move outside of
|
||||
a syntactic block for syntactic fontification. Typical values are nil
|
||||
\(equivalent to `beginning-of-buffer'), `beginning-of-line' (i.e., the start of
|
||||
the line is known to be outside a syntactic block), or `beginning-of-defun' for
|
||||
programming modes or `backward-paragraph' for textual modes (i.e., the
|
||||
mode-dependent function is known to move outside a syntactic block).
|
||||
|
||||
These item elements are used by Font Lock mode to set the variables
|
||||
`font-lock-keywords', `font-lock-no-comments',
|
||||
`font-lock-keywords-case-fold-search', `font-lock-syntax-table' and
|
||||
`font-lock-beginning-of-syntax-function', respectively.")
|
||||
|
||||
(defvar font-lock-no-comments nil
|
||||
"*Non-nil means Font Lock should not fontify comments or strings.
|
||||
This is normally set via `font-lock-defaults'.")
|
||||
|
||||
(defvar font-lock-keywords-case-fold-search nil
|
||||
"*Non-nil means the patterns in `font-lock-keywords' are case-insensitive.")
|
||||
"*Non-nil means the patterns in `font-lock-keywords' are case-insensitive.
|
||||
This is normally set via `font-lock-defaults'.")
|
||||
|
||||
(defvar font-lock-syntax-table nil
|
||||
"Non-nil means use this syntax table for fontifying.
|
||||
If this is nil, the major mode's syntax table is used.")
|
||||
If this is nil, the major mode's syntax table is used.
|
||||
This is normally set via `font-lock-defaults'.")
|
||||
|
||||
(defvar font-lock-beginning-of-syntax-function nil
|
||||
"*Non-nil means use this function to move outside of a syntactic block.
|
||||
If this is nil, `beginning-of-buffer' is used.
|
||||
This is normally set via `font-lock-defaults'.")
|
||||
|
||||
(defvar font-lock-verbose t
|
||||
"*Non-nil means `font-lock-fontify-buffer' should print status messages.")
|
||||
|
||||
;;;###autoload
|
||||
(defvar font-lock-maximum-decoration nil
|
||||
"Non-nil means use the maximum decoration for fontifying.
|
||||
"*If non-nil, the maximum decoration for fontifying.
|
||||
If nil, use the default decoration (typically the minimum available).
|
||||
If t, use the maximum decoration available.
|
||||
If a number, use that level of decoration (or if not available the maximum).")
|
||||
|
||||
;;;###autoload
|
||||
(defvar font-lock-maximum-size
|
||||
(if font-lock-maximum-decoration (* 150 1024) (* 300 1024))
|
||||
"*If non-nil, the maximum size for buffers.
|
||||
"*If non-nil, the maximum size for buffers for fontifying.
|
||||
Only buffers less than this can be fontified when Font Lock mode is turned on.
|
||||
If nil, means size is irrelevant.")
|
||||
|
||||
@ -305,14 +342,21 @@ See `font-lock-make-face' and `list-faces-display'."
|
||||
(font-lock-type-face "PaleGreen")
|
||||
(font-lock-reference-face "Aquamarine")))))))
|
||||
;; Now make the faces if we have to.
|
||||
(mapcar (function (lambda (face-attributes)
|
||||
(mapcar (function
|
||||
(lambda (face-attributes)
|
||||
(let ((face (nth 0 face-attributes)))
|
||||
(if override
|
||||
(font-lock-make-face face-attributes)
|
||||
(if (not (and (boundp face) (facep (symbol-value face))))
|
||||
(if (facep face)
|
||||
(set face face)
|
||||
(font-lock-make-face face-attributes)))))))
|
||||
(cond (override
|
||||
;; We can stomp all over it anyway. Get outta my face!
|
||||
(font-lock-make-face face-attributes))
|
||||
((and (boundp face) (facep (symbol-value face)))
|
||||
;; The variable exists and is already bound to a face.
|
||||
nil)
|
||||
((facep face)
|
||||
;; We already have a face so we bind the variable to it.
|
||||
(set face face))
|
||||
(t
|
||||
;; No variable or no face.
|
||||
(font-lock-make-face face-attributes))))))
|
||||
font-lock-face-attributes))
|
||||
|
||||
(defun font-lock-make-face (face-attributes)
|
||||
@ -366,7 +410,8 @@ the face is also set; its value is the face name."
|
||||
(goto-char start)
|
||||
(beginning-of-line)
|
||||
(if loudly (message "Fontifying %s... (syntactically...)" (buffer-name)))
|
||||
(let ((inhibit-read-only t) (buffer-undo-list t) (buffer-file-name)
|
||||
(let ((inhibit-read-only t) (buffer-undo-list t)
|
||||
buffer-file-name buffer-file-truename
|
||||
(modified (buffer-modified-p))
|
||||
(old-syntax (syntax-table))
|
||||
(synstart (if comment-start-skip
|
||||
@ -379,20 +424,36 @@ the face is also set; its value is the face name."
|
||||
state prev prevstate)
|
||||
(unwind-protect
|
||||
(progn
|
||||
;;
|
||||
;; Use the fontification syntax table, if any.
|
||||
(if font-lock-syntax-table
|
||||
(set-syntax-table font-lock-syntax-table))
|
||||
;; Find the state at the line-beginning before START.
|
||||
;;
|
||||
;; Find the state at the `beginning-of-line' before `start'.
|
||||
(if (eq startline font-lock-cache-position)
|
||||
;; Use the cache for the state of `startline'.
|
||||
(setq state font-lock-cache-state)
|
||||
;; Find outermost containing sexp.
|
||||
(beginning-of-defun)
|
||||
;; Find the state at STARTLINE.
|
||||
(while (< (point) startline)
|
||||
(setq state (parse-partial-sexp (point) startline 0)))
|
||||
;; Find the state of `startline'.
|
||||
(if (null font-lock-beginning-of-syntax-function)
|
||||
;; Use the state at the previous cache position, if any, or
|
||||
;; otherwise calculate from `point-min'.
|
||||
(if (or (null font-lock-cache-position)
|
||||
(< startline font-lock-cache-position))
|
||||
(setq state (parse-partial-sexp
|
||||
(point-min) startline))
|
||||
(setq state (parse-partial-sexp
|
||||
font-lock-cache-position startline
|
||||
nil nil font-lock-cache-state)))
|
||||
;; Call the function to move outside any syntactic block.
|
||||
(funcall font-lock-beginning-of-syntax-function)
|
||||
(setq state (parse-partial-sexp (point) startline)))
|
||||
;; Cache the state and position of `startline'.
|
||||
(setq font-lock-cache-state state
|
||||
font-lock-cache-position (point)))
|
||||
;; Now find the state precisely at START.
|
||||
(setq state (parse-partial-sexp (point) start nil nil state))
|
||||
font-lock-cache-position startline))
|
||||
;;
|
||||
;; Now find the state at `start' based on that of `startline'.
|
||||
(setq state (parse-partial-sexp startline start nil nil state))
|
||||
;;
|
||||
;; If the region starts inside a string, show the extent of it.
|
||||
(if (nth 3 state)
|
||||
(let ((beg (point)))
|
||||
@ -402,6 +463,7 @@ the face is also set; its value is the face name."
|
||||
(put-text-property beg (point) 'face font-lock-string-face)
|
||||
(setq state (parse-partial-sexp beg (point)
|
||||
nil nil state))))
|
||||
;;
|
||||
;; Likewise for a comment.
|
||||
(if (or (nth 4 state) (nth 7 state))
|
||||
(let ((beg (point)))
|
||||
@ -419,7 +481,8 @@ the face is also set; its value is the face name."
|
||||
font-lock-comment-face)
|
||||
(setq state (parse-partial-sexp beg (point)
|
||||
nil nil state))))
|
||||
;; Find each interesting place between here and END.
|
||||
;;
|
||||
;; Find each interesting place between here and `end'.
|
||||
(while (and (< (point) end)
|
||||
(setq prev (point) prevstate state)
|
||||
(re-search-forward synstart end t)
|
||||
@ -432,6 +495,7 @@ the face is also set; its value is the face name."
|
||||
nil nil state))))
|
||||
(let ((here (point)))
|
||||
(if (or (nth 4 state) (nth 7 state))
|
||||
;;
|
||||
;; We found a real comment start.
|
||||
(let ((beg (match-beginning 0)))
|
||||
(goto-char beg)
|
||||
@ -449,6 +513,8 @@ the face is also set; its value is the face name."
|
||||
(setq state (parse-partial-sexp here (point)
|
||||
nil nil state)))
|
||||
(if (nth 3 state)
|
||||
;;
|
||||
;; We found a real string start.
|
||||
(let ((beg (match-beginning 0)))
|
||||
(while (and (re-search-forward "\\s\"" end 'move)
|
||||
(nth 3 (parse-partial-sexp
|
||||
@ -457,20 +523,23 @@ the face is also set; its value is the face name."
|
||||
font-lock-string-face)
|
||||
(setq state (parse-partial-sexp here (point)
|
||||
nil nil state))))))
|
||||
;; Make sure PREV is non-nil after the loop
|
||||
;;
|
||||
;; Make sure `prev' is non-nil after the loop
|
||||
;; only if it was set on the very last iteration.
|
||||
(setq prev nil)))
|
||||
;;
|
||||
;; Clean up.
|
||||
(set-syntax-table old-syntax)
|
||||
(and prev
|
||||
(remove-text-properties prev end '(face nil)))
|
||||
(and (buffer-modified-p)
|
||||
(not modified)
|
||||
(set-buffer-modified-p nil)))))))
|
||||
|
||||
|
||||
(defun font-lock-unfontify-region (beg end)
|
||||
(let ((modified (buffer-modified-p))
|
||||
(buffer-undo-list t) (inhibit-read-only t) (buffer-file-name))
|
||||
(buffer-undo-list t) (inhibit-read-only t)
|
||||
buffer-file-name buffer-file-truename)
|
||||
(remove-text-properties beg end '(face nil))
|
||||
(and (buffer-modified-p)
|
||||
(not modified)
|
||||
@ -562,12 +631,13 @@ the face is also set; its value is the face name."
|
||||
font-lock-keywords
|
||||
(font-lock-compile-keywords))))
|
||||
(count 0)
|
||||
(inhibit-read-only t) (buffer-undo-list t) (buffer-file-name)
|
||||
(inhibit-read-only t) (buffer-undo-list t)
|
||||
buffer-file-name buffer-file-truename
|
||||
(modified (buffer-modified-p))
|
||||
(old-syntax (syntax-table))
|
||||
(bufname (buffer-name)))
|
||||
(unwind-protect
|
||||
(let (keyword matcher highlights)
|
||||
(let (keyword matcher highlights lowdarks)
|
||||
(if loudly (message "Fontifying %s... (regexps...)" bufname))
|
||||
(if font-lock-syntax-table (set-syntax-table font-lock-syntax-table))
|
||||
(while keywords
|
||||
@ -577,7 +647,12 @@ the face is also set; its value is the face name."
|
||||
(while (if (stringp matcher)
|
||||
(re-search-forward matcher end t)
|
||||
(funcall matcher end))
|
||||
(mapcar 'font-lock-apply-highlight highlights))
|
||||
;; An explicit `while' loop is slightly faster than a `mapcar'.
|
||||
;(mapcar 'font-lock-apply-highlight highlights)
|
||||
(setq lowdarks highlights)
|
||||
(while lowdarks
|
||||
(font-lock-apply-highlight (car lowdarks))
|
||||
(setq lowdarks (cdr lowdarks))))
|
||||
(if loudly (message "Fontifying %s... (regexps...%s)" bufname
|
||||
(make-string (setq count (1+ count)) ?.)))))
|
||||
(set-syntax-table old-syntax)
|
||||
@ -717,23 +792,79 @@ size, you can use \\[font-lock-fontify-buffer]."
|
||||
(not modified)
|
||||
(set-buffer-modified-p nil))
|
||||
(font-lock-after-fontify-buffer)))
|
||||
|
||||
(defun font-lock-choose-keywords (keywords level)
|
||||
;; Return LEVELth element of KEYWORDS. A LEVEL of nil is equal to a
|
||||
;; LEVEL of 0, a LEVEL of t is equal to (1- (length KEYWORDS)).
|
||||
(cond ((symbolp keywords)
|
||||
keywords)
|
||||
((numberp level)
|
||||
(or (nth level keywords) (car (reverse keywords))))
|
||||
((eq level t)
|
||||
(car (reverse keywords)))
|
||||
(t
|
||||
(car keywords))))
|
||||
|
||||
(defun font-lock-set-defaults ()
|
||||
"Set fontification defaults appropriately for this mode.
|
||||
Sets `font-lock-keywords', `font-lock-no-comments', `font-lock-syntax-table'
|
||||
and `font-lock-keywords-case-fold-search' using `font-lock-defaults' (or, if
|
||||
nil, using `font-lock-defaults-alist') and `font-lock-maximum-decoration'."
|
||||
;; Set face defaults.
|
||||
(font-lock-make-faces)
|
||||
;; Set fontification defaults.
|
||||
(or font-lock-keywords
|
||||
(let ((defaults (or font-lock-defaults
|
||||
(cdr (assq major-mode font-lock-defaults-alist)))))
|
||||
;; Keywords?
|
||||
(setq font-lock-keywords
|
||||
(font-lock-compile-keywords
|
||||
(eval (font-lock-choose-keywords (nth 0 defaults)
|
||||
font-lock-maximum-decoration))))
|
||||
;; Syntactic?
|
||||
(if (nth 1 defaults)
|
||||
(set (make-local-variable 'font-lock-no-comments) t))
|
||||
;; Case fold?
|
||||
(if (nth 2 defaults)
|
||||
(set (make-local-variable 'font-lock-keywords-case-fold-search) t))
|
||||
;; Syntax table?
|
||||
(if (nth 3 defaults)
|
||||
(let ((slist (nth 3 defaults)))
|
||||
(set (make-local-variable 'font-lock-syntax-table)
|
||||
(copy-syntax-table (syntax-table)))
|
||||
(while slist
|
||||
(modify-syntax-entry (car (car slist)) (cdr (car slist))
|
||||
font-lock-syntax-table)
|
||||
(setq slist (cdr slist)))))
|
||||
;; Syntactic cache function?
|
||||
(if (nth 4 defaults)
|
||||
(set (make-local-variable 'font-lock-beginning-of-syntax-function)
|
||||
(nth 4 defaults))))))
|
||||
|
||||
;;; Various information shared by several modes.
|
||||
;;; Information specific to a single mode should go in its load library.
|
||||
|
||||
(defconst lisp-font-lock-keywords-1
|
||||
(list
|
||||
;; highlight defining forms. This doesn't work too nicely for
|
||||
;; (defun (setf foo) ...) but it does work for (defvar foo) which
|
||||
;; is more important.
|
||||
(list (concat "^(\\(def\\(const\\|ine-key\\(\\|-after\\)\\|var\\)\\)\\>"
|
||||
"[ \t']*\\([^ \t\n\(\)]+\\)?")
|
||||
'(1 font-lock-keyword-face) '(4 font-lock-variable-name-face nil t))
|
||||
(list (concat "^(\\(def[^ \t\n\(\)]+\\|eval-"
|
||||
"\\(a\\(fter-load\\|nd-compile\\)\\|when-compile\\)\\)\\>"
|
||||
"[ \t']*\\([^ \t\n\(\)]+\\)?")
|
||||
'(1 font-lock-keyword-face) '(4 font-lock-function-name-face nil t))
|
||||
)
|
||||
;; Everything not a variable or type declaration is fontified as a function.
|
||||
;; It would be cleaner to allow preceding whitespace, but it would also be
|
||||
;; about five times slower.
|
||||
(list (concat "^(\\(def\\("
|
||||
;; Variable declarations.
|
||||
"\\(const\\(\\|ant\\)\\|ine-key\\(\\|-after\\)\\|var\\)\\|"
|
||||
;; Structure declarations.
|
||||
"\\(class\\|struct\\|type\\)\\|"
|
||||
;; Everything else is a function declaration.
|
||||
"\\([^ \t\n\(\)]+\\)"
|
||||
"\\)\\)\\>"
|
||||
;; Any whitespace and declared object.
|
||||
"[ \t'\(]*"
|
||||
"\\([^ \t\n\)]+\\)?")
|
||||
'(1 font-lock-keyword-face)
|
||||
'(8 (cond ((match-beginning 3) font-lock-variable-name-face)
|
||||
((match-beginning 6) font-lock-type-face)
|
||||
(t font-lock-function-name-face))
|
||||
nil t)))
|
||||
"Subdued level highlighting Lisp modes.")
|
||||
|
||||
(defconst lisp-font-lock-keywords-2
|
||||
@ -742,19 +873,22 @@ size, you can use \\[font-lock-fontify-buffer]."
|
||||
(list
|
||||
;;
|
||||
;; Control structures. ELisp and CLisp combined.
|
||||
; ("cond" "if" "while" "let\\*?" "prog[nv12*]?" "catch" "throw"
|
||||
; "save-restriction" "save-excursion" "save-window-excursion"
|
||||
; "save-selected-window" "save-match-data" "unwind-protect"
|
||||
; "condition-case" "track-mouse"
|
||||
; "when" "unless" "do" "flet" "labels" "return" "return-from")
|
||||
; (make-regexp
|
||||
; '("cond" "if" "while" "let\\*?" "prog[nv12*]?" "catch" "throw"
|
||||
; "save-restriction" "save-excursion" "save-window-excursion"
|
||||
; "save-selected-window" "save-match-data" "unwind-protect"
|
||||
; "condition-case" "track-mouse"
|
||||
; "eval-after-load" "eval-and-compile" "eval-when-compile"
|
||||
; "when" "unless" "do" "flet" "labels" "return" "return-from"))
|
||||
(cons
|
||||
(concat
|
||||
"(\\("
|
||||
"c\\(atch\\|ond\\(\\|ition-case\\)\\)\\|do\\|flet\\|if\\|"
|
||||
"l\\(abels\\|et\\*?\\)\\|prog[nv12*]?\\|return\\(\\|-from\\)\\|"
|
||||
"save-\\(excursion\\|match-data\\|restriction\\|"
|
||||
"selected-window\\|window-excursion\\)\\|t\\(hrow\\|rack-mouse\\)\\|"
|
||||
"un\\(less\\|wind-protect\\)\\|wh\\(en\\|ile\\)"
|
||||
"\\(c\\(atch\\|ond\\(\\|ition-case\\)\\)\\|do\\|"
|
||||
"eval-\\(a\\(fter-load\\|nd-compile\\)\\|when-compile\\)\\|flet\\|"
|
||||
"if\\|l\\(abels\\|et\\*?\\)\\|prog[nv12*]?\\|return\\(\\|-from\\)\\|"
|
||||
"save-\\(excursion\\|match-data\\|restriction\\|selected-window\\|"
|
||||
"window-excursion\\)\\|t\\(hrow\\|rack-mouse\\)\\|"
|
||||
"un\\(less\\|wind-protect\\)\\|wh\\(en\\|ile\\)\\)"
|
||||
"\\)\\>") 1)
|
||||
;;
|
||||
;; Function names in emacs-lisp docstrings (in the syntax that
|
||||
@ -778,6 +912,32 @@ size, you can use \\[font-lock-fontify-buffer]."
|
||||
"Default expressions to highlight in Lisp modes.")
|
||||
|
||||
|
||||
(defvar scheme-font-lock-keywords
|
||||
(list
|
||||
;;
|
||||
;; Declarations.
|
||||
'("^[ \t]*(\\(define\\)\\>[ \t]*(?\\([^ \t\n\)]+\\)?"
|
||||
(1 font-lock-keyword-face) (2 font-lock-function-name-face nil t))
|
||||
;;
|
||||
;; Control structures.
|
||||
;(make-regexp '("begin" "call-with-current-continuation" "call/cc"
|
||||
; "call-with-input-file" "call-with-output-file" "case" "cond"
|
||||
; "define-syntax" "do" "else" "for-each" "if" "lambda"
|
||||
; "let-syntax" "let\\*?" "letrec" "letrec-syntax"
|
||||
; ;; Stefan Monnier <stefan.monnier@epfl.ch> says don't bother.
|
||||
; ;;"quasiquote" "quote" "unquote" "unquote-splicing"
|
||||
; "map" "syntax" "syntax-rules"))
|
||||
(cons
|
||||
(concat "(\\("
|
||||
"begin\\|c\\(a\\(ll\\(-with-\\(current-continuation\\|"
|
||||
"input-file\\|output-file\\)\\|/cc\\)\\|se\\)\\|ond\\)\\|"
|
||||
"d\\(efine-syntax\\|o\\)\\|else\\|for-each\\|if\\|"
|
||||
"l\\(ambda\\|et\\(-syntax\\|\\*?\\|rec\\(\\|-syntax\\)\\)\\)\\|"
|
||||
"map\\|syntax\\(\\|-rules\\)"
|
||||
"\\)\\>") 1))
|
||||
"Default expressions to highlight in Scheme modes.")
|
||||
|
||||
|
||||
(defconst c-font-lock-keywords-1 nil
|
||||
"Subdued level highlighting for C modes.")
|
||||
|
||||
@ -886,14 +1046,14 @@ size, you can use \\[font-lock-fontify-buffer]."
|
||||
(cons (concat "\\<\\(" c++-type-types "\\)\\>") 'font-lock-type-face)
|
||||
(list (concat "\\<\\(" c++-type-types "\\)[ \t*&]+"
|
||||
"\\(" ctoken "[ \t*&]+\\)*"
|
||||
"\\(" ctoken "\\)[ \t]*\\((\\)?")
|
||||
"\\(" ctoken "\\)[ \t<>=!+-]*\\((\\)?")
|
||||
14
|
||||
'(if (match-beginning 15)
|
||||
font-lock-function-name-face
|
||||
font-lock-variable-name-face))
|
||||
(list (concat "^" ctoken "[ \t*]+"
|
||||
"\\(" ctoken "[ \t*]+\\)*"
|
||||
"\\(" ctoken "\\)[ \t]*\\((\\)?")
|
||||
"\\(" ctoken "\\)[ \t<>=!+-]*\\((\\)?")
|
||||
2
|
||||
'(if (match-beginning 3)
|
||||
font-lock-function-name-face
|
||||
@ -911,64 +1071,38 @@ size, you can use \\[font-lock-fontify-buffer]."
|
||||
(defvar c++-font-lock-keywords c++-font-lock-keywords-1
|
||||
"Default expressions to highlight in C++ mode.")
|
||||
|
||||
|
||||
(defvar tex-font-lock-keywords
|
||||
;; Regexps updated with help from Ulrik Dickow <dickow@nbi.dk>.
|
||||
; ;; Regexps updated with help from Ulrik Dickow <dickow@nbi.dk>.
|
||||
; '(("\\\\\\(begin\\|end\\|newcommand\\){\\([a-zA-Z0-9\\*]+\\)}"
|
||||
; 2 font-lock-function-name-face)
|
||||
; ("\\\\\\(cite\\|label\\|pageref\\|ref\\){\\([^} \t\n]+\\)}"
|
||||
; 2 font-lock-reference-face)
|
||||
; ;; It seems a bit dubious to use `bold' and `italic' faces since we might
|
||||
; ;; not be able to display those fonts.
|
||||
; ("{\\\\bf\\([^}]+\\)}" 1 'bold keep)
|
||||
; ("{\\\\\\(em\\|it\\|sl\\)\\([^}]+\\)}" 2 'italic keep)
|
||||
; ("\\\\\\([a-zA-Z@]+\\|.\\)" . font-lock-keyword-face)
|
||||
; ("^[ \t\n]*\\\\def[\\\\@]\\(\\w+\\)" 1 font-lock-function-name-face keep))
|
||||
;; Rewritten and extended for LaTeX2e by Ulrik Dickow <dickow@nbi.dk>.
|
||||
'(("\\\\\\(begin\\|end\\|newcommand\\){\\([a-zA-Z0-9\\*]+\\)}"
|
||||
2 font-lock-function-name-face)
|
||||
("\\\\\\(cite\\|label\\|pageref\\|ref\\){\\([^} \t\n]+\\)}"
|
||||
2 font-lock-reference-face)
|
||||
("^[ \t]*\\\\def\\\\\\(\\(\\w\\|@\\)+\\)" 1 font-lock-function-name-face)
|
||||
("\\\\\\([a-zA-Z@]+\\|.\\)" . font-lock-keyword-face)
|
||||
;; It seems a bit dubious to use `bold' and `italic' faces since we might
|
||||
;; not be able to display those fonts.
|
||||
("{\\\\bf\\([^}]+\\)}" 1 'bold keep)
|
||||
("{\\\\\\(em\\|it\\|sl\\)\\([^}]+\\)}" 2 'italic keep)
|
||||
("\\\\\\([a-zA-Z@]+\\|.\\)" . font-lock-keyword-face)
|
||||
("^[ \t\n]*\\\\def[\\\\@]\\(\\w+\\)" 1 font-lock-function-name-face keep))
|
||||
"Additional expressions to highlight in TeX mode.")
|
||||
|
||||
(defun font-lock-choose-keywords (keywords level)
|
||||
;; Return evaled LEVELth element of KEYWORDS. A LEVEL of nil is equal to a
|
||||
;; LEVEL of 0, a LEVEL of t is equal to (1- (length KEYWORDS)).
|
||||
(cond ((symbolp keywords)
|
||||
keywords)
|
||||
((numberp level)
|
||||
(or (nth level keywords) (car (reverse keywords))))
|
||||
((eq level t)
|
||||
(car (reverse keywords)))
|
||||
(t
|
||||
(car keywords))))
|
||||
|
||||
(defun font-lock-set-defaults ()
|
||||
"Set fontification defaults appropriately for this mode.
|
||||
Sets `font-lock-keywords', `font-lock-no-comments', `font-lock-syntax-table'
|
||||
and `font-lock-keywords-case-fold-search' using `font-lock-defaults' (or, if
|
||||
nil, using `font-lock-defaults-alist') and `font-lock-maximum-decoration'."
|
||||
;; Set face defaults.
|
||||
(font-lock-make-faces)
|
||||
;; Set fontification defaults.
|
||||
(or font-lock-keywords
|
||||
(let ((defaults (or font-lock-defaults
|
||||
(cdr (assq major-mode font-lock-defaults-alist)))))
|
||||
;; Keywords?
|
||||
(setq font-lock-keywords
|
||||
(font-lock-compile-keywords
|
||||
(eval (font-lock-choose-keywords (nth 0 defaults)
|
||||
font-lock-maximum-decoration))))
|
||||
;; Syntactic?
|
||||
(if (nth 1 defaults)
|
||||
(set (make-local-variable 'font-lock-no-comments) t))
|
||||
;; Case fold?
|
||||
(if (nth 2 defaults)
|
||||
(set (make-local-variable 'font-lock-keywords-case-fold-search) t))
|
||||
;; Syntax table?
|
||||
(if (nth 3 defaults)
|
||||
(let ((slist (nth 3 defaults)))
|
||||
(set (make-local-variable 'font-lock-syntax-table)
|
||||
(copy-syntax-table (syntax-table)))
|
||||
(while slist
|
||||
(modify-syntax-entry (car (car slist)) (cdr (car slist))
|
||||
font-lock-syntax-table)
|
||||
(setq slist (cdr slist))))))))
|
||||
|
||||
;; LaTeX2e: \emph{This is emphasized}.
|
||||
("\\\\emph{\\([^}]+\\)}" 1 'italic keep)
|
||||
;; LaTeX2e: \textbf{This is bold}, \textit{...}, \textsl{...}
|
||||
("\\\\text\\(\\(bf\\)\\|it\\|sl\\){\\([^}]+\\)}"
|
||||
3 (if (match-beginning 2) 'bold 'italic) keep)
|
||||
;; Old-style bf/em/it/sl. Stop at `\\' and un-escaped `&', for good tables.
|
||||
("\\\\\\(\\(bf\\)\\|em\\|it\\|sl\\)\\>\\(\\([^}&\\]\\|\\\\[^\\]\\)+\\)"
|
||||
3 (if (match-beginning 2) 'bold 'italic) keep))
|
||||
"Additional expressions to highlight in TeX modes.")
|
||||
|
||||
;; Install ourselves:
|
||||
|
||||
(or (assq 'font-lock-mode minor-mode-alist)
|
||||
|
Loading…
Reference in New Issue
Block a user