78 lines
2.0 KiB
78 lines
2.0 KiB
|
|
/* Support for dynamic loading of extension modules */ |
|
|
|
#include "Python.h" |
|
|
|
/* ./configure sets HAVE_DYNAMIC_LOADING if dynamic loading of modules is |
|
supported on this platform. configure will then compile and link in one |
|
of the dynload_*.c files, as appropriate. We will call a function in |
|
those modules to get a function pointer to the module's init function. |
|
*/ |
|
#ifdef HAVE_DYNAMIC_LOADING |
|
|
|
#include "importdl.h" |
|
|
|
extern dl_funcptr _PyImport_GetDynLoadFunc(const char *name, |
|
const char *shortname, |
|
const char *pathname, FILE *fp); |
|
|
|
|
|
|
|
PyObject * |
|
_PyImport_LoadDynamicModule(char *name, char *pathname, FILE *fp) |
|
{ |
|
PyObject *m; |
|
char *lastdot, *shortname, *packagecontext, *oldcontext; |
|
dl_funcptr p; |
|
|
|
if ((m = _PyImport_FindExtension(name, pathname)) != NULL) { |
|
Py_INCREF(m); |
|
return m; |
|
} |
|
lastdot = strrchr(name, '.'); |
|
if (lastdot == NULL) { |
|
packagecontext = NULL; |
|
shortname = name; |
|
} |
|
else { |
|
packagecontext = name; |
|
shortname = lastdot+1; |
|
} |
|
|
|
p = _PyImport_GetDynLoadFunc(name, shortname, pathname, fp); |
|
if (PyErr_Occurred()) |
|
return NULL; |
|
if (p == NULL) { |
|
PyErr_Format(PyExc_ImportError, |
|
"dynamic module does not define init function (init%.200s)", |
|
shortname); |
|
return NULL; |
|
} |
|
oldcontext = _Py_PackageContext; |
|
_Py_PackageContext = packagecontext; |
|
(*p)(); |
|
_Py_PackageContext = oldcontext; |
|
if (PyErr_Occurred()) |
|
return NULL; |
|
|
|
m = PyDict_GetItemString(PyImport_GetModuleDict(), name); |
|
if (m == NULL) { |
|
PyErr_SetString(PyExc_SystemError, |
|
"dynamic module not initialized properly"); |
|
return NULL; |
|
} |
|
/* Remember the filename as the __file__ attribute */ |
|
if (PyModule_AddStringConstant(m, "__file__", pathname) < 0) |
|
PyErr_Clear(); /* Not important enough to report */ |
|
|
|
if (_PyImport_FixupExtension(name, pathname) == NULL) |
|
return NULL; |
|
if (Py_VerboseFlag) |
|
PySys_WriteStderr( |
|
"import %s # dynamically loaded from %s\n", |
|
name, pathname); |
|
Py_INCREF(m); |
|
return m; |
|
} |
|
|
|
#endif /* HAVE_DYNAMIC_LOADING */
|
|
|