diff options
Diffstat (limited to 'oh-my-zsh/themes/peepcode.zsh-theme')
-rw-r--r-- | oh-my-zsh/themes/peepcode.zsh-theme | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/oh-my-zsh/themes/peepcode.zsh-theme b/oh-my-zsh/themes/peepcode.zsh-theme new file mode 100644 index 0000000..0445346 --- /dev/null +++ b/oh-my-zsh/themes/peepcode.zsh-theme @@ -0,0 +1,47 @@ +# +# Based on Geoffrey Grosenbach's peepcode zsh theme from +# https://github.com/topfunky/zsh-simple +# + +git_repo_path() { + command git rev-parse --git-dir 2>/dev/null +} + +git_commit_id() { + command git rev-parse --short HEAD 2>/dev/null +} + +git_mode() { + if [[ -e "$repo_path/BISECT_LOG" ]]; then + echo "+bisect" + elif [[ -e "$repo_path/MERGE_HEAD" ]]; then + echo "+merge" + elif [[ -e "$repo_path/rebase" || -e "$repo_path/rebase-apply" || -e "$repo_path/rebase-merge" || -e "$repo_path/../.dotest" ]]; then + echo "+rebase" + fi +} + +git_dirty() { + if [[ "$repo_path" != '.' && -n "$(command git ls-files -m)" ]]; then + echo " %{$fg_bold[grey]%}✗%{$reset_color%}" + fi +} + +git_prompt() { + local cb=$(git_current_branch) + if [[ -n "$cb" ]]; then + local repo_path=$(git_repo_path) + echo " %{$fg_bold[grey]%}$cb %{$fg[white]%}$(git_commit_id)%{$reset_color%}$(git_mode)$(git_dirty)" + fi +} + +local smiley='%(?.%F{green}☺%f.%F{red}☹%f)' + +PROMPT=' +${VIRTUAL_ENV:+"($VIRTUAL_ENV) "}%~ +${smiley} ' + +RPROMPT='%F{white} $(ruby_prompt_info)$(git_prompt)%{$reset_color%}' + +# Disable automatic virtualenv prompt change +export VIRTUAL_ENV_DISABLE_PROMPT=1 |