about summary refs log tree commit diff
path: root/Completion/Base
diff options
context:
space:
mode:
authorPaul Ackersviller <packersv@users.sourceforge.net>2007-11-05 01:59:42 +0000
committerPaul Ackersviller <packersv@users.sourceforge.net>2007-11-05 01:59:42 +0000
commite6a78cc112e727eec71ce8dc9a16f40189ef8ca0 (patch)
treecfd84b9386d275afef01a5f40cbbeb1bd4ac695d /Completion/Base
parentc450d7eb1e1656b15ff91622a320f0072fe6a178 (diff)
downloadzsh-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_file24
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