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
Xavier Thompson
cython
Commits
f9ef0611
Commit
f9ef0611
authored
May 23, 2020
by
Xavier Thompson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Initialise PyObject_HEAD fields
parent
a47a6b9e
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
52 additions
and
13 deletions
+52
-13
Cython/Compiler/CypclassWrapper.py
Cython/Compiler/CypclassWrapper.py
+46
-11
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+6
-2
No files found.
Cython/Compiler/CypclassWrapper.py
View file @
f9ef0611
...
...
@@ -70,16 +70,44 @@ def cypclass_iter(scope):
for
e
in
cypclass_iter
(
cypclass_scope
):
yield
e
def
cypclass_iter_scopes
(
scope
):
"""
Recursively iterate over nested cypclasses and their associated scope
"""
for
entry
in
scope
.
cypclass_entries
:
cypclass_scope
=
entry
.
type
.
scope
yield
entry
,
cypclass_scope
if
cypclass_scope
:
for
e
,
s
in
cypclass_iter_scopes
(
cypclass_scope
):
yield
e
,
s
def
generate_cypclass_typeobj_declarations
(
env
,
code
,
definition
):
"""
Generate declarations of global pointers to the PyTypeObject for each cypclass
"""
for
entry
in
cypclass_iter
(
env
):
for
entry
,
scope
in
cypclass_iter_scopes
(
env
):
if
definition
or
entry
.
defined_in_pxd
:
code
.
putln
(
"static PyTypeObject *%s = 0;"
%
(
entry
.
type
.
typeptr_cname
))
# the entry regrouping the constructors for this cypclass
c
=
scope
.
lookup_here
(
"<constructor>"
)
# Todo: determine whether the __new__ called in the constructor
# actually returns an instance of the cypclass type.
# and do this computation only once
# (cf generate_cyp_class_wrapper_definition)
#
# n = scope.lookup_here("<new>")
# # whether a user-defined __new__ actually returns another type
# is_new_return_type = not n or (n.type.return_type == entry.type)
# if a constructor is unused it will not be defined, and if none are
# defined the PyTypeObject pointer is never assigned to an instance,
# so no need to declare it.
if
entry
.
type
.
templates
or
any
(
map
(
lambda
e
:
e
.
used
,
c
.
all_alternatives
())):
code
.
putln
(
"static PyTypeObject *%s = 0;"
%
(
entry
.
type
.
typeptr_cname
))
...
...
@@ -88,13 +116,13 @@ def generate_cypclass_typeobj_declarations(env, code, definition):
# Cypclass generation, originally authored by Gwenaël Samain, moved here from ModuleNode.py
#
def
generate_cyp_class_deferred_definitions
(
type_entries
,
code
):
def
generate_cyp_class_deferred_definitions
(
env
,
code
,
definition
):
"""
Generate all cypclass method definitions, deferred till now
"""
for
entry
in
type_entries
:
if
entry
.
type
.
is_cyp_class
:
for
entry
,
scope
in
cypclass_iter_scopes
(
env
)
:
if
definition
or
entry
.
defined_in_pxd
:
if
entry
.
type
.
activable
:
# Generate acthon-specific classes
generate_cyp_class_reifying_entries
(
entry
,
code
)
...
...
@@ -103,7 +131,6 @@ def generate_cyp_class_deferred_definitions(type_entries, code):
# Generate cypclass attr destructor
generate_cyp_class_attrs_destructor_definition
(
entry
,
code
)
# Generate wrapper constructor
scope
=
entry
.
type
.
scope
wrapper
=
scope
.
lookup_here
(
"<constructor>"
)
constructor
=
scope
.
lookup_here
(
"<init>"
)
new
=
scope
.
lookup_here
(
"__new__"
)
...
...
@@ -111,9 +138,6 @@ def generate_cyp_class_deferred_definitions(type_entries, code):
for
wrapper_entry
in
wrapper
.
all_alternatives
():
if
wrapper_entry
.
used
or
entry
.
type
.
templates
:
generate_cyp_class_wrapper_definition
(
entry
.
type
,
wrapper_entry
,
constructor
,
new
,
alloc
,
code
)
# Generate deferred definitions for any nested types
generate_cyp_class_deferred_definitions
(
scope
.
sue_entries
,
code
)
def
generate_cyp_class_attrs_destructor_definition
(
entry
,
code
):
"""
...
...
@@ -578,10 +602,21 @@ def generate_cyp_class_wrapper_definition(type, wrapper_entry, constructor_entry
else
:
code
.
putln
(
"%s self = %s();"
%
(
self_type
,
alloc_entry
.
func_cname
))
# __new__ can be defined by user and return another type
is_new_return_type
=
not
new_entry
or
new_entry
.
type
.
return_type
==
type
# initialise PyObject fields
if
(
is_new_return_type
):
code
.
putln
(
"if(self) {"
)
code
.
putln
(
"self->ob_refcnt = 0;"
)
# code.putln("self->ob_type = NULL;")
code
.
putln
(
"self->ob_type = %s;"
%
type
.
typeptr_cname
)
code
.
putln
(
"}"
)
if
init_entry
:
init_entry
=
PyrexTypes
.
best_match
(
wrapper_arg_types
,
init_entry
.
all_alternatives
(),
None
)
if
init_entry
and
(
not
new_entry
or
new_entry
.
type
.
return_type
==
type
):
if
init_entry
and
(
is_new_return_
type
):
# Calling __init__
max_init_nargs
=
len
(
init_entry
.
type
.
args
)
...
...
Cython/Compiler/ModuleNode.py
View file @
f9ef0611
...
...
@@ -586,7 +586,12 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
type_entries
.
append
(
entry
)
type_entries
=
[
t
for
t
in
type_entries
if
t
not
in
vtabslot_entries
]
self
.
generate_type_header_code
(
type_entries
,
code
)
CypclassWrapper
.
generate_cyp_class_deferred_definitions
(
type_entries
,
code
)
code
.
putln
(
""
)
code
.
putln
(
"/* PyTypeObject pointer declarations for cypclasses */"
)
CypclassWrapper
.
generate_cypclass_typeobj_declarations
(
module
,
code
,
definition
)
code
.
putln
(
""
)
code
.
putln
(
"/* Deferred definitions for cypclasses */"
)
CypclassWrapper
.
generate_cyp_class_deferred_definitions
(
env
,
code
,
definition
)
for
entry
in
vtabslot_list
:
self
.
generate_objstruct_definition
(
entry
.
type
,
code
)
self
.
generate_typeobj_predeclaration
(
entry
,
code
)
...
...
@@ -616,7 +621,6 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
modulecode
.
putln
(
""
)
modulecode
.
putln
(
"/* Module declarations from '%s' */"
%
module
.
qualified_name
)
self
.
generate_c_class_declarations
(
module
,
modulecode
,
defined_here
)
CypclassWrapper
.
generate_cypclass_typeobj_declarations
(
module
,
modulecode
,
defined_here
)
self
.
generate_cvariable_declarations
(
module
,
modulecode
,
defined_here
)
self
.
generate_cfunction_declarations
(
module
,
modulecode
,
defined_here
)
...
...
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