]> granicus.if.org Git - clang/commitdiff
Sigh. Be *really* careful when copying a default function argument during template...
authorDouglas Gregor <dgregor@apple.com>
Fri, 25 Sep 2009 07:03:22 +0000 (07:03 +0000)
committerDouglas Gregor <dgregor@apple.com>
Fri, 25 Sep 2009 07:03:22 +0000 (07:03 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@82761 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaTemplateInstantiateDecl.cpp

index fc51684f9e74ba766ae800fca10bd478df1e8f69..b7548415aa3edf721f4ad0ccdcf979ca85066fed 100644 (file)
@@ -711,7 +711,9 @@ ParmVarDecl *TemplateDeclInstantiator::VisitParmVarDecl(ParmVarDecl *D) {
   // Mark the default argument as being uninstantiated.
   if (D->hasUninstantiatedDefaultArg())
     Param->setUninstantiatedDefaultArg(D->getUninstantiatedDefaultArg());
-
+  else if (Expr *Arg = D->getDefaultArg())
+    Param->setUninstantiatedDefaultArg(Arg);
+  
   // Note: we don't try to instantiate function parameters until after
   // we've instantiated the function's type. Therefore, we don't have
   // to check for 'void' parameter types here.