diff --git a/include/fmt/format.h b/include/fmt/format.h index 116fc539..75333ef8 100644 --- a/include/fmt/format.h +++ b/include/fmt/format.h @@ -842,9 +842,8 @@ Char* format_uint(Char* buffer, internal::fallback_uintptr n, int num_digits, template inline It format_uint(It out, UInt value, int num_digits, bool upper = false) { - // Buffer should be large enough to hold all digits (digits / BASE_BITS + 1) - // and null. - char buffer[std::numeric_limits::digits / BASE_BITS + 2]; + // Buffer should be large enough to hold all digits (digits / BASE_BITS + 1). + char buffer[std::numeric_limits::digits / BASE_BITS + 1]; format_uint(buffer, value, num_digits, upper); return internal::copy_str(buffer, buffer + num_digits, out); } @@ -966,14 +965,10 @@ template It write_exponent(int exp, It it) { if (exp >= 100) { *it++ = static_cast(static_cast('0' + exp / 100)); exp %= 100; - const char* d = data::digits + exp * 2; - *it++ = static_cast(d[0]); - *it++ = static_cast(d[1]); - } else { - const char* d = data::digits + exp * 2; - *it++ = static_cast(d[0]); - *it++ = static_cast(d[1]); } + const char* d = data::digits + exp * 2; + *it++ = static_cast(d[0]); + *it++ = static_cast(d[1]); return it; } @@ -1226,7 +1221,7 @@ void arg_map::init(const basic_format_args& args) { if (map_) return; map_ = new entry[args.max_size()]; if (args.is_packed()) { - for (unsigned i = 0; /*nothing*/; ++i) { + for (unsigned i = 0;; ++i) { internal::type arg_type = args.type(i); if (arg_type == internal::none_type) return; if (arg_type == internal::named_arg_type) push_back(args.values_[i]); @@ -1239,15 +1234,13 @@ void arg_map::init(const basic_format_args& args) { } } -/** - This template provides operations for formatting and writing data into a - character range. - */ +// This template provides operations for formatting and writing data into a +// character range. template class basic_writer { public: - typedef typename Range::value_type char_type; - typedef decltype(std::declval().begin()) iterator; - typedef basic_format_specs format_specs; + using char_type = typename Range::value_type; + using iterator = typename Range::iterator; + using format_specs = basic_format_specs; private: iterator out_; // Output iterator. @@ -1403,7 +1396,7 @@ template class basic_writer { bin_writer<3>{abs_value, num_digits}); } - enum { SEP_SIZE = 1 }; + enum { sep_size = 1 }; struct num_writer { unsigned_type abs_value; @@ -1411,7 +1404,7 @@ template class basic_writer { char_type sep; template void operator()(It&& it) const { - basic_string_view s(&sep, SEP_SIZE); + basic_string_view s(&sep, sep_size); // Index of a decimal digit with the least significant digit having // index 0. unsigned digit_index = 0; @@ -1428,7 +1421,7 @@ template class basic_writer { void on_num() { int num_digits = internal::count_digits(abs_value); char_type sep = internal::thousands_sep(writer.locale_); - int size = num_digits + SEP_SIZE * ((num_digits - 1) / 3); + int size = num_digits + sep_size * ((num_digits - 1) / 3); writer.write_int(size, get_prefix(), specs, num_writer{abs_value, size, sep}); } @@ -1438,7 +1431,7 @@ template class basic_writer { } }; - enum { INF_SIZE = 3 }; // This is an enum to workaround a bug in MSVC. + enum { inf_size = 3 }; // This is an enum to workaround a bug in MSVC. struct inf_or_nan_writer { char sign; @@ -1446,7 +1439,7 @@ template class basic_writer { const char* str; size_t size() const { - return static_cast(INF_SIZE + (sign ? 1 : 0) + + return static_cast(inf_size + (sign ? 1 : 0) + (as_percentage ? 1 : 0)); } size_t width() const { return size(); } @@ -1454,7 +1447,7 @@ template class basic_writer { template void operator()(It&& it) const { if (sign) *it++ = static_cast(sign); it = internal::copy_str( - str, str + static_cast(INF_SIZE), it); + str, str + static_cast(inf_size), it); if (as_percentage) *it++ = static_cast('%'); } }; @@ -1672,12 +1665,12 @@ using writer = basic_writer>; template class arg_formatter_base { public: - typedef typename Range::value_type char_type; - typedef decltype(std::declval().begin()) iterator; - typedef basic_format_specs format_specs; + using char_type = typename Range::value_type; + using iterator = typename Range::iterator; + using format_specs = basic_format_specs; private: - typedef basic_writer writer_type; + using writer_type = basic_writer; writer_type writer_; format_specs* specs_; diff --git a/include/fmt/ostream.h b/include/fmt/ostream.h index 49aa5805..f589fcae 100644 --- a/include/fmt/ostream.h +++ b/include/fmt/ostream.h @@ -16,8 +16,8 @@ namespace internal { template class formatbuf : public std::basic_streambuf { private: - typedef typename std::basic_streambuf::int_type int_type; - typedef typename std::basic_streambuf::traits_type traits_type; + using int_type = typename std::basic_streambuf::int_type; + using traits_type = typename std::basic_streambuf::traits_type; buffer& buffer_; @@ -63,7 +63,7 @@ template class is_streamable { template static std::false_type test(...); - typedef decltype(test(0)) result; + using result = decltype(test(0)); public: static const bool value = result::value; @@ -73,12 +73,12 @@ template class is_streamable { template void write(std::basic_ostream& os, buffer& buf) { const Char* buf_data = buf.data(); - typedef std::make_unsigned::type UnsignedStreamSize; - UnsignedStreamSize size = buf.size(); - UnsignedStreamSize max_size = - internal::to_unsigned((std::numeric_limits::max)()); + using unsigned_streamsize = std::make_unsigned::type; + unsigned_streamsize size = buf.size(); + unsigned_streamsize max_size = + to_unsigned((std::numeric_limits::max)()); do { - UnsignedStreamSize n = size <= max_size ? size : max_size; + unsigned_streamsize n = size <= max_size ? size : max_size; os.write(buf_data, static_cast(n)); buf_data += n; size -= n; @@ -87,7 +87,7 @@ void write(std::basic_ostream& os, buffer& buf) { template void format_value(buffer& buf, const T& value) { - internal::formatbuf format_buf(buf); + formatbuf format_buf(buf); std::basic_ostream output(&format_buf); output.exceptions(std::ios_base::failbit | std::ios_base::badbit); output << value; @@ -96,13 +96,12 @@ void format_value(buffer& buf, const T& value) { // Formats an object of type T that has an overloaded ostream operator<<. template -struct fallback_formatter::value>> +struct fallback_formatter::value>> : formatter, Char> { template auto format(const T& value, Context& ctx) -> decltype(ctx.out()) { basic_memory_buffer buffer; - internal::format_value(buffer, value); + format_value(buffer, value); basic_string_view str(buffer.data(), buffer.size()); return formatter, Char>::format(str, ctx); }