diff options
author | Denis Vlasenko | 2008-02-24 14:56:10 +0000 |
---|---|---|
committer | Denis Vlasenko | 2008-02-24 14:56:10 +0000 |
commit | 52feee9b1fc996acb9c2857596bc5c2440644525 (patch) | |
tree | 1345002c66b651ddec2739cddc8138e7a3d2c5c9 | |
parent | 28b29916cbc532fafa1b195e3917fb49ae53bb8e (diff) | |
download | busybox-52feee9b1fc996acb9c2857596bc5c2440644525.zip busybox-52feee9b1fc996acb9c2857596bc5c2440644525.tar.gz |
rmdir: optional long options support for Debian users. +68 bytes.
By Roberto Gordo Saez <roberto.gordo AT gmail.com>
-rw-r--r-- | coreutils/rmdir.c | 33 |
1 files changed, 21 insertions, 12 deletions
diff --git a/coreutils/rmdir.c b/coreutils/rmdir.c index 71d29dd..96bee23 100644 --- a/coreutils/rmdir.c +++ b/coreutils/rmdir.c @@ -10,20 +10,30 @@ /* BB_AUDIT SUSv3 compliant */ /* http://www.opengroup.org/onlinepubs/007904975/utilities/rmdir.html */ -#include <libgen.h> #include "libbb.h" /* This is a NOFORK applet. Be very careful! */ +#define PARENTS 0x01 +#define IGNORE_NON_EMPTY 0x02 + int rmdir_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int rmdir_main(int argc, char **argv) { int status = EXIT_SUCCESS; int flags; - int do_dot; char *path; +#if ENABLE_FEATURE_RMDIR_LONG_OPTIONS + static const char rmdir_longopts[] ALIGN1 = + "parents\0" No_argument "p" + /* Debian etch: many packages fail to be purged or installed + * because they desperately want this option: */ + "ignore-fail-on-non-empty\0" No_argument "\xff" + ; + applet_long_options = rmdir_longopts; +#endif flags = getopt32(argv, "p"); argv += optind; @@ -34,27 +44,26 @@ int rmdir_main(int argc, char **argv) do { path = *argv; - /* Record if the first char was a '.' so we can use dirname later. */ - do_dot = (*path == '.'); - while (1) { if (rmdir(path) < 0) { +#if ENABLE_FEATURE_RMDIR_LONG_OPTIONS + if ((flags & IGNORE_NON_EMPTY) && errno == ENOTEMPTY) + break; +#endif bb_perror_msg("'%s'", path); /* Match gnu rmdir msg. */ status = EXIT_FAILURE; - } else if (flags) { - /* Note: path was not empty or null since rmdir succeeded. */ + } else if (flags & PARENTS) { + /* Note: path was not "" since rmdir succeeded. */ path = dirname(path); - /* Path is now just the parent component. Note that dirname - * returns "." if there are no parents. We must distinguish - * this from the case of the original path starting with '.'. + /* Path is now just the parent component. Dirname + * returns "." if there are no parents. */ - if (do_dot || (*path != '.') || path[1]) { + if (NOT_LONE_CHAR(path, '.')) { continue; } } break; } - } while (*++argv); return status; |