Added runtime displaying
This commit is contained in:
parent
a39c2c8342
commit
b075b46c85
@ -65,6 +65,7 @@ commits to push;
|
|||||||
number of pending commits, if any;
|
number of pending commits, if any;
|
||||||
* a yellow plus if there is stashed modifications;
|
* a yellow plus if there is stashed modifications;
|
||||||
* a red star if there is some untracked files in the repository;
|
* a red star if there is some untracked files in the repository;
|
||||||
|
* the runtime of the last command, if it has exceeded a certain threshold
|
||||||
* the error code of the last command, if it has failed in some way;
|
* the error code of the last command, if it has failed in some way;
|
||||||
* a smart mark: ± for git directories, ☿ for mercurial, ‡ for svn,
|
* a smart mark: ± for git directories, ☿ for mercurial, ‡ for svn,
|
||||||
‡± for git-svn, ⌘ for fossil, $ or % for simple user, a red # for root;
|
‡± for git-svn, ⌘ for fossil, $ or % for simple user, a red # for root;
|
||||||
@ -132,9 +133,10 @@ You can configure some variables in the `~/.config/liquidpromptrc` file:
|
|||||||
|
|
||||||
* `LP_BATTERY_THRESHOLD`, the maximal value under which the battery level is
|
* `LP_BATTERY_THRESHOLD`, the maximal value under which the battery level is
|
||||||
displayed
|
displayed
|
||||||
* `LP_LOAD_THRESHOLD`, the minimal value after which the load average is
|
* `LP_LOAD_THRESHOLD`, the minimal value after which the load average is displayed
|
||||||
* `LP_TEMP_THRESHOLD`, the minimal value after which the temperature average is
|
* `LP_TEMP_THRESHOLD`, the minimal value after which the temperature average is
|
||||||
displayed
|
displayed
|
||||||
|
* `LP_RUNTIME_THRESHOLD`, the minimal value after which the runtime is displayed
|
||||||
* `LP_PATH_LENGTH`, the maximum percentage of the screen width used to display
|
* `LP_PATH_LENGTH`, the maximum percentage of the screen width used to display
|
||||||
the path
|
the path
|
||||||
* `LP_PATH_KEEP`, how many directories to keep at the beginning of a shortened
|
* `LP_PATH_KEEP`, how many directories to keep at the beginning of a shortened
|
||||||
@ -161,6 +163,7 @@ building:
|
|||||||
* `LP_ENABLE_TITLE`, if you want to use the prompt as your terminal window's title
|
* `LP_ENABLE_TITLE`, if you want to use the prompt as your terminal window's title
|
||||||
* `LP_ENABLE_SCREEN_TITLE`, if you want to use the prompt as your screen window's title
|
* `LP_ENABLE_SCREEN_TITLE`, if you want to use the prompt as your screen window's title
|
||||||
* `LP_ENABLE_SSH_COLORS`, if you want different colors for hosts you SSH in
|
* `LP_ENABLE_SSH_COLORS`, if you want different colors for hosts you SSH in
|
||||||
|
* `LP_ENABLE_RUNTIME`, if you want to display the runtime of the last command
|
||||||
* `LP_ENABLE_TIME`, if you want to display the time at which the prompt was shown
|
* `LP_ENABLE_TIME`, if you want to display the time at which the prompt was shown
|
||||||
* `LP_TIME_ANALOG`, when showing time, use an analog clock instead of numeric values
|
* `LP_TIME_ANALOG`, when showing time, use an analog clock instead of numeric values
|
||||||
|
|
||||||
@ -340,3 +343,4 @@ limitation of the Subversion versionning model.
|
|||||||
sufficiently complete font on your system.
|
sufficiently complete font on your system.
|
||||||
The [Symbola](http://users.teilar.gr/~g1951d/) font, designed by Georges Douros,
|
The [Symbola](http://users.teilar.gr/~g1951d/) font, designed by Georges Douros,
|
||||||
is known to work well.
|
is known to work well.
|
||||||
|
* Displaying the runtime currently only works with bash
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
# LP_ERR last error code
|
# LP_ERR last error code
|
||||||
# LP_MARK prompt mark
|
# LP_MARK prompt mark
|
||||||
# LP_TIME current time
|
# LP_TIME current time
|
||||||
|
# LP_RUNTIME runtime of last command
|
||||||
# LP_PS1_PREFIX user-defined general-purpose prefix (default set a generic prompt as the window title)
|
# LP_PS1_PREFIX user-defined general-purpose prefix (default set a generic prompt as the window title)
|
||||||
|
|
||||||
# Remember that most features come with their corresponding colors,
|
# Remember that most features come with their corresponding colors,
|
||||||
@ -40,7 +41,7 @@ else
|
|||||||
[[ "$LP_ENABLE_VCS_ROOT" = "1" ]] && LP_PS1="${LP_PS1}${LP_VCS}"
|
[[ "$LP_ENABLE_VCS_ROOT" = "1" ]] && LP_PS1="${LP_PS1}${LP_VCS}"
|
||||||
fi
|
fi
|
||||||
# add return code and prompt mark
|
# add return code and prompt mark
|
||||||
LP_PS1="${LP_PS1}${LP_ERR}${LP_MARK}"
|
LP_PS1="${LP_PS1}${LP_RUNTIME}${LP_ERR}${LP_MARK}"
|
||||||
|
|
||||||
# "invisible" parts
|
# "invisible" parts
|
||||||
# Get the current prompt on the fly and make it a title
|
# Get the current prompt on the fly and make it a title
|
||||||
|
@ -101,6 +101,9 @@ LP_COLOR_TIME="$BLUE"
|
|||||||
# Virtualenv
|
# Virtualenv
|
||||||
LP_COLOR_VIRTUALENV="$CYAN"
|
LP_COLOR_VIRTUALENV="$CYAN"
|
||||||
|
|
||||||
|
# Runtime
|
||||||
|
LP_COLOR_RUNTIME="$YELLOW"
|
||||||
|
|
||||||
# Color maps (battery and load levels)
|
# Color maps (battery and load levels)
|
||||||
# Range from 0 (nothing special) to 9 (alert)
|
# Range from 0 (nothing special) to 9 (alert)
|
||||||
LP_COLORMAP_0=""
|
LP_COLORMAP_0=""
|
||||||
|
56
liquidprompt
56
liquidprompt
@ -38,6 +38,7 @@
|
|||||||
# Joris Vaillant <joris.vaillant@gmail.com> # small git fix
|
# Joris Vaillant <joris.vaillant@gmail.com> # small git fix
|
||||||
# Luc Didry <luc@fiat-tux.fr> # Zsh port, several fix
|
# Luc Didry <luc@fiat-tux.fr> # Zsh port, several fix
|
||||||
# Ludovic Rousseau <ludovic.rousseau@gmail.com> # Lot of bugfixes.
|
# Ludovic Rousseau <ludovic.rousseau@gmail.com> # Lot of bugfixes.
|
||||||
|
# Markus Dreseler <github@dreseler.de> # Runtime of last command
|
||||||
# Nicolas Lacourte <nicolas@dotinfra.fr> # screen title
|
# Nicolas Lacourte <nicolas@dotinfra.fr> # screen title
|
||||||
# nojhan <nojhan@gmail.com> # Main author.
|
# nojhan <nojhan@gmail.com> # Main author.
|
||||||
# Olivier Mengué <dolmen@cpan.org> # Major optimizations and refactorings everywhere.
|
# Olivier Mengué <dolmen@cpan.org> # Major optimizations and refactorings everywhere.
|
||||||
@ -207,6 +208,7 @@ _lp_source_config()
|
|||||||
LP_BATTERY_THRESHOLD=${LP_BATTERY_THRESHOLD:-75}
|
LP_BATTERY_THRESHOLD=${LP_BATTERY_THRESHOLD:-75}
|
||||||
LP_LOAD_THRESHOLD=${LP_LOAD_THRESHOLD:-60}
|
LP_LOAD_THRESHOLD=${LP_LOAD_THRESHOLD:-60}
|
||||||
LP_TEMP_THRESHOLD=${LP_TEMP_THRESHOLD:-60}
|
LP_TEMP_THRESHOLD=${LP_TEMP_THRESHOLD:-60}
|
||||||
|
LP_RUNTIME_THRESHOLD=${LP_RUNTIME_THRESHOLD:-2}
|
||||||
LP_PATH_LENGTH=${LP_PATH_LENGTH:-35}
|
LP_PATH_LENGTH=${LP_PATH_LENGTH:-35}
|
||||||
LP_PATH_KEEP=${LP_PATH_KEEP:-2}
|
LP_PATH_KEEP=${LP_PATH_KEEP:-2}
|
||||||
LP_HOSTNAME_ALWAYS=${LP_HOSTNAME_ALWAYS:-0}
|
LP_HOSTNAME_ALWAYS=${LP_HOSTNAME_ALWAYS:-0}
|
||||||
@ -233,6 +235,13 @@ _lp_source_config()
|
|||||||
LP_ENABLE_HG=${LP_ENABLE_HG:-1}
|
LP_ENABLE_HG=${LP_ENABLE_HG:-1}
|
||||||
LP_ENABLE_BZR=${LP_ENABLE_BZR:-1}
|
LP_ENABLE_BZR=${LP_ENABLE_BZR:-1}
|
||||||
LP_ENABLE_TIME=${LP_ENABLE_TIME:-0}
|
LP_ENABLE_TIME=${LP_ENABLE_TIME:-0}
|
||||||
|
if [[ "$_LP_SHELL_bash" == true ]]
|
||||||
|
then
|
||||||
|
LP_ENABLE_RUNTIME=${LP_ENABLE_RUNTIME:-1}
|
||||||
|
else
|
||||||
|
[[ "$LP_ENABLE_RUNTIME" == 1 ]] && echo Unfortunately, runtime printing for zsh is not yet supported. Turn LP_ENABLE_RUNTIME off in your config to hide this message.
|
||||||
|
LP_ENABLE_RUNTIME=0
|
||||||
|
fi
|
||||||
LP_ENABLE_VIRTUALENV=${LP_ENABLE_VIRTUALENV:-1}
|
LP_ENABLE_VIRTUALENV=${LP_ENABLE_VIRTUALENV:-1}
|
||||||
LP_ENABLE_VCS_ROOT=${LP_ENABLE_VCS_ROOT:-0}
|
LP_ENABLE_VCS_ROOT=${LP_ENABLE_VCS_ROOT:-0}
|
||||||
LP_ENABLE_TITLE=${LP_ENABLE_TITLE:-0}
|
LP_ENABLE_TITLE=${LP_ENABLE_TITLE:-0}
|
||||||
@ -288,6 +297,7 @@ _lp_source_config()
|
|||||||
LP_COLOR_DISCHARGING_UNDER=${LP_COLOR_DISCHARGING_UNDER:-$RED}
|
LP_COLOR_DISCHARGING_UNDER=${LP_COLOR_DISCHARGING_UNDER:-$RED}
|
||||||
LP_COLOR_TIME=${LP_COLOR_TIME:-$BLUE}
|
LP_COLOR_TIME=${LP_COLOR_TIME:-$BLUE}
|
||||||
LP_COLOR_IN_MULTIPLEXER=${LP_COLOR_IN_MULTIPLEXER:-$BOLD_BLUE}
|
LP_COLOR_IN_MULTIPLEXER=${LP_COLOR_IN_MULTIPLEXER:-$BOLD_BLUE}
|
||||||
|
LP_COLOR_RUNTIME=${LP_COLOR_RUNTIME:-$YELLOW}
|
||||||
|
|
||||||
LP_COLORMAP_0=${LP_COLORMAP_0:-""}
|
LP_COLORMAP_0=${LP_COLORMAP_0:-""}
|
||||||
LP_COLORMAP_1=${LP_COLORMAP_1:-$GREEN}
|
LP_COLORMAP_1=${LP_COLORMAP_1:-$GREEN}
|
||||||
@ -1186,6 +1196,47 @@ _lp_color_map() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
###########################
|
||||||
|
# runtime of last command #
|
||||||
|
###########################
|
||||||
|
|
||||||
|
_LP_RUNTIME_LAST_SECONDS=0
|
||||||
|
|
||||||
|
_lp_runtime()
|
||||||
|
{
|
||||||
|
[[ "$LP_ENABLE_RUNTIME" != 1 ]] && return
|
||||||
|
if [[ $_LP_RUNTIME_SECONDS -ge $LP_RUNTIME_THRESHOLD ]]
|
||||||
|
then
|
||||||
|
echo -ne "${LP_COLOR_RUNTIME}"
|
||||||
|
# display runtime seconds as days, hours, minutes, and seconds
|
||||||
|
[[ "$_LP_RUNTIME_SECONDS" -ge 86400 ]] && echo -ne $(expr ${_LP_RUNTIME_SECONDS} / 86400)d
|
||||||
|
[[ "$_LP_RUNTIME_SECONDS" -ge 3600 ]] && echo -ne $(expr ${_LP_RUNTIME_SECONDS} % 86400 / 3600)h
|
||||||
|
[[ "$_LP_RUNTIME_SECONDS" -ge 60 ]] && echo -ne $(expr ${_LP_RUNTIME_SECONDS} % 3600 / 60)m
|
||||||
|
echo -ne $(expr ${_LP_RUNTIME_SECONDS} % 60)s
|
||||||
|
echo -ne "${NO_COL}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
_lp_reset_runtime()
|
||||||
|
{
|
||||||
|
# Compute number of seconds since program was started
|
||||||
|
_LP_RUNTIME_SECONDS=$(expr $SECONDS - $_LP_RUNTIME_LAST_SECONDS)
|
||||||
|
|
||||||
|
# If no proper command was executed (i.e., someone pressed enter without entering a command),
|
||||||
|
# reset the runtime counter
|
||||||
|
[ "$_LP_RUNTIME_COMMAND_EXECUTED" != 1 ] && _LP_RUNTIME_LAST_SECONDS=$SECONDS && _LP_RUNTIME_SECONDS=0
|
||||||
|
|
||||||
|
# A proper command has been executed if the last command was not related to liquidprompt
|
||||||
|
[ "$BASH_COMMAND" = _lp_set_prompt ] && _LP_RUNTIME_COMMAND_EXECUTED=0 && return
|
||||||
|
_LP_RUNTIME_COMMAND_EXECUTED=1
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ "$LP_ENABLE_RUNTIME" = 1 ]
|
||||||
|
then
|
||||||
|
# _lp_reset_runtime gets called whenever bash executes a command
|
||||||
|
trap '_lp_reset_runtime' DEBUG
|
||||||
|
fi
|
||||||
|
|
||||||
###############
|
###############
|
||||||
# System load #
|
# System load #
|
||||||
###############
|
###############
|
||||||
@ -1449,6 +1500,9 @@ _lp_set_prompt()
|
|||||||
# right of main prompt: space at left
|
# right of main prompt: space at left
|
||||||
LP_VENV="$(_lp_sl "$(_lp_virtualenv)")"
|
LP_VENV="$(_lp_sl "$(_lp_virtualenv)")"
|
||||||
# if change of working directory
|
# if change of working directory
|
||||||
|
|
||||||
|
LP_RUNTIME=$(_lp_sl "$(_lp_runtime)")
|
||||||
|
|
||||||
if [[ "$LP_OLD_PWD" != "$PWD" ]]; then
|
if [[ "$LP_OLD_PWD" != "$PWD" ]]; then
|
||||||
LP_VCS=""
|
LP_VCS=""
|
||||||
LP_VCS_TYPE=""
|
LP_VCS_TYPE=""
|
||||||
@ -1536,7 +1590,7 @@ _lp_set_prompt()
|
|||||||
PS1="${PS1}${LP_VCS}"
|
PS1="${PS1}${LP_VCS}"
|
||||||
|
|
||||||
# add return code and prompt mark
|
# add return code and prompt mark
|
||||||
PS1="${PS1}${LP_ERR}${LP_MARK}${LP_PS1_POSTFIX}"
|
PS1="${PS1}${LP_RUNTIME}${LP_ERR}${LP_MARK}${LP_PS1_POSTFIX}"
|
||||||
|
|
||||||
# "invisible" parts
|
# "invisible" parts
|
||||||
# Get the current prompt on the fly and make it a title
|
# Get the current prompt on the fly and make it a title
|
||||||
|
@ -99,6 +99,14 @@ LP_ENABLE_BZR=1
|
|||||||
# Recommended value is 0
|
# Recommended value is 0
|
||||||
LP_ENABLE_TIME=0
|
LP_ENABLE_TIME=0
|
||||||
|
|
||||||
|
# Show runtime of the last command if over LP_RUNTIME_THRESHOLD
|
||||||
|
# Recommended value is 0
|
||||||
|
LP_ENABLE_RUNTIME=0
|
||||||
|
|
||||||
|
# Minimal runtime to be displayed
|
||||||
|
# Recommended value is 2
|
||||||
|
LP_RUNTIME_THRESHOLD=2
|
||||||
|
|
||||||
# Display the virtualenv that is currently activated, if any
|
# Display the virtualenv that is currently activated, if any
|
||||||
# Recommended value is 1
|
# Recommended value is 1
|
||||||
LP_ENABLE_VIRTUALENV=1
|
LP_ENABLE_VIRTUALENV=1
|
||||||
|
Loading…
x
Reference in New Issue
Block a user