Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
[PATCH] Fix diff completion for non GNU / FreeBSD platforms
- X-seq: zsh-workers 51276
- From: Nathan Houghton <nathan@xxxxxxxxxxxxx>
- To: zsh-workers@xxxxxxx
- Cc: Nathan Houghton <nathan@xxxxxxxxxxxxx>
- Subject: [PATCH] Fix diff completion for non GNU / FreeBSD platforms
- Date: Wed, 4 Jan 2023 14:44:18 -0800
- Archived-at: <https://zsh.org/workers/51276>
- Feedback-id: ibb394747:Fastmail
- List-id: <zsh-workers.zsh.org>
On OpenBSD, "diff -urpN dir1/ di<TAB>" would refuse to complete a second
filename/directory name. This was caused by the -u and -U options
getting dropped from args (overwriting args vs appending).
In addition:
- Fully build up $of before utilizing it to avoid inconsistent
behavior in the treatment of mutually exclusive output formats.
- Remove the "-l" option for OpenBSD (this flag was removed in
2015).
- Mark the "-x" option as being repeatable on OpenBSD
---
Completion/Unix/Type/_diff_options | 41 +++++++++++++++++++-----------
1 file changed, 26 insertions(+), 15 deletions(-)
diff --git a/Completion/Unix/Type/_diff_options b/Completion/Unix/Type/_diff_options
index dfa9889f2..2646527df 100644
--- a/Completion/Unix/Type/_diff_options
+++ b/Completion/Unix/Type/_diff_options
@@ -133,33 +133,44 @@ else
case $OSTYPE in
openbsd*|solaris2.<9->)
of+=' -u -U'
+ ;|
+ openbsd*|solaris*)
+ of+=' -n -C -D'
+ ;|
+ solaris*)
+ of+=' -h'
+ ;|
+ openbsd*)
+ of+=' -q'
+ ;|
+ # modifications to "$of" should be done above this line so that it is
+ # uniformly defined while constructing $args
+ openbsd*|solaris2.<9->)
args+=(
- "($of)-u[output a unified diff]"
- "($of)-U+[output a unified diff]:lines of context"
+ "($of)-u[output a unified diff]"
+ "($of)-U+[output a unified diff]:lines of context"
)
;|
openbsd*|solaris*)
args+=(
- "($of)-C+[output a context diff]:lines of context"
- "($of)-D+[output merged file with preprocessor directives]:preprocessor symbol"
- '-i[case insensitive]'
- '-l[long output format (paginate with pr(1))]'
- '-s[report on identical files]'
- '-t[expand tabs in output lines]'
+ "($of)-C+[output a context diff]:lines of context"
+ "($of)-D+[output merged file with preprocessor directives]:preprocessor symbol"
+ '-i[case insensitive]'
+ '-s[report on identical files]'
+ '-t[expand tabs in output lines]'
)
;|
solaris*)
- of+=' -h -n'
args+=(
- '-w[ignore all white space]'
- "($of)-h[do a fast, half-hearted job]"
- "($of)-n[output a reversed ed script]"
+ '-w[ignore all white space]'
+ "($of)-h[do a fast, half-hearted job]"
+ "($of)-n[output a reversed ed script]"
'-S+[set first file in comparison]:start with file:_files'
+ '-l[long output format (paginate with pr(1))]'
)
;;
openbsd*)
- of+=' -n -q -u -C -D -U'
- args=(
+ args+=(
"($of)-n[output an rcsdiff(1)-compatible diff]"
"($of)-q[only print a line when the files differ; does not produce a list of changes]"
'-a[treat all files as ASCII text]'
@@ -173,7 +184,7 @@ else
'-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'
'*-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'
+ '*-x[exclude files and subdirectories whose basenames match a pattern]:pattern'
)
;;
esac
--
2.37.3
Messages sorted by:
Reverse Date,
Date,
Thread,
Author