From edc449275b6c04445f58b108ca0937a87c1e8430 Mon Sep 17 00:00:00 2001 From: Aditya Date: Mon, 27 Feb 2023 20:04:56 +0530 Subject: add zsh --- oh-my-zsh/themes/peepcode.zsh-theme | 47 +++++++++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 oh-my-zsh/themes/peepcode.zsh-theme (limited to 'oh-my-zsh/themes/peepcode.zsh-theme') 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 -- cgit v1.2.3