From 9127be8a19471039f1c8e50e92c8ebd0460048e9 Mon Sep 17 00:00:00 2001 From: Bill Wendling Date: Mon, 3 Dec 2012 19:44:25 +0000 Subject: Add 'getInt64Field()' method to get the signed integer instead of unsigned. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@169145 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/DebugInfo.h | 1 + lib/VMCore/DebugInfo.cpp | 12 ++++++++++++ 2 files changed, 13 insertions(+) diff --git a/include/llvm/DebugInfo.h b/include/llvm/DebugInfo.h index e66ee933b3..ee0505b2f5 100644 --- a/include/llvm/DebugInfo.h +++ b/include/llvm/DebugInfo.h @@ -71,6 +71,7 @@ namespace llvm { return (unsigned)getUInt64Field(Elt); } uint64_t getUInt64Field(unsigned Elt) const; + int64_t getInt64Field(unsigned Elt) const; DIDescriptor getDescriptorField(unsigned Elt) const; template diff --git a/lib/VMCore/DebugInfo.cpp b/lib/VMCore/DebugInfo.cpp index 7d8cf72aab..73eb92ee84 100644 --- a/lib/VMCore/DebugInfo.cpp +++ b/lib/VMCore/DebugInfo.cpp @@ -75,6 +75,18 @@ uint64_t DIDescriptor::getUInt64Field(unsigned Elt) const { return 0; } +int64_t DIDescriptor::getInt64Field(unsigned Elt) const { + if (DbgNode == 0) + return 0; + + if (Elt < DbgNode->getNumOperands()) + if (ConstantInt *CI + = dyn_cast_or_null(DbgNode->getOperand(Elt))) + return CI->getSExtValue(); + + return 0; +} + DIDescriptor DIDescriptor::getDescriptorField(unsigned Elt) const { if (DbgNode == 0) return DIDescriptor(); -- cgit v1.2.3-18-g5258