Fix for errno-style error reporting in printf

This commit is contained in:
ridiculousfish 2013-03-24 15:51:18 -07:00
parent 3a475a99fc
commit 40c0c5a298

View file

@ -66,7 +66,7 @@ struct builtin_printf_state_t
{ {
} }
void verify_numeric(const wchar_t *s, const wchar_t *end); void verify_numeric(const wchar_t *s, const wchar_t *end, int errcode);
void print_direc(const wchar_t *start, size_t length, wchar_t conversion, void print_direc(const wchar_t *start, size_t length, wchar_t conversion,
bool have_field_width, int field_width, bool have_field_width, int field_width,
@ -216,11 +216,11 @@ void builtin_printf_state_t::append_format_output(const wchar_t *fmt, ...)
} }
void builtin_printf_state_t::verify_numeric(const wchar_t *s, const wchar_t *end) void builtin_printf_state_t::verify_numeric(const wchar_t *s, const wchar_t *end, int errcode)
{ {
if (errno) if (errcode != 0)
{ {
this->fatal_error(L"%ls", s); this->fatal_error(L"%ls: %s", s, strerror(errcode));
} }
else if (*end) else if (*end)
{ {
@ -267,7 +267,7 @@ static T string_to_scalar_type(const wchar_t *s, builtin_printf_state_t *state)
wchar_t *end = NULL; wchar_t *end = NULL;
errno = 0; errno = 0;
val = raw_string_to_scalar_type<T>(s, &end); val = raw_string_to_scalar_type<T>(s, &end);
state->verify_numeric(s, end); state->verify_numeric(s, end, errno);
} }
return val; return val;
} }
@ -405,11 +405,7 @@ void builtin_printf_state_t::print_direc(const wchar_t *start, size_t length, wc
// Start with everything except the conversion specifier // Start with everything except the conversion specifier
wcstring fmt(start, length); wcstring fmt(start, length);
/* Create a null-terminated copy of the % directive, with an /* Create a copy of the % directive, with an intmax_t-wide width modifier substituted for any existing integer length modifier. */
intmax_t-wide width modifier substituted for any existing
integer length modifier. */
{
// Append the appropriate width specifier
switch (conversion) switch (conversion)
{ {
case L'd': case L'd':
@ -436,7 +432,6 @@ void builtin_printf_state_t::print_direc(const wchar_t *start, size_t length, wc
// Append the conversion itself // Append the conversion itself
fmt.push_back(conversion); fmt.push_back(conversion);
}
switch (conversion) switch (conversion)
{ {
@ -735,6 +730,6 @@ static int builtin_printf(parser_t &parser, wchar_t **argv)
argc -= args_used; argc -= args_used;
argv += args_used; argv += args_used;
} }
while (args_used > 0 && argc > 0); while (args_used > 0 && argc > 0 && ! state.early_exit);
return state.exit_code; return state.exit_code;
} }