X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=basename.c;h=fcc7d4619ec458fbbddaf88e63605aa385f3d78b;hb=46f44d24fcc25a5d6e13e0453485881bdf147e91;hp=78265a5e61bda1eb1252008c1f00df5df02f5f2a;hpb=330fd2b5767110f29544131d4c72c77e0506b6df;p=oweals%2Fbusybox.git diff --git a/basename.c b/basename.c index 78265a5e6..fcc7d4619 100644 --- a/basename.c +++ b/basename.c @@ -21,21 +21,13 @@ * */ -#include "internal.h" +#include "busybox.h" #include -const char *basename_usage="basename FILE [SUFFIX]\n" -#ifndef BB_FEATURE_TRIVIAL_HELP - "\nStrips directory path and suffixes from FILE.\n" - "If specified, also removes any trailing SUFFIX.\n" -#endif -; - - extern int basename_main(int argc, char **argv) { int m, n; - char *s, *s1; + char *s; if ((argc < 2) || (**(argv + 1) == '-')) { usage(basename_usage); @@ -43,14 +35,7 @@ extern int basename_main(int argc, char **argv) argv++; - s1=*argv+strlen(*argv)-1; - while (s1 && *s1 == '/') { - *s1 = '\0'; - s1--; - } - s = strrchr(*argv, '/'); - if (s==NULL) s=*argv; - else s++; + s = get_last_path_component(*argv); if (argc>2) { argv++; @@ -60,6 +45,5 @@ extern int basename_main(int argc, char **argv) s[m-n] = '\0'; } printf("%s\n", s); - exit(TRUE); + return EXIT_SUCCESS; } -