1 // Time-stamp: <01/08/01 20:58:55 keuchel@w2k>
12 #ifdef PERL_IMPLICIT_SYS
15 #endif /* PERL_IMPLICIT_SYS */
18 /* Register any extra external extensions */
19 char *staticlinkmodules[] = {
24 EXTERN_C void boot_DynaLoader (pTHXo_ CV* cv);
29 char *file = __FILE__;
31 newXS("DynaLoader::boot_DynaLoader", boot_DynaLoader, file);
34 #ifdef PERL_IMPLICIT_SYS
39 perl_get_host_info(struct IPerlMemInfo* perlMemInfo,
40 struct IPerlMemInfo* perlMemSharedInfo,
41 struct IPerlMemInfo* perlMemParseInfo,
42 struct IPerlEnvInfo* perlEnvInfo,
43 struct IPerlStdIOInfo* perlStdIOInfo,
44 struct IPerlLIOInfo* perlLIOInfo,
45 struct IPerlDirInfo* perlDirInfo,
46 struct IPerlSockInfo* perlSockInfo,
47 struct IPerlProcInfo* perlProcInfo)
50 Copy(&perlMem, &perlMemInfo->perlMemList, perlMemInfo->nCount, void*);
51 perlMemInfo->nCount = (sizeof(struct IPerlMem)/sizeof(void*));
53 if (perlMemSharedInfo) {
54 Copy(&perlMem, &perlMemSharedInfo->perlMemList, perlMemSharedInfo->nCount, void*);
55 perlMemSharedInfo->nCount = (sizeof(struct IPerlMem)/sizeof(void*));
57 if (perlMemParseInfo) {
58 Copy(&perlMem, &perlMemParseInfo->perlMemList, perlMemParseInfo->nCount, void*);
59 perlMemParseInfo->nCount = (sizeof(struct IPerlMem)/sizeof(void*));
62 Copy(&perlEnv, &perlEnvInfo->perlEnvList, perlEnvInfo->nCount, void*);
63 perlEnvInfo->nCount = (sizeof(struct IPerlEnv)/sizeof(void*));
66 Copy(&perlStdIO, &perlStdIOInfo->perlStdIOList, perlStdIOInfo->nCount, void*);
67 perlStdIOInfo->nCount = (sizeof(struct IPerlStdIO)/sizeof(void*));
70 Copy(&perlLIO, &perlLIOInfo->perlLIOList, perlLIOInfo->nCount, void*);
71 perlLIOInfo->nCount = (sizeof(struct IPerlLIO)/sizeof(void*));
74 Copy(&perlDir, &perlDirInfo->perlDirList, perlDirInfo->nCount, void*);
75 perlDirInfo->nCount = (sizeof(struct IPerlDir)/sizeof(void*));
78 Copy(&perlSock, &perlSockInfo->perlSockList, perlSockInfo->nCount, void*);
79 perlSockInfo->nCount = (sizeof(struct IPerlSock)/sizeof(void*));
82 Copy(&perlProc, &perlProcInfo->perlProcList, perlProcInfo->nCount, void*);
83 perlProcInfo->nCount = (sizeof(struct IPerlProc)/sizeof(void*));
87 EXTERN_C PerlInterpreter*
88 perl_alloc_override(struct IPerlMem** ppMem, struct IPerlMem** ppMemShared,
89 struct IPerlMem** ppMemParse, struct IPerlEnv** ppEnv,
90 struct IPerlStdIO** ppStdIO, struct IPerlLIO** ppLIO,
91 struct IPerlDir** ppDir, struct IPerlSock** ppSock,
92 struct IPerlProc** ppProc)
94 PerlInterpreter *my_perl = NULL;
95 CPerlHost* pHost = new CPerlHost(ppMem, ppMemShared, ppMemParse, ppEnv,
96 ppStdIO, ppLIO, ppDir, ppSock, ppProc);
99 my_perl = perl_alloc_using(pHost->m_pHostperlMem,
100 pHost->m_pHostperlMemShared,
101 pHost->m_pHostperlMemParse,
102 pHost->m_pHostperlEnv,
103 pHost->m_pHostperlStdIO,
104 pHost->m_pHostperlLIO,
105 pHost->m_pHostperlDir,
106 pHost->m_pHostperlSock,
107 pHost->m_pHostperlProc);
110 CPerlObj* pPerl = (CPerlObj*)my_perl;
112 w32_internal_host = pHost;
118 EXTERN_C PerlInterpreter*
121 PerlInterpreter* my_perl = NULL;
122 CPerlHost* pHost = new CPerlHost();
124 my_perl = perl_alloc_using(pHost->m_pHostperlMem,
125 pHost->m_pHostperlMemShared,
126 pHost->m_pHostperlMemParse,
127 pHost->m_pHostperlEnv,
128 pHost->m_pHostperlStdIO,
129 pHost->m_pHostperlLIO,
130 pHost->m_pHostperlDir,
131 pHost->m_pHostperlSock,
132 pHost->m_pHostperlProc);
135 CPerlObj* pPerl = (CPerlObj*)my_perl;
137 w32_internal_host = pHost;
144 win32_delete_internal_host(void *h)
146 CPerlHost *host = (CPerlHost*)h;
153 perl_construct(PerlInterpreter* my_perl)
155 CPerlObj* pPerl = (CPerlObj*)my_perl;
162 win32_fprintf(stderr, "%s\n",
163 "Error: Unable to construct data structures");
169 perl_destruct(PerlInterpreter* my_perl)
171 CPerlObj* pPerl = (CPerlObj*)my_perl;
186 perl_free(PerlInterpreter* my_perl)
188 CPerlObj* pPerl = (CPerlObj*)my_perl;
189 void *host = w32_internal_host;
201 win32_delete_internal_host(host);
206 perl_run(PerlInterpreter* my_perl)
208 CPerlObj* pPerl = (CPerlObj*)my_perl;
219 win32_fprintf(stderr, "Error: Runtime exception\n");
227 perl_parse(PerlInterpreter* my_perl, void (*xsinit)(CPerlObj*), int argc, char** argv, char** env)
230 CPerlObj* pPerl = (CPerlObj*)my_perl;
232 retVal = Perl_parse(xsinit, argc, argv, env);
236 retVal = Perl_parse(xsinit, argc, argv, env);
240 win32_fprintf(stderr, "Error: Parse exception\n");
248 #undef PL_perl_destruct_level
249 #define PL_perl_destruct_level int dummy
251 #endif /* PERL_OBJECT */
252 #endif /* PERL_IMPLICIT_SYS */
254 EXTERN_C HANDLE w32_perldll_handle;
256 EXTERN_C DllExport int
257 RunPerl(int argc, char **argv, char **env)
260 PerlInterpreter *my_perl, *new_perl = NULL;
263 /* XXX this _may_ be a problem on some compilers (e.g. Borland) that
264 * want to free() argv after main() returns. As luck would have it,
265 * Borland's CRT does the right thing to argv[0] already. */
266 char szModuleName[MAX_PATH];
269 XCEGetModuleFileNameA(NULL, szModuleName, sizeof(szModuleName));
270 (void)win32_longpath(szModuleName);
271 argv[0] = szModuleName;
274 #ifdef PERL_GLOBAL_STRUCT
275 #define PERLVAR(var,type) /**/
276 #define PERLVARA(var,type) /**/
277 #define PERLVARI(var,type,init) PL_Vars.var = init;
278 #define PERLVARIC(var,type,init) PL_Vars.var = init;
279 #include "perlvars.h"
286 PERL_SYS_INIT(&argc,&argv);
288 if (!(my_perl = perl_alloc()))
290 perl_construct(my_perl);
291 PL_perl_destruct_level = 0;
293 exitstatus = perl_parse(my_perl, xs_init, argc, argv, env);
295 #if defined(TOP_CLONE) && defined(USE_ITHREADS) /* XXXXXX testing */
297 CPerlHost *h = new CPerlHost();
298 new_perl = perl_clone_using(my_perl, 1,
300 h->m_pHostperlMemShared,
301 h->m_pHostperlMemParse,
309 CPerlObj *pPerl = (CPerlObj*)new_perl;
311 new_perl = perl_clone(my_perl, 1);
313 exitstatus = perl_run(new_perl);
314 PERL_SET_THX(my_perl);
316 exitstatus = perl_run(my_perl);
320 perl_destruct(my_perl);
324 PERL_SET_THX(new_perl);
325 perl_destruct(new_perl);
336 set_w32_module_name(void);
339 EXTERN_C /* GCC in C++ mode mangles the name, otherwise */
342 DllMain(HANDLE hModule, /* DLL module handle */
343 DWORD fdwReason, /* reason called */
344 LPVOID lpvReserved) /* reserved */
347 /* The DLL is attaching to a process due to process
348 * initialization or a call to LoadLibrary.
350 case DLL_PROCESS_ATTACH:
351 /* #define DEFAULT_BINMODE */
352 #ifdef DEFAULT_BINMODE
353 setmode( fileno( stdin ), O_BINARY );
354 setmode( fileno( stdout ), O_BINARY );
355 setmode( fileno( stderr ), O_BINARY );
360 DisableThreadLibraryCalls((HMODULE)hModule);
363 w32_perldll_handle = hModule;
364 set_w32_module_name();
367 /* The DLL is detaching from a process due to
368 * process termination or call to FreeLibrary.
370 case DLL_PROCESS_DETACH:
373 /* The attached process creates a new thread. */
374 case DLL_THREAD_ATTACH:
377 /* The thread of the attached process terminates. */
378 case DLL_THREAD_DETACH: