Prefix Template Arg Names with Multiclass Name
authorDavid Greene <greened@obbligato.org>
Wed, 5 Oct 2011 22:42:54 +0000 (22:42 +0000)
committerDavid Greene <greened@obbligato.org>
Wed, 5 Oct 2011 22:42:54 +0000 (22:42 +0000)
For consistency, prefix multiclass template arg names with the
multiclass name followed by "::" to avoid name clashes among
multiclass arguments and other entities in the multiclass.

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

lib/TableGen/TGParser.cpp

index ed51977c3d011ab14d5cdfe876370b27812e8b5c..97240481fcbb604be3b11468f5e25693db4b78ff 100644 (file)
@@ -650,6 +650,9 @@ Init *TGParser::ParseIDValue(Record *CurRec,
       return VarInit::get(Name, RV->getType());
 
     std::string TemplateArgName = CurRec->getName()+":"+Name;
+    if (CurMultiClass)
+      TemplateArgName = CurMultiClass->Rec.getName()+"::"+TemplateArgName;
+
     if (CurRec->isTemplateArg(TemplateArgName)) {
       const RecordVal *RV = CurRec->getValue(TemplateArgName);
       assert(RV && "Template arg doesn't exist??");