Revert some of the previous change; intead,
authorJim Meyering <jim@meyering.net>
Tue, 4 Sep 2001 20:28:31 +0000 (20:28 +0000)
committerJim Meyering <jim@meyering.net>
Tue, 4 Sep 2001 20:28:31 +0000 (20:28 +0000)
fix the HAVE_GETCWD_NULL code to behave more like the
!HAVE_GETCWD_NULL code used to.

Include "xalloc.h".
(xgetcwd): Do not return NULL when memory is exhausted; instead,
invoke xalloc_die.

lib/xgetcwd.c

index 85ac368738950bfd7183c944ca2eedc8871ae8ee..1409bcfba7d684d628e6b1283a2e7303f1d6dd4e 100644 (file)
@@ -45,6 +45,8 @@ char *getwd ();
 # define getcwd(Buf, Max) getwd (Buf)
 #endif
 
+#include "xalloc.h"
+
 /* Return the current directory, newly allocated, arbitrarily long.
    Return NULL and set errno on error. */
 
@@ -52,7 +54,10 @@ char *
 xgetcwd ()
 {
 #if HAVE_GETCWD_NULL
-  return getcwd (NULL, 0);
+  char *cwd = getcwd (NULL, 0);
+  if (! cwd && errno == ENOMEM)
+    xalloc_die ();
+  return cwd;
 #else
 
   /* The initial buffer size for the working directory.  A power of 2
@@ -65,12 +70,9 @@ xgetcwd ()
 
   while (1)
     {
-      char *cwd;
+      char *buf = xmalloc (buf_size);
+      char *cwd = getcwd (buf, buf_size);
       int saved_errno;
-      char *buf = malloc (buf_size);
-      if (! buf)
-       return NULL;
-      cwd = getcwd (buf, buf_size);
       if (cwd)
        return cwd;
       saved_errno = errno;
@@ -79,10 +81,7 @@ xgetcwd ()
        return NULL;
       buf_size *= 2;
       if (buf_size == 0)
-       {
-         errno = ENOMEM;
-         return NULL;
-       }
+       xalloc_die ();
     }
 #endif
 }