diff options
author | Enrico Granata <egranata@apple.com> | 2012-10-06 00:06:18 +0000 |
---|---|---|
committer | Enrico Granata <egranata@apple.com> | 2012-10-06 00:06:18 +0000 |
commit | ffe2d52a066678b17539960ba945f2e07899a716 (patch) | |
tree | 26feac407b9b52394772fcdebda8f18a56197818 /lldb/scripts/Python/python-extensions.swig | |
parent | 6a41c3c005fcb11449f3874e13a96fd25734d93f (diff) | |
download | bcm5719-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.swig | 31 |
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) |