(basename): Rewrite so it doesn't rely on strrchr,
authorJim Meyering <jim@meyering.net>
Fri, 19 Apr 1996 04:41:27 +0000 (04:41 +0000)
committerJim Meyering <jim@meyering.net>
Fri, 19 Apr 1996 04:41:27 +0000 (04:41 +0000)
and hence doesn't need to include string.h -- on some alpha-based
OSF systems, there's a conflicting prototype for basename in string.h.
Reported by Kaveh Ghazi.

lib/basename.c

index a47b200e5fc55c016414f708c77d5764693b3eef..7e0c1f611c7527f7576d764e6c19338886c03fab 100644 (file)
 #include <config.h>
 #endif
 
-#if defined(STDC_HEADERS) || defined(HAVE_STRING_H)
-#include <string.h>
-#else
-#include <strings.h>
-#ifndef strrchr
-#define strrchr rindex
-#endif
-#endif
-
-/* Return NAME with any leading path stripped off.  */
+/* Return NAME with any leading path stripped off.
+   Don't use strrchr/rindex.  */
 
 char *
 basename (name)
      const char *name;
 {
-  char *base;
-
-  base = strrchr (name, '/');
-  return base ? base + 1 : (char *) name;
+  const char *base = name;
+
+  while (*name)
+    {
+      if (*name == '/')
+       base = name + 1;
+      ++name;
+    }
+  return (char *) base;
 }