3 * Platform: Win32 (Windows NT/Windows 95)
4 * Author: Wei-Yuen Tan (wyt@hip.com)
5 * Created: A warm day in June, 1995
8 * August 23rd 1995 - rewritten after losing everything when I
9 * wiped off my NT partition (eek!)
14 I merely took Paul's dl_dlopen.xs, took out extraneous stuff and
15 replaced the appropriate SunOS calls with the corresponding Win32
20 #define WIN32_LEAN_AND_MEAN
27 #define PERL_NO_GET_CONTEXT
37 } my_cxtx_t; /* this *must* be named my_cxtx_t */
39 #define DL_CXT_EXTRA /* ask for dl_cxtx to be defined in dlutils.c */
40 #include "dlutils.c" /* SaveError() etc */
42 #define dl_error_sv (dl_cxtx.x_error_sv)
48 DWORD err = GetLastError();
51 dl_error_sv = newSVpvn("",0);
52 PerlProc_GetOSError(dl_error_sv,err);
53 return SvPV(dl_error_sv,len);
59 (void)dl_generic_private_init(aTHX);
63 This function assumes the list staticlinkmodules
64 will be formed from package names with '::' replaced
65 with '/'. Thus Win32::OLE is in the list as Win32/OLE
68 dl_static_linked(char *filename)
72 static char subStr[] = "/auto/";
73 char szBuffer[MAX_PATH];
75 /* change all the '\\' to '/' */
76 strcpy(szBuffer, filename);
77 for(ptr = szBuffer; ptr = strchr(ptr, '\\'); ++ptr)
80 /* delete the file name */
81 ptr = strrchr(szBuffer, '/');
85 /* remove leading lib path */
86 ptr = strstr(szBuffer, subStr);
88 ptr += sizeof(subStr)-1;
92 for (p = staticlinkmodules; *p;p++) {
93 if (hptr = strstr(ptr, *p)) {
94 /* found substring, need more detailed check if module name match */
96 return strcmp(ptr, *p)==0;
98 if (hptr[strlen(*p)] == 0)
105 MODULE = DynaLoader PACKAGE = DynaLoader
108 (void)dl_private_init(aTHX);
111 dl_load_file(filename,flags=0)
117 DLDEBUG(1,PerlIO_printf(Perl_debug_log,"dl_load_file(%s):\n", filename));
118 if (dl_static_linked(filename) == 0) {
119 RETVAL = PerlProc_DynaLoad(filename);
122 RETVAL = (void*) Win_GetModuleHandle(NULL);
123 DLDEBUG(2,PerlIO_printf(Perl_debug_log," libref=%x\n", RETVAL));
124 ST(0) = sv_newmortal() ;
126 SaveError(aTHX_ "load_file:%s",
127 OS_Error_String(aTHX)) ;
129 sv_setiv( ST(0), (IV)RETVAL);
133 dl_unload_file(libref)
136 DLDEBUG(1,PerlIO_printf(Perl_debug_log, "dl_unload_file(%lx):\n", PTR2ul(libref)));
137 RETVAL = FreeLibrary(libref);
139 SaveError(aTHX_ "unload_file:%s", OS_Error_String(aTHX)) ;
140 DLDEBUG(2,PerlIO_printf(Perl_debug_log, " retval = %d\n", RETVAL));
145 dl_find_symbol(libhandle, symbolname)
149 DLDEBUG(2,PerlIO_printf(Perl_debug_log,"dl_find_symbol(handle=%x, symbol=%s)\n",
150 libhandle, symbolname));
151 RETVAL = (void*) GetProcAddress((HINSTANCE) libhandle, symbolname);
152 DLDEBUG(2,PerlIO_printf(Perl_debug_log," symbolref = %x\n", RETVAL));
153 ST(0) = sv_newmortal() ;
155 SaveError(aTHX_ "find_symbol:%s",
156 OS_Error_String(aTHX)) ;
158 sv_setiv( ST(0), (IV)RETVAL);
167 # These functions should not need changing on any platform:
170 dl_install_xsub(perl_name, symref, filename="$Package")
175 DLDEBUG(2,PerlIO_printf(Perl_debug_log,"dl_install_xsub(name=%s, symref=%x)\n",
177 ST(0) = sv_2mortal(newRV((SV*)newXS(perl_name,
178 (void(*)(pTHX_ CV *))symref,
186 RETVAL = dl_last_error;
190 #if defined(USE_ITHREADS)
197 /* MY_CXT_CLONE just does a memcpy on the whole structure, so to avoid
198 * using Perl variables that belong to another thread, we create our
199 * own for this thread.
201 MY_CXT.x_dl_last_error = newSVpvn("", 0);