[hackers] [sbase] Fix basename suffix treatment || Brandon Mulcahy

From: <git_AT_suckless.org>
Date: Thu, 04 Dec 2014 09:00:12 +0100

commit 757cf0651aed57015b508861aeeaf72f93b3950e
Author: Brandon Mulcahy <brandon_AT_jangler.info>
Date: Wed Dec 3 18:37:34 2014 -0500

    Fix basename suffix treatment
    
    Explicitly use "." instead of the result of basename(3) when argv[0] is
    an empty string in order to avoid a segfault.
    
    Skip suffix treatment if the result of basename(3) is "/", per POSIX.
    
    Fix the suffix check, which was previously checking for a match at any
    location in the string.

diff --git a/basename.c b/basename.c
index 402be17..cbfaf70 100644
--- a/basename.c
+++ b/basename.c
_AT_@ -18,6 +18,7 @@ int
 main(int argc, char *argv[])
 {
         char *s, *p;
+ size_t d;
 
         ARGBEGIN {
         default:
_AT_@ -27,11 +28,14 @@ main(int argc, char *argv[])
         if (argc < 1)
                 usage();
 
- s = basename(argv[0]);
- if (argc == 2) {
- p = strstr(s, argv[1]);
- if (p && p[strlen(p)] == '\0')
- *p = '\0';
+ s = strlen(argv[0]) ? basename(argv[0]) : ".";
+ if (argc == 2 && *s != '/') {
+ d = strlen(s) - strlen(argv[1]);
+ if (d >= 0) {
+ p = s + d;
+ if (strcmp(p, argv[1]) == 0)
+ *p = '\0';
+ }
         }
         puts(s);
         return 0;
Received on Thu Dec 04 2014 - 09:00:12 CET

This archive was generated by hypermail 2.3.0 : Thu Dec 04 2014 - 09:12:14 CET