| //===-- RuntimeInfo.cpp - Compute and cache info about running program ----===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file was developed by the LLVM research group and is distributed under |
| // the University of Illinois Open Source License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file implements the RuntimeInfo and related classes, by querying and |
| // cachine information from the running inferior process. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "llvm/Debugger/InferiorProcess.h" |
| #include "llvm/Debugger/ProgramInfo.h" |
| #include "llvm/Debugger/RuntimeInfo.h" |
| using namespace llvm; |
| |
| //===----------------------------------------------------------------------===// |
| // StackFrame class implementation |
| |
| StackFrame::StackFrame(RuntimeInfo &ri, void *ParentFrameID) |
| : RI(ri), SourceInfo(0) { |
| FrameID = RI.getInferiorProcess().getPreviousFrame(ParentFrameID); |
| if (FrameID == 0) throw "Stack frame does not exist!"; |
| |
| // Compute lazily as needed. |
| FunctionDesc = 0; |
| } |
| |
| const GlobalVariable *StackFrame::getFunctionDesc() { |
| if (FunctionDesc == 0) |
| FunctionDesc = RI.getInferiorProcess().getSubprogramDesc(FrameID); |
| return FunctionDesc; |
| } |
| |
| /// getSourceLocation - Return the source location that this stack frame is |
| /// sitting at. |
| void StackFrame::getSourceLocation(unsigned &lineNo, unsigned &colNo, |
| const SourceFileInfo *&sourceInfo) { |
| if (SourceInfo == 0) { |
| const GlobalVariable *SourceDesc = 0; |
| RI.getInferiorProcess().getFrameLocation(FrameID, LineNo,ColNo, SourceDesc); |
| SourceInfo = &RI.getProgramInfo().getSourceFile(SourceDesc); |
| } |
| |
| lineNo = LineNo; |
| colNo = ColNo; |
| sourceInfo = SourceInfo; |
| } |
| |
| //===----------------------------------------------------------------------===// |
| // RuntimeInfo class implementation |
| |
| /// materializeFrame - Create and process all frames up to and including the |
| /// specified frame number. This throws an exception if the specified frame |
| /// ID is nonexistant. |
| void RuntimeInfo::materializeFrame(unsigned ID) { |
| assert(ID >= CallStack.size() && "no need to materialize this frame!"); |
| void *CurFrame = 0; |
| if (!CallStack.empty()) |
| CurFrame = CallStack.back().getFrameID(); |
| |
| while (CallStack.size() <= ID) { |
| CallStack.push_back(StackFrame(*this, CurFrame)); |
| CurFrame = CallStack.back().getFrameID(); |
| } |
| } |