[libcxx-commits] [PATCH] D114001: [libc++][format] Adds formatter floating-point.
Arthur O'Dwyer via Phabricator via libcxx-commits
libcxx-commits at lists.llvm.org
Tue Jan 18 10:23:18 PST 2022
Quuxplusone added inline comments.
================
Comment at: libcxx/include/__format/formatter.h:211
+ _LIBCPP_ASSERT(__first <= __last, "Not a valid range");
+ _LIBCPP_ASSERT(__num_trailing_zeros > 0, "The overload not writing trailing zeros should have been used");
+
----------------
`_LIBCPP_ASSERT(__num_trailing_zeros > 0, "The overload not writing trailing zeros should have been used");`
I haven't looked really closely at the logic around this, but it feels very weird that we have two different overloads — one taking `__num_trailing_zeros` but internally checking that it's never zero, and one //not// taking `__num_trailing_zeros` and internally assuming that it's always zero. Then, in the caller (new line 603), we have `if (__num_trailing_zeros) /*call the first overload*/ else /*call the second overload*/`. Couldn't we just have one overload, and no precondition, and do the `if` test //inside// the callee?
Also, this smells very much like "When Should You Give Two Things the Same Name?". Why do you need the two overloads to //both// be named `__write`, so that accidentally omitting an argument will do the wrong thing? Could you simply name them `__write` and `__write_with_trailing_zeros` instead?
If so, then //even if you keep everything else the same//, your precondition-failure message can use the greppable and unambiguous name "`__write_with_trailing_zeros`" in place of the verbose epithet "The overload not writing trailing zeros".
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D114001/new/
https://reviews.llvm.org/D114001
More information about the libcxx-commits
mailing list