summaryrefslogtreecommitdiff
path: root/Functions/Zftp/zftp_chpwd
diff options
context:
space:
mode:
authorTanaka Akira <akr@users.sourceforge.net>1999-04-25 15:43:45 +0000
committerTanaka Akira <akr@users.sourceforge.net>1999-04-25 15:43:45 +0000
commite8eb43fc308acb3f1a8ebada7633c097e5050e46 (patch)
tree2df36ef3c7709c7d4d3b7bdcb5761f98649859bf /Functions/Zftp/zftp_chpwd
parente74702b467171dbdafb56dfe354794a212e020d9 (diff)
downloadzsh-e8eb43fc308acb3f1a8ebada7633c097e5050e46.tar.gz
zsh-e8eb43fc308acb3f1a8ebada7633c097e5050e46.zip
Initial revision
Diffstat (limited to 'Functions/Zftp/zftp_chpwd')
-rw-r--r--Functions/Zftp/zftp_chpwd39
1 files changed, 39 insertions, 0 deletions
diff --git a/Functions/Zftp/zftp_chpwd b/Functions/Zftp/zftp_chpwd
new file mode 100644
index 000000000..0df199cfb
--- /dev/null
+++ b/Functions/Zftp/zftp_chpwd
@@ -0,0 +1,39 @@
+# function zftp_chpwd {
+# You may want to alter chpwd to call this when $ZFTP_USER is set.
+
+# Cancel the filename cache for the current directory.
+zftp_fcache=()
+# ...and also empty the stored directory listing cache.
+# As this function is called when we close the connection, this
+# is the only place we need to do these two things.
+[[ -n $zfcurdir && -f $zfcurdir ]] && rm -f $zfcurdir
+zfotherargs=
+
+if [[ -z $ZFTP_USER ]]; then
+ # last call, after an FTP logout
+
+ # delete the non-current cached directory
+ [[ -n $zfotherdir && -f $zfotherdir ]] && rm -f $zfotherdir
+
+ # don't keep zflastdir between opens (do keep zflastsession)
+ zflastdir=
+
+ # return the display to standard
+ # uncomment the following line if you have a chpwd which shows directories
+ # chpwd
+else
+ [[ -n $ZFTP_PWD ]] && zflastdir=$ZFTP_PWD
+ zflastsession="$ZFTP_HOST:$ZFTP_PWD"
+ local args
+ if [[ -t 1 && -t 2 ]]; then
+ local str=$zflastsession
+ [[ ${#str} -lt 70 ]] && str="%m: %~ $str"
+ case $TERM in
+ sun-cmd) print -n -P "\033]l$str\033\\"
+ ;;
+ xterm) print -n -P "\033]2;$str\a"
+ ;;
+ esac
+ fi
+fi
+# }