From 8542ae3328dda8e3c6083a5af2d314a623188778 Mon Sep 17 00:00:00 2001 From: Pavel Machek Date: Wed, 3 May 2000 19:10:52 +0000 Subject: [PATCH] Fixed problems with stating / of ftp archive; minor bugfix. --- vfs/ChangeLog | 7 +++++++ vfs/direntry.c | 18 ++++++++---------- vfs/vfs.c | 3 +-- 3 files changed, 16 insertions(+), 12 deletions(-) diff --git a/vfs/ChangeLog b/vfs/ChangeLog index 8e0995015..0d504000b 100644 --- a/vfs/ChangeLog +++ b/vfs/ChangeLog @@ -1,3 +1,10 @@ +2000-05-01 Pavel Machek + + * direntry.c (vfs_s_inode_from_path): fix for stating / directory + done properly + + * vfs.c: == 0 is right test of eof. + 2000-04-28 Pavel Machek * direntry.c (vfs_s_internal_stat): added ugly special case for / diff --git a/vfs/direntry.c b/vfs/direntry.c index 4710100dc..3bece9e21 100644 --- a/vfs/direntry.c +++ b/vfs/direntry.c @@ -565,12 +565,17 @@ vfs_s_inode * vfs_s_inode_from_path (vfs *me, char *name, int flags) { struct vfs_s_super *super; + struct vfs_s_inode *ino; char *q; if (!(q = vfs_s_get_path_mangle (me, name, &super, 0))) return NULL; - return vfs_s_find_inode (me, super->root, q, flags & FL_FOLLOW ? LINK_FOLLOW : LINK_NO_FOLLOW, flags & ~FL_FOLLOW); + ino = vfs_s_find_inode (me, super->root, q, flags & FL_FOLLOW ? LINK_FOLLOW : LINK_NO_FOLLOW, flags & ~FL_FOLLOW); + if ((!ino) && (!*q)) + /* We are asking about / directory of ftp server: assume it exists */ + ino = vfs_s_find_inode (me, super->root, q, flags & FL_FOLLOW ? LINK_FOLLOW : LINK_NO_FOLLOW, FL_DIR | (flags & ~FL_FOLLOW)); + return ino; } struct dirhandle { @@ -683,18 +688,11 @@ vfs_s_chdir (vfs *me, char *path) static int vfs_s_internal_stat (vfs *me, char *path, struct stat *buf, int flag) { - char *path2; struct vfs_s_inode *ino; - path2 = g_strdup(path); - if (!(ino = vfs_s_inode_from_path (me, path2, flag))) { - if ((!path) || (*path) || !(ino = vfs_s_inode_from_path (me, path, flag|FL_DIR))) { /* Seems we have problem: vfs_s_inode_from_path on directories always succeeds. This is *hack* to make / directory of ftp archive statable */ - g_free(path2); - return -1; - } - } + if (!(ino = vfs_s_inode_from_path (me, path, flag))) + return -1; *buf = ino->st; - g_free(path2); return 0; } diff --git a/vfs/vfs.c b/vfs/vfs.c index 5c5e7f3a1..b91db0f7f 100644 --- a/vfs/vfs.c +++ b/vfs/vfs.c @@ -1074,9 +1074,8 @@ mc_def_getlocalcopy (vfs *vfs, char *filename) fdout = open (tmp, O_CREAT|O_WRONLY|O_TRUNC|O_EXCL, 0600); if (fdout == -1) goto fail; - while ((i = mc_read (fdin, buffer, sizeof (buffer))) == sizeof (buffer)){ + while ((i = mc_read (fdin, buffer, sizeof (buffer))) > 0) write (fdout, buffer, i); - } if (i == -1) goto fail; if (write (fdout, buffer, i)==-1)