chown: support long options
authorMatheus Izvekov <mizvekov@gmail.com>
Thu, 21 Jan 2010 21:30:25 +0000 (19:30 -0200)
committerDenys Vlasenko <vda.linux@googlemail.com>
Fri, 22 Jan 2010 23:10:40 +0000 (00:10 +0100)
function                                             old     new   delta
chown_longopts                                         -      81     +81
chown_main                                           182     192     +10

Signed-off-by: Matheus Izvekov <mizvekov@gmail.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
coreutils/Config.in
coreutils/chown.c

index 49e285982c751cb404dfec0f239f871d230ba415..1e32e266497080fe4bf44951179eaa1b8554c67d 100644 (file)
@@ -52,6 +52,13 @@ config CHOWN
          chown is used to change the user and/or group ownership
          of files.
 
+config FEATURE_CHOWN_LONG_OPTIONS
+       bool "Enable long options"
+       default n
+       depends on CHOWN && LONG_OPTS
+       help
+         Enable use of long options
+
 config CHROOT
        bool "chroot"
        default n
index 2d8e556f06029f2ed5f7e2e117db952d8b290a32..d29f8252a5336e735cd34260123d2c6a69c3dbde 100644 (file)
@@ -8,7 +8,6 @@
  */
 
 /* BB_AUDIT SUSv3 defects - none? */
-/* BB_AUDIT GNU defects - unsupported long options. */
 /* http://www.opengroup.org/onlinepubs/007904975/utilities/chown.html */
 
 #include "libbb.h"
 #define BIT_TRAVERSE_TOP (0x20|0x40)
 #define OPT_TRAVERSE_TOP (IF_DESKTOP(opt & BIT_TRAVERSE_TOP) IF_NOT_DESKTOP(0))
 
+#if ENABLE_FEATURE_CHOWN_LONG_OPTIONS
+static const char chown_longopts[] ALIGN1 =
+       "recursive\0"        No_argument   "R"
+       "dereference\0"      No_argument   "\xff"
+       "no-dereference\0"   No_argument   "h"
+# if ENABLE_DESKTOP
+       "changes\0"          No_argument   "c"
+       "silent\0"           No_argument   "f"
+       "quiet\0"            No_argument   "f"
+       "verbose\0"          No_argument   "v"
+# endif
+       ;
+#endif
+
 typedef int (*chown_fptr)(const char *, uid_t, gid_t);
 
 struct param_t {
@@ -78,6 +91,9 @@ int chown_main(int argc UNUSED_PARAM, char **argv)
        param.ugid.gid = -1;
        param.chown_func = chown;
 
+#if ENABLE_FEATURE_CHOWN_LONG_OPTIONS
+       applet_long_options = chown_longopts;
+#endif
        opt_complementary = "-2";
        opt = getopt32(argv, OPT_STR);
        argv += optind;