This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
phase 1 of somewhat major rearrangement of PERL_OBJECT stuff
[perl5.git] / win32 / perlhost.h
CommitLineData
0f4eea8f
DL
1
2#include "iperlsys.h"
3
4extern CPerlObj *pPerl;
5
6#define CALLFUNC0RET(x)\
7 int ret = x;\
8 if (ret < 0)\
9 err = errno;\
10 return ret;
11
12#define PROCESS_AND_RETURN \
13 if (errno) \
14 err = errno; \
15 return r
16
17#define CALLFUNCRET(x)\
18 int ret = x;\
19 if (ret)\
20 err = errno;\
21 return ret;
22
23#define CALLFUNCERR(x)\
24 int ret = x;\
25 if (errno)\
26 err = errno;\
27 return ret;
28
29#define LCALLFUNCERR(x)\
30 long ret = x;\
31 if (errno)\
32 err = errno;\
33 return ret;
34
0f4eea8f
DL
35class CPerlDir : public IPerlDir
36{
37public:
38 CPerlDir() {};
39 virtual int Makedir(const char *dirname, int mode, int &err)
40 {
41 CALLFUNC0RET(win32_mkdir(dirname, mode));
42 };
43 virtual int Chdir(const char *dirname, int &err)
44 {
45 CALLFUNC0RET(win32_chdir(dirname));
46 };
47 virtual int Rmdir(const char *dirname, int &err)
48 {
49 CALLFUNC0RET(win32_rmdir(dirname));
50 };
51 virtual int Close(DIR *dirp, int &err)
52 {
72311751 53 return win32_closedir(dirp);
0f4eea8f
DL
54 };
55 virtual DIR *Open(char *filename, int &err)
56 {
72311751 57 return win32_opendir(filename);
0f4eea8f
DL
58 };
59 virtual struct direct *Read(DIR *dirp, int &err)
60 {
72311751 61 return win32_readdir(dirp);
0f4eea8f
DL
62 };
63 virtual void Rewind(DIR *dirp, int &err)
64 {
72311751 65 win32_rewinddir(dirp);
0f4eea8f
DL
66 };
67 virtual void Seek(DIR *dirp, long loc, int &err)
68 {
72311751 69 win32_seekdir(dirp, loc);
0f4eea8f
DL
70 };
71 virtual long Tell(DIR *dirp, int &err)
72 {
72311751 73 return win32_telldir(dirp);
0f4eea8f
DL
74 };
75};
76
77
78extern char * g_win32_get_privlib(char *pl);
79extern char * g_win32_get_sitelib(char *pl);
80
81class CPerlEnv : public IPerlEnv
82{
83public:
84 CPerlEnv() {};
85 virtual char *Getenv(const char *varname, int &err)
86 {
87 return win32_getenv(varname);
88 };
89 virtual int Putenv(const char *envstring, int &err)
90 {
91 return putenv(envstring);
92 };
93 virtual char* LibPath(char *pl)
94 {
95 return g_win32_get_privlib(pl);
96 };
97 virtual char* SiteLibPath(char *pl)
98 {
99 return g_win32_get_sitelib(pl);
100 };
101};
102
103class CPerlSock : public IPerlSock
104{
105public:
106 CPerlSock() {};
107 virtual u_long Htonl(u_long hostlong)
108 {
109 return win32_htonl(hostlong);
110 };
111 virtual u_short Htons(u_short hostshort)
112 {
113 return win32_htons(hostshort);
114 };
115 virtual u_long Ntohl(u_long netlong)
116 {
117 return win32_ntohl(netlong);
118 };
119 virtual u_short Ntohs(u_short netshort)
120 {
121 return win32_ntohs(netshort);
122 }
123
124 virtual SOCKET Accept(SOCKET s, struct sockaddr* addr, int* addrlen, int &err)
125 {
126 SOCKET r = win32_accept(s, addr, addrlen);
127 PROCESS_AND_RETURN;
128 };
129 virtual int Bind(SOCKET s, const struct sockaddr* name, int namelen, int &err)
130 {
131 int r = win32_bind(s, name, namelen);
132 PROCESS_AND_RETURN;
133 };
134 virtual int Connect(SOCKET s, const struct sockaddr* name, int namelen, int &err)
135 {
136 int r = win32_connect(s, name, namelen);
137 PROCESS_AND_RETURN;
138 };
139 virtual void Endhostent(int &err)
140 {
141 win32_endhostent();
142 };
143 virtual void Endnetent(int &err)
144 {
145 win32_endnetent();
146 };
147 virtual void Endprotoent(int &err)
148 {
149 win32_endprotoent();
150 };
151 virtual void Endservent(int &err)
152 {
153 win32_endservent();
154 };
155 virtual struct hostent* Gethostbyaddr(const char* addr, int len, int type, int &err)
156 {
157 struct hostent *r = win32_gethostbyaddr(addr, len, type);
158 PROCESS_AND_RETURN;
159 };
160 virtual struct hostent* Gethostbyname(const char* name, int &err)
161 {
162 struct hostent *r = win32_gethostbyname(name);
163 PROCESS_AND_RETURN;
164 };
165 virtual struct hostent* Gethostent(int &err)
166 {
167 croak("gethostent not implemented!\n");
168 return NULL;
169 };
170 virtual int Gethostname(char* name, int namelen, int &err)
171 {
172 int r = win32_gethostname(name, namelen);
173 PROCESS_AND_RETURN;
174 };
175 virtual struct netent *Getnetbyaddr(long net, int type, int &err)
176 {
177 struct netent *r = win32_getnetbyaddr(net, type);
178 PROCESS_AND_RETURN;
179 };
180 virtual struct netent *Getnetbyname(const char *name, int &err)
181 {
182 struct netent *r = win32_getnetbyname((char*)name);
183 PROCESS_AND_RETURN;
184 };
185 virtual struct netent *Getnetent(int &err)
186 {
187 struct netent *r = win32_getnetent();
188 PROCESS_AND_RETURN;
189 };
190 virtual int Getpeername(SOCKET s, struct sockaddr* name, int* namelen, int &err)
191 {
192 int r = win32_getpeername(s, name, namelen);
193 PROCESS_AND_RETURN;
194 };
195 virtual struct protoent* Getprotobyname(const char* name, int &err)
196 {
197 struct protoent *r = win32_getprotobyname(name);
198 PROCESS_AND_RETURN;
199 };
200 virtual struct protoent* Getprotobynumber(int number, int &err)
201 {
202 struct protoent *r = win32_getprotobynumber(number);
203 PROCESS_AND_RETURN;
204 };
205 virtual struct protoent* Getprotoent(int &err)
206 {
207 struct protoent *r = win32_getprotoent();
208 PROCESS_AND_RETURN;
209 };
210 virtual struct servent* Getservbyname(const char* name, const char* proto, int &err)
211 {
212 struct servent *r = win32_getservbyname(name, proto);
213 PROCESS_AND_RETURN;
214 };
215 virtual struct servent* Getservbyport(int port, const char* proto, int &err)
216 {
217 struct servent *r = win32_getservbyport(port, proto);
218 PROCESS_AND_RETURN;
219 };
220 virtual struct servent* Getservent(int &err)
221 {
222 struct servent *r = win32_getservent();
223 PROCESS_AND_RETURN;
224 };
225 virtual int Getsockname(SOCKET s, struct sockaddr* name, int* namelen, int &err)
226 {
227 int r = win32_getsockname(s, name, namelen);
228 PROCESS_AND_RETURN;
229 };
230 virtual int Getsockopt(SOCKET s, int level, int optname, char* optval, int* optlen, int &err)
231 {
232 int r = win32_getsockopt(s, level, optname, optval, optlen);
233 PROCESS_AND_RETURN;
234 };
235 virtual unsigned long InetAddr(const char* cp, int &err)
236 {
237 unsigned long r = win32_inet_addr(cp);
238 PROCESS_AND_RETURN;
239 };
240 virtual char* InetNtoa(struct in_addr in, int &err)
241 {
242 char *r = win32_inet_ntoa(in);
243 PROCESS_AND_RETURN;
244 };
245 virtual int Listen(SOCKET s, int backlog, int &err)
246 {
247 int r = win32_listen(s, backlog);
248 PROCESS_AND_RETURN;
249 };
250 virtual int Recv(SOCKET s, char* buffer, int len, int flags, int &err)
251 {
252 int r = win32_recv(s, buffer, len, flags);
253 PROCESS_AND_RETURN;
254 };
255 virtual int Recvfrom(SOCKET s, char* buffer, int len, int flags, struct sockaddr* from, int* fromlen, int &err)
256 {
257 int r = win32_recvfrom(s, buffer, len, flags, from, fromlen);
258 PROCESS_AND_RETURN;
259 };
260 virtual int Select(int nfds, char* readfds, char* writefds, char* exceptfds, const struct timeval* timeout, int &err)
261 {
262 int r = win32_select(nfds, (Perl_fd_set*)readfds, (Perl_fd_set*)writefds, (Perl_fd_set*)exceptfds, timeout);
263 PROCESS_AND_RETURN;
264 };
265 virtual int Send(SOCKET s, const char* buffer, int len, int flags, int &err)
266 {
267 int r = win32_send(s, buffer, len, flags);
268 PROCESS_AND_RETURN;
269 };
270 virtual int Sendto(SOCKET s, const char* buffer, int len, int flags, const struct sockaddr* to, int tolen, int &err)
271 {
272 int r = win32_sendto(s, buffer, len, flags, to, tolen);
273 PROCESS_AND_RETURN;
274 };
275 virtual void Sethostent(int stayopen, int &err)
276 {
277 win32_sethostent(stayopen);
278 };
279 virtual void Setnetent(int stayopen, int &err)
280 {
281 win32_setnetent(stayopen);
282 };
283 virtual void Setprotoent(int stayopen, int &err)
284 {
285 win32_setprotoent(stayopen);
286 };
287 virtual void Setservent(int stayopen, int &err)
288 {
289 win32_setservent(stayopen);
290 };
291 virtual int Setsockopt(SOCKET s, int level, int optname, const char* optval, int optlen, int &err)
292 {
293 int r = win32_setsockopt(s, level, optname, optval, optlen);
294 PROCESS_AND_RETURN;
295 };
296 virtual int Shutdown(SOCKET s, int how, int &err)
297 {
298 int r = win32_shutdown(s, how);
299 PROCESS_AND_RETURN;
300 };
301 virtual SOCKET Socket(int af, int type, int protocol, int &err)
302 {
303 SOCKET r = win32_socket(af, type, protocol);
304 PROCESS_AND_RETURN;
305 };
306 virtual int Socketpair(int domain, int type, int protocol, int* fds, int &err)
307 {
308 croak("socketpair not implemented!\n");
309 return 0;
310 };
311 virtual int Closesocket(SOCKET s, int& err)
312 {
313 int r = win32_closesocket(s);
314 PROCESS_AND_RETURN;
315 };
316 virtual int Ioctlsocket(SOCKET s, long cmd, u_long *argp, int& err)
317 {
318 int r = win32_ioctlsocket(s, cmd, argp);
319 PROCESS_AND_RETURN;
320 };
321};
322
323class CPerlLIO : public IPerlLIO
324{
325public:
326 CPerlLIO() {};
327 virtual int Access(const char *path, int mode, int &err)
328 {
329 CALLFUNCRET(access(path, mode))
330 };
331 virtual int Chmod(const char *filename, int pmode, int &err)
332 {
333 CALLFUNCRET(chmod(filename, pmode))
334 };
335 virtual int Chown(const char *filename, uid_t owner, gid_t group, int &err)
336 {
337 CALLFUNCERR(chown(filename, owner, group))
338 };
339 virtual int Chsize(int handle, long size, int &err)
340 {
341 CALLFUNCRET(chsize(handle, size))
342 };
343 virtual int Close(int handle, int &err)
344 {
345 CALLFUNCRET(win32_close(handle))
346 };
347 virtual int Dup(int handle, int &err)
348 {
349 CALLFUNCERR(win32_dup(handle))
350 };
351 virtual int Dup2(int handle1, int handle2, int &err)
352 {
353 CALLFUNCERR(win32_dup2(handle1, handle2))
354 };
355 virtual int Flock(int fd, int oper, int &err)
356 {
357 CALLFUNCERR(win32_flock(fd, oper))
358 };
359 virtual int FileStat(int handle, struct stat *buffer, int &err)
360 {
361 CALLFUNCERR(fstat(handle, buffer))
362 };
363 virtual int IOCtl(int i, unsigned int u, char *data, int &err)
364 {
365 CALLFUNCERR(win32_ioctlsocket((SOCKET)i, (long)u, (u_long*)data))
366 };
367 virtual int Isatty(int fd, int &err)
368 {
369 return isatty(fd);
370 };
371 virtual long Lseek(int handle, long offset, int origin, int &err)
372 {
373 LCALLFUNCERR(win32_lseek(handle, offset, origin))
374 };
375 virtual int Lstat(const char *path, struct stat *buffer, int &err)
376 {
377 return NameStat(path, buffer, err);
378 };
379 virtual char *Mktemp(char *Template, int &err)
380 {
381 return mktemp(Template);
382 };
383 virtual int Open(const char *filename, int oflag, int &err)
384 {
385 CALLFUNCERR(win32_open(filename, oflag))
386 };
387 virtual int Open(const char *filename, int oflag, int pmode, int &err)
388 {
389 int ret;
390 if(stricmp(filename, "/dev/null") == 0)
391 ret = open("NUL", oflag, pmode);
392 else
393 ret = open(filename, oflag, pmode);
394
395 if(errno)
396 err = errno;
397 return ret;
398 };
399 virtual int Read(int handle, void *buffer, unsigned int count, int &err)
400 {
401 CALLFUNCERR(win32_read(handle, buffer, count))
402 };
403 virtual int Rename(const char *OldFileName, const char *newname, int &err)
404 {
e24c7c18 405 CALLFUNCRET(win32_rename(OldFileName, newname))
0f4eea8f
DL
406 };
407 virtual int Setmode(int handle, int mode, int &err)
408 {
409 CALLFUNCRET(win32_setmode(handle, mode))
410 };
411 virtual int NameStat(const char *path, struct stat *buffer, int &err)
412 {
413 return win32_stat(path, buffer);
414 };
415 virtual char *Tmpnam(char *string, int &err)
416 {
417 return tmpnam(string);
418 };
419 virtual int Umask(int pmode, int &err)
420 {
421 return umask(pmode);
422 };
423 virtual int Unlink(const char *filename, int &err)
424 {
425 chmod(filename, S_IREAD | S_IWRITE);
426 CALLFUNCRET(unlink(filename))
427 };
428 virtual int Utime(char *filename, struct utimbuf *times, int &err)
429 {
430 CALLFUNCRET(win32_utime(filename, times))
431 };
432 virtual int Write(int handle, const void *buffer, unsigned int count, int &err)
433 {
434 CALLFUNCERR(win32_write(handle, buffer, count))
435 };
436};
437
438class CPerlMem : public IPerlMem
439{
440public:
441 CPerlMem() {};
442 virtual void* Malloc(size_t size)
443 {
444 return win32_malloc(size);
445 };
446 virtual void* Realloc(void* ptr, size_t size)
447 {
448 return win32_realloc(ptr, size);
449 };
450 virtual void Free(void* ptr)
451 {
452 win32_free(ptr);
453 };
454};
455
456#define EXECF_EXEC 1
457#define EXECF_SPAWN 2
458
459extern char * g_getlogin(void);
460extern int do_spawn2(char *cmd, int exectype);
461extern int g_do_aspawn(void *vreally, void **vmark, void **vsp);
462
463class CPerlProc : public IPerlProc
464{
465public:
466 CPerlProc() {};
467 virtual void Abort(void)
468 {
469 win32_abort();
470 };
ff95b63e
DL
471 virtual char * Crypt(const char* clear, const char* salt)
472 {
473 return win32_crypt(clear, salt);
474 };
0f4eea8f
DL
475 virtual void Exit(int status)
476 {
477 exit(status);
478 };
479 virtual void _Exit(int status)
480 {
481 _exit(status);
482 };
483 virtual int Execl(const char *cmdname, const char *arg0, const char *arg1, const char *arg2, const char *arg3)
484 {
485 return execl(cmdname, arg0, arg1, arg2, arg3);
486 };
487 virtual int Execv(const char *cmdname, const char *const *argv)
488 {
489 return win32_execvp(cmdname, argv);
490 };
491 virtual int Execvp(const char *cmdname, const char *const *argv)
492 {
493 return win32_execvp(cmdname, argv);
494 };
495 virtual uid_t Getuid(void)
496 {
497 return getuid();
498 };
499 virtual uid_t Geteuid(void)
500 {
501 return geteuid();
502 };
503 virtual gid_t Getgid(void)
504 {
505 return getgid();
506 };
507 virtual gid_t Getegid(void)
508 {
509 return getegid();
510 };
511 virtual char *Getlogin(void)
512 {
513 return g_getlogin();
514 };
515 virtual int Kill(int pid, int sig)
516 {
517 return win32_kill(pid, sig);
518 };
519 virtual int Killpg(int pid, int sig)
520 {
521 croak("killpg not implemented!\n");
522 return 0;
523 };
524 virtual int PauseProc(void)
525 {
526 return win32_sleep((32767L << 16) + 32767);
527 };
528 virtual PerlIO* Popen(const char *command, const char *mode)
529 {
530 win32_fflush(stdout);
531 win32_fflush(stderr);
532 return (PerlIO*)win32_popen(command, mode);
533 };
534 virtual int Pclose(PerlIO *stream)
535 {
536 return win32_pclose((FILE*)stream);
537 };
538 virtual int Pipe(int *phandles)
539 {
540 return win32_pipe(phandles, 512, O_BINARY);
541 };
542 virtual int Setuid(uid_t u)
543 {
544 return setuid(u);
545 };
546 virtual int Setgid(gid_t g)
547 {
548 return setgid(g);
549 };
550 virtual int Sleep(unsigned int s)
551 {
552 return win32_sleep(s);
553 };
554 virtual int Times(struct tms *timebuf)
555 {
556 return win32_times(timebuf);
557 };
558 virtual int Wait(int *status)
559 {
560 return win32_wait(status);
561 };
562 virtual int Waitpid(int pid, int *status, int flags)
563 {
564 return win32_waitpid(pid, status, flags);
565 };
566 virtual Sighandler_t Signal(int sig, Sighandler_t subcode)
567 {
568 return 0;
569 };
570 virtual void GetSysMsg(char*& sMsg, DWORD& dwLen, DWORD dwErr)
571 {
572 dwLen = FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER
573 |FORMAT_MESSAGE_IGNORE_INSERTS
574 |FORMAT_MESSAGE_FROM_SYSTEM, NULL,
575 dwErr, 0, (char *)&sMsg, 1, NULL);
576 if (0 < dwLen) {
577 while (0 < dwLen && isspace(sMsg[--dwLen]))
578 ;
579 if ('.' != sMsg[dwLen])
580 dwLen++;
581 sMsg[dwLen]= '\0';
582 }
583 if (0 == dwLen) {
584 sMsg = (char*)LocalAlloc(0, 64/**sizeof(TCHAR)*/);
585 dwLen = sprintf(sMsg,
586 "Unknown error #0x%lX (lookup 0x%lX)",
587 dwErr, GetLastError());
588 }
589 };
590 virtual void FreeBuf(char* sMsg)
591 {
592 LocalFree(sMsg);
593 };
594 virtual BOOL DoCmd(char *cmd)
595 {
596 do_spawn2(cmd, EXECF_EXEC);
597 return FALSE;
598 };
599 virtual int Spawn(char* cmds)
600 {
601 return do_spawn2(cmds, EXECF_SPAWN);
602 };
603 virtual int Spawnvp(int mode, const char *cmdname, const char *const *argv)
604 {
605 return win32_spawnvp(mode, cmdname, argv);
606 };
607 virtual int ASpawn(void *vreally, void **vmark, void **vsp)
608 {
609 return g_do_aspawn(vreally, vmark, vsp);
610 };
611};
612
613
614class CPerlStdIO : public IPerlStdIO
615{
616public:
617 CPerlStdIO() {};
618 virtual PerlIO* Stdin(void)
619 {
620 return (PerlIO*)win32_stdin();
621 };
622 virtual PerlIO* Stdout(void)
623 {
624 return (PerlIO*)win32_stdout();
625 };
626 virtual PerlIO* Stderr(void)
627 {
628 return (PerlIO*)win32_stderr();
629 };
630 virtual PerlIO* Open(const char *path, const char *mode, int &err)
631 {
632 PerlIO*pf = (PerlIO*)win32_fopen(path, mode);
633 if(errno)
634 err = errno;
635 return pf;
636 };
637 virtual int Close(PerlIO* pf, int &err)
638 {
639 CALLFUNCERR(win32_fclose(((FILE*)pf)))
640 };
641 virtual int Eof(PerlIO* pf, int &err)
642 {
643 CALLFUNCERR(win32_feof((FILE*)pf))
644 };
645 virtual int Error(PerlIO* pf, int &err)
646 {
647 CALLFUNCERR(win32_ferror((FILE*)pf))
648 };
649 virtual void Clearerr(PerlIO* pf, int &err)
650 {
651 win32_clearerr((FILE*)pf);
652 };
653 virtual int Getc(PerlIO* pf, int &err)
654 {
655 CALLFUNCERR(win32_getc((FILE*)pf))
656 };
657 virtual char* GetBase(PerlIO* pf, int &err)
658 {
2bd2b9e0
GS
659#ifdef FILE_base
660 FILE *f = (FILE*)pf;
661 return FILE_base(f);
662#else
663 return Nullch;
664#endif
0f4eea8f
DL
665 };
666 virtual int GetBufsiz(PerlIO* pf, int &err)
667 {
7a5f8e82 668#ifdef FILE_bufsiz
2bd2b9e0
GS
669 FILE *f = (FILE*)pf;
670 return FILE_bufsiz(f);
671#else
672 return (-1);
673#endif
0f4eea8f
DL
674 };
675 virtual int GetCnt(PerlIO* pf, int &err)
676 {
2bd2b9e0
GS
677#ifdef USE_STDIO_PTR
678 FILE *f = (FILE*)pf;
679 return FILE_cnt(f);
680#else
681 return (-1);
682#endif
0f4eea8f
DL
683 };
684 virtual char* GetPtr(PerlIO* pf, int &err)
685 {
2bd2b9e0
GS
686#ifdef USE_STDIO_PTR
687 FILE *f = (FILE*)pf;
688 return FILE_ptr(f);
689#else
690 return Nullch;
691#endif
0f4eea8f
DL
692 };
693 virtual char* Gets(PerlIO* pf, char* s, int n, int& err)
694 {
695 char* ret = win32_fgets(s, n, (FILE*)pf);
696 if(errno)
697 err = errno;
698 return ret;
699 };
700 virtual int Putc(PerlIO* pf, int c, int &err)
701 {
702 CALLFUNCERR(win32_fputc(c, (FILE*)pf))
703 };
704 virtual int Puts(PerlIO* pf, const char *s, int &err)
705 {
706 CALLFUNCERR(win32_fputs(s, (FILE*)pf))
707 };
708 virtual int Flush(PerlIO* pf, int &err)
709 {
710 CALLFUNCERR(win32_fflush((FILE*)pf))
711 };
712 virtual int Ungetc(PerlIO* pf,int c, int &err)
713 {
714 CALLFUNCERR(win32_ungetc(c, (FILE*)pf))
715 };
716 virtual int Fileno(PerlIO* pf, int &err)
717 {
718 CALLFUNCERR(win32_fileno((FILE*)pf))
719 };
720 virtual PerlIO* Fdopen(int fd, const char *mode, int &err)
721 {
722 PerlIO* pf = (PerlIO*)win32_fdopen(fd, mode);
723 if(errno)
724 err = errno;
725 return pf;
726 };
727 virtual PerlIO* Reopen(const char*path, const char*mode, PerlIO* pf, int &err)
728 {
729 PerlIO* newPf = (PerlIO*)win32_freopen(path, mode, (FILE*)pf);
730 if(errno)
731 err = errno;
732 return newPf;
733 };
734 virtual SSize_t Read(PerlIO* pf, void *buffer, Size_t size, int &err)
735 {
736 SSize_t i = win32_fread(buffer, 1, size, (FILE*)pf);
737 if(errno)
738 err = errno;
739 return i;
740 };
741 virtual SSize_t Write(PerlIO* pf, const void *buffer, Size_t size, int &err)
742 {
743 SSize_t i = win32_fwrite(buffer, 1, size, (FILE*)pf);
744 if(errno)
745 err = errno;
746 return i;
747 };
748 virtual void SetBuf(PerlIO* pf, char* buffer, int &err)
749 {
750 win32_setbuf((FILE*)pf, buffer);
751 };
752 virtual int SetVBuf(PerlIO* pf, char* buffer, int type, Size_t size, int &err)
753 {
754 int i = win32_setvbuf((FILE*)pf, buffer, type, size);
755 if(errno)
756 err = errno;
757 return i;
758 };
759 virtual void SetCnt(PerlIO* pf, int n, int &err)
760 {
2bd2b9e0
GS
761#ifdef STDIO_CNT_LVALUE
762 FILE *f = (FILE*)pf;
763 FILE_cnt(f) = n;
764#endif
0f4eea8f
DL
765 };
766 virtual void SetPtrCnt(PerlIO* pf, char * ptr, int n, int& err)
767 {
2bd2b9e0
GS
768#ifdef STDIO_PTR_LVALUE
769 FILE *f = (FILE*)pf;
770 FILE_ptr(f) = ptr;
771 FILE_cnt(f) = n;
772#endif
0f4eea8f
DL
773 };
774 virtual void Setlinebuf(PerlIO* pf, int &err)
775 {
776 win32_setvbuf((FILE*)pf, NULL, _IOLBF, 0);
777 };
778 virtual int Printf(PerlIO* pf, int &err, const char *format,...)
779 {
780 va_list(arglist);
781 va_start(arglist, format);
782 int i = win32_vfprintf((FILE*)pf, format, arglist);
783 if(errno)
784 err = errno;
785 return i;
786 };
787 virtual int Vprintf(PerlIO* pf, int &err, const char *format, va_list arglist)
788 {
789 int i = win32_vfprintf((FILE*)pf, format, arglist);
790 if(errno)
791 err = errno;
792 return i;
793 };
794 virtual long Tell(PerlIO* pf, int &err)
795 {
796 long l = win32_ftell((FILE*)pf);
797 if(errno)
798 err = errno;
799 return l;
800 };
801 virtual int Seek(PerlIO* pf, off_t offset, int origin, int &err)
802 {
803 int i = win32_fseek((FILE*)pf, offset, origin);
804 if(errno)
805 err = errno;
806 return i;
807 };
808 virtual void Rewind(PerlIO* pf, int &err)
809 {
810 win32_rewind((FILE*)pf);
811 };
812 virtual PerlIO* Tmpfile(int &err)
813 {
814 PerlIO* pf = (PerlIO*)win32_tmpfile();
815 if(errno)
816 err = errno;
817 return pf;
818 };
819 virtual int Getpos(PerlIO* pf, Fpos_t *p, int &err)
820 {
821 int i = win32_fgetpos((FILE*)pf, p);
822 if(errno)
823 err = errno;
824 return i;
825 };
826 virtual int Setpos(PerlIO* pf, const Fpos_t *p, int &err)
827 {
828 int i = win32_fsetpos((FILE*)pf, p);
829 if(errno)
830 err = errno;
831 return i;
832 };
833 virtual void Init(int &err)
834 {
835 };
836 virtual void InitOSExtras(void* p)
837 {
838 Perl_init_os_extras();
839 };
840 virtual int OpenOSfhandle(long osfhandle, int flags)
841 {
842 return win32_open_osfhandle(osfhandle, flags);
843 }
844 virtual int GetOSfhandle(int filenum)
845 {
846 return win32_get_osfhandle(filenum);
847 }
848};
849
850class CPerlHost
851{
852public:
853 CPerlHost() { pPerl = NULL; };
854 inline BOOL PerlCreate(void)
855 {
856 try
857 {
858 pPerl = perl_alloc(&perlMem, &perlEnv, &perlStdIO, &perlLIO,
859 &perlDir, &perlSock, &perlProc);
860 if(pPerl != NULL)
861 {
862 try
863 {
22c35a8c 864 perl_construct();
0f4eea8f
DL
865 }
866 catch(...)
867 {
868 win32_fprintf(stderr, "%s\n",
869 "Error: Unable to construct data structures");
22c35a8c 870 perl_free();
0f4eea8f
DL
871 pPerl = NULL;
872 }
873 }
874 }
875 catch(...)
876 {
877 win32_fprintf(stderr, "%s\n", "Error: Unable to allocate memory");
878 pPerl = NULL;
879 }
880 return (pPerl != NULL);
881 };
882 inline int PerlParse(void (*xs_init)(CPerlObj*), int argc, char** argv, char** env)
883 {
884 int retVal;
885 try
886 {
22c35a8c 887 retVal = perl_parse(xs_init, argc, argv, env);
0f4eea8f
DL
888 }
889 catch(int x)
890 {
891 // this is where exit() should arrive
892 retVal = x;
893 }
894 catch(...)
895 {
896 win32_fprintf(stderr, "Error: Parse exception\n");
897 retVal = -1;
898 }
899 *win32_errno() = 0;
900 return retVal;
901 };
902 inline int PerlRun(void)
903 {
904 int retVal;
905 try
906 {
22c35a8c 907 retVal = perl_run();
0f4eea8f
DL
908 }
909 catch(int x)
910 {
911 // this is where exit() should arrive
912 retVal = x;
913 }
914 catch(...)
915 {
916 win32_fprintf(stderr, "Error: Runtime exception\n");
917 retVal = -1;
918 }
919 return retVal;
920 };
921 inline void PerlDestroy(void)
922 {
923 try
924 {
22c35a8c
GS
925 perl_destruct();
926 perl_free();
0f4eea8f
DL
927 }
928 catch(...)
929 {
930 }
931 };
932
933protected:
934 CPerlDir perlDir;
935 CPerlEnv perlEnv;
936 CPerlLIO perlLIO;
937 CPerlMem perlMem;
938 CPerlProc perlProc;
939 CPerlSock perlSock;
940 CPerlStdIO perlStdIO;
941};