mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-01-01 05:16:05 +01:00
273 lines
12 KiB
Text
273 lines
12 KiB
Text
--------------
|
|
INSTALLING ZSH
|
|
--------------
|
|
|
|
Check MACHINES File
|
|
-------------------
|
|
|
|
Check the file MACHINES in the subdirectory Etc to see the architectures
|
|
that zsh is known to compile on, as well as any special instructions
|
|
for your particular architecture. Most architectures will not require any
|
|
special instructions.
|
|
|
|
Configuring Zsh
|
|
---------------
|
|
|
|
To configure zsh, from the top level directory, do the command:
|
|
./configure
|
|
|
|
Configure accepts several options (explained below). To display
|
|
currently available options, do the command:
|
|
./configure --help
|
|
|
|
Most of the interesting configuration options can be added after running
|
|
configure by editing the user configuration section of config.h and the
|
|
top level Makefile.
|
|
|
|
Dynamic loading
|
|
---------------
|
|
|
|
Zsh-3.1 has support for dynamically loadable modules. To enable this run
|
|
configure with the --enable-dynamic option. Note that dynamic loading
|
|
does not work on all systems. On these systems this option will have no
|
|
effect, so it is always safe to use --enable-dynamic. When dynamic
|
|
loading is enabled, major parts of zsh (including the Zsh Line Editor) are
|
|
compiled into modules and not included into the main zsh binary. Zsh
|
|
autoloads these modules when they are required. This means that you have
|
|
to execute make install.modules before you try the newly compiled zsh
|
|
executable.
|
|
|
|
Adding more modules
|
|
-------------------
|
|
|
|
The zsh distribution contains several modules, in the Src/Builtins,
|
|
Src/Modules and Src/Zle directories. If you have any additional zsh
|
|
modules that you wish to compile for this version of zsh, create another
|
|
subdirectory of the Src directory and put them there. You can create
|
|
as many extra subdirectory hierarchies as you need. The subdirectories
|
|
must be actual directories; symbolic links will not work.
|
|
|
|
If you wish to add or remove modules or module directories after you
|
|
have already run make, then after adding or removing the modules run:
|
|
make prep
|
|
|
|
Controlling what is compiled into the main zsh binary
|
|
-----------------------------------------------------
|
|
|
|
By default the comp1, compctl, zle, sched and rlimits modules are compiled
|
|
into non-dynamic zsh and no modules are compiled into the main binary if
|
|
dynamic loading is available. This can be overridden by creating the file
|
|
mymods.conf in the compilation directory (Src, unless you have told
|
|
configure to use another directory) with the list of modules which are to
|
|
be compiled into the main binary. See the zshmodules manual page for the
|
|
list of available modules.
|
|
|
|
Compiler Options or Using a Different Compiler
|
|
----------------------------------------------
|
|
|
|
By default, configure will use the "gcc" compiler if found. You can use a
|
|
different compiler, or add unusual options for compiling or linking that
|
|
the "configure" script does not know about, by either editing the user
|
|
configuration section of the top level Makefile (after running configure)
|
|
or giving "configure" initial values for these variables by setting them
|
|
in the environment. Using a Bourne-compatible shell (such as sh,ksh,zsh),
|
|
|
|
you can do that on the command line like this:
|
|
CC=c89 CFLAGS=-O2 LIBS=-lposix ./configure
|
|
|
|
Or on systems that have the "env" program, you can do it like this:
|
|
env CPPFLAGS=-I/usr/local/include LDFLAGS=-s ./configure
|
|
|
|
Check Generated Files
|
|
---------------------
|
|
|
|
Configure will probe your system and create a "config.h" header file.
|
|
You should check the user configuration section at the beginning of
|
|
this include file. You should also examine the values (determined by
|
|
configure) of HOSTTYPE, OSTYPE, MACHTYPE, and VENDOR to make sure they
|
|
are correct. The value of these #defines's is used only to initialize
|
|
the corresponding default shell parameters. Since these shell parameters
|
|
are only for informational purposes, you can change them to whatever
|
|
you feel is appropriate.
|
|
|
|
Also configure will create a Makefile in the top level directory as well
|
|
as in the various subdirectories. You should check the user configuration
|
|
section of the top level Makefile.
|
|
|
|
Compiling Zsh
|
|
-------------
|
|
|
|
After configuring, to build zsh, do the command:
|
|
make
|
|
|
|
Installing Zsh
|
|
--------------
|
|
|
|
If no make/compilation errors occur, then to install the zsh binary, do
|
|
the command:
|
|
make install.bin
|
|
|
|
Any previous copy of zsh will be renamed "zsh.old"
|
|
|
|
To install the dynamically-loadable modules, do the command:
|
|
make install.modules
|
|
|
|
To install the zsh man page, do the command:
|
|
make install.man
|
|
|
|
Or alternatively, you can install all the above with the command:
|
|
make install
|
|
|
|
To install the zsh info files (this must be done separately), do the
|
|
command:
|
|
make install.info
|
|
|
|
If the programme install-info is available, "make install.info" will
|
|
insert an entry in the file "dir" in the same directory as the info
|
|
files. Otherwise you will have to edit the topmost node of the info
|
|
tree "dir" manually in order to have the zsh info files available to
|
|
your info reader.
|
|
|
|
Building Zsh On Additional Architectures
|
|
----------------------------------------
|
|
|
|
To build zsh on additional architectures, you can do a "make distclean".
|
|
This should restore the zsh source distribution back to its original
|
|
state. You can then configure zsh as above on other architectures in
|
|
which you wish to build zsh. Or alternatively, you can use a different
|
|
build directory for each architecture.
|
|
|
|
Using A Different Build Directory
|
|
---------------------------------
|
|
|
|
You can compile the zsh in a different directory from the one containing
|
|
the source code. Doing so allows you to compile it on more than one
|
|
architecture at the same time. To do this, you must use a version of
|
|
"make" that supports the "VPATH" variable, such as GNU "make". "cd" to
|
|
the directory where you want the object files and executables to go and
|
|
run the "configure" script. "configure" automatically checks for the
|
|
source code in the directory that "configure" is in. For example,
|
|
|
|
cd /usr/local/SunOS/zsh
|
|
/usr/local/src/zsh-3.0/configure
|
|
make
|
|
|
|
Memory Routines
|
|
---------------
|
|
|
|
Included in this release are alternate malloc and associated functions
|
|
which reduce memory usage on some systems. To use these, add the option
|
|
--enable-zsh-mem
|
|
when invoking "configure".
|
|
|
|
You should check Etc/MACHINES to see if there are specific recommendations
|
|
about using the zsh malloc routines on your particular architecture.
|
|
|
|
Debugging Routines
|
|
------------------
|
|
|
|
You can turn on various debugging options when invoking "configure".
|
|
|
|
To turn on some extra checking in the memory management routines, you
|
|
can use the following options when invoking "configure".
|
|
--enable-zsh-mem-warning # turn on warnings of memory allocation errors
|
|
--enable-zsh-secure-free # turn on memory checking of free()
|
|
|
|
If you are using zsh's memory allocation routines (--enable-zsh-mem), you
|
|
can turn on debugging of this code. This enables the builtin "mem".
|
|
--enable-zsh-mem-debug # debug zsh's memory allocators
|
|
|
|
You can turn on some debugging information of zsh's internal hash tables.
|
|
This enables the builtin "hashinfo".
|
|
--enable-zsh-hash-debug # turn on debugging of internal hash tables
|
|
|
|
To add some sanity checks and generate debugging information for debuggers
|
|
you can use the following option. This also disables optimization.
|
|
--enable-zsh-debug # use it if you want to debug zsh
|
|
|
|
Startup/shutdown files
|
|
----------------------
|
|
|
|
Zsh has several startup/shutdown files which are in /etc by default. This
|
|
can be overriden using one of the options below when invoking "configure".
|
|
|
|
--enable-etcdir=directory # default directory for global zsh scripts
|
|
--enable-zshenv=pathname # the full pathname of the global zshenv script
|
|
--enable-zshrc=pathname # the full pathname of the global zshrc script
|
|
--enable-zlogin=pathname # the full pathname of the global zlogin script
|
|
--enable-zprofile=pathname # the full pathname of the global zprofile script
|
|
--enable-zlogout=pathname # the full pathname of the global zlogout script
|
|
|
|
Any startup/shutdown script can be disabled by giving the
|
|
--disable-scriptname option to "configure". The --disable-etcdir option
|
|
disables all startup/shutdown files which are not explicitely enabled.
|
|
|
|
Support for large files and integers
|
|
------------------------------------
|
|
|
|
Some 32-bit systems allow special compilation modes to get around the 2GB
|
|
file size barrier; the zsh support for this is still experimental, and
|
|
feedback is particularly appreciated. The option --enable-lfs turns on the
|
|
configure check for support for large files. Not all systems recognize the
|
|
test used by zsh (via the getconf command), so flags may need to be set by
|
|
hand, but --enable-lfs should be used in any case to compile in the code
|
|
for using 64 bit integers. On HP-UX 10.20, zsh has been successfully
|
|
compiled with large file support by configuring with
|
|
CC="cc -Ae" CPPFLAGS="-D_LARGEFILE_SOURCE -D_FILE64" configure \
|
|
--enable-lfs ...
|
|
You can also give a value to --enable-lfs, which will be interpreted as the
|
|
name of a 64-bit integer type, for example --enable-lfs="long long"
|
|
(although this type is checked for anyway).
|
|
|
|
Furthermore, use of --enable-lfs will also enable 64-bit arithmetic for
|
|
shell parameters, and anywhere they are used such as in mathematical
|
|
formulae. This depends only on the shell finding a suitable 64-bit integer
|
|
type; it does not require that support for large files is actually
|
|
enabled. Hence you might consider using --enable-lfs on any 32-bit system
|
|
with a suitable compiler such as gcc.
|
|
|
|
None of this is relevant for 64-bit systems; zsh should compile and run
|
|
without problems if (sizeof(long) == 8).
|
|
|
|
Options For Configure
|
|
---------------------
|
|
|
|
The `configure' program accepts many options, not all of which are useful
|
|
or relevant to zsh. To get the complete list of configure options, run
|
|
"./configure --help". The following list should contain most of the
|
|
options of interest for configuring zsh.
|
|
|
|
Configuration:
|
|
--cache-file=FILE # cache test results in FILE
|
|
--help # print a help message
|
|
--version # print the version of autoconf that create configure
|
|
--quiet, --silent # do not print `checking...' messages
|
|
--no-create # do not create output files
|
|
|
|
Directories:
|
|
--prefix=PREFIX # install host independent files in PREFIX [/usr/local]
|
|
--exec-prefix=EPREFIX # install host dependent files in EPREFIX [same as prefix]
|
|
--bindir=DIR # install user executables in DIR [EPREFIX/bin]
|
|
--infodir=DIR # install info documentation in DIR [PREFIX/info]
|
|
--mandir=DIR # install man documentation in DIR [PREFIX/man]
|
|
--srcdir=DIR # find the sources in DIR [configure dir or ..]
|
|
|
|
Features:
|
|
--enable-FEATURE # enable use of this feature
|
|
--disable-FEATURE # disable use of this feature
|
|
|
|
The FEATURES currently supported are:
|
|
zsh-debug # use it if you want to debug zsh
|
|
zsh-mem # use zsh's memory allocators
|
|
zsh-mem-debug # debug zsh's memory allocators
|
|
zsh-mem-warning # turn on warnings of memory allocation errors
|
|
zsh-secure-free # turn on memory checking of free()
|
|
zsh-hash-debug # turn on debugging of internal hash tables
|
|
etcdir=directory # default directory for global zsh scripts
|
|
zshenv=pathname # the full pathname of the global zshenv script
|
|
zshrc=pathname # the full pathname of the global zshrc script
|
|
zlogin=pathname # the full pathname of the global zlogin script
|
|
zprofile=pathname # the full pathname of the global zprofile script
|
|
zlogout=pathname # the full pathname of the global zlogout script
|
|
dynamic # allow dynamically loaded binary modules
|
|
lfs # allow configure check for large files
|