clisp (1)
Leading comments
Title: clisp Author: Bruno Haible <\m[blue]\fB\%http://www.haible.de/bruno/\fR\m[]> Generator: DocBook XSL Stylesheets vsnapshot_8706 <http://docbook.sf.net/> Date: Last modified: 2010-07-07 Manual: Platform: x86_64-unknown-linux-gnu Source: CLISP 2.49 Language: English
NAME
clisp - m[blue]ANSIm[]SYNOPSIS
- clisp [[-h] | [--help]] [--version] [--license] [-help-image] [-B lisp-lib-dir] [-b] [-K linking-set] [-M mem-file] [-m memory-size] [-L language] [-N locale-dir] [-Edomain encoding] [[-q] | [--quiet] | [--silent] | [-v] | [--verbose]] [-on-error action] [-repl] [-w] [-I] [-disable-readline] [[-ansi] | [-traditional]] [-modern] [-p package] [-C] [-norc] [-lp directory...] [-i init-file...] [-c [-l] lisp-file [-o output-file]...] [-x expressions...] [lisp-file [argument...]]
DESCRIPTION
Interactive Mode
When called without arguments, executes the m[blue]read-eval-print loopm[]
-
*
m[blue]READm[][3]from the standard input,
-
*
m[blue]EVALm[][4]uated by the lisp interpreter,
-
*
and their results are
m[blue]PRINTm[][5]ed to the standard output.
Non-Interactive (Batch) Mode
Invoked with -c, compiles the specified lisp files to a platform-independent bytecode which can be executed more efficiently.
Invoked with -x, executes the specified lisp expressions.
Invoked with lisp-file, runs the specified lisp file.
OPTIONS
-h
--help
-
Displays a help message on how to invoke
m[blue]CLISPm[][6].
--version
-
Displays the
m[blue]CLISPm[][6]version number, as given by the function m[blue]LISP-IMPLEMENTATION-VERSIONm[][7], the value of the variable *FEATURES*, as well some other information.
--license
-
Displays a summary of the licensing information, the
m[blue]GNUm[][8]m[blue]GPLm[][9].
-help-image
- Displays information about the memory image being invoked: whether is it suitable for scripting as well as the :DOCUMENTATION supplied to EXT:SAVEINITMEM.
-B lisp-lib-dir
-
Specifies the installation directory. This is the directory containing the linking sets and other data files. This option is normally not necessary, because the installation directory is already built-in into the
clisp
executable. Directory
lisp-lib-dir
can be changed dynamically using the
m[blue]SYMBOL-MACROm[][10]CUSTOM:*LIB-DIRECTORY*.
-b
- Print the installation directory and exit immediately. The namestring of CUSTOM:*LIB-DIRECTORY* is printed without any quotes. This is mostly useful in module Makefiles, see, e.g., modules/syscalls/Makefile.in (file in the CLISP sources).
-K linking-set
-
Specifies the
linking set
to be run. This is a directory (relative to the
lisp-lib-dir) containing at least a main executable (runtime) and an initial
memory image. Possible values are
base
-
the core
m[blue]CLISPm[][6]
full
- core plus all the modules with which this installation was built, see Section 32.2, lqExternal Modulesrq.
The default is base.
-
the core
m[blue]CLISPm[]
-M mem-file
-
Specifies the initial
memory image. This must be a memory dump produced by the
EXT:SAVEINITMEM
function by this
clisp
runtime.
It may have been compressed using
m[blue]GNUm[][8]m[blue]gzipm[][11].
-m memory-size
-
Sets the amount of memory
m[blue]CLISPm[][6]tries to grab on startup. The amount may be given as
n
nB- measured in bytes
n
nW- measured in machine words (4×n on 32-bit platforms, 8×n on 64-bit platforms)
nK
nKB- measured in kilobytes
nKW
- measured in kilowords
nM
nMB- measured in megabytes
nMW
- measured in megawords
The default is 3 megabytes. The argument is constrained above 100 KB.
This version of m[blue]CLISPm[]
[6]is not likely to actually use the entire memory-size since garbage-collection will periodically reduce the amount of used memory. It is therefore common to specify 10 MB even if only 2 MB are going to be used.
-L language
-
Specifies the
language
m[blue]CLISPm[][6]uses to communicate with the user. This may be one of english, german, french, spanish, dutch, russian, danish. Other languages may be specified through the m[blue]environment variablem[][12]LANG, provided the corresponding message catalog is installed. The language may be changed dynamically using the m[blue]SYMBOL-MACROm[][10]CUSTOM:*CURRENT-LANGUAGE*.
-N locale-dir
-
Specifies the base directory of locale files.
m[blue]CLISPm[][6]will search its message catalogs in locale-dir/language/LC_MESSAGES/clisp.mo. This directory may be changed dynamically using the m[blue]SYMBOL-MACROm[][10]CUSTOM:*CURRENT-LANGUAGE*.
-Edomain encoding
-
Specifies the encoding used for the given domain, overriding the default which depends on the
m[blue]environment variablem[][12]s LC_ALL, LC_CTYPE, LANG. domain can be
file
- affecting CUSTOM:*DEFAULT-FILE-ENCODING*
pathname
- affecting CUSTOM:*PATHNAME-ENCODING*
terminal
- affecting CUSTOM:*TERMINAL-ENCODING*
foreign
- affecting CUSTOM:*FOREIGN-ENCODING*
misc
- affecting CUSTOM:*MISC-ENCODING*
blank
- affecting all of the above.
-
Warning
Note that the values of these m[blue]SYMBOL-MACROm[][10]s that have been saved in a memory image are ignored: these m[blue]SYMBOL-MACROm[][10]s are reset based on the OS environment after the memory image is loaded. You have to use the RC file, CUSTOM:*INIT-HOOKS* or init function to set them on startup, but it is best to set the aforementioned m[blue]environment variablem[][12]s appropriately for consistency with other programs. See Section 31.1, lqCustomizing CLISP Process Initialization and Terminationrq.
-q
--quiet
--silent
-v
--verbose
-
Change verbosity level: by default,
m[blue]CLISPm[][6]displays a banner at startup and a good-bye message when quitting, and initializes m[blue]*LOAD-VERBOSE*m[][13]and m[blue]*COMPILE-VERBOSE*m[][14]to m[blue]Tm[][15], and m[blue]*LOAD-PRINT*m[][13]and m[blue]*COMPILE-PRINT*m[][14]to m[blue]NILm[][16], as per [ANSI CL standard]. The first -q removes the banner and the good-bye message, the second sets variables m[blue]*LOAD-VERBOSE*m[][13], m[blue]*COMPILE-VERBOSE*m[][14]and CUSTOM:*SAVEINITMEM-VERBOSE* to m[blue]NILm[][16]. The first -v sets variables CUSTOM:*REPORT-ERROR-PRINT-BACKTRACE*, m[blue]*LOAD-PRINT*m[][13]and m[blue]*COMPILE-PRINT*m[][14]to m[blue]Tm[][15], the second sets CUSTOM:*LOAD-ECHO* to m[blue]Tm[][15]. These settings affect the output produced by -i and -c options. Note that these settings persist into the m[blue]read-eval-print loopm[][2]. Repeated -q and -v cancel each other, e.g., -q -q -v -v -v is equivalent to -v.
-on-error action
-
Establish global error handlers, depending on
action:.PP
appease
-
m[blue]continuablem[][17]m[blue]ERRORm[][18]s are turned into m[blue]WARNINGm[][19]s (with EXT:APPEASE-CERRORS) other m[blue]ERRORm[][18]s are handled in the default way
debug
-
m[blue]ERRORm[][18]s m[blue]INVOKE-DEBUGGERm[][20](the normal m[blue]read-eval-print loopm[][2]behavior), disables batch mode imposed by -c, -x, and lisp-file,
abort
-
m[blue]continuablem[][17]m[blue]ERRORm[][18]s are appeased, other m[blue]ERRORm[][18]s are m[blue]ABORTm[][21]ed with EXT:ABORT-ON-ERROR
exit
-
m[blue]continuablem[][17]m[blue]ERRORm[][18]s are appeased, other m[blue]ERRORm[][18]s terminate m[blue]CLISPm[][6]with EXT:EXIT-ON-ERROR (the normal batch mode behavior).
See also EXT:SET-GLOBAL-HANDLER.
-
m[blue]continuablem[]
-repl
-
Start an interactive
m[blue]read-eval-print loopm[][2]after processing the -c, -x, and lisp-file options and on any m[blue]ERRORm[][18]m[blue]SIGNALm[][22]ed during that processing.
Disables batch mode.
-w
- Wait for a keypress after program termination.
-I
-
Interact better with
m[blue]Emacsm[][23](useful when running m[blue]CLISPm[][6]under m[blue]Emacsm[][23]using m[blue]SLIMEm[][24], m[blue]ILISPm[][25]et al). With this option, m[blue]CLISPm[][6]interacts in a way that m[blue]Emacsm[][23]can deal with:
- * unnecessary prompts are not suppressed.
-
*
The
m[blue]GNUm[][8]m[blue]readlinem[][26]library treats TAB (see TAB key) as a normal self-inserting character (see Q: A.4.6).
-disable-readline
-
Do not use
m[blue]GNUm[][8]m[blue]readlinem[][26]even when it has been linked against. This can be used if one wants to paste non-m[blue]ASCIIm[][27]characters, or when m[blue]GNUm[][8]m[blue]readlinem[][26]misbehaves due to installation (different versions on the build and install machines) or setup (bad TERM m[blue]environment variablem[][12]value) issues.
-ansi
-
Comply with the
[ANSI CL standard]
specification even where
m[blue]CLISPm[][6]has been traditionally different by setting the m[blue]SYMBOL-MACROm[][10]CUSTOM:*ANSI* to m[blue]Tm[][15].
-traditional
- Traditional: reverses the residual effects of -ansi in the saved memory image.
-modern
-
Provides a modern view of symbols: at startup the
m[blue]*PACKAGE*m[][28]variable will be set to the lqCS-COMMON-LISP-USERrq package, and the m[blue]*PRINT-CASE*m[][29]will be set to :DOWNCASE. This has the effect that symbol lookup is case-sensitive (except for keywords and old-style packages) and that keywords and uninterned symbols are printed with lower-case preferrence. See Section 11.5, lqPackage Case-Sensitivityrq.
-p package
-
At startup the value of the variable
m[blue]*PACKAGE*m[][28]will be set to the package named package. The default is the value of m[blue]*PACKAGE*m[][28]when the image was saved, normally m[blue]lqCOMMON-LISP-USERrqm[][30].
-C
-
Compile when loading: at startup the value of the variable
CUSTOM:*LOAD-COMPILING*
will be set to
m[blue]Tm[][15]. Code being m[blue]LOADm[][31]ed will then be m[blue]COMPILEm[][32]d on the fly. This results in slower loading, but faster execution.
-norc
-
Normally
m[blue]CLISPm[][6]loads the user m[blue]lqrun controlrq (RC)m[][33]file on startup (this happens after the -C option is processed). The file loaded is .clisprc.lisp or .clisprc.fas in the home directory m[blue]USER-HOMEDIR-PATHNAMEm[][34], whichever is newer. This option, -norc, prevents loading of the RC file.
-lp directory
- Specifies directories to be added to CUSTOM:*LOAD-PATHS* at startup. This is done after loading the RC file (so that it does not override the command-line option) but before loading the init-files specified by the -i options (so that the init-files will be searched for in the specified directories). Several -lp options can be given; all the specified directories will be added.
-i init-file
-
Specifies initialization files to be
m[blue]LOADm[][31]ed at startup. These should be lisp files (source or compiled). Several -i options can be given; all the specified files will be loaded in order.
-c lisp-file
-
Compiles the specified
lisp-files to
bytecode
(*.fas). The compiled files can then be
m[blue]LOADm[][31]ed instead of the sources to gain efficiency.
Imposes batch mode.
-o outputfile
- Specifies the output file or directory for the compilation of the last specified lisp-file.
-l
-
Produce a
bytecode
m[blue]DISASSEMBLEm[][35]listing (*.lis) of the files being compiled. Useful only for debugging. See Section 24.1, lqFunction COMPILE-FILErq for details.
-x expressions
-
Executes a series of arbitrary expressions instead of a
m[blue]read-eval-print loopm[][2]. The values of the expressions will be output to m[blue]*STANDARD-OUTPUT*m[][36]. Due to the argument processing done by the shell, the expressions must be enclosed in double quotes, and double quotes and backslashes must be escaped with backslashes.
Imposes batch mode.
lisp-file [ argument ... ]
-
Loads and executes a
lisp-file, as described in
Section 32.6.2, lqScripting with CLISPrq. There will be no
m[blue]read-eval-print loopm[][2]. Before lisp-file is loaded, the variable EXT:*ARGS* will be bound to a list of strings, representing the arguments. The first line of lisp-file may start with #!, thus permitting m[blue]CLISPm[][6]to be used as a script interpreter. If lisp-file is -, the m[blue]*STANDARD-INPUT*m[][36]is used instead of a file.
This option is disabled if the memory image was created by EXT:SAVEINITMEM with m[blue]NILm[]
[16]:SCRIPT argument. In that case the m[blue]LISTm[][37]EXT:*ARGS* starts with lisp-file.This option must be the last one.
No RC file will be executed.
Imposes batch mode.
As usual, -- stops option processing and places all remaining command line arguments into EXT:*ARGS*.
LANGUAGE REFERENCE
The language implemented is m[blue]ANSI
m[blue]Information Technology - Programming Language - Common Lispm[]
[formerly ANSI X3.226-1994 (R1999)].
COMMAND LINE USER ENVIRONMENT
help
- get context-sensitive on-line help, see Chapter 25, Environment.
(APROPOS name)
-
list the
m[blue]SYMBOLm[][41]s matching name.
(DESCRIBE symbol)
- describe the symbol.
(exit)
(quit)
(bye)
-
quit
m[blue]CLISPm[][6].
EOF (Control+D on m[blue]UNIXm[]
-
leave the current level of the
m[blue]read-eval-print loopm[][2](see also Section 1.1, lqSpecial Symbols rq).
arrow keys
-
for editing and viewing the input history, using the
m[blue]GNUm[][8]m[blue]readlinem[][26]library.
TAB key
-
Context sensitive:
-
*
If you are in the
lqfunction positionrq
(in the first symbol after an opening paren or in the first symbol after a
m[blue]#'m[][44]), the completion is limited to the symbols that name functions.
-
*
If you are in the "filename position" (inside a string after
m[blue]#Pm[][45]), the completion is done across file names, m[blue]GNUm[][8]m[blue]bashm[][46]-style.
- * If you have not typed anything yet, you will get a help message, as if by the help command.
- * If you have not started typing the next symbol (i.e., you are at a whitespace), the current function or macro is DESCRIBEd.
- * Otherwise, the symbol you are currently typing is completed.
-
*
If you are in the
lqfunction positionrq
(in the first symbol after an opening paren or in the first symbol after a
m[blue]#'m[]
USING AND EXTENDING CLISP
m[blue]Common Lispm[]
To avoid having to re-enter the same definitions by hand in every session, one can create a lisp file with all the variables, functions, macros, etc.; (optionally) compile it with m[blue]COMPILE-FILEm[]
However, sometimes one needs to use some functionality implemented in another language, e.g., call a m[blue]Cm[]
FILES
clisp
clisp.exe
- startup driver (an executable or, rarely, a shell script) which remembers the location of the runtime and starts it with the appropriate arguments
lisp.run
lisp.exe
-
main executable (runtime) - the part of
m[blue]CLISPm[][6]implemented in m[blue]Cm[][52].
lispinit.mem
-
initial
memory image
(the part of
m[blue]CLISPm[][6]implemented in lisp)
config.lisp
-
site-dependent configuration (should have been customized before
m[blue]CLISPm[][6]was built); see Section 31.12, lqCustomizing CLISP behaviorrq
*.lisp
- lisp source
*.fas
-
lisp code, compiled by
m[blue]CLISPm[][6]
*.lib
- lisp source library information, generated by COMPILE-FILE, see Section 24.3, lqFunction REQUIRErq.
*.c
-
C code, compiled from lisp source by
m[blue]CLISPm[][6](see Section 32.3, lqThe Foreign Function Call Facilityrq)
For the m[blue]CLISPm[]
ENVIRONMENT
All m[blue]environment variablem[]
CLISP_LANGUAGE
-
specifies the language
m[blue]CLISPm[][6]uses to communicate with the user. The legal values are identical to those of the -L option which can be used to override this m[blue]environment variablem[][12].
LC_CTYPE
-
specifies the locale which determines the character set in use. The value can be of the form
language
or
language_country
or
language_country.charset, where
language
is a two-letter ISO 639 language code (lower case),
country
is a two-letter ISO 3166 country code (upper case).
charset
is an optional character set specification, and needs normally not be given because the character set can be inferred from the language and country. This
m[blue]environment variablem[][12]can be overridden with the -Edomain encoding option.
LANG
-
specifies the language
m[blue]CLISPm[][6]uses to communicate with the user, unless it is already specified through the m[blue]environment variablem[][12]CLISP_LANGUAGE or the -L option. It also specifies the locale determining the character set in use, unless already specified through the m[blue]environment variablem[][12]LC_CTYPE. The value may begin with a two-letter ISO 639 language code, for example en, de, fr.
HOME
USER
-
used for determining the value of the function
m[blue]USER-HOMEDIR-PATHNAMEm[][34].
SHELL
COMSPEC
- is used to find the interactive command interpreter called by EXT:SHELL.
TERM
- determines the screen size recognized by the pretty printer.
ORGANIZATION
-
for
m[blue]SHORT-SITE-NAMEm[][53]and m[blue]LONG-SITE-NAMEm[][53]in config.lisp.
CLHSROOT
- for CUSTOM:CLHS-ROOT in config.lisp.
IMPNOTES
- for CUSTOM:IMPNOTES-ROOT in config.lisp.
EDITOR
- for editor-name in config.lisp.
LOGICAL_HOST_host_FROM
LOGICAL_HOST_host_TO
LOGICAL_HOST_host
- for CUSTOM:*LOAD-LOGICAL-PATHNAME-TRANSLATIONS-DATABASE*
INPUT AND OUTUT
See Section 21.1.1, lqInitialization of Standard Streamsrq.
SEE ALSO
- CLISP impnotes
-
m[blue]CMU CLm[][54]- cmucl(1)
-
m[blue]Emacsm[][23]- emacs(1)
-
m[blue]XEmacsm[][55]- xemacs(1)
BUGS
When you encounter a bug in m[blue]CLISPm[]
Before submitting a bug report, please take the following basic steps to make the report more useful:
-
1.
Please do a clean build (remove your build directory and build
m[blue]CLISPm[][6]with ./configure --cbc build or at least do a make distclean before make).
-
2.
If you are reporting a
lqhard crashrq
(segmentation fault, bus error, core dump etc), please do
./configure --with-debug --cbc build-g ; cd build-g; gdb lisp.run, then load the appropriate
linking set
by either
base
or
full
m[blue]gdbm[][57]command, and report the backtrace (see also Q: A.1.1.10).
- 3. If you are using pre-built binaries and experience a hard crash, the problem is likely to be in the incompatibilities between the platform on which the binary was built and yours; please try compiling the sources and report the problem if it persists.
When submitting a bug report, please specify the following information:
-
1.
What is your platform (uname -a
on a
m[blue]UNIXm[][42]system)? Compiler version? m[blue]GNUm[][8]m[blue]libcm[][58]version (on m[blue]GNUm[][8]/m[blue]Linuxm[][59])?
- 2. Where did you get the sources or binaries? When? (Absolute dates, e.g., lq2006-01-17rq, are preferred over the relative ones, e.g., lq2 days agorq).
-
3.
How did you build
m[blue]CLISPm[][6]? (What command, options &c.)
- 4. What is the output of clisp --version?
- 5. Please supply the full output (copy and paste) of all the error messages, as well as detailed instructions on how to reproduce them.
PROJECTS
- * Enhance the compiler so that it can inline local functions.
-
*
Embed
m[blue]CLISPm[][6]in m[blue]VIMm[][60].
AUTHORS
Bruno Haible <m[blue]www.haible.de/brunom[]>
- The original author and long-time maintainer.
Michael Stoll <m[blue]www.faculty.iu-bremen.de/mstollm[]>
- The original author.
Sam Steingold <m[blue]sds.podval.orgm[]>
- Co-maintainer since 1998.
Others
- See COPYRIGHT (file in the CLISP sources) for the list of other contributors and the license.
COPYRIGHT
Copyright © 1992-2010 Bruno Haible
Copyright © 1998-2010 Sam Steingold
NOTES
- 1.
- Common Lisp
- 2.
-
read-eval-print loop
- [set $man.base.url.for.relative.links]/sec_25-1-1
- 3.
- READ
- 4.
- EVAL
- 5.
- 6.
- CLISP
- 7.
- LISP-IMPLEMENTATION-VERSION
- 8.
- GNU
- 9.
- GPL
- 10.
-
SYMBOL-MACRO
- [set $man.base.url.for.relative.links]/mac_define-symbol-macro
- 11.
- gzip
- 12.
-
environment variable
- [set $man.base.url.for.relative.links]/basedefs/xbd_chap08.html
- 13.
- *LOAD-VERBOSE*
- 14.
- *COMPILE-VERBOSE*
- 15.
- T
- 16.
- NIL
- 17.
-
continuable
- [set $man.base.url.for.relative.links]/clhs/glo
- 18.
- ERROR
- 19.
- WARNING
- 20.
- INVOKE-DEBUGGER
- 21.
- ABORT
- 22.
- SIGNAL
- 23.
- Emacs
- 24.
- SLIME
- 25.
- ILISP
- 26.
- readline
- 27.
- ASCII
- 28.
- *PACKAGE*
- 29.
- *PRINT-CASE*
- 30.
-
lqCOMMON-LISP-USERrq
- [set $man.base.url.for.relative.links]/sec_11-1-2-2
- 31.
- LOAD
- 32.
- COMPILE
- 33.
-
lqrun
controlrq (RC) - 34.
- USER-HOMEDIR-PATHNAME
- 35.
- DISASSEMBLE
- 36.
- *STANDARD-OUTPUT*
- 37.
- LIST
- 38.
- ANSI
- 39.
- The American National Standards Institute
- 40.
- Information Technology - Programming Language - Common Lisp
- 41.
- SYMBOL
- 42.
- UNIX
- 43.
- Win32
- 44.
-
#'
- [set $man.base.url.for.relative.links]/sec_2-4-8-2
- 45.
-
#P
- [set $man.base.url.for.relative.links]/sec_2-4-8-14
- 46.
- bash
- 47.
- John Foderaro
- 48.
- DEFVAR
- 49.
- DEFUN
- 50.
- DEFMACRO
- 51.
- COMPILE-FILE
- 52.
- C
- 53.
- SHORT-SITE-NAME
- 54.
- CMU CL
- 55.
- XEmacs
- 56.
-
SourceForge bug tracker
- sourceforge.net/tracker/?func=add&group_id=1355&atid=101355
- 57.
- gdb
- 58.
- libc
- 59.
- Linux
- 60.
-
VIM