diff options
author | David Greene <greened@obbligato.org> | 2011-10-05 22:42:07 +0000 |
---|---|---|
committer | David Greene <greened@obbligato.org> | 2011-10-05 22:42:07 +0000 |
commit | e499a2df4492dab21a50d74f3f687b989f910a2f (patch) | |
tree | 85310a72635bab58028a7fcbc83c99a110d2299f /lib/TableGen/TGParser.h | |
parent | 792860883e00edd8ccb55360cd22d1e131bbe396 (diff) |
Refactor Multiclass Def Processing
Move the code to instantiate a multiclass def, bind its arguments and
resolve its members into three helper functions. These will be reused
to support a new kind of multiclass def: a multidef.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141229 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/TableGen/TGParser.h')
-rw-r--r-- | lib/TableGen/TGParser.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/lib/TableGen/TGParser.h b/lib/TableGen/TGParser.h index b408c80b7a..db8a620297 100644 --- a/lib/TableGen/TGParser.h +++ b/lib/TableGen/TGParser.h @@ -83,6 +83,21 @@ private: // Parser methods. bool ParseObject(MultiClass *MC); bool ParseClass(); bool ParseMultiClass(); + Record *InstantiateMulticlassDef(MultiClass &MC, + Record *DefProto, + const std::string &DefmPrefix, + SMLoc DefmPrefixLoc); + bool ResolveMulticlassDefArgs(MultiClass &MC, + Record *DefProto, + SMLoc DefmPrefixLoc, + SMLoc SubClassLoc, + const std::vector<std::string> &TArgs, + std::vector<Init *> &TemplateVals, + bool DeleteArgs); + bool ResolveMulticlassDef(MultiClass &MC, + Record *CurRec, + Record *DefProto, + SMLoc DefmPrefixLoc); bool ParseDefm(MultiClass *CurMultiClass); bool ParseDef(MultiClass *CurMultiClass); bool ParseTopLevelLet(MultiClass *CurMultiClass); |