From a40e5ad69f5ab5da1671a5e84e75a60202ad03d5 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Thu, 7 Aug 2003 19:41:59 +0000 Subject: [PATCH] Add and use a new method git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7682 91177308-0d34-0410-b5e6-96231b3b80d8 --- support/tools/TableGen/Record.h | 7 +++++++ support/tools/TableGen/RegisterInfoEmitter.cpp | 3 +-- utils/TableGen/Record.h | 7 +++++++ utils/TableGen/RegisterInfoEmitter.cpp | 3 +-- 4 files changed, 16 insertions(+), 4 deletions(-) diff --git a/support/tools/TableGen/Record.h b/support/tools/TableGen/Record.h index b6214516435..5c50a07651d 100644 --- a/support/tools/TableGen/Record.h +++ b/support/tools/TableGen/Record.h @@ -703,6 +703,13 @@ public: return false; } + bool isSubClassOf(const std::string &Name) const { + for (unsigned i = 0, e = SuperClasses.size(); i != e; ++i) + if (SuperClasses[i]->getName() == Name) + return true; + return false; + } + void addSuperClass(Record *R) { assert(!isSubClassOf(R) && "Already subclassing record!"); SuperClasses.push_back(R); diff --git a/support/tools/TableGen/RegisterInfoEmitter.cpp b/support/tools/TableGen/RegisterInfoEmitter.cpp index f1f8a86bd4f..9ef5f020a28 100644 --- a/support/tools/TableGen/RegisterInfoEmitter.cpp +++ b/support/tools/TableGen/RegisterInfoEmitter.cpp @@ -73,7 +73,6 @@ void RegisterInfoEmitter::run(std::ostream &OS) { Records.getAllDerivedDefinitions("RegisterClass"); std::vector Registers = Records.getAllDerivedDefinitions("Register"); - Record *RegisterClass = Records.getClass("Register"); std::set RegistersFound; std::vector RegClassNames; @@ -99,7 +98,7 @@ void RegisterInfoEmitter::run(std::ostream &OS) { DefInit *RegDef = dynamic_cast(RegList->getElement(i)); if (!RegDef) throw "Register class member is not a record!"; Record *Reg = RegDef->getDef(); - if (!Reg->isSubClassOf(RegisterClass)) + if (!Reg->isSubClassOf("Register")) throw "Register Class member '" + Reg->getName() + " does not derive from the Register class!"; if (RegistersFound.count(Reg)) diff --git a/utils/TableGen/Record.h b/utils/TableGen/Record.h index b6214516435..5c50a07651d 100644 --- a/utils/TableGen/Record.h +++ b/utils/TableGen/Record.h @@ -703,6 +703,13 @@ public: return false; } + bool isSubClassOf(const std::string &Name) const { + for (unsigned i = 0, e = SuperClasses.size(); i != e; ++i) + if (SuperClasses[i]->getName() == Name) + return true; + return false; + } + void addSuperClass(Record *R) { assert(!isSubClassOf(R) && "Already subclassing record!"); SuperClasses.push_back(R); diff --git a/utils/TableGen/RegisterInfoEmitter.cpp b/utils/TableGen/RegisterInfoEmitter.cpp index f1f8a86bd4f..9ef5f020a28 100644 --- a/utils/TableGen/RegisterInfoEmitter.cpp +++ b/utils/TableGen/RegisterInfoEmitter.cpp @@ -73,7 +73,6 @@ void RegisterInfoEmitter::run(std::ostream &OS) { Records.getAllDerivedDefinitions("RegisterClass"); std::vector Registers = Records.getAllDerivedDefinitions("Register"); - Record *RegisterClass = Records.getClass("Register"); std::set RegistersFound; std::vector RegClassNames; @@ -99,7 +98,7 @@ void RegisterInfoEmitter::run(std::ostream &OS) { DefInit *RegDef = dynamic_cast(RegList->getElement(i)); if (!RegDef) throw "Register class member is not a record!"; Record *Reg = RegDef->getDef(); - if (!Reg->isSubClassOf(RegisterClass)) + if (!Reg->isSubClassOf("Register")) throw "Register Class member '" + Reg->getName() + " does not derive from the Register class!"; if (RegistersFound.count(Reg))