[libc-commits] [libc] [libc] Optimize BigInt→decimal in IntegerToString (PR #123580)
via libc-commits
libc-commits at lists.llvm.org
Mon Feb 3 08:30:07 PST 2025
================
@@ -164,6 +164,168 @@ template <size_t radix> using Custom = details::Fmt<radix>;
} // namespace radix
+// Extract the low-order decimal digit from a value of integer type T. The
+// returned value is the digit itself, from 0 to 9. The input value is passed
+// by reference, and modified by dividing by 10, so that iterating this
+// function extracts all the digits of the original number one at a time from
+// low to high.
+template <typename T, cpp::enable_if_t<cpp::is_integral_v<T>, int> = 0>
+LIBC_INLINE uint8_t extract_decimal_digit(T &value) {
----------------
lntue wrote:
For free functions, do you mind using `enable_if_t` on the return type of the function? That will free the second template parameter to be used if needed.
https://github.com/llvm/llvm-project/pull/123580
More information about the libc-commits
mailing list