Fix fontification of LaTeX environments
* lisp/org.el (org-compute-latex-and-related-regexp): (org-do-latex-and-related): Fix fontification of LaTeX environments.
This commit is contained in:
parent
a60a0edc6f
commit
a86b14253b
68
lisp/org.el
68
lisp/org.el
|
@ -6226,24 +6226,31 @@ Also refresh fontification if needed."
|
||||||
(defun org-compute-latex-and-related-regexp ()
|
(defun org-compute-latex-and-related-regexp ()
|
||||||
"Compute regular expression for LaTeX, entities and sub/superscript.
|
"Compute regular expression for LaTeX, entities and sub/superscript.
|
||||||
Result depends on variable `org-highlight-latex-and-related'."
|
Result depends on variable `org-highlight-latex-and-related'."
|
||||||
(setq-local
|
(let ((re-sub
|
||||||
org-latex-and-related-regexp
|
|
||||||
(let* ((re-sub
|
|
||||||
(cond ((not (memq 'script org-highlight-latex-and-related)) nil)
|
(cond ((not (memq 'script org-highlight-latex-and-related)) nil)
|
||||||
((eq org-use-sub-superscripts '{})
|
((eq org-use-sub-superscripts '{})
|
||||||
(list org-match-substring-with-braces-regexp))
|
(list org-match-substring-with-braces-regexp))
|
||||||
(org-use-sub-superscripts (list org-match-substring-regexp))))
|
(org-use-sub-superscripts (list org-match-substring-regexp))))
|
||||||
(re-latex
|
(re-latex
|
||||||
(when (memq 'latex org-highlight-latex-and-related)
|
(when (memq 'latex org-highlight-latex-and-related)
|
||||||
(let ((matchers (plist-get org-format-latex-options :matchers)))
|
(let* ((matchers (plist-get org-format-latex-options :matchers))
|
||||||
(delq nil
|
(regexps (and (member "begin" matchers)
|
||||||
(mapcar (lambda (x)
|
'("\\\\end{[a-zA-Z0-9\\*]+}[ \t]*$"))))
|
||||||
(and (member (car x) matchers) (nth 1 x)))
|
(dolist (matcher matchers)
|
||||||
org-latex-regexps)))))
|
(pcase (assoc matcher org-latex-regexps)
|
||||||
|
(`("begin" . ,_) (push "^[ \t]*\\\\begin{[a-zA-Z0-9\\*]+}"
|
||||||
|
regexps))
|
||||||
|
(`(,_ ,regexp . ,_) (push regexp regexps))
|
||||||
|
(_ nil)))
|
||||||
|
(nreverse regexps))))
|
||||||
(re-entities
|
(re-entities
|
||||||
(when (memq 'entities org-highlight-latex-and-related)
|
(when (memq 'entities org-highlight-latex-and-related)
|
||||||
(list "\\\\\\(there4\\|sup[123]\\|frac[13][24]\\|[a-zA-Z]+\\)\\($\\|{}\\|[^[:alpha:]]\\)"))))
|
(list "\\\\\\(there4\\|sup[123]\\|frac[13][24]\\|[a-zA-Z]+\\)\
|
||||||
(mapconcat 'identity (append re-latex re-entities re-sub) "\\|"))))
|
\\($\\|{}\\|[^[:alpha:]]\\)"))))
|
||||||
|
(setq-local org-latex-and-related-regexp
|
||||||
|
(mapconcat #'identity
|
||||||
|
(append re-latex re-entities re-sub)
|
||||||
|
"\\|"))))
|
||||||
|
|
||||||
(defun org-do-latex-and-related (limit)
|
(defun org-do-latex-and-related (limit)
|
||||||
"Highlight LaTeX snippets and environments, entities and sub/superscript.
|
"Highlight LaTeX snippets and environments, entities and sub/superscript.
|
||||||
|
@ -6253,22 +6260,41 @@ done, nil otherwise."
|
||||||
(when (org-string-nw-p org-latex-and-related-regexp)
|
(when (org-string-nw-p org-latex-and-related-regexp)
|
||||||
(catch 'found
|
(catch 'found
|
||||||
(while (re-search-forward org-latex-and-related-regexp limit t)
|
(while (re-search-forward org-latex-and-related-regexp limit t)
|
||||||
(unless
|
(unless (cl-some
|
||||||
(cl-some
|
(lambda (f) (memq f '(org-code org-verbatim underline
|
||||||
(lambda (f)
|
org-special-keyword)))
|
||||||
(memq f '(org-code org-verbatim underline org-special-keyword)))
|
|
||||||
(save-excursion
|
(save-excursion
|
||||||
(goto-char (1+ (match-beginning 0)))
|
(goto-char (1+ (match-beginning 0)))
|
||||||
(face-at-point nil t)))
|
(face-at-point nil t)))
|
||||||
(let ((offset (if (memq (char-after (1+ (match-beginning 0)))
|
(let* ((start (if (memq (char-after (1+ (match-beginning 0)))
|
||||||
'(?_ ?^))
|
'(?_ ?^))
|
||||||
1
|
(1+ (match-beginning 0))
|
||||||
0)))
|
(match-beginning 0)))
|
||||||
|
(end
|
||||||
|
(let* ((b (match-beginning 0))
|
||||||
|
(e (match-end 0))
|
||||||
|
(m (buffer-substring-no-properties b e)))
|
||||||
|
(cond
|
||||||
|
((string-match "\\`[ \t]*\\\\begin{\\([a-zA-Z0-9\\*]+\\)}"
|
||||||
|
m)
|
||||||
|
(let ((closing
|
||||||
|
(format "\\\\end{%s}[ \t]*$"
|
||||||
|
(regexp-quote (match-string 1 m)))))
|
||||||
|
(or (re-search-forward closing nil t) e)))
|
||||||
|
((string-match "\\\\end{\\([a-zA-Z0-9\\*]+\\)}[ \t]*\\'" m)
|
||||||
|
(let ((opening
|
||||||
|
(format "^[ \t]*\\\\begin{%s}"
|
||||||
|
(regexp-quote (match-string 1 m)))))
|
||||||
|
(setq start (or (save-excursion
|
||||||
|
(re-search-backward opening nil t))
|
||||||
|
b))
|
||||||
|
(line-end-position)))
|
||||||
|
((string-match "\\\\[a-zA-Z]+\\*?{" m)
|
||||||
|
(search-forward "}" nil t))
|
||||||
|
(t e)))))
|
||||||
(font-lock-prepend-text-property
|
(font-lock-prepend-text-property
|
||||||
(+ offset (match-beginning 0)) (match-end 0)
|
start end 'face 'org-latex-and-related)
|
||||||
'face 'org-latex-and-related)
|
(add-text-properties start end '(font-lock-multiline t)))
|
||||||
(add-text-properties (+ offset (match-beginning 0)) (match-end 0)
|
|
||||||
'(font-lock-multiline t)))
|
|
||||||
(throw 'found t)))
|
(throw 'found t)))
|
||||||
nil)))
|
nil)))
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue