mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-16 00:18:06 +00:00
rename getSlot -> getSlotType and getOrCreateSlot ->getOrCreateTypeSlot
for types. llvm-svn: 34113
This commit is contained in:
parent
a86214b294
commit
7141ac8812
@ -55,7 +55,7 @@ void SlotCalculator::insertPrimitives() {
|
|||||||
insertType(Type::FloatTy, true); // 1: FloatTySlot
|
insertType(Type::FloatTy, true); // 1: FloatTySlot
|
||||||
insertType(Type::DoubleTy, true); // 2: DoubleTySlot
|
insertType(Type::DoubleTy, true); // 2: DoubleTySlot
|
||||||
insertType(Type::LabelTy, true); // 3: LabelTySlot
|
insertType(Type::LabelTy, true); // 3: LabelTySlot
|
||||||
assert(TypeMap.size() == Type::FirstDerivedTyID && "Invalid primitive insert");
|
assert(TypeMap.size() == Type::FirstDerivedTyID &&"Invalid primitive insert");
|
||||||
// Above here *must* correspond 1:1 with the primitive types.
|
// Above here *must* correspond 1:1 with the primitive types.
|
||||||
insertType(Type::Int1Ty, true); // 4: BoolTySlot
|
insertType(Type::Int1Ty, true); // 4: BoolTySlot
|
||||||
insertType(Type::Int8Ty, true); // 5: Int8TySlot
|
insertType(Type::Int8Ty, true); // 5: Int8TySlot
|
||||||
@ -161,7 +161,7 @@ void SlotCalculator::processModule() {
|
|||||||
isa<InlineAsm>(*OI))
|
isa<InlineAsm>(*OI))
|
||||||
getOrCreateSlot(*OI);
|
getOrCreateSlot(*OI);
|
||||||
}
|
}
|
||||||
getOrCreateSlot(I->getType());
|
getOrCreateTypeSlot(I->getType());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -212,7 +212,7 @@ void SlotCalculator::processModule() {
|
|||||||
void SlotCalculator::processTypeSymbolTable(const TypeSymbolTable *TST) {
|
void SlotCalculator::processTypeSymbolTable(const TypeSymbolTable *TST) {
|
||||||
for (TypeSymbolTable::const_iterator TI = TST->begin(), TE = TST->end();
|
for (TypeSymbolTable::const_iterator TI = TST->begin(), TE = TST->end();
|
||||||
TI != TE; ++TI )
|
TI != TE; ++TI )
|
||||||
getOrCreateSlot(TI->second);
|
getOrCreateTypeSlot(TI->second);
|
||||||
}
|
}
|
||||||
|
|
||||||
// processSymbolTable - Insert all of the values in the specified symbol table
|
// processSymbolTable - Insert all of the values in the specified symbol table
|
||||||
@ -237,7 +237,8 @@ void SlotCalculator::incorporateFunction(const Function *F) {
|
|||||||
ModuleTypeLevel = Types.size();
|
ModuleTypeLevel = Types.size();
|
||||||
|
|
||||||
// Iterate over function arguments, adding them to the value table...
|
// Iterate over function arguments, adding them to the value table...
|
||||||
for(Function::const_arg_iterator I = F->arg_begin(), E = F->arg_end(); I != E; ++I)
|
for(Function::const_arg_iterator I = F->arg_begin(), E = F->arg_end();
|
||||||
|
I != E; ++I)
|
||||||
getOrCreateSlot(I);
|
getOrCreateSlot(I);
|
||||||
|
|
||||||
if (!ModuleContainsAllFunctionConstants) {
|
if (!ModuleContainsAllFunctionConstants) {
|
||||||
@ -326,7 +327,7 @@ int SlotCalculator::getSlot(const Value *V) const {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int SlotCalculator::getSlot(const Type*T) const {
|
int SlotCalculator::getTypeSlot(const Type*T) const {
|
||||||
std::map<const Type*, unsigned>::const_iterator I = TypeMap.find(T);
|
std::map<const Type*, unsigned>::const_iterator I = TypeMap.find(T);
|
||||||
if (I != TypeMap.end())
|
if (I != TypeMap.end())
|
||||||
return (int)I->second;
|
return (int)I->second;
|
||||||
@ -369,33 +370,33 @@ int SlotCalculator::getOrCreateSlot(const Value *V) {
|
|||||||
return insertValue(V);
|
return insertValue(V);
|
||||||
}
|
}
|
||||||
|
|
||||||
int SlotCalculator::getOrCreateSlot(const Type* T) {
|
int SlotCalculator::insertValue(const Value *V, bool dontIgnore) {
|
||||||
int SlotNo = getSlot(T); // Check to see if it's already in!
|
assert(V && "Can't insert a null value!");
|
||||||
if (SlotNo != -1) return SlotNo;
|
assert(getSlot(V) == -1 && "Value is already in the table!");
|
||||||
return insertType(T);
|
|
||||||
}
|
|
||||||
|
|
||||||
int SlotCalculator::insertValue(const Value *D, bool dontIgnore) {
|
|
||||||
assert(D && "Can't insert a null value!");
|
|
||||||
assert(getSlot(D) == -1 && "Value is already in the table!");
|
|
||||||
|
|
||||||
// If this node does not contribute to a plane, or if the node has a
|
// If this node does not contribute to a plane, or if the node has a
|
||||||
// name and we don't want names, then ignore the silly node... Note that types
|
// name and we don't want names, then ignore the silly node... Note that types
|
||||||
// do need slot numbers so that we can keep track of where other values land.
|
// do need slot numbers so that we can keep track of where other values land.
|
||||||
//
|
//
|
||||||
if (!dontIgnore) // Don't ignore nonignorables!
|
if (!dontIgnore) // Don't ignore nonignorables!
|
||||||
if (D->getType() == Type::VoidTy ) { // Ignore void type nodes
|
if (V->getType() == Type::VoidTy) { // Ignore void type nodes
|
||||||
SC_DEBUG("ignored value " << *D << "\n");
|
SC_DEBUG("ignored value " << *V << "\n");
|
||||||
return -1; // We do need types unconditionally though
|
return -1; // We do need types unconditionally though
|
||||||
}
|
}
|
||||||
|
|
||||||
// Okay, everything is happy, actually insert the silly value now...
|
// Okay, everything is happy, actually insert the silly value now...
|
||||||
return doInsertValue(D);
|
return doInsertValue(V);
|
||||||
|
}
|
||||||
|
|
||||||
|
int SlotCalculator::getOrCreateTypeSlot(const Type* T) {
|
||||||
|
int SlotNo = getTypeSlot(T); // Check to see if it's already in!
|
||||||
|
if (SlotNo != -1) return SlotNo;
|
||||||
|
return insertType(T);
|
||||||
}
|
}
|
||||||
|
|
||||||
int SlotCalculator::insertType(const Type *Ty, bool dontIgnore) {
|
int SlotCalculator::insertType(const Type *Ty, bool dontIgnore) {
|
||||||
assert(Ty && "Can't insert a null type!");
|
assert(Ty && "Can't insert a null type!");
|
||||||
assert(getSlot(Ty) == -1 && "Type is already in the table!");
|
assert(getTypeSlot(Ty) == -1 && "Type is already in the table!");
|
||||||
|
|
||||||
// Insert the current type before any subtypes. This is important because
|
// Insert the current type before any subtypes. This is important because
|
||||||
// recursive types elements are inserted in a bottom up order. Changing
|
// recursive types elements are inserted in a bottom up order. Changing
|
||||||
@ -414,7 +415,7 @@ int SlotCalculator::insertType(const Type *Ty, bool dontIgnore) {
|
|||||||
if (*I != Ty) {
|
if (*I != Ty) {
|
||||||
const Type *SubTy = *I;
|
const Type *SubTy = *I;
|
||||||
// If we haven't seen this sub type before, add it to our type table!
|
// If we haven't seen this sub type before, add it to our type table!
|
||||||
if (getSlot(SubTy) == -1) {
|
if (getTypeSlot(SubTy) == -1) {
|
||||||
SC_DEBUG(" Inserting subtype: " << SubTy->getDescription() << "\n");
|
SC_DEBUG(" Inserting subtype: " << SubTy->getDescription() << "\n");
|
||||||
doInsertType(SubTy);
|
doInsertType(SubTy);
|
||||||
SC_DEBUG(" Inserted subtype: " << SubTy->getDescription() << "\n");
|
SC_DEBUG(" Inserted subtype: " << SubTy->getDescription() << "\n");
|
||||||
@ -436,7 +437,7 @@ int SlotCalculator::doInsertValue(const Value *D) {
|
|||||||
// llvm_cerr << "Inserting type '"<<cast<Type>(D)->getDescription() <<"'!\n";
|
// llvm_cerr << "Inserting type '"<<cast<Type>(D)->getDescription() <<"'!\n";
|
||||||
|
|
||||||
if (Typ->isDerivedType()) {
|
if (Typ->isDerivedType()) {
|
||||||
int ValSlot = getSlot(Typ);
|
int ValSlot = getTypeSlot(Typ);
|
||||||
if (ValSlot == -1) { // Have we already entered this type?
|
if (ValSlot == -1) { // Have we already entered this type?
|
||||||
// Nope, this is the first we have seen the type, process it.
|
// Nope, this is the first we have seen the type, process it.
|
||||||
ValSlot = insertType(Typ, true);
|
ValSlot = insertType(Typ, true);
|
||||||
|
@ -73,7 +73,7 @@ public:
|
|||||||
/// plane. This returns < 0 on error!
|
/// plane. This returns < 0 on error!
|
||||||
///
|
///
|
||||||
int getSlot(const Value *V) const;
|
int getSlot(const Value *V) const;
|
||||||
int getSlot(const Type* T) const;
|
int getTypeSlot(const Type* T) const;
|
||||||
|
|
||||||
inline unsigned getNumPlanes() const { return Table.size(); }
|
inline unsigned getNumPlanes() const { return Table.size(); }
|
||||||
inline unsigned getNumTypes() const { return Types.size(); }
|
inline unsigned getNumTypes() const { return Types.size(); }
|
||||||
@ -116,7 +116,7 @@ private:
|
|||||||
// they are ignored.
|
// they are ignored.
|
||||||
//
|
//
|
||||||
int getOrCreateSlot(const Value *V);
|
int getOrCreateSlot(const Value *V);
|
||||||
int getOrCreateSlot(const Type *T);
|
int getOrCreateTypeSlot(const Type *T);
|
||||||
|
|
||||||
// insertValue - Insert a value into the value table... Return the
|
// insertValue - Insert a value into the value table... Return the
|
||||||
// slot that it occupies, or -1 if the declaration is to be ignored
|
// slot that it occupies, or -1 if the declaration is to be ignored
|
||||||
|
@ -214,7 +214,7 @@ void BytecodeWriter::outputType(const Type *T) {
|
|||||||
break;
|
break;
|
||||||
case Type::FunctionTyID: {
|
case Type::FunctionTyID: {
|
||||||
const FunctionType *MT = cast<FunctionType>(T);
|
const FunctionType *MT = cast<FunctionType>(T);
|
||||||
int Slot = Table.getSlot(MT->getReturnType());
|
int Slot = Table.getTypeSlot(MT->getReturnType());
|
||||||
assert(Slot != -1 && "Type used but not available!!");
|
assert(Slot != -1 && "Type used but not available!!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
output_vbr(unsigned(MT->getParamAttrs(0)));
|
output_vbr(unsigned(MT->getParamAttrs(0)));
|
||||||
@ -226,7 +226,7 @@ void BytecodeWriter::outputType(const Type *T) {
|
|||||||
FunctionType::param_iterator I = MT->param_begin();
|
FunctionType::param_iterator I = MT->param_begin();
|
||||||
unsigned Idx = 1;
|
unsigned Idx = 1;
|
||||||
for (; I != MT->param_end(); ++I) {
|
for (; I != MT->param_end(); ++I) {
|
||||||
Slot = Table.getSlot(*I);
|
Slot = Table.getTypeSlot(*I);
|
||||||
assert(Slot != -1 && "Type used but not available!!");
|
assert(Slot != -1 && "Type used but not available!!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
output_vbr(unsigned(MT->getParamAttrs(Idx)));
|
output_vbr(unsigned(MT->getParamAttrs(Idx)));
|
||||||
@ -241,7 +241,7 @@ void BytecodeWriter::outputType(const Type *T) {
|
|||||||
|
|
||||||
case Type::ArrayTyID: {
|
case Type::ArrayTyID: {
|
||||||
const ArrayType *AT = cast<ArrayType>(T);
|
const ArrayType *AT = cast<ArrayType>(T);
|
||||||
int Slot = Table.getSlot(AT->getElementType());
|
int Slot = Table.getTypeSlot(AT->getElementType());
|
||||||
assert(Slot != -1 && "Type used but not available!!");
|
assert(Slot != -1 && "Type used but not available!!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
output_vbr(AT->getNumElements());
|
output_vbr(AT->getNumElements());
|
||||||
@ -250,7 +250,7 @@ void BytecodeWriter::outputType(const Type *T) {
|
|||||||
|
|
||||||
case Type::PackedTyID: {
|
case Type::PackedTyID: {
|
||||||
const PackedType *PT = cast<PackedType>(T);
|
const PackedType *PT = cast<PackedType>(T);
|
||||||
int Slot = Table.getSlot(PT->getElementType());
|
int Slot = Table.getTypeSlot(PT->getElementType());
|
||||||
assert(Slot != -1 && "Type used but not available!!");
|
assert(Slot != -1 && "Type used but not available!!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
output_vbr(PT->getNumElements());
|
output_vbr(PT->getNumElements());
|
||||||
@ -262,7 +262,7 @@ void BytecodeWriter::outputType(const Type *T) {
|
|||||||
// Output all of the element types...
|
// Output all of the element types...
|
||||||
for (StructType::element_iterator I = ST->element_begin(),
|
for (StructType::element_iterator I = ST->element_begin(),
|
||||||
E = ST->element_end(); I != E; ++I) {
|
E = ST->element_end(); I != E; ++I) {
|
||||||
int Slot = Table.getSlot(*I);
|
int Slot = Table.getTypeSlot(*I);
|
||||||
assert(Slot != -1 && "Type used but not available!!");
|
assert(Slot != -1 && "Type used but not available!!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
}
|
}
|
||||||
@ -274,7 +274,7 @@ void BytecodeWriter::outputType(const Type *T) {
|
|||||||
|
|
||||||
case Type::PointerTyID: {
|
case Type::PointerTyID: {
|
||||||
const PointerType *PT = cast<PointerType>(T);
|
const PointerType *PT = cast<PointerType>(T);
|
||||||
int Slot = Table.getSlot(PT->getElementType());
|
int Slot = Table.getTypeSlot(PT->getElementType());
|
||||||
assert(Slot != -1 && "Type used but not available!!");
|
assert(Slot != -1 && "Type used but not available!!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
break;
|
break;
|
||||||
@ -309,7 +309,7 @@ void BytecodeWriter::outputConstant(const Constant *CPV) {
|
|||||||
int Slot = Table.getSlot(*OI);
|
int Slot = Table.getSlot(*OI);
|
||||||
assert(Slot != -1 && "Unknown constant used in ConstantExpr!!");
|
assert(Slot != -1 && "Unknown constant used in ConstantExpr!!");
|
||||||
output_vbr((unsigned)Slot);
|
output_vbr((unsigned)Slot);
|
||||||
Slot = Table.getSlot((*OI)->getType());
|
Slot = Table.getTypeSlot((*OI)->getType());
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
}
|
}
|
||||||
if (CE->isCompare())
|
if (CE->isCompare())
|
||||||
@ -419,7 +419,7 @@ void BytecodeWriter::outputConstantStrings() {
|
|||||||
// Emit all of the strings.
|
// Emit all of the strings.
|
||||||
for (I = Table.string_begin(); I != E; ++I) {
|
for (I = Table.string_begin(); I != E; ++I) {
|
||||||
const ConstantArray *Str = *I;
|
const ConstantArray *Str = *I;
|
||||||
int Slot = Table.getSlot(Str->getType());
|
int Slot = Table.getTypeSlot(Str->getType());
|
||||||
assert(Slot != -1 && "Constant string of unknown type?");
|
assert(Slot != -1 && "Constant string of unknown type?");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
|
|
||||||
@ -459,7 +459,7 @@ void BytecodeWriter::outputInstructionFormat0(const Instruction *I,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (isa<CastInst>(I) || isa<VAArgInst>(I)) {
|
if (isa<CastInst>(I) || isa<VAArgInst>(I)) {
|
||||||
int Slot = Table.getSlot(I->getType());
|
int Slot = Table.getTypeSlot(I->getType());
|
||||||
assert(Slot != -1 && "Cast return type unknown?");
|
assert(Slot != -1 && "Cast return type unknown?");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
} else if (isa<CmpInst>(I)) {
|
} else if (isa<CmpInst>(I)) {
|
||||||
@ -545,7 +545,7 @@ void BytecodeWriter::outputInstrVarArgsCall(const Instruction *I,
|
|||||||
|
|
||||||
for (unsigned i = NumFixedOperands, e = I->getNumOperands(); i != e; ++i) {
|
for (unsigned i = NumFixedOperands, e = I->getNumOperands(); i != e; ++i) {
|
||||||
// Output Arg Type ID
|
// Output Arg Type ID
|
||||||
int Slot = Table.getSlot(I->getOperand(i)->getType());
|
int Slot = Table.getTypeSlot(I->getOperand(i)->getType());
|
||||||
assert(Slot >= 0 && "No slot number for value!?!?");
|
assert(Slot >= 0 && "No slot number for value!?!?");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
|
|
||||||
@ -672,7 +672,7 @@ void BytecodeWriter::outputInstruction(const Instruction &I) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned Type;
|
unsigned Type;
|
||||||
int Slot = Table.getSlot(Ty);
|
int Slot = Table.getTypeSlot(Ty);
|
||||||
assert(Slot != -1 && "Type not available!!?!");
|
assert(Slot != -1 && "Type not available!!?!");
|
||||||
Type = (unsigned)Slot;
|
Type = (unsigned)Slot;
|
||||||
|
|
||||||
@ -710,7 +710,7 @@ void BytecodeWriter::outputInstruction(const Instruction &I) {
|
|||||||
if (isa<CastInst>(I) || isa<VAArgInst>(I)) {
|
if (isa<CastInst>(I) || isa<VAArgInst>(I)) {
|
||||||
// Cast has to encode the destination type as the second argument in the
|
// Cast has to encode the destination type as the second argument in the
|
||||||
// packet, or else we won't know what type to cast to!
|
// packet, or else we won't know what type to cast to!
|
||||||
Slots[1] = Table.getSlot(I.getType());
|
Slots[1] = Table.getTypeSlot(I.getType());
|
||||||
assert(Slots[1] != ~0U && "Cast return type unknown?");
|
assert(Slots[1] != ~0U && "Cast return type unknown?");
|
||||||
if (Slots[1] > MaxOpSlot) MaxOpSlot = Slots[1];
|
if (Slots[1] > MaxOpSlot) MaxOpSlot = Slots[1];
|
||||||
NumOperands++;
|
NumOperands++;
|
||||||
@ -887,7 +887,7 @@ void BytecodeWriter::outputConstantsInPlane(const std::vector<const Value*>
|
|||||||
output_vbr(NC);
|
output_vbr(NC);
|
||||||
|
|
||||||
// Put out the Type ID Number...
|
// Put out the Type ID Number...
|
||||||
int Slot = Table.getSlot(Plane.front()->getType());
|
int Slot = Table.getTypeSlot(Plane.front()->getType());
|
||||||
assert (Slot != -1 && "Type in constant pool but not in function!!");
|
assert (Slot != -1 && "Type in constant pool but not in function!!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
|
|
||||||
@ -961,7 +961,7 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) {
|
|||||||
// Output the types for the global variables in the module...
|
// Output the types for the global variables in the module...
|
||||||
for (Module::const_global_iterator I = M->global_begin(),
|
for (Module::const_global_iterator I = M->global_begin(),
|
||||||
End = M->global_end(); I != End; ++I) {
|
End = M->global_end(); I != End; ++I) {
|
||||||
int Slot = Table.getSlot(I->getType());
|
int Slot = Table.getTypeSlot(I->getType());
|
||||||
assert(Slot != -1 && "Module global vars is broken!");
|
assert(Slot != -1 && "Module global vars is broken!");
|
||||||
|
|
||||||
assert((I->hasInitializer() || !I->hasInternalLinkage()) &&
|
assert((I->hasInitializer() || !I->hasInternalLinkage()) &&
|
||||||
@ -1011,11 +1011,11 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) {
|
|||||||
output_vbr((unsigned)Slot);
|
output_vbr((unsigned)Slot);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
output_typeid((unsigned)Table.getSlot(Type::VoidTy));
|
output_typeid((unsigned)Table.getTypeSlot(Type::VoidTy));
|
||||||
|
|
||||||
// Output the types of the functions in this module.
|
// Output the types of the functions in this module.
|
||||||
for (Module::const_iterator I = M->begin(), End = M->end(); I != End; ++I) {
|
for (Module::const_iterator I = M->begin(), End = M->end(); I != End; ++I) {
|
||||||
int Slot = Table.getSlot(I->getType());
|
int Slot = Table.getTypeSlot(I->getType());
|
||||||
assert(Slot != -1 && "Module slot calculator is broken!");
|
assert(Slot != -1 && "Module slot calculator is broken!");
|
||||||
assert(Slot >= Type::FirstDerivedTyID && "Derived type not in range!");
|
assert(Slot >= Type::FirstDerivedTyID && "Derived type not in range!");
|
||||||
assert(((Slot << 6) >> 6) == Slot && "Slot # too big!");
|
assert(((Slot << 6) >> 6) == Slot && "Slot # too big!");
|
||||||
@ -1062,7 +1062,7 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
output_vbr((unsigned)Table.getSlot(Type::VoidTy) << 5);
|
output_vbr((unsigned)Table.getTypeSlot(Type::VoidTy) << 5);
|
||||||
|
|
||||||
// Emit the list of dependent libraries for the Module.
|
// Emit the list of dependent libraries for the Module.
|
||||||
Module::lib_iterator LI = M->lib_begin();
|
Module::lib_iterator LI = M->lib_begin();
|
||||||
@ -1129,7 +1129,7 @@ void BytecodeWriter::outputTypeSymbolTable(const TypeSymbolTable &TST) {
|
|||||||
for (TypeSymbolTable::const_iterator TI = TST.begin(), TE = TST.end();
|
for (TypeSymbolTable::const_iterator TI = TST.begin(), TE = TST.end();
|
||||||
TI != TE; ++TI) {
|
TI != TE; ++TI) {
|
||||||
// Symtab entry:[def slot #][name]
|
// Symtab entry:[def slot #][name]
|
||||||
output_typeid((unsigned)Table.getSlot(TI->second));
|
output_typeid((unsigned)Table.getTypeSlot(TI->second));
|
||||||
output(TI->first);
|
output(TI->first);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1165,7 +1165,7 @@ void BytecodeWriter::outputValueSymbolTable(const ValueSymbolTable &VST) {
|
|||||||
output_vbr((unsigned)PI->second.size());
|
output_vbr((unsigned)PI->second.size());
|
||||||
|
|
||||||
// Write the slot number of the type for this plane
|
// Write the slot number of the type for this plane
|
||||||
Slot = Table.getSlot(PI->first);
|
Slot = Table.getTypeSlot(PI->first);
|
||||||
assert(Slot != -1 && "Type in symtab, but not in table!");
|
assert(Slot != -1 && "Type in symtab, but not in table!");
|
||||||
output_typeid((unsigned)Slot);
|
output_typeid((unsigned)Slot);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user