support null buffer argument to getcwd, auto-allocating behavior
authorRich Felker <dalias@aerifal.cx>
Fri, 2 Mar 2012 03:08:05 +0000 (22:08 -0500)
committerRich Felker <dalias@aerifal.cx>
Fri, 2 Mar 2012 03:08:05 +0000 (22:08 -0500)
this is a popular extension some programs depend on, and by using a
temporary buffer and strdup rather than malloc prior to the syscall,
i've avoided the dependency on free and thus minimized the bloat cost
of supporting this feature.

src/unistd/getcwd.c

index b64b560feeb5bf71d24f2354721a7b39d1f85004..2e540cd41daef91efd37c7656f8f9274d4447ed6 100644 (file)
@@ -1,8 +1,13 @@
 #include <unistd.h>
 #include <errno.h>
+#include <limits.h>
+#include <string.h>
 #include "syscall.h"
 
 char *getcwd(char *buf, size_t size)
 {
-       return syscall(SYS_getcwd, buf, size) < 0 ? NULL : buf;
+       char tmp[PATH_MAX];
+       if (!buf) buf = tmp, size = PATH_MAX;
+       if (syscall(SYS_getcwd, buf, size) < 0) return 0;
+       return buf == tmp ? strdup(buf) : buf;
 }