When you include the posix header libgen.h, glibc #defines basename to some random...
authorRob Landley <rob@landley.net>
Wed, 31 Dec 2014 22:22:31 +0000 (16:22 -0600)
committerRob Landley <rob@landley.net>
Wed, 31 Dec 2014 22:22:31 +0000 (16:22 -0600)
lib/portability.c
lib/portability.h
toys.h
toys/posix/dirname.c

index 7d6d85f..4fd1e22 100644 (file)
@@ -6,6 +6,14 @@
 
 #include "toys.h"
 
+#if defined(__GLIBC__)
+#include <libgen.h>
+char *basename(char *path)
+{
+  return __xpg_basename(path);
+}
+#endif
+
 #if !defined(__uClinux__)
 pid_t xfork(void)
 {
index 1464c65..8bbbdb2 100644 (file)
@@ -60,6 +60,15 @@ int wcwidth(wchar_t wc);
 #include <time.h>
 char *strptime(const char *buf, const char *format, struct tm *tm);
 
+// They didn't like posix basename so they defined another function with the
+// same name and if you include libgen.h it #defines basename to something
+// else (where they implemented the real basename), and that define breaks
+// the table entry for the basename command. They didn't make a new function
+// with a different name for their new behavior because gnu.
+//
+// Implement our own in portability.c and don't use their broken header.
+char *basename(char *path);
+
 // uClibc pretends to be glibc and copied a lot of its bugs, but has a few more
 #if defined(__UCLIBC__)
 #include <unistd.h>
diff --git a/toys.h b/toys.h
index 6b5f87a..3b50849 100644 (file)
--- a/toys.h
+++ b/toys.h
@@ -17,7 +17,6 @@
 #include <grp.h>
 #include <inttypes.h>
 #include <limits.h>
-#include <libgen.h>
 #include <math.h>
 #include <pwd.h>
 #include <regex.h>
index 06470ad..7f51e9f 100644 (file)
@@ -16,6 +16,7 @@ config DIRNAME
 */
 
 #include "toys.h"
+#include <libgen.h>
 
 void dirname_main(void)
 {