Reputation: 1004
The output for this code printed out ‘Success’.
printf("%m\n");
Upvotes: 59
Views: 32824
Reputation: 5201
Actually, the manual of printf() concerning %m is quite laconic:
m (Glibc extension; supported by uClibc and musl.) Print output
of strerror(errno). No argument is required.
But strerror()
is not multi-thread safe: it is not reentrant. The thread-safe version is strerror_r().
A little study of the GLIBC implementation shows that %m is actually equivalent to strerror_r()
and not to strerror()
. Hence %m is thread-safe! The online manual is consequently wrong (or at least not accurate enough)!
Note: From GLIBC 2.32, strerror()
has been made MT-safe (cf. this answer)
Upvotes: 9
Reputation: 145829
m
conversion specifier is not C but is a GNU extension to printf
:
From GNU documentation:
http://www.gnu.org/software/libc/manual/html_node/Other-Output-Conversions.html
The ‘%m’ conversion prints the string corresponding to the error code in errno. See Error Messages. Thus:
fprintf (stderr, "can't open `%s': %m\n", filename);
is equivalent to:
fprintf (stderr, "can't open `%s': %s\n", filename, strerror (errno));
The ‘%m’ conversion is a GNU C Library extension.
So:
printf("%m\n", d);
is equivalent to
printf("%s\n", strerror (errno), d);
which is equivalent to
printf("%s\n", strerror (errno));
Note that %m
does not require an argument. Here printf("%m\n", d)
and printf("%s\n", strerror (errno), d)
have more arguments than required: with printf
if there are extra trailing arguments, they are just evaluated and ignored.
Upvotes: 75