aboutsummaryrefslogtreecommitdiff
path: root/lldb/scripts/Python/modify-python-lldb.py
diff options
context:
space:
mode:
authorPavel Labath <pavel@labath.sk>2019-03-11 13:58:46 +0000
committerPavel Labath <pavel@labath.sk>2019-03-11 13:58:46 +0000
commit7f5237bccc27103c2718139e8316f14028ca9a5e (patch)
tree11a9d4cf1be8828f7fd14ffa958bd6758613568a /lldb/scripts/Python/modify-python-lldb.py
parent52760bf43525018bf19b5d3533d3e0b907bb8dae (diff)
downloadllvm-7f5237bccc27103c2718139e8316f14028ca9a5e.zip
llvm-7f5237bccc27103c2718139e8316f14028ca9a5e.tar.gz
llvm-7f5237bccc27103c2718139e8316f14028ca9a5e.tar.bz2
Add "operator bool" to SB APIs
Summary: Our python version of the SB API has (the python equivalent of) operator bool, but the C++ version doesn't. This is because our python operators are added by modify-python-lldb.py, which performs postprocessing on the swig-generated interface files. In this patch, I add the "operator bool" to all SB classes which have an IsValid method (which is the same logic used by modify-python-lldb.py). This way, we make the two interfaces more constent, and it allows us to rely on swig's automatic syntesis of python __nonzero__ methods instead of doing manual fixups. Reviewers: zturner, jingham, clayborg, jfb, serge-sans-paille Subscribers: jdoerfert, lldb-commits Differential Revision: https://reviews.llvm.org/D58792 llvm-svn: 355824
Diffstat (limited to 'lldb/scripts/Python/modify-python-lldb.py')
-rw-r--r--lldb/scripts/Python/modify-python-lldb.py15
1 files changed, 0 insertions, 15 deletions
diff --git a/lldb/scripts/Python/modify-python-lldb.py b/lldb/scripts/Python/modify-python-lldb.py
index 831de5a..8852ad41 100644
--- a/lldb/scripts/Python/modify-python-lldb.py
+++ b/lldb/scripts/Python/modify-python-lldb.py
@@ -91,16 +91,6 @@ len_def = " def __len__(self): return self.%s()"
eq_def = " def __eq__(self, other): return isinstance(other, %s) and %s"
ne_def = " def __ne__(self, other): return not self.__eq__(other)"
-# Called to implement truth value testing and the built-in operation bool();
-# Note that Python 2 uses __nonzero__(), whereas Python 3 uses __bool__()
-# should return False or True, or their integer equivalents 0 or 1.
-# Delegate to self.IsValid() if it is defined for the current lldb object.
-
-if six.PY2:
- nonzero_def = " def __nonzero__(self): return self.IsValid()"
-else:
- nonzero_def = " def __bool__(self): return self.IsValid()"
-
# A convenience iterator for SBSymbol!
symbol_in_section_iter_def = '''
def symbol_in_section_iter(self, section):
@@ -332,11 +322,6 @@ for line in content.splitlines():
if one_liner_docstring_pattern.match(line):
line = char_to_str_xform(line)
- # Look for 'def IsValid(*args):', and once located, add implementation
- # of truth value testing for this object by delegation.
- if isvalid_pattern.search(line):
- new_content.add_line(nonzero_def)
-
# Pass the original line of content to new_content.
new_content.add_line(line)