about summary refs log tree commit diff
path: root/Functions/Zftp/zfget_match
diff options
context:
space:
mode:
authorTanaka Akira <akr@users.sourceforge.net>1999-04-25 15:43:41 +0000
committerTanaka Akira <akr@users.sourceforge.net>1999-04-25 15:43:41 +0000
commit206237c8ec4b7619d9e70a75004cd1ae1066b0a0 (patch)
treeff703cbc295605f90755edb68672ed2de11f4a81 /Functions/Zftp/zfget_match
parent8ceb54fbc2f879e0e80f58c18761bd54db07e5f7 (diff)
downloadzsh-206237c8ec4b7619d9e70a75004cd1ae1066b0a0.tar.gz
zsh-206237c8ec4b7619d9e70a75004cd1ae1066b0a0.tar.xz
zsh-206237c8ec4b7619d9e70a75004cd1ae1066b0a0.zip
Diffstat (limited to 'Functions/Zftp/zfget_match')
-rw-r--r--Functions/Zftp/zfget_match27
1 files changed, 27 insertions, 0 deletions
diff --git a/Functions/Zftp/zfget_match b/Functions/Zftp/zfget_match
new file mode 100644
index 000000000..677108ede
--- /dev/null
+++ b/Functions/Zftp/zfget_match
@@ -0,0 +1,27 @@
+# function zfget_match {
+
+emulate -L zsh
+
+# the zfcd hack:  this may not be necessary here
+if [[ $1 == $HOME || $1 == $HOME/* ]]; then
+  1="~${1#$HOME}"
+fi
+
+local tmpf=${TMPPREFIX}zfgm$$
+
+if [[ $ZFTP_SYSTEM == UNIX* && $1 == */* ]]; then
+  # On the first argument to ls, we usually get away with a glob.
+  zftp ls "$1*$2" >$tmpf
+  reply=($(<$tmpf))
+  rm -f $tmpf
+else
+  if (( $#zftp_fcache == 0 )); then
+    # Always cache the current directory and use it
+    # even if the system is UNIX.
+    zftp ls >$tmpf
+    zftp_fcache=($(<$tmpf))
+    rm -f $tmpf
+  fi
+  reply=($zftp_fcache);
+fi
+# }