aboutsummaryrefslogtreecommitdiff
path: root/bindings
diff options
context:
space:
mode:
authorSerge Guelton <sguelton@quarkslab.com>2019-01-03 15:43:14 +0000
committerSerge Guelton <sguelton@quarkslab.com>2019-01-03 15:43:14 +0000
commit19b8509e559a1e8c25af2b5caa7a72ff991d2b07 (patch)
treee1d06c8febd3d46717b69469df371afb7f8a4075 /bindings
parent39c11273d10721c36624abcf7494060587e156df (diff)
downloadllvm-19b8509e559a1e8c25af2b5caa7a72ff991d2b07.tar.gz
Python compat - iterator protocol
In Python2 next() is used wile it's __next__ in Python3. Differential Revision: https://reviews.llvm.org/D56250 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@350326 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'bindings')
-rw-r--r--bindings/python/llvm/core.py21
1 files changed, 16 insertions, 5 deletions
diff --git a/bindings/python/llvm/core.py b/bindings/python/llvm/core.py
index 43a318f2efb..81e354af062 100644
--- a/bindings/python/llvm/core.py
+++ b/bindings/python/llvm/core.py
@@ -19,6 +19,8 @@ from ctypes import byref
from ctypes import c_char_p
from ctypes import c_uint
+import sys
+
__all__ = [
"lib",
"Enums",
@@ -236,7 +238,7 @@ class Module(LLVMObject):
def __iter__(self):
return self
- def next(self):
+ def __next__(self):
if not isinstance(self.function, Function):
raise StopIteration("")
result = self.function
@@ -245,7 +247,10 @@ class Module(LLVMObject):
else:
self.function = self.function.next
return result
-
+
+ if sys.version_info.major == 2:
+ next = __next__
+
def __iter__(self):
return Module.__function_iterator(self)
@@ -304,7 +309,7 @@ class Function(Value):
def __iter__(self):
return self
- def next(self):
+ def __next__(self):
if not isinstance(self.bb, BasicBlock):
raise StopIteration("")
result = self.bb
@@ -313,6 +318,9 @@ class Function(Value):
else:
self.bb = self.bb.next
return result
+
+ if sys.version_info.major == 2:
+ next = __next__
def __iter__(self):
return Function.__bb_iterator(self)
@@ -381,7 +389,7 @@ class BasicBlock(LLVMObject):
def __iter__(self):
return self
- def next(self):
+ def __next__(self):
if not isinstance(self.inst, Instruction):
raise StopIteration("")
result = self.inst
@@ -390,7 +398,10 @@ class BasicBlock(LLVMObject):
else:
self.inst = self.inst.next
return result
-
+
+ if sys.version_info.major == 2:
+ next = __next__
+
def __iter__(self):
return BasicBlock.__inst_iterator(self)