aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDominik Ritter <dritter03@googlemail.com>2015-04-05 01:13:02 +0300
committerDominik Ritter <dritter03@googlemail.com>2015-04-05 01:13:02 +0300
commit41bc89fb72a558ead29390177f29f0125d673f3c (patch)
tree6cd5e8c8a5dcd4fffbaa1c451ca0f23d7516dba0
parent8d52f7b1894ac00eb01b79129750d69a3d21b5dd (diff)
parent13273fccd66709db62f93c772c9e052d398dac88 (diff)
Merge branch 'master' into dritter/test-ratio
-rw-r--r--README.md12
-rw-r--r--powerlevel9k.zsh-theme132
2 files changed, 82 insertions, 62 deletions
diff --git a/README.md b/README.md
index e03cd98b..99e86317 100644
--- a/README.md
+++ b/README.md
@@ -111,13 +111,21 @@ elements (it is by default), and define a `DEFAULT_USER` in your `~/.zshrc`:
#### Test ratio
-The `symfony2_tests` and `rspec_tests` segments show both a ratio of code classes
+The `symfony2_tests` and `rspec_tests` segments show both a ratio of "real" classes
vs test classes. This is just a very simple ratio, and does not show your code
coverage or any sophisticated stats. All this does is just to count your files
and test files and calculate the ratio between them. Not more, but is may give
a quick overview about the test situation of the project you are dealing with.
-#### The VCS Information Segment
+#### The 'time' segment
+
+By default the time is show in 'H:M:S' format. If you want to change it,
+just set another format in your `~/.zshrc`:
+
+ # Reversed time format
+ POWERLEVEL9K_TIME_FORMAT='%D{%S:%M:%H}'
+
+#### The 'vcs' Segment
By default, the `vcs` segment will provide quite a bit of information. If you
would also like for it to display the current hash / changeset, simply define
diff --git a/powerlevel9k.zsh-theme b/powerlevel9k.zsh-theme
index 1ac02d6d..1662d58d 100644
--- a/powerlevel9k.zsh-theme
+++ b/powerlevel9k.zsh-theme
@@ -28,6 +28,9 @@
# Set your username for the `context` segment:
# export DEFAULT_USER=<your username>
#
+# Customized the format of the time segment. Example of reverse format:
+# POWERLEVEL9K_TIME_FORMAT='%D{%S:%M:%H}'
+#
# Show the hash/changeset string in the `vcs` segment:
# POWERLEVEL9K_SHOW_CHANGESET=true
# Set the length of the hash/changeset if enabled in the `vcs` segment:
@@ -157,18 +160,8 @@ right_prompt_segment() {
}
################################################################
-# Prompt Components
+# The 'vcs' Segment and VCS_INFO hooks / helper functions
################################################################
-
-# Context: user@hostname (who am I and where am I)
-# Note that if $DEFAULT_USER is not set, this prompt segment will always print
-prompt_context() {
- if [[ "$USER" != "$DEFAULT_USER" || -n "$SSH_CLIENT" ]]; then
- $1_prompt_segment $DEFAULT_COLOR "011" "%(!.%{%F{yellow}%}.)$USER@%m"
- fi
-}
-
-# branch/detached head, dirty status
prompt_vcs() {
local vcs_prompt="${vcs_info_msg_0_}"
@@ -251,31 +244,35 @@ function +vi-vcs-detect-changes() {
fi
}
-# Dir: current working directory
-prompt_dir() {
- $1_prompt_segment blue $DEFAULT_COLOR '%~'
+################################################################
+# Prompt Segments
+################################################################
+
+# AWS Profile
+prompt_aws() {
+ local aws_profile=$AWS_DEFAULT_PROFILE
+ if [[ -n $aws_profile ]];
+ then
+ $1_prompt_segment red white "AWS: $aws_profile"
+ fi
}
-# Virtualenv: current working virtualenv
-# More information on virtualenv (Python):
-# https://virtualenv.pypa.io/en/latest/
-prompt_virtualenv() {
- local virtualenv_path="$VIRTUAL_ENV"
- if [[ -n $virtualenv_path && -n $VIRTUAL_ENV_DISABLE_PROMPT ]]; then
- $1_prompt_segment blue $DEFAULT_COLOR "(`basename $virtualenv_path`)"
+# Context: user@hostname (who am I and where am I)
+# Note that if $DEFAULT_USER is not set, this prompt segment will always print
+prompt_context() {
+ if [[ "$USER" != "$DEFAULT_USER" || -n "$SSH_CLIENT" ]]; then
+ $1_prompt_segment $DEFAULT_COLOR "011" "%(!.%{%F{yellow}%}.)$USER@%m"
fi
}
-# Left Status: (return code, root status, background jobs)
-# This creates a status segment for the *left* prompt
-prompt_status() {
- local symbols
- symbols=()
- [[ $RETVAL -ne 0 ]] && symbols+="%{%F{red}%}✘"
- [[ $UID -eq 0 ]] && symbols+="%{%F{yellow}%}⚡"
- [[ $(jobs -l | wc -l) -gt 0 ]] && symbols+="%{%F{cyan}%}⚙"
+# Dir: current working directory
+prompt_dir() {
+ $1_prompt_segment blue $DEFAULT_COLOR '%~'
+}
- [[ -n "$symbols" ]] && $1_prompt_segment $DEFAULT_COLOR default "$symbols"
+# Command number (in local history)
+prompt_history() {
+ $1_prompt_segment "244" $DEFAULT_COLOR '%h'
}
# Right Status: (return code, root status, background jobs)
@@ -299,25 +296,6 @@ prompt_longstatus() {
[[ -n "$symbols" ]] && $1_prompt_segment $bg $DEFAULT_COLOR "$symbols"
}
-# System time
-prompt_time() {
- $1_prompt_segment $DEFAULT_COLOR_INVERTED $DEFAULT_COLOR '%D{%H:%M:%S} '
-}
-
-# Command number (in local history)
-prompt_history() {
- $1_prompt_segment "244" $DEFAULT_COLOR '%h'
-}
-
-# Ruby Version Manager information
-prompt_rvm() {
- local rvm_prompt
- rvm_prompt=`rvm-prompt`
- if [ "$rvm_prompt" != "" ]; then
- $1_prompt_segment "240" $DEFAULT_COLOR "$rvm_prompt "
- fi
-}
-
# rbenv information
prompt_rbenv() {
if [[ -n "$RBENV_VERSION" ]]; then
@@ -325,15 +303,6 @@ prompt_rbenv() {
fi
}
-# AWS Profile
-prompt_aws() {
- local aws_profile=$AWS_DEFAULT_PROFILE
- if [[ -n $aws_profile ]];
- then
- $1_prompt_segment red white "AWS: $aws_profile"
- fi
-}
-
# RSpec test ratio
prompt_rspec_stats() {
if [[ (-d app && -d spec) ]]; then
@@ -344,6 +313,27 @@ prompt_rspec_stats() {
fi
}
+# Ruby Version Manager information
+prompt_rvm() {
+ local rvm_prompt
+ rvm_prompt=`rvm-prompt`
+ if [ "$rvm_prompt" != "" ]; then
+ $1_prompt_segment "240" $DEFAULT_COLOR "$rvm_prompt "
+ fi
+}
+
+# Left Status: (return code, root status, background jobs)
+# This creates a status segment for the *left* prompt
+prompt_status() {
+ local symbols
+ symbols=()
+ [[ $RETVAL -ne 0 ]] && symbols+="%{%F{red}%}✘"
+ [[ $UID -eq 0 ]] && symbols+="%{%F{yellow}%}⚡"
+ [[ $(jobs -l | wc -l) -gt 0 ]] && symbols+="%{%F{cyan}%}⚙"
+
+ [[ -n "$symbols" ]] && $1_prompt_segment $DEFAULT_COLOR default "$symbols"
+}
+
# Symfony2-PHPUnit test ratio
prompt_symfony2_tests() {
if [[ (-d src && -d app && -f app/AppKernel.php) ]]; then
@@ -369,6 +359,30 @@ build_test_stats() {
[[ ratio -lt 0.5 ]] && $1_prompt_segment red $DEFAULT_COLOR "$headline: $ratio%%"
}
+# System time
+prompt_time() {
+ local time_format='%D{%H:%M:%S}'
+ if [[ -n $POWERLEVEL9K_TIME_FORMAT ]]; then
+ time_format=$POWERLEVEL9K_TIME_FORMAT
+ fi
+
+ $1_prompt_segment $DEFAULT_COLOR_INVERTED $DEFAULT_COLOR "$time_format "
+}
+
+# Virtualenv: current working virtualenv
+# More information on virtualenv (Python):
+# https://virtualenv.pypa.io/en/latest/
+prompt_virtualenv() {
+ local virtualenv_path="$VIRTUAL_ENV"
+ if [[ -n $virtualenv_path && -n $VIRTUAL_ENV_DISABLE_PROMPT ]]; then
+ $1_prompt_segment blue $DEFAULT_COLOR "(`basename $virtualenv_path`)"
+ fi
+}
+
+################################################################
+# Prompt processing and drawing
+################################################################
+
# Main prompt
build_left_prompt() {
if [[ ${#POWERLEVEL9K_LEFT_PROMPT_ELEMENTS} == 0 ]]; then
@@ -395,8 +409,6 @@ build_right_prompt() {
done
}
-################################################################
-# Create the prompts
precmd() {
vcs_info