aboutsummaryrefslogtreecommitdiffstats
path: root/utils
diff options
context:
space:
mode:
authorMikhail Glushenkov <foldr@codedgers.com>2008-12-07 16:42:22 +0000
committerMikhail Glushenkov <foldr@codedgers.com>2008-12-07 16:42:22 +0000
commit08509493e53baf43ff23cc5436d2450cf5bf3c5e (patch)
tree2df8b3b9d1e1f1a259988e3164da7c4de2efea21 /utils
parent15dcc2a15ba97359093410ba7d4f76c53cddf938 (diff)
downloadexternal_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.cpp47
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