diff options
author | David Greene <greened@obbligato.org> | 2011-10-19 13:04:13 +0000 |
---|---|---|
committer | David Greene <greened@obbligato.org> | 2011-10-19 13:04:13 +0000 |
commit | d699161a997082c4cc8e57ddd712eb8bdb68722c (patch) | |
tree | e5f9f948817e7e38a9a6416f3fb627109d4f9f15 /llvm/lib/TableGen | |
parent | 7b6e641144d8ef95f3b38e1c8146930075ef4c7d (diff) | |
download | bcm5719-llvm-d699161a997082c4cc8e57ddd712eb8bdb68722c.tar.gz bcm5719-llvm-d699161a997082c4cc8e57ddd712eb8bdb68722c.zip |
Add NAME Member
Add a Value named "NAME" to each Record. This will be set to the def or defm
name when instantiating multiclasses. This will replace the #NAME# processing
hack once paste functionality is in place.
llvm-svn: 142518
Diffstat (limited to 'llvm/lib/TableGen')
-rw-r--r-- | llvm/lib/TableGen/Record.cpp | 5 | ||||
-rw-r--r-- | llvm/lib/TableGen/TGParser.cpp | 2 |
2 files changed, 6 insertions, 1 deletions
diff --git a/llvm/lib/TableGen/Record.cpp b/llvm/lib/TableGen/Record.cpp index a22c80c5e2e..92559d15b5f 100644 --- a/llvm/lib/TableGen/Record.cpp +++ b/llvm/lib/TableGen/Record.cpp @@ -1686,6 +1686,11 @@ unsigned Record::LastID = 0; void Record::init() { checkName(); + + // Every record potentially has a def at the top. This value is + // replaced with the top-level def name at instantiation time. + RecordVal DN("NAME", StringRecTy::get(), 0); + addValue(DN); } void Record::checkName() { diff --git a/llvm/lib/TableGen/TGParser.cpp b/llvm/lib/TableGen/TGParser.cpp index 45625f98d98..085136d4815 100644 --- a/llvm/lib/TableGen/TGParser.cpp +++ b/llvm/lib/TableGen/TGParser.cpp @@ -1744,7 +1744,7 @@ bool TGParser::ParseClass() { Record *CurRec = Records.getClass(Lex.getCurStrVal()); if (CurRec) { // If the body was previously defined, this is an error. - if (!CurRec->getValues().empty() || + if (CurRec->getValues().size() > 1 || // Account for NAME. !CurRec->getSuperClasses().empty() || !CurRec->getTemplateArgs().empty()) return TokError("Class '" + CurRec->getNameInitAsString() |