Discussion:
What does the argument list in C-h f delete-duplicates mean?
Alan Mackenzie
2015-06-05 12:11:00 UTC
Permalink
Hello, XEmacs.

When I do C-h f delete-duplicates, the resulting text starts off:

`delete-duplicates' is a built-in function
-- loaded from "/home/acm/emacs/xemacs.hg/xemacs/src/sequence.c"
(delete-duplicates SEQUENCE &key (TEST #'eql) (KEY #'identity) (START 0) END FROM-END TEST-NOT)

. What does this mean? In particular, I have never seen parenthesised
expressions, such as "(TEST #'eql)" inside an argument list before. The
XEmacs manual (page "Name Help") doesn't explain this. Are TEST, KEY
and START some sort of optional parameters, or what?

Thanks for the elucidation!
--
Alan Mackenzie (Nuremberg, Germany).
Aidan Kehoe
2015-06-05 14:27:45 UTC
Permalink
Hello Alan,
Post by Alan Mackenzie
`delete-duplicates' is a built-in function
-- loaded from "/home/acm/emacs/xemacs.hg/xemacs/src/sequence.c"
(delete-duplicates SEQUENCE &key (TEST #'eql) (KEY #'identity) (START 0) END FROM-END TEST-NOT)
. What does this mean? In particular, I have never seen parenthesised
expressions, such as "(TEST #'eql)" inside an argument list before. The
XEmacs manual (page "Name Help") doesn't explain this. Are TEST, KEY
and START some sort of optional parameters, or what?
Yes, they’re optional keyword parameters, as also used, for example, by
#'make-hash-table. The docstring for defun* goes into more detail on the
syntax.

I have been considering moving the extra functionality offered by defun* into
defun, but there are possible bootstrapping complications; if I do it I’ll
move the relevant documentation into the defun docstring, if I don’t I’ll add
a cross-reference to all the C functions that use keywords. Thanks for
pointing out the weakness in our docs!

Best,

Aidan
--
‘Tramadol is further fed to cattle […] when working them […] (as draft
animals) so that the animals do not get tired quickly. …’
— Angewandte Chemie, Sept 2014, describing the social context of
(synthetic) tramadol having been found in Cameroon tree roots.
Alan Mackenzie
2015-06-05 18:30:47 UTC
Permalink
Hello, Aidan.
Post by Aidan Kehoe
Hello Alan,
Post by Alan Mackenzie
`delete-duplicates' is a built-in function
-- loaded from "/home/acm/emacs/xemacs.hg/xemacs/src/sequence.c"
(delete-duplicates SEQUENCE &key (TEST #'eql) (KEY #'identity) (START 0) END FROM-END TEST-NOT)
. What does this mean? In particular, I have never seen parenthesised
expressions, such as "(TEST #'eql)" inside an argument list before. The
XEmacs manual (page "Name Help") doesn't explain this. Are TEST, KEY
and START some sort of optional parameters, or what?
Yes, they’re optional keyword parameters, as also used, for example, by
#'make-hash-table. The docstring for defun* goes into more detail on the
syntax.
Thanks, that's helpful.
Post by Aidan Kehoe
I have been considering moving the extra functionality offered by defun* into
defun, but there are possible bootstrapping complications; if I do it I’ll
move the relevant documentation into the defun docstring, if I don’t I’ll add
a cross-reference to all the C functions that use keywords. Thanks for
pointing out the weakness in our docs!
Best,
Aidan
--
Alan Mackenzie (Nuremberg, Germany).
Loading...