Merge branch 'Jambu'
This commit is contained in:
commit
95fa250e60
216
lisp/org-exp.el
216
lisp/org-exp.el
|
@ -49,6 +49,12 @@
|
||||||
(declare-function org-table-cookie-line-p "org-table" (line))
|
(declare-function org-table-cookie-line-p "org-table" (line))
|
||||||
(declare-function org-table-colgroup-line-p "org-table" (line))
|
(declare-function org-table-colgroup-line-p "org-table" (line))
|
||||||
(autoload 'org-export-generic "org-export-generic" "Export using the generic exporter" t)
|
(autoload 'org-export-generic "org-export-generic" "Export using the generic exporter" t)
|
||||||
|
|
||||||
|
(autoload 'org-export-as-odt "org-odt"
|
||||||
|
"Export the outline to a OpenDocumentText file." t)
|
||||||
|
(autoload 'org-export-as-odt-and-open "org-odt"
|
||||||
|
"Export the outline to a OpenDocumentText file and open it." t)
|
||||||
|
|
||||||
(defgroup org-export nil
|
(defgroup org-export nil
|
||||||
"Options for exporting org-listings."
|
"Options for exporting org-listings."
|
||||||
:tag "Org Export"
|
:tag "Org Export"
|
||||||
|
@ -933,6 +939,8 @@ Pressing `1' will switch between these two options."
|
||||||
|
|
||||||
\[D] export as DocBook [V] export as DocBook, process to PDF, and open
|
\[D] export as DocBook [V] export as DocBook, process to PDF, and open
|
||||||
|
|
||||||
|
\[o] export as OpenDocumentText [O] ... and open
|
||||||
|
|
||||||
\[j] export as TaskJuggler [J] ... and open
|
\[j] export as TaskJuggler [J] ... and open
|
||||||
|
|
||||||
\[m] export as Freemind mind map
|
\[m] export as Freemind mind map
|
||||||
|
@ -961,6 +969,8 @@ Pressing `1' will switch between these two options."
|
||||||
(?g org-export-generic t)
|
(?g org-export-generic t)
|
||||||
(?D org-export-as-docbook t)
|
(?D org-export-as-docbook t)
|
||||||
(?V org-export-as-docbook-pdf-and-open t)
|
(?V org-export-as-docbook-pdf-and-open t)
|
||||||
|
(?o org-export-as-odt t)
|
||||||
|
(?O org-export-as-odt-and-open t)
|
||||||
(?j org-export-as-taskjuggler t)
|
(?j org-export-as-taskjuggler t)
|
||||||
(?J org-export-as-taskjuggler-and-open t)
|
(?J org-export-as-taskjuggler-and-open t)
|
||||||
(?m org-export-as-freemind t)
|
(?m org-export-as-freemind t)
|
||||||
|
@ -1651,52 +1661,53 @@ from the buffer."
|
||||||
(add-text-properties beg (if (bolp) (1- (point)) (point))
|
(add-text-properties beg (if (bolp) (1- (point)) (point))
|
||||||
'(org-protected t)))))
|
'(org-protected t)))))
|
||||||
|
|
||||||
|
(defvar org-export-backends
|
||||||
|
'(docbook html beamer ascii latex)
|
||||||
|
"List of Org supported export backends.")
|
||||||
|
|
||||||
(defun org-export-select-backend-specific-text ()
|
(defun org-export-select-backend-specific-text ()
|
||||||
(let ((formatters
|
(let ((formatters org-export-backends)
|
||||||
'((docbook "DOCBOOK" "BEGIN_DOCBOOK" "END_DOCBOOK")
|
|
||||||
(html "HTML" "BEGIN_HTML" "END_HTML")
|
|
||||||
(beamer "BEAMER" "BEGIN_BEAMER" "END_BEAMER")
|
|
||||||
(ascii "ASCII" "BEGIN_ASCII" "END_ASCII")
|
|
||||||
(latex "LaTeX" "BEGIN_LaTeX" "END_LaTeX")))
|
|
||||||
(case-fold-search t)
|
(case-fold-search t)
|
||||||
fmt beg beg-content end end-content ind)
|
backend backend-name beg beg-content end end-content ind)
|
||||||
|
|
||||||
(while formatters
|
(while formatters
|
||||||
(setq fmt (pop formatters))
|
(setq backend (pop formatters)
|
||||||
;; Handle #+backend: stuff
|
backend-name (symbol-name backend))
|
||||||
|
|
||||||
|
;; Handle #+BACKEND: stuff
|
||||||
(goto-char (point-min))
|
(goto-char (point-min))
|
||||||
(while (re-search-forward (concat "^\\([ \t]*\\)#\\+" (cadr fmt)
|
(while (re-search-forward (concat "^\\([ \t]*\\)#\\+" backend-name
|
||||||
":[ \t]*\\(.*\\)") nil t)
|
":[ \t]*\\(.*\\)") nil t)
|
||||||
(if (not (eq (car fmt) org-export-current-backend))
|
(if (not (eq backend org-export-current-backend))
|
||||||
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))
|
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))
|
||||||
(replace-match "\\1\\2" t)
|
(replace-match "\\1\\2" t)
|
||||||
(add-text-properties
|
(add-text-properties
|
||||||
(point-at-bol) (min (1+ (point-at-eol)) (point-max))
|
(point-at-bol) (min (1+ (point-at-eol)) (point-max))
|
||||||
`(org-protected t original-indentation ,ind))))
|
`(org-protected t original-indentation ,ind org-native-text t))))
|
||||||
;; Delete #+attr_Backend: stuff of another backend. Those
|
;; Delete #+ATTR_BACKEND: stuff of another backend. Those
|
||||||
;; matching the current backend will be taken care of by
|
;; matching the current backend will be taken care of by
|
||||||
;; `org-export-attach-captions-and-attributes'
|
;; `org-export-attach-captions-and-attributes'
|
||||||
(goto-char (point-min))
|
(goto-char (point-min))
|
||||||
(while (re-search-forward (concat "^\\([ \t]*\\)#\\+attr_" (cadr fmt)
|
(while (re-search-forward (concat "^\\([ \t]*\\)#\\+ATTR_" backend-name
|
||||||
":[ \t]*\\(.*\\)") nil t)
|
":[ \t]*\\(.*\\)") nil t)
|
||||||
(setq ind (org-get-indentation))
|
(setq ind (org-get-indentation))
|
||||||
(when (not (eq (car fmt) org-export-current-backend))
|
(when (not (eq backend org-export-current-backend))
|
||||||
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))))
|
(delete-region (point-at-bol) (min (1+ (point-at-eol)) (point-max)))))
|
||||||
;; Handle #+begin_backend and #+end_backend stuff
|
;; Handle #+BEGIN_BACKEND and #+END_BACKEND stuff
|
||||||
(goto-char (point-min))
|
(goto-char (point-min))
|
||||||
(while (re-search-forward (concat "^[ \t]*#\\+" (caddr fmt) "\\>.*\n?")
|
(while (re-search-forward (concat "^[ \t]*#\\+BEGIN_" backend-name "\\>.*\n?")
|
||||||
nil t)
|
nil t)
|
||||||
(setq beg (match-beginning 0) beg-content (match-end 0))
|
(setq beg (match-beginning 0) beg-content (match-end 0))
|
||||||
(setq ind (save-excursion (goto-char beg) (org-get-indentation)))
|
(setq ind (save-excursion (goto-char beg) (org-get-indentation)))
|
||||||
(when (re-search-forward (concat "^[ \t]*#\\+" (cadddr fmt) "\\>.*\n?")
|
(when (re-search-forward (concat "^[ \t]*#\\+END_" backend-name "\\>.*\n?")
|
||||||
nil t)
|
nil t)
|
||||||
(setq end (match-end 0) end-content (match-beginning 0))
|
(setq end (match-end 0) end-content (match-beginning 0))
|
||||||
(if (eq (car fmt) org-export-current-backend)
|
(if (eq backend org-export-current-backend)
|
||||||
;; yes, keep this
|
;; yes, keep this
|
||||||
(progn
|
(progn
|
||||||
(add-text-properties
|
(add-text-properties
|
||||||
beg-content end-content
|
beg-content end-content
|
||||||
`(org-protected t original-indentation ,ind))
|
`(org-protected t original-indentation ,ind org-native-text t))
|
||||||
(delete-region (match-beginning 0) (match-end 0))
|
(delete-region (match-beginning 0) (match-end 0))
|
||||||
(save-excursion
|
(save-excursion
|
||||||
(goto-char beg)
|
(goto-char beg)
|
||||||
|
@ -2462,6 +2473,16 @@ in the list) and remove property and value from the list in LISTVAR."
|
||||||
(defun org-export-format-source-code-or-example
|
(defun org-export-format-source-code-or-example
|
||||||
(lang code &optional opts indent caption)
|
(lang code &optional opts indent caption)
|
||||||
"Format CODE from language LANG and return it formatted for export.
|
"Format CODE from language LANG and return it formatted for export.
|
||||||
|
The CODE is marked up in `org-export-current-backend' format.
|
||||||
|
|
||||||
|
Check if a function by name
|
||||||
|
\"org-<backend>-format-source-code-or-example\" is bound. If yes,
|
||||||
|
use it as the custom formatter. Otherwise, use the default
|
||||||
|
formatter. Default formatters are provided for docbook, html,
|
||||||
|
latex and ascii backends. For example, use
|
||||||
|
`org-html-format-source-code-or-example' to provide a custom
|
||||||
|
formatter for export to \"html\".
|
||||||
|
|
||||||
If LANG is nil, do not add any fontification.
|
If LANG is nil, do not add any fontification.
|
||||||
OPTS contains formatting options, like `-n' for triggering numbering lines,
|
OPTS contains formatting options, like `-n' for triggering numbering lines,
|
||||||
and `+n' for continuing previous numbering.
|
and `+n' for continuing previous numbering.
|
||||||
|
@ -2469,7 +2490,15 @@ Code formatting according to language currently only works for HTML.
|
||||||
Numbering lines works for all three major backends (html, latex, and ascii).
|
Numbering lines works for all three major backends (html, latex, and ascii).
|
||||||
INDENT was the original indentation of the block."
|
INDENT was the original indentation of the block."
|
||||||
(save-match-data
|
(save-match-data
|
||||||
(let (num cont rtn rpllbl keepp textareap preserve-indentp cols rows fmt)
|
(let* ((backend-name (symbol-name org-export-current-backend))
|
||||||
|
(backend-formatter
|
||||||
|
(intern (format "org-%s-format-source-code-or-example"
|
||||||
|
backend-name)))
|
||||||
|
(backend-feature (intern (concat "org-" backend-name)))
|
||||||
|
(backend-formatter
|
||||||
|
(and (require (intern (concat "org-" backend-name)) nil)
|
||||||
|
(fboundp backend-formatter) backend-formatter))
|
||||||
|
num cont rtn rpllbl keepp textareap preserve-indentp cols rows fmt)
|
||||||
(setq opts (or opts "")
|
(setq opts (or opts "")
|
||||||
num (string-match "[-+]n\\>" opts)
|
num (string-match "[-+]n\\>" opts)
|
||||||
cont (string-match "\\+n\\>" opts)
|
cont (string-match "\\+n\\>" opts)
|
||||||
|
@ -2506,14 +2535,14 @@ INDENT was the original indentation of the block."
|
||||||
;; Now backend-specific coding
|
;; Now backend-specific coding
|
||||||
(setq rtn
|
(setq rtn
|
||||||
(cond
|
(cond
|
||||||
|
(backend-formatter
|
||||||
|
(funcall backend-formatter lang caption textareap cols rows num
|
||||||
|
cont rpllbl fmt))
|
||||||
((eq org-export-current-backend 'docbook)
|
((eq org-export-current-backend 'docbook)
|
||||||
(setq rtn (org-export-number-lines rtn 0 0 num cont rpllbl fmt))
|
(setq rtn (org-export-number-lines rtn 0 0 num cont rpllbl fmt))
|
||||||
(concat "\n#+BEGIN_DOCBOOK\n"
|
(concat "<programlisting><![CDATA["
|
||||||
(org-add-props (concat "<programlisting><![CDATA["
|
rtn
|
||||||
rtn
|
"]]></programlisting>\n"))
|
||||||
"]]></programlisting>\n")
|
|
||||||
'(org-protected t org-example t))
|
|
||||||
"#+END_DOCBOOK\n"))
|
|
||||||
((eq org-export-current-backend 'html)
|
((eq org-export-current-backend 'html)
|
||||||
;; We are exporting to HTML
|
;; We are exporting to HTML
|
||||||
(when lang
|
(when lang
|
||||||
|
@ -2583,78 +2612,79 @@ INDENT was the original indentation of the block."
|
||||||
(setq rtn (org-export-number-lines rtn 1 1 num cont rpllbl fmt)))
|
(setq rtn (org-export-number-lines rtn 1 1 num cont rpllbl fmt)))
|
||||||
(if (string-match "\\(\\`<[^>]*>\\)\n" rtn)
|
(if (string-match "\\(\\`<[^>]*>\\)\n" rtn)
|
||||||
(setq rtn (replace-match "\\1" t nil rtn)))
|
(setq rtn (replace-match "\\1" t nil rtn)))
|
||||||
(concat "\n#+BEGIN_HTML\n" (org-add-props rtn '(org-protected t org-example t)) "\n#+END_HTML\n\n"))
|
rtn)
|
||||||
((eq org-export-current-backend 'latex)
|
((eq org-export-current-backend 'latex)
|
||||||
(setq rtn (org-export-number-lines rtn 0 0 num cont rpllbl fmt))
|
(setq rtn (org-export-number-lines rtn 0 0 num cont rpllbl fmt))
|
||||||
(concat
|
(cond
|
||||||
"#+BEGIN_LaTeX\n"
|
((and lang org-export-latex-listings)
|
||||||
(org-add-props
|
(flet ((make-option-string
|
||||||
(cond
|
(pair)
|
||||||
((and lang org-export-latex-listings)
|
(concat (first pair)
|
||||||
(flet ((make-option-string
|
(if (> (length (second pair)) 0)
|
||||||
(pair)
|
(concat "=" (second pair))))))
|
||||||
(concat (first pair)
|
(let* ((lang-sym (intern lang))
|
||||||
(if (> (length (second pair)) 0)
|
(minted-p (eq org-export-latex-listings 'minted))
|
||||||
(concat "=" (second pair))))))
|
(listings-p (not minted-p))
|
||||||
(let* ((lang-sym (intern lang))
|
(backend-lang
|
||||||
(minted-p (eq org-export-latex-listings 'minted))
|
(or (cadr
|
||||||
(listings-p (not minted-p))
|
(assq
|
||||||
(backend-lang
|
lang-sym
|
||||||
(or (cadr
|
(cond
|
||||||
(assq
|
(minted-p org-export-latex-minted-langs)
|
||||||
lang-sym
|
(listings-p org-export-latex-listings-langs))))
|
||||||
(cond
|
lang))
|
||||||
(minted-p org-export-latex-minted-langs)
|
(custom-environment
|
||||||
(listings-p org-export-latex-listings-langs))))
|
(cadr
|
||||||
lang))
|
(assq
|
||||||
(custom-environment
|
lang-sym
|
||||||
(cadr
|
org-export-latex-custom-lang-environments))))
|
||||||
(assq
|
(concat
|
||||||
lang-sym
|
(when (and listings-p (not custom-environment))
|
||||||
org-export-latex-custom-lang-environments))))
|
(format
|
||||||
(concat
|
"\\lstset{%s}\n"
|
||||||
(when (and listings-p (not custom-environment))
|
(mapconcat
|
||||||
(format
|
#'make-option-string
|
||||||
"\\lstset{%s}\n"
|
(append org-export-latex-listings-options
|
||||||
(mapconcat
|
`(("language" ,backend-lang))) ",")))
|
||||||
#'make-option-string
|
(when (and caption org-export-latex-listings-w-names)
|
||||||
(append org-export-latex-listings-options
|
(format
|
||||||
`(("language" ,backend-lang))) ",")))
|
"\n%s $\\equiv$ \n"
|
||||||
(when (and caption org-export-latex-listings-w-names)
|
(replace-regexp-in-string "_" "\\\\_" caption)))
|
||||||
(format
|
(cond
|
||||||
"\n%s $\\equiv$ \n"
|
(custom-environment
|
||||||
(replace-regexp-in-string "_" "\\\\_" caption)))
|
(format "\\begin{%s}\n%s\\end{%s}\n"
|
||||||
(cond
|
custom-environment rtn custom-environment))
|
||||||
(custom-environment
|
(listings-p
|
||||||
(format "\\begin{%s}\n%s\\end{%s}\n"
|
(format "\\begin{%s}\n%s\\end{%s}\n"
|
||||||
custom-environment rtn custom-environment))
|
"lstlisting" rtn "lstlisting"))
|
||||||
(listings-p
|
(minted-p
|
||||||
(format "\\begin{%s}\n%s\\end{%s}\n"
|
(format
|
||||||
"lstlisting" rtn "lstlisting"))
|
"\\begin{minted}[%s]{%s}\n%s\\end{minted}\n"
|
||||||
(minted-p
|
(mapconcat #'make-option-string
|
||||||
(format
|
org-export-latex-minted-options ",")
|
||||||
"\\begin{minted}[%s]{%s}\n%s\\end{minted}\n"
|
backend-lang rtn)))))))
|
||||||
(mapconcat #'make-option-string
|
(t (concat (car org-export-latex-verbatim-wrap)
|
||||||
org-export-latex-minted-options ",")
|
rtn (cdr org-export-latex-verbatim-wrap)))))
|
||||||
backend-lang rtn)))))))
|
|
||||||
(t (concat (car org-export-latex-verbatim-wrap)
|
|
||||||
rtn (cdr org-export-latex-verbatim-wrap))))
|
|
||||||
'(org-protected t org-example t))
|
|
||||||
"#+END_LaTeX\n"))
|
|
||||||
((eq org-export-current-backend 'ascii)
|
((eq org-export-current-backend 'ascii)
|
||||||
;; This is not HTML or LaTeX, so just make it an example.
|
;; This is not HTML or LaTeX, so just make it an example.
|
||||||
(setq rtn (org-export-number-lines rtn 0 0 num cont rpllbl fmt))
|
(setq rtn (org-export-number-lines rtn 0 0 num cont rpllbl fmt))
|
||||||
(concat caption "\n"
|
(concat caption "\n"
|
||||||
"#+BEGIN_ASCII\n"
|
(concat
|
||||||
(org-add-props
|
(mapconcat
|
||||||
(concat
|
(lambda (l) (concat " " l))
|
||||||
(mapconcat
|
(org-split-string rtn "\n")
|
||||||
(lambda (l) (concat " " l))
|
"\n")
|
||||||
(org-split-string rtn "\n")
|
"\n")
|
||||||
"\n")
|
))
|
||||||
"\n")
|
(t
|
||||||
'(org-protected t org-example t))
|
(error "Don't know how to markup source or example block in %s"
|
||||||
"#+END_ASCII\n"))))
|
(upcase backend-name)))))
|
||||||
|
(setq rtn
|
||||||
|
(concat
|
||||||
|
"\n#+BEGIN_" backend-name "\n"
|
||||||
|
(org-add-props rtn
|
||||||
|
'(org-protected t org-example t org-native-text t))
|
||||||
|
"\n#+END_" backend-name "\n\n"))
|
||||||
(org-add-props rtn nil 'original-indentation indent))))
|
(org-add-props rtn nil 'original-indentation indent))))
|
||||||
|
|
||||||
(defun org-export-number-lines (text &optional skip1 skip2 number cont
|
(defun org-export-number-lines (text &optional skip1 skip2 number cont
|
||||||
|
|
|
@ -362,6 +362,9 @@ With prefix arg SPECIAL, offer additional commands in a menu."
|
||||||
(org-footnote-goto-previous-reference (nth 1 tmp)))
|
(org-footnote-goto-previous-reference (nth 1 tmp)))
|
||||||
(t (org-footnote-new)))))
|
(t (org-footnote-new)))))
|
||||||
|
|
||||||
|
(defvar org-footnote-insert-pos-for-preprocessor 'point-max
|
||||||
|
"See `org-footnote-normalize'.")
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun org-footnote-normalize (&optional sort-only for-preprocessor)
|
(defun org-footnote-normalize (&optional sort-only for-preprocessor)
|
||||||
"Collect the footnotes in various formats and normalize them.
|
"Collect the footnotes in various formats and normalize them.
|
||||||
|
@ -369,7 +372,20 @@ This finds the different sorts of footnotes allowed in Org, and
|
||||||
normalizes them to the usual [N] format that is understood by the
|
normalizes them to the usual [N] format that is understood by the
|
||||||
Org-mode exporters.
|
Org-mode exporters.
|
||||||
When SORT-ONLY is set, only sort the footnote definitions into the
|
When SORT-ONLY is set, only sort the footnote definitions into the
|
||||||
referenced sequence."
|
referenced sequence.
|
||||||
|
|
||||||
|
When FOR-PREPROCESSOR is non nil, the default action, is to
|
||||||
|
insert normalized footnotes towards the end of the pre-processing
|
||||||
|
buffer. Some exporters like docbook, odt etc expect that footnote
|
||||||
|
definitions be available before any references to them. Such
|
||||||
|
exporters can let bind `org-footnote-insert-pos-for-preprocessor'
|
||||||
|
to symbol 'point-min to achieve the desired behaviour.
|
||||||
|
|
||||||
|
Additional note on `org-footnote-insert-pos-for-preprocessor':
|
||||||
|
1. This variable has not effect when FOR-PREPROCESSOR is nil.
|
||||||
|
2. This variable (potentially) obviates the need for extra scan
|
||||||
|
of pre-processor buffer as witnessed in
|
||||||
|
`org-export-docbook-get-footnotes'."
|
||||||
;; This is based on Paul's function, but rewritten.
|
;; This is based on Paul's function, but rewritten.
|
||||||
(let* ((limit-level
|
(let* ((limit-level
|
||||||
(and (boundp 'org-inlinetask-min-level)
|
(and (boundp 'org-inlinetask-min-level)
|
||||||
|
@ -461,7 +477,12 @@ referenced sequence."
|
||||||
(setq ins-point (point))))
|
(setq ins-point (point))))
|
||||||
|
|
||||||
;; Insert the footnotes again
|
;; Insert the footnotes again
|
||||||
(goto-char (or ins-point (point-max)))
|
(goto-char (or (and for-preprocessor
|
||||||
|
(equal org-footnote-insert-pos-for-preprocessor
|
||||||
|
'point-min)
|
||||||
|
(point-min))
|
||||||
|
ins-point
|
||||||
|
(point-max)))
|
||||||
(setq ref-table (reverse ref-table))
|
(setq ref-table (reverse ref-table))
|
||||||
(when sort-only
|
(when sort-only
|
||||||
;; remove anonymous and inline footnotes from the list
|
;; remove anonymous and inline footnotes from the list
|
||||||
|
|
Loading…
Reference in New Issue