mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-01-11 20:31:11 +01:00
402 lines
18 KiB
Text
402 lines
18 KiB
Text
++++++++++++++
|
|
INSTALLING ZSH
|
|
++++++++++++++
|
|
|
|
This file is divided into two parts: making and installing the shell, and
|
|
a description of various additional configuration options. You should
|
|
have a look at the items in the second part before following the
|
|
instructions in the first.
|
|
|
|
=====================
|
|
MAKING AND INSTALLING
|
|
=====================
|
|
|
|
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.
|
|
|
|
Pre-configuration
|
|
-----------------
|
|
|
|
If you are using a normal source release, skip this section.
|
|
|
|
If the `configure' script does not already exist -- e.g., if you've got
|
|
a snapshot of the bare sources just checked out from a CVS repository
|
|
-- some things need to be built before the configuration can proceed.
|
|
Run the script `./Util/preconfig' to do this.
|
|
|
|
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. This is now enabled
|
|
by default; to disable it, run configure with the --disable-dynamic option.
|
|
Note that dynamic loading does not work on all systems. On these systems
|
|
this option will have no effect. 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, and hence
|
|
also the install paths must be correct. The installation path for modules
|
|
is EPREFIX/lib/zsh/<zsh-version-number>, where EPREFIX defaults to PREFIX
|
|
unless given explicitly, and PREFIX defaults to /usr/local. See the end of
|
|
this file for options to configure to change these.
|
|
|
|
Adding and removing 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
|
|
|
|
You can also instruct the configuration process that a certain module
|
|
should neither be compiled nor installed without modifying any files. To
|
|
do this, give the argument `--enable-omit-modules=mod1,mod2,...' to
|
|
configure. The module arguments are the full names of the modules,
|
|
probably including the prefix `zsh/'. For example,
|
|
`configure --enable-omit-modules=zsh/zpty,zsh/example' says that the
|
|
modules zsh/zpty and zsh/example are not to be compiled nor installed.
|
|
Note that it is up to you to make sure the modules in question are not going
|
|
to be compiled into the main zsh binary, as described in the next section.
|
|
It is unlikely you would want to omit any of the modules liable to be
|
|
compiled in by default.
|
|
|
|
Controlling what is compiled into the main zsh binary
|
|
-----------------------------------------------------
|
|
|
|
By default the complete, compctl, zle, computil, complist, sched, parameter,
|
|
zleparameter 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, one
|
|
module name per line with no punctuation and no suffix. See the zshmodules
|
|
manual page for the list of available modules.
|
|
|
|
Note that mymods.conf replaces the standard list of linked-in modules from
|
|
Src/xmods.conf. If you wish to add to the standard list, copy the lines
|
|
that begin with "L " from xmods.conf into mymods.conf and remove the "L "
|
|
from each such line in mymods.conf. Then add the names of other modules
|
|
that you want to link. Module names typically must begin with "zsh/";
|
|
see the ".mdd" file for the module for the actual name. The modules must
|
|
be listed in dependency order, e.g., "zsh/zle" must precede "zsh/complete",
|
|
"zsh/complete" must precede "zsh/compctl", and similarly for any other
|
|
dependencies.
|
|
|
|
Note that the modules depending on zle or complete (e.g.: complist and
|
|
deltochar) cannot be loaded dynamically on systems which do not allow symbols
|
|
in one dynamically loaded library to be visible from another; this is true,
|
|
for example, of version 4 of SunOS. The most convenient workaround is to
|
|
compile zle and complete into the base executable by including them in
|
|
mymods.conf as described above.
|
|
|
|
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
|
|
|
|
The flags CFLAGS, CPPFLAGS, LDFLAGS and LIBS can also be set as flags to
|
|
configure, where the name appears in lower case:
|
|
configure --enable-cflags=-O2 --enable-libs=-lposix
|
|
|
|
The advantage of this form is that `config.status --recheck' will remember
|
|
the flags you originally specified. You can still override the flags when
|
|
running `make' (although these will not be passed down via `config.status
|
|
--recheck').
|
|
|
|
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
|
|
|
|
To install all the shell functions which come with the distribution, do the
|
|
command:
|
|
make install.fns
|
|
|
|
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
|
|
|
|
|
|
=====================
|
|
CONFIGURATION OPTIONS
|
|
=====================
|
|
|
|
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.
|
|
|
|
Shell functions
|
|
---------------
|
|
|
|
By default, the shell functions which are installed with `make install' or
|
|
`make install.fns' go into the directory ${datadir}/zsh/functions, which
|
|
unless you have specified --datadir is the same as
|
|
${prefix}/share/zsh/$ZSH_VERSION/functions ($prefix itself defaults to
|
|
/usr/local, as described below). This directory will also be compiled into
|
|
the shell as the default directory for the variable $fpath/$FPATH. You can
|
|
override it with --enable-fndir=directory; --disable-fndir or
|
|
--enable-fndir=no will turn off both installation of functions and the
|
|
setting of a default value for $fpath/$FPATH. Note the presence of
|
|
$ZSH_VERSION (e.g. `3.1.7') to avoid clashes between versions of zsh.
|
|
If you only run one version of zsh at once, installing into a common
|
|
directory such as /usr/local/share/zsh/functions is fine.
|
|
|
|
You can control the functions which get installed by setting
|
|
FUNCTIONS_INSTALL, either when running configure (e.g.
|
|
`FUNCTIONS_INSTALL="..." configure ...') or when running `make install' or
|
|
`make install.fns'. It includes a list of files relative to either the
|
|
Completion or Functions subdirectories. By default, all the functions for
|
|
the Completion system will be installed (see the zshcompsys manual page),
|
|
plus those provide functions for the line editor, i.e.
|
|
FUNCTIONS_INSTALL='Core/* Base/* Builtins/* User/* Commands/* Debian/* Linux/* X/* Zle/* Prompts/* Misc/*'
|
|
and if the --enable-dynamic option was given, the functions in
|
|
Functions/Zftp, which require the zftp module to be available (see the
|
|
zshzftpsys manual page), will be included as well. Note, however, that
|
|
some of the functions in the User subdirectory are version- and
|
|
system-specific.
|
|
|
|
There are also some miscellaneous functions with documentation in comments;
|
|
the complete set of functions can be installed with
|
|
FUNCTIONS_INSTALL='Core/* Base/* Builtins/* User/* Commands/* \
|
|
Debian/* Linux/* X/* Misc/* Zftp/* Zle/*'
|
|
Note you should set this by hand to include `Zftp/*' if you have zftp
|
|
compiled into a statically linked shell.
|
|
|
|
You can also use the configure option --enable-function-subdirs to allow
|
|
shell functions to be installed into subdirectories of the function
|
|
directory, i.e. `Core/*' files will be installed into `FNDIR/Core', and so
|
|
on. This also initialises $fpath/$FPATH appropriately.
|
|
|
|
The option --enable-site-fndir controls whether to create and initialise
|
|
$fpath to include a directory for site-specific functions. By default this
|
|
is created in the location ${datadir}/zsh/site-functions, i.e. parallel to
|
|
the version-specific functions directory, and inserted at the start of the
|
|
$fpath array on shell startup. This directory will not be affected by
|
|
`make uninstall' or `make uninstall.fns', although the version-specific
|
|
directory and its contents will be deleted.
|
|
|
|
Support for large files and integers
|
|
------------------------------------
|
|
|
|
Some 32-bit systems allow special compilation modes to get around the 2GB
|
|
file size barrier. The option --enable-lfs turns on the configure check
|
|
for support for large files. This is now enabled by default; use
|
|
--disable-lfs to turn it off. Not all systems recognize the test used by
|
|
zsh (via the getconf command), so flags may need to be set by hand. 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.
|
|
|
|
Also note that if `configure' finds out that either of the types off_t or
|
|
ino_t are 64-bit quantities, but that long integers are only 32 bits, all
|
|
the above will be enabled automatically. This is necessary to ensure
|
|
correct handling of these types.
|
|
|
|
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
|
|
fndir=directory # the directory where shell functions will go
|
|
site-fndir=directory# the directory where site-specific functions can go
|
|
function-subdirs # if functions will be installed into subdirectories
|
|
omit-modules=mod1,..# don't compile nor install the modules named mod1,...
|
|
dynamic # allow dynamically loaded binary modules
|
|
lfs # allow configure check for large files
|
|
locale # allow use of locale library
|