From d8c040ccb06a9b860e90584825f3c9c99bbfe8fa Mon Sep 17 00:00:00 2001 From: Miguel de Icaza Date: Sun, 25 Apr 1999 19:57:53 +0000 Subject: [PATCH] 1999-04-25 Sergei Ivanov * find.c: The origin of the bug is in the function do_search (file find.c). It limits the number of subdirectories to scan by the number stat.st_nlink-2, or infinite if st_nlink<2. On tar vfs, st_nlink is always 1, so it should be the second case. But before doing stat, do_search does opendir. And opendir on tar vfs (vfs_s_opendir in vfs/direntry.c) increases the st_nlink value in the stat data! So mc_stat called after mc_opendir on tar vfs returns st_nlink==2 instead of 1. This is interpreted as if the directory had no subdirs, thus subdirs are not searched in. Changing the order of calls to mc_stat and mc_opendir fixes the problem. --- src/ChangeLog | 21 +++++++++++++++++++++ src/find.c | 5 ++++- 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/src/ChangeLog b/src/ChangeLog index c77eabc56..10a09e905 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,23 @@ +1999-04-25 Sergei Ivanov + + * find.c: The origin of the bug is in the function do_search (file + find.c). It limits the number of subdirectories to scan by the + number stat.st_nlink-2, or infinite if st_nlink<2. On tar vfs, + st_nlink is always 1, so it should be the second case. + + But before doing stat, do_search does opendir. And opendir on tar + vfs (vfs_s_opendir in vfs/direntry.c) increases the st_nlink value + in the stat data! So mc_stat called after mc_opendir on tar vfs + returns st_nlink==2 instead of 1. This is interpreted as if the + directory had no subdirs, thus subdirs are not searched in. + + Changing the order of calls to mc_stat and mc_opendir fixes the + problem. + +1999-03-25 Miguel de Icaza + + * setup.c (save_setup): Only save this if there is a current panel + Wed Apr 21 21:47:15 1999 Norbert Warmuth * ext.c (exec_extension): Use tempnam instead of tmpnam (AIX doesn't @@ -22,6 +42,7 @@ Wed Apr 21 20:19:45 1999 Norbert Warmuth * main.c (main): call (init|done)_textmode_x11_support +>>>>>>> 1.297 Sat Apr 17 13:04:19 1999 Norbert Warmuth * view.c (do_view_init): Enable viewing of files with negative diff --git a/src/find.c b/src/find.c index afb823ac5..b513a653a 100644 --- a/src/find.c +++ b/src/find.c @@ -561,13 +561,16 @@ do_search (struct Dlg_head *h) g_snprintf (buffer, sizeof (buffer), _("Searching %s"), name_trunc (directory, FIND2_X_USE)); status_update (buffer); } - dirp = mc_opendir (directory); + /* mc_stat should not be called after mc_opendir + because vfs_s_opendir modifies the st_nlink + */ mc_stat (directory, &tmp_stat); subdirs_left = tmp_stat.st_nlink - 2; /* Commented out as unnecessary if (subdirs_left < 0) subdirs_left = MAXINT; */ + dirp = mc_opendir (directory); } dp = mc_readdir (dirp); }