// addSubprogram - Add subprgoram into SPs.
bool addSubprogram(DISubprogram SP);
+ /// addType - Add type into Tys.
+ bool addType(DIType DT);
+
public:
typedef SmallVector<GlobalVariable *, 8>::iterator iterator;
iterator compile_unit_begin() { return CUs.begin(); }
iterator subprogram_end() { return SPs.end(); }
iterator global_variable_begin() { return GVs.begin(); }
iterator global_variable_end() { return GVs.end(); }
+ iterator type_begin() { return TYs.begin(); }
+ iterator type_end() { return TYs.end(); }
unsigned compile_unit_count() { return CUs.size(); }
unsigned global_variable_count() { return GVs.size(); }
unsigned subprogram_count() { return SPs.size(); }
+ unsigned type_count() { return TYs.size(); }
private:
SmallVector<GlobalVariable *, 8> CUs; // Compile Units
SmallVector<GlobalVariable *, 8> SPs; // Subprograms
- SmallVector<GlobalVariable *, 8> GVs; // Global Variables;
+ SmallVector<GlobalVariable *, 8> GVs; // Global Variables
+ SmallVector<GlobalVariable *, 8> TYs; // Types
SmallPtrSet<GlobalVariable *, 64> NodesSeen;
};
/// processType - Process DIType.
void DebugInfoFinder::processType(DIType DT) {
- if (DT.isNull())
- return;
- if (!NodesSeen.insert(DT.getGV()))
+ if (!addType(DT))
return;
addCompileUnit(DT.getCompileUnit());
processType(DV.getType());
}
+/// addType - Add type into Tys.
+bool DebugInfoFinder::addType(DIType DT) {
+ if (DT.isNull())
+ return false;
+
+ if (!NodesSeen.insert(DT.getGV()))
+ return false;
+
+ TYs.push_back(DT.getGV());
+ return true;
+}
+
/// addCompileUnit - Add compile unit into CUs.
bool DebugInfoFinder::addCompileUnit(DICompileUnit CU) {
if (CU.isNull())