dexonsmith added inline comments.

================
Comment at: clang/include/clang/StaticAnalyzer/Core/AnalyzerOptions.h:261-263
   /// The inlining stack depth limit.
-  // Cap the stack depth at 4 calls (5 stack frames, base + 4 calls).
-  unsigned InlineMaxStackDepth = 5;
+  unsigned InlineMaxStackDepth;
 
----------------
Hmm, I wonder if this is entirely better. It's not obvious at all, looking at 
the code here, whether `InlineMaxStackDepth` can be used without getting 
initialized at all.

I agree we should have the default value in two places -- I think removing 
assignment to 5 is the right thing to do -- but I'm not sure leaving this 
entirely uninitialized is a good thing. WDYT of initializing it to 0?


================
Comment at: clang/lib/Frontend/CompilerInvocation.cpp:287
+static void
+denormalizeString(SmallVectorImpl<const char *> &Args, const char *Spelling,
+                  CompilerInvocation::StringAllocator SA, unsigned, T &&Value) 
{
----------------
jansvoboda11 wrote:
> dexonsmith wrote:
> > jansvoboda11 wrote:
> > > We should keep an eye on the number of instantiations of this function 
> > > template (and `normalizeStringIntegral`).
> > > 
> > > If it grows, we can employ the SFINAE trick used for 
> > > `makeFlagToValueNormalizer`.
> > Does it work to take the parameter as a `Twine` to avoid the template?
> > ```
> > static void
> > denormalizeString(SmallVectorImpl<const char *> &Args, const char *Spelling,
> >                   CompilerInvocation::StringAllocator SA, unsigned, Twine 
> > Value) {
> >   Args.push_back(Spelling);
> >   Args.push_back(SA(Value));
> > }
> > ```
> In general no. The `Twine` constructor is `explicit` for some types 
> (integers, chars, etc.).
Okay, then I suggest at least handling the ones that are convertible separately 
(without the template):
```
static void denormalizeString(..., Twine Value) {
  Args.push_back(Spelling);
  Args.push_back(SA(Value));
}

template <class T,
          std::enable_if_t<!std::is_convertible<T, Twine>::value &&
                           std::is_constructible<Twine, T>::value, bool> = 
false>
static void denormalizeString(..., T Value) {
  denormalizeString(..., Twine(Value));
}
```



================
Comment at: clang/lib/Frontend/CompilerInvocation.cpp:289-290
+                  CompilerInvocation::StringAllocator SA, unsigned, T &&Value) 
{
+  static_assert(std::is_constructible<Twine, T>::value,
+                "Cannot convert this value to Twine");
   Args.push_back(Spelling);
----------------
I think it'd be better to reduce the overload set using `std::enable_if` than 
to add a `static_assert` here.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D84186/new/

https://reviews.llvm.org/D84186

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to