diff options
author | Jim Meyering <jim@meyering.net> | 2003-03-09 09:22:55 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2003-03-09 09:22:55 +0000 |
commit | 3d23ede4ebee271a6ab60cd181ee830979756064 (patch) | |
tree | ec892d9a802416458b7eb9e427828bfb22a5424e /lib | |
parent | ff47d1602f96ba629e9717d6b30d973307869830 (diff) | |
download | coreutils-3d23ede4ebee271a6ab60cd181ee830979756064.tar.xz |
Include "save-cwd.h".
(ftw_startup): Avoid use of getcwd, if possible.
Instead, use fopen/fchdir via save_cwd/restore_cwd.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/ftw.c | 27 |
1 files changed, 17 insertions, 10 deletions
@@ -88,6 +88,8 @@ char *stpcpy (); /* #define NDEBUG 1 */ #include <assert.h> +#include "save-cwd.h" + #ifndef _LIBC # undef __chdir # define __chdir chdir @@ -95,9 +97,6 @@ char *stpcpy (); # define __closedir closedir # undef __fchdir # define __fchdir fchdir -# undef __getcwd -# define __getcwd(P, N) xgetcwd () -extern char *xgetcwd (void); # undef __mempcpy # define __mempcpy mempcpy # undef __opendir @@ -643,7 +642,7 @@ ftw_startup (const char *dir, int is_nftw, NFTW_FUNC_T func, int descriptors, struct STAT st; int result = 0; int save_err; - char *cwd = NULL; + struct saved_cwd cwd; size_t dir_len; /* First make sure the parameters are reasonable. */ @@ -694,9 +693,7 @@ ftw_startup (const char *dir, int is_nftw, NFTW_FUNC_T func, int descriptors, /* Now go to the directory containing the initial file/directory. */ if (flags & FTW_CHDIR) { - /* GNU extension ahead. */ - cwd = __getcwd (NULL, 0); - if (cwd == NULL) + if (save_cwd (&cwd)) result = -1; else if (data.ftw.base > 0) { @@ -772,11 +769,21 @@ ftw_startup (const char *dir, int is_nftw, NFTW_FUNC_T func, int descriptors, } /* Return to the start directory (if necessary). */ - if (cwd != NULL) + if (flags & FTW_CHDIR) { save_err = errno; - __chdir (cwd); - free (cwd); + /* If restore_cwd fails and there wasn't a prior failure, + then let this new errno override any prior value. + FIXME: ideally, we'd be able to return some indication + of what the failure means. Otherwise, the caller will + have a hard time distinguishing between e.g., `out of memory' + and this sort of failure. */ + if (restore_cwd (&cwd) && result == 0) + { + save_err = errno; + result = -1; + } + __set_errno (save_err); } |