diff options
author | Guido van Rossum <guido@python.org> | 1997-10-01 04:29:29 +0000 |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1997-10-01 04:29:29 +0000 |
commit | 4b8e0c621466c5c3fafbd5bb1e118cfc39099587 (patch) | |
tree | cbd84522fa4f907a6be71281dfeaebf81e4c0eec /Modules/fpectlmodule.c | |
parent | a238a57073391f9c0c4ddfd3b587ebe13bf086e3 (diff) | |
download | cpython-4b8e0c621466c5c3fafbd5bb1e118cfc39099587.tar.gz |
Apply two changes, systematically:
(1) Use PyErr_NewException("module.class", NULL, NULL) to create the
exception object.
(2) Remove all calls to Py_FatalError(); instead, return or
ignore the errors -- the import code now checks PyErr_Occurred()
after calling a module's init function, so it's no longer a
fatal error for the initialization to fail.
Also did some small cleanups, e.g. removed unnecessary test for
"already initialized" from initfpectl(), and unified
initposix()/initnt().
I haven't checked this very thoroughly, so while the changes are
pretty trivial -- beware of untested code!
Diffstat (limited to 'Modules/fpectlmodule.c')
-rw-r--r-- | Modules/fpectlmodule.c | 12 |
1 files changed, 3 insertions, 9 deletions
diff --git a/Modules/fpectlmodule.c b/Modules/fpectlmodule.c index 0b7e8d77de..b0ba9dbc4b 100644 --- a/Modules/fpectlmodule.c +++ b/Modules/fpectlmodule.c @@ -227,17 +227,11 @@ static void sigfpe_handler(int signo) void initfpectl(void) { PyObject *m, *d; - static int already_initialized = 0; - - if (already_initialized) return; m = Py_InitModule("fpectl", fpectl_methods); d = PyModule_GetDict(m); - fpe_error = PyString_FromString("fpectl.error"); - PyDict_SetItemString(d, "error", fpe_error); - - if (PyErr_Occurred()) - Py_FatalError("Cannot initialize module fpectl"); - already_initialized = 1; + fpe_error = PyErr_NewException("fpectl.error", NULL, NULL); + if (fpe_error != NULL) + PyDict_SetItemString(d, "error", fpe_error); } #ifdef __cplusplus |