diff options
author | Paul Ackersviller <packersv@users.sourceforge.net> | 2007-11-05 01:59:42 +0000 |
---|---|---|
committer | Paul Ackersviller <packersv@users.sourceforge.net> | 2007-11-05 01:59:42 +0000 |
commit | e6a78cc112e727eec71ce8dc9a16f40189ef8ca0 (patch) | |
tree | cfd84b9386d275afef01a5f40cbbeb1bd4ac695d /Completion/Base | |
parent | c450d7eb1e1656b15ff91622a320f0072fe6a178 (diff) | |
download | zsh-e6a78cc112e727eec71ce8dc9a16f40189ef8ca0.tar.gz zsh-e6a78cc112e727eec71ce8dc9a16f40189ef8ca0.tar.xz zsh-e6a78cc112e727eec71ce8dc9a16f40189ef8ca0.zip |
Merge of 22953: didn't work if file started with a hyphen.
Diffstat (limited to 'Completion/Base')
-rw-r--r-- | Completion/Base/Widget/_most_recent_file | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/Completion/Base/Widget/_most_recent_file b/Completion/Base/Widget/_most_recent_file new file mode 100644 index 000000000..68d1c91a2 --- /dev/null +++ b/Completion/Base/Widget/_most_recent_file @@ -0,0 +1,24 @@ +#compdef -k complete-word \C-xm + +# Complete the most recently modified file matching the pattern on the line +# so far: globbing is active, i.e. *.txt will be expanded to the most recent +# file ending in .txt +# +# With a prefix argument, select the Nth most recent matching file; +# negative arguments work in the opposite direction, so for example +# `Esc - \C-x m' gets you the oldest file. + +local file tilde etilde +if [[ $PREFIX = \~*/* ]]; then + tilde=${PREFIX%%/*} + etilde=${~tilde} + # PREFIX and SUFFIX have full command line quoting in, but we want + # any globbing characters which are quoted to stay quoted. + eval "file=($PREFIX*$SUFFIX(om[${NUMERIC:-1}]N))" + file=(${file/#$etilde}) + file=($tilde${(q)^file}) +else + eval "file=($PREFIX*$SUFFIX(om[${NUMERIC:-1}]N))" + file=(${(q)file}) +fi +(( $#file )) && compadd -U -i "$IPREFIX" -I "$ISUFFIX" -f -Q -- $file |