diff options
author | Stuart Hastings <stuart@apple.com> | 2010-06-11 20:08:44 +0000 |
---|---|---|
committer | Stuart Hastings <stuart@apple.com> | 2010-06-11 20:08:44 +0000 |
commit | afe54f1625f57ab65a8446d582621a167eec5c9a (patch) | |
tree | 96af7e8995ef3dcb1715f8c9c3a6969a1371e2c6 /llvm/lib/Analysis/DebugInfo.cpp | |
parent | 6111abf8ad70095be2214f8354045412a9bee126 (diff) | |
download | bcm5719-llvm-afe54f1625f57ab65a8446d582621a167eec5c9a.tar.gz bcm5719-llvm-afe54f1625f57ab65a8446d582621a167eec5c9a.zip |
Support for nested functions/classes in debug output. (Again.) Radar 7424645.
llvm-svn: 105828
Diffstat (limited to 'llvm/lib/Analysis/DebugInfo.cpp')
-rw-r--r-- | llvm/lib/Analysis/DebugInfo.cpp | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/llvm/lib/Analysis/DebugInfo.cpp b/llvm/lib/Analysis/DebugInfo.cpp index 46abf333398..774dce06421 100644 --- a/llvm/lib/Analysis/DebugInfo.cpp +++ b/llvm/lib/Analysis/DebugInfo.cpp @@ -73,6 +73,15 @@ GlobalVariable *DIDescriptor::getGlobalVariableField(unsigned Elt) const { return 0; } +Function *DIDescriptor::getFunctionField(unsigned Elt) const { + if (DbgNode == 0) + return 0; + + if (Elt < DbgNode->getNumOperands()) + return dyn_cast_or_null<Function>(DbgNode->getOperand(Elt)); + return 0; +} + unsigned DIVariable::getNumAddrElements() const { return DbgNode->getNumOperands()-6; } @@ -938,7 +947,8 @@ DISubprogram DIFactory::CreateSubprogram(DIDescriptor Context, unsigned VK, unsigned VIndex, DIType ContainingType, bool isArtificial, - bool isOptimized) { + bool isOptimized, + Function *Fn) { Value *Elts[] = { GetTagConstant(dwarf::DW_TAG_subprogram), @@ -956,9 +966,10 @@ DISubprogram DIFactory::CreateSubprogram(DIDescriptor Context, ConstantInt::get(Type::getInt32Ty(VMContext), VIndex), ContainingType, ConstantInt::get(Type::getInt1Ty(VMContext), isArtificial), - ConstantInt::get(Type::getInt1Ty(VMContext), isOptimized) + ConstantInt::get(Type::getInt1Ty(VMContext), isOptimized), + Fn }; - return DISubprogram(MDNode::get(VMContext, &Elts[0], 16)); + return DISubprogram(MDNode::get(VMContext, &Elts[0], 17)); } /// CreateSubprogramDefinition - Create new subprogram descriptor for the |