Another change that doesn't affect functionality. Since we are only looking

at types in the symbol table, only traverse the type plane, saving a loop nest.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3858 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2002-09-20 15:12:13 +00:00
parent 2c601a7be1
commit 2db41cd5de
2 changed files with 54 additions and 58 deletions

View File

@ -566,14 +566,17 @@ void CWriter::printModule(Module *M) {
}
/// printSymbolTable - Run through symbol table looking for named constants
/// if a named constant is found, emit it's declaration...
/// Assuming that symbol table has only types and constants.
/// printSymbolTable - Run through symbol table looking for type names. If a
/// type name is found, emit it's declaration...
///
void CWriter::printSymbolTable(const SymbolTable &ST) {
for (SymbolTable::const_iterator TI = ST.begin(); TI != ST.end(); ++TI) {
SymbolTable::type_const_iterator I = ST.type_begin(TI->first);
SymbolTable::type_const_iterator End = ST.type_end(TI->first);
// If there are no type names, exit early.
if (ST.find(Type::TypeTy) == ST.end())
return;
// We are only interested in the type plane of the symbol table...
SymbolTable::type_const_iterator I = ST.type_begin(Type::TypeTy);
SymbolTable::type_const_iterator End = ST.type_end(Type::TypeTy);
for (; I != End; ++I) {
const Value *V = I->second;
@ -589,7 +592,6 @@ void CWriter::printSymbolTable(const SymbolTable &ST) {
Out << ";\n";
}
}
}
Out << "\n";
@ -598,14 +600,10 @@ void CWriter::printSymbolTable(const SymbolTable &ST) {
// Loop over all structures then push them into the stack so they are
// printed in the correct order.
for (SymbolTable::const_iterator TI = ST.begin(); TI != ST.end(); ++TI) {
SymbolTable::type_const_iterator I = ST.type_begin(TI->first);
SymbolTable::type_const_iterator End = ST.type_end(TI->first);
for (; I != End; ++I)
//
for (I = ST.type_begin(Type::TypeTy); I != End; ++I)
if (const StructType *STy = dyn_cast<StructType>(I->second))
printContainedStructs(STy, StructPrinted);
}
}
// Push the struct onto the stack and recursively push all structs

View File

@ -566,14 +566,17 @@ void CWriter::printModule(Module *M) {
}
/// printSymbolTable - Run through symbol table looking for named constants
/// if a named constant is found, emit it's declaration...
/// Assuming that symbol table has only types and constants.
/// printSymbolTable - Run through symbol table looking for type names. If a
/// type name is found, emit it's declaration...
///
void CWriter::printSymbolTable(const SymbolTable &ST) {
for (SymbolTable::const_iterator TI = ST.begin(); TI != ST.end(); ++TI) {
SymbolTable::type_const_iterator I = ST.type_begin(TI->first);
SymbolTable::type_const_iterator End = ST.type_end(TI->first);
// If there are no type names, exit early.
if (ST.find(Type::TypeTy) == ST.end())
return;
// We are only interested in the type plane of the symbol table...
SymbolTable::type_const_iterator I = ST.type_begin(Type::TypeTy);
SymbolTable::type_const_iterator End = ST.type_end(Type::TypeTy);
for (; I != End; ++I) {
const Value *V = I->second;
@ -589,7 +592,6 @@ void CWriter::printSymbolTable(const SymbolTable &ST) {
Out << ";\n";
}
}
}
Out << "\n";
@ -598,14 +600,10 @@ void CWriter::printSymbolTable(const SymbolTable &ST) {
// Loop over all structures then push them into the stack so they are
// printed in the correct order.
for (SymbolTable::const_iterator TI = ST.begin(); TI != ST.end(); ++TI) {
SymbolTable::type_const_iterator I = ST.type_begin(TI->first);
SymbolTable::type_const_iterator End = ST.type_end(TI->first);
for (; I != End; ++I)
//
for (I = ST.type_begin(Type::TypeTy); I != End; ++I)
if (const StructType *STy = dyn_cast<StructType>(I->second))
printContainedStructs(STy, StructPrinted);
}
}
// Push the struct onto the stack and recursively push all structs