unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#75170: add-to-alist: new function
@ 2024-12-29  5:33 Roland Winkler
  2024-12-29  6:34 ` Roland Winkler
                   ` (5 more replies)
  0 siblings, 6 replies; 63+ messages in thread
From: Roland Winkler @ 2024-12-29  5:33 UTC (permalink / raw)
  To: 75170

On Mon, 12 Feb 2001, Stephen Gildea wrote:
> Here's a handy function I'd like to see added to Emacs 21: add-to-alist.
> It is like add-to-list, but it looks only at the cars of the element to
> be added and the existing list elements when considering a match.  An
> additional optional argument to add-to-alist says what to do if the car
> matches but the cdr does not.
> 
> I use this function in my .emacs to update values in alists such as
> default-frame-alist and auto-mode-alist; I'm sure it has other uses.
> My goal in proposing this function is to allow .emacs files to be
> shorter and easier to write.  The functions add-to-list and add-hook
> were important steps in that direction; here is another such step.
> 
> 
> (defun add-to-alist (alist-var elt-cons &optional no-replace)
>   "Add to the value of ALIST-VAR an element ELT-CONS if it isn't there yet.
> If an element with the same car as the car of ELT-CONS is already present,
> replace it with ELT-CONS unless NO-REPLACE is non-nil; if a matching
> element is not already present, add ELT-CONS to the front of the alist.
> The test for presence of the car of ELT-CONS is done with `equal'."
>   (let ((existing-element (assoc (car elt-cons) (symbol-value alist-var))))
>     (if existing-element
>         (or no-replace
>             (rplacd existing-element (cdr elt-cons)))
>       (set alist-var (cons elt-cons (symbol-value alist-var))))))
> 
> 
> The no-replace argument is useful for setting auto-mode-alist when you
> don't know whether Emacs supports a particular programming language.
> For example, the following suppresses using text-mode for m4 files in
> Emacs 19 but doesn't override using m4-mode in Emacs 20.
> 
> (setq default-major-mode 'text-mode)
> (add-to-alist 'auto-mode-alist '("\\.m4\\'" . fundamental-mode) t)

While I thought about a function add-to-alist I found the above thread
from 24 years ago.  Stephen's message describes nicely when such a
function can be useful.  I suggest to add such a function to subr.el.

The code below follows the conventions of add-to-list.

(defun add-to-alist (alist-var elt-cons &optional no-replace append compare-fn)
  "Add ELT-CONS to the value of ALIST-VAR if it isn't there yet.
If an element with the same car as the car of ELT-CONS is already present
in ALIST-VAR, replace it with ELT-CONS unless NO-REPLACE is non-nil.
If a matching element is not yet present, add ELT-CONS at the beginning
of ALIST-VAR.  If APPEND is non-nil, add ELT-CONS at the end of ALIST-VAR.
The test for presence of ELT-CONS is done with `equal', or with COMPARE-FN
if that's non-nil.
ALIST-VAR should not refer to a lexical variable.

The return value is the new value of ALIST-VAR."
  (let ((elt (cond ((or (null compare-fn) (eq compare-fn #'equal))
	            (assoc (car elt-cons) (symbol-value alist-var)))
                   ((eq compare-fn #'eq)
	            (assq (car elt-cons) (symbol-value alist-var)))
                   (t
	            (let ((alist (symbol-value alist-var))
                          (key (car elt-cons)))
	              (while (and alist
                                  (not (funcall compare-fn key (caar alist))))
	                (setq alist (cdr alist)))
                      (car alist))))))
    (if elt
        (progn
          (unless no-replace
            (setcdr elt (cdr elt-cons)))
          (symbol-value alist-var))
      (set alist-var
	   (if append
	       (append (symbol-value alist-var) (list elt-cons))
	     (cons elt-cons (symbol-value alist-var)))))))





^ permalink raw reply	[flat|nested] 63+ messages in thread

end of thread, other threads:[~2025-01-23  5:51 UTC | newest]

Thread overview: 63+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-12-29  5:33 bug#75170: add-to-alist: new function Roland Winkler
2024-12-29  6:34 ` Roland Winkler
2024-12-29  7:54   ` Juri Linkov
2024-12-29 14:54     ` Roland Winkler
2024-12-29  7:33 ` Eshel Yaron via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-12-29  7:50 ` Eli Zaretskii
2024-12-29 14:50   ` Roland Winkler
2025-01-05 15:21     ` Eli Zaretskii
2025-01-18  9:33       ` Eli Zaretskii
     [not found]         ` <87ed0xd8t5.fsf@gmail.com>
2025-01-20 19:12           ` Roland Winkler
2025-01-20 20:41             ` Stefan Kangas
2025-01-20 21:03               ` Roland Winkler
2025-01-20 21:40                 ` Stefan Kangas
2025-01-21  8:22                   ` Robert Pluim
2025-01-21  9:06                     ` Alfred M. Szmidt
2025-01-21  9:12                       ` Stefan Kangas
2025-01-21  9:35                         ` Robert Pluim
2025-01-21 10:33                           ` Alfred M. Szmidt
2025-01-21 10:53                             ` Robert Pluim
2025-01-21 11:34                               ` Alfred M. Szmidt
2025-01-21 10:33                         ` Alfred M. Szmidt
2025-01-21 10:57                           ` Robert Pluim
2025-01-21 13:09                             ` Alfred M. Szmidt
2025-01-21 13:09                             ` Alfred M. Szmidt
2025-01-21 18:50                             ` Stefan Kangas
2025-01-22  8:30                               ` Robert Pluim
2025-01-22 12:38                                 ` Arash Esbati
2025-01-22 15:06                                   ` Eli Zaretskii
2025-01-22 15:50                                     ` Roland Winkler
2025-01-22 16:08                                       ` Alfred M. Szmidt
2025-01-22 21:56                                     ` Arash Esbati
2025-01-23  5:51                                       ` Alfred M. Szmidt
2025-01-21 18:47                     ` Stefan Kangas
2025-01-21 19:15                       ` Eli Zaretskii
2025-01-21 19:21                         ` Roland Winkler
2025-01-21 19:35                           ` Eli Zaretskii
2025-01-22  5:09                             ` Roland Winkler
2025-01-21 19:41                           ` Stefan Kangas
2025-01-21 20:30                             ` Eli Zaretskii
2025-01-21 20:34                               ` Stefan Kangas
2025-01-21 20:34                                 ` Stefan Kangas
2025-01-22 14:05                                   ` Eli Zaretskii
2025-01-21 20:57                           ` Drew Adams via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-19 11:23       ` Stefan Kangas
2025-01-19 15:14         ` Thierry Volpiatto
2025-01-19 21:21           ` Roland Winkler
2025-01-20  0:29         ` Michael Heerdegen via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-20  0:53         ` Michael Heerdegen via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-19  2:20     ` Michael Heerdegen via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-19  6:17       ` Roland Winkler
2025-01-19 14:34         ` Roland Winkler
2025-01-19 19:35         ` Juri Linkov
2025-01-19 21:17           ` Roland Winkler
2025-01-20  0:47             ` Michael Heerdegen via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-20  1:06         ` Michael Heerdegen via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-20  3:41           ` Roland Winkler
     [not found]             ` <871pwxha95.fsf@web.de>
2025-01-20 19:08               ` Roland Winkler
2025-01-20 20:53                 ` Michael Heerdegen via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-21 21:11 ` Stephen Gildea
2025-01-21 22:53   ` Drew Adams via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-21 23:08 ` Stefan Monnier via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-22  5:09   ` Roland Winkler
2025-01-22  3:57 ` Stephen Gildea

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).