Skip to content

Commit

Permalink
bpo-1635741: Port faulthandler module to multiphase initialization (p…
Browse files Browse the repository at this point in the history
  • Loading branch information
corona10 authored Jul 3, 2020
1 parent 3549ca3 commit c0b214b
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 35 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Port :mod:`faulthandler` to multiphase initialization.
66 changes: 31 additions & 35 deletions Modules/faulthandler.c
Original file line number Diff line number Diff line change
Expand Up @@ -1291,59 +1291,55 @@ static PyMethodDef module_methods[] = {
{NULL, NULL} /* sentinel */
};

static struct PyModuleDef module_def = {
PyModuleDef_HEAD_INIT,
"faulthandler",
module_doc,
0, /* non-negative size to be able to unload the module */
module_methods,
NULL,
faulthandler_traverse,
NULL,
NULL
};

PyMODINIT_FUNC
PyInit_faulthandler(void)
{
PyObject *m = PyModule_Create(&module_def);
if (m == NULL)
return NULL;

static int
PyExec_faulthandler(PyObject *module) {
/* Add constants for unit tests */
#ifdef MS_WINDOWS
/* RaiseException() codes (prefixed by an underscore) */
if (PyModule_AddIntConstant(m, "_EXCEPTION_ACCESS_VIOLATION",
if (PyModule_AddIntConstant(module, "_EXCEPTION_ACCESS_VIOLATION",
EXCEPTION_ACCESS_VIOLATION)) {
goto error;
return -1;
}
if (PyModule_AddIntConstant(m, "_EXCEPTION_INT_DIVIDE_BY_ZERO",
if (PyModule_AddIntConstant(module, "_EXCEPTION_INT_DIVIDE_BY_ZERO",
EXCEPTION_INT_DIVIDE_BY_ZERO)) {
goto error;
return -1;
}
if (PyModule_AddIntConstant(m, "_EXCEPTION_STACK_OVERFLOW",
if (PyModule_AddIntConstant(module, "_EXCEPTION_STACK_OVERFLOW",
EXCEPTION_STACK_OVERFLOW)) {
goto error;
return -1;
}

/* RaiseException() flags (prefixed by an underscore) */
if (PyModule_AddIntConstant(m, "_EXCEPTION_NONCONTINUABLE",
if (PyModule_AddIntConstant(module, "_EXCEPTION_NONCONTINUABLE",
EXCEPTION_NONCONTINUABLE)) {
goto error;
return -1;
}
if (PyModule_AddIntConstant(m, "_EXCEPTION_NONCONTINUABLE_EXCEPTION",
if (PyModule_AddIntConstant(module, "_EXCEPTION_NONCONTINUABLE_EXCEPTION",
EXCEPTION_NONCONTINUABLE_EXCEPTION)) {
goto error;
return -1;
}
#endif
return 0;
}

return m;
static PyModuleDef_Slot faulthandler_slots[] = {
{Py_mod_exec, PyExec_faulthandler},
{0, NULL}
};

#ifdef MS_WINDOWS
error:
Py_DECREF(m);
return NULL;
#endif
static struct PyModuleDef module_def = {
PyModuleDef_HEAD_INIT,
.m_name = "faulthandler",
.m_doc = module_doc,
.m_methods = module_methods,
.m_traverse = faulthandler_traverse,
.m_slots = faulthandler_slots
};

PyMODINIT_FUNC
PyInit_faulthandler(void)
{
return PyModuleDef_Init(&module_def);
}

static int
Expand Down

0 comments on commit c0b214b

Please sign in to comment.