Home | History | Annotate | Download | only in basic.lookup.argdep
      1 // RUN: %clang_cc1 -fsyntax-only -verify %s
      2 
      3 namespace N {
      4   struct X { };
      5 
      6   X operator+(X, X);
      7 
      8   void f(X); // expected-note 2 {{'N::f' declared here}}
      9   void g(X); // expected-note{{candidate function}}
     10 
     11   void test_multiadd(X x) {
     12     (void)(x + x);
     13   }
     14 }
     15 
     16 namespace M {
     17   struct Y : N::X { };
     18 }
     19 
     20 void f();
     21 
     22 void test_operator_adl(N::X x, M::Y y) {
     23   (void)(x + x);
     24   (void)(y + y);
     25 }
     26 
     27 void test_func_adl(N::X x, M::Y y) {
     28   f(x);
     29   f(y);
     30   (f)(x); // expected-error{{too many arguments to function call, expected 0, have 1; did you mean 'N::f'?}}
     31   ::f(x); // expected-error{{too many arguments to function call, expected 0, have 1; did you mean 'N::f'?}}
     32 }
     33 
     34 namespace N {
     35   void test_multiadd2(X x) {
     36     (void)(x + x);
     37   }
     38 }
     39 
     40 
     41 void test_func_adl_only(N::X x) {
     42   g(x);
     43 }
     44 
     45 namespace M {
     46   int g(N::X); // expected-note{{candidate function}}
     47 
     48   void test(N::X x) {
     49     g(x); // expected-error{{call to 'g' is ambiguous}}
     50     int i = (g)(x);
     51 
     52     int g(N::X);
     53     g(x); // okay; calls locally-declared function, no ADL
     54   }
     55 }
     56 
     57 
     58 void test_operator_name_adl(N::X x) {
     59   (void)operator+(x, x);
     60 }
     61 
     62 struct Z { };
     63 int& f(Z);
     64 
     65 namespace O {
     66   char &f();
     67   void test_global_scope_adl(Z z) {
     68     {
     69       int& ir = f(z);
     70     }
     71   }
     72 }
     73 
     74 extern "C" {
     75   struct L { int x; };
     76 }
     77 
     78 void h(L); // expected-note{{candidate function}}
     79 
     80 namespace P {
     81   void h(L); // expected-note{{candidate function}}
     82   void test_transparent_context_adl(L l) {
     83     {
     84       h(l); // expected-error {{call to 'h' is ambiguous}}
     85     }
     86   }
     87 }
     88 
     89 namespace test5 {
     90   namespace NS {
     91     struct A;
     92     void foo(void (*)(A&));
     93   }
     94   void bar(NS::A& a);
     95 
     96   void test() {
     97     foo(&bar);
     98   }
     99 }
    100 
    101 // PR6762: __builtin_va_list should be invisible to ADL on all platforms.
    102 void test6_function(__builtin_va_list &argv);
    103 namespace test6 {
    104   void test6_function(__builtin_va_list &argv);
    105 
    106   void test() {
    107     __builtin_va_list args;
    108     test6_function(args);
    109   }
    110 }
    111 
    112 // PR13682: we might need to instantiate class temploids.
    113 namespace test7 {
    114   namespace inner {
    115     class A {};
    116     void test7_function(A &);
    117   }
    118   template <class T> class B : public inner::A {};
    119 
    120   void test(B<int> &ref) {
    121     test7_function(ref);
    122   }
    123 }
    124 
    125 // Like test7, but ensure we don't complain if the type is properly
    126 // incomplete.
    127 namespace test8 {
    128   template <class T> class B;
    129   void test8_function(B<int> &);
    130 
    131   void test(B<int> &ref) {
    132     test8_function(ref);
    133   }
    134 }
    135