summaryrefslogtreecommitdiffstats
path: root/Modules/posixmodule.c
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1997-10-01 04:29:29 (GMT)
committerGuido van Rossum <guido@python.org>1997-10-01 04:29:29 (GMT)
commit0cb96de2699fa032ef1379ebb62a4dfb66ee5fde (patch)
tree7c8fed41fb1b4ad5da7bb2fe8d0200e27c125561 /Modules/posixmodule.c
parentccf0a44d2dd9b754fd98c15dbef1c2e8c1b41797 (diff)
downloadcpython-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.c68
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 */