org-element: Fix latex environment parsing
* contrib/lisp/org-element.el (org-element-latex-environment-parser): Grab value until closing of main environment block. (org-element-current-element): Check if main block is properly closed. * testing/lisp/test-org-element.el: Add test.
This commit is contained in:
parent
294589270e
commit
d308ea3172
|
@ -1265,20 +1265,23 @@ keywords.
|
||||||
Assume point is at the beginning of the latex environment."
|
Assume point is at the beginning of the latex environment."
|
||||||
(save-excursion
|
(save-excursion
|
||||||
(let* ((case-fold-search t)
|
(let* ((case-fold-search t)
|
||||||
(contents-begin (point))
|
(code-begin (point))
|
||||||
(keywords (org-element-collect-affiliated-keywords))
|
(keywords (org-element-collect-affiliated-keywords))
|
||||||
(begin (car keywords))
|
(begin (car keywords))
|
||||||
(contents-end (progn (re-search-forward "^[ \t]*\\\\end")
|
(env (progn (looking-at "^[ \t]*\\\\begin{\\([A-Za-z0-9*]+\\)}")
|
||||||
|
(regexp-quote (match-string 1))))
|
||||||
|
(code-end
|
||||||
|
(progn (re-search-forward (format "^[ \t]*\\\\end{%s}" env))
|
||||||
(forward-line)
|
(forward-line)
|
||||||
(point)))
|
(point)))
|
||||||
(value (buffer-substring-no-properties contents-begin contents-end))
|
(value (buffer-substring-no-properties code-begin code-end))
|
||||||
(end (progn (org-skip-whitespace)
|
(end (progn (org-skip-whitespace)
|
||||||
(if (eobp) (point) (point-at-bol)))))
|
(if (eobp) (point) (point-at-bol)))))
|
||||||
`(latex-environment
|
`(latex-environment
|
||||||
(:begin ,begin
|
(:begin ,begin
|
||||||
:end ,end
|
:end ,end
|
||||||
:value ,value
|
:value ,value
|
||||||
:post-blank ,(count-lines contents-end end)
|
:post-blank ,(count-lines code-end end)
|
||||||
,@(cadr keywords))))))
|
,@(cadr keywords))))))
|
||||||
|
|
||||||
(defun org-element-latex-environment-interpreter (latex-environment contents)
|
(defun org-element-latex-environment-interpreter (latex-environment contents)
|
||||||
|
@ -3076,9 +3079,12 @@ element it has to parse."
|
||||||
;; Inlinetask.
|
;; Inlinetask.
|
||||||
((org-at-heading-p) (org-element-inlinetask-parser raw-secondary-p))
|
((org-at-heading-p) (org-element-inlinetask-parser raw-secondary-p))
|
||||||
;; LaTeX Environment.
|
;; LaTeX Environment.
|
||||||
((looking-at "[ \t]*\\\\begin{")
|
((looking-at "[ \t]*\\\\begin{\\([A-Za-z0-9*]+\\)}")
|
||||||
(if (save-excursion
|
(if (save-excursion
|
||||||
(re-search-forward "[ \t]*\\\\end{[^}]*}[ \t]*" nil t))
|
(re-search-forward
|
||||||
|
(format "[ \t]*\\\\end{%s}[ \t]*"
|
||||||
|
(regexp-quote (match-string 1)))
|
||||||
|
nil t))
|
||||||
(org-element-latex-environment-parser)
|
(org-element-latex-environment-parser)
|
||||||
(org-element-paragraph-parser)))
|
(org-element-paragraph-parser)))
|
||||||
;; Drawer and Property Drawer.
|
;; Drawer and Property Drawer.
|
||||||
|
|
|
@ -841,7 +841,25 @@ Paragraph"
|
||||||
(should
|
(should
|
||||||
(org-test-with-temp-text "\\begin{equation}\ne^{i\\pi}+1=0\n\\end{equation}"
|
(org-test-with-temp-text "\\begin{equation}\ne^{i\\pi}+1=0\n\\end{equation}"
|
||||||
(org-element-map
|
(org-element-map
|
||||||
(org-element-parse-buffer) 'latex-environment 'identity))))
|
(org-element-parse-buffer) 'latex-environment 'identity)))
|
||||||
|
;; Allow nested environments.
|
||||||
|
(should
|
||||||
|
(equal
|
||||||
|
"\\begin{outer}
|
||||||
|
\\begin{inner}
|
||||||
|
e^{i\\pi}+1=0
|
||||||
|
\\end{inner}
|
||||||
|
\\end{outer}"
|
||||||
|
(org-test-with-temp-text "
|
||||||
|
\\begin{outer}
|
||||||
|
\\begin{inner}
|
||||||
|
e^{i\\pi}+1=0
|
||||||
|
\\end{inner}
|
||||||
|
\\end{outer}"
|
||||||
|
(org-element-property
|
||||||
|
:value
|
||||||
|
(org-element-map
|
||||||
|
(org-element-parse-buffer) 'latex-environment 'identity nil t))))))
|
||||||
|
|
||||||
|
|
||||||
;;;; Latex Fragment
|
;;;; Latex Fragment
|
||||||
|
|
Loading…
Reference in New Issue