GNU bug report logs -
#12854
24.2.50; `display-buffer-alist': conditions are not handled as documented
Previous Next
Reported by: michael_heerdegen <at> web.de
Date: Sat, 10 Nov 2012 19:19:02 UTC
Severity: normal
Found in version 24.2.50
Done: martin rudalics <rudalics <at> gmx.at>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
> (defun display-buffer-assq-regexp (buffer-name alist)
> "Retrieve ALIST entry corresponding to BUFFER-NAME."
> (catch 'match
> (dolist (entry alist)
> (let ((key (car entry)))
> (when (or (and (stringp key)
> (string-match-p key buffer-name))
> (and (symbolp key) (functionp key)
> (funcall key buffer-name alist)))
> (throw 'match (cdr entry)))))))
>
>
> Obviously, two things are wrong here:
>
> (1) If CONDITION is a function, it currently must be a symbol. I don't
> see why lambda expressions should be forbidden. The user should not
> need to use defun only to be able specify an argument.
I see no problems with removing the (symbolp key) check.
> (2) If CONDITION is a function, it takes _two_ arguments: a buffer
> _name_ (not a buffer) _and_ an alist. That should be clarified in the
> docstring.
IIUC the correct solution is to not pass ALIST to the function specified
by `key'.
martin
This bug report was last modified 12 years and 273 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.