]> sourceware.org Git - glibc.git/commitdiff
mach: Make xpg_strerror_r set a message on error
authorSamuel Thibault <samuel.thibault@ens-lyon.org>
Sat, 27 Aug 2022 12:46:23 +0000 (14:46 +0200)
committerSamuel Thibault <samuel.thibault@ens-lyon.org>
Sat, 27 Aug 2022 12:56:35 +0000 (14:56 +0200)
posix advises to have strerror_r fill a message even when we are returning
an error.

This makes mach's xpg_strerror_r do this, like the generic version does.

Spotted by the libunistring testsuite test-strerror_r

sysdeps/mach/xpg-strerror.c

index 92bb67e2bc923290a08e5d953ea43d368b6c79e1..de75cc84ae2b976b746c22b04b9ac94a121e9679 100644 (file)
@@ -51,7 +51,11 @@ __xpg_strerror_r (int errnum, char *buf, size_t buflen)
   code = err_get_code (errnum);
 
   if (system > err_max_system || ! __mach_error_systems[system].bad_sub)
-    return EINVAL;
+    {
+      __snprintf (buf, buflen, "%s%X", _("Error in unknown error system: "),
+                 errnum);
+      return EINVAL;
+    }
 
   es = &__mach_error_systems[system];
 
@@ -62,11 +66,11 @@ __xpg_strerror_r (int errnum, char *buf, size_t buflen)
   else
     estr = (const char *) _(es->subsystem[sub].codes[code]);
 
-  size_t estrlen = strlen (estr) + 1;
+  size_t estrlen = strlen (estr);
 
-  if (buflen < estrlen)
-    return ERANGE;
+  /* Terminate the string in any case.  */
+  if (buflen > 0)
+    *((char *) __mempcpy (buf, estr, MIN (buflen - 1, estrlen))) = '\0';
 
-  memcpy (buf, estr, estrlen);
-  return 0;
+  return buflen <= estrlen ? ERANGE : 0;
 }
This page took 0.046006 seconds and 5 git commands to generate.