summaryrefslogtreecommitdiff
path: root/lisp/emacs-lisp/ewoc.el
diff options
context:
space:
mode:
authorThien-Thi Nguyen <ttn@gnuvola.org>2006-05-27 10:10:35 +0000
committerThien-Thi Nguyen <ttn@gnuvola.org>2006-05-27 10:10:35 +0000
commit63910b2311ccfd008de65a72e27eebc20033d088 (patch)
treea334d508adad88a8cfd6423e144fd758629604cd /lisp/emacs-lisp/ewoc.el
parentec491f90014dd3e6c15cafba0570fe67355c1413 (diff)
downloademacs-63910b2311ccfd008de65a72e27eebc20033d088.tar.gz
emacs-63910b2311ccfd008de65a72e27eebc20033d088.tar.bz2
emacs-63910b2311ccfd008de65a72e27eebc20033d088.zip
(ewoc--node-branch): Merge into unique caller.
Diffstat (limited to 'lisp/emacs-lisp/ewoc.el')
-rw-r--r--lisp/emacs-lisp/ewoc.el12
1 files changed, 4 insertions, 8 deletions
diff --git a/lisp/emacs-lisp/ewoc.el b/lisp/emacs-lisp/ewoc.el
index a02425b0cec..1e85ef813fc 100644
--- a/lisp/emacs-lisp/ewoc.el
+++ b/lisp/emacs-lisp/ewoc.el
@@ -139,15 +139,10 @@
(defvar ewoc--current-dll)
(defstruct (ewoc--node
- (:type vector) ;required for ewoc--node-branch hack
+ (:type vector) ;ewoc--node-nth needs this
(:constructor ewoc--node-create (start-marker data)))
left right data start-marker)
-(defalias 'ewoc--node-branch 'aref
- "Get the left (CHILD=0) or right (CHILD=1) child of the NODE.
-
-\(fn NODE CHILD)")
-
(defun ewoc--node-next (node)
"Return the node after NODE, or nil if NODE is the last node."
(let ((R (ewoc--node-right node)))
@@ -164,13 +159,14 @@ N counts from zero. If N is negative, return the -(N+1)th last element.
If N is out of range, return nil.
Thus, (ewoc--node-nth 0) returns the first node,
and (ewoc--node-nth -1) returns the last node."
+ ;; Presuming a node is ":type vector", starting with `left' and `right':
;; Branch 0 ("follow left pointer") is used when n is negative.
;; Branch 1 ("follow right pointer") is used otherwise.
(let* ((branch (if (< n 0) 0 1))
- (node (ewoc--node-branch ewoc--current-dll branch)))
+ (node (aref ewoc--current-dll branch)))
(if (< n 0) (setq n (- -1 n)))
(while (and (not (eq ewoc--current-dll node)) (> n 0))
- (setq node (ewoc--node-branch node branch))
+ (setq node (aref node branch))
(setq n (1- n)))
(unless (eq ewoc--current-dll node) node)))