Merge branch 'dm/completion-remote-names-fix' into next
The bash command line completion script (in contrib/) has been updated to cope with remote repository nicknames with slashes in them. * dm/completion-remote-names-fix: completion: fix bugs with slashes in remote names completion: add helper to count path componentsnext
commit
b9460e20ae
contrib/completion
|
@ -234,6 +234,17 @@ __git_dequote ()
|
|||
done
|
||||
}
|
||||
|
||||
# Prints the number of slash-separated components in a path.
|
||||
# 1: Path to count components of.
|
||||
__git_count_path_components ()
|
||||
{
|
||||
local path="$1"
|
||||
local relative="${path#/}"
|
||||
relative="${relative%/}"
|
||||
local slashes="/${relative//[^\/]}"
|
||||
echo "${#slashes}"
|
||||
}
|
||||
|
||||
# The following function is based on code from:
|
||||
#
|
||||
# bash_completion - programmable completion functions for bash 3.2+
|
||||
|
@ -779,16 +790,39 @@ __git_tags ()
|
|||
__git_dwim_remote_heads ()
|
||||
{
|
||||
local pfx="${1-}" cur_="${2-}" sfx="${3-}"
|
||||
local fer_pfx="${pfx//\%/%%}" # "escape" for-each-ref format specifiers
|
||||
|
||||
# employ the heuristic used by git checkout and git switch
|
||||
# Try to find a remote branch that cur_es the completion word
|
||||
# but only output if the branch name is unique
|
||||
__git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \
|
||||
--sort="refname:strip=3" \
|
||||
${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \
|
||||
"refs/remotes/*/$cur_*" "refs/remotes/*/$cur_*/**" | \
|
||||
uniq -u
|
||||
local awk_script='
|
||||
function casemap(s) {
|
||||
if (ENVIRON["IGNORE_CASE"])
|
||||
return tolower(s)
|
||||
else
|
||||
return s
|
||||
}
|
||||
BEGIN {
|
||||
split(ENVIRON["REMOTES"], remotes, /\n/)
|
||||
for (i in remotes)
|
||||
remotes[i] = "refs/remotes/" casemap(remotes[i])
|
||||
cur_ = casemap(ENVIRON["CUR_"])
|
||||
}
|
||||
{
|
||||
ref_case = casemap($0)
|
||||
for (i in remotes) {
|
||||
if (index(ref_case, remotes[i] "/" cur_) == 1) {
|
||||
branch = substr($0, length(remotes[i] "/") + 1)
|
||||
print ENVIRON["PFX"] branch ENVIRON["SFX"]
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
'
|
||||
__git for-each-ref --format='%(refname)' refs/remotes/ |
|
||||
PFX="$pfx" SFX="$sfx" CUR_="$cur_" \
|
||||
IGNORE_CASE=${GIT_COMPLETION_IGNORE_CASE+1} \
|
||||
REMOTES="$(__git_remotes | sort -r)" awk "$awk_script" |
|
||||
sort | uniq -u
|
||||
}
|
||||
|
||||
# Lists refs from the local (by default) or from a remote repository.
|
||||
|
@ -894,7 +928,8 @@ __git_refs ()
|
|||
case "HEAD" in
|
||||
$match*|$umatch*) echo "${pfx}HEAD$sfx" ;;
|
||||
esac
|
||||
__git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \
|
||||
local strip="$(__git_count_path_components "refs/remotes/$remote")"
|
||||
__git for-each-ref --format="$fer_pfx%(refname:strip=$strip)$sfx" \
|
||||
${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \
|
||||
"refs/remotes/$remote/$match*" \
|
||||
"refs/remotes/$remote/$match*/**"
|
||||
|
|
|
@ -149,7 +149,8 @@ fi
|
|||
test_expect_success 'setup for __git_find_repo_path/__gitdir tests' '
|
||||
mkdir -p subdir/subsubdir &&
|
||||
mkdir -p non-repo &&
|
||||
git init -b main otherrepo
|
||||
git init -b main otherrepo &&
|
||||
git init -b main slashrepo
|
||||
'
|
||||
|
||||
test_expect_success '__git_find_repo_path - from command line (through $__git_dir)' '
|
||||
|
@ -455,6 +456,32 @@ test_expect_success '__git_dequote - open double quote' '
|
|||
'
|
||||
|
||||
|
||||
test_expect_success '__git_count_path_components - no slashes' '
|
||||
echo 1 >expected &&
|
||||
__git_count_path_components a >"$actual" &&
|
||||
test_cmp expected "$actual"
|
||||
'
|
||||
|
||||
test_expect_success '__git_count_path_components - relative' '
|
||||
echo 3 >expected &&
|
||||
__git_count_path_components a/b/c >"$actual" &&
|
||||
test_cmp expected "$actual"
|
||||
|
||||
'
|
||||
|
||||
test_expect_success '__git_count_path_components - absolute' '
|
||||
echo 3 >expected &&
|
||||
__git_count_path_components /a/b/c >"$actual" &&
|
||||
test_cmp expected "$actual"
|
||||
'
|
||||
|
||||
test_expect_success '__git_count_path_components - trailing slash' '
|
||||
echo 3 >expected &&
|
||||
__git_count_path_components a/b/c/ >"$actual" &&
|
||||
test_cmp expected "$actual"
|
||||
'
|
||||
|
||||
|
||||
test_expect_success '__gitcomp_direct - puts everything into COMPREPLY as-is' '
|
||||
sed -e "s/Z$//g" >expected <<-EOF &&
|
||||
with-trailing-space Z
|
||||
|
@ -648,6 +675,13 @@ test_expect_success 'setup for ref completion' '
|
|||
) &&
|
||||
git remote add other "$ROOT/otherrepo/.git" &&
|
||||
git fetch --no-tags other &&
|
||||
(
|
||||
cd slashrepo &&
|
||||
git commit --allow-empty -m initial &&
|
||||
git branch -m main branch/with/slash
|
||||
) &&
|
||||
git remote add remote/with/slash "$ROOT/slashrepo/.git" &&
|
||||
git fetch --no-tags remote/with/slash &&
|
||||
rm -f .git/FETCH_HEAD &&
|
||||
git init thirdrepo
|
||||
'
|
||||
|
@ -660,6 +694,8 @@ test_expect_success '__git_refs - simple' '
|
|||
other/HEAD
|
||||
other/branch-in-other
|
||||
other/main-in-other
|
||||
remote/with/slash/HEAD
|
||||
remote/with/slash/branch/with/slash
|
||||
matching-tag
|
||||
EOF
|
||||
(
|
||||
|
@ -676,6 +712,8 @@ test_expect_success '__git_refs - full refs' '
|
|||
refs/remotes/other/HEAD
|
||||
refs/remotes/other/branch-in-other
|
||||
refs/remotes/other/main-in-other
|
||||
refs/remotes/remote/with/slash/HEAD
|
||||
refs/remotes/remote/with/slash/branch/with/slash
|
||||
refs/tags/matching-tag
|
||||
EOF
|
||||
(
|
||||
|
@ -741,6 +779,19 @@ test_expect_success '__git_refs - configured remote' '
|
|||
test_cmp expected "$actual"
|
||||
'
|
||||
|
||||
test_expect_success '__git_refs - configured remote - with slash' '
|
||||
cat >expected <<-EOF &&
|
||||
HEAD
|
||||
HEAD
|
||||
branch/with/slash
|
||||
EOF
|
||||
(
|
||||
cur= &&
|
||||
__git_refs remote/with/slash >"$actual"
|
||||
) &&
|
||||
test_cmp expected "$actual"
|
||||
'
|
||||
|
||||
test_expect_success '__git_refs - configured remote - full refs' '
|
||||
cat >expected <<-EOF &&
|
||||
HEAD
|
||||
|
@ -883,17 +934,19 @@ test_expect_success '__git_refs - unique remote branches for git checkout DWIMer
|
|||
other/ambiguous
|
||||
other/branch-in-other
|
||||
other/main-in-other
|
||||
remote/ambiguous
|
||||
remote/branch-in-remote
|
||||
remote/with/slash/HEAD
|
||||
remote/with/slash/ambiguous
|
||||
remote/with/slash/branch-in-remote
|
||||
remote/with/slash/branch/with/slash
|
||||
matching-tag
|
||||
HEAD
|
||||
branch-in-other
|
||||
branch-in-remote
|
||||
branch/with/slash
|
||||
main-in-other
|
||||
EOF
|
||||
for remote_ref in refs/remotes/other/ambiguous \
|
||||
refs/remotes/remote/ambiguous \
|
||||
refs/remotes/remote/branch-in-remote
|
||||
refs/remotes/remote/with/slash/ambiguous \
|
||||
refs/remotes/remote/with/slash/branch-in-remote
|
||||
do
|
||||
git update-ref $remote_ref main &&
|
||||
test_when_finished "git update-ref -d $remote_ref" || return 1
|
||||
|
@ -913,6 +966,8 @@ test_expect_success '__git_refs - after --opt=' '
|
|||
other/HEAD
|
||||
other/branch-in-other
|
||||
other/main-in-other
|
||||
remote/with/slash/HEAD
|
||||
remote/with/slash/branch/with/slash
|
||||
matching-tag
|
||||
EOF
|
||||
(
|
||||
|
@ -929,6 +984,8 @@ test_expect_success '__git_refs - after --opt= - full refs' '
|
|||
refs/remotes/other/HEAD
|
||||
refs/remotes/other/branch-in-other
|
||||
refs/remotes/other/main-in-other
|
||||
refs/remotes/remote/with/slash/HEAD
|
||||
refs/remotes/remote/with/slash/branch/with/slash
|
||||
refs/tags/matching-tag
|
||||
EOF
|
||||
(
|
||||
|
@ -946,6 +1003,8 @@ test_expect_success '__git refs - excluding refs' '
|
|||
^other/HEAD
|
||||
^other/branch-in-other
|
||||
^other/main-in-other
|
||||
^remote/with/slash/HEAD
|
||||
^remote/with/slash/branch/with/slash
|
||||
^matching-tag
|
||||
EOF
|
||||
(
|
||||
|
@ -962,6 +1021,8 @@ test_expect_success '__git refs - excluding full refs' '
|
|||
^refs/remotes/other/HEAD
|
||||
^refs/remotes/other/branch-in-other
|
||||
^refs/remotes/other/main-in-other
|
||||
^refs/remotes/remote/with/slash/HEAD
|
||||
^refs/remotes/remote/with/slash/branch/with/slash
|
||||
^refs/tags/matching-tag
|
||||
EOF
|
||||
(
|
||||
|
@ -989,6 +1050,8 @@ test_expect_success '__git_refs - do not filter refs unless told so' '
|
|||
other/branch-in-other
|
||||
other/main-in-other
|
||||
other/matching/branch-in-other
|
||||
remote/with/slash/HEAD
|
||||
remote/with/slash/branch/with/slash
|
||||
matching-tag
|
||||
matching/tag
|
||||
EOF
|
||||
|
@ -1109,6 +1172,8 @@ test_expect_success '__git_complete_refs - simple' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
matching-tag Z
|
||||
EOF
|
||||
(
|
||||
|
@ -1147,6 +1212,20 @@ test_expect_success '__git_complete_refs - remote' '
|
|||
test_cmp expected out
|
||||
'
|
||||
|
||||
test_expect_success '__git_complete_refs - remote - with slash' '
|
||||
sed -e "s/Z$//" >expected <<-EOF &&
|
||||
HEAD Z
|
||||
HEAD Z
|
||||
branch/with/slash Z
|
||||
EOF
|
||||
(
|
||||
cur= &&
|
||||
__git_complete_refs --remote=remote/with/slash &&
|
||||
print_comp
|
||||
) &&
|
||||
test_cmp expected out
|
||||
'
|
||||
|
||||
test_expect_success '__git_complete_refs - track' '
|
||||
sed -e "s/Z$//" >expected <<-EOF &&
|
||||
HEAD Z
|
||||
|
@ -1155,9 +1234,11 @@ test_expect_success '__git_complete_refs - track' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
matching-tag Z
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main-in-other Z
|
||||
EOF
|
||||
(
|
||||
|
@ -1202,6 +1283,8 @@ test_expect_success '__git_complete_refs - suffix' '
|
|||
other/HEAD.
|
||||
other/branch-in-other.
|
||||
other/main-in-other.
|
||||
remote/with/slash/HEAD.
|
||||
remote/with/slash/branch/with/slash.
|
||||
matching-tag.
|
||||
EOF
|
||||
(
|
||||
|
@ -1227,6 +1310,20 @@ test_expect_success '__git_complete_fetch_refspecs - simple' '
|
|||
test_cmp expected out
|
||||
'
|
||||
|
||||
test_expect_success '__git_complete_fetch_refspecs - with slash' '
|
||||
sed -e "s/Z$//" >expected <<-EOF &&
|
||||
HEAD:HEAD Z
|
||||
HEAD:HEAD Z
|
||||
branch/with/slash:branch/with/slash Z
|
||||
EOF
|
||||
(
|
||||
cur= &&
|
||||
__git_complete_fetch_refspecs remote/with/slash &&
|
||||
print_comp
|
||||
) &&
|
||||
test_cmp expected out
|
||||
'
|
||||
|
||||
test_expect_success '__git_complete_fetch_refspecs - matching' '
|
||||
sed -e "s/Z$//" >expected <<-EOF &&
|
||||
branch-in-other:branch-in-other Z
|
||||
|
@ -1307,8 +1404,8 @@ test_expect_success '__git_complete_worktree_paths with -C' '
|
|||
|
||||
test_expect_success 'git switch - with no options, complete local branches and unique remote branch names for DWIM logic' '
|
||||
test_completion "git switch " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1454,8 +1551,8 @@ test_expect_success 'git-bisect - existing view subcommand is recognized and ena
|
|||
test_expect_success 'git checkout - completes refs and unique remote branches for DWIM' '
|
||||
test_completion "git checkout " <<-\EOF
|
||||
HEAD Z
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1463,6 +1560,8 @@ test_expect_success 'git checkout - completes refs and unique remote branches fo
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1482,8 +1581,8 @@ test_expect_success 'git switch - with GIT_COMPLETION_CHECKOUT_NO_GUESS=1, compl
|
|||
|
||||
test_expect_success 'git switch - --guess overrides GIT_COMPLETION_CHECKOUT_NO_GUESS=1, complete local branches and unique remote names for DWIM logic' '
|
||||
GIT_COMPLETION_CHECKOUT_NO_GUESS=1 test_completion "git switch --guess " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1492,8 +1591,8 @@ test_expect_success 'git switch - --guess overrides GIT_COMPLETION_CHECKOUT_NO_G
|
|||
|
||||
test_expect_success 'git switch - a later --guess overrides previous --no-guess, complete local and remote unique branches for DWIM' '
|
||||
test_completion "git switch --no-guess --guess " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1516,14 +1615,16 @@ test_expect_success 'git checkout - with GIT_COMPLETION_NO_GUESS=1 only complete
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success 'git checkout - --guess overrides GIT_COMPLETION_NO_GUESS=1, complete refs and unique remote branches for DWIM' '
|
||||
GIT_COMPLETION_CHECKOUT_NO_GUESS=1 test_completion "git checkout --guess " <<-\EOF
|
||||
HEAD Z
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1531,6 +1632,8 @@ test_expect_success 'git checkout - --guess overrides GIT_COMPLETION_NO_GUESS=1,
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1543,14 +1646,16 @@ test_expect_success 'git checkout - with --no-guess, only completes refs' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success 'git checkout - a later --guess overrides previous --no-guess, complete refs and unique remote branches for DWIM' '
|
||||
test_completion "git checkout --no-guess --guess " <<-\EOF
|
||||
HEAD Z
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1558,6 +1663,8 @@ test_expect_success 'git checkout - a later --guess overrides previous --no-gues
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1570,6 +1677,8 @@ test_expect_success 'git checkout - a later --no-guess overrides previous --gues
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1583,6 +1692,8 @@ test_expect_success 'git checkout - with checkout.guess = false, only completes
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1590,8 +1701,8 @@ test_expect_success 'git checkout - with checkout.guess = true, completes refs a
|
|||
test_config checkout.guess true &&
|
||||
test_completion "git checkout " <<-\EOF
|
||||
HEAD Z
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1599,6 +1710,8 @@ test_expect_success 'git checkout - with checkout.guess = true, completes refs a
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1606,8 +1719,8 @@ test_expect_success 'git checkout - a later --guess overrides previous checkout.
|
|||
test_config checkout.guess false &&
|
||||
test_completion "git checkout --guess " <<-\EOF
|
||||
HEAD Z
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -1615,6 +1728,8 @@ test_expect_success 'git checkout - a later --guess overrides previous checkout.
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1628,6 +1743,8 @@ test_expect_success 'git checkout - a later --no-guess overrides previous checko
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1640,6 +1757,8 @@ test_expect_success 'git switch - with --detach, complete all references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1652,6 +1771,8 @@ test_expect_success 'git checkout - with --detach, complete only references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1824,6 +1945,8 @@ test_expect_success 'git switch - with -d, complete all references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1836,6 +1959,8 @@ test_expect_success 'git checkout - with -d, complete only references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1844,11 +1969,15 @@ test_expect_success 'git switch - with --track, complete only remote branches' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
test_completion "git switch -t " <<-\EOF
|
||||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1857,11 +1986,15 @@ test_expect_success 'git checkout - with --track, complete only remote branches'
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
test_completion "git checkout -t " <<-\EOF
|
||||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1881,6 +2014,8 @@ test_expect_success 'git checkout - with --no-track, complete only local referen
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1893,6 +2028,8 @@ test_expect_success 'git switch - with -c, complete all references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1905,6 +2042,8 @@ test_expect_success 'git switch - with -C, complete all references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1917,6 +2056,8 @@ test_expect_success 'git switch - with -c and --track, complete all references'
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1929,6 +2070,8 @@ test_expect_success 'git switch - with -C and --track, complete all references'
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1941,6 +2084,8 @@ test_expect_success 'git switch - with -c and --no-track, complete all reference
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1953,6 +2098,8 @@ test_expect_success 'git switch - with -C and --no-track, complete all reference
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1965,6 +2112,8 @@ test_expect_success 'git checkout - with -b, complete all references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1977,6 +2126,8 @@ test_expect_success 'git checkout - with -B, complete all references' '
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -1989,6 +2140,8 @@ test_expect_success 'git checkout - with -b and --track, complete all references
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -2001,6 +2154,8 @@ test_expect_success 'git checkout - with -B and --track, complete all references
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -2013,6 +2168,8 @@ test_expect_success 'git checkout - with -b and --no-track, complete all referen
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -2025,13 +2182,15 @@ test_expect_success 'git checkout - with -B and --no-track, complete all referen
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
test_expect_success 'git switch - for -c, complete local branches and unique remote branches' '
|
||||
test_completion "git switch -c " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -2040,8 +2199,8 @@ test_expect_success 'git switch - for -c, complete local branches and unique rem
|
|||
|
||||
test_expect_success 'git switch - for -C, complete local branches and unique remote branches' '
|
||||
test_completion "git switch -C " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -2078,8 +2237,8 @@ test_expect_success 'git switch - for -C with --no-track, complete local branche
|
|||
|
||||
test_expect_success 'git checkout - for -b, complete local branches and unique remote branches' '
|
||||
test_completion "git checkout -b " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -2088,8 +2247,8 @@ test_expect_success 'git checkout - for -b, complete local branches and unique r
|
|||
|
||||
test_expect_success 'git checkout - for -B, complete local branches and unique remote branches' '
|
||||
test_completion "git checkout -B " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -2126,8 +2285,8 @@ test_expect_success 'git checkout - for -B with --no-track, complete local branc
|
|||
|
||||
test_expect_success 'git switch - with --orphan completes local branch names and unique remote branch names' '
|
||||
test_completion "git switch --orphan " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -2142,8 +2301,8 @@ test_expect_success 'git switch - --orphan with branch already provided complete
|
|||
|
||||
test_expect_success 'git checkout - with --orphan completes local branch names and unique remote branch names' '
|
||||
test_completion "git checkout --orphan " <<-\EOF
|
||||
HEAD Z
|
||||
branch-in-other Z
|
||||
branch/with/slash Z
|
||||
main Z
|
||||
main-in-other Z
|
||||
matching-branch Z
|
||||
|
@ -2159,6 +2318,8 @@ test_expect_success 'git checkout - --orphan with branch already provided comple
|
|||
other/HEAD Z
|
||||
other/branch-in-other Z
|
||||
other/main-in-other Z
|
||||
remote/with/slash/HEAD Z
|
||||
remote/with/slash/branch/with/slash Z
|
||||
EOF
|
||||
'
|
||||
|
||||
|
@ -2173,7 +2334,8 @@ test_expect_success 'git restore completes modified files' '
|
|||
test_expect_success 'teardown after ref completion' '
|
||||
git branch -d matching-branch &&
|
||||
git tag -d matching-tag &&
|
||||
git remote remove other
|
||||
git remote remove other &&
|
||||
git remote remove remote/with/slash
|
||||
'
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue