1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-01-01 05:16:05 +01:00

48435 (tweaked): vcs_info docs: applied-string/unapplied-string: Correct an omission in the documentation and add an example.

The example code is a reduced version of my function from workers/47519,
with one bug fixed.  (In workers/47519, if $1 doesn't contain spaces -
which is the case under hg mq - then $H and $s will be set to the same
value.)

Tweaked: Extended the contrib.yo hunk with details about mq.
This commit is contained in:
Daniel Shahaf 2021-04-07 20:22:58 +00:00
parent c40a63ab67
commit b110d6d5af
3 changed files with 67 additions and 3 deletions

View file

@ -1,5 +1,9 @@
2021-04-20 Daniel Shahaf <d.s@daniel.shahaf.name>
* 48435 (tweaked): Doc/Zsh/contrib.yo, Misc/vcs_info-examples:
vcs_info docs: applied-string/unapplied-string: Correct an
omission in the documentation and add an example.
* 48528/0002: Misc/vcs_info-examples: vcs_info git docs:
ahead/behind commits: Reduce the number of forks

View file

@ -1652,10 +1652,17 @@ Called in the tt(git) (with tt(stgit) or during rebase or merge), and tt(hg)
is generated; the tt(use-quilt) zstyle must be true for tt(quilt) (the tt(mq)
and tt(stgit) backends are active by default).
This hook gets the names of all applied patches which tt(vcs_info) collected
so far in the opposite order, which means that the first argument is the
The arguments to this hook describe applied patches
in the opposite order, which means that the first argument is the
top-most patch and so forth.
When the patches' log messages can be extracted, those are embedded
within each argument after a space, so each argument is of the form
`var(patch-name) var(first line of the log message)', where var(patch-name)
contains no whitespace. The tt(mq) backend passes arguments of
the form `var(patch name)', with possible embedded spaces, but without
extracting the patch's log message.
When setting tt(ret) to non-zero, the string in
tt(${hook_com[applied-string]}) will be
available as tt(%p) in the tt(patch-format) and tt(nopatch-format) styles.
@ -1669,9 +1676,11 @@ tt(mq)) backend and in tt(quilt) support when the tt(unapplied-string) is
generated; the tt(get-unapplied) style must be true.
This hook gets the names of all unapplied patches which tt(vcs_info)
collected so far in order, which means that the first argument is
in order, which means that the first argument is
the patch next-in-line to be applied and so forth.
The format of each argument is as for tt(gen-applied-string), above.
When setting tt(ret) to non-zero, the string in
tt(${hook_com[unapplied-string]}) will be available as tt(%u) in the
tt(patch-format) and tt(nopatch-format) styles.

View file

@ -285,6 +285,54 @@ function +vi-hg-branchhead() {
}
### Show information about patch series
# This is used with with hg mq, quilt, and git rebases and conflicts.
#
# All these cases have a notion of a "series of patches/commits" that is being
# applied. The following shows the information about the most recent patch to
# have been applied:
zstyle ':vcs_info:*+gen-applied-string:*' hooks gen-applied-string
function +vi-gen-applied-string() {
# Separate the patch id from the patch log message.
if [[ $1 == *\ * ]]; then
local patch_name_or_filename="${1%% *}"
local patch_description="${1#* }"
else
local patch_name_or_filename="$1"
local patch_description=""
fi
# Apply escaping; see `Oddities' in the manual.
patch_name_or_filename=${patch_name_or_filename//'%'/%%}
patch_description=${patch_description//'%'/%%}
# Apply different colouring to the patch description.
if [[ -n ${patch_description} ]]; then
patch_description="%F{yellow}${patch_description}%f"
fi
# Re-assemble $1, escaped and coloured.
hook_com[applied-string]="${patch_name_or_filename} ${patch_description}"
ret=1
}
# The value of hook_com[applied-string] is incorporated into the %m expando
# (see the 'patch-format' style for details), which is not included in the
# 'formats' and 'actionformats' style by default, so to actually use this,
# you'll need to add %m (or %Q under quilt in add-on mode) to your 'formats'
# and 'actionformats' styles, as in:
#
# zstyle ':vcs_info:*' actionformats ' (%s)-[%b|%a]%u%c- %m'
# zstyle ':vcs_info:*' formats ' (%s)-[%b]%u%c- %m'
#
# Or you could add it as a new word, as in:
#
# zstyle ':vcs_info:*' actionformats ' (%s)-[%b|%a]%u%c-' '%m'
# zstyle ':vcs_info:*' formats ' (%s)-[%b]%u%c-' '%m'
#
# In the latter case, you will need to arrange to print ${vcs_info_msg_1_} in
# addition to ${vcs_info_msg_0_}; see the top of this file for details.
### Run vcs_info selectively to increase speed in large repos ################
# The following example shows a possible setup for vcs_info which displays
@ -547,6 +595,9 @@ function +vi-set-quilt-patches() {
# This would take care of all the dedicated-patches-directory-in-${HOME}
# from earlier examples, too.
# Finally, the "Show information about patch series" example above this section
# may also be useful.
### Using vcs_info from CVS ##################################################