Skip to content

Commit

Permalink
bpo-1635741: Port itertools module to multiphase initialization (GH-1…
Browse files Browse the repository at this point in the history
  • Loading branch information
corona10 authored Mar 17, 2020
1 parent ebf6bb9 commit 514c469
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 35 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Port itertools module to multiphase initialization (:pep:`489`).
77 changes: 42 additions & 35 deletions Modules/itertoolsmodule.c
Original file line number Diff line number Diff line change
Expand Up @@ -4701,31 +4701,9 @@ combinations(p, r)\n\
combinations_with_replacement(p, r)\n\
");


static PyMethodDef module_methods[] = {
ITERTOOLS_TEE_METHODDEF
{NULL, NULL} /* sentinel */
};


static struct PyModuleDef itertoolsmodule = {
PyModuleDef_HEAD_INIT,
"itertools",
module_doc,
-1,
module_methods,
NULL,
NULL,
NULL,
NULL
};

PyMODINIT_FUNC
PyInit_itertools(void)
static int
itertoolsmodule_exec(PyObject *m)
{
int i;
PyObject *m;
const char *name;
PyTypeObject *typelist[] = {
&accumulate_type,
&combinations_type,
Expand All @@ -4751,19 +4729,48 @@ PyInit_itertools(void)
};

Py_SET_TYPE(&teedataobject_type, &PyType_Type);
m = PyModule_Create(&itertoolsmodule);
if (m == NULL) {
return NULL;
}

for (i=0 ; typelist[i] != NULL ; i++) {
if (PyType_Ready(typelist[i]) < 0) {
return NULL;
for (int i = 0; typelist[i] != NULL; i++) {
PyTypeObject *type = typelist[i];
if (PyType_Ready(type) < 0) {
return -1;
}
const char *name = _PyType_Name(type);
Py_INCREF(type);
if (PyModule_AddObject(m, name, (PyObject *)type) < 0) {
Py_DECREF(type);
return -1;
}
name = _PyType_Name(typelist[i]);
Py_INCREF(typelist[i]);
PyModule_AddObject(m, name, (PyObject *)typelist[i]);
}

return m;
return 0;
}

static struct PyModuleDef_Slot itertoolsmodule_slots[] = {
{Py_mod_exec, itertoolsmodule_exec},
{0, NULL}
};

static PyMethodDef module_methods[] = {
ITERTOOLS_TEE_METHODDEF
{NULL, NULL} /* sentinel */
};


static struct PyModuleDef itertoolsmodule = {
PyModuleDef_HEAD_INIT,
"itertools",
module_doc,
0,
module_methods,
itertoolsmodule_slots,
NULL,
NULL,
NULL
};

PyMODINIT_FUNC
PyInit_itertools(void)
{
return PyModuleDef_Init(&itertoolsmodule);
}

0 comments on commit 514c469

Please sign in to comment.