readlink: support -n, -v, -s and -q too if support for -f is requested

function                                             old     new   delta
readlink_main                                        104     135     +31
packed_usage                                       26322   26321      -1
------------------------------------------------------------------------------
(add/remove: 0/0 grow/shrink: 1/1 up/down: 31/-1)              Total: 30 bytes

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
Denys Vlasenko 2009-06-12 13:16:21 +02:00
parent 641dd7b080
commit a99aa6e9c4
2 changed files with 33 additions and 7 deletions

View File

@ -6,9 +6,31 @@
* *
* Licensed under GPL v2 or later, see file LICENSE in this tarball for details. * Licensed under GPL v2 or later, see file LICENSE in this tarball for details.
*/ */
#include "libbb.h" #include "libbb.h"
/*
* # readlink --version
* readlink (GNU coreutils) 6.10
* # readlink --help
* -f, --canonicalize
* canonicalize by following every symlink in
* every component of the given name recursively;
* all but the last component must exist
* -e, --canonicalize-existing
* canonicalize by following every symlink in
* every component of the given name recursively,
* all components must exist
* -m, --canonicalize-missing
* canonicalize by following every symlink in
* every component of the given name recursively,
* without requirements on components existence
* -n, --no-newline do not output the trailing newline
* -q, --quiet, -s, --silent suppress most error messages
* -v, --verbose report error messages
*
* bbox supports: -f -n -v (fully), -q -s (accepts but ignores)
*/
int readlink_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int readlink_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE;
int readlink_main(int argc UNUSED_PARAM, char **argv) int readlink_main(int argc UNUSED_PARAM, char **argv)
{ {
@ -20,7 +42,7 @@ int readlink_main(int argc UNUSED_PARAM, char **argv)
unsigned opt; unsigned opt;
/* We need exactly one non-option argument. */ /* We need exactly one non-option argument. */
opt_complementary = "=1"; opt_complementary = "=1";
opt = getopt32(argv, "f"); opt = getopt32(argv, "fnvsq");
fname = argv[optind]; fname = argv[optind];
) )
IF_NOT_FEATURE_READLINK_FOLLOW( IF_NOT_FEATURE_READLINK_FOLLOW(
@ -30,9 +52,10 @@ int readlink_main(int argc UNUSED_PARAM, char **argv)
) )
/* compat: coreutils readlink reports errors silently via exit code */ /* compat: coreutils readlink reports errors silently via exit code */
logmode = LOGMODE_NONE; if (!(opt & 4)) /* not -v */
logmode = LOGMODE_NONE;
if (opt) { if (opt & 1) { /* -f */
buf = realpath(fname, pathbuf); buf = realpath(fname, pathbuf);
} else { } else {
buf = xmalloc_readlink_or_warn(fname); buf = xmalloc_readlink_or_warn(fname);
@ -40,7 +63,7 @@ int readlink_main(int argc UNUSED_PARAM, char **argv)
if (!buf) if (!buf)
return EXIT_FAILURE; return EXIT_FAILURE;
puts(buf); printf((opt & 2) ? "%s" : "%s\n", buf);
if (ENABLE_FEATURE_CLEAN_UP && !opt) if (ENABLE_FEATURE_CLEAN_UP && !opt)
free(buf); free(buf);

View File

@ -3466,12 +3466,15 @@
"files do not block on disk I/O" "files do not block on disk I/O"
#define readlink_trivial_usage \ #define readlink_trivial_usage \
IF_FEATURE_READLINK_FOLLOW("[-f] ") "FILE" IF_FEATURE_READLINK_FOLLOW("[-fnv] ") "FILE"
#define readlink_full_usage "\n\n" \ #define readlink_full_usage "\n\n" \
"Display the value of a symlink" \ "Display the value of a symlink" \
IF_FEATURE_READLINK_FOLLOW( "\n" \ IF_FEATURE_READLINK_FOLLOW( "\n" \
"\nOptions:" \ "\nOptions:" \
"\n -f Canonicalize by following all symlinks") \ "\n -f Canonicalize by following all symlinks" \
"\n -n Don't add newline" \
"\n -v Verbose" \
) \
#define readprofile_trivial_usage \ #define readprofile_trivial_usage \
"[OPTIONS]..." "[OPTIONS]..."