2012-08-14 14:35:20 +02:00
|
|
|
Liquid prompt -- A useful adaptive prompt for Bash & Zsh
|
|
|
|
========================================================
|
2012-07-19 14:17:32 +02:00
|
|
|
|
2012-08-12 10:10:50 +02:00
|
|
|
Liquid prompt is a smart prompt for the "Bourne-Again" Unix shell (bash) and for
|
|
|
|
Zsh.
|
2012-07-19 14:17:32 +02:00
|
|
|
|
|
|
|
The basic idea of the liquid prompt is to nicely display useful informations on
|
|
|
|
the shell prompt, only when they are needed. It adds carefuly chosen colors to
|
|
|
|
draw your attention on what differs from the normal context. Thus, you will
|
|
|
|
notice what changes, when it changes, because you do not become accommodated to
|
|
|
|
informations that are always displayed in the same way.
|
|
|
|
|
2012-08-12 10:10:50 +02:00
|
|
|
You can use it with either bash and zsh.
|
2012-07-19 14:17:32 +02:00
|
|
|
|
2012-08-16 20:47:41 +03:00
|
|
|
![Screenshot](https://raw.github.com/nojhan/liquidprompt/master/demo.png)
|
2012-08-13 09:35:50 +02:00
|
|
|
|
2012-07-19 14:17:32 +02:00
|
|
|
## FEATURES
|
|
|
|
|
|
|
|
If there is nothing special in the current context, the liquid prompt is close
|
|
|
|
to a default prompt:
|
|
|
|
|
|
|
|
`[user:~] $ `
|
|
|
|
|
|
|
|
If you have ran one command in background that is still running and that you are
|
2012-08-04 19:55:56 +02:00
|
|
|
in a git repository on a server, at branch "myb":
|
2012-07-19 14:17:32 +02:00
|
|
|
|
|
|
|
`1r [user@server:~/liquidprompt] myb ± `
|
|
|
|
|
|
|
|
A liquid prompt displaying everything may look like this:
|
|
|
|
|
2012-08-16 14:28:55 +02:00
|
|
|
`⌁24% ⌂42% 3d/2&/1z [user@server:~/ … /code/liquidprompt]↥ master(+10/-5,3)* 125 ± `
|
2012-07-19 14:17:32 +02:00
|
|
|
|
|
|
|
It displays:
|
|
|
|
|
2012-08-12 12:13:47 +02:00
|
|
|
* a green ⌁ if the battery is charging and above a given threshold,
|
|
|
|
a yellow ⌁ if the battery is charging and under threshold,
|
|
|
|
a red ⌁ if the battery is discharging but above threshold;
|
|
|
|
* the average of the batteries remaining power, if it is under the given
|
|
|
|
threshold, with a colormap, going more and more red with decreasing power;
|
2012-07-19 14:17:32 +02:00
|
|
|
* the average of the processors load, if it is over a given limit, with a
|
2012-07-19 14:48:20 +02:00
|
|
|
colormap that became more and more noticeable with increasing load;
|
2012-08-10 14:28:18 +02:00
|
|
|
* the number of detached sessions (`screen`), if there is any;
|
2012-07-19 14:48:20 +02:00
|
|
|
* the number of attached sleeping jobs (when you interrupt a command with Ctrl-Z
|
|
|
|
and bring it back with `fg`), if there is any;
|
2012-07-19 14:17:32 +02:00
|
|
|
* the number of attached running jobs (commands started with a `&`), if there is
|
|
|
|
any;
|
2012-07-19 15:08:18 +02:00
|
|
|
* the current user, in bold yellow if it is root, in light white if it is not
|
|
|
|
the same as the login user;
|
2012-09-23 23:07:51 +02:00
|
|
|
* a blue @ if the connection has X11 support;
|
2012-07-19 14:17:32 +02:00
|
|
|
* the current host, if you are connected via an SSH or telnet connection, with
|
|
|
|
different colors for each case;
|
2012-08-14 15:38:33 +02:00
|
|
|
* a green colon if the user has write permissions on the current directory,
|
2012-07-29 22:20:12 +02:00
|
|
|
a red one if he has not;
|
2012-07-29 22:09:11 +02:00
|
|
|
* the current directory in bold, shortened if it takes too much space, while
|
|
|
|
preserving the first two directories;
|
2013-01-03 16:44:15 +01:00
|
|
|
* the current Python virtual environment, if any;
|
2012-08-09 12:11:51 +02:00
|
|
|
* an up arrow if an HTTP proxy is in use;
|
2012-07-19 14:17:32 +02:00
|
|
|
* the name of the current branch if you are in a version control repository
|
2013-01-12 16:29:55 +01:00
|
|
|
(git, mercurial, subversion or fossil), in green if everything is up
|
|
|
|
to date, in red if there is changes, in yellow if there is pending
|
|
|
|
commits to push;
|
2013-01-05 23:03:26 +01:00
|
|
|
* the number of added/deleted lines (git) or files (fossil), if
|
|
|
|
changes have been made and the number of pending commits, if any;
|
2013-01-17 23:02:17 +01:00
|
|
|
* a yellow plus if there is stashed modifications;
|
|
|
|
* a red star if there is some untracked files in the repository;
|
2012-07-19 14:17:32 +02:00
|
|
|
* the error code of the last command, if it has failed in some way;
|
2013-01-05 23:03:26 +01:00
|
|
|
* a smart mark: ± for git directories, ☿ for mercurial, ‡ for svn, ⌘
|
|
|
|
for fossil, $ for simple user, a red # for root.
|
2013-01-10 17:18:45 +01:00
|
|
|
* if you ask for, the liquidprompt will be replicated in your terminal window's
|
|
|
|
title (without the colors)
|
2012-07-19 14:17:32 +02:00
|
|
|
|
2012-08-04 19:05:34 +02:00
|
|
|
You can temporarily deactivate the liquid prompt and come back to your previous
|
2012-08-11 10:20:37 +02:00
|
|
|
one by typing `prompt_off`. Use `prompt_on` to bring it back. You can deactivate
|
|
|
|
any prompt and use a single mark sign (`$ ` for user and `# ` for root) with the
|
|
|
|
`prompt_OFF` command.
|
2012-08-04 19:05:34 +02:00
|
|
|
|
2012-07-19 14:17:32 +02:00
|
|
|
|
2012-08-01 19:33:32 +02:00
|
|
|
## INSTALL
|
2012-07-19 14:17:32 +02:00
|
|
|
|
|
|
|
Include the file in your bash configuration, for example in your `.bashrc`:
|
|
|
|
|
2012-08-12 10:10:50 +02:00
|
|
|
`source liquidprompt`
|
2012-07-19 14:17:32 +02:00
|
|
|
|
2012-08-01 19:33:32 +02:00
|
|
|
Copy the `liquidpromptrc-dist` file in your home directory as
|
2012-08-04 17:47:56 +02:00
|
|
|
`~/.config/liquidpromptrc` or `~/.liquidpromptrc` and edit it according to your
|
|
|
|
preferences. If you skip this step, the default behaviour will be used.
|
2012-08-01 19:33:32 +02:00
|
|
|
|
2013-01-17 21:44:16 +01:00
|
|
|
Note that you should not overwrite the `PROMPT_COMMAND` variable, or else the
|
|
|
|
prompt will not be available.
|
|
|
|
|
2012-07-19 14:17:32 +02:00
|
|
|
|
2012-08-10 14:30:13 +02:00
|
|
|
## DEPENDENCIES
|
|
|
|
|
2012-08-13 09:35:50 +02:00
|
|
|
Apart from obvious ones, some features depends on specific commands. If you do
|
|
|
|
not install them, the corresponding feature will not be available, but you will
|
|
|
|
see no error.
|
2012-08-10 14:30:13 +02:00
|
|
|
|
|
|
|
* battery status need `acpi`,
|
|
|
|
* detached sessions is looking for `screen`.
|
2012-08-13 09:35:50 +02:00
|
|
|
* VCS support features needs… `git`, `hg` or `svn`, but you knew it.
|
2012-08-10 14:30:13 +02:00
|
|
|
|
|
|
|
For other features, the script uses commands that should be available on a large
|
|
|
|
variety of unixes: `tput`, `grep`, `awk`, `sed`, `ps`, `who`.
|
|
|
|
|
|
|
|
|
2012-08-14 15:38:33 +02:00
|
|
|
## FEATURES CONFIGURATION
|
2012-07-19 14:17:32 +02:00
|
|
|
|
2012-08-01 19:33:32 +02:00
|
|
|
You can configure some variables in the `~/.liquidpromptrc` file:
|
|
|
|
|
|
|
|
* `LP_BATTERY_THRESHOLD`, the maximal value under which the battery level is
|
|
|
|
displayed
|
|
|
|
* `LP_LOAD_THRESHOLD`, the minimal value after which the load average is
|
|
|
|
displayed
|
|
|
|
* `LP_PATH_LENGTH`, the maximum percentage of the screen width used to display
|
|
|
|
the path
|
|
|
|
* `LP_PATH_KEEP`, how many directories to keep at the beginning of a shortened
|
|
|
|
path
|
2012-08-07 20:52:32 +02:00
|
|
|
* `LP_HOSTNAME_ALWAYS`, choose between always displaying the hostname or showing
|
|
|
|
it only when connected with a remote shell
|
2013-01-11 10:15:12 +01:00
|
|
|
* `LP_USER_ALWAYS`, choose between always displaying the user or showing
|
|
|
|
it only when he is different from the logged one
|
2012-08-16 17:10:58 +02:00
|
|
|
|
|
|
|
You can also force some features to be disabled, to save some time in the prompt
|
|
|
|
building:
|
2012-08-16 15:16:48 +02:00
|
|
|
* `LP_ENABLE_PERM`, if you want to detect if the directory is writable
|
|
|
|
* `LP_ENABLE_SHORTEN_PATH`, if you to shorten the path display
|
|
|
|
* `LP_ENABLE_PROXY`, if you want to detect if a proxy is used
|
|
|
|
* `LP_ENABLE_JOBS`, if you want to have jobs informations
|
|
|
|
* `LP_ENABLE_LOAD`, if you want to have load informations
|
|
|
|
* `LP_ENABLE_BATT`, if you want to have battery informations
|
|
|
|
* `LP_ENABLE_GIT`, if you want to have git informations
|
|
|
|
* `LP_ENABLE_SVN`, if you want to have subversion informations
|
|
|
|
* `LP_ENABLE_HG`, if you want to have mercurial informations
|
2013-01-05 23:03:26 +01:00
|
|
|
* `LP_ENABLE_FOSSIL`, if you want to have fossil informations
|
2013-01-04 12:13:00 +01:00
|
|
|
* `LP_ENABLE_VCS_ROOT`, if you want to show VCS informations with root account
|
2013-01-10 17:18:45 +01:00
|
|
|
* `LP_ENABLE_TITLE`, if you want to use the prompt as your terminal window's title
|
2012-08-16 15:16:48 +02:00
|
|
|
|
2012-08-16 17:10:58 +02:00
|
|
|
Note that if required commands are not installed, enabling the
|
|
|
|
corresponding feature will have no effect.
|
|
|
|
Note also that all the `LP_ENABLE_…` variables override the templates,
|
|
|
|
i.e. if you use `$LP_BATT` in your template and you set `LP_ENABLE_BATT=0`
|
|
|
|
in your config file, you will not have the battery informations.
|
2012-08-01 19:33:32 +02:00
|
|
|
|
2013-01-10 10:22:58 +01:00
|
|
|
If you are using bash and want to use the `PROMPT_DIRTRIM` built-in
|
|
|
|
functionality to shorten but still have liquidprompt calculating the number of
|
|
|
|
directories to keep in the path, precise a value for `PROMPT_DIRTRIM` before
|
|
|
|
sourcing liquidprompt and liquidprompt will override this value with one
|
|
|
|
fitting the width of your terminal.
|
|
|
|
|
|
|
|
|
2013-01-04 13:08:36 +01:00
|
|
|
## CUSTOMIZING THE PROMPT
|
2012-08-14 15:38:33 +02:00
|
|
|
|
2013-01-04 13:08:36 +01:00
|
|
|
### ADD A PS1 PREFIX
|
2013-01-04 13:01:06 +01:00
|
|
|
|
|
|
|
You can prefix the `LP_PS1` variable with anything you want using the
|
2013-01-10 17:18:45 +01:00
|
|
|
`LP_PS1_PREFIX`. The following example activate a custom window's title:
|
2013-01-04 13:01:06 +01:00
|
|
|
|
2013-01-04 14:08:26 +01:00
|
|
|
LP_PS1_PREFIX="\[\e]0;\u@\h: \w\a\]"
|
2012-08-14 15:38:33 +02:00
|
|
|
|
2013-01-04 13:08:36 +01:00
|
|
|
### PUT THE PROMPT IN A DIFFERENT ORDER
|
2012-08-14 15:38:33 +02:00
|
|
|
|
|
|
|
You can sort what you want to see by sourcing your favorite template file
|
2012-09-09 23:03:39 +02:00
|
|
|
(`*.ps1`) in the configuration file.
|
2012-08-14 15:38:33 +02:00
|
|
|
|
|
|
|
Those scripts basically export the `LP_PS1` variable, by appending features and
|
|
|
|
theme colors.
|
|
|
|
|
|
|
|
Available features:
|
|
|
|
* `LP_BATT` battery
|
|
|
|
* `LP_LOAD` load
|
|
|
|
* `LP_JOBS` screen sessions/running jobs/suspended jobs
|
|
|
|
* `LP_USER` user
|
|
|
|
* `LP_HOST` hostname
|
|
|
|
* `LP_PERM` a colon ":"
|
|
|
|
* `LP_PWD` current working directory
|
|
|
|
* `LP_PROXY` HTTP proxy
|
2013-01-23 18:26:21 +01:00
|
|
|
* `LP_VCS` informations concerning the current working repository
|
2012-08-14 15:38:33 +02:00
|
|
|
* `LP_ERR` last error code
|
|
|
|
* `LP_MARK` prompt mark
|
2013-01-10 17:18:45 +01:00
|
|
|
* `LP_TITLE` the prompt as a window's title escaped sequence
|
2012-08-14 15:38:33 +02:00
|
|
|
|
2012-08-10 15:46:44 +02:00
|
|
|
For example, if you just want to have a liquidprompt displaying the user and the
|
2012-08-14 15:38:33 +02:00
|
|
|
host, with a normal full path in blue and only the git support:
|
2012-08-10 15:46:44 +02:00
|
|
|
|
2012-08-13 23:15:24 +02:00
|
|
|
export LP_PS1=`echo -ne "[\${LP_USER}\${LP_HOST}:\${BLUE}\$(pwd)\${NO_COL}] \${LP_GIT} \\\$ "`
|
2012-08-10 15:46:44 +02:00
|
|
|
|
|
|
|
Note that you need to properly escape dollars in a string that wil be
|
|
|
|
interpreted by bash at each prompt.
|
|
|
|
|
|
|
|
To erase your new formatting, just bring the `LP_PS1` to a null string:
|
|
|
|
|
|
|
|
export LP_PS1=""
|
2012-07-19 14:17:32 +02:00
|
|
|
|
|
|
|
|
2013-01-23 18:26:21 +01:00
|
|
|
|
2012-08-16 15:22:01 +02:00
|
|
|
## THEMES
|
2012-08-14 12:01:14 +02:00
|
|
|
|
2012-08-16 15:22:01 +02:00
|
|
|
You can change the colors and special characters of some part of the liquid
|
2012-09-09 23:03:39 +02:00
|
|
|
prompt by sourcing your favorite theme file (`*.theme`) in the configuration file.
|
2012-08-16 15:22:01 +02:00
|
|
|
|
|
|
|
### COLORS
|
2012-08-14 12:01:14 +02:00
|
|
|
|
|
|
|
Available colors are:
|
2012-08-14 15:06:58 +02:00
|
|
|
BOLD, BLACK, BOLD_GRAY, WHITE, BOLD_WHITE,
|
|
|
|
GREEN, BOLD_GREEN, YELLOW, BOLD_YELLOW, BLUE, BOLD_BLUE, PINK, CYAN, BOLD_CYAN
|
|
|
|
RED, BOLD_RED, WARN_RED, CRIT_RED, DANGER_RED,
|
2012-08-14 15:38:33 +02:00
|
|
|
NO_COL.
|
2012-08-14 12:01:14 +02:00
|
|
|
Set to a null string "" if you do not want color.
|
|
|
|
|
|
|
|
* Current working directory
|
|
|
|
* `LP_COLOR_PATH` as normal user
|
|
|
|
* `LP_COLOR_PATH_ROOT` as root
|
|
|
|
* Color of the proxy mark
|
|
|
|
* `LP_COLOR_PROXY`
|
|
|
|
* Jobs count
|
|
|
|
* `LP_COLOR_JOB_D` Detached (aka screen sessions)
|
|
|
|
* `LP_COLOR_JOB_R` Running (xterm &)
|
|
|
|
* `LP_COLOR_JOB_Z` Sleeping (Ctrl-Z)
|
|
|
|
* Last error code
|
|
|
|
* `LP_COLOR_ERR`
|
|
|
|
* Prompt mark
|
|
|
|
* `LP_COLOR_MARK` as user
|
|
|
|
* `LP_COLOR_MARK_ROOT` as root
|
|
|
|
* Current user
|
|
|
|
* `LP_COLOR_USER_LOGGED` user who logged in
|
|
|
|
* `LP_COLOR_USER_ALT` user but not the one who logged in
|
|
|
|
* `LP_COLOR_USER_ROOT` root
|
|
|
|
* Hostname
|
|
|
|
* `LP_COLOR_HOST` local host
|
|
|
|
* `LP_COLOR_SSH` connected via SSH
|
|
|
|
* `LP_COLOR_TELNET` connected via telnet
|
2012-09-25 21:09:51 +02:00
|
|
|
* `LP_COLOR_X11_ON` connected with X11 support
|
|
|
|
* `LP_COLOR_X11_OFF` connected without X11 support
|
2012-08-14 12:01:14 +02:00
|
|
|
* Separation mark (aka permiison in the working dir)
|
|
|
|
* `LP_COLOR_WRITE` have write permission
|
|
|
|
* `LP_COLOR_NOWRITE` do not have write permission
|
2012-08-14 14:35:20 +02:00
|
|
|
* VCS
|
|
|
|
* `LP_COLOR_UP` repository is up to date / a push have been made
|
|
|
|
* `LP_COLOR_COMMITS` some commits have not been pushed
|
|
|
|
* `LP_COLOR_CHANGES` there is some changes to commit
|
2013-01-05 23:03:26 +01:00
|
|
|
* `LP_COLOR_DIFF` number of lines or files impacted by current changes
|
2012-08-14 14:35:20 +02:00
|
|
|
* Battery
|
|
|
|
* `LP_COLOR_CHARGING_ABOVE` charging and above threshold
|
|
|
|
* `LP_COLOR_CHARGING_UNDER` charging but under threshold
|
|
|
|
* `LP_COLOR_DISCHARGING_ABOVE` discharging but above threshold
|
|
|
|
* `LP_COLOR_DISCHARGING_UNDER` discharging and under threshold
|
2012-08-14 12:01:14 +02:00
|
|
|
|
|
|
|
|
2012-08-16 15:22:01 +02:00
|
|
|
### CHARACTERS
|
|
|
|
|
|
|
|
Special characters:
|
|
|
|
* `LP_MARK_BATTERY` (default: "⌁") in front of the battery charge
|
|
|
|
* `LP_MARK_ADAPTER` (default: "⏚") displayed when plugged
|
|
|
|
* `LP_MARK_LOAD` (default: "⌂") in front of the load
|
|
|
|
* `LP_MARK_PROXY` (default: "↥") indicate a proxy in use
|
|
|
|
* `LP_MARK_HG` (default: "☿") prompt mark in hg repositories
|
|
|
|
* `LP_MARK_SVN` (default: "‡") prompt mark in svn repositories
|
|
|
|
* `LP_MARK_GIT` (default: "±") prompt mark in git repositories
|
2013-01-05 23:03:26 +01:00
|
|
|
* `LP_MARK_FOSSIL` (default: "⌘") prompt mark in fossil repositories
|
2012-08-16 15:22:01 +02:00
|
|
|
* `LP_MARK_UNTRACKED` (default: "*") if git has untracked files
|
2013-01-17 23:02:17 +01:00
|
|
|
* `LP_MARK_STASH` (default: "+") if git has stashed modifications
|
2013-01-10 17:18:45 +01:00
|
|
|
* `LP_TITLE_OPEN` (default: "\e]0;") escape character opening a window's title
|
|
|
|
* `LP_TITLE_CLOSE` (default: "\a") escape character closing a window's title
|
2012-08-16 15:22:01 +02:00
|
|
|
|
|
|
|
|
2012-07-19 14:17:32 +02:00
|
|
|
## KNOWN LIMITATIONS AND BUGS
|
|
|
|
|
2012-08-10 16:52:23 +02:00
|
|
|
Liquid prompt is distributed under the GNU Affero General Public License
|
|
|
|
version 3.
|
|
|
|
|
2012-08-10 14:28:18 +02:00
|
|
|
* detached sessions only looks for `screen`, a `tmux` support would be nice…
|
2012-07-19 14:17:32 +02:00
|
|
|
* Does not display the number of commits to be pushed in Mercurial repositories.
|
2012-08-13 09:35:50 +02:00
|
|
|
* Browsing into very large subversion repositories may dramatically slow down
|
|
|
|
the display of the liquid prompt.
|
2012-07-19 14:17:32 +02:00
|
|
|
* Subversion repository cannot display commits to be pushed, this is a
|
|
|
|
limitation of the Subversion versionning model.
|
2012-08-09 12:11:51 +02:00
|
|
|
* The proxy detection only uses the `$http_proxy` environment variable.
|
2013-01-10 17:18:45 +01:00
|
|
|
* The window's title escape sequence may not work properly on some terminals
|
|
|
|
(like xterm-256)
|
2012-07-19 14:17:32 +02:00
|
|
|
|