Skip to content
This repository
tree: ae7f1d1660
Fetching contributors…


Cannot retrieve contributors at this time

file 145 lines (129 sloc) 4.311 kb
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
.TH Z "1" "February 2011" "z" "User Commands"

z \- jump around

z [\-h] [\-l] [\-r] [\-t] [regex1 regex2 ... regexn]

bash, zsh

Tracks your most used directories, based on 'frecency'.
After a short learning phase, \fBz\fR will take you to the most 'frecent'
directory that matches ALL of the regexes given on the command line.

\fB\-h\fR show a brief help message
\fB\-l\fR list only
\fB\-r\fR match by rank only
\fB\-t\fR match by recent access only

\fBz foo\fR cd to most frecent dir matching foo
\fBz foo bar\fR cd to most frecent dir matching foo and bar
\fBz -r foo\fR cd to highest ranked dir matching foo
\fBz -t foo\fR cd to most recently accessed dir matching foo
\fBz -l foo\fR list all dirs matching foo (by frecency)


Put something like this in your \fB$HOME/.bashrc\fR:
 \fB. /path/to/\fR
Put something like this in your \fB$HOME/.zshrc\fR:
 \fB. /path/to/
 function precmd () {
   _z --add "$(pwd -P)"
\fBcd\fR around for a while to build up the db.
 Set \fB$_Z_CMD\fR in .bashrc/.zshrc to change the command (default \fBz\fR).
 Set \fB$_Z_DATA\fR to change the datafile (default \fB$HOME/.z\fR).
 Set \fB$_Z_NO_RESOLVE_SYMLINKS\fR to prevent symlink resolution.
 Set \fB$_Z_NO_PROMPT_COMMAND\fR if you're handling \fBPROMPT_COMMAND\fR yourself.
 (These settings should go before the lines added above.)
 Install the provided man page \fBz.1\fR somewhere like \fB/usr/local/man/man1\fB.
The rank of directories maintained by \fBz\fR undergoes aging based on a simple
formula. The rank of each entry is incremented every time it is accessed. When
the sum of ranks is greater than 1000, all ranks are multiplied by 0.9. Entries
with a rank lower than 1 are forgotten.

Frecency is a portmantaeu of 'recent' and 'frequency'. It is a weighted rank
that depends on how often and how recently something occured. As far as I
know, Mozilla came up with the term.
To \fBz\fR, a directory that has low ranking but has been accessed recently
will quickly have higher rank than a directory accessed frequently a long time

Frecency is determined at runtime.

When multiple directories match all queries, and they all have a common prefix,
\fBz\fR will cd to the shortest matching directory, without regard to priority.
This has been in effect, if undocumented, for quite some time, but should
probably be configurable or reconsidered.

\fBTab Completion\fR
\fBz\fR supports tab completion. After any number of arguments, press TAB to
complete on directories that match each argument. Due to limitations of the
completion implementations, only the last argument will be completed in the
Internally, \fBz\fR decides you've requested a completion if the last argument
passed is an absolute path to an existing directory. This may cause unexpected
behavior if the last argument to \fBz\fR begins with \fB/\fR.

A function \fB_z()\fR is defined.
An alias \fB$_Z_CMD\fR='_z 2>&1' is defined. If not set, \fB$_Z_CMD\fR defaults
to \fBz\fR.
The environment variable \fB$_Z_DATA\fR can be used to control the datafile
location. If it is not defined, the location defaults to \fB$HOME/.z\fR.
The environment variable \fB$_Z_NO_RESOLVE_SYMLINKS\fR can be set to prevent
resolving of symlinks. If it is not set, symbolic links will be resolved when
added to the datafile.
In bash, \fBz\fR uses the \fBPROMPT_COMMAND\fR environment variable to maintain
its database. Specifically it prepends:
 \fB_z --add "$(pwd -P 2>/dev/null)" 2>/dev/null;\fR
to any existing \fBPROMPT_COMMAND\fR. zsh users need to manually set
\fBprecmd()\fR as described in the installation instructions.
The environment variable \fB$_Z_NO_PROMPT_COMMAND\fR can be set if you want to
handle \fRPROMPT_COMMAND\fR yourself.

Data is stored in \fB$HOME/.z\fR. This can be overridden by setting the
\fB$_Z_DATA\fR environment variable.
A man page (\fBz.1\fR) is provided.

regex(7), cdargs, pushd, popd, autojump, cdargs
Please file bugs at
Something went wrong with that request. Please try again.