dynload_hpux.c 1.35 KB
Newer Older
1 2 3 4 5 6 7 8 9

/* Support for dynamic loading of extension modules */

#include "dl.h"
#include <errno.h>

#include "Python.h"
#include "importdl.h"

10 11 12 13 14
#if defined(__hp9000s300)
#define FUNCNAME_PATTERN "_init%.200s"
#else
#define FUNCNAME_PATTERN "init%.200s"
#endif
15 16 17 18 19 20 21

const struct filedescr _PyImport_DynLoadFiletab[] = {
	{".sl", "rb", C_EXTENSION},
	{"module.sl", "rb", C_EXTENSION},
	{0, 0}
};

22
dl_funcptr _PyImport_GetDynLoadFunc(const char *fqname, const char *shortname,
23 24 25 26 27
				    const char *pathname, FILE *fp)
{
	dl_funcptr p;
	shl_t lib;
	int flags;
28
	char funcname[258];
29 30 31 32 33 34 35 36 37 38 39 40 41

	flags = BIND_FIRST | BIND_DEFERRED;
	if (Py_VerboseFlag) {
		flags = DYNAMIC_PATH | BIND_FIRST | BIND_IMMEDIATE |
			BIND_NONFATAL | BIND_VERBOSE;
		printf("shl_load %s\n",pathname);
	}
	lib = shl_load(pathname, flags, 0);
	/* XXX Chuck Blake once wrote that 0 should be BIND_NOSTART? */
	if (lib == NULL) {
		char buf[256];
		if (Py_VerboseFlag)
			perror(pathname);
42 43
		PyOS_snprintf(buf, sizeof(buf), "Failed to load %.200s",
			      pathname);
44 45 46
		PyErr_SetString(PyExc_ImportError, buf);
		return NULL;
	}
47
	PyOS_snprintf(funcname, sizeof(funcname), FUNCNAME_PATTERN, shortname);
48 49
	if (Py_VerboseFlag)
		printf("shl_findsym %s\n", funcname);
50 51 52 53
	if (shl_findsym(&lib, funcname, TYPE_UNDEFINED, (void *) &p) == -1) {
		shl_unload(lib);
		p = NULL;
	}
54 55 56 57 58
	if (p == NULL && Py_VerboseFlag)
		perror(funcname);

	return p;
}