Commit 3d280f63 authored by Stefan Behnel's avatar Stefan Behnel

fix octal literals as Python constants, convert octal/binary/hex integer...

fix octal literals as Python constants, convert octal/binary/hex integer literals to plain decimal integers when using them as Python integers
parent 22111321
...@@ -833,19 +833,28 @@ class IntNode(ConstNode): ...@@ -833,19 +833,28 @@ class IntNode(ConstNode):
def generate_evaluation_code(self, code): def generate_evaluation_code(self, code):
if self.type.is_pyobject: if self.type.is_pyobject:
# pre-allocate a Python version of the number # pre-allocate a Python version of the number
self.result_code = code.get_py_num(self.value, self.longness) plain_integer_string = self.value_as_c_integer_string(plain_digits=True)
self.result_code = code.get_py_num(plain_integer_string, self.longness)
else: else:
self.result_code = self.get_constant_c_result_code() self.result_code = self.get_constant_c_result_code()
def get_constant_c_result_code(self): def get_constant_c_result_code(self):
return self.value_as_c_integer_string() + self.unsigned + self.longness
def value_as_c_integer_string(self, plain_digits=False):
value = self.value value = self.value
if isinstance(value, basestring) and len(value) > 2: if isinstance(value, basestring) and len(value) > 2:
# must convert C-incompatible Py3 oct/bin notations # must convert C-incompatible Py3 oct/bin notations
if value[1] in 'oO': if value[1] in 'oO':
if plain_digits:
value = int(value[2:], 8)
else:
value = value[0] + value[2:] # '0o123' => '0123' value = value[0] + value[2:] # '0o123' => '0123'
elif value[1] in 'bB': elif value[1] in 'bB':
value = int(value[2:], 2) value = int(value[2:], 2)
return str(value) + self.unsigned + self.longness elif plain_digits and value[1] in 'xX':
value = int(value[2:], 16)
return str(value)
def calculate_result_code(self): def calculate_result_code(self):
return self.result_code return self.result_code
......
...@@ -53,3 +53,56 @@ def c_long_types(): ...@@ -53,3 +53,56 @@ def c_long_types():
print typeof(1U) print typeof(1U)
print typeof(1UL) print typeof(1UL)
print typeof(1ULL) print typeof(1ULL)
# different ways to write an integer in Python
def c_oct():
"""
>>> c_oct()
(1, 17, 63)
"""
cdef int a = 0o01
cdef int b = 0o21
cdef int c = 0o77
return a,b,c
def py_oct():
"""
>>> py_oct()
(1, 17, 63)
"""
return 0o01, 0o21, 0o77
def c_hex():
"""
>>> c_hex()
(1, 33, 255)
"""
cdef int a = 0x01
cdef int b = 0x21
cdef int c = 0xFF
return a,b,c
def py_hex():
"""
>>> py_hex()
(1, 33, 255)
"""
return 0x01, 0x21, 0xFF
def c_bin():
"""
>>> c_bin()
(1, 2, 15)
"""
cdef int a = 0b01
cdef int b = 0b10
cdef int c = 0b1111
return a,b,c
def py_bin():
"""
>>> py_bin()
(1, 2, 15)
"""
return 0b01, 0b10, 0b1111
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment