summaryrefslogtreecommitdiffstats
path: root/lldb/scripts/Python/python-extensions.swig
diff options
context:
space:
mode:
authorEnrico Granata <egranata@apple.com>2012-10-06 00:06:18 +0000
committerEnrico Granata <egranata@apple.com>2012-10-06 00:06:18 +0000
commitffe2d52a066678b17539960ba945f2e07899a716 (patch)
tree26feac407b9b52394772fcdebda8f18a56197818 /lldb/scripts/Python/python-extensions.swig
parent6a41c3c005fcb11449f3874e13a96fd25734d93f (diff)
downloadbcm5719-llvm-ffe2d52a066678b17539960ba945f2e07899a716.tar.gz
bcm5719-llvm-ffe2d52a066678b17539960ba945f2e07899a716.zip
patch from Vishal Patel to improve our lldb.value wrapper
llvm-svn: 165348
Diffstat (limited to 'lldb/scripts/Python/python-extensions.swig')
-rw-r--r--lldb/scripts/Python/python-extensions.swig31
1 files changed, 20 insertions, 11 deletions
diff --git a/lldb/scripts/Python/python-extensions.swig b/lldb/scripts/Python/python-extensions.swig
index f9e5a130dbd..aa45ceeb178 100644
--- a/lldb/scripts/Python/python-extensions.swig
+++ b/lldb/scripts/Python/python-extensions.swig
@@ -539,13 +539,15 @@ class value(object):
# Allow array access if this value has children...
if type(key) is int:
return value(self.sbvalue.GetValueForExpressionPath("[%i]" % key))
- raise TypeError
+ if type(key) is value:
+ return value(self.sbvalue.GetValueForExpressionPath("[%i]" % int(key))
+ raise TypeError("No array item of type %s" % str(type(key)))
def __getattr__(self, name):
child_sbvalue = self.sbvalue.GetChildMemberWithName (name)
if child_sbvalue:
return value(child_sbvalue)
- raise AttributeError
+ raise AttributeError("Attribute '%s' is not defined" % name)
def __add__(self, other):
return int(self) + int(other)
@@ -690,15 +692,22 @@ class value(object):
return '0x%x' % self.sbvalue.GetValueAsUnsigned()
def __eq__(self, other):
- self_err = SBError()
- other_err = SBError()
- self_val = self.sbvalue.GetValueAsUnsigned(self_err)
- if self_err.fail:
- raise ValueError("unable to extract value of self")
- other_val = other.sbvalue.GetValueAsUnsigned(other_err)
- if other_err.fail:
- raise ValueError("unable to extract value of other")
- return self_val == other_val
+ if type(other) is int:
+ return int(self) == other
+ elif type(other) is str:
+ return str(self) == other
+ elif type(other) is value:
+ self_err = SBError()
+ other_err = SBError()
+ self_val = self.sbvalue.GetValueAsUnsigned(self_err)
+ if self_err.fail:
+ raise ValueError("unable to extract value of self")
+ other_val = other.sbvalue.GetValueAsUnsigned(other_err)
+ if other_err.fail:
+ raise ValueError("unable to extract value of other")
+ return self_val == other_val
+ raise TypeError("Unknown type %s, No equality operation defined." % str(type(other)))
+
def __neq__(self, other):
return not self.__eq__(other)
OpenPOWER on IntegriCloud