aaron.ballman accepted this revision.
aaron.ballman added a comment.

LGTM



================
Comment at: clang/test/SemaCXX/type-traits.cpp:822
+
+  { int a[F(__is_referenceable(void))]; }
+}
----------------
aaron.ballman wrote:
> cjdb wrote:
> > aaron.ballman wrote:
> > > I think we should have test cases for the following:
> > > ```
> > > struct incomplete;
> > > 
> > > __is_referenceable(struct incomplete); // Also interesting to make sure 
> > > we handle elaborated type specifiers properly
> > > 
> > > typedef void function_type(int);
> > > __is_referenceable(function_type); // Note, this is not a function 
> > > *pointer* type
> > > 
> > > struct S {
> > >   void func1() &;
> > >   void func2() const;
> > > };
> > > 
> > > // Both of these should be false, by my understanding of what 
> > > "referenceable" means in the standard.
> > > __is_referenceable(decltype(&S::func1));
> > > __is_referenceable(decltype(&S::func2));
> > > ```
> > I think the latter two are pointer-to-member functions, which are 
> > referenceable. We want to check `void(int) const`, which is done on the 
> > last green line of this file.
> Do you have a test for:
> ```
> struct S {
>   void func1() &;
>   void func2() const;
> };
> 
> // Both of these should be false, by my understanding of what "referenceable" 
> means in the standard.
> __is_referenceable(decltype(&S::func1));
> __is_referenceable(decltype(&S::func2));
> ```
> 
Ah thank you for showing me we already had the coverage!


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D135177

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

Reply via email to