- patch from Denis Vlasenko to add and use bb_xchdir()
authorBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Wed, 12 Apr 2006 18:39:58 +0000 (18:39 -0000)
committerBernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Wed, 12 Apr 2006 18:39:58 +0000 (18:39 -0000)
12 files changed:
archival/dpkg_deb.c
archival/tar.c
archival/unzip.c
coreutils/chroot.c
include/libbb.h
libbb/Makefile.in
libbb/bb_xchdir.c [new file with mode: 0644]
miscutils/crond.c
miscutils/crontab.c
miscutils/makedevs.c
networking/httpd.c
procps/top.c

index fa89e44a0e47b7322d59ad9e830309381e722c3e..fc8b9221d139539f42b97d20e43f9add2e706d56 100644 (file)
@@ -1,18 +1,8 @@
+/* vi: set sw=4 ts=4: */
 /*
- *  This program is free software; you can redistribute it and/or modify
- *  it under the terms of the GNU General Public License as published by
- *  the Free Software Foundation; either version 2 of the License, or
- *  (at your option) any later version.
- *
- *  This program is distributed in the hope that it will be useful,
- *  but WITHOUT ANY WARRANTY; without even the implied warranty of
- *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- *  GNU Library General Public License for more details.
- *
- *  You should have received a copy of the GNU General Public License
- *  along with this program; if not, write to the Free Software
- *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ * dpkg-deb packs, unpacks and provides information about Debian archives.
  *
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
  */
 #include <fcntl.h>
 #include <stdlib.h>
@@ -100,7 +90,7 @@ int dpkg_deb_main(int argc, char **argv)
        }
        if (extract_dir) {
                mkdir(extract_dir, 0777);
-               chdir(extract_dir);
+               chdir(extract_dir); /* error check? */
        }
        unpack_ar_archive(ar_archive);
 
index 9d0a7c5e4e1b0875c1fe25e333b31f358d055717..dcc2f163e4a695f6298f5da0e867048272764f43 100644 (file)
@@ -19,9 +19,8 @@
  *
  * Based in part on the tar implementation from busybox-0.28
  *  Copyright (C) 1995 Bruce Perens
- *  This is free software under the GNU General Public License.
  *
- * Licensed under GPL v2 (or later), see file LICENSE in this tarball.
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
  */
 
 #include <fcntl.h>
@@ -834,8 +833,8 @@ int tar_main(int argc, char **argv)
                }
        }
 
-       if ((base_dir) && (chdir(base_dir)))
-               bb_perror_msg_and_die("Couldnt chdir to %s", base_dir);
+       if (base_dir)
+               bb_xchdir(base_dir);
 
        /* create an archive */
        if (ENABLE_FEATURE_TAR_CREATE && (opt & CTX_CREATE)) {
index bb7197d3e4a424f0c51adabab76193bd388ea255..b9dff1985524fdb20c4a429c3607c259efb11634 100644 (file)
@@ -236,9 +236,8 @@ int unzip_main(int argc, char **argv)
        }
 
        /* Change dir if necessary */
-       if (base_dir && chdir(base_dir)) {
-               bb_perror_msg_and_die("Cannot chdir");
-       }
+       if (base_dir)
+               bb_xchdir(base_dir);
 
        if (verbosity != v_silent)
                printf("Archive:  %s\n", src_fn);
index 62257021d303a5a9898fa7d708b4e85ad2560f67..8ad680c02c5c4bd80d6b0028ae0bddf5b677947f 100644 (file)
@@ -4,20 +4,7 @@
  *
  * Copyright (C) 1999-2004 by Erik Andersen <andersen@codepoet.org>
  *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- *
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
  */
 
 /* BB_AUDIT SUSv3 N/A -- Matches GNU behavior. */
@@ -35,9 +22,10 @@ int chroot_main(int argc, char **argv)
        }
 
        ++argv;
-       if (chroot(*argv) || (chdir("/"))) {
+       if (chroot(*argv)) {
                bb_perror_msg_and_die("cannot change root directory to %s", *argv);
        }
+       bb_xchdir("/");
 
        ++argv;
        if (argc == 2) {
index d70c71cc043bb52ef12bbeb75b3ed617f7c188d1..e1ac912f690504ff243b6bd705ee03379d970d6d 100644 (file)
@@ -149,6 +149,7 @@ extern int  bb_xsocket(int domain, int type, int protocol);
 extern void bb_xdaemon(int nochdir, int noclose);
 extern void bb_xbind(int sockfd, struct sockaddr *my_addr, socklen_t addrlen);
 extern void bb_xlisten(int s, int backlog);
+extern void bb_xchdir(const char *path);
 
 #define BB_GETOPT_ERROR 0x80000000UL
 extern const char *bb_opt_complementally;
index f05bf80ed766ee590bc5c020c314067433c5cd3f..eac14c60ce6280516a7022c6c6eed5d3307992d5 100644 (file)
@@ -30,7 +30,7 @@ LIBBB-y:= \
        trim.c u_signal_names.c vdprintf.c verror_msg.c \
        vherror_msg.c vperror_msg.c wfopen.c xconnect.c xgetcwd.c xstat.c \
        xgethostbyname.c xgethostbyname2.c xreadlink.c xregcomp.c xgetlarg.c \
-       bb_xsocket.c bb_xdaemon.c bb_xbind.c bb_xlisten.c \
+       bb_xsocket.c bb_xdaemon.c bb_xbind.c bb_xlisten.c bb_xchdir.c \
        get_terminal_width_height.c fclose_nonstdin.c fflush_stdout_and_exit.c \
        getopt_ulflags.c default_error_retval.c wfopen_input.c speed_table.c \
        perror_nomsg_and_die.c perror_nomsg.c skip_whitespace.c bb_askpass.c \
diff --git a/libbb/bb_xchdir.c b/libbb/bb_xchdir.c
new file mode 100644 (file)
index 0000000..65b0153
--- /dev/null
@@ -0,0 +1,17 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * bb_xchdir.c - a chdir() which dies on failure with error message
+ *
+ * Copyright (C) 2006 Denis Vlasenko
+ *
+ * Licensed under LGPL, see file docs/lesser.txt in this tarball for details.
+ */
+#include <unistd.h>
+#include "libbb.h"
+
+void bb_xchdir(const char *path)
+{
+       if (chdir(path))
+               bb_perror_msg_and_die("chdir(%s)", path);
+}
+
index 06b8769fab5bb58a2c99c891e7149de00f03cd03..4d479bc0d3ba00197dbf0dae73292e7245720279 100644 (file)
@@ -197,9 +197,7 @@ int crond_main(int ac, char **av)
         * change directory
         */
 
-       if (chdir(CDir) != 0) {
-               bb_perror_msg_and_die("%s", CDir);
-       }
+       bb_xchdir(CDir);
        signal(SIGHUP, SIG_IGN);        /* hmm.. but, if kill -HUP original
                                                                 * version - his died. ;(
                                                                 */
index df94c855a4b8615170f55158d76fc78513e3b91a..703d01ecc88e5c978cd23afb94f8551c6d7a59f5 100644 (file)
@@ -1,3 +1,4 @@
+/* vi: set sw=4 ts=4: */
 /*
  * CRONTAB
  *
@@ -148,8 +149,7 @@ crontab_main(int ac, char **av)
      * Change directory to our crontab directory
      */
 
-    if (chdir(CDir) < 0)
-       bb_perror_msg_and_die("cannot change dir to %s", CDir);
+    bb_xchdir(CDir);
 
     /*
      * Handle options as appropriate
@@ -358,10 +358,7 @@ ChangeUser(const char *user, short dochdir)
     if (dochdir) {
        if (chdir(pas->pw_dir) < 0) {
            bb_perror_msg("chdir failed: %s %s", user, pas->pw_dir);
-           if (chdir(TMPDIR) < 0) {
-               bb_perror_msg_and_die("chdir failed: %s %s", user, TMPDIR);
-               return(-1);
-           }
+           bb_xchdir(TMPDIR);
        }
     }
     return(pas->pw_uid);
index 999b99331f4a86113b95f288eb4e8add9d5224bd..24d07ebe0f3f253fd8b35395aee346bf306dda9e 100644 (file)
@@ -1,4 +1,11 @@
 /* vi: set sw=4 ts=4: */
+/*
+ * public domain -- Dave 'Kill a Cop' Cinege <dcinege@psychosis.com>
+ *
+ * makedevs
+ * Make ranges of device files quickly.
+ * known bugs: can't deal with alpha ranges
+ */
 
 #include <stdio.h>
 #include <stdlib.h>
 #include "busybox.h"
 
 #ifdef CONFIG_FEATURE_MAKEDEVS_LEAF
-/*
- * public domain -- Dave 'Kill a Cop' Cinege <dcinege@psychosis.com>
- *
- * makedevs
- * Make ranges of device files quickly.
- * known bugs: can't deal with alpha ranges
- */
 int makedevs_main(int argc, char **argv)
 {
        mode_t mode;
@@ -94,9 +94,7 @@ int makedevs_main(int argc, char **argv)
                bb_error_msg_and_die("root directory not specified");
        }
 
-       if (chdir(rootdir) != 0) {
-               bb_perror_msg_and_die("could not chdir to %s", rootdir);
-       }
+       bb_xchdir(rootdir);
 
        umask(0);
 
index 0f6174140828e85d5b8a06625631394609f4f314..df280ccf554e2f6f88cb70004cde94ed06b3b373 100644 (file)
@@ -2077,9 +2077,7 @@ int httpd_main(int argc, char *argv[])
 #endif
 #endif
 
-  if(chdir(home_httpd)) {
-    bb_perror_msg_and_die("can`t chdir to %s", home_httpd);
-  }
+  bb_xchdir(home_httpd);
 #ifndef CONFIG_FEATURE_HTTPD_USAGE_FROM_INETD_ONLY
   server = openServer();
 # ifdef CONFIG_FEATURE_HTTPD_SETUID
index afd419ba55f55587925b05a7a6ab5e6f0f26bfb7..d140924d8d9955d2d001a413fe43426979da819b 100644 (file)
@@ -1,3 +1,4 @@
+/* vi: set sw=4 ts=4: */
 /*
  * A tiny 'top' utility.
  *
@@ -468,9 +469,7 @@ int top_main(int argc, char **argv)
        col = 35;
 #endif
        /* change to /proc */
-       if (chdir("/proc") < 0) {
-               bb_perror_msg_and_die("chdir('/proc')");
-       }
+       bb_xchdir("/proc");
 #ifdef CONFIG_FEATURE_USE_TERMIOS
        tcgetattr(0, (void *) &initial_settings);
        memcpy(&new_settings, &initial_settings, sizeof(struct termios));