Sema: Provide a valid source location when instantiating templates based on a CXXDefa...
authorBenjamin Kramer <benny.kra@googlemail.com>
Fri, 23 Nov 2012 17:04:52 +0000 (17:04 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Fri, 23 Nov 2012 17:04:52 +0000 (17:04 +0000)
Fixes PR13758.

llvm-svn: 168521

clang/include/clang/AST/ExprCXX.h
clang/lib/Sema/SemaOverload.cpp
clang/test/SemaTemplate/default-expr-arguments.cpp

index d4a0c32..9f213f1 100644 (file)
@@ -795,6 +795,8 @@ public:
     return SourceRange();
   }
 
+  SourceLocation getExprLoc() const LLVM_READONLY { return Loc; }
+
   static bool classof(const Stmt *T) {
     return T->getStmtClass() == CXXDefaultArgExprClass;
   }
index 549fa8f..0c37c59 100644 (file)
@@ -2980,7 +2980,7 @@ IsUserDefinedConversion(Sema &S, Expr *From, QualType ToType,
          S.IsDerivedFrom(From->getType(), ToType)))
       ConstructorsOnly = true;
 
-    S.RequireCompleteType(From->getLocStart(), ToType, 0);
+    S.RequireCompleteType(From->getExprLoc(), ToType, 0);
     // RequireCompleteType may have returned true due to some invalid decl
     // during template instantiation, but ToType may be complete enough now
     // to try to recover.
index 1eefa9f..4e76a5a 100644 (file)
@@ -303,3 +303,21 @@ namespace PR12581 {
   {
   }
 }
+
+namespace PR13758 {
+  template <typename T> struct move_from {
+    T invalid; // expected-error {{field has incomplete type 'void'}}
+  };
+  template <class K>
+  struct unordered_map {
+    explicit unordered_map(int n = 42);
+    unordered_map(move_from<K> other);
+  };
+  template<typename T>
+  void StripedHashTable() {
+    new unordered_map<void>(); // expected-note {{in instantiation of template class 'PR13758::move_from<void>' requested here}}
+  }
+  void tt() {
+    StripedHashTable<int>(); // expected-note {{in instantiation of function template specialization 'PR13758::StripedHashTable<int>' requested here}}
+  }
+}