svn commit: trunk/busybox: debianutils libbb

vda at busybox.net vda at busybox.net
Fri Oct 20 18:36:56 UTC 2006


Author: vda
Date: 2006-10-20 11:36:55 -0700 (Fri, 20 Oct 2006)
New Revision: 16414

Log:
readlink: do not emit errors if file doesnt not exist / not a link
getopt32: add =N support


Modified:
   trunk/busybox/debianutils/readlink.c
   trunk/busybox/libbb/getopt32.c


Changeset:
Modified: trunk/busybox/debianutils/readlink.c
===================================================================
--- trunk/busybox/debianutils/readlink.c	2006-10-20 13:42:57 UTC (rev 16413)
+++ trunk/busybox/debianutils/readlink.c	2006-10-20 18:36:55 UTC (rev 16414)
@@ -13,22 +13,33 @@
 #include <stdlib.h>
 #include <getopt.h>
 
-#define READLINK_FLAG_f	(1 << 0)
-
 int readlink_main(int argc, char **argv)
 {
 	char *buf;
-	unsigned opt = ENABLE_FEATURE_READLINK_FOLLOW ?
-			getopt32(argc, argv, "f") : 0;
+	char *fname;
 
-	if (argc != (ENABLE_FEATURE_READLINK_FOLLOW ? optind + 1 : 2))
-			bb_show_usage();
+	USE_FEATURE_READLINK_FOLLOW(
+		unsigned opt;
+		/* We need exactly one non-option argument.  */
+		opt_complementary = "=1";
+		opt = getopt32(argc, argv, "f");
+		fname = argv[optind];
+	)
+	SKIP_FEATURE_READLINK_FOLLOW(
+		const unsigned opt = 0;
+		if (argc != 2) bb_show_usage();
+		fname = argv[1];
+	)
 
-	if (opt & READLINK_FLAG_f)
-		buf = realpath(argv[optind], bb_common_bufsiz1);
-	else
-		buf = xreadlink(argv[ENABLE_FEATURE_READLINK_FOLLOW ? optind : 1]);
+	/* compat: coreutils readlink reports errors silently via exit code */
+	logmode = LOGMODE_NONE;
 
+	if (opt) {
+		buf = realpath(fname, bb_common_bufsiz1);
+	} else {
+		buf = xreadlink(fname);
+	}
+
 	if (!buf)
 		return EXIT_FAILURE;
 	puts(buf);
@@ -36,5 +47,5 @@
 	if (ENABLE_FEATURE_CLEAN_UP && buf != bb_common_bufsiz1)
 		free(buf);
 
-	return EXIT_SUCCESS;
+	bb_fflush_stdout_and_exit(EXIT_SUCCESS);
 }

Modified: trunk/busybox/libbb/getopt32.c
===================================================================
--- trunk/busybox/libbb/getopt32.c	2006-10-20 13:42:57 UTC (rev 16413)
+++ trunk/busybox/libbb/getopt32.c	2006-10-20 18:36:55 UTC (rev 16414)
@@ -188,6 +188,10 @@
         by a single digit (0-9) means that at least N non-option
         arguments must be present on the command line
 
+ "=N"   An equal sign as the first char in a opt_complementary group followed
+        by a single digit (0-9) means that exactly N non-option
+        arguments must be present on the command line
+
  "V-"   An option with dash before colon or end-of-line results in
         bb_show_usage being called if this option is encountered.
         This is typically used to implement "print verbose usage message
@@ -400,6 +404,11 @@
 			}
 			continue;
 		}
+		if (*s == '=') {
+			min_arg = max_arg = c - '0';
+			s++;
+			continue;
+		}
 		for (on_off = complementary; on_off->opt; on_off++)
 			if (on_off->opt == *s)
 				break;




More information about the busybox-cvs mailing list