Setting Variable Values
The usual way to change the value of a variable is with the special form setq. When you need to compute the choice of variable at run time, use the function set.
- Special Form: setq [symbol form]…
-
This special form is the most common method of changing a variable’s value. Each symbol is given a new value, which is the result of evaluating the corresponding form. The current binding of the symbol is changed.
setqdoes not evaluate symbol; it sets the symbol that you write. We say that this argument is automatically quoted. The ‘q’ insetqstands for “quoted”.The value of the
setqform is the value of the last form.(setq x (1+ 2)) ⇒ 3x ;xnow has a global value. ⇒ 3(let ((x 5)) (setq x 6) ; The local binding ofxis set. x) ⇒ 6x ; The global value is unchanged. ⇒ 3Note that the first form is evaluated, then the first symbol is set, then the second form is evaluated, then the second symbol is set, and so on:
(setq x 10 ; Notice that
xis set before y (1+ x)) ; the value ofyis computed. ⇒ 11
- Function: set symbol value
-
This function puts value in the value cell of symbol. Since it is a function rather than a special form, the expression written for symbol is evaluated to obtain the symbol to set. The return value is value.
When dynamic variable binding is in effect (the default),
sethas the same effect assetq, apart from the fact thatsetevaluates its symbol argument whereassetqdoes not. But when a variable is lexically bound,setaffects its dynamic value, whereassetqaffects its current (lexical) value. See Variable Scoping.(set one 1) error→ Symbol's value as variable is void: one
(set 'one 1) ⇒ 1(set 'two 'one) ⇒ one(set two 2) ;twoevaluates to symbolone. ⇒ 2one ; So it is
onethat was set. ⇒ 2 (let ((one 1)) ; This binding ofoneis set, (set 'one 3) ; not the global value. one) ⇒ 3one ⇒ 2If symbol is not actually a symbol, a
wrong-type-argumenterror is signaled.(set '(x y) 'z) error→ Wrong type argument: symbolp, (x y)
Copyright © 1990-1996, 1998-2021 Free Software Foundation, Inc.
Licensed under the GNU GPL license.
https://www.gnu.org/software/emacs/manual/html_node/elisp/Setting-Variables.html