]> granicus.if.org Git - clang/commitdiff
Within a template, qualified name lookup can refer to a non-dependent type
authorDouglas Gregor <dgregor@apple.com>
Sun, 1 Nov 2009 17:08:18 +0000 (17:08 +0000)
committerDouglas Gregor <dgregor@apple.com>
Sun, 1 Nov 2009 17:08:18 +0000 (17:08 +0000)
that is not known to be a base class at template definition time due
to some dependent base class. Treat qualified name lookup that refers
to a non-static data member or function as implicit class member
access when the "this" type would be dependent.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@85718 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaExprCXX.cpp
test/SemaTemplate/instantiate-method.cpp

index 32eeddb0fe719dd1d35109ac7d898c744a4081c8..fad1f3e2639403ec584ee8cc16df39d2680bfe23 100644 (file)
@@ -2395,6 +2395,12 @@ bool Sema::isImplicitMemberReference(const CXXScopeSpec *SS, NamedDecl *D,
   // Determine whether the declaration(s) we found are actually in a base 
   // class. If not, this isn't an implicit member reference.
   ThisType = MD->getThisType(Context);
+  
+  // If the type of "this" is dependent, we can't tell if the member is in a 
+  // base class or not, so treat this as a dependent implicit member reference.
+  if (ThisType->isDependentType())
+    return true;
+  
   QualType CtxType = Context.getTypeDeclType(cast<CXXRecordDecl>(Ctx));
   QualType ClassType
     = Context.getTypeDeclType(cast<CXXRecordDecl>(MD->getParent()));
index f7c09ef87900813841fc3c2f10370a93269ca5d8..df1e1d964eb6d3196da9ed0965e36723a516cfca 100644 (file)
@@ -81,3 +81,20 @@ int *a(A0<int> &x0, A1<int> &x1) {
   int *y0 = x0;
   int *y1 = x1; // expected-error{{initializing}}
 }
+
+struct X0Base {
+  int &f();
+};
+
+template<typename T>
+struct X0 : X0Base {
+};
+
+template<typename U>
+struct X1 : X0<U> {
+  int &f2() { return X0Base::f(); }
+};
+
+void test_X1(X1<int> x1i) {
+  int &ir = x1i.f2();
+}