(INTERNAL): Explicitly set errno and avoid returning ERANGE if this
authordrepper <drepper>
Thu, 4 Sep 2003 04:43:12 +0000 (04:43 +0000)
committerdrepper <drepper>
Thu, 4 Sep 2003 04:43:12 +0000 (04:43 +0000)
wasn't intended.

nss/getXXbyYY_r.c

index aca6a94..a0e0e00 100644 (file)
@@ -247,13 +247,24 @@ done:
 #ifdef POSTPROCESS
   POSTPROCESS;
 #endif
-  return (status == NSS_STATUS_SUCCESS ? 0
+
+  int result;
+  if (status == NSS_STATUS_SUCCESS)
+    result = 0;
+  /* Don't pass back ERANGE if this is not for a too-small buffer.  */
+  else if (errno == ERANGE && status != NSS_STATUS_TRYAGAIN)
+    {
 #ifdef NEED_H_ERRNO
-         /* These functions only set errno if h_errno is NETDB_INTERNAL.  */
-         : status == NSS_STATUS_TRYAGAIN && *h_errnop != NETDB_INTERNAL
-         ? EAGAIN
+      /* These functions only set errno if h_errno is NETDB_INTERNAL.  */
+      if (*h_errnop != NETDB_INTERNAL)
 #endif
-         : errno);
+       result = ENOENT;
+    }
+  else
+    return errno;
+
+  __set_errno (result);
+  return result;
 }