[PATCH] D100672: [ADT] Add new type traits for type pack indexes
    David Blaikie via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Fri May 14 17:49:35 PDT 2021
    
    
  
dblaikie accepted this revision.
dblaikie added a comment.
This revision is now accepted and ready to land.
Sounds good - thanks!
================
Comment at: llvm/include/llvm/ADT/STLExtras.h:151-154
+  for (size_t I = 1; I <= sizeof...(Ts); ++I)
+    if (Matches[I])
+      return I - 1;
+  return sizeof...(Ts);
----------------
scott.linder wrote:
> dblaikie wrote:
> > scott.linder wrote:
> > > dblaikie wrote:
> > > > Could this be replaced with:
> > > > ```
> > > > return llvm::find(Matches, true) - std::begin(Matches);
> > > > ```
> > > > or something like that?
> > > > (similarly below in "AreTypesDistinct")?
> > > > 
> > > > Hmm, what's the purpose of the first element of the array being 'false', and then iterating from the second element and subtracting one from the index before returning?
> > > > 
> > > > Oh, that's to support the zero-length case? Fair enough. I don't mind either way, but maybe it'd be simpler/more obvious if that were done via specialization? - oh, what happens if you put the buffer value at the end rather than the beginning. In this algorithm you could put "true" at the end (and remove "false" from the start) and then it'd return 1 when sizeof...(Ts) is zero?
> > > > 
> > > Sure, I think `llvm::find` would need to be constexpr then? I assume that will ripple through some other things in `STLExtras.h`, so maybe I should do a pass to add `constexpr` wherever possible in `STLExtras.h`? Or in this case would just marking what I need be better?
> > > 
> > > Putting the extra element at the end and having it defined to return a size >= sizeof...(Ts) seems reasonable, especially as it is just a detail function. I'll make that change, thank you!
> > oh, sure if there's stuff that needs to be constexpr and isn't - if it's not a ton of stuff, can probably include it in this patch (adding the constexpr keyword as needed) - if it's a lot, maybe a separate preliminary patch. (I probably wouldn't bother adding unit tests for constexpr-ness, but treat it as a quasi-NFC change). (if you want to include only what's needed in this patch and also separately submit a patch to constexpr the rest (then maybe some testing may be needed, to ensure all the implementation details got constexpr'd correctly))
> It looks like `std::find` isn't `constexpr` until `C++20`, and `llvm::find` just wraps it. I think I could change `llvm::find` to have a standalone implementation and make it `constexpr`, but I don't know how often this will be useful. Do you have a preference on how I approach this?
Nah, that's OK. Whichever's cool - making our llvm::find constexpr would be nice (separate patch, though) - but equally if that's beyond what you want to do here - a comment saying "use find once it's constexpr/in C++20" or something like that.
Repository:
  rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D100672/new/
https://reviews.llvm.org/D100672
    
    
More information about the llvm-commits
mailing list