[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