1999-04-15 20:05:35 +02:00
|
|
|
-----------------
|
|
|
|
THE Z SHELL (ZSH)
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Version
|
|
|
|
-------
|
|
|
|
|
2009-04-21 11:33:30 +02:00
|
|
|
This is version 4.3.10 of the shell. This is a development release,
|
2006-02-28 13:20:43 +01:00
|
|
|
but is believed to be reasonably stable. Sites where the users need to
|
|
|
|
edit command lines with multibyte characters (in particular UTF-8)
|
2008-10-30 13:18:54 +01:00
|
|
|
will probably want to upgrade. The previous widely released version
|
2009-04-21 11:33:30 +02:00
|
|
|
of the shell was 4.3.9.
|
1999-04-15 20:05:35 +02:00
|
|
|
|
|
|
|
Installing Zsh
|
|
|
|
--------------
|
|
|
|
|
|
|
|
The instructions for compiling zsh are in the file INSTALL. You should
|
2004-07-02 17:59:07 +02:00
|
|
|
also check the file MACHINES in the top directory to see if there
|
1999-04-15 20:05:35 +02:00
|
|
|
are any special instructions for your particular architecture.
|
|
|
|
|
2007-05-21 13:32:02 +02:00
|
|
|
Note in particular the zsh/newuser module that guides new users through
|
|
|
|
setting basic shell options without the administrator's intervention. This
|
|
|
|
is turned on by default. See the section AUTOMATIC NEW USER CONFIGURATION
|
|
|
|
in INSTALL for configuration information.
|
|
|
|
|
1999-04-15 20:05:35 +02:00
|
|
|
Features
|
|
|
|
--------
|
|
|
|
|
2001-05-30 18:08:16 +02:00
|
|
|
Zsh is a shell with lots of features. For a list of some of these, see the
|
2004-07-02 17:59:07 +02:00
|
|
|
file FEATURES, and for the latest changes see NEWS. For more
|
2000-04-04 02:19:16 +02:00
|
|
|
details, see the documentation.
|
|
|
|
|
2001-03-12 18:39:22 +01:00
|
|
|
Possible incompatibilities
|
2000-04-04 02:19:16 +02:00
|
|
|
---------------------------
|
|
|
|
|
2009-02-05 11:08:35 +01:00
|
|
|
In some 4.3.X releases of zsh, the completion system added a ".." as a
|
2009-02-05 10:51:28 +01:00
|
|
|
trial completion whenever completing directories. This was a bug: as
|
|
|
|
documented in the zshcompsys manual, this feature needs to be turned on by
|
|
|
|
a style:
|
|
|
|
|
|
|
|
zstyle ':completion:*' special-dirs true
|
|
|
|
|
|
|
|
|
|
|
|
The rest of this section documents incompatibilities in the shell since the
|
|
|
|
4.2 series of releases.
|
2008-06-01 20:35:50 +02:00
|
|
|
|
2008-10-28 21:55:22 +01:00
|
|
|
In previous releases of the shell, builtin commands and precommand
|
|
|
|
modifiers that did not accept options also did not recognize the
|
|
|
|
argument "--" as marking the end of option processing without being
|
|
|
|
considered an argument. This was not documented and was incompatible
|
|
|
|
with other shells. All such commands now handle this syntax.
|
|
|
|
|
2008-06-01 20:35:50 +02:00
|
|
|
The configuration option --enable-lfs to enable large file support has
|
|
|
|
been replaced by autoconf's standard --enable-largefile mechanism.
|
|
|
|
As this is usually used whenever necessary, this won't usually
|
|
|
|
be noticeable; however, anyone configuring with --disable-lfs
|
|
|
|
should configure with --disable-largefile instead.
|
2004-07-30 13:09:16 +02:00
|
|
|
|
2007-10-02 12:22:26 +02:00
|
|
|
The configuration option --with-curses-terminfo has been replaced
|
|
|
|
by the option --with-term-lib="LIBS" where LIBS is a space-separated
|
|
|
|
list of libraries to search for termcap and curses features.
|
|
|
|
|
2006-02-16 15:28:53 +01:00
|
|
|
The option SH_WORD_SPLIT, used in Bourne/Korn/Posix shell compatibility
|
|
|
|
mode, has been made more like other shells in the case of substitutions of
|
|
|
|
the form ${1+"$@"} (a common trick used to work around problems in older
|
|
|
|
Bourne shells) or any of the related forms with the + replaced by - or =
|
2006-02-16 20:05:13 +01:00
|
|
|
with an optional colon preceding. Previously, with SH_WORD_SPLIT in
|
2006-02-16 15:28:53 +01:00
|
|
|
effect, this expression would cause splitting on all white space in the
|
|
|
|
shell arguments. (This was always regarded as a bug but was long-standing
|
|
|
|
behaviour.) Now it is treated identically to "$@". The same change
|
|
|
|
applies to expressions with forced splitting such as ${=1+"$@"}, but
|
|
|
|
otherwise the case where SH_WORD_SPLIT is not set is unaffected.
|
|
|
|
|
2008-08-07 18:25:14 +02:00
|
|
|
Debug traps (`trap ... DEBUG' or the function TRAPDEBUG) now run by default
|
|
|
|
before the command to which they refer instead of after. This is almost
|
|
|
|
always the right behaviour for the intended purpose of debugging and is
|
|
|
|
consistent with recent versions of other shells. The option
|
|
|
|
DEBUG_BEFORE_CMD can be unset to revert to the previous behaviour.
|
|
|
|
|
2008-11-13 22:18:14 +01:00
|
|
|
Previously, process substitutions of the form =(...), <(...) and >(...)
|
|
|
|
were only handled if they appeared as separate command arguments.
|
|
|
|
(However, the latter two forms caused the current argument to be
|
|
|
|
terminated and a new one started even if they occurred in the middle of
|
|
|
|
a string.) Now all three may be followed by other strings, and the
|
2008-11-17 17:11:29 +01:00
|
|
|
latter two may also be preceeded by other strings. Remaining
|
|
|
|
limitations on their use (to reduce incompatibilities to a minimum)
|
|
|
|
are documented in the zshexpn.1 manual.
|
2008-11-13 22:18:14 +01:00
|
|
|
|
2007-06-18 15:25:03 +02:00
|
|
|
In previous versions of the shell it was possible to use index 0 in an
|
|
|
|
array or string subscript to refer to the same element as index 1 if the
|
|
|
|
option KSH_ARRAYS was not in effect. This was a limited approximation to
|
|
|
|
the full KSH_ARRAYS handling and so was not very useful. In this version
|
|
|
|
of the shell, this behaviour is only provided when the option
|
|
|
|
KSH_ZERO_SUBSCRIPT is set. Note that despite the name this does not provide
|
|
|
|
true compatibility with ksh or other shells and KSH_ARRAYS should still be
|
|
|
|
used for that purpose. By default, the option is not set; an array
|
|
|
|
subscript that evaluates to 0 returns an empty string or array element and
|
|
|
|
attempts to write to an array or string range including only a zero
|
|
|
|
subscript are treated as an error. Writes to otherwise valid ranges that
|
|
|
|
also include index zero are allowed; hence for example the assignment
|
|
|
|
array[(R)notfound,(r)notfound]=()
|
|
|
|
(where the string "notfound" does not match an element in $array) sets the
|
|
|
|
entire array to be empty, as in previous versions of the shell.
|
|
|
|
KSH_ZERO_SUBSCRIPT is irrelevant when KSH_ARRAYS is set. Also as in previous
|
|
|
|
versions, attempts to write to non-existent elements at the end of an array
|
|
|
|
cause the array to be suitably extended. This difference means that, for
|
|
|
|
example
|
|
|
|
array[(R)notfound]=(replacement)
|
|
|
|
is an error if KSH_ZERO_SUBSCRIPT is not set (new behaviour), while
|
|
|
|
array[(r)notfound]=(replacement)
|
|
|
|
causes the given value to be appended to the array (same behaviour as
|
|
|
|
previous versions).
|
|
|
|
|
2007-05-08 12:02:58 +02:00
|
|
|
The "exec" precommand modifier now takes various options for compatibility
|
|
|
|
with other shells. This means that whereas "exec -prog" previously
|
|
|
|
tried to execute a command name "-prog", it will now report an error
|
|
|
|
in option handling. "exec -- -prog" will execute "-prog". If
|
|
|
|
the option EQUALS is set, as it is by default in zsh's native mode,
|
|
|
|
"exec =-prog" behaves the same way in all versions of zsh provided
|
|
|
|
the command can be found.
|
|
|
|
|
2005-03-09 18:13:59 +01:00
|
|
|
The "unset" builtin now does not regard the unsetting of non-existent
|
|
|
|
variables as an error, so can still return status 0 (depending on the
|
|
|
|
handling of other arguments). This appears to be the standard shell
|
|
|
|
behaviour.
|
2003-05-08 12:30:45 +02:00
|
|
|
|
2007-02-08 11:47:21 +01:00
|
|
|
The variable BAUD is no longer set automatically by the shell.
|
|
|
|
In previous versions it was set to the baud rate reported by
|
|
|
|
the terminal driver in order to initialise the line editor's
|
|
|
|
compensation mechanism for slow baud rates. However, the baud
|
|
|
|
rate so reported is very rarely related to the limiting speed of
|
|
|
|
screen updates on modern systems. Users who need the compensation
|
|
|
|
mechanism should set BAUD to an appropriate rate by hand.
|
|
|
|
|
2006-02-07 12:29:30 +01:00
|
|
|
The variable HOME is no longer set by the shell if zsh is emulating any
|
|
|
|
other shell at startup; it must be present in the environment or set
|
|
|
|
subsequently by the user. It is valid for the variable to be unset.
|
2006-02-06 12:57:03 +01:00
|
|
|
|
2006-11-01 13:25:18 +01:00
|
|
|
Parameter substitutions in the form ${param//#%search/replace} match
|
|
|
|
against "search" anchored at both ends of the parameter value. Previously
|
|
|
|
this syntax would have matched against "%search", anchored only at the head
|
|
|
|
of the value. The form ${param//#$search/replace} where the value
|
|
|
|
$search starts with "%" considers the "%" to be part of the search
|
|
|
|
string as before.
|
|
|
|
|
2006-09-15 15:17:27 +02:00
|
|
|
The MULTIBYTE option is on by default where it is available; this
|
|
|
|
causes many operations to recognise characters as in the current locale.
|
|
|
|
Older versions of the shell always assumed a character was one byte.
|
|
|
|
In some places the width of the character will be used; this is transparent
|
|
|
|
when used for calculations of screen position, but also occurs, for
|
2008-04-02 14:51:31 +02:00
|
|
|
example, in calculations of padding width. Note that MULTIBYTE is
|
|
|
|
not automatically set when emulating Bourne- and POSIX-style shells;
|
|
|
|
for interative use of these emulations it may be necessary to set
|
|
|
|
it by hand.
|
2006-09-15 15:17:27 +02:00
|
|
|
|
2006-02-06 13:05:31 +01:00
|
|
|
Zsh has previously been lax about whether it allows octets with the
|
2006-07-10 15:08:22 +02:00
|
|
|
top bit set to be part of a shell identifier. Older versions of the shell
|
|
|
|
assumed all such octets were allowed in identifiers, however the POSIX
|
|
|
|
standard does not allow such characters in identifiers. The older
|
|
|
|
behaviour is still obtained with --disable-multibyte in effect.
|
2006-08-04 17:31:03 +02:00
|
|
|
With --enable-multibyte in effect (this is now the default anywhere
|
|
|
|
it is supported) there are three possible cases:
|
2006-07-10 15:08:22 +02:00
|
|
|
MULTIBYTE option unset: only ASCII characters are allowed; the
|
|
|
|
shell does not attempt to identify non-ASCII characters at all.
|
|
|
|
MULTIBYTE option set, POSIX_IDENTIFIERS option unset: in addition
|
|
|
|
to the POSIX characters, any alphanumeric characters in the
|
|
|
|
local character set are allowed. Note that scripts and functions that
|
|
|
|
take advantage of this are non-portable; however, this is in the spirit
|
|
|
|
of previous versions of the shell. Note also that the options must
|
|
|
|
be set before the shell parses the script or function; setting
|
|
|
|
them during execution is not sufficient.
|
|
|
|
MULITBYTE option set, POSIX_IDENTIFIERS set: only ASCII characters
|
|
|
|
are allowed in identifiers even though the shell will recognise
|
|
|
|
alphanumeric multibyte characters.
|
2006-02-06 13:05:31 +01:00
|
|
|
|
2006-09-10 17:24:26 +02:00
|
|
|
The sched builtin now keeps entries in time order. This means that
|
|
|
|
after adding an entry the index of an existing entry used for deletion
|
|
|
|
may change, if that entry had a later time than the new entry. However,
|
|
|
|
deleting a entry with a later time will now never change the index of an
|
|
|
|
entry with an earlier time, which could happen with the previous method.
|
|
|
|
|
2006-02-28 12:57:18 +01:00
|
|
|
The completion style pine-directory must now be set to use completion
|
|
|
|
for PINE mailbox folders; previously it had the default ~/mail. This
|
|
|
|
change was necessary because otherwise recursive directories under
|
|
|
|
~/mail were searched by default, which could be a considerable unnecessary
|
|
|
|
hit for anyone not using PINE. The previous default can be restored with:
|
|
|
|
zstyle ':completion:*' pine-directory ~/mail
|
|
|
|
|
2007-05-01 11:29:35 +02:00
|
|
|
The completion style fake-files now allows patterns as directories,
|
|
|
|
for example the value '/home/*:.snapshot' is now valid. This will
|
|
|
|
only cause problems in the unlikely event that a directory in the style
|
|
|
|
has a pattern character in it.
|
|
|
|
|
2006-06-26 11:57:16 +02:00
|
|
|
The default maximum function depth (configurable with
|
|
|
|
--enable-max-function-depth) has been decreased to 1000 from 4096. The
|
2008-04-02 14:51:31 +02:00
|
|
|
previous value was observed to be small enough that crashes still occurred
|
2006-06-26 11:57:16 +02:00
|
|
|
on some fairly common PC configurations. This change is only likely to
|
|
|
|
affect some highly specialised uses of the shell.
|
|
|
|
|
2006-08-02 19:16:37 +02:00
|
|
|
The variables HISTCHARS and histchars now reject any attempt to
|
|
|
|
set non-ASCII characters for history or comments. Multibyte characters
|
|
|
|
have never worked and the most consistent change was to restrict the
|
|
|
|
set to portable characters only.
|
|
|
|
|
2007-05-29 19:01:07 +02:00
|
|
|
Writers of add-on modules should note that the API has changed
|
|
|
|
significantly to allow user control of individual features provided by
|
|
|
|
modules. See the documentation for zmodload -F and
|
|
|
|
Etc/zsh-development-guide, in that order.
|
|
|
|
|
1999-04-15 20:05:35 +02:00
|
|
|
Documentation
|
|
|
|
-------------
|
|
|
|
|
|
|
|
There are a number of documents about zsh in this distribution:
|
|
|
|
|
|
|
|
Doc/Zsh/*.yo The master source for the zsh documentation is written in
|
|
|
|
yodl. Yodl is a document language written by Karel Kubat.
|
|
|
|
It is not required by zsh but but it is a nice program so
|
|
|
|
you might want to get it anyway, especially if you are a
|
|
|
|
zsh developer. It can be downloaded from
|
2006-03-20 12:06:22 +01:00
|
|
|
ftp://yodl.sourceforge.net/
|
1999-04-15 20:05:35 +02:00
|
|
|
|
|
|
|
Doc/zsh*.1 Man pages in nroff format. These will be installed
|
|
|
|
by "make install.man" or "make install". By default,
|
|
|
|
these will be installed in /usr/local/man/man1, although
|
|
|
|
you can change this with the --mandir option to configure
|
|
|
|
or editing the user configuration section of the top level
|
|
|
|
Makefile.
|
|
|
|
|
|
|
|
Doc/zsh.texi Everything the man pages have, but in texinfo format. These
|
|
|
|
will be installed by "make install.info" or "make install".
|
|
|
|
By default, these will be installed in /usr/local/info,
|
|
|
|
although you can change this with the --infodir option to
|
|
|
|
configure or editing the user configuration section of the
|
2001-06-28 19:02:57 +02:00
|
|
|
top level Makefile. Version 4.0 or above of the
|
|
|
|
Texinfo tools are recommended for processing this file.
|
1999-04-15 20:05:35 +02:00
|
|
|
|
|
|
|
Also include in the distribution are:
|
|
|
|
|
|
|
|
Doc/intro.ms An introduction to zsh in troff format using the ms
|
|
|
|
macros. This document explains many of the features
|
|
|
|
that make zsh more equal than other shells.
|
|
|
|
Unfortunately this is based on zsh-2.5 so some examples
|
|
|
|
may not work without changes but it is still a good
|
|
|
|
introduction.
|
|
|
|
|
2001-05-30 18:08:16 +02:00
|
|
|
For more information, see the website, as described in the META-FAQ.
|
|
|
|
|
2006-02-28 12:57:18 +01:00
|
|
|
If you do not have the necessary tools to process these documents, PDF,
|
|
|
|
Info and DVI versions are available in the separate file zsh-doc.tar.gz at
|
|
|
|
the archive sites listed in the META-FAQ.
|
1999-04-15 20:05:35 +02:00
|
|
|
|
|
|
|
The distribution also contains a Perl script in Utils/helpfiles which
|
|
|
|
can be used to extract the descriptions of builtin commands from the
|
|
|
|
zshbuiltins manual page. See the comments at the beginning of the
|
|
|
|
script about its usage. The files created by this script can be used
|
2000-04-04 02:19:16 +02:00
|
|
|
by example function run-help located in the subdirectory Functions/Misc to
|
1999-04-15 20:05:35 +02:00
|
|
|
show information about zsh builtins and run `man' on external commands.
|
|
|
|
For this the shell variable HELPDIR should point to a directory containing
|
2001-03-12 18:39:22 +01:00
|
|
|
the files generated by the helpfiles script. run-help should be
|
1999-04-15 20:05:35 +02:00
|
|
|
unaliased before loading the run-help function. After that this function
|
|
|
|
will be executed by the run-help ZLE function which is by default bound
|
|
|
|
to ESC-h in emacs mode.
|
|
|
|
|
|
|
|
Examples
|
|
|
|
--------
|
|
|
|
|
|
|
|
Examples of zsh startup files are located in the subdirectory
|
|
|
|
StartupFiles. Examples of zsh functions and scripts are located in
|
|
|
|
the subdirectory Functions. Examples of completion control commands
|
|
|
|
(compctl) are located in the file Misc/compctl-examples.
|
|
|
|
|
|
|
|
Zsh FTP Sites, Web Pages, and Mailing Lists
|
|
|
|
-------------------------------------------
|
|
|
|
|
|
|
|
The current list of zsh FTP sites, web pages, and mailing lists can be
|
|
|
|
found in the META-FAQ. A copy is included in this distribution and is
|
|
|
|
available separately at any of the zsh FTP sites.
|
|
|
|
|
|
|
|
Common Problems and Frequently Asked Questions
|
|
|
|
----------------------------------------------
|
|
|
|
|
|
|
|
Zsh has a list of Frequently Asked Questions (FAQ) maintained by Peter
|
|
|
|
Stephenson <pws@zsh.org>. It covers many common problems encountered
|
|
|
|
when building, installing, and using zsh. A copy is included in this
|
|
|
|
distribution in Etc/FAQ and is available separately at any of the zsh
|
|
|
|
ftp sites.
|
|
|
|
|
|
|
|
Zsh Maintenance and Bug Reports
|
|
|
|
-------------------------------
|
|
|
|
|
|
|
|
Zsh is currently maintained by the members of the zsh-workers mailing list
|
2001-05-30 18:08:16 +02:00
|
|
|
and coordinated by Peter Stephenson <coordinator@zsh.org>. Please send
|
2001-02-01 16:48:57 +01:00
|
|
|
any feedback and bugs reports to <zsh-workers@sunsite.dk>.
|
1999-04-15 20:05:35 +02:00
|
|
|
|
2001-06-13 05:50:55 +02:00
|
|
|
Reports are most helpful if you can reproduce the bug starting zsh with
|
1999-04-15 20:05:35 +02:00
|
|
|
the -f option. This skips the execution of local startup files except
|
|
|
|
/etc/zshenv. If a bug occurs only when some options set try to locate
|
|
|
|
the option which triggers the bug.
|
|
|
|
|
2001-06-13 05:50:55 +02:00
|
|
|
There is a script "reporter" in the subdirectory Util which will print out
|
|
|
|
your current shell environment/setup. If you cannot reproduce the bug
|
|
|
|
with "zsh -f", use this script and include the output from sourcing this
|
|
|
|
file. This way, the problem you are reporting can be recreated.
|
|
|
|
|
1999-04-15 20:05:35 +02:00
|
|
|
The known bugs in zsh are listed in the file Etc/BUGS. Check this as
|
|
|
|
well as the Frequently Asked Questions (FAQ) list before sending a bug
|
|
|
|
report. Note that zsh has some features which are not compatible with
|
|
|
|
sh but these are not bugs. Most of these incompatibilities go away
|
|
|
|
when zsh is invoked as sh or ksh (e.g. using a symbolic link).
|
|
|
|
|
|
|
|
If you send a bug report to the list and are not a subscriber, please
|
|
|
|
mention this in your message if you want a response.
|
|
|
|
|
|
|
|
If you would like to contribute to the development and maintenance of zsh,
|
|
|
|
then you should join the zsh-workers mailing list (check the META-FAQ
|
|
|
|
for info on this). You should also read the "zsh-development-guide"
|
|
|
|
located in the subdirectory Util.
|
|
|
|
|
|
|
|
Contributors
|
|
|
|
------------
|
|
|
|
|
|
|
|
The people who have contributed to this software project are listed
|
|
|
|
in Etc/CONTRIBUTORS.
|