mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2025-12-26 02:12:33 +01:00
Reorder functions in file, change default format, remove GIT_PROMPT_INFO_FUNC:
- Reorder the git-prompt.plugin.zsh functions and file order to make it easier for beginners to scan and find things. - The previous default is now in the ashleydev file and the default format follows the robbierussle original (in bare basic form). - GIT_PROMPT_INFO_FUNC is no longer used. If you want to override the default format just define your own git_prompt_info() function in your theme file that sets what ever global variables you want to use in your prompt.
This commit is contained in:
parent
b33e6b6598
commit
53da2d86f6
2 changed files with 281 additions and 269 deletions
|
|
@ -17,6 +17,18 @@ if [[ "$DISABLE_COLOR" != "true" ]]; then
|
|||
# Reset formating:
|
||||
local R="%{$terminfo[sgr0]%}"
|
||||
|
||||
# git prompt info colors:
|
||||
local _Cerror_="%{$fg[yellow]%}" # bad (empty) .git/ directory
|
||||
local _Cbranch_new_repo_="%{$fg_bold[default]%}" # branch color of new repo
|
||||
local _Cbranch_clean_="%{$fg_no_bold[green]%}" # branch color when clean
|
||||
local _Cbranch_dirty_="%{$fg_no_bold[red]%}" # branch color when dirty
|
||||
local _Crebase_="%{$bold_color$fg[yellow]%}" # rebase info
|
||||
local _Cindex_="%{$bold_color$fg[red]%}" # index info
|
||||
local _Cuntracked_clean_="" # untracked files state when clean
|
||||
local _Cuntracked_dirty_="%{$fg_bold[red]%}" # untracked files state when dirty
|
||||
local _Cupstream_="%{${fg[cyan]}%}" # upstream info
|
||||
local _Cstash_="" # stash state
|
||||
|
||||
# PROMPT colors:
|
||||
local _Cuser_root_="%{$fg_bold[yellow]$bg[red]%}"
|
||||
local _Chost_root_="%{$fg[red]%}"
|
||||
|
|
@ -40,9 +52,6 @@ local host_="%(!.$_Chost_root_.$_Chost_)%m$R"
|
|||
local path_="%(!.$_Cpath_root_.$_Cpath_)%~$R"
|
||||
local jobs_="%(1j.$_Cjobs_%j$R.)"
|
||||
|
||||
# git_prompt_info_default() will set $GIT_PROMPT_INFO
|
||||
GIT_PROMPT_INFO_FUNC=git_prompt_info_default
|
||||
|
||||
PROMPT='$user_$host_$path_ $GIT_PROMPT_INFO$jobs_# '
|
||||
|
||||
local date_format_='%D{%a %b %d}, %*'
|
||||
|
|
@ -53,3 +62,82 @@ RPROMPT='$return_code_$date_'
|
|||
|
||||
# use the vi-mode oh-my-zsh plugin to get this:
|
||||
MODE_INDICATOR="${_Cvi_mode_}-- CMD MODE -- $R"
|
||||
|
||||
|
||||
#-------------------- Git prompt info format: ----------------------
|
||||
git_prompt_info ()
|
||||
{
|
||||
local dir_="$(git_prompt__git_dir)"
|
||||
if [ -z "$dir_" ]; then
|
||||
GIT_PROMPT_INFO=''
|
||||
return
|
||||
fi
|
||||
|
||||
git_prompt__stash
|
||||
local stash_=$GIT_PROMPT_STASH_STATE_DIRTY
|
||||
|
||||
git_prompt__upstream
|
||||
local upstream_=$GIT_PROMPT_UPSTREAM_STATE
|
||||
|
||||
git_prompt__branch
|
||||
local branch_=$GIT_PROMPT_BRANCH
|
||||
|
||||
git_prompt__rebase_info
|
||||
local rebase_=$GIT_PROMPT_REBASE_INFO
|
||||
|
||||
git_prompt__dirty_state
|
||||
local work_=$GIT_PROMPT_DIRTY_STATE_WORKTREE_DIRTY
|
||||
local index_=$GIT_PROMPT_DIRTY_STATE_INDEX_DIRTY
|
||||
local untracked_=$GIT_PROMPT_DIRTY_STATE_WORKTREE_UNTRACKED
|
||||
local freshy_=$GIT_PROMPT_DIRTY_STATE_FRESH_REPO
|
||||
|
||||
if [ -z "$branch_$index_$work_$untracked_" ]; then
|
||||
if [ -n "$dir_" ]; then
|
||||
GIT_PROMPT_INFO="$R$_Cerror_(Error: bad ./$dir_ dir)$R"
|
||||
return
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "$stash_" = 'yes' ]; then
|
||||
stash_="$_Cstash_\$$R"
|
||||
else
|
||||
stash_=""
|
||||
fi
|
||||
|
||||
if [ -n "$upstream_" ]; then
|
||||
upstream_="$_Cupstream_$upstream_$R"
|
||||
fi
|
||||
|
||||
if [ "$index_" = "yes" ]; then
|
||||
index_="$_Cindex_+$R"
|
||||
else
|
||||
index_=""
|
||||
fi
|
||||
|
||||
if [ -n "$branch_" ]; then
|
||||
if [ "$freshy_" = "yes" ]; then
|
||||
# this is a fresh repo, nothing here...
|
||||
branch_="$_Cbranch_new_repo_$branch_$R"
|
||||
elif [ "$work_" = 'yes' ]; then
|
||||
branch_="$_Cbranch_dirty_$branch_$R"
|
||||
elif [ "$work_" = 'no' ]; then
|
||||
branch_="$_Cbranch_clean_$branch_$R"
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ -n "$rebase_" ]; then
|
||||
rebase_="$_Crebase_$rebase_$R"
|
||||
fi
|
||||
|
||||
local _prompt="$branch_$rebase_$index_$stash_$upstream_"
|
||||
# add ( ) around _prompt:
|
||||
if [ "$untracked_" = "yes" ]; then
|
||||
_prompt="$_Cuntracked_dirty_($_prompt$_Cuntracked_dirty_)"
|
||||
elif [ "$untracked_" = "no" ]; then
|
||||
_prompt="$_Cuntracked_clean_($_prompt$_Cuntracked_clean_)"
|
||||
else
|
||||
_prompt="($_prompt)"
|
||||
fi
|
||||
|
||||
GIT_PROMPT_INFO="$R$_prompt$R"
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue