2 @section @code{strerror_r}
5 POSIX specification:@* @url{http://www.opengroup.org/onlinepubs/9699919799/functions/strerror_r.html}
7 Gnulib module: strerror_r-posix
9 Portability problems fixed by Gnulib:
12 This function is missing on some platforms:
13 NetBSD 3.0, Minix 3.1.8, HP-UX 11.23, IRIX 6.5, Solaris 9, mingw, MSVC 14.
15 glibc, Cygwin, and Android have an incompatible version of this function.
16 The POSIX compliant code
18 char *s = (strerror_r (err, buf, buflen) == 0 ? buf : NULL);
20 is essentially equivalent to this code using the glibc function:
22 char *s = strerror_r (err, buf, buflen);
25 This function clobbers the @code{strerror} buffer on some platforms:
28 This function is sometimes not declared in @code{<string.h>} on some platforms:
31 The third argument is of type @code{int} instead of @code{size_t} on some
35 When this function fails, it returns @minus{}1 and sets @code{errno}, instead of
36 returning the error number, on some platforms:
37 glibc 2.12 with @code{-D_POSIX_C_SOURCE=200112L}, AIX 6.1, OSF/1 5.1.
39 When this function fails, it corrupts @code{errno}, on some platforms:
42 This function does not support many error values defined in @code{<errno.h>} on
46 This function does not support the error values that are specified by POSIX
47 but not defined by the system, on some platforms:
48 OpenBSD 4.0, OSF/1 5.1, NonStop Kernel, Cygwin 1.5.x.
50 This function reports failure for @code{strerror_r(0, buf, len)},
51 although POSIX requires this to succeed, on some platforms:
54 This function produces a different string for @code{0} than
55 @code{strerror} on some platforms:
58 This function always fails when the third argument is less than 80 on some
62 When the buffer is too small and the value is in range, this function
63 does not fail, but instead truncates the result and returns 0 on some
65 AIX 6.1, OSF/1 5.1, Haiku 2017.
67 When the value is not in range or the buffer is too small, this
68 function fails to leave a NUL-terminated string in the buffer on some
70 glibc 2.13, FreeBSD 8.2, Solaris 10.
72 When the value is out of range but the buffer is too small, this
73 function does not always return the longest possible string on some
78 Portability problems not fixed by Gnulib: