diff options
author | Kim F. Storm <storm@cua.dk> | 2005-06-14 08:14:06 +0000 |
---|---|---|
committer | Kim F. Storm <storm@cua.dk> | 2005-06-14 08:14:06 +0000 |
commit | 8da6c2f88823000244c6f8d2c5eb6d199bccbae6 (patch) | |
tree | c489bdb8c68d95233d7f002d30ca844399c1dfa4 /lisp/subr.el | |
parent | 47d4e709887e5f7f9fdaf1e9961b2f806dfb827c (diff) | |
download | emacs-8da6c2f88823000244c6f8d2c5eb6d199bccbae6.tar.gz |
(add-to-ordered-list): Rework to use list-order property of list-var.
Diffstat (limited to 'lisp/subr.el')
-rw-r--r-- | lisp/subr.el | 41 |
1 files changed, 26 insertions, 15 deletions
diff --git a/lisp/subr.el b/lisp/subr.el index fb48e578157..b67fc14a010 100644 --- a/lisp/subr.el +++ b/lisp/subr.el @@ -963,25 +963,36 @@ other hooks, such as major mode hooks, can do the job." The test for presence of ELEMENT is done with `equal'. The resulting list is reordered so that the elements are in the -order given by each element's `list-order' property (a number). -Elements which are not symbols, and symbol elements without a -numeric `lisp-order' property are placed at the end of the list. +order given by each element's numeric list order. Elements which +are not symbols, and symbol elements without a numeric list order +are placed at the end of the list. If the third optional argument ORDER is non-nil and ELEMENT is -a symbol, set the symbol's `list-order' property to the given value. +a symbol, set the symbol's list order to the given value. + +The list order for each symbol is stored in LIST-VAR's +`list-order' property. The return value is the new value of LIST-VAR." - (when (and order (symbolp element)) - (put element 'list-order (and (numberp order) order))) - (add-to-list list-var element) - (set list-var (sort (symbol-value list-var) - (lambda (a b) - (let ((oa (and (symbolp a) (get a 'list-order))) - (ob (and (symbolp b) (get b 'list-order)))) - (cond - ((not oa) nil) - ((not ob) t) - (t (< oa ob)))))))) + (let* ((ordering (get list-var 'list-order)) + (cur (and (symbolp element) (assq element ordering)))) + (when order + (unless (symbolp element) + (error "cannot specify order for non-symbols")) + (if cur + (setcdr cur order) + (setq cur (cons element order)) + (setq ordering (cons cur ordering)) + (put list-var 'list-order ordering))) + (add-to-list list-var element) + (set list-var (sort (symbol-value list-var) + (lambda (a b) + (let ((oa (and (symbolp a) (assq a ordering))) + (ob (and (symbolp b) (assq b ordering)))) + (cond + ((not oa) nil) + ((not ob) t) + (t (< (cdr oa) (cdr ob)))))))))) ;;; Load history |