1303 files changed, 32187 insertions, 57138 deletions
diff --git a/miscutils/strings.c b/miscutils/strings.c index b040508..edd0e66 100644 --- a/miscutils/strings.c +++ b/miscutils/strings.c @@ -6,15 +6,28 @@ * * Licensed under GPLv2 or later, see file LICENSE in this source tree. */ +//config:config STRINGS +//config: bool "strings" +//config: default y +//config: help +//config: strings prints the printable character sequences for each file +//config: specified. + +//applet:IF_STRINGS(APPLET(strings, BB_DIR_USR_BIN, BB_SUID_DROP)) + +//kbuild:lib-$(CONFIG_STRINGS) += strings.o //usage:#define strings_trivial_usage -//usage: "[-afo] [-n LEN] [FILE]..." +//usage: "[-fo] [-t o/d/x] [-n LEN] [FILE]..." //usage:#define strings_full_usage "\n\n" //usage: "Display printable strings in a binary file\n" -//usage: "\n -a Scan whole file (default)" -//usage: "\n -f Precede strings with filenames" -//usage: "\n -n LEN At least LEN characters form a string (default 4)" -//usage: "\n -o Precede strings with decimal offsets" +//We usually don't bother user with "nop" options. They work, but are not shown: +////usage: "\n -a Scan whole file (default)" +//unimplemented alternative is -d: Only strings from initialized, loaded data sections +//usage: "\n -f Precede strings with filenames" +//usage: "\n -o Precede strings with octal offsets" +//usage: "\n -t o/d/x Precede strings with offsets in base 8/10/16" +//usage: "\n -n LEN At least LEN characters form a string (default 4)" #include "libbb.h" @@ -22,6 +35,7 @@ #define PRINT_NAME 2 #define PRINT_OFFSET 4 #define SIZE 8 +#define PRINT_RADIX 16 int strings_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int strings_main(int argc UNUSED_PARAM, char **argv) @@ -33,8 +47,11 @@ int strings_main(int argc UNUSED_PARAM, char **argv) char *string; const char *fmt = "%s: "; const char *n_arg = "4"; + /* default for -o */ + const char *radix = "o"; + char *radix_fmt; - getopt32(argv, "afon:", &n_arg); + getopt32(argv, "afon:t:", &n_arg, &radix); /* -a is our default behaviour */ /*argc -= optind;*/ argv += optind; @@ -43,6 +60,11 @@ int strings_main(int argc UNUSED_PARAM, char **argv) string = xzalloc(n + 1); n--; + if ((radix[0] != 'd' && radix[0] != 'o' && radix[0] != 'x') || radix[1] != 0) + bb_show_usage(); + + radix_fmt = xasprintf("%%7"OFF_FMT"%s ", radix); + if (!*argv) { fmt = "{%s}: "; *--argv = (char *)bb_msg_standard_input; @@ -67,8 +89,8 @@ int strings_main(int argc UNUSED_PARAM, char **argv) if (option_mask32 & PRINT_NAME) { printf(fmt, *argv); } - if (option_mask32 & PRINT_OFFSET) { - printf("%7"OFF_FMT"o ", offset - n); + if (option_mask32 & (PRINT_OFFSET | PRINT_RADIX)) { + printf(radix_fmt, offset - n); } fputs(string, stdout); } @@ -85,8 +107,10 @@ int strings_main(int argc UNUSED_PARAM, char **argv) fclose_if_not_stdin(file); } while (*++argv); - if (ENABLE_FEATURE_CLEAN_UP) + if (ENABLE_FEATURE_CLEAN_UP) { free(string); + free(radix_fmt); + } fflush_stdout_and_exit(status); } |