summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--Completion/Unix/Type/_diff_options52
2 files changed, 47 insertions, 12 deletions
diff --git a/ChangeLog b/ChangeLog
index 8164236d2..86da9fccb 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,4 +1,9 @@
-2015-07-06 Oliver Kiddle <opk@zsh.org>
+2015-07-08 Oliver Kiddle <opk@zsh.org>
+
+ * Matthew Martin: 35727: Completion/Unix/Type/_diff_options:
+ support OpenBSD for diff options
+
+2015-07-07 Oliver Kiddle <opk@zsh.org>
* 35700: Completion/Unix/Type/_date_formats: complete OS specific
date format specifiers and put % in a prefix
diff --git a/Completion/Unix/Type/_diff_options b/Completion/Unix/Type/_diff_options
index d76c265ca..6af392a13 100644
--- a/Completion/Unix/Type/_diff_options
+++ b/Completion/Unix/Type/_diff_options
@@ -101,33 +101,63 @@ if _pick_variant -c $cmd gnu=GNU unix -v; then
'--help[display help info]' \
"$@"
else
+ of='-c -e -f'
case $OSTYPE in
solaris2.<9->)
+ of+=' -u -U'
args=(
- '(-c -e -f -C -U)-u[output a unified diff]'
- '(-c -e -f -C -u)-U[output a unified diff]:lines of context'
+ "($of)-u[output a unified diff]"
+ "($of)-U[output a unified diff]:lines of context"
)
;&
solaris*)
+ of+=' -C -h -n -D'
args+=(
'-i[case insensitive]'
'-t[expand tabs to spaces]'
'-w[ignore all white space]'
- '(-c -e -f -n -u -U -h -D)-C+[output a context diff]:lines of context'
- '(-c -e -f -n -u -U -C -D)-h[do a fast, half-hearted job]'
- '(-c -e -f -u -U -h -C -D)-n[reversed ed script]'
- '(-c -e -f -n -u -U -h -C)-D[output merged file with preprocessor directives]:preprocessor symbol'
+ "($of)-C+[output a context diff]:lines of context"
+ "($of)-h[do a fast, half-hearted job]"
+ "($of)-n[reversed ed script]"
+ "($of)-D[output merged file with preprocessor directives]:preprocessor symbol"
'-l[output through pr]'
'-s[report on identical files]'
'-S+[set first file in comparison]:start with file:_files'
)
;;
+ openbsd*)
+ of+=' -n -q -u -C -D -U'
+ args=(
+ "($of)-n[produce an rcsdiff(1)-compatible diff]"
+ "($of)-q[only print a line when the files differ; does not produce a list of changes]"
+ "($of)-u[produce a unified diff with 3 lines of context]"
+ "($of)-C+[produce a context diff]:number of lines of context"
+ "($of)-D[produce a merged file with preprocessor directives]:preprocessor symbol"
+ "($of)-U+[produce a unified diff]:number of lines of context"
+ '-a[treat all files as ASCII text]'
+ '-d[try to produce the smallest diff possible]'
+ '-I[ignore changes whose lines match the extended regular expression]:extended regular expression pattern'
+ '-i[ignore case]'
+ '*-L[print a label instead of the file name and time]:label'
+ '-l[long output format (paginate with pr(1))]'
+ '-p[show characters from the last line before the context]'
+ '-T[consistently align tabs]'
+ '-t[expand tabs in output lines]'
+ '-w[like -b, but totally ignore whitespace]'
+ '-N[treat absent files in either directory as if they were empty]'
+ '-P[treat absent files in the second directory as if they were empty]'
+ '-S[start a directory diff from a file name]:file name:_files'
+ '-s[report files that are the same]'
+ '*-X[exclude files and subdirectories whose basenames match lines in a file]:file name:_files'
+ '-x[exclude files and subdirectories whose basenames match a pattern]:pattern'
+ )
+ ;;
esac
-
- _arguments "$args[@]" \
- "(-e -f -u -n)-c[output a context diff]" \
- "(-c -f -u -n)-e[output an ed script]" \
- "(-c -e -u -n)-f[output a reversed ed script]" \
+
+ _arguments -s "$args[@]" \
+ "($of)-c[output a context diff]" \
+ "($of)-e[output an ed script]" \
+ "($of)-f[output a reversed ed script]" \
'-b[skip trailing white spaces]' \
'-r[recursively compare subdirectories]' \
"$@"