summaryrefslogtreecommitdiff
path: root/oh-my-zsh/themes/peepcode.zsh-theme
diff options
context:
space:
mode:
Diffstat (limited to 'oh-my-zsh/themes/peepcode.zsh-theme')
-rw-r--r--oh-my-zsh/themes/peepcode.zsh-theme47
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