1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-10-27 04:40:59 +01:00

Frank Terbeck: 26549: VCS_Info improvements: check for changes in git

This commit is contained in:
Peter Stephenson 2009-02-11 12:48:21 +00:00
parent b0066bc202
commit 76f05a9932
14 changed files with 86 additions and 15 deletions

View file

@ -22,5 +22,5 @@ fi
rrn=${bzrbase:t}
zstyle -s ":vcs_info:${vcs}:${usercontext}:${rrn}" branchformat bzrbr || bzrbr="%b:%r"
zformat -f bzrbr "${bzrbr}" "b:${bzrinfo[2]}" "r:${bzrinfo[1]}"
VCS_INFO_formats '' "${bzrbr}" "${bzrbase}"
VCS_INFO_formats '' "${bzrbr}" "${bzrbase}" '' ''
return 0

View file

@ -7,5 +7,5 @@ local cdvbase
cdvbase=${vcs_comm[basedir]}
rrn=${cdvbase:t}
VCS_INFO_formats '' "${cdvbase:t}" "${cdvbase}"
VCS_INFO_formats '' "${cdvbase:t}" "${cdvbase}" '' ''
return 0

View file

@ -14,5 +14,5 @@ cvsbranch=$(< ./CVS/Repository)
rrn=${cvsbase:t}
cvsbranch=${cvsbranch##${rrn}/}
[[ -z ${cvsbranch} ]] && cvsbranch=${rrn}
VCS_INFO_formats '' "${cvsbranch}" "${cvsbase}"
VCS_INFO_formats '' "${cvsbranch}" "${cvsbase}" '' ''
return 0

View file

@ -7,5 +7,5 @@ local darcsbase
darcsbase=${vcs_comm[basedir]}
rrn=${darcsbase:t}
VCS_INFO_formats '' "${darcsbase:t}" "${darcsbase}"
VCS_INFO_formats '' "${darcsbase:t}" "${darcsbase}" '' ''
return 0

View file

@ -3,7 +3,7 @@
## Distributed under the same BSD-ish license as zsh itself.
setopt localoptions extendedglob NO_shwordsplit
local gitdir gitbase gitbranch gitaction
local gitdir gitbase gitbranch gitaction gitunstaged gitstaged
VCS_INFO_git_getaction () {
local gitaction='' gitdir=$1
@ -96,9 +96,17 @@ if [[ -z ${gitdir} ]] || [[ -z ${gitbranch} ]] ; then
return 1
fi
if zstyle -t ":vcs_info:${vcs}:${usercontext}:${rrn}" "check-for-changes" ; then
# Default: off - these are potentially expensive on big repositories
${vcs_comm[cmd]} diff --no-ext-diff --ignore-submodules --quiet --exit-code ||
gitunstaged=1
${vcs_comm[cmd]} diff-index --cached --quiet --ignore-submodules HEAD ||
gitstaged=1
fi
VCS_INFO_adjust
gitaction="$(VCS_INFO_git_getaction ${gitdir})"
gitbase=${PWD%/${$( ${vcs_comm[cmd]} rev-parse --show-prefix )%/##}}
rrn=${gitbase:t}
VCS_INFO_formats "${gitaction}" "${gitbranch}" "${gitbase}"
VCS_INFO_formats "${gitaction}" "${gitbranch}" "${gitbase}" "${gitstaged}" "${gitunstaged}"
return 0

View file

@ -8,5 +8,5 @@ local hgbranch hgbase
hgbase=${vcs_comm[basedir]}
rrn=${hgbase:t}
hgbranch=$(< ${hgbase}/.hg/branch)
VCS_INFO_formats '' "${hgbranch}" "${hgbase}"
VCS_INFO_formats '' "${hgbranch}" "${hgbase}" '' ''
return 0

View file

@ -8,5 +8,5 @@ local mtnbranch mtnbase
mtnbase=${vcs_comm[basedir]}
rrn=${mtnbase:t}
mtnbranch=${${(M)${(f)"$( ${vcs_comm[cmd]} status )"}:#(#s)Current branch:*}/*: /}
VCS_INFO_formats '' "${mtnbranch}" "${mtnbase}"
VCS_INFO_formats '' "${mtnbranch}" "${mtnbase}" '' ''
return 0

View file

@ -21,4 +21,4 @@ p4branch="%b:%r"
zformat -f p4branch "${p4branch}" "b:${p4info[Client_name]}" \
"r:$change"
VCS_INFO_formats '' "${p4branch}" "${p4base}"
VCS_INFO_formats '' "${p4branch}" "${p4base}" '' ''

View file

@ -9,5 +9,5 @@ svkbase=${vcs_comm[basedir]}
rrn=${svkbase:t}
zstyle -s ":vcs_info:${vcs}:${usercontext}:${rrn}" branchformat svkbranch || svkbranch="%b:%r"
zformat -f svkbranch "${svkbranch}" "b:${vcs_comm[branch]}" "r:${vcs_comm[revision]}"
VCS_INFO_formats '' "${svkbranch}" "${svkbase}"
VCS_INFO_formats '' "${svkbranch}" "${svkbase}" '' ''
return 0

View file

@ -24,5 +24,5 @@ svnbase="$(VCS_INFO_realpath ${svnbase})"
rrn=${svnbase:t}
zstyle -s ":vcs_info:${vcs}:${usercontext}:${rrn}" branchformat svnbranch || svnbranch="%b:%r"
zformat -f svnbranch "${svnbranch}" "b:${svninfo[URL]##*/}" "r:${svninfo[Revision]}"
VCS_INFO_formats '' "${svnbranch}" "${svnbase}"
VCS_INFO_formats '' "${svnbranch}" "${svnbase}" '' ''
return 0

View file

@ -9,5 +9,5 @@ tlabase="$(VCS_INFO_realpath ${vcs_comm[basedir]})"
rrn=${tlabase:t}
# tree-id gives us something like 'foo@example.com/demo--1.0--patch-4', so:
tlabranch=${${"$( ${vcs_comm[cmd]} tree-id )"}/*\//}
VCS_INFO_formats '' "${tlabranch}" "${tlabase}"
VCS_INFO_formats '' "${tlabranch}" "${tlabase}" '' ''
return 0

View file

@ -3,7 +3,7 @@
## Distributed under the same BSD-ish license as zsh itself.
setopt localoptions noksharrays NO_shwordsplit
local action=$1 branch=$2 base=$3
local action=$1 branch=$2 base=$3 staged=$4 unstaged=$5
local msg
local -i i j
@ -15,9 +15,27 @@ else
(( ${#msgs} < 1 )) && msgs[1]=' (%s)-[%b]-'
fi
if [[ -n ${staged} ]] ; then
zstyle -s ":vcs_info:${vcs}:${usercontext}:${rrn}" stagedstr staged
[[ -z ${staged} ]] && staged='S'
fi
if [[ -n ${unstaged} ]] ; then
zstyle -s ":vcs_info:${vcs}:${usercontext}:${rrn}" unstagedstr unstaged
[[ -z ${unstaged} ]] && unstaged='U'
fi
(( ${#msgs} > maxexports )) && msgs[$(( maxexports + 1 )),-1]=()
for i in {1..${#msgs}} ; do
zformat -f msg ${msgs[$i]} a:${action} b:${branch} s:${vcs} r:${base:t} R:${base} S:"$(VCS_INFO_reposub ${base})"
zformat -f msg ${msgs[$i]} \
a:${action} \
b:${branch} \
c:${staged} \
r:${base:t} \
s:${vcs} \
u:${unstaged} \
R:${base} \
S:"$(VCS_INFO_reposub ${base})"
msgs[$i]=${msg}
done
return 0