summaryrefslogtreecommitdiffstats
path: root/llvm/support/tools/TableGen/CodeEmitterGen.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-07-29 23:00:08 +0000
committerChris Lattner <sabre@nondot.org>2003-07-29 23:00:08 +0000
commit590fd82e42cd80809f6f88e5b11d5faec5f6b1f7 (patch)
tree12f4c259cfdece742caab0ddec90a0ed8484f077 /llvm/support/tools/TableGen/CodeEmitterGen.cpp
parent0f918540b665f31367376328f604f2de9aac8cb3 (diff)
downloadbcm5719-llvm-590fd82e42cd80809f6f88e5b11d5faec5f6b1f7.tar.gz
bcm5719-llvm-590fd82e42cd80809f6f88e5b11d5faec5f6b1f7.zip
Don't crash if there is no Inst class in the tablegen file!
llvm-svn: 7402
Diffstat (limited to 'llvm/support/tools/TableGen/CodeEmitterGen.cpp')
-rw-r--r--llvm/support/tools/TableGen/CodeEmitterGen.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/llvm/support/tools/TableGen/CodeEmitterGen.cpp b/llvm/support/tools/TableGen/CodeEmitterGen.cpp
index 90497cc620b..8805c7cab09 100644
--- a/llvm/support/tools/TableGen/CodeEmitterGen.cpp
+++ b/llvm/support/tools/TableGen/CodeEmitterGen.cpp
@@ -2,7 +2,7 @@
#include "Record.h"
#include "CodeEmitterGen.h"
-void CodeEmitterGen::createEmitter(std::ostream &o) {
+int CodeEmitterGen::createEmitter(std::ostream &o) {
std::vector<Record*> Insts;
const std::map<std::string, Record*> &Defs = Records.getDefs();
@@ -31,8 +31,12 @@ void CodeEmitterGen::createEmitter(std::ostream &o) {
<< " DEBUG(std::cerr << \"Emitting " << R->getName() << "\\n\");\n";
const RecordVal *InstVal = R->getValue("Inst");
- Init *InitVal = InstVal->getValue();
+ if (!InstVal) {
+ std::cerr << "No 'Inst' record found in target description file!\n";
+ return 1;
+ }
+ Init *InitVal = InstVal->getValue();
assert(dynamic_cast<BitsInit*>(InitVal) &&
"Can only handle undefined bits<> types!");
BitsInit *BI = (BitsInit*)InitVal;
@@ -225,4 +229,5 @@ void CodeEmitterGen::createEmitter(std::ostream &o) {
<< " }\n"
<< " return Value;\n"
<< "}\n";
+ return 0;
}
OpenPOWER on IntegriCloud