File: git-merge

package info (click to toggle)
yash 2.50-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 5,036 kB
  • sloc: ansic: 33,211; makefile: 839; sh: 477; sed: 16
file content (106 lines) | stat: -rw-r--r-- 3,428 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
# (C) 2011 magicant

# Completion script for the "git-merge" command.
# Supports Git 1.7.7.

function completion/git-merge {
	WORDS=(git merge "${WORDS[2,-1]}")
	command -f completion//reexecute
}

function completion/git::merge:arg {

	OPTIONS=( #>#
	"--abort; reset to the state before starting merge"
	"m:; specify the message"
	"--no-rerere-autoupdate; disable the rerere mechanism"
	"--rerere-autoupdate; enable the rerere mechanism"
	) #<#
	command -f completion/git::merge:getopt

	command -f completion//parseoptions
	case $ARGOPT in
		(-)
			command -f completion//completeoptions
			;;
		('')
			command -f completion/git::completeref
			;;
		(*)
			command -f completion/git::merge:compopt
			;;
	esac

}

function completion/git::merge:getopt {
	OPTIONS=("$OPTIONS" #>#
	"--commit; commit the merge result automatically"
	"--ff; fast-forward if possible"
	"--ff-only; allow fast-forward only"
	"--log::; specify the number of commits in the merged branch of which the messages are reused"
	"--no-commit; don't commit the merge result automatically"
	"--no-ff; don't fast-forward even if possible"
	"--no-log; don't reuse messages from the commits on the merged branch"
	"--no-progress; don't print progress info"
	"--no-squash; cancel the --squash option"
	"n --no-stat --no-summary; don't print a diffstat"
	"--progress; print progress info"
	"q --quiet; don't print anything"
	"--squash; like --no-commit, but don't set MERGE_HEAD"
	"--stat --summary; print a diffstat"
	"s: --strategy:; specify the merge strategy"
	"X: --strategy-option:; specify a strategy-specific option"
	"v --verbose" # TODO description
	) #<#
}

function completion/git::merge:compopt
	case $ARGOPT in
		(m|--log)
			;;
		(s|--strategy) #>>#
			complete -P "$PREFIX" -D "standard algorithm for merging more than 2 heads" octopus
			complete -P "$PREFIX" -D "simple algorithm that makes no change" ours
			complete -P "$PREFIX" -D "recursive 3-way merge" recursive
			complete -P "$PREFIX" -D "safe and fast 3-way merge" resolve
			complete -P "$PREFIX" -D "recursive 3-way merge with subtree matching" subtree
			;; #<<#
		(X|--strategy-option)
			typeset i=2 strategy=recursive
			while [ $i -le ${WORDS[#]} ]; do
				case ${WORDS[i]} in
					(-s*)
						strategy=${WORDS[i]#-s}
						;;
					(--strategy=*)
						strategy=${WORDS[i]#--strategy=}
						;;
					(--)
						break
						;;
				esac
				i=$((i+1))
			done
			case $strategy in
				(recursive) #>>#
					complete -P "$PREFIX" -D "resolve conflicts by discarding remote changes" ours
					complete -P "$PREFIX" -D "resolve conflicts by discarding local changes" theirs
					complete -P "$PREFIX" -D "use the patience diff algorithm" patience
					complete -P "$PREFIX" -D "discard conflicting changes of the number of spaces" ignore-space-change
					complete -P "$PREFIX" -D "discard conflicting changes of spaces" ignore-all-space
					complete -P "$PREFIX" -D "discard conflicting changes of spaces at end of line" ignore-space-at-eol
					complete -P "$PREFIX" -D "run hooks to obtain trees to merge" renormalize
					complete -P "$PREFIX" -D "don't run hooks to obtain trees to merge" no-renormalize
					complete -P "$PREFIX" -D "specify the threshold for detecting renames" -T rename-threshold=
					complete -P "$PREFIX" -D "match directory trees before merging" subtree
					;; #<<#
			esac
			;;
		(*)
			return 1
			;;
	esac


# vim: set ft=sh ts=8 sts=8 sw=8 noet: