summaryrefslogtreecommitdiff
path: root/Completion/Unix
diff options
context:
space:
mode:
authorAxel Beckert <abe@deuxchevaux.org>2019-02-04 13:17:38 +0100
committerAxel Beckert <abe@deuxchevaux.org>2019-02-04 13:17:38 +0100
commitea17cf89d7680e1ceb19f80d3a6401cb07d1ee4f (patch)
tree5b5b623b3b51346b32711f24010fb1fd1e33f6ac /Completion/Unix
parent14d262602341f1a2d69aa9149a331d047851ef55 (diff)
parent8b89d0d57710d044e85591aac25952f5a6ae84c7 (diff)
downloadzsh-ea17cf89d7680e1ceb19f80d3a6401cb07d1ee4f.tar.gz
zsh-ea17cf89d7680e1ceb19f80d3a6401cb07d1ee4f.zip
New upstream bugfix release 5.7.1
Merge branch 'upstream' at 'zsh-5.7.1' into 'debian'.
Diffstat (limited to 'Completion/Unix')
-rw-r--r--Completion/Unix/Command/_dos2unix129
-rw-r--r--Completion/Unix/Command/_git2
-rw-r--r--Completion/Unix/Type/_date_formats19
3 files changed, 142 insertions, 8 deletions
diff --git a/Completion/Unix/Command/_dos2unix b/Completion/Unix/Command/_dos2unix
new file mode 100644
index 000000000..c7820a8ec
--- /dev/null
+++ b/Completion/Unix/Command/_dos2unix
@@ -0,0 +1,129 @@
+#compdef dos2unix unix2dos mac2unix unix2mac
+
+local variant ret=1
+local -a context expl line state state_descr cp_opts xl_opts args
+local -A opt_args
+
+# Code-page options for ISO translation (use group `cp`)
+cp_opts=(
+ '(-7 -ascii)-437[use DOS code page 437 (US) for ISO translation]'
+ '(-7 -ascii)-850[use DOS code page 850 (Western European) for ISO translation]'
+ '(-7 -ascii)-860[use DOS code page 860 (Portuguese) for ISO translation]'
+ '(-7 -ascii)-863[use DOS code page 863 (French Canadian) for ISO translation]'
+ '(-7 -ascii)-865[use DOS code page 865 (Nordic) for ISO translation]'
+
+ '(-7 -ascii)-1252[use Windows code page 1252 (Western European) for ISO translation]'
+)
+# Translation/conversion options (use group `xl`)
+xl_opts=(
+ '(cp)-7[also replace 8-bit characters by 7-bit spaces]'
+ '(cp)-ascii[convert only line breaks (CRLF<->LF)]'
+ '-iso[also convert between DOS and ISO character sets]'
+
+ {-c,--convmode}'[specify conversion mode]:conversion mode:((
+ 7bit\:"also replace 8-bit characters by 7-bit spaces"
+ ascii\:"convert only line breaks (CRLF<->LF)"
+ iso\:"also convert between DOS and ISO character sets"
+ mac\:"convert only line breaks (CR<->LF)"
+ ))'
+ {-ub,--assume-utf16be}'[assume input file format is UTF-16BE]'
+ {-ul,--assume-utf16le}'[assume input file format is UTF-16LE]'
+)
+
+# `dos2unix` here is the dos2unix package provided by many Linux distributions,
+# Homebrew, &al. `unix2dos` is the unix2dos package provided by FreeBSD, &al.
+# Some implementations (Solaris) don't bother with any kind of argument
+# validation, so we pass in /dev/null to make sure they never hang
+_pick_variant -r variant \
+ dos2unix='(#i)waterlan' \
+ unix2dos='-p' \
+ $OSTYPE \
+ --version /dev/null{,}
+
+case $variant in
+ dos2unix)
+ # -D and -gb are omitted, since they only make sense on Windows
+ args=(
+ '(: * -)'{-h,--help}'[display help information]'
+ '(: * -)'{-L,--license}'[display license information]'
+ '(: * -)'{-V,--version}'[display version information]'
+ '(-l --newline)'{-l,--newline}'[write two line breaks to output for each converted line break]'
+ '(-u --keep-utf16)'{-u,--keep-utf16}'[write output in same UTF-16 encoding as input]'
+ '*:: :->file'
+ + '(qv)' # Verbosity options
+ {-q,--quiet}'[reduce output verbosity]'
+ {-v,--verbose}'[increase output verbosity]'
+ + '(cp)' # Code-page options
+ $cp_opts
+ + '(xl)' # Translation/conversion options
+ $xl_opts
+ + bm # BOM options
+ '(-b -r --keep-bom --remove-bom)'{-b,--keep-bom}'[write existing BOM to output]'
+ '(-m -r --add-bom --remove-bom)'{-m,--add-bom}'[write new BOM to output]'
+ '(bm)'{-r,--remove-bom}"[don't write BOM to output]"
+ + '(ch)' # chown options
+ '--allow-chown[allow file-ownership changes in old-file mode]'
+ "--no-allow-chown[don't allow file-ownership changes in old-file mode]"
+ + '(fs)' # Force/safe options
+ {-f,--force}'[force conversion of binary files]'
+ {-s,--safe}'[skip binary files]'
+ + '(in)' # Info options
+ {-i-,--info=-}'[display (specified) file information]:: :->info'
+ + '(ln)' # Symlink options
+ {-F,--follow-symlink}'[follow symbolic links]'
+ {-R,--replace-symlink}'[replace symbolic links]'
+ {-S,--skip-symlink}'[skip symbolic links]'
+ + '(no)' # File-mode options
+ {-n,--newfile}'[convert each input file to specified output file]'
+ {-o,--oldfile}'[convert input files in place]'
+ )
+ # No stacking!
+ _arguments -S -A '-*' : $args && ret=0
+
+ case $state in
+ file)
+ if (( CURRENT % 2 == 0 )) && [[ -n ${opt_args[(I)*-(-n|--newfile)]} ]]; then
+ _description files expl 'output file'
+ else
+ _description files expl 'input file'
+ fi
+ _files "${(@)expl}" && ret=0
+ ;;
+ info)
+ _values -s '' 'information flag [dumbt]' \
+ '0[end each output line with NUL instead of newline]' \
+ 'b[show BOM type]' \
+ 'c[show only files that would be converted]' \
+ 'd[show number of DOS line breaks (CRLF)]' \
+ 'h[show header]' \
+ 'm[show number of Mac line breaks (CR)]' \
+ 'p[show file names without paths]' \
+ 't[show whether file is text or binary]' \
+ 'u[show number of UNIX line breaks (LF)]' \
+ && ret=0
+ ;;
+ esac
+
+ return ret
+ ;;
+ unix2dos)
+ _arguments -s -S -A '-*' : \
+ '-p[preserve access and modification times]' \
+ '*:input file:_files'
+ return
+ ;;
+ solaris*)
+ _arguments -A '-*' : \
+ '1:input file:_files' \
+ '2:output file:_files' \
+ + '(cp)' \
+ ${(@M)cp_opts:#(|\([^\)]#\))-(437|850|860|863|865)(|\[*)} \
+ + '(xl)' \
+ ${(@M)xl_opts:#(|\([^\)]#\))-(7|ascii|iso)(|\[*)}
+ return
+ ;;
+ *)
+ _default
+ return
+ ;;
+esac
diff --git a/Completion/Unix/Command/_git b/Completion/Unix/Command/_git
index 0ebbbe861..b3e54f7f9 100644
--- a/Completion/Unix/Command/_git
+++ b/Completion/Unix/Command/_git
@@ -2049,7 +2049,7 @@ _git-tag () {
'(-i --ignore-case)'{-i,--ignore-case}'[sorting and filtering are case-insensitive]' \
':: :_guard "^-*" pattern' \
- verification \
- '(-v --verify)'{-v,--verify}'[verify gpg signutare of tags]' \
+ '(-v --verify)'{-v,--verify}'[verify gpg signature of tags]' \
'*:: :__git_ignore_line_inside_arguments __git_tags'
}
diff --git a/Completion/Unix/Type/_date_formats b/Completion/Unix/Type/_date_formats
index 6bd5c6d6b..889a95779 100644
--- a/Completion/Unix/Type/_date_formats
+++ b/Completion/Unix/Type/_date_formats
@@ -24,7 +24,7 @@ specs=(
'c:preferred locale date and time'
'C:2-digit century'
'd:day of month (01-31)'
- 'D:american format month/day/year (%m/%d/%y)'
+ 'D:American format month/day/year (%m/%d/%y)'
'e:day of month ( 1-31)'
'F:ISO 8601 year-month-date (%Y-%m-%d)'
'G:4-digit ISO 8601 week-based year'
@@ -44,21 +44,25 @@ specs=(
'S:seconds (00-60)'
't:tab'
'T:24-hour notation with seconds (%H:%M:%S)'
- 'u:day of week (1-7, 1=monday)'
- 'U:week number of current year, sunday based (00-53)'
+ 'u:day of week (1-7, 1=Monday)'
+ 'U:week number of current year, Sunday based (00-53)'
'V:ISO 8601 week number of current year, week 1 has 4 days in current year (01-53)'
- 'w:day of week (0-6, 0=sunday)'
- 'W:week number of current year, monday based (00-53)'
+ 'w:day of week (0-6, 0=Sunday)'
+ 'W:week number of current year, Monday based (00-53)'
'x:locale dependent date representation without time'
'X:locale dependent time representation without date'
'y:2-digit year (00-99)'
'Y:full year'
'z:UTC offset'
'Z:timezone name'
- '%:A %'
+ '%:literal %'
)
case $OSTYPE in
+ linux-gnu)
+ [[ $1 == zsh ]] || # %N is handled below in this case
+ specs+=( 'N:fractional part of seconds since epoch, in nanoseconds' )
+ ;|
freebsd*|dragonfly*|darwin*|linux-gnu|solaris2.<11->)
specs+=(
'E:alternate representation'
@@ -91,6 +95,7 @@ if [[ $1 == zsh ]]; then
'f:day of month (1-31)'
'K:hour (0-23)'
'L:hour (0-12)'
+ 'N:fractional part of seconds since epoch, in nanoseconds (%9.)'
'.:fractional part of seconds since epoch'
"-:don't pad numeric values"
)
@@ -102,4 +107,4 @@ done
_describe -t date-format-specifier 'date format specifier' specs \
-p "${(Q)PREFIX:-%}" -S ''
-[[ $1 == zsh ]] && _message -e date-format-precision 'precision for %%. (1-6)'
+[[ $1 == zsh ]] && _message -e date-format-precision 'precision for %%. (1-9)'