Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
cython
Commits
2a5e66ae
Commit
2a5e66ae
authored
Nov 03, 2009
by
Dag Sverre Seljebotn
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix #441
parent
cf818792
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
66 additions
and
22 deletions
+66
-22
Cython/Compiler/Code.py
Cython/Compiler/Code.py
+4
-2
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+6
-2
Cython/Compiler/PyrexTypes.py
Cython/Compiler/PyrexTypes.py
+19
-11
tests/run/complex_numbers_T305.pyx
tests/run/complex_numbers_T305.pyx
+37
-7
No files found.
Cython/Compiler/Code.py
View file @
2a5e66ae
...
@@ -408,8 +408,10 @@ class GlobalState(object):
...
@@ -408,8 +408,10 @@ class GlobalState(object):
code_layout = [
code_layout = [
'h_code',
'h_code',
'utility_code_proto_before_types',
'utility_code_proto_before_types',
'type_declarations',
'numeric_typedefs', # Let these detailed individual parts stay!,
'utility_code_proto',
'complex_type_declarations', # as the proper solution is to make a full DAG...
'type_declarations', # More coarse-grained blocks would simply hide
'utility_code_proto', # the ugliness, not fix it
'module_declarations',
'module_declarations',
'typeinfo',
'typeinfo',
'before_global_var',
'before_global_var',
...
...
Cython/Compiler/ModuleNode.py
View file @
2a5e66ae
...
@@ -654,8 +654,12 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
...
@@ -654,8 +654,12 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
def
generate_typedef
(
self
,
entry
,
code
):
def
generate_typedef
(
self
,
entry
,
code
):
base_type
=
entry
.
type
.
typedef_base_type
base_type
=
entry
.
type
.
typedef_base_type
code
.
putln
(
""
)
if
base_type
.
is_numeric
:
code
.
putln
(
"typedef %s;"
%
base_type
.
declaration_code
(
entry
.
cname
))
writer
=
code
.
globalstate
[
'numeric_typedefs'
]
else
:
writer
=
code
writer
.
putln
(
""
)
writer
.
putln
(
"typedef %s;"
%
base_type
.
declaration_code
(
entry
.
cname
))
def
sue_header_footer
(
self
,
type
,
kind
,
name
):
def
sue_header_footer
(
self
,
type
,
kind
,
name
):
if
type
.
typedef_flag
:
if
type
.
typedef_flag
:
...
...
Cython/Compiler/PyrexTypes.py
View file @
2a5e66ae
...
@@ -871,12 +871,21 @@ class CComplexType(CNumericType):
...
@@ -871,12 +871,21 @@ class CComplexType(CNumericType):
scope
=
None
scope
=
None
def
__init__
(
self
,
real_type
):
def
__init__
(
self
,
real_type
):
while
real_type
.
is_typedef
and
not
real_type
.
typedef_is_external
:
real_type
=
real_type
.
typedef_base_type
if
real_type
.
is_typedef
and
real_type
.
typedef_is_external
:
# The below is not actually used: Coercions are currently disabled
# so that complex types of external types can not be created
self
.
funcsuffix
=
"_%s"
%
real_type
.
specalization_name
()
else
:
self
.
funcsuffix
=
real_type
.
math_h_modifier
self
.
real_type
=
real_type
self
.
real_type
=
real_type
CNumericType
.
__init__
(
self
,
real_type
.
rank
+
0.5
,
real_type
.
signed
)
CNumericType
.
__init__
(
self
,
real_type
.
rank
+
0.5
,
real_type
.
signed
)
self
.
binops
=
{}
self
.
binops
=
{}
self
.
from_parts
=
"%s_from_parts"
%
self
.
specalization_name
()
self
.
from_parts
=
"%s_from_parts"
%
self
.
specalization_name
()
self
.
default_value
=
"%s(0, 0)"
%
self
.
from_parts
self
.
default_value
=
"%s(0, 0)"
%
self
.
from_parts
def
__eq__
(
self
,
other
):
def
__eq__
(
self
,
other
):
if
isinstance
(
self
,
CComplexType
)
and
isinstance
(
other
,
CComplexType
):
if
isinstance
(
self
,
CComplexType
)
and
isinstance
(
other
,
CComplexType
):
return
self
.
real_type
==
other
.
real_type
return
self
.
real_type
==
other
.
real_type
...
@@ -899,7 +908,7 @@ class CComplexType(CNumericType):
...
@@ -899,7 +908,7 @@ class CComplexType(CNumericType):
def
__hash__
(
self
):
def
__hash__
(
self
):
return
~
hash
(
self
.
real_type
)
return
~
hash
(
self
.
real_type
)
def
declaration_code
(
self
,
entity_code
,
def
declaration_code
(
self
,
entity_code
,
for_display
=
0
,
dll_linkage
=
None
,
pyrex
=
0
):
for_display
=
0
,
dll_linkage
=
None
,
pyrex
=
0
):
if
for_display
:
if
for_display
:
...
@@ -915,8 +924,9 @@ class CComplexType(CNumericType):
...
@@ -915,8 +924,9 @@ class CComplexType(CNumericType):
def
assignable_from
(
self
,
src_type
):
def
assignable_from
(
self
,
src_type
):
# Temporary hack/feature disabling, see #441
# Temporary hack/feature disabling, see #441
if
not
src_type
.
is_complex
and
src_type
.
is_numeric
and
src_type
.
is_typedef
:
if
(
not
src_type
.
is_complex
and
src_type
.
is_numeric
and
src_type
.
is_typedef
return
False
and
src_type
.
typedef_is_external
):
return
False
else
:
else
:
return
super
(
CComplexType
,
self
).
assignable_from
(
src_type
)
return
super
(
CComplexType
,
self
).
assignable_from
(
src_type
)
...
@@ -940,7 +950,7 @@ class CComplexType(CNumericType):
...
@@ -940,7 +950,7 @@ class CComplexType(CNumericType):
CFuncType
(
self
,
[
CFuncTypeArg
(
"self"
,
self
,
None
)]),
CFuncType
(
self
,
[
CFuncTypeArg
(
"self"
,
self
,
None
)]),
pos
=
None
,
pos
=
None
,
defining
=
1
,
defining
=
1
,
cname
=
"__Pyx_c_conj%s"
%
self
.
real_type
.
math_h_modifier
)
cname
=
"__Pyx_c_conj%s"
%
self
.
funcsuffix
)
return
True
return
True
...
@@ -956,7 +966,7 @@ class CComplexType(CNumericType):
...
@@ -956,7 +966,7 @@ class CComplexType(CNumericType):
utility_code
.
specialize
(
utility_code
.
specialize
(
self
,
self
,
real_type
=
self
.
real_type
.
declaration_code
(
''
),
real_type
=
self
.
real_type
.
declaration_code
(
''
),
m
=
self
.
real_type
.
math_h_modifier
))
m
=
self
.
funcsuffix
))
return
True
return
True
def
create_to_py_utility_code
(
self
,
env
):
def
create_to_py_utility_code
(
self
,
env
):
...
@@ -973,7 +983,7 @@ class CComplexType(CNumericType):
...
@@ -973,7 +983,7 @@ class CComplexType(CNumericType):
utility_code
.
specialize
(
utility_code
.
specialize
(
self
,
self
,
real_type
=
self
.
real_type
.
declaration_code
(
''
),
real_type
=
self
.
real_type
.
declaration_code
(
''
),
m
=
self
.
real_type
.
math_h_modifier
))
m
=
self
.
funcsuffix
))
self
.
from_py_function
=
"__Pyx_PyComplex_As_"
+
self
.
specalization_name
()
self
.
from_py_function
=
"__Pyx_PyComplex_As_"
+
self
.
specalization_name
()
return
True
return
True
...
@@ -984,8 +994,7 @@ class CComplexType(CNumericType):
...
@@ -984,8 +994,7 @@ class CComplexType(CNumericType):
pass
pass
try
:
try
:
op_name
=
complex_ops
[
nargs
,
op
]
op_name
=
complex_ops
[
nargs
,
op
]
modifier
=
self
.
real_type
.
math_h_modifier
self
.
binops
[
nargs
,
op
]
=
func_name
=
"__Pyx_c_%s%s"
%
(
op_name
,
self
.
funcsuffix
)
self
.
binops
[
nargs
,
op
]
=
func_name
=
"__Pyx_c_%s%s"
%
(
op_name
,
modifier
)
return
func_name
return
func_name
except
KeyError
:
except
KeyError
:
return
None
return
None
...
@@ -1045,7 +1054,7 @@ proto="""
...
@@ -1045,7 +1054,7 @@ proto="""
"""
)
"""
)
complex_type_utility_code
=
UtilityCode
(
complex_type_utility_code
=
UtilityCode
(
proto_block
=
'
utility_code_proto_before_type
s'
,
proto_block
=
'
complex_type_declaration
s'
,
proto
=
"""
proto
=
"""
#if CYTHON_CCOMPLEX
#if CYTHON_CCOMPLEX
#ifdef __cplusplus
#ifdef __cplusplus
...
@@ -1204,7 +1213,6 @@ impl="""
...
@@ -1204,7 +1213,6 @@ impl="""
#endif
#endif
"""
)
"""
)
class
CArrayType
(
CType
):
class
CArrayType
(
CType
):
# base_type CType Element type
# base_type CType Element type
# size integer or None Number of elements
# size integer or None Number of elements
...
...
tests/run/complex_numbers_T305.pyx
View file @
2a5e66ae
...
@@ -123,15 +123,45 @@ def test_conjugate_double(double complex z):
...
@@ -123,15 +123,45 @@ def test_conjugate_double(double complex z):
ctypedef
double
complex
cdouble
ctypedef
double
complex
cdouble
def
test_conjugate_typedef
(
cdouble
z
):
def
test_conjugate_typedef
(
cdouble
z
):
"""
>>> test_conjugate_typedef(2+3j)
(2-3j)
"""
return
z
.
conjugate
()
return
z
.
conjugate
()
#ctypedef double mydouble
## cdef extern from "complex_numbers_T305.h":
#def test_coerce_typedef_multiply(mydouble x, double complex z):
## ctypedef double double_really_float "myfloat"
# """
## ctypedef float float_really_double "mydouble"
# >>> test_coerce_typedef_multiply(3, 1j)
## ctypedef float real_float "myfloat"
# (3j)
## ctypedef double real_double "mydouble"
# """
# return x * z
## def test_conjugate_nosizeassumptions(double_really_float x,
## float_really_double y,
## real_float z, real_double w):
## """
## >>> test_conjugate_nosizeassumptions(1, 1, 1, 1)
## (-1j, -1j, -1j, -1j)
## >>> ["%.2f" % x.imag for x in test_conjugate_nosizeassumptions(2e300, 2e300, 2e300, 2e300)]
## ['-inf', '-2e+300', '-inf', '-2e+300']
## """
## cdef double complex I = 1j
## return ((x*I).conjugate(), (y*I).conjugate(), (z*I).conjugate(), (w*I).conjugate())
ctypedef
double
mydouble
def
test_coerce_typedef_multiply
(
mydouble
x
,
double
complex
z
):
"""
>>> test_coerce_typedef_multiply(3, 1+1j)
(3+3j)
"""
return
x
*
z
ctypedef
int
myint
def
test_coerce_typedef_multiply_int
(
myint
x
,
double
complex
z
):
"""
>>> test_coerce_typedef_multiply_int(3, 1+1j)
(3+3j)
"""
return
x
*
z
cpdef
double
complex
complex_retval
():
cpdef
double
complex
complex_retval
():
"""
"""
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment