Add arch taglines
[bpt/emacs.git] / lispref / symbols.texi
CommitLineData
1621af1e
RS
1@c -*-texinfo-*-
2@c This is part of the GNU Emacs Lisp Reference Manual.
fd897522 3@c Copyright (C) 1990, 1991, 1992, 1993, 1994, 1995, 1998, 1999
177c0ea7 4@c Free Software Foundation, Inc.
1621af1e
RS
5@c See the file elisp.texi for copying conditions.
6@setfilename ../info/symbols
8241495d 7@node Symbols, Evaluation, Hash Tables, Top
1621af1e
RS
8@chapter Symbols
9@cindex symbol
10
11 A @dfn{symbol} is an object with a unique name. This chapter
12describes symbols, their components, their property lists, and how they
13are created and interned. Separate chapters describe the use of symbols
14as variables and as function names; see @ref{Variables}, and
15@ref{Functions}. For the precise read syntax for symbols, see
16@ref{Symbol Type}.
17
18 You can test whether an arbitrary Lisp object is a symbol
19with @code{symbolp}:
20
21@defun symbolp object
22This function returns @code{t} if @var{object} is a symbol, @code{nil}
23otherwise.
24@end defun
25
26@menu
27* Symbol Components:: Symbols have names, values, function definitions
28 and property lists.
29* Definitions:: A definition says how a symbol will be used.
30* Creating Symbols:: How symbols are kept unique.
31* Property Lists:: Each symbol has a property list
32 for recording miscellaneous information.
33@end menu
34
35@node Symbol Components, Definitions, Symbols, Symbols
36@section Symbol Components
37@cindex symbol components
38
39 Each symbol has four components (or ``cells''), each of which
40references another object:
41
42@table @asis
43@item Print name
44@cindex print name cell
2b3fc6c3 45The @dfn{print name cell} holds a string that names the symbol for
1621af1e
RS
46reading and printing. See @code{symbol-name} in @ref{Creating Symbols}.
47
48@item Value
49@cindex value cell
50The @dfn{value cell} holds the current value of the symbol as a
51variable. When a symbol is used as a form, the value of the form is the
52contents of the symbol's value cell. See @code{symbol-value} in
53@ref{Accessing Variables}.
54
55@item Function
56@cindex function cell
57The @dfn{function cell} holds the function definition of the symbol.
58When a symbol is used as a function, its function definition is used in
59its place. This cell is also used to make a symbol stand for a keymap
60or a keyboard macro, for editor command execution. Because each symbol
8241495d 61has separate value and function cells, variables names and function names do
1621af1e
RS
62not conflict. See @code{symbol-function} in @ref{Function Cells}.
63
64@item Property list
65@cindex property list cell
66The @dfn{property list cell} holds the property list of the symbol. See
67@code{symbol-plist} in @ref{Property Lists}.
68@end table
69
70 The print name cell always holds a string, and cannot be changed. The
71other three cells can be set individually to any specified Lisp object.
72
73 The print name cell holds the string that is the name of the symbol.
74Since symbols are represented textually by their names, it is important
75not to have two symbols with the same name. The Lisp reader ensures
76this: every time it reads a symbol, it looks for an existing symbol with
77the specified name before it creates a new one. (In GNU Emacs Lisp,
78this lookup uses a hashing algorithm and an obarray; see @ref{Creating
79Symbols}.)
80
72821190
RS
81 The value cell holds the symbol's value as a variable
82(@pxref{Variables}). That is what you get if you evaluate the symbol as
83a Lisp expression (@pxref{Evaluation}). Any Lisp object is a legitimate
84value. Certain symbols have values that cannot be changed; these
85include @code{nil} and @code{t}, and any symbol whose name starts with
86@samp{:} (those are called @dfn{keywords}). @xref{Constant Variables}.
87
7b67d693
RS
88 We often refer to ``the function @code{foo}'' when we really mean
89the function stored in the function cell of the symbol @code{foo}. We
90make the distinction explicit only when necessary. In normal
91usage, the function cell usually contains a function
f9f59935
RS
92(@pxref{Functions}) or a macro (@pxref{Macros}), as that is what the
93Lisp interpreter expects to see there (@pxref{Evaluation}). Keyboard
7b67d693
RS
94macros (@pxref{Keyboard Macros}), keymaps (@pxref{Keymaps}) and
95autoload objects (@pxref{Autoloading}) are also sometimes stored in
96the function cells of symbols.
1621af1e
RS
97
98 The property list cell normally should hold a correctly formatted
99property list (@pxref{Property Lists}), as a number of functions expect
100to see a property list there.
101
102 The function cell or the value cell may be @dfn{void}, which means
103that the cell does not reference any object. (This is not the same
104thing as holding the symbol @code{void}, nor the same as holding the
f9f59935
RS
105symbol @code{nil}.) Examining a function or value cell that is void
106results in an error, such as @samp{Symbol's value as variable is void}.
1621af1e
RS
107
108 The four functions @code{symbol-name}, @code{symbol-value},
109@code{symbol-plist}, and @code{symbol-function} return the contents of
110the four cells of a symbol. Here as an example we show the contents of
111the four cells of the symbol @code{buffer-file-name}:
112
113@example
114(symbol-name 'buffer-file-name)
115 @result{} "buffer-file-name"
116(symbol-value 'buffer-file-name)
117 @result{} "/gnu/elisp/symbols.texi"
118(symbol-plist 'buffer-file-name)
119 @result{} (variable-documentation 29529)
120(symbol-function 'buffer-file-name)
121 @result{} #<subr buffer-file-name>
122@end example
123
124@noindent
125Because this symbol is the variable which holds the name of the file
126being visited in the current buffer, the value cell contents we see are
127the name of the source file of this chapter of the Emacs Lisp Manual.
128The property list cell contains the list @code{(variable-documentation
12929529)} which tells the documentation functions where to find the
130documentation string for the variable @code{buffer-file-name} in the
f9f59935
RS
131@file{DOC-@var{version}} file. (29529 is the offset from the beginning
132of the @file{DOC-@var{version}} file to where that documentation string
a9f0a989
RS
133begins---see @ref{Documentation Basics}.) The function cell contains
134the function for returning the name of the file.
135@code{buffer-file-name} names a primitive function, which has no read
136syntax and prints in hash notation (@pxref{Primitive Function Type}). A
137symbol naming a function written in Lisp would have a lambda expression
138(or a byte-code object) in this cell.
1621af1e
RS
139
140@node Definitions, Creating Symbols, Symbol Components, Symbols
141@section Defining Symbols
142@cindex definition of a symbol
143
144 A @dfn{definition} in Lisp is a special form that announces your
145intention to use a certain symbol in a particular way. In Emacs Lisp,
146you can define a symbol as a variable, or define it as a function (or
147macro), or both independently.
148
149 A definition construct typically specifies a value or meaning for the
150symbol for one kind of use, plus documentation for its meaning when used
151in this way. Thus, when you define a symbol as a variable, you can
152supply an initial value for the variable, plus documentation for the
153variable.
154
155 @code{defvar} and @code{defconst} are special forms that define a
156symbol as a global variable. They are documented in detail in
969fe9b5
RS
157@ref{Defining Variables}. For defining user option variables that can
158be customized, use @code{defcustom} (@pxref{Customization}).
1621af1e
RS
159
160 @code{defun} defines a symbol as a function, creating a lambda
161expression and storing it in the function cell of the symbol. This
162lambda expression thus becomes the function definition of the symbol.
163(The term ``function definition'', meaning the contents of the function
164cell, is derived from the idea that @code{defun} gives the symbol its
bfe721d1
KH
165definition as a function.) @code{defsubst} and @code{defalias} are two
166other ways of defining a function. @xref{Functions}.
1621af1e
RS
167
168 @code{defmacro} defines a symbol as a macro. It creates a macro
169object and stores it in the function cell of the symbol. Note that a
170given symbol can be a macro or a function, but not both at once, because
171both macro and function definitions are kept in the function cell, and
172that cell can hold only one Lisp object at any given time.
173@xref{Macros}.
174
bfe721d1
KH
175 In Emacs Lisp, a definition is not required in order to use a symbol
176as a variable or function. Thus, you can make a symbol a global
1621af1e
RS
177variable with @code{setq}, whether you define it first or not. The real
178purpose of definitions is to guide programmers and programming tools.
179They inform programmers who read the code that certain symbols are
180@emph{intended} to be used as variables, or as functions. In addition,
181utilities such as @file{etags} and @file{make-docfile} recognize
182definitions, and add appropriate information to tag tables and the
f9f59935 183@file{DOC-@var{version}} file. @xref{Accessing Documentation}.
1621af1e
RS
184
185@node Creating Symbols, Property Lists, Definitions, Symbols
186@section Creating and Interning Symbols
187@cindex reading symbols
188
189 To understand how symbols are created in GNU Emacs Lisp, you must know
190how Lisp reads them. Lisp must ensure that it finds the same symbol
191every time it reads the same set of characters. Failure to do so would
192cause complete confusion.
193
194@cindex symbol name hashing
195@cindex hashing
196@cindex obarray
197@cindex bucket (in obarray)
198 When the Lisp reader encounters a symbol, it reads all the characters
199of the name. Then it ``hashes'' those characters to find an index in a
200table called an @dfn{obarray}. Hashing is an efficient method of
201looking something up. For example, instead of searching a telephone
202book cover to cover when looking up Jan Jones, you start with the J's
203and go from there. That is a simple version of hashing. Each element
204of the obarray is a @dfn{bucket} which holds all the symbols with a
205given hash code; to look for a given name, it is sufficient to look
8241495d
RS
206through all the symbols in the bucket for that name's hash code. (The
207same idea is used for general Emacs hash tables, but they are a
208different data type; see @ref{Hash Tables}.)
1621af1e
RS
209
210@cindex interning
2b3fc6c3
RS
211 If a symbol with the desired name is found, the reader uses that
212symbol. If the obarray does not contain a symbol with that name, the
213reader makes a new symbol and adds it to the obarray. Finding or adding
214a symbol with a certain name is called @dfn{interning} it, and the
215symbol is then called an @dfn{interned symbol}.
216
217 Interning ensures that each obarray has just one symbol with any
218particular name. Other like-named symbols may exist, but not in the
219same obarray. Thus, the reader gets the same symbols for the same
220names, as long as you keep reading with the same obarray.
1621af1e 221
8241495d
RS
222 Interning usually happens automatically in the reader, but sometimes
223other programs need to do it. For example, after the @kbd{M-x} command
224obtains the command name as a string using the minibuffer, it then
225interns the string, to get the interned symbol with that name.
226
1621af1e
RS
227@cindex symbol equality
228@cindex uninterned symbol
2b3fc6c3
RS
229 No obarray contains all symbols; in fact, some symbols are not in any
230obarray. They are called @dfn{uninterned symbols}. An uninterned
231symbol has the same four cells as other symbols; however, the only way
232to gain access to it is by finding it in some other object or as the
233value of a variable.
1621af1e 234
8241495d
RS
235 Creating an uninterned symbol is useful in generating Lisp code,
236because an uninterned symbol used as a variable in the code you generate
237cannot clash with any variables used in other Lisp programs.
238
1621af1e
RS
239 In Emacs Lisp, an obarray is actually a vector. Each element of the
240vector is a bucket; its value is either an interned symbol whose name
241hashes to that bucket, or 0 if the bucket is empty. Each interned
242symbol has an internal link (invisible to the user) to the next symbol
243in the bucket. Because these links are invisible, there is no way to
244find all the symbols in an obarray except using @code{mapatoms} (below).
245The order of symbols in a bucket is not significant.
246
8241495d 247 In an empty obarray, every element is 0, so you can create an obarray
1621af1e
RS
248with @code{(make-vector @var{length} 0)}. @strong{This is the only
249valid way to create an obarray.} Prime numbers as lengths tend
250to result in good hashing; lengths one less than a power of two are also
251good.
252
f9f59935
RS
253 @strong{Do not try to put symbols in an obarray yourself.} This does
254not work---only @code{intern} can enter a symbol in an obarray properly.
255
1621af1e
RS
256@cindex CL note---symbol in obarrays
257@quotation
ec221d13 258@b{Common Lisp note:} In Common Lisp, a single symbol may be interned in
1621af1e
RS
259several obarrays.
260@end quotation
261
262 Most of the functions below take a name and sometimes an obarray as
263arguments. A @code{wrong-type-argument} error is signaled if the name
264is not a string, or if the obarray is not a vector.
265
266@defun symbol-name symbol
267This function returns the string that is @var{symbol}'s name. For example:
268
269@example
270@group
271(symbol-name 'foo)
272 @result{} "foo"
273@end group
274@end example
275
f9f59935
RS
276@strong{Warning:} Changing the string by substituting characters does
277change the name of the symbol, but fails to update the obarray, so don't
278do it!
1621af1e
RS
279@end defun
280
281@defun make-symbol name
282This function returns a newly-allocated, uninterned symbol whose name is
283@var{name} (which must be a string). Its value and function definition
284are void, and its property list is @code{nil}. In the example below,
285the value of @code{sym} is not @code{eq} to @code{foo} because it is a
286distinct uninterned symbol whose name is also @samp{foo}.
287
288@example
289(setq sym (make-symbol "foo"))
290 @result{} foo
291(eq sym 'foo)
292 @result{} nil
293@end example
294@end defun
295
296@defun intern name &optional obarray
297This function returns the interned symbol whose name is @var{name}. If
298there is no such symbol in the obarray @var{obarray}, @code{intern}
299creates a new one, adds it to the obarray, and returns it. If
300@var{obarray} is omitted, the value of the global variable
301@code{obarray} is used.
302
303@example
304(setq sym (intern "foo"))
305 @result{} foo
306(eq sym 'foo)
307 @result{} t
308
309(setq sym1 (intern "foo" other-obarray))
310 @result{} foo
433d0b26 311(eq sym1 'foo)
1621af1e
RS
312 @result{} nil
313@end example
314@end defun
315
f9f59935
RS
316@cindex CL note---interning existing symbol
317@quotation
318@b{Common Lisp note:} In Common Lisp, you can intern an existing symbol
319in an obarray. In Emacs Lisp, you cannot do this, because the argument
320to @code{intern} must be a string, not a symbol.
321@end quotation
322
1621af1e
RS
323@defun intern-soft name &optional obarray
324This function returns the symbol in @var{obarray} whose name is
325@var{name}, or @code{nil} if @var{obarray} has no symbol with that name.
326Therefore, you can use @code{intern-soft} to test whether a symbol with
327a given name is already interned. If @var{obarray} is omitted, the
328value of the global variable @code{obarray} is used.
329
02b14400
RS
330The argument @var{name} may also be a symbol; in that case,
331the function returns @var{name} if @var{name} is interned
332in the specified obarray, and otherwise @code{nil}.
333
1621af1e
RS
334@smallexample
335(intern-soft "frazzle") ; @r{No such symbol exists.}
336 @result{} nil
337(make-symbol "frazzle") ; @r{Create an uninterned one.}
338 @result{} frazzle
bda144f4 339@group
1621af1e
RS
340(intern-soft "frazzle") ; @r{That one cannot be found.}
341 @result{} nil
bda144f4
MW
342@end group
343@group
1621af1e
RS
344(setq sym (intern "frazzle")) ; @r{Create an interned one.}
345 @result{} frazzle
bda144f4
MW
346@end group
347@group
1621af1e
RS
348(intern-soft "frazzle") ; @r{That one can be found!}
349 @result{} frazzle
bda144f4 350@end group
1621af1e
RS
351@group
352(eq sym 'frazzle) ; @r{And it is the same one.}
353 @result{} t
354@end group
355@end smallexample
356@end defun
357
358@defvar obarray
359This variable is the standard obarray for use by @code{intern} and
360@code{read}.
361@end defvar
362
363@defun mapatoms function &optional obarray
f9f59935
RS
364This function calls @var{function} once with each symbol in the obarray
365@var{obarray}. Then it returns @code{nil}. If @var{obarray} is
366omitted, it defaults to the value of @code{obarray}, the standard
367obarray for ordinary symbols.
1621af1e
RS
368
369@smallexample
370(setq count 0)
371 @result{} 0
372(defun count-syms (s)
373 (setq count (1+ count)))
374 @result{} count-syms
375(mapatoms 'count-syms)
376 @result{} nil
377count
378 @result{} 1871
379@end smallexample
380
381See @code{documentation} in @ref{Accessing Documentation}, for another
382example using @code{mapatoms}.
383@end defun
384
22697dac
KH
385@defun unintern symbol &optional obarray
386This function deletes @var{symbol} from the obarray @var{obarray}. If
387@code{symbol} is not actually in the obarray, @code{unintern} does
388nothing. If @var{obarray} is @code{nil}, the current obarray is used.
389
390If you provide a string instead of a symbol as @var{symbol}, it stands
391for a symbol name. Then @code{unintern} deletes the symbol (if any) in
392the obarray which has that name. If there is no such symbol,
393@code{unintern} does nothing.
394
395If @code{unintern} does delete a symbol, it returns @code{t}. Otherwise
396it returns @code{nil}.
397@end defun
398
1621af1e
RS
399@node Property Lists,, Creating Symbols, Symbols
400@section Property Lists
401@cindex property list
402@cindex plist
403
404 A @dfn{property list} (@dfn{plist} for short) is a list of paired
405elements stored in the property list cell of a symbol. Each of the
406pairs associates a property name (usually a symbol) with a property or
407value. Property lists are generally used to record information about a
2b3fc6c3
RS
408symbol, such as its documentation as a variable, the name of the file
409where it was defined, or perhaps even the grammatical class of the
410symbol (representing a word) in a language-understanding system.
1621af1e
RS
411
412 Character positions in a string or buffer can also have property lists.
413@xref{Text Properties}.
414
415 The property names and values in a property list can be any Lisp
f9f59935
RS
416objects, but the names are usually symbols. Property list functions
417compare the property names using @code{eq}. Here is an example of a
418property list, found on the symbol @code{progn} when the compiler is
419loaded:
1621af1e
RS
420
421@example
422(lisp-indent-function 0 byte-compile byte-compile-progn)
423@end example
424
425@noindent
426Here @code{lisp-indent-function} and @code{byte-compile} are property
427names, and the other two elements are the corresponding values.
428
22697dac
KH
429@menu
430* Plists and Alists:: Comparison of the advantages of property
431 lists and association lists.
432* Symbol Plists:: Functions to access symbols' property lists.
433* Other Plists:: Accessing property lists stored elsewhere.
434@end menu
435
436@node Plists and Alists
437@subsection Property Lists and Association Lists
438
1621af1e
RS
439@cindex property lists vs association lists
440 Association lists (@pxref{Association Lists}) are very similar to
441property lists. In contrast to association lists, the order of the
442pairs in the property list is not significant since the property names
443must be distinct.
444
445 Property lists are better than association lists for attaching
f9f59935
RS
446information to various Lisp function names or variables. If your
447program keeps all of its associations in one association list, it will
448typically need to search that entire list each time it checks for an
449association. This could be slow. By contrast, if you keep the same
450information in the property lists of the function names or variables
451themselves, each search will scan only the length of one property list,
452which is usually short. This is why the documentation for a variable is
453recorded in a property named @code{variable-documentation}. The byte
454compiler likewise uses properties to record those functions needing
455special treatment.
1621af1e
RS
456
457 However, association lists have their own advantages. Depending on
458your application, it may be faster to add an association to the front of
459an association list than to update a property. All properties for a
460symbol are stored in the same property list, so there is a possibility
461of a conflict between different uses of a property name. (For this
462reason, it is a good idea to choose property names that are probably
969fe9b5
RS
463unique, such as by beginning the property name with the program's usual
464name-prefix for variables and functions.) An association list may be
465used like a stack where associations are pushed on the front of the list
466and later discarded; this is not possible with a property list.
1621af1e 467
22697dac
KH
468@node Symbol Plists
469@subsection Property List Functions for Symbols
470
1621af1e
RS
471@defun symbol-plist symbol
472This function returns the property list of @var{symbol}.
473@end defun
474
475@defun setplist symbol plist
22697dac 476This function sets @var{symbol}'s property list to @var{plist}.
1621af1e
RS
477Normally, @var{plist} should be a well-formed property list, but this is
478not enforced.
479
480@smallexample
481(setplist 'foo '(a 1 b (2 3) c nil))
482 @result{} (a 1 b (2 3) c nil)
483(symbol-plist 'foo)
484 @result{} (a 1 b (2 3) c nil)
485@end smallexample
486
487For symbols in special obarrays, which are not used for ordinary
488purposes, it may make sense to use the property list cell in a
489nonstandard fashion; in fact, the abbrev mechanism does so
490(@pxref{Abbrevs}).
491@end defun
492
493@defun get symbol property
494This function finds the value of the property named @var{property} in
495@var{symbol}'s property list. If there is no such property, @code{nil}
496is returned. Thus, there is no distinction between a value of
497@code{nil} and the absence of the property.
498
499The name @var{property} is compared with the existing property names
500using @code{eq}, so any object is a legitimate property.
501
502See @code{put} for an example.
503@end defun
504
505@defun put symbol property value
506This function puts @var{value} onto @var{symbol}'s property list under
507the property name @var{property}, replacing any previous property value.
508The @code{put} function returns @var{value}.
509
510@smallexample
511(put 'fly 'verb 'transitive)
512 @result{}'transitive
513(put 'fly 'noun '(a buzzing little bug))
514 @result{} (a buzzing little bug)
515(get 'fly 'verb)
516 @result{} transitive
517(symbol-plist 'fly)
518 @result{} (verb transitive noun (a buzzing little bug))
519@end smallexample
520@end defun
22697dac
KH
521
522@node Other Plists
523@subsection Property Lists Outside Symbols
524
4e5d744e 525 These functions are useful for manipulating property lists
22697dac
KH
526that are stored in places other than symbols:
527
528@defun plist-get plist property
529This returns the value of the @var{property} property
530stored in the property list @var{plist}. For example,
531
532@example
533(plist-get '(foo 4) 'foo)
534 @result{} 4
535@end example
536@end defun
537
538@defun plist-put plist property value
bfe721d1
KH
539This stores @var{value} as the value of the @var{property} property in
540the property list @var{plist}. It may modify @var{plist} destructively,
cc8c51f1 541or it may construct a new list structure without altering the old. The
bfe721d1
KH
542function returns the modified property list, so you can store that back
543in the place where you got @var{plist}. For example,
22697dac
KH
544
545@example
546(setq my-plist '(bar t foo 4))
547 @result{} (bar t foo 4)
548(setq my-plist (plist-put my-plist 'foo 69))
549 @result{} (bar t foo 69)
550(setq my-plist (plist-put my-plist 'quux '(a)))
f9f59935 551 @result{} (bar t foo 69 quux (a))
22697dac
KH
552@end example
553@end defun
554
969fe9b5
RS
555 You could define @code{put} in terms of @code{plist-put} as follows:
556
557@example
558(defun put (symbol prop value)
559 (setplist symbol
560 (plist-put (symbol-plist symbol) prop value)))
561@end example
4e5d744e 562
55ccf8be
RS
563@defun lax-plist-get plist property
564Like @code{plist-get} except that it compares properties
565using @code{equal} instead of @code{eq}.
566@end defun
567
568@defun lax-plist-put plist property value
569Like @code{plist-put} except that it compares properties
570using @code{equal} instead of @code{eq}.
571@end defun
572
4e5d744e
DL
573@defun plist-member plist property
574@tindex plist-member
575This returns non-@code{nil} if @var{plist} contains the given
576@var{property}. Unlike @code{plist-get}, this allows you to distinguish
577between a missing property and a property with the value @code{nil}.
578The value is actually the tail of @var{plist} whose @code{car} is
579@var{property}.
580@end defun
ab5796a9
MB
581
582@ignore
583 arch-tag: 8750b7d2-de4c-4923-809a-d35fc39fd8ce
584@end ignore