Major Section: EVENTS
Examples: (defconst *digits* '(0 1 2 3 4 5 6 7 8 9)) (defconst *n-digits* (the unsigned-byte (length *digits*))) General Form: (defconst name term doc-string)where
name is a symbol beginning and ending with the character *,
term is a variable-free term that is evaluated to determine the
value of the constant, and doc-string is an optional documentation
string (see doc-string).When a constant symbol is used as a term, ACL2 replaces it by its value; see term.
Note that defconst uses a ``safe mode'' to evaluate its form, in order
to avoids soundness issues but with an efficiency penalty (perhaps increasing
the evaluation time by several hundred percent). If efficiency is a concern,
or if for some reason you need the form to be evaluated without safe mode
(e.g., you are an advanced system hacker using trust tags to traffic in raw
Lisp code), consider using the macro defconst-fast instead, defined in
community book books/make-event/defconst-fast.lisp, for example:
(defconst-fast *x* (expensive-fn ...))A more general utility may be found in community book
books/tools/defconsts.lisp. Also see using-tables-efficiently for an
analogous issue with table events.It may be of interest to note that defconst is implemented at the
lisp level using defparameter, as opposed to defconstant.
(Implementation note: this is important for proper support of
undoing and redefinition.)
We close with a technical remark, perhaps of interest only to users of
ACL2(h), the experimental extension of ACL2 that supports hash cons, function
memoization, and hash-table-based ``fast alists''; see hons-and-memoization.
For an event of the form (defconst *C* (quote OBJ)), i.e.,
(defconst *C* 'OBJ), then the value associated with *C* is OBJ;
that is, the value of *C* is eq to the actual object OBJ
occurring in the defconst form. So for example, if make-event is
used to generate such a defconst event, as it is in the two books
mentioned above, and OBJ is a fast alist (using ACL2(h)), then the value
of *C* is a fast alist. This guarantee disappears if the term in the
defconst form is not a quoted object, i.e., if it is not of the form
(quote OBJ).