mirror of
https://github.com/sheumann/hush.git
synced 2025-01-02 09:31:26 +00:00
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:
parent
641dd7b080
commit
a99aa6e9c4
@ -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 */
|
||||||
|
if (!(opt & 4)) /* not -v */
|
||||||
logmode = LOGMODE_NONE;
|
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);
|
||||||
|
@ -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]..."
|
||||||
|
Loading…
Reference in New Issue
Block a user