org-element: Refactor object parsing

* lisp/org-element.el (org-element--get-next-object-candidates):
  Rewrite function to simplify algorithm.
(org-element-context, (org-element--parse-elements)): Apply
changes.
* lisp/org.el (org-fill-paragraph): Apply changes.
This commit is contained in:
Nicolas Goaziou 2013-02-25 21:28:18 +01:00
parent be9d3bc3a7
commit e024beaa7e
2 changed files with 34 additions and 42 deletions

View File

@ -4255,9 +4255,9 @@ Elements are accumulated into ACC."
Objects are accumulated in ACC.
RESTRICTION is a list of object types which are allowed in the
current object."
(let (candidates)
RESTRICTION is a list of object successors which are allowed in
the current object."
(let ((candidates 'initial))
(save-excursion
(goto-char beg)
(while (and (< (point) end)
@ -4309,44 +4309,35 @@ current object."
"Return an alist of candidates for the next object.
LIMIT bounds the search, and RESTRICTION narrows candidates to
some object types.
some object successors.
Return value is an alist whose CAR is position and CDR the object
type, as a symbol.
OBJECTS is the previous candidates alist. If it is set to
`initial', no search has been done before, and all symbols in
RESTRICTION should be looked after.
OBJECTS is the previous candidates alist."
;; Filter out any object found but not belonging to RESTRICTION.
(setq objects
(org-remove-if-not
Return value is an alist whose CAR is the object type and CDR its
beginning position."
(delq
nil
(if (eq objects 'initial)
;; When searching for the first time, look for every successor
;; allowed in RESTRICTION.
(mapcar
(lambda (res)
(funcall (intern (format "org-element-%s-successor" res)) limit))
restriction)
;; Focus on objects returned during last search. Keep those
;; still after point. Search again objects before it.
(mapcar
(lambda (obj)
(let ((type (car obj)))
(memq (or (cdr (assq type org-element-object-successor-alist))
type)
restriction)))
objects))
(let (next-candidates types-to-search)
;; If no previous result, search every object type in RESTRICTION.
;; Otherwise, keep potential candidates (old objects located after
;; point) and ask to search again those which had matched before.
(if (not objects) (setq types-to-search restriction)
(mapc (lambda (obj)
(if (< (cdr obj) (point)) (push (car obj) types-to-search)
(push obj next-candidates)))
objects))
;; Call the appropriate successor function for each type to search
;; and accumulate matches.
(mapc
(lambda (type)
(let* ((successor-fun
(intern
(format "org-element-%s-successor"
(or (cdr (assq type org-element-object-successor-alist))
type))))
(obj (funcall successor-fun limit)))
(and obj (push obj next-candidates))))
types-to-search)
;; Return alist.
next-candidates))
(if (>= (cdr obj) (point)) obj
(let* ((type (car obj))
(succ (or (cdr (assq type org-element-object-successor-alist))
type)))
(and succ
(funcall (intern (format "org-element-%s-successor" succ))
limit)))))
objects))))
@ -4776,7 +4767,7 @@ Providing it allows for quicker computation."
element
(let ((restriction (org-element-restriction type))
(parent element)
candidates)
(candidates 'initial))
(catch 'exit
(while (setq candidates (org-element--get-next-object-candidates
end restriction candidates))
@ -4810,6 +4801,7 @@ Providing it allows for quicker computation."
(org-element-put-property object :parent parent)
(setq parent object
restriction (org-element-restriction object)
candidates 'initial
end cend)))))))
parent))))))

View File

@ -21741,7 +21741,7 @@ meant to be filled."
(declare-function message-goto-body "message" ())
(defvar message-cite-prefix-regexp) ; From message.el
(defvar org-element-all-objects) ; From org-element.el
(defvar org-element-all-successors) ; From org-element.el
(defun org-fill-paragraph (&optional justify)
"Fill element at point, when applicable.
@ -21819,7 +21819,7 @@ a footnote definition, try to fill the first paragraph within."
(cons beg
(org-element-map
(org-element--parse-objects
beg end nil org-element-all-objects)
beg end nil org-element-all-successors)
'line-break
(lambda (lb) (org-element-property :end lb)))))))
t)))