diff options
author | Mikhail Glushenkov <foldr@codedgers.com> | 2008-12-07 16:42:22 +0000 |
---|---|---|
committer | Mikhail Glushenkov <foldr@codedgers.com> | 2008-12-07 16:42:22 +0000 |
commit | 08509493e53baf43ff23cc5436d2450cf5bf3c5e (patch) | |
tree | 2df8b3b9d1e1f1a259988e3164da7c4de2efea21 /utils | |
parent | 15dcc2a15ba97359093410ba7d4f76c53cddf938 (diff) | |
download | external_llvm-08509493e53baf43ff23cc5436d2450cf5bf3c5e.zip external_llvm-08509493e53baf43ff23cc5436d2450cf5bf3c5e.tar.gz external_llvm-08509493e53baf43ff23cc5436d2450cf5bf3c5e.tar.bz2 |
Add a (progn)-like construct for (actions). Implemented as a DAG list.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@60658 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rw-r--r-- | utils/TableGen/LLVMCConfigurationEmitter.cpp | 47 |
1 files changed, 37 insertions, 10 deletions
diff --git a/utils/TableGen/LLVMCConfigurationEmitter.cpp b/utils/TableGen/LLVMCConfigurationEmitter.cpp index 175de45..3456b9a 100644 --- a/utils/TableGen/LLVMCConfigurationEmitter.cpp +++ b/utils/TableGen/LLVMCConfigurationEmitter.cpp @@ -802,11 +802,8 @@ void WalkCase(Init* Case, F1 TestCallback, F2 StatementCallback) { /// CheckForSuperfluousOptions() to walk the 'case' DAG. class ExtractOptionNames { llvm::StringSet<>& OptionNames_; -public: - ExtractOptionNames(llvm::StringSet<>& OptionNames) : OptionNames_(OptionNames) - {} - void operator()(const Init* Statement) { + void processDag(const Init* Statement) { const DagInit& Stmt = InitPtrToDag(Statement); const std::string& ActionName = Stmt.getOperator()->getAsString(); if (ActionName == "forward" || ActionName == "forward_as" || @@ -819,10 +816,26 @@ public: } else if (ActionName == "and" || ActionName == "or") { for (unsigned i = 0, NumArgs = Stmt.getNumArgs(); i < NumArgs; ++i) { - this->operator()(Stmt.getArg(i)); + this->processDag(Stmt.getArg(i)); } } } + +public: + ExtractOptionNames(llvm::StringSet<>& OptionNames) : OptionNames_(OptionNames) + {} + + void operator()(const Init* Statement) { + if (typeid(*Statement) == typeid(ListInit)) { + const ListInit& DagList = *static_cast<const ListInit*>(Statement); + for (ListInit::const_iterator B = DagList.begin(), E = DagList.end(); + B != E; ++B) + this->processDag(*B); + } + else { + this->processDag(Statement); + } + } }; /// CheckForSuperfluousOptions - Check that there are no side @@ -1185,12 +1198,9 @@ void EmitForwardOptionPropertyHandlingCode (const OptionDescription& D, /// EmitCaseConstructHandler(). class EmitActionHandler { const OptionDescriptions& OptDescs; - public: - EmitActionHandler(const OptionDescriptions& OD) - : OptDescs(OD) {} - void operator()(const Init* Statement, const char* IndentLevel, - std::ostream& O) const + void processActionDag(const Init* Statement, const char* IndentLevel, + std::ostream& O) const { const DagInit& Dag = InitPtrToDag(Statement); const std::string& ActionName = Dag.getOperator()->getAsString(); @@ -1246,6 +1256,23 @@ class EmitActionHandler { throw "Unknown action name: " + ActionName + "!"; } } + public: + EmitActionHandler(const OptionDescriptions& OD) + : OptDescs(OD) {} + + void operator()(const Init* Statement, const char* IndentLevel, + std::ostream& O) const + { + if (typeid(*Statement) == typeid(ListInit)) { + const ListInit& DagList = *static_cast<const ListInit*>(Statement); + for (ListInit::const_iterator B = DagList.begin(), E = DagList.end(); + B != E; ++B) + this->processActionDag(*B, IndentLevel, O); + } + else { + this->processActionDag(Statement, IndentLevel, O); + } + } }; // EmitGenerateActionMethod - Emit one of two versions of the |