• Stars
    star
    16,226
  • Rank 1,758 (Top 0.04 %)
  • Language
    Shell
  • License
    Do What The F*ck ...
  • Created over 15 years ago
  • Updated 5 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

z - jump around
Z(1)                             User Commands                            Z(1)



NAME
       z - jump around

SYNOPSIS
       z [-chlrtx] [regex1 regex2 ... regexn]

AVAILABILITY
       bash, zsh

DESCRIPTION
       Tracks your most used directories, based on 'frecency'.

       After  a  short  learning  phase, z will take you to the most 'frecent'
       directory that matches ALL of the regexes given on the command line, in
       order.

       For example, z foo bar would match /foo/bar but not /bar/foo.

OPTIONS
       -c     restrict matches to subdirectories of the current directory

       -e     echo the best match, don't cd

       -h     show a brief help message

       -l     list only

       -r     match by rank only

       -t     match by recent access only

       -x     remove the current directory from the datafile

EXAMPLES
       z foo         cd to most frecent dir matching foo

       z foo bar     cd to most frecent dir matching foo, then bar

       z -r foo      cd to highest ranked dir matching foo

       z -t foo      cd to most recently accessed dir matching foo

       z -l foo      list all dirs matching foo (by frecency)

NOTES
   Installation:
       Put something like this in your $HOME/.bashrc or $HOME/.zshrc:

              . /path/to/z.sh

       cd around for a while to build up the db.

       PROFIT!!

       Optionally:
              Set $_Z_CMD to change the command name (default z).
              Set $_Z_DATA to change the datafile (default $HOME/.z).
              Set  $_Z_MAX_SCORE  lower  to  age  entries  out faster (default
              9000).
              Set $_Z_NO_RESOLVE_SYMLINKS to prevent symlink resolution.
              Set $_Z_NO_PROMPT_COMMAND to handle PROMPT_COMMAND/precmd  your-
              self.
              Set $_Z_EXCLUDE_DIRS to an array of directory trees to  exclude.
              Set $_Z_OWNER to allow usage when in 'sudo -s' mode.
              (These  settings  should  go  in  .bashrc/.zshrc before the line
              added above.)
              Install the provided man page z.1  somewhere  in  your  MANPATH,
              like /usr/local/man/man1.

   Aging:
       The rank of directories maintained by z undergoes aging based on a sim-
       ple formula. The rank of each entry is incremented  every  time  it  is
       accessed.  When the sum of ranks is over 9000, all ranks are multiplied
       by 0.99. Entries with a rank lower than 1 are forgotten.

   Frecency:
       Frecency is a portmanteau of 'recent' and 'frequency'. It is a weighted
       rank  that depends on how often and how recently something occurred. As
       far as I know, Mozilla came up with the term.

       To z, a directory that has low ranking but has been  accessed  recently
       will  quickly  have  higher rank than a directory accessed frequently a
       long time ago.

       Frecency is determined at runtime.

   Common:
       When multiple directories match all queries, and they all have a common
       prefix, z 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.

   Tab Completion:
       z  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 com-
       pleted in the shell.

       Internally, z decides you've requested a completion if the  last  argu-
       ment  passed  is  an  absolute  path to an existing directory. This may
       cause unexpected behavior if the last argument to z begins with /.

ENVIRONMENT
       A function _z() is defined.

       The contents of the variable $_Z_CMD is aliased to _z 2>&1. If not set,
       $_Z_CMD defaults to z.

       The  environment  variable $_Z_DATA can be used to control the datafile
       location. If it is not defined, the location defaults to $HOME/.z.

       The environment variable $_Z_NO_RESOLVE_SYMLINKS 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, z appends a command to the PROMPT_COMMAND environment variable
       to maintain its database. In zsh, z appends a function _z_precmd to the
       precmd_functions array.

       The environment variable $_Z_NO_PROMPT_COMMAND can be set if  you  want
       to handle PROMPT_COMMAND or precmd yourself.

       The  environment  variable  $_Z_EXCLUDE_DIRS  can be set to an array of
       directory trees to exclude from tracking.  $HOME  is  always  excluded.
       Directories must be full paths without trailing slashes.

       The  environment  variable  $_Z_OWNER  can  be set to your username, to
       allow usage of z when your sudo environment keeps $HOME set.

FILES
       Data is stored in $HOME/.z. This  can  be  overridden  by  setting  the
       $_Z_DATA  environment variable. When initialized, z will raise an error
       if this path is a directory, and not function correctly.

       A man page (z.1) is provided.

SEE ALSO
       regex(7), pushd, popd, autojump, cdargs

       Please file bugs at https://github.com/rupa/z/



z                                January 2013                             Z(1)

More Repositories

1

sprunge

command line pastebin for google appengine
Python
724
star
2

v

z for vim
Roff
446
star
3

epub

python/curses cli epub reader
Python
380
star
4

j2

python version of z, for experimentation
Python
239
star
5

j

semi clone of autojump (http://github.com/joelthelion/autojump) in shell/awk
Shell
157
star
6

YOU_ARE_DEAD

AN EXPERIMENTAL INDIE 1D ROGUELIKE. YOU ARE DEAD
Shell
73
star
7

cuecat

concatenate WAV files, with cue points or even spacing
JavaScript
38
star
8

octoeuclid

Up to 8 Euclidean Rhythms at once, on your BeatStep Pro
Python
23
star
9

password-store

Simple password manager using gpg and ordinary unix directories.
Shell
18
star
10

isNaan

Easily test if javascript things are delicious Indian bread
JavaScript
15
star
11

applescript

some utilities written in applescript
Shell
15
star
12

rvn

revision control for single files, written in bash :)
13
star
13

irssi

some scripts for irssi
Perl
11
star
14

el

mnemonic wrapper for $EDITOR
C
11
star
15

xmonad

my xmonad.hs (darcs/gnome/karmic)
Haskell
10
star
16

p

A couple of python/virtualenv utilities.
Shell
10
star
17

cfdns

Dynamic DNS with Cloudflare
Python
8
star
18

mkdn

markdown previewer (python, gtk, webkit)
Python
8
star
19

cnv

ebook manager using mod_python and calibre cli tools
Python
6
star
20

birc

An IRC bot written in shell
6
star
21

s

sed for $PWD
Shell
5
star
22

yts

make youtube into a nice jukebox
5
star
23

ansiimg

Images in B/W, Greyscale, 16 and 256 ANSI colors, delivered to STDOUT
Python
5
star
24

rupa.github.com

userpage
4
star
25

automeme

A cheeky random nonsense generator.
Python
4
star
26

dodns

Dynamic DNS with Digital Ocean
Shell
4
star
27

.vim

.vim
Python
3
star
28

horse_dev

/dev/horse horse device
C
3
star
29

marko

bog simple markov
Python
3
star
30

gnauriqs

Minimum dynamically modifiable IRC bot.
Python
3
star
31

lmp

python wrapper for mplayer to submit to lastfm
3
star
32

euclid

Euclidean Rhythm Sequencer stuff
Python
2
star
33

node-basicauth

http basic auth for node as simple as I can make it
JavaScript
2
star
34

wsgi_skeleton

My WSGI skeleton
Python
1
star
35

gxl

shell interface to google translate
Python
1
star