summaryrefslogtreecommitdiff
path: root/Python/dynload_shlib.c
diff options
context:
space:
mode:
authorMartin v. Löwis <martin@v.loewis.de>2001-07-18 16:17:16 +0000
committerMartin v. Löwis <martin@v.loewis.de>2001-07-18 16:17:16 +0000
commit8844f8cf00b503f45dcd28086515d540bb861ac0 (patch)
treeea20a73bce37559d4e24b3af1d4cbee2e42d384a /Python/dynload_shlib.c
parentf4cf190623bf4e1b4a81a3ab05c395bca82d9b29 (diff)
downloadcpython-8844f8cf00b503f45dcd28086515d540bb861ac0.tar.gz
Patch #412229: Add functions sys.getdlopenflags and sys.setdlopenflags.
Add dlopenflags to PyInterpreterState, and use it in dlopen calls.
Diffstat (limited to 'Python/dynload_shlib.c')
-rw-r--r--Python/dynload_shlib.c20
1 files changed, 7 insertions, 13 deletions
diff --git a/Python/dynload_shlib.c b/Python/dynload_shlib.c
index 7c8bfd2c3b..7de3b7d43e 100644
--- a/Python/dynload_shlib.c
+++ b/Python/dynload_shlib.c
@@ -22,10 +22,6 @@
#define LEAD_UNDERSCORE ""
#endif
-#ifndef RTLD_LAZY
-#define RTLD_LAZY 1
-#endif
-
const struct filedescr _PyImport_DynLoadFiletab[] = {
#ifdef __CYGWIN__
@@ -53,6 +49,7 @@ dl_funcptr _PyImport_GetDynLoadFunc(const char *fqname, const char *shortname,
void *handle;
char funcname[258];
char pathbuf[260];
+ int dlopenflags=0;
if (strchr(pathname, '/') == NULL) {
/* Prefix bare filename with "./" */
@@ -80,16 +77,13 @@ dl_funcptr _PyImport_GetDynLoadFunc(const char *fqname, const char *shortname,
}
}
-#ifdef RTLD_NOW
- /* RTLD_NOW: resolve externals now
- (i.e. core dump now if some are missing) */
- handle = dlopen(pathname, RTLD_NOW);
-#else
+ dlopenflags = PyThreadState_Get()->interp->dlopenflags;
+
if (Py_VerboseFlag)
- printf("dlopen(\"%s\", %d);\n", pathname,
- RTLD_LAZY);
- handle = dlopen(pathname, RTLD_LAZY);
-#endif /* RTLD_NOW */
+ printf("dlopen(\"%s\", %x);\n", pathname, dlopenflags);
+
+ handle = dlopen(pathname, dlopenflags);
+
if (handle == NULL) {
PyErr_SetString(PyExc_ImportError, dlerror());
return NULL;