1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-24 19:52:54 +01:00

Change getConstantValue to throw an exception on error, not return null

llvm-svn: 8988
This commit is contained in:
Chris Lattner 2003-10-09 20:41:16 +00:00
parent 8e6b42c567
commit 36f2dcd3d5
2 changed files with 7 additions and 10 deletions

View File

@ -165,9 +165,7 @@ Constant *BytecodeParser::parseConstantValue(const unsigned char *&Buf,
<< ArgValSlot << "\n");
// Get the arg value from its slot if it exists, otherwise a placeholder
Constant *C = getConstantValue(ArgTy, ArgValSlot);
if (C == 0) throw std::string("No arg value or placeholder found.");
ArgVec.push_back(C);
ArgVec.push_back(getConstantValue(ArgTy, ArgValSlot));
}
// Construct a ConstantExpr of the appropriate kind
@ -241,9 +239,7 @@ Constant *BytecodeParser::parseConstantValue(const unsigned char *&Buf,
while (NumElements--) { // Read all of the elements of the constant.
unsigned Slot;
if (read_vbr(Buf, EndBuf, Slot)) throw Error_readvbr;
Constant *C = getConstantValue(AT->getElementType(), Slot);
if (!C) throw std::string("Unable to get const value of array slot.");
Elements.push_back(C);
Elements.push_back(getConstantValue(AT->getElementType(), Slot));
}
return ConstantArray::get(AT, Elements);
}
@ -256,9 +252,7 @@ Constant *BytecodeParser::parseConstantValue(const unsigned char *&Buf,
for (unsigned i = 0; i < ET.size(); ++i) {
unsigned Slot;
if (read_vbr(Buf, EndBuf, Slot)) throw Error_readvbr;
Constant *C = getConstantValue(ET[i], Slot);
if (!C) throw std::string("Could not read const value in struct slot.");
Elements.push_back(C);
Elements.push_back(getConstantValue(ET[i], Slot));
}
return ConstantStruct::get(ST, Elements);

View File

@ -164,7 +164,10 @@ BasicBlock *BytecodeParser::getBasicBlock(unsigned ID) {
///
Constant *BytecodeParser::getConstantValue(const Type *Ty, unsigned Slot) {
if (Value *V = getValue(Ty, Slot, false))
return dyn_cast<Constant>(V); // If we already have the value parsed...
if (Constant *C = dyn_cast<Constant>(V))
return C; // If we already have the value parsed, just return it
else
throw std::string("Reference of a value is expected to be a constant!");
std::pair<const Type*, unsigned> Key(Ty, Slot);
GlobalRefsType::iterator I = GlobalRefs.lower_bound(Key);