Commit 316ae7e2 authored by Victor Zverovich's avatar Victor Zverovich

Implement more printf length specifiers.

parent 6a8becb5
......@@ -908,26 +908,30 @@ void fmt::internal::PrintfFormatter<Char>::format(
}
// Parse length and convert the argument to the required type.
switch (*s) {
case 'h': {
++s;
switch (*s++) {
case 'h':
if (*s == 'h')
ArgConverter<signed char>(arg, *++s).visit(arg);
else
ArgConverter<short>(arg, *s).visit(arg);
break;
}
case 'l':
++s;
ArgConverter<long>(arg, *s).visit(arg);
break;
case 'j':
ArgConverter<intmax_t>(arg, *s).visit(arg);
break;
case 'z':
ArgConverter<size_t>(arg, *s).visit(arg);
break;
case 't':
ArgConverter<ptrdiff_t>(arg, *s).visit(arg);
break;
case 'L':
// TODO: handle length
++s;
break;
default:
--s;
}
// Parse type.
......
......@@ -350,8 +350,8 @@ TEST(PrintfTest, Length) {
TestLength<unsigned char>("hh");
TestLength<short>("h");
TestLength<unsigned short>("h");
//TestLength<long>("l");
//TestLength<unsigned long>("l");
TestLength<long>("l");
TestLength<unsigned long>("l");
// TODO: more tests
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment