peepcode: add virtualenv prompt and fix git calls

pull/8939/merge
Marc Cornellà 2020-06-08 20:36:27 +02:00
parent e27a6e75cc
commit 374b4e02ef
1 changed files with 11 additions and 8 deletions

View File

@ -4,11 +4,11 @@
# #
git_repo_path() { git_repo_path() {
git rev-parse --git-dir 2>/dev/null command git rev-parse --git-dir 2>/dev/null
} }
git_commit_id() { git_commit_id() {
git rev-parse --short HEAD 2>/dev/null command git rev-parse --short HEAD 2>/dev/null
} }
git_mode() { git_mode() {
@ -22,23 +22,26 @@ git_mode() {
} }
git_dirty() { git_dirty() {
if [[ "$repo_path" != '.' && `git ls-files -m` != "" ]]; then if [[ "$repo_path" != '.' && -n "$(command git ls-files -m)" ]]; then
echo " %{$fg_bold[grey]%}✗%{$reset_color%}" echo " %{$fg_bold[grey]%}✗%{$reset_color%}"
fi fi
} }
git_prompt() { git_prompt() {
local cb=$(git_current_branch) local cb=$(git_current_branch)
if [ -n "$cb" ]; then if [[ -n "$cb" ]]; then
local repo_path=$(git_repo_path) local repo_path=$(git_repo_path)
echo " %{$fg_bold[grey]%}$cb %{$fg[white]%}$(git_commit_id)%{$reset_color%}$(git_mode)$(git_dirty)" echo " %{$fg_bold[grey]%}$cb %{$fg[white]%}$(git_commit_id)%{$reset_color%}$(git_mode)$(git_dirty)"
fi fi
} }
local smiley="%(?,%{$fg[green]%}☺%{$reset_color%},%{$fg[red]%}☹%{$reset_color%})" local smiley='%(?.%F{green}☺%f.%F{red}☹%f)'
PROMPT=' PROMPT='
%~ ${VIRTUAL_ENV:+"($VIRTUAL_ENV) "}%~
${smiley} %{$reset_color%}' ${smiley} '
RPROMPT='%{$fg[white]%} $(ruby_prompt_info)$(git_prompt)%{$reset_color%}' RPROMPT='%F{white} $(ruby_prompt_info)$(git_prompt)%{$reset_color%}'
# Disable automatic virtualenv prompt change
export VIRTUAL_ENV_DISABLE_PROMPT=1