2016-08-11 08:44:00 +08:00
|
|
|
# A plugin to shrink directory paths for brevity and pretty-printing
|
|
|
|
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
|
|
|
For this directory tree:
|
|
|
|
```
|
|
|
|
/home/
|
|
|
|
me/
|
2020-03-05 20:08:05 +08:00
|
|
|
f o o/ # The prefix f is ambiguous between "f o o" and "f i g".
|
2016-08-11 08:44:00 +08:00
|
|
|
bar/
|
|
|
|
quux/
|
|
|
|
biz/ # The prefix b is ambiguous between bar and biz.
|
2020-03-05 20:08:05 +08:00
|
|
|
f i g/
|
|
|
|
baz/
|
2016-08-11 08:44:00 +08:00
|
|
|
```
|
|
|
|
here are the results of calling `shrink_path <option> /home/me/foo/bar/quux`:
|
|
|
|
```
|
|
|
|
Option Result
|
2020-03-05 20:08:05 +08:00
|
|
|
<none> /h/m/f o/ba/q
|
|
|
|
-l|--last /h/m/f o/ba/q
|
2016-08-11 08:44:00 +08:00
|
|
|
-s|--short /h/m/f/b/q
|
2020-03-05 20:08:05 +08:00
|
|
|
-t|--tilde ~/f o/ba/q
|
2016-08-11 08:44:00 +08:00
|
|
|
-f|--fish ~/f/b/quux
|
2020-03-05 20:08:05 +08:00
|
|
|
-g|--glob /h*/m*/f o*/ba*/q*
|
|
|
|
-3 /hom/me/f o/bar/quu
|
|
|
|
-e '$' -3 /hom$/me/f o$/bar/quu$
|
|
|
|
-q /h/m/f\ o/ba/q
|
|
|
|
-g -q /h*/m*/f\ o*/ba*/q*
|
2016-08-11 08:44:00 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
For a fish-style working directory in your command prompt, add the following to
|
|
|
|
your theme or zshrc:
|
|
|
|
|
|
|
|
```
|
|
|
|
setopt prompt_subst
|
|
|
|
PS1='%n@%m $(shrink_path -f)>'
|
|
|
|
```
|
|
|
|
|
|
|
|
The following options are available:
|
|
|
|
|
|
|
|
```
|
|
|
|
-f, --fish fish simulation, equivalent to -l -s -t.
|
2020-03-05 20:08:05 +08:00
|
|
|
-g, --glob Add asterisk to allow globbing of shrunk path (equivalent to -e "*")
|
2016-08-11 08:44:00 +08:00
|
|
|
-l, --last Print the last directory's full name.
|
2020-03-02 20:30:52 +08:00
|
|
|
-s, --short Truncate directory names to the number of characters given by -. Without
|
2016-08-11 08:44:00 +08:00
|
|
|
-s, names are truncated without making them ambiguous.
|
|
|
|
-t, --tilde Substitute ~ for the home directory.
|
|
|
|
-T, --nameddirs Substitute named directories as well.
|
2020-03-02 20:30:52 +08:00
|
|
|
-# Truncate each directly to at least this many characters inclusive of the
|
|
|
|
ellipsis character(s) (defaulting to 1).
|
|
|
|
-e SYMBOL Postfix symbol(s) to indicate that a directory name had been truncated.
|
2020-03-05 20:08:05 +08:00
|
|
|
-q, --quote Quote special characters in the shrunk path
|
2016-08-11 08:44:00 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
The long options can also be set via zstyle, like
|
|
|
|
```
|
|
|
|
zstyle :prompt:shrink_path fish yes
|
|
|
|
```
|
|
|
|
|
|
|
|
Note: Directory names containing two or more consecutive spaces are not yet
|
|
|
|
supported.
|
|
|
|
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Copyright (C) 2008 by Daniel Friesel <derf@xxxxxxxxxxxxxxxxxx>
|
2020-03-02 20:30:52 +08:00
|
|
|
Copyright (C) 2018-2020 by Pavel N. Krivitsky
|
2016-08-11 08:44:00 +08:00
|
|
|
|
2018-08-08 02:42:02 +08:00
|
|
|
License: WTFPL <http://www.wtfpl.net>
|
2016-08-11 08:44:00 +08:00
|
|
|
|
2018-08-08 02:42:02 +08:00
|
|
|
Ref: https://www.zsh.org/mla/workers/2009/msg00415.html
|
|
|
|
https://www.zsh.org/mla/workers/2009/msg00419.html
|
2016-08-11 08:44:00 +08:00
|
|
|
|
|
|
|
|
|
|
|
## Misc
|
|
|
|
|
|
|
|
Keywords: prompt directory truncate shrink collapse fish
|