org-export: Objects in secondary strings can also be ignored
* contrib/lisp/org-export.el (org-export--populate-ignore-list): Move into secondary strings when looking for objects to ignore in the parse tree.
This commit is contained in:
parent
86b1be57b9
commit
9f2824852c
|
@ -1733,29 +1733,30 @@ associated numbering \(in the shape of a list of numbers\)."
|
|||
DATA is the parse tree to traverse. OPTIONS is the plist holding
|
||||
export options."
|
||||
(let* (ignore
|
||||
walk-data ; for byte-compiler.
|
||||
walk-data
|
||||
;; First find trees containing a select tag, if any.
|
||||
(selected (org-export--selected-trees data options))
|
||||
(walk-data
|
||||
(function
|
||||
(lambda (data options selected)
|
||||
;; Collect ignored elements or objects into IGNORE-LIST.
|
||||
(mapc
|
||||
(lambda (el)
|
||||
(if (org-export--skip-p el options selected) (push el ignore)
|
||||
(let ((type (org-element-type el)))
|
||||
(if (and (eq (plist-get options :with-archived-trees)
|
||||
'headline)
|
||||
(eq (org-element-type el) 'headline)
|
||||
(org-element-property :archivedp el))
|
||||
;; If headline is archived but tree below has
|
||||
;; to be skipped, add it to ignore list.
|
||||
(mapc (lambda (e) (push e ignore))
|
||||
(org-element-contents el))
|
||||
;; Move into recursive objects/elements.
|
||||
(when (org-element-contents el)
|
||||
(funcall walk-data el options selected))))))
|
||||
(org-element-contents data))))))
|
||||
;; Main call. First find trees containing a select tag, if any.
|
||||
(funcall walk-data data options (org-export--selected-trees data options))
|
||||
(lambda (data)
|
||||
;; Collect ignored elements or objects into IGNORE-LIST.
|
||||
(let ((type (org-element-type data)))
|
||||
(if (org-export--skip-p data options selected) (push data ignore)
|
||||
(if (and (eq type 'headline)
|
||||
(eq (plist-get options :with-archived-trees) 'headline)
|
||||
(org-element-property :archivedp data))
|
||||
;; If headline is archived but tree below has
|
||||
;; to be skipped, add it to ignore list.
|
||||
(mapc (lambda (e) (push e ignore))
|
||||
(org-element-contents data))
|
||||
;; Move into secondary string, if any.
|
||||
(let ((sec-prop
|
||||
(cdr (assq type org-element-secondary-value-alist))))
|
||||
(when sec-prop
|
||||
(mapc walk-data (org-element-property sec-prop data))))
|
||||
;; Move into recursive objects/elements.
|
||||
(mapc walk-data (org-element-contents data))))))))
|
||||
;; Main call.
|
||||
(funcall walk-data data)
|
||||
;; Return value.
|
||||
ignore))
|
||||
|
||||
|
|
Loading…
Reference in New Issue