From: clyne Date: Mon, 29 Jun 2020 17:21:04 +0000 (-0400) Subject: Merge branch 'master' into digits_array X-Git-Url: https://code.bitgloo.com/?a=commitdiff_plain;h=95d70525cec057b4ba556bdb552983e079ea70fa;p=clyne%2Fconstexpr-to-string.git Merge branch 'master' into digits_array --- 95d70525cec057b4ba556bdb552983e079ea70fa diff --cc to_string.hpp index 2d18589,eb363f0..63b52ab --- a/to_string.hpp +++ b/to_string.hpp @@@ -18,15 -15,15 +18,15 @@@ constexpr auto digit_count = sizeof(dig * @tparam N Number to convert * @tparam base Desired base, can be from 2 to 36 */ - template, int> = 0, - std::enable_if_t<(base > 1 && base < 37), int> = 0> + std::enable_if_t<(base > 1 && base < digit_count), int> = 0> - struct to_string_t { + class to_string_t { // The lambda calculates what the string length of N will be, so that `buf` // fits to the number perfectly. - char_type buf[([] { + char_type buf[([]() constexpr noexcept { unsigned int len = N > 0 ? 1 : 2; - for (auto n = N < 0 ? -N : N; n; len++, n /= base); + for (auto n = N; n; len++, n /= base); return len; }())] = {}; @@@ -34,11 -32,11 +35,11 @@@ * Constructs the object, filling `buf` with the string representation of N. */ constexpr to_string_t() noexcept { + auto ptr = end(); + *--ptr = '\0'; if (N != 0) { - auto ptr = buf + sizeof(buf) / sizeof(buf[0]); - *--ptr = '\0'; - for (auto n = N < 0 ? -N : N; n; n /= base) - *--ptr = digits[n % base]; + for (auto n = N; n; n /= base) - *--ptr = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"[(N < 0 ? -1 : 1) * (n % base)]; ++ *--ptr = digits[(N < 0 ? -1 : 1) * (n % base)]; if (N < 0) *--ptr = '-'; } else {