From: Lute Kamstra Date: Thu, 21 Apr 2005 21:18:29 +0000 (+0000) Subject: (assq-delete-all): New implementation that is linear, not quadratic. X-Git-Tag: ttn-vms-21-2-B4~850 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=2c7b5da17afabf02cd58a5530dcfbdb4459ed62c;p=emacs.git (assq-delete-all): New implementation that is linear, not quadratic. Suggested by David Kastrup . (rassq-delete-all): New function. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index d4a67928ab7..e242caae13f 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,5 +1,9 @@ 2005-04-21 Lute Kamstra + * subr.el (assq-delete-all): New implementation that is linear, + not quadratic. Suggested by David Kastrup . + (rassq-delete-all): New function. + * menu-bar.el (menu-bar-options-save, menu-bar-showhide-menu): Add size-indication-mode. diff --git a/lisp/subr.el b/lisp/subr.el index 7330f1d6ddf..f791faffd91 100644 --- a/lisp/subr.el +++ b/lisp/subr.el @@ -2376,15 +2376,34 @@ macros." (eq (car-safe object) 'lambda))) (defun assq-delete-all (key alist) - "Delete from ALIST all elements whose car is KEY. + "Delete from ALIST all elements whose car is `eq' to KEY. Return the modified alist. Elements of ALIST that are not conses are ignored." - (let ((tail alist)) - (while tail - (if (and (consp (car tail)) (eq (car (car tail)) key)) - (setq alist (delq (car tail) alist))) - (setq tail (cdr tail))) - alist)) + (while (and (consp (car alist)) + (eq (car (car alist)) key)) + (setq alist (cdr alist))) + (let ((tail alist) tail-cdr) + (while (setq tail-cdr (cdr tail)) + (if (and (consp (car tail-cdr)) + (eq (car (car tail-cdr)) key)) + (setcdr tail (cdr tail-cdr)) + (setq tail tail-cdr)))) + alist) + +(defun rassq-delete-all (value alist) + "Delete from ALIST all elements whose cdr is `eq' to VALUE. +Return the modified alist. +Elements of ALIST that are not conses are ignored." + (while (and (consp (car alist)) + (eq (cdr (car alist)) value)) + (setq alist (cdr alist))) + (let ((tail alist) tail-cdr) + (while (setq tail-cdr (cdr tail)) + (if (and (consp (car tail-cdr)) + (eq (cdr (car tail-cdr)) value)) + (setcdr tail (cdr tail-cdr)) + (setq tail tail-cdr)))) + alist) (defun make-temp-file (prefix &optional dir-flag suffix) "Create a temporary file.