diff options
author | Guido van Rossum <guido@python.org> | 1997-10-01 04:29:29 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1997-10-01 04:29:29 (GMT) |
commit | 0cb96de2699fa032ef1379ebb62a4dfb66ee5fde (patch) | |
tree | 7c8fed41fb1b4ad5da7bb2fe8d0200e27c125561 /Modules/posixmodule.c | |
parent | ccf0a44d2dd9b754fd98c15dbef1c2e8c1b41797 (diff) | |
download | cpython-0cb96de2699fa032ef1379ebb62a4dfb66ee5fde.zip cpython-0cb96de2699fa032ef1379ebb62a4dfb66ee5fde.tar.gz cpython-0cb96de2699fa032ef1379ebb62a4dfb66ee5fde.tar.bz2 |
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/posixmodule.c')
-rw-r--r-- | Modules/posixmodule.c | 68 |
1 files changed, 16 insertions, 52 deletions
diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c index 3069d34..e06827a 100644 --- a/Modules/posixmodule.c +++ b/Modules/posixmodule.c @@ -2254,73 +2254,37 @@ all_ins(d) } -/* XXX The following should be more unified -- only difference left is - function name and module name. */ - #if defined(_MSC_VER) || defined(__WATCOMC__) -void -initnt() -{ - PyObject *m, *d, *v; - - m = Py_InitModule4("nt", - posix_methods, - posix__doc__, - (PyObject *)NULL, - PYTHON_API_VERSION); - d = PyModule_GetDict(m); - - /* Initialize nt.environ dictionary */ - v = convertenviron(); - if (v == NULL || PyDict_SetItemString(d, "environ", v) != 0) - goto finally; - Py_DECREF(v); - - if (all_ins(d)) - goto finally; - - /* Initialize nt.error exception */ - PosixError = PyString_FromString("os.error"); - PyDict_SetItemString(d, "error", PosixError); - - if (!PyErr_Occurred()) - return; +#define INITFUNC initnt +#define MODNAME "nt" +#else +#define INITFUNC initposix +#define MODNAME "posix" +#endif - finally: - /* XXX Shouldn't */ - Py_FatalError("can't initialize NT posixmodule"); -} -#else /* not a PC port */ void -initposix() +INITFUNC() { PyObject *m, *d, *v; - m = Py_InitModule4("posix", + m = Py_InitModule4(MODNAME, posix_methods, posix__doc__, - (PyObject *)NULL, - PYTHON_API_VERSION); + (PyObject *)NULL, + PYTHON_API_VERSION); d = PyModule_GetDict(m); - /* Initialize posix.environ dictionary */ + /* Initialize environ dictionary */ v = convertenviron(); if (v == NULL || PyDict_SetItemString(d, "environ", v) != 0) - goto finally; + return; Py_DECREF(v); if (all_ins(d)) - goto finally; - - /* Initialize posix.error exception */ - PosixError = PyString_FromString("os.error"); - PyDict_SetItemString(d, "error", PosixError); - - if (!PyErr_Occurred()) return; - finally: - /* XXX Shouldn't */ - Py_FatalError("can't initialize posix module"); + /* Initialize exception */ + PosixError = PyErr_NewException("os.error", NULL, NULL); + if (PosixError != NULL) + PyDict_SetItemString(d, "error", PosixError); } -#endif /* !_MSC_VER */ |