//===-- llvm/CodeGen/MachineDebugInfo.cpp -----------------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file was developed by James M. Laskey and is distributed under // the University of Illinois Open Source License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // Collect debug information for a module. This information should be in a // neutral form that can be used by different debugging schemes. // //===----------------------------------------------------------------------===// #include "llvm/CodeGen/MachineDebugInfo.h" using namespace llvm; // Handle the Pass registration stuff necessary to use TargetData's. namespace { RegisterPass X("machinedebuginfo", "Debug Information", PassInfo::Analysis | PassInfo::Optimization); } namespace llvm { /// DebugInfo - Keep track of debug information for the function. /// // FIXME - making it global until we can find a proper place to hang it from. MachineDebugInfo *DebugInfo; // FIXME - temporary hack until we can find a place to hand debug info from. ModulePass *createDebugInfoPass() { if (!DebugInfo) DebugInfo = new MachineDebugInfo(); return (ModulePass *)DebugInfo; } /// getDebugInfo - Returns the DebugInfo. MachineDebugInfo &getMachineDebugInfo() { assert(DebugInfo && "DebugInfo pass not created"); return *DebugInfo; } /// doInitialization - Initialize the debug state for a new module. /// bool MachineDebugInfo::doInitialization() { return true; } /// doFinalization - Tear down the debug state after completion of a module. /// bool MachineDebugInfo::doFinalization() { return true; } /// RecordSource - Register a source file with debug info. Returns an id. /// unsigned MachineDebugInfo::RecordSource(std::string fname, std::string dirname) { // Compose a key std::string path = dirname + "/" + fname; // Check if the source file is already recorded StrIntMapIter SMI = SourceMap.find(path); // If already there return existing id if (SMI != SourceMap.end()) return SMI->second; // Bump up the count ++SourceCount; // Record the count SourceMap[path] = SourceCount; // Return id return SourceCount; } /// getSourceFiles - Return a vector of files. Vector index + 1 equals id. /// std::vector MachineDebugInfo::getSourceFiles() { std::vector Sources(SourceCount); for (StrIntMapIter SMI = SourceMap.begin(), E = SourceMap.end(); SMI != E; SMI++) { unsigned Index = SMI->second - 1; std::string Path = SMI->first; Sources[Index] = Path; } return Sources; } };