Replace some append_format with push_back

This commit is contained in:
ridiculousfish 2013-03-21 22:36:21 -07:00
parent e0e0bcdc1e
commit 1d93e89eed

View file

@ -190,7 +190,7 @@ void builtin_printf_state_t::verify_numeric(const wchar_t *s, const wchar_t *end
} }
template<typename T> template<typename T>
T raw_string_to_scalar_type(const wchar_t *s, wchar_t ** end); static T raw_string_to_scalar_type(const wchar_t *s, wchar_t ** end);
template<> template<>
intmax_t raw_string_to_scalar_type(const wchar_t *s, wchar_t ** end) intmax_t raw_string_to_scalar_type(const wchar_t *s, wchar_t ** end)
@ -212,7 +212,7 @@ long double raw_string_to_scalar_type(const wchar_t *s, wchar_t ** end)
} }
template<typename T> template<typename T>
T string_to_scalar_type(const wchar_t *s, builtin_printf_state_t *state) static T string_to_scalar_type(const wchar_t *s, builtin_printf_state_t *state)
{ {
T val; T val;
if (*s == L'\"' || *s == L'\'') if (*s == L'\"' || *s == L'\'')
@ -237,31 +237,31 @@ static void print_esc_char(wchar_t c)
switch (c) switch (c)
{ {
case L'a': /* Alert. */ case L'a': /* Alert. */
append_format(stdout_buffer, L"%lc", L'\a'); stdout_buffer.push_back(L'\a');
break; break;
case L'b': /* Backspace. */ case L'b': /* Backspace. */
append_format(stdout_buffer, L"%lc", L'\b'); stdout_buffer.push_back(L'\b');
break; break;
case L'c': /* Cancel the rest of the output. */ case L'c': /* Cancel the rest of the output. */
return; return;
break; break;
case L'f': /* Form feed. */ case L'f': /* Form feed. */
append_format(stdout_buffer, L"%lc", L'\f'); stdout_buffer.push_back(L'\f');
break; break;
case L'n': /* New line. */ case L'n': /* New line. */
append_format(stdout_buffer, L"%lc", L'\n'); stdout_buffer.push_back(L'\n');
break; break;
case L'r': /* Carriage retturn. */ case L'r': /* Carriage return. */
append_format(stdout_buffer, L"%lc", L'\r'); stdout_buffer.push_back(L'\r');
break; break;
case L't': /* Horizontal tab. */ case L't': /* Horizontal tab. */
append_format(stdout_buffer, L"%lc", L'\t'); stdout_buffer.push_back(L'\t');
break; break;
case L'v': /* Vertical tab. */ case L'v': /* Vertical tab. */
append_format(stdout_buffer, L"%lc", L'\v'); stdout_buffer.push_back(L'\v');
break; break;
default: default:
append_format(stdout_buffer, L"%lc", c); stdout_buffer.push_back(c);
break; break;
} }
} }
@ -538,7 +538,7 @@ int builtin_printf_state_t::print_formatted(const wchar_t *format, int argc, wch
have_field_width = have_precision = false; have_field_width = have_precision = false;
if (*f == L'%') if (*f == L'%')
{ {
append_format(stdout_buffer, L"%lc", L'%'); stdout_buffer.push_back(L'%');
break; break;
} }
if (*f == L'b') if (*f == L'b')
@ -562,9 +562,7 @@ int builtin_printf_state_t::print_formatted(const wchar_t *format, int argc, wch
{ {
switch (*f) switch (*f)
{ {
#if (__GLIBC__ == 2 && 2 <= __GLIBC_MINOR__) || 3 <= __GLIBC__
case L'I': case L'I':
#endif
case L'\'': case L'\'':
ok['a'] = ok['A'] = ok['c'] = ok['e'] = ok['E'] = ok['a'] = ok['A'] = ok['c'] = ok['e'] = ok['E'] =
ok['o'] = ok['s'] = ok['x'] = ok['X'] = false; ok['o'] = ok['s'] = ok['x'] = ok['X'] = false;
@ -680,7 +678,7 @@ no_more_flag_characters:
break; break;
default: default:
append_format(stdout_buffer, L"%lc", *f); stdout_buffer.push_back(*f);
} }
} }
return save_argc - argc; return save_argc - argc;
@ -697,7 +695,7 @@ static int builtin_printf(parser_t &parser, wchar_t **argv)
if (argc <= 1) if (argc <= 1)
{ {
append_format(stderr_buffer, _(L"missing operand")); append_format(stderr_buffer, _(L"printf: not enough arguments"));
return STATUS_BUILTIN_ERROR; return STATUS_BUILTIN_ERROR;
} }