mirror of
https://git.savannah.gnu.org/git/emacs/org-mode.git
synced 2024-11-21 06:55:35 +00:00
ox-texinfo: Tiny refactoring
* lisp/ox-texinfo.el (org-texinfo-link): Use `org-texinfo--sanitize-content'. (cherry picked from commit8fd24c0a53
) [km]: This fixes a double-escaping regression introduced by706970efb
(ox-texinfo.el: Fix escaping special chars in raw-path, 2020-06-05).
This commit is contained in:
parent
dab32da708
commit
13dfab3fb2
@ -1046,17 +1046,16 @@ DESC is the description part of the link, or the empty string.
|
||||
INFO is a plist holding contextual information. See
|
||||
`org-export-data'."
|
||||
(let* ((type (org-element-property :type link))
|
||||
(raw-path
|
||||
(replace-regexp-in-string
|
||||
"[@{}]" "@\\&"
|
||||
(org-element-property :path link)))
|
||||
(raw-path (org-element-property :path link))
|
||||
;; Ensure DESC really exists, or set it to nil.
|
||||
(desc (and (not (string= desc "")) desc))
|
||||
(path (cond
|
||||
((member type '("http" "https" "ftp"))
|
||||
(concat type ":" raw-path))
|
||||
((string= type "file") (org-export-file-uri raw-path))
|
||||
(t raw-path))))
|
||||
(path (org-texinfo--sanitize-content
|
||||
(cond
|
||||
((member type '("http" "https" "ftp"))
|
||||
(concat type ":" raw-path))
|
||||
((string-equal type "file")
|
||||
(org-export-file-uri raw-path))
|
||||
(t raw-path)))))
|
||||
(cond
|
||||
((org-export-custom-protocol-maybe link desc 'texinfo))
|
||||
((org-export-inline-image-p link org-texinfo-inline-image-rules)
|
||||
@ -1072,8 +1071,7 @@ INFO is a plist holding contextual information. See
|
||||
(org-export-resolve-id-link link info))))
|
||||
(pcase (org-element-type destination)
|
||||
(`nil
|
||||
(format org-texinfo-link-with-unknown-path-format
|
||||
(org-texinfo--sanitize-content path)))
|
||||
(format org-texinfo-link-with-unknown-path-format path))
|
||||
;; Id link points to an external file.
|
||||
(`plain-text
|
||||
(if desc (format "@uref{file://%s,%s}" destination desc)
|
||||
@ -1091,8 +1089,7 @@ INFO is a plist holding contextual information. See
|
||||
(_ (org-texinfo--@ref destination desc info)))))
|
||||
((string= type "mailto")
|
||||
(format "@email{%s}"
|
||||
(concat (org-texinfo--sanitize-content path)
|
||||
(and desc (concat ", " desc)))))
|
||||
(concat path (and desc (concat ", " desc)))))
|
||||
;; External link with a description part.
|
||||
((and path desc) (format "@uref{%s, %s}" path desc))
|
||||
;; External link without a description part.
|
||||
|
Loading…
Reference in New Issue
Block a user