Commit caea47a4 authored by Stefan Behnel's avatar Stefan Behnel

avoid redundant NULL inits for extension type fields in tp_new()

parent b0618a07
...@@ -1074,8 +1074,12 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -1074,8 +1074,12 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
base_type = type.base_type base_type = type.base_type
have_entries, (py_attrs, py_buffers, memoryview_slices) = \ have_entries, (py_attrs, py_buffers, memoryview_slices) = \
scope.get_refcounted_entries(include_weakref=True) scope.get_refcounted_entries()
cpp_class_attrs = [entry for entry in scope.var_entries if entry.type.is_cpp_class] if scope.is_internal:
# internal classes (should) never need None inits, normal zeroing will do
py_attrs = []
cpp_class_attrs = [entry for entry in scope.var_entries
if entry.type.is_cpp_class]
new_func_entry = scope.lookup_here("__new__") new_func_entry = scope.lookup_here("__new__")
if base_type or (new_func_entry and new_func_entry.is_special if base_type or (new_func_entry and new_func_entry.is_special
...@@ -1105,7 +1109,9 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -1105,7 +1109,9 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
"static PyObject *%s(PyTypeObject *t, %sPyObject *a, %sPyObject *k) {" "static PyObject *%s(PyTypeObject *t, %sPyObject *a, %sPyObject *k) {"
% (slot_func, unused_marker, unused_marker)) % (slot_func, unused_marker, unused_marker))
need_self_cast = type.vtabslot_cname or have_entries or cpp_class_attrs need_self_cast = (type.vtabslot_cname or
(py_buffers or memoryview_slices or py_attrs) or
cpp_class_attrs)
if need_self_cast: if need_self_cast:
code.putln("%s;" % scope.parent_type.declaration_code("p")) code.putln("%s;" % scope.parent_type.declaration_code("p"))
if base_type: if base_type:
...@@ -1153,11 +1159,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): ...@@ -1153,11 +1159,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
(entry.cname, entry.type.declaration_code(""))) (entry.cname, entry.type.declaration_code("")))
for entry in py_attrs: for entry in py_attrs:
if scope.is_internal or entry.name == "__weakref__": code.put_init_var_to_py_none(entry, "p->%s", nanny=False)
# internal classes do not need None inits
code.putln("p->%s = 0;" % entry.cname)
else:
code.put_init_var_to_py_none(entry, "p->%s", nanny=False)
for entry in memoryview_slices: for entry in memoryview_slices:
code.putln("p->%s.data = NULL;" % entry.cname) code.putln("p->%s.data = NULL;" % entry.cname)
......
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