org-element: Refactor code
This commit is contained in:
parent
29e633f7cd
commit
fcd4418a70
|
@ -2985,29 +2985,7 @@ Nil values returned from FUN are ignored in the result."
|
||||||
(assq (car el)
|
(assq (car el)
|
||||||
org-element-string-restrictions))))
|
org-element-string-restrictions))))
|
||||||
collect (car el))))
|
collect (car el))))
|
||||||
--walk-tree ; For byte-compiler
|
|
||||||
--acc
|
--acc
|
||||||
(--check-blob
|
|
||||||
(function
|
|
||||||
(lambda (--type types fun --blob)
|
|
||||||
;; Check if TYPE is matching among TYPES. If so, apply
|
|
||||||
;; FUN to --BLOB and accumulate return value into --ACC.
|
|
||||||
;; INFO is the communication channel. If --BLOB has
|
|
||||||
;; a secondary string that can contain objects with their
|
|
||||||
;; type amond TYPES, look into that string first.
|
|
||||||
(when (memq --type types)
|
|
||||||
(let ((result (funcall fun --blob)))
|
|
||||||
(cond ((not result))
|
|
||||||
(first-match (throw 'first-match result))
|
|
||||||
(t (push result --acc)))))
|
|
||||||
(when (memq --type --restricts)
|
|
||||||
(funcall
|
|
||||||
--walk-tree
|
|
||||||
`(org-data
|
|
||||||
nil
|
|
||||||
,@(org-element-property
|
|
||||||
(cdr (assq --type org-element-secondary-value-alist))
|
|
||||||
--blob)))))))
|
|
||||||
(--walk-tree
|
(--walk-tree
|
||||||
(function
|
(function
|
||||||
(lambda (--data)
|
(lambda (--data)
|
||||||
|
@ -3015,31 +2993,34 @@ Nil values returned from FUN are ignored in the result."
|
||||||
;; a plist holding contextual information.
|
;; a plist holding contextual information.
|
||||||
(mapc
|
(mapc
|
||||||
(lambda (--blob)
|
(lambda (--blob)
|
||||||
|
(unless (and info (member --blob (plist-get info :ignore-list)))
|
||||||
(let ((--type (org-element-type --blob)))
|
(let ((--type (org-element-type --blob)))
|
||||||
;; Determine if a recursion into --BLOB is
|
;; Check if TYPE is matching among TYPES. If so,
|
||||||
;; possible and allowed.
|
;; apply FUN to --BLOB and accumulate return value
|
||||||
(cond
|
;; into --ACC (or exit if FIRST-MATCH is non-nil).
|
||||||
;; Element or object not exportable.
|
(when (memq --type types)
|
||||||
((and info (member --blob (plist-get info :ignore-list))))
|
(let ((result (funcall fun --blob)))
|
||||||
;; Limiting recursion to greater elements, and --BLOB
|
(cond ((not result))
|
||||||
;; isn't one.
|
(first-match (throw 'first-match result))
|
||||||
((and (eq --category 'greater-elements)
|
(t (push result --acc)))))
|
||||||
(not (memq --type org-element-greater-elements)))
|
;; If --BLOB has a secondary string that can
|
||||||
(funcall --check-blob --type types fun --blob))
|
;; contain objects with their type among TYPES,
|
||||||
;; Limiting recursion to elements, and --BLOB only
|
;; look into that string.
|
||||||
;; contains objects.
|
(when (memq --type --restricts)
|
||||||
((and (eq --category 'elements) (eq --type 'paragraph))
|
(funcall
|
||||||
(funcall --check-blob --type types fun --blob))
|
--walk-tree
|
||||||
;; No limitation on recursion, but --BLOB hasn't
|
`(org-data
|
||||||
;; got a recursive type.
|
nil
|
||||||
((and (eq --category 'objects)
|
,@(org-element-property
|
||||||
(not (or (eq --type 'paragraph)
|
(cdr (assq --type org-element-secondary-value-alist))
|
||||||
(memq --type org-element-greater-elements)
|
--blob))))
|
||||||
(memq --type org-element-recursive-objects))))
|
;; Now determine if a recursion into --BLOB is
|
||||||
(funcall --check-blob --type types fun --blob))
|
;; possible. If so, do it.
|
||||||
;; Recursion is possible and allowed: Maybe apply
|
(when (or (memq --type org-element-recursive-objects)
|
||||||
;; FUN to --BLOB, then move into it.
|
(and (memq --type org-element-all-elements)
|
||||||
(t (funcall --check-blob --type types fun --blob)
|
(not (eq --category 'elements)))
|
||||||
|
(and (memq --type org-element-greater-elements)
|
||||||
|
(not (eq --category 'greater-elements))))
|
||||||
(funcall --walk-tree --blob)))))
|
(funcall --walk-tree --blob)))))
|
||||||
(org-element-contents --data))))))
|
(org-element-contents --data))))))
|
||||||
(catch 'first-match
|
(catch 'first-match
|
||||||
|
|
Loading…
Reference in New Issue