Mercurial > emacs
diff lispref/lists.texi @ 6558:fa8ff07eaafc
Initial revision
| author | Richard M. Stallman <rms@gnu.org> |
|---|---|
| date | Mon, 28 Mar 1994 20:21:44 +0000 |
| parents | |
| children | 08d61ef58d13 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/lispref/lists.texi Mon Mar 28 20:21:44 1994 +0000 @@ -0,0 +1,1384 @@ +@c -*-texinfo-*- +@c This is part of the GNU Emacs Lisp Reference Manual. +@c Copyright (C) 1990, 1991, 1992, 1993, 1994 Free Software Foundation, Inc. +@c See the file elisp.texi for copying conditions. +@setfilename ../info/lists +@node Lists, Sequences Arrays Vectors, Strings and Characters, Top +@chapter Lists +@cindex list +@cindex element (of list) + + A @dfn{list} represents a sequence of zero or more elements (which may +be any Lisp objects). The important difference between lists and +vectors is that two or more lists can share part of their structure; in +addition, you can insert or delete elements in a list without copying +the whole list. + +@menu +* Cons Cells:: How lists are made out of cons cells. +* Lists as Boxes:: Graphical notation to explain lists. +* List-related Predicates:: Is this object a list? Comparing two lists. +* List Elements:: Extracting the pieces of a list. +* Building Lists:: Creating list structure. +* Modifying Lists:: Storing new pieces into an existing list. +* Sets And Lists:: A list can represent a finite mathematical set. +* Association Lists:: A list can represent a finite relation or mapping. +@end menu + +@node Cons Cells +@section Lists and Cons Cells +@cindex lists and cons cells +@cindex @code{nil} and lists + + Lists in Lisp are not a primitive data type; they are built up from +@dfn{cons cells}. A cons cell is a data object which represents an ordered +pair. It records two Lisp objects, one labeled as the @sc{car}, and the +other labeled as the @sc{cdr}. These names are traditional; @sc{cdr} is +pronounced ``could-er.'' + + A list is a series of cons cells chained together, one cons cell per +element of the list. By convention, the @sc{car}s of the cons cells are +the elements of the list, and the @sc{cdr}s are used to chain the list: +the @sc{cdr} of each cons cell is the following cons cell. The @sc{cdr} +of the last cons cell is @code{nil}. This asymmetry between the +@sc{car} and the @sc{cdr} is entirely a matter of convention; at the +level of cons cells, the @sc{car} and @sc{cdr} slots have the same +characteristics. + + The symbol @code{nil} is considered a list as well as a symbol; it is +the list with no elements. For convenience, the symbol @code{nil} is +considered to have @code{nil} as its @sc{cdr} (and also as its +@sc{car}). + + The @sc{cdr} of any nonempty list @var{l} is a list containing all the +elements of @var{l} except the first. + +@node Lists as Boxes +@comment node-name, next, previous, up +@section Lists as Linked Pairs of Boxes +@cindex box representation for lists +@cindex lists represented as boxes +@cindex cons cell as box + + A cons cell can be illustrated as a pair of boxes. The first box +represents the @sc{car} and the second box represents the @sc{cdr}. +Here is an illustration of the two-element list, @code{(tulip lily)}, +made from two cons cells: + +@example +@group + --------------- --------------- +| car | cdr | | car | cdr | +| tulip | o---------->| lily | nil | +| | | | | | + --------------- --------------- +@end group +@end example + + Each pair of boxes represents a cons cell. Each box ``refers to'', +``points to'' or ``contains'' a Lisp object. (These terms are +synonymous.) The first box, which is the @sc{car} of the first cons +cell, contains the symbol @code{tulip}. The arrow from the @sc{cdr} of +the first cons cell to the second cons cell indicates that the @sc{cdr} +of the first cons cell points to the second cons cell. + + The same list can be illustrated in a different sort of box notation +like this: + +@example +@group + ___ ___ ___ ___ + |___|___|--> |___|___|--> nil + | | + | | + --> tulip --> lily +@end group +@end example + + Here is a more complex illustration, showing the three-element list, +@code{((pine needles) oak maple)}, the first element of which is a +two-element list: + +@example +@group + ___ ___ ___ ___ ___ ___ + |___|___|--> |___|___|--> |___|___|--> nil + | | | + | | | + | --> oak --> maple + | + | ___ ___ ___ ___ + --> |___|___|--> |___|___|--> nil + | | + | | + --> pine --> needles +@end group +@end example + + The same list represented in the first box notation looks like this: + +@example +@group + -------------- -------------- -------------- +| car | cdr | | car | cdr | | car | cdr | +| o | o------->| oak | o------->| maple | nil | +| | | | | | | | | | + -- | --------- -------------- -------------- + | + | + | -------------- ---------------- + | | car | cdr | | car | cdr | + ------>| pine | o------->| needles | nil | + | | | | | | + -------------- ---------------- +@end group +@end example + + @xref{List Type}, for the read and print syntax of lists, and for more +``box and arrow'' illustrations of lists. + +@node List-related Predicates +@section Predicates on Lists + + The following predicates test whether a Lisp object is an atom, is a +cons cell or is a list, or whether it is the distinguished object +@code{nil}. (Many of these predicates can be defined in terms of the +others, but they are used so often that it is worth having all of them.) + +@defun consp object +This function returns @code{t} if @var{object} is a cons cell, @code{nil} +otherwise. @code{nil} is not a cons cell, although it @emph{is} a list. +@end defun + +@defun atom object +@cindex atoms +This function returns @code{t} if @var{object} is an atom, @code{nil} +otherwise. All objects except cons cells are atoms. The symbol +@code{nil} is an atom and is also a list; it is the only Lisp object +which is both. + +@example +(atom @var{object}) @equiv{} (not (consp @var{object})) +@end example +@end defun + +@defun listp object +This function returns @code{t} if @var{object} is a cons cell or +@code{nil}. Otherwise, it returns @code{nil}. + +@example +@group +(listp '(1)) + @result{} t +@end group +@group +(listp '()) + @result{} t +@end group +@end example +@end defun + +@defun nlistp object +This function is the opposite of @code{listp}: it returns @code{t} if +@var{object} is not a list. Otherwise, it returns @code{nil}. + +@example +(listp @var{object}) @equiv{} (not (nlistp @var{object})) +@end example +@end defun + +@defun null object +This function returns @code{t} if @var{object} is @code{nil}, and +returns @code{nil} otherwise. This function is identical to @code{not}, +but as a matter of clarity we use @code{null} when @var{object} is +considered a list and @code{not} when it is considered a truth value +(see @code{not} in @ref{Combining Conditions}). + +@example +@group +(null '(1)) + @result{} nil +@end group +@group +(null '()) + @result{} t +@end group +@end example +@end defun + +@need 1000 + +@node List Elements +@section Accessing Elements of Lists +@cindex list elements + +@defun car cons-cell +This function returns the value pointed to by the first pointer of the +cons cell @var{cons-cell}. Expressed another way, this function +returns the @sc{car} of @var{cons-cell}. + +As a special case, if @var{cons-cell} is @code{nil}, then @code{car} +is defined to return @code{nil}; therefore, any list is a valid argument +for @code{car}. An error is signaled if the argument is not a cons cell +or @code{nil}. + +@example +@group +(car '(a b c)) + @result{} a +@end group +@group +(car '()) + @result{} nil +@end group +@end example +@end defun + +@defun cdr cons-cell +This function returns the value pointed to by the second pointer of +the cons cell @var{cons-cell}. Expressed another way, this function +returns the @sc{cdr} of @var{cons-cell}. + +As a special case, if @var{cons-cell} is @code{nil}, then @code{cdr} +is defined to return @code{nil}; therefore, any list is a valid argument +for @code{cdr}. An error is signaled if the argument is not a cons cell +or @code{nil}. + +@example +@group +(cdr '(a b c)) + @result{} (b c) +@end group +@group +(cdr '()) + @result{} nil +@end group +@end example +@end defun + +@defun car-safe object +This function lets you take the @sc{car} of a cons cell while avoiding +errors for other data types. It returns the @sc{car} of @var{object} if +@var{object} is a cons cell, @code{nil} otherwise. This is in contrast +to @code{car}, which signals an error if @var{object} is not a list. + +@example +@group +(car-safe @var{object}) +@equiv{} +(let ((x @var{object})) + (if (consp x) + (car x) + nil)) +@end group +@end example +@end defun + +@defun cdr-safe object +This function lets you take the @sc{cdr} of a cons cell while +avoiding errors for other data types. It returns the @sc{cdr} of +@var{object} if @var{object} is a cons cell, @code{nil} otherwise. +This is in contrast to @code{cdr}, which signals an error if +@var{object} is not a list. + +@example +@group +(cdr-safe @var{object}) +@equiv{} +(let ((x @var{object})) + (if (consp x) + (cdr x) + nil)) +@end group +@end example +@end defun + +@defun nth n list +This function returns the @var{n}th element of @var{list}. Elements +are numbered starting with zero, so the @sc{car} of @var{list} is +element number zero. If the length of @var{list} is @var{n} or less, +the value is @code{nil}. + +If @var{n} is negative, @code{nth} returns the first element of +@var{list}. + +@example +@group +(nth 2 '(1 2 3 4)) + @result{} 3 +@end group +@group +(nth 10 '(1 2 3 4)) + @result{} nil +@end group +@group +(nth -3 '(1 2 3 4)) + @result{} 1 + +(nth n x) @equiv{} (car (nthcdr n x)) +@end group +@end example +@end defun + +@defun nthcdr n list +This function returns the @var{n}th @sc{cdr} of @var{list}. In other +words, it removes the first @var{n} links of @var{list} and returns +what follows. + +If @var{n} is zero or negative, @code{nthcdr} returns all of +@var{list}. If the length of @var{list} is @var{n} or less, +@code{nthcdr} returns @code{nil}. + +@example +@group +(nthcdr 1 '(1 2 3 4)) + @result{} (2 3 4) +@end group +@group +(nthcdr 10 '(1 2 3 4)) + @result{} nil +@end group +@group +(nthcdr -3 '(1 2 3 4)) + @result{} (1 2 3 4) +@end group +@end example +@end defun + +@node Building Lists +@comment node-name, next, previous, up +@section Building Cons Cells and Lists +@cindex cons cells +@cindex building lists + + Many functions build lists, as lists reside at the very heart of Lisp. +@code{cons} is the fundamental list-building function; however, it is +interesting to note that @code{list} is used more times in the source +code for Emacs than @code{cons}. + +@defun cons object1 object2 +This function is the fundamental function used to build new list +structure. It creates a new cons cell, making @var{object1} the +@sc{car}, and @var{object2} the @sc{cdr}. It then returns the new cons +cell. The arguments @var{object1} and @var{object2} may be any Lisp +objects, but most often @var{object2} is a list. + +@example +@group +(cons 1 '(2)) + @result{} (1 2) +@end group +@group +(cons 1 '()) + @result{} (1) +@end group +@group +(cons 1 2) + @result{} (1 . 2) +@end group +@end example + +@cindex consing +@code{cons} is often used to add a single element to the front of a +list. This is called @dfn{consing the element onto the list}. For +example: + +@example +(setq list (cons newelt list)) +@end example + +Note that there is no conflict between the variable named @code{list} +used in this example and the function named @code{list} described below; +any symbol can serve both purposes. +@end defun + +@defun list &rest objects +This function creates a list with @var{objects} as its elements. The +resulting list is always @code{nil}-terminated. If no @var{objects} +are given, the empty list is returned. + +@example +@group +(list 1 2 3 4 5) + @result{} (1 2 3 4 5) +@end group +@group +(list 1 2 '(3 4 5) 'foo) + @result{} (1 2 (3 4 5) foo) +@end group +@group +(list) + @result{} nil +@end group +@end example +@end defun + +@defun make-list length object +This function creates a list of length @var{length}, in which all the +elements have the identical value @var{object}. Compare +@code{make-list} with @code{make-string} (@pxref{Creating Strings}). + +@example +@group +(make-list 3 'pigs) + @result{} (pigs pigs pigs) +@end group +@group +(make-list 0 'pigs) + @result{} nil +@end group +@end example +@end defun + +@defun append &rest sequences +@cindex copying lists +This function returns a list containing all the elements of +@var{sequences}. The @var{sequences} may be lists, vectors, or strings. +All arguments except the last one are copied, so none of them are +altered. + + The final argument to @code{append} may be any object but it is +typically a list. The final argument is not copied or converted; it +becomes part of the structure of the new list. + + Here is an example: + +@example +@group +(setq trees '(pine oak)) + @result{} (pine oak) +(setq more-trees (append '(maple birch) trees)) + @result{} (maple birch pine oak) +@end group + +@group +trees + @result{} (pine oak) +more-trees + @result{} (maple birch pine oak) +@end group +@group +(eq trees (cdr (cdr more-trees))) + @result{} t +@end group +@end example + +You can see what happens by looking at a box diagram. The variable +@code{trees} is set to the list @code{(pine oak)} and then the variable +@code{more-trees} is set to the list @code{(maple birch pine oak)}. +However, the variable @code{trees} continues to refer to the original +list: + +@smallexample +@group +more-trees trees +| | +| ___ ___ ___ ___ -> ___ ___ ___ ___ + --> |___|___|--> |___|___|--> |___|___|--> |___|___|--> nil + | | | | + | | | | + --> maple -->birch --> pine --> oak +@end group +@end smallexample + +An empty sequence contributes nothing to the value returned by +@code{append}. As a consequence of this, a final @code{nil} argument +forces a copy of the previous argument. + +@example +@group +trees + @result{} (pine oak) +@end group +@group +(setq wood (append trees ())) + @result{} (pine oak) +@end group +@group +wood + @result{} (pine oak) +@end group +@group +(eq wood trees) + @result{} nil +@end group +@end example + +@noindent +This once was the usual way to copy a list, before the function +@code{copy-sequence} was invented. @xref{Sequences Arrays Vectors}. + +With the help of @code{apply}, we can append all the lists in a list of +lists: + +@example +@group +(apply 'append '((a b c) nil (x y z) nil)) + @result{} (a b c x y z) +@end group +@end example + +If no @var{sequences} are given, @code{nil} is returned: + +@example +@group +(append) + @result{} nil +@end group +@end example + +See @code{nconc} in @ref{Rearrangement}, for a way to join lists with no +copying. + +Integers are also allowed as arguments to @code{append}. They are +converted to strings of digits making up the decimal print +representation of the integer, and these strings are then appended. +Here's what happens: + +@example +@group +(setq trees '(pine oak)) + @result{} (pine oak) +@end group +@group +(char-to-string 54) + @result{} "6" +@end group +@group +(setq longer-list (append trees 6 '(spruce))) + @result{} (pine oak 54 spruce) +@end group +@group +(setq x-list (append trees 6 6)) + @result{} (pine oak 54 . 6) +@end group +@end example + +This special case exists for compatibility with Mocklisp, and we don't +recommend you take advantage of it. If you want to convert an integer +in this way, use @code{format} (@pxref{Formatting Strings}) or +@code{number-to-string} (@pxref{String Conversion}). +@end defun + +@defun reverse list +This function creates a new list whose elements are the elements of +@var{list}, but in reverse order. The original argument @var{list} is +@emph{not} altered. + +@example +@group +(setq x '(1 2 3 4)) + @result{} (1 2 3 4) +@end group +@group +(reverse x) + @result{} (4 3 2 1) +x + @result{} (1 2 3 4) +@end group +@end example +@end defun + +@node Modifying Lists +@section Modifying Existing List Structure + + You can modify the @sc{car} and @sc{cdr} contents of a cons cell with the +primitives @code{setcar} and @code{setcdr}. + +@cindex CL note---@code{rplaca} vrs @code{setcar} +@quotation +@findex rplaca +@findex rplacd +@b{Common Lisp note:} Common Lisp uses functions @code{rplaca} and +@code{rplacd} to alter list structure; they change structure the same +way as @code{setcar} and @code{setcdr}, but the Common Lisp functions +return the cons cell while @code{setcar} and @code{setcdr} return the +new @sc{car} or @sc{cdr}. +@end quotation + +@menu +* Setcar:: Replacing an element in a list. +* Setcdr:: Replacing part of the list backbone. + This can be used to remove or add elements. +* Rearrangement:: Reordering the elements in a list; combining lists. +@end menu + +@node Setcar +@subsection Altering List Elements with @code{setcar} + + Changing the @sc{car} of a cons cell is done with @code{setcar}, which +replaces one element of a list with a different element. + +@defun setcar cons object +This function stores @var{object} as the new @sc{car} of @var{cons}, +replacing its previous @sc{car}. It returns the value @var{object}. +For example: + +@example +@group +(setq x '(1 2)) + @result{} (1 2) +@end group +@group +(setcar x 4) + @result{} 4 +@end group +@group +x + @result{} (4 2) +@end group +@end example +@end defun + + When a cons cell is part of the shared structure of several lists, +storing a new @sc{car} into the cons changes one element of each of +these lists. Here is an example: + +@example +@group +;; @r{Create two lists that are partly shared.} +(setq x1 '(a b c)) + @result{} (a b c) +(setq x2 (cons 'z (cdr x1))) + @result{} (z b c) +@end group + +@group +;; @r{Replace the @sc{car} of a shared link.} +(setcar (cdr x1) 'foo) + @result{} foo +x1 ; @r{Both lists are changed.} + @result{} (a foo c) +x2 + @result{} (z foo c) +@end group + +@group +;; @r{Replace the @sc{car} of a link that is not shared.} +(setcar x1 'baz) + @result{} baz +x1 ; @r{Only one list is changed.} + @result{} (baz foo c) +x2 + @result{} (z foo c) +@end group +@end example + + Here is a graphical depiction of the shared structure of the two lists +in the variables @code{x1} and @code{x2}, showing why replacing @code{b} +changes them both: + +@example +@group + ___ ___ ___ ___ ___ ___ +x1---> |___|___|----> |___|___|--> |___|___|--> nil + | --> | | + | | | | + --> a | --> b --> c + | + ___ ___ | +x2--> |___|___|-- + | + | + --> z +@end group +@end example + + Here is an alternative form of box diagram, showing the same relationship: + +@example +@group +x1: + -------------- -------------- -------------- +| car | cdr | | car | cdr | | car | cdr | +| a | o------->| b | o------->| c | nil | +| | | -->| | | | | | + -------------- | -------------- -------------- + | +x2: | + -------------- | +| car | cdr | | +| z | o---- +| | | + -------------- +@end group +@end example + +@node Setcdr +@subsection Altering the CDR of a List + + The lowest-level primitive for modifying a @sc{cdr} is @code{setcdr}: + +@defun setcdr cons object +This function stores @var{object} into the @sc{cdr} of @var{cons}. The +value returned is @var{object}, not @var{cons}. +@end defun + + Here is an example of replacing the @sc{cdr} of a list with a +different list. All but the first element of the list are removed in +favor of a different sequence of elements. The first element is +unchanged, because it resides in the @sc{car} of the list, and is not +reached via the @sc{cdr}. + +@example +@group +(setq x '(1 2 3)) + @result{} (1 2 3) +@end group +@group +(setcdr x '(4)) + @result{} (4) +@end group +@group +x + @result{} (1 4) +@end group +@end example + + You can delete elements from the middle of a list by altering the +@sc{cdr}s of the cons cells in the list. For example, here we delete +the second element, @code{b}, from the list @code{(a b c)}, by changing +the @sc{cdr} of the first cell: + +@example +@group +(setq x1 '(a b c)) + @result{} (a b c) +(setcdr x1 (cdr (cdr x1))) + @result{} (c) +x1 + @result{} (a c) +@end group +@end example + + Here is the result in box notation: + +@example +@group + -------------------- + | | + -------------- | -------------- | -------------- +| car | cdr | | | car | cdr | -->| car | cdr | +| a | o----- | b | o-------->| c | nil | +| | | | | | | | | + -------------- -------------- -------------- +@end group +@end example + +@noindent +The second cons cell, which previously held the element @code{b}, still +exists and its @sc{car} is still @code{b}, but it no longer forms part +of this list. + + It is equally easy to insert a new element by changing @sc{cdr}s: + +@example +@group +(setq x1 '(a b c)) + @result{} (a b c) +(setcdr x1 (cons 'd (cdr x1))) + @result{} (d b c) +x1 + @result{} (a d b c) +@end group +@end example + + Here is this result in box notation: + +@smallexample +@group + -------------- ------------- ------------- +| car | cdr | | car | cdr | | car | cdr | +| a | o | -->| b | o------->| c | nil | +| | | | | | | | | | | + --------- | -- | ------------- ------------- + | | + ----- -------- + | | + | --------------- | + | | car | cdr | | + -->| d | o------ + | | | + --------------- +@end group +@end smallexample + +@node Rearrangement +@subsection Functions that Rearrange Lists +@cindex rearrangement of lists +@cindex modification of lists + + Here are some functions that rearrange lists ``destructively'' by +modifying the @sc{cdr}s of their component cons cells. We call these +functions ``destructive'' because they chew up the original lists passed +to them as arguments, to produce a new list that is the returned value. + +@defun nconc &rest lists +@cindex concatenating lists +@cindex joining lists +This function returns a list containing all the elements of @var{lists}. +Unlike @code{append} (@pxref{Building Lists}), the @var{lists} are +@emph{not} copied. Instead, the last @sc{cdr} of each of the +@var{lists} is changed to refer to the following list. The last of the +@var{lists} is not altered. For example: + +@example +@group +(setq x '(1 2 3)) + @result{} (1 2 3) +@end group +@group +(nconc x '(4 5)) + @result{} (1 2 3 4 5) +@end group +@group +x + @result{} (1 2 3 4 5) +@end group +@end example + + Since the last argument of @code{nconc} is not itself modified, it is +reasonable to use a constant list, such as @code{'(4 5)}, as in the +above example. For the same reason, the last argument need not be a +list: + +@example +@group +(setq x '(1 2 3)) + @result{} (1 2 3) +@end group +@group +(nconc x 'z) + @result{} (1 2 3 . z) +@end group +@group +x + @result{} (1 2 3 . z) +@end group +@end example + +A common pitfall is to use a quoted constant list as a non-last +argument to @code{nconc}. If you do this, your program will change +each time you run it! Here is what happens: + +@smallexample +@group +(defun add-foo (x) ; @r{We want this function to add} + (nconc '(foo) x)) ; @r{@code{foo} to the front of its arg.} +@end group + +@group +(symbol-function 'add-foo) + @result{} (lambda (x) (nconc (quote (foo)) x)) +@end group + +@group +(setq xx (add-foo '(1 2))) ; @r{It seems to work.} + @result{} (foo 1 2) +@end group +@group +(setq xy (add-foo '(3 4))) ; @r{What happened?} + @result{} (foo 1 2 3 4) +@end group +@group +(eq xx xy) + @result{} t +@end group + +@group +(symbol-function 'add-foo) + @result{} (lambda (x) (nconc (quote (foo 1 2 3 4) x))) +@end group +@end smallexample +@end defun + +@defun nreverse list +@cindex reversing a list + This function reverses the order of the elements of @var{list}. +Unlike @code{reverse}, @code{nreverse} alters its argument destructively +by reversing the @sc{cdr}s in the cons cells forming the list. The cons +cell which used to be the last one in @var{list} becomes the first cell +of the value. + + For example: + +@example +@group +(setq x '(1 2 3 4)) + @result{} (1 2 3 4) +@end group +@group +x + @result{} (1 2 3 4) +(nreverse x) + @result{} (4 3 2 1) +@end group +@group +;; @r{The cell that was first is now last.} +x + @result{} (1) +@end group +@end example + + To avoid confusion, we usually store the result of @code{nreverse} +back in the same variable which held the original list: + +@example +(setq x (nreverse x)) +@end example + + Here is the @code{nreverse} of our favorite example, @code{(a b c)}, +presented graphically: + +@smallexample +@group +@r{Original list head:} @r{Reversed list:} + ------------- ------------- ------------ +| car | cdr | | car | cdr | | car | cdr | +| a | nil |<-- | b | o |<-- | c | o | +| | | | | | | | | | | | | + ------------- | --------- | - | -------- | - + | | | | + ------------- ------------ +@end group +@end smallexample +@end defun + +@defun sort list predicate +@cindex stable sort +@cindex sorting lists +This function sorts @var{list} stably, though destructively, and +returns the sorted list. It compares elements using @var{predicate}. A +stable sort is one in which elements with equal sort keys maintain their +relative order before and after the sort. Stability is important when +successive sorts are used to order elements according to different +criteria. + +The argument @var{predicate} must be a function that accepts two +arguments. It is called with two elements of @var{list}. To get an +increasing order sort, the @var{predicate} should return @code{t} if the +first element is ``less than'' the second, or @code{nil} if not. + +The destructive aspect of @code{sort} is that it rearranges the cons +cells forming @var{list} by changing @sc{cdr}s. A nondestructive sort +function would create new cons cells to store the elements in their +sorted order. If you wish to make a sorted copy without destroying the +original, copy it first with @code{copy-sequence} and then sort. + +Sorting does not change the @sc{car}s of the cons cells in @var{list}; +the cons cell that originally contained the element @code{a} in +@var{list} still has @code{a} in its @sc{car} after sorting, but it now +appears in a different position in the list due to the change of +@sc{cdr}s. For example: + +@example +@group +(setq nums '(1 3 2 6 5 4 0)) + @result{} (1 3 2 6 5 4 0) +@end group +@group +(sort nums '<) + @result{} (0 1 2 3 4 5 6) +@end group +@group +nums + @result{} (1 2 3 4 5 6) +@end group +@end example + +@noindent +Note that the list in @code{nums} no longer contains 0; this is the same +cons cell that it was before, but it is no longer the first one in the +list. Don't assume a variable that formerly held the argument now holds +the entire sorted list! Instead, save the result of @code{sort} and use +that. Most often we store the result back into the variable that held +the original list: + +@example +(setq nums (sort nums '<)) +@end example + +@xref{Sorting}, for more functions that perform sorting. +See @code{documentation} in @ref{Accessing Documentation}, for a +useful example of @code{sort}. +@end defun + +@ifinfo + See @code{delq}, in @ref{Sets And Lists}, for another function +that modifies cons cells. +@end ifinfo +@iftex + The function @code{delq} in the following section is another example +of destructive list manipulation. +@end iftex + +@node Sets And Lists +@section Using Lists as Sets +@cindex lists as sets +@cindex sets + + A list can represent an unordered mathematical set---simply consider a +value an element of a set if it appears in the list, and ignore the +order of the list. To form the union of two sets, use @code{append} (as +long as you don't mind having duplicate elements). Other useful +functions for sets include @code{memq} and @code{delq}, and their +@code{equal} versions, @code{member} and @code{delete}. + +@cindex CL note---lack @code{union}, @code{set} +@quotation +@b{Common Lisp note:} Common Lisp has functions @code{union} (which +avoids duplicate elements) and @code{intersection} for set operations, +but GNU Emacs Lisp does not have them. You can write them in Lisp if +you wish. +@end quotation + +@defun memq object list +@cindex membership in a list +This function tests to see whether @var{object} is a member of +@var{list}. If it is, @code{memq} returns a list starting with the +first occurrence of @var{object}. Otherwise, it returns @code{nil}. +The letter @samp{q} in @code{memq} says that it uses @code{eq} to +compare @var{object} against the elements of the list. For example: + +@example +@group +(memq 2 '(1 2 3 2 1)) + @result{} (2 3 2 1) +@end group +@group +(memq '(2) '((1) (2))) ; @r{@code{(2)} and @code{(2)} are not @code{eq}.} + @result{} nil +@end group +@end example +@end defun + +@defun delq object list +@cindex deletion of elements +This function destructively removes all elements @code{eq} to +@var{object} from @var{list}. The letter @samp{q} in @code{delq} says +that it uses @code{eq} to compare @var{object} against the elements of +the list, like @code{memq}. +@end defun + +When @code{delq} deletes elements from the front of the list, it does so +simply by advancing down the list and returning a sublist that starts +after those elements: + +@example +@group +(delq 'a '(a b c)) @equiv{} (cdr '(a b c)) +@end group +@end example + +When an element to be deleted appears in the middle of the list, +removing it involves changing the @sc{cdr}s (@pxref{Setcdr}). + +@example +@group +(setq sample-list '(1 2 3 (4))) + @result{} (1 2 3 (4)) +@end group +@group +(delq 1 sample-list) + @result{} (2 3 (4)) +@end group +@group +sample-list + @result{} (1 2 3 (4)) +@end group +@group +(delq 2 sample-list) + @result{} (1 3 (4)) +@end group +@group +sample-list + @result{} (1 3 (4)) +@end group +@end example + +Note that @code{(delq 2 sample-list)} modifies @code{sample-list} to +splice out the second element, but @code{(delq 1 sample-list)} does not +splice anything---it just returns a shorter list. Don't assume that a +variable which formerly held the argument @var{list} now has fewer +elements, or that it still holds the original list! Instead, save the +result of @code{delq} and use that. Most often we store the result back +into the variable that held the original list: + +@example +(setq flowers (delq 'rose flowers)) +@end example + +In the following example, the @code{(4)} that @code{delq} attempts to match +and the @code{(4)} in the @code{sample-list} are not @code{eq}: + +@example +@group +(delq '(4) sample-list) + @result{} (1 3 (4)) +@end group +@end example + +The following two functions are like @code{memq} and @code{delq} but use +@code{equal} rather than @code{eq} to compare elements. They are new in +Emacs 19. + +@defun member object list +The function @code{member} tests to see whether @var{object} is a member +of @var{list}, comparing members with @var{object} using @code{equal}. +If @var{object} is a member, @code{member} returns a list starting with +its first occurrence in @var{list}. Otherwise, it returns @code{nil}. + +Compare this with @code{memq}: + +@example +@group +(member '(2) '((1) (2))) ; @r{@code{(2)} and @code{(2)} are @code{equal}.} + @result{} ((2)) +@end group +@group +(memq '(2) '((1) (2))) ; @r{@code{(2)} and @code{(2)} are not @code{eq}.} + @result{} nil +@end group +@group +;; @r{Two strings with the same contents are @code{equal}.} +(member "foo" '("foo" "bar")) + @result{} ("foo" "bar") +@end group +@end example +@end defun + +@defun delete object list +This function destructively removes all elements @code{equal} to +@var{object} from @var{list}. It is to @code{delq} as @code{member} is +to @code{memq}: it uses @code{equal} to compare elements with +@var{object}, like @code{member}; when it finds an element that matches, +it removes the element just as @code{delq} would. For example: + +@example +@group +(delete '(2) '((2) (1) (2))) + @result{} '((1)) +@end group +@end example +@end defun + +@quotation +@b{Common Lisp note:} The functions @code{member} and @code{delete} in +GNU Emacs Lisp are derived from Maclisp, not Common Lisp. The Common +Lisp versions do not use @code{equal} to compare elements. +@end quotation + +@node Association Lists +@section Association Lists +@cindex association list +@cindex alist + + An @dfn{association list}, or @dfn{alist} for short, records a mapping +from keys to values. It is a list of cons cells called +@dfn{associations}: the @sc{car} of each cell is the @dfn{key}, and the +@sc{cdr} is the @dfn{associated value}.@footnote{This usage of ``key'' +is not related to the term ``key sequence''; it means a value used to +look up an item in a table. In this case, the table is the alist, and +the alist associations are the items.} + + Here is an example of an alist. The key @code{pine} is associated with +the value @code{cones}; the key @code{oak} is associated with +@code{acorns}; and the key @code{maple} is associated with @code{seeds}. + +@example +@group +'((pine . cones) + (oak . acorns) + (maple . seeds)) +@end group +@end example + + The associated values in an alist may be any Lisp objects; so may the +keys. For example, in the following alist, the symbol @code{a} is +associated with the number @code{1}, and the string @code{"b"} is +associated with the @emph{list} @code{(2 3)}, which is the @sc{cdr} of +the alist element: + +@example +((a . 1) ("b" 2 3)) +@end example + + Sometimes it is better to design an alist to store the associated +value in the @sc{car} of the @sc{cdr} of the element. Here is an +example: + +@example +'((rose red) (lily white) (buttercup yellow)) +@end example + +@noindent +Here we regard @code{red} as the value associated with @code{rose}. One +advantage of this method is that you can store other related +information---even a list of other items---in the @sc{cdr} of the +@sc{cdr}. One disadvantage is that you cannot use @code{rassq} (see +below) to find the element containing a given value. When neither of +these considerations is important, the choice is a matter of taste, as +long as you are consistent about it for any given alist. + + Note that the same alist shown above could be regarded as having the +associated value in the @sc{cdr} of the element; the value associated +with @code{rose} would be the list @code{(red)}. + + Association lists are often used to record information that you might +otherwise keep on a stack, since new associations may be added easily to +the front of the list. When searching an association list for an +association with a given key, the first one found is returned, if there +is more than one. + + In Emacs Lisp, it is @emph{not} an error if an element of an +association list is not a cons cell. The alist search functions simply +ignore such elements. Many other versions of Lisp signal errors in such +cases. + + Note that property lists are similar to association lists in several +respects. A property list behaves like an association list in which +each key can occur only once. @xref{Property Lists}, for a comparison +of property lists and association lists. + +@defun assoc key alist +This function returns the first association for @var{key} in +@var{alist}. It compares @var{key} against the alist elements using +@code{equal} (@pxref{Equality Predicates}). It returns @code{nil} if no +association in @var{alist} has a @sc{car} @code{equal} to @var{key}. +For example: + +@smallexample +(setq trees '((pine . cones) (oak . acorns) (maple . seeds))) + @result{} ((pine . cones) (oak . acorns) (maple . seeds)) +(assoc 'oak trees) + @result{} (oak . acorns) +(cdr (assoc 'oak trees)) + @result{} acorns +(assoc 'birch trees) + @result{} nil +@end smallexample + +Here is another example in which the keys and values are not symbols: + +@smallexample +(setq needles-per-cluster + '((2 "Austrian Pine" "Red Pine") + (3 "Pitch Pine") + (5 "White Pine"))) + +(cdr (assoc 3 needles-per-cluster)) + @result{} ("Pitch Pine") +(cdr (assoc 2 needles-per-cluster)) + @result{} ("Austrian Pine" "Red Pine") +@end smallexample +@end defun + +@defun assq key alist +This function is like @code{assoc} in that it returns the first +association for @var{key} in @var{alist}, but it makes the comparison +using @code{eq} instead of @code{equal}. @code{assq} returns @code{nil} +if no association in @var{alist} has a @sc{car} @code{eq} to @var{key}. +This function is used more often than @code{assoc}, since @code{eq} is +faster than @code{equal} and most alists use symbols as keys. +@xref{Equality Predicates}. + +@smallexample +(setq trees '((pine . cones) (oak . acorns) (maple . seeds))) + @result{} ((pine . cones) (oak . acorns) (maple . seeds)) +(assq 'pine trees) + @result{} (pine . cones) +@end smallexample + +On the other hand, @code{assq} is not usually useful in alists where the +keys may not be symbols: + +@smallexample +(setq leaves + '(("simple leaves" . oak) + ("compound leaves" . horsechestnut))) + +(assq "simple leaves" leaves) + @result{} nil +(assoc "simple leaves" leaves) + @result{} ("simple leaves" . oak) +@end smallexample +@end defun + +@defun rassq value alist +This function returns the first association with value @var{value} in +@var{alist}. It returns @code{nil} if no association in @var{alist} has +a @sc{cdr} @code{eq} to @var{value}. + +@code{rassq} is like @code{assq} except that it compares the @sc{cdr} of +each @var{alist} association instead of the @sc{car}. You can think of +this as ``reverse @code{assq}'', finding the key for a given value. + +For example: + +@smallexample +(setq trees '((pine . cones) (oak . acorns) (maple . seeds))) + +(rassq 'acorns trees) + @result{} (oak . acorns) +(rassq 'spores trees) + @result{} nil +@end smallexample + +Note that @code{rassq} cannot search for a value stored in the @sc{car} +of the @sc{cdr} of an element: + +@smallexample +(setq colors '((rose red) (lily white) (buttercup yellow))) + +(rassq 'white colors) + @result{} nil +@end smallexample + +In this case, the @sc{cdr} of the association @code{(lily white)} is not +the symbol @code{white}, but rather the list @code{(white)}. This +becomes clearer if the association is written in dotted pair notation: + +@smallexample +(lily white) @equiv{} (lily . (white)) +@end smallexample +@end defun + +@defun copy-alist alist +@cindex copying alists +This function returns a two-level deep copy of @var{alist}: it creates a +new copy of each association, so that you can alter the associations of +the new alist without changing the old one. + +@smallexample +@group +(setq needles-per-cluster + '((2 . ("Austrian Pine" "Red Pine")) + (3 . "Pitch Pine") + (5 . "White Pine"))) +@result{} +((2 "Austrian Pine" "Red Pine") + (3 . "Pitch Pine") + (5 . "White Pine")) + +(setq copy (copy-alist needles-per-cluster)) +@result{} +((2 "Austrian Pine" "Red Pine") + (3 . "Pitch Pine") + (5 . "White Pine")) + +(eq needles-per-cluster copy) + @result{} nil +(equal needles-per-cluster copy) + @result{} t +(eq (car needles-per-cluster) (car copy)) + @result{} nil +(cdr (car (cdr needles-per-cluster))) + @result{} "Pitch Pine" +(eq (cdr (car (cdr needles-per-cluster))) + (cdr (car (cdr copy)))) + @result{} t +@end group +@end smallexample +@end defun + +
