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
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
15613e7c
Commit
15613e7c
authored
Aug 13, 2009
by
Robert Bradshaw
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Propagate more type specialization.
parent
fe2b8aaf
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
70 additions
and
8 deletions
+70
-8
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+7
-3
Cython/Compiler/PyrexTypes.py
Cython/Compiler/PyrexTypes.py
+56
-5
Cython/Compiler/Symtab.py
Cython/Compiler/Symtab.py
+7
-0
No files found.
Cython/Compiler/Nodes.py
View file @
15613e7c
...
@@ -728,7 +728,7 @@ class CSimpleBaseTypeNode(CBaseTypeNode):
...
@@ -728,7 +728,7 @@ class CSimpleBaseTypeNode(CBaseTypeNode):
if
self
.
templates
:
if
self
.
templates
:
if
not
self
.
name
in
self
.
templates
:
if
not
self
.
name
in
self
.
templates
:
error
(
self
.
pos
,
"'%s' is not a type identifier"
%
self
.
name
)
error
(
self
.
pos
,
"'%s' is not a type identifier"
%
self
.
name
)
type
=
PyrexTypes
.
Template
d
Type
(
self
.
name
)
type
=
PyrexTypes
.
Template
Placeholder
Type
(
self
.
name
)
else
:
else
:
error
(
self
.
pos
,
"'%s' is not a type identifier"
%
self
.
name
)
error
(
self
.
pos
,
"'%s' is not a type identifier"
%
self
.
name
)
if
self
.
complex
:
if
self
.
complex
:
...
@@ -771,7 +771,7 @@ class TemplatedTypeNode(CBaseTypeNode):
...
@@ -771,7 +771,7 @@ class TemplatedTypeNode(CBaseTypeNode):
template_types
=
[]
template_types
=
[]
for
template_node
in
self
.
positional_args
:
for
template_node
in
self
.
positional_args
:
template_types
.
append
(
template_node
.
analyse_as_type
(
env
))
template_types
.
append
(
template_node
.
analyse_as_type
(
env
))
self
.
type
=
base_type
.
specialize
(
self
.
pos
,
template_types
)
self
.
type
=
base_type
.
specialize
_here
(
self
.
pos
,
template_types
)
else
:
else
:
...
@@ -956,9 +956,13 @@ class CppClassNode(CStructOrUnionDefNode):
...
@@ -956,9 +956,13 @@ class CppClassNode(CStructOrUnionDefNode):
error
(
self
.
pos
,
"'%s' is not a cpp class type"
%
base_class_name
)
error
(
self
.
pos
,
"'%s' is not a cpp class type"
%
base_class_name
)
else
:
else
:
base_class_types
.
append
(
base_class_entry
.
type
)
base_class_types
.
append
(
base_class_entry
.
type
)
if
self
.
templates
is
None
:
template_types
=
None
else
:
template_types
=
[
PyrexTypes
.
TemplatePlaceholderType
(
template_name
)
for
template_name
in
self
.
templates
]
self
.
entry
=
env
.
declare_cpp_class
(
self
.
entry
=
env
.
declare_cpp_class
(
self
.
name
,
scope
,
self
.
pos
,
self
.
name
,
scope
,
self
.
pos
,
self
.
cname
,
base_class_types
,
visibility
=
self
.
visibility
,
templates
=
self
.
templat
es
)
self
.
cname
,
base_class_types
,
visibility
=
self
.
visibility
,
templates
=
template_typ
es
)
self
.
entry
.
is_cpp_class
=
1
self
.
entry
.
is_cpp_class
=
1
if
self
.
attributes
is
not
None
:
if
self
.
attributes
is
not
None
:
if
self
.
in_pxd
and
not
env
.
in_cinclude
:
if
self
.
in_pxd
and
not
env
.
in_cinclude
:
...
...
Cython/Compiler/PyrexTypes.py
View file @
15613e7c
...
@@ -108,6 +108,9 @@ class PyrexType(BaseType):
...
@@ -108,6 +108,9 @@ class PyrexType(BaseType):
# If a typedef, returns the base type.
# If a typedef, returns the base type.
return
self
return
self
def
specialize
(
self
,
values
):
return
self
def
literal_code
(
self
,
value
):
def
literal_code
(
self
,
value
):
# Returns a C code fragment representing a literal
# Returns a C code fragment representing a literal
# value of this type.
# value of this type.
...
@@ -999,6 +1002,13 @@ class CPtrType(CType):
...
@@ -999,6 +1002,13 @@ class CPtrType(CType):
if
other_type
.
is_array
or
other_type
.
is_ptr
:
if
other_type
.
is_array
or
other_type
.
is_ptr
:
return
self
.
base_type
.
is_void
or
self
.
base_type
.
same_as
(
other_type
.
base_type
)
return
self
.
base_type
.
is_void
or
self
.
base_type
.
same_as
(
other_type
.
base_type
)
return
0
return
0
def
specialize
(
self
,
values
):
base_type
=
self
.
base_type
.
specialize
(
values
)
if
base_type
==
self
.
base_type
:
return
self
else
:
return
CPtrType
(
base_type
)
class
CNullPtrType
(
CPtrType
):
class
CNullPtrType
(
CPtrType
):
...
@@ -1376,15 +1386,17 @@ class CppClassType(CType):
...
@@ -1376,15 +1386,17 @@ class CppClassType(CType):
has_attributes
=
1
has_attributes
=
1
exception_check
=
True
exception_check
=
True
def
__init__
(
self
,
name
,
scope
,
cname
,
base_classes
,
templates
=
None
):
def
__init__
(
self
,
name
,
scope
,
cname
,
base_classes
,
templates
=
None
,
template_type
=
None
):
self
.
name
=
name
self
.
name
=
name
self
.
cname
=
cname
self
.
cname
=
cname
self
.
scope
=
scope
self
.
scope
=
scope
self
.
base_classes
=
base_classes
self
.
base_classes
=
base_classes
self
.
operators
=
[]
self
.
operators
=
[]
self
.
templates
=
templates
self
.
templates
=
templates
self
.
template_type
=
template_type
def
specialize
(
self
,
pos
,
template_values
):
def
specialize_here
(
self
,
pos
,
template_values
=
None
):
# TODO: cache for efficiency
if
self
.
templates
is
None
:
if
self
.
templates
is
None
:
error
(
pos
,
"'%s' type is not a template"
%
self
);
error
(
pos
,
"'%s' type is not a template"
%
self
);
return
PyrexTypes
.
error_type
return
PyrexTypes
.
error_type
...
@@ -1392,7 +1404,13 @@ class CppClassType(CType):
...
@@ -1392,7 +1404,13 @@ class CppClassType(CType):
error
(
pos
,
"%s templated type receives %d arguments, got %d"
%
error
(
pos
,
"%s templated type receives %d arguments, got %d"
%
(
base_type
,
len
(
self
.
templates
),
len
(
template_values
)))
(
base_type
,
len
(
self
.
templates
),
len
(
template_values
)))
return
PyrexTypes
.
error_type
return
PyrexTypes
.
error_type
return
CppClassType
(
self
.
name
,
self
.
scope
,
self
.
cname
,
self
.
base_classes
,
template_values
)
return
self
.
specialize
(
dict
(
zip
(
self
.
templates
,
template_values
)))
def
specialize
(
self
,
values
):
# TODO: cache for efficiency
template_values
=
[
t
.
specialize
(
values
)
for
t
in
self
.
templates
]
return
CppClassType
(
self
.
name
,
self
.
scope
.
specialize
(
values
),
self
.
cname
,
self
.
base_classes
,
template_values
,
template_type
=
self
)
def
declaration_code
(
self
,
entity_code
,
for_display
=
0
,
dll_linkage
=
None
,
pyrex
=
0
):
def
declaration_code
(
self
,
entity_code
,
for_display
=
0
,
dll_linkage
=
None
,
pyrex
=
0
):
if
self
.
templates
:
if
self
.
templates
:
...
@@ -1407,24 +1425,57 @@ class CppClassType(CType):
...
@@ -1407,24 +1425,57 @@ class CppClassType(CType):
return
"%s %s%s"
%
(
name
,
entity_code
,
templates
)
return
"%s %s%s"
%
(
name
,
entity_code
,
templates
)
def
is_subclass
(
self
,
other_type
):
def
is_subclass
(
self
,
other_type
):
# TODO: handle templates
if
self
.
same_as_resolved_type
(
other_type
):
if
self
.
same_as_resolved_type
(
other_type
):
return
1
return
1
for
base_class
in
self
.
base_classes
:
for
base_class
in
self
.
base_classes
:
if
base_class
.
is_subclass
(
other_type
):
if
base_class
.
is_subclass
(
other_type
):
return
1
return
1
return
0
return
0
def
same_as_resolved_type
(
self
,
other_type
):
if
other_type
.
is_cpp_class
:
if
self
==
other_type
:
return
1
elif
self
.
template_type
==
other
.
template_type
:
for
t1
,
t2
in
zip
(
self
.
templates
,
other
.
templates
):
if
not
t1
.
same_as_resolved_type
(
t2
):
return
0
return
1
return
0
def
attributes_known
(
self
):
def
attributes_known
(
self
):
return
self
.
scope
is
not
None
return
self
.
scope
is
not
None
class
Template
d
Type
(
CType
):
class
Template
Placeholder
Type
(
CType
):
def
__init__
(
self
,
name
):
def
__init__
(
self
,
name
):
self
.
name
=
name
self
.
name
=
name
def
declaration_code
(
self
,
entity_code
,
for_display
=
0
,
dll_linkage
=
None
,
pyrex
=
0
):
def
declaration_code
(
self
,
entity_code
,
for_display
=
0
,
dll_linkage
=
None
,
pyrex
=
0
):
return
""
return
self
.
name
+
" "
+
entity_code
def
specialize
(
self
,
values
):
if
self
in
values
:
return
values
[
self
]
else
:
return
self
def
same_as_resolved_type
(
self
,
other_type
):
if
isinstance
(
other_type
,
TemplatePlaceholderType
):
return
self
.
name
==
other
.
name
else
:
return
0
def
__hash__
(
self
):
return
hash
(
self
.
name
)
def
__cmp__
(
self
,
other
):
if
isinstance
(
other
,
TemplatePlaceholderType
):
return
cmp
(
self
.
name
,
other
.
name
)
else
:
return
cmp
(
type
(
self
),
type
(
other
))
class
CEnumType
(
CType
):
class
CEnumType
(
CType
):
# name string
# name string
...
...
Cython/Compiler/Symtab.py
View file @
15613e7c
...
@@ -1638,6 +1638,13 @@ class CppClassScope(Scope):
...
@@ -1638,6 +1638,13 @@ class CppClassScope(Scope):
base_entry
.
pos
,
adapt
(
base_entry
.
cname
),
base_entry
.
pos
,
adapt
(
base_entry
.
cname
),
base_entry
.
visibility
,
base_entry
.
func_modifiers
)
base_entry
.
visibility
,
base_entry
.
func_modifiers
)
entry
.
is_inherited
=
1
entry
.
is_inherited
=
1
def
specialize
(
self
,
values
):
scope
=
CppClassScope
()
for
entry
in
self
.
entries
.
values
():
scope
.
declare_var
(
entry
.
name
,
entry
.
type
.
specialize
(
values
),
entry
.
pos
,
entry
.
cname
,
entry
.
visibility
)
return
scope
class
PropertyScope
(
Scope
):
class
PropertyScope
(
Scope
):
# Scope holding the __get__, __set__ and __del__ methods for
# Scope holding the __get__, __set__ and __del__ methods for
...
...
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