]> granicus.if.org Git - clang/commitdiff
Fixed implicit instantiations source range.
authorAbramo Bagnara <abramo.bagnara@gmail.com>
Fri, 18 Nov 2011 08:08:52 +0000 (08:08 +0000)
committerAbramo Bagnara <abramo.bagnara@gmail.com>
Fri, 18 Nov 2011 08:08:52 +0000 (08:08 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@144977 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaTemplateInstantiate.cpp
lib/Sema/SemaTemplateInstantiateDecl.cpp

index 301bf6a1126072f12f29cb2dbdda522433c40f0a..e86912a5218ad73b0481adc8bb7593c061897740 100644 (file)
@@ -1818,8 +1818,10 @@ Sema::InstantiateClass(SourceLocation PointOfInstantiation,
   if (!FieldsWithMemberInitializers.empty())
     ActOnFinishDelayedMemberInitializers(Instantiation);
 
-  if (TSK == TSK_ImplicitInstantiation)
+  if (TSK == TSK_ImplicitInstantiation) {
+    Instantiation->setLocStart(Pattern->getInnerLocStart());
     Instantiation->setRBraceLoc(Pattern->getRBraceLoc());
+  }
 
   if (Instantiation->isInvalidDecl())
     Invalid = true;
index 865d62e14b9b3c517cdb15b97f50560a913da2f9..c20033bbc258fd24af4184a74e851b0d065ca341 100644 (file)
@@ -2478,6 +2478,9 @@ void Sema::InstantiateFunctionDefinition(SourceLocation PointOfInstantiation,
   if (Inst)
     return;
 
+  // Copy the inner loc start from the pattern.
+  Function->setInnerLocStart(PatternDecl->getInnerLocStart());
+
   // If we're performing recursive template instantiation, create our own
   // queue of pending implicit instantiations that we will instantiate later,
   // while we're still within our own instantiation context.