# define getlogin g_getlogin
#endif
-#if defined(PERL_OBJECT)
-# undef do_aspawn
-# define do_aspawn g_do_aspawn
-# undef Perl_do_exec
-# define Perl_do_exec g_do_exec
-#endif
-
static void get_shell(void);
static long tokenize(const char *str, char **dest, char ***destv);
int do_spawn2(char *cmd, int exectype);
if (retval == ERROR_SUCCESS
&& (type == REG_SZ || type == REG_EXPAND_SZ))
{
- dTHXo;
+ dTHX;
if (!*svp)
*svp = sv_2mortal(newSVpvn("",0));
SvGROW(*svp, datalen);
/* only add directory if it exists */
if (GetFileAttributes(mod_name) != (DWORD) -1) {
/* directory exists */
- dTHXo;
+ dTHX;
if (!*prev_pathp)
*prev_pathp = sv_2mortal(newSVpvn("",0));
sv_catpvn(*prev_pathp, ";", 1);
char *
win32_get_privlib(const char *pl)
{
- dTHXo;
+ dTHX;
char *stdlib = "lib";
char buffer[MAX_PATH+1];
SV *sv = Nullsv;
static char *
win32_get_xlib(const char *pl, const char *xlib, const char *libname)
{
- dTHXo;
+ dTHX;
char regstr[40];
char pathstr[MAX_PATH+1];
DWORD datalen;
{
int pid;
#ifdef USE_ITHREADS
- dTHXo;
+ dTHX;
if (w32_pseudo_id)
return -((int)w32_pseudo_id);
#endif
char **retvstart = 0;
int items = -1;
if (str) {
- dTHXo;
+ dTHX;
int slen = strlen(str);
register char *ret;
register char **retv;
static void
get_shell(void)
{
- dTHXo;
+ dTHX;
if (!w32_perlshell_tokens) {
/* we don't use COMSPEC here for two reasons:
* 1. the same reason perl on UNIX doesn't use SHELL--rampant and
int
do_aspawn(void *vreally, void **vmark, void **vsp)
{
- dTHXo;
+ dTHX;
SV *really = (SV*)vreally;
SV **mark = (SV**)vmark;
SV **sp = (SV**)vsp;
int
do_spawn2(char *cmd, int exectype)
{
- dTHXo;
+ dTHX;
char **a;
char *s;
char **argv;
DllExport DIR *
win32_opendir(char *filename)
{
- dTHXo;
+ dTHX;
DIR *dirp;
long len;
long idx;
/* Now set up for the next call to readdir */
dirp->curr += len + 1;
if (dirp->curr >= dirp->end) {
- dTHXo;
+ dTHX;
char* ptr;
BOOL res;
WIN32_FIND_DATAW wFindData;
DllExport int
win32_closedir(DIR *dirp)
{
- dTHXo;
+ dTHX;
if (dirp->handle != INVALID_HANDLE_VALUE)
FindClose(dirp->handle);
Safefree(dirp->start);
char *
getlogin(void)
{
- dTHXo;
+ dTHX;
char *buf = w32_getlogin_buffer;
DWORD size = sizeof(w32_getlogin_buffer);
if (GetUserName(buf,&size))
static long
find_pid(int pid)
{
- dTHXo;
+ dTHX;
long child = w32_num_children;
while (--child >= 0) {
if (w32_child_pids[child] == pid)
remove_dead_process(long child)
{
if (child >= 0) {
- dTHXo;
+ dTHX;
CloseHandle(w32_child_handles[child]);
Move(&w32_child_handles[child+1], &w32_child_handles[child],
(w32_num_children-child-1), HANDLE);
static long
find_pseudo_pid(int pid)
{
- dTHXo;
+ dTHX;
long child = w32_num_pseudo_children;
while (--child >= 0) {
if (w32_pseudo_child_pids[child] == pid)
remove_dead_pseudo_process(long child)
{
if (child >= 0) {
- dTHXo;
+ dTHX;
CloseHandle(w32_pseudo_child_handles[child]);
Move(&w32_pseudo_child_handles[child+1], &w32_pseudo_child_handles[child],
(w32_num_pseudo_children-child-1), HANDLE);
DllExport int
win32_kill(int pid, int sig)
{
- dTHXo;
+ dTHX;
HANDLE hProcess;
long child;
#ifdef USE_ITHREADS
DllExport int
win32_stat(const char *path, struct stat *sbuf)
{
- dTHXo;
+ dTHX;
char buffer[MAX_PATH+1];
int l = strlen(path);
int res;
DllExport char *
win32_getenv(const char *name)
{
- dTHXo;
+ dTHX;
WCHAR wBuffer[MAX_PATH+1];
DWORD needlen;
SV *curitem = Nullsv;
DllExport int
win32_putenv(const char *name)
{
- dTHXo;
+ dTHX;
char* curitem;
char* val;
WCHAR* wCuritem;
DllExport int
win32_unlink(const char *filename)
{
- dTHXo;
+ dTHX;
int ret;
DWORD attrs;
DllExport int
win32_utime(const char *filename, struct utimbuf *times)
{
- dTHXo;
+ dTHX;
HANDLE handle;
FILETIME ftCreate;
FILETIME ftAccess;
DllExport int
win32_waitpid(int pid, int *status, int flags)
{
- dTHXo;
+ dTHX;
DWORD timeout = (flags & WNOHANG) ? 0 : INFINITE;
int retval = -1;
long child;
/* XXX this wait emulation only knows about processes
* spawned via win32_spawnvp(P_NOWAIT, ...).
*/
- dTHXo;
+ dTHX;
int i, retval;
DWORD exitcode, waitcode;
return -1;
}
-#ifndef PERL_OBJECT
-
static UINT timerid = 0;
static VOID CALLBACK TimerProc(HWND win, UINT msg, UINT id, DWORD time)
{
- dTHXo;
+ dTHX;
KillTimer(NULL,timerid);
timerid=0;
CALL_FPTR(PL_sighandlerp)(14);
}
-#endif /* !PERL_OBJECT */
DllExport unsigned int
win32_alarm(unsigned int sec)
{
-#ifndef PERL_OBJECT
/*
* the 'obvious' implentation is SetTimer() with a callback
* which does whatever receiving SIGALRM would do
* Snag is unless something is looking at the message queue
* nothing happens :-(
*/
- dTHXo;
+ dTHX;
if (sec)
{
timerid = SetTimer(NULL,timerid,sec*1000,(TIMERPROC)TimerProc);
timerid=0;
}
}
-#endif /* !PERL_OBJECT */
return 0;
}
DllExport char *
win32_crypt(const char *txt, const char *salt)
{
- dTHXo;
+ dTHX;
#ifdef HAVE_DES_FCRYPT
return des_fcrypt(txt, salt, w32_crypt_buffer);
#else
HANDLE fh;
if (!IsWinNT()) {
- dTHXo;
+ dTHX;
Perl_croak_nocontext("flock() unimplemented on this platform");
return -1;
}
DWORD source = 0;
if (e < 0 || e > sys_nerr) {
- dTHXo;
+ dTHX;
if (e < 0)
e = GetLastError();
dwErr, GetLastError());
}
if (sMsg) {
- dTHXo;
+ dTHX;
sv_setpvn((SV*)sv, sMsg, dwLen);
LocalFree(sMsg);
}
DllExport FILE *
win32_fopen(const char *filename, const char *mode)
{
- dTHXo;
+ dTHX;
WCHAR wMode[MODE_SIZE], wBuffer[MAX_PATH+1];
FILE *f;
DllExport FILE *
win32_fdopen(int handle, const char *mode)
{
- dTHXo;
+ dTHX;
WCHAR wMode[MODE_SIZE];
FILE *f;
if (USING_WIDE()) {
DllExport FILE *
win32_freopen(const char *path, const char *mode, FILE *stream)
{
- dTHXo;
+ dTHX;
WCHAR wMode[MODE_SIZE], wBuffer[MAX_PATH+1];
if (stricmp(path, "/dev/null")==0)
path = "NUL";
/* start the child */
{
- dTHXo;
+ dTHX;
if ((childpid = do_spawn_nowait((char*)command)) == -1)
goto cleanup;
#ifdef USE_RTL_POPEN
return _pclose(pf);
#else
- dTHXo;
+ dTHX;
int childpid, status;
SV *sv;
DllExport int
win32_link(const char *oldname, const char *newname)
{
- dTHXo;
+ dTHX;
BOOL (__stdcall *pfnCreateHardLinkW)(LPCWSTR,LPCWSTR,LPSECURITY_ATTRIBUTES);
WCHAR wOldName[MAX_PATH+1];
WCHAR wNewName[MAX_PATH+1];
char szOldName[MAX_PATH+1];
char szNewName[MAX_PATH+1];
BOOL bResult;
- dTHXo;
+ dTHX;
/* XXX despite what the documentation says about MoveFileEx(),
* it doesn't work under Windows95!
DllExport int
win32_open(const char *path, int flag, ...)
{
- dTHXo;
+ dTHX;
va_list ap;
int pmode;
WCHAR wBuffer[MAX_PATH+1];
DllExport int
win32_mkdir(const char *dir, int mode)
{
- dTHXo;
+ dTHX;
if (USING_WIDE()) {
WCHAR wBuffer[MAX_PATH+1];
A2WHELPER(dir, wBuffer, sizeof(wBuffer));
DllExport int
win32_rmdir(const char *dir)
{
- dTHXo;
+ dTHX;
if (USING_WIDE()) {
WCHAR wBuffer[MAX_PATH+1];
A2WHELPER(dir, wBuffer, sizeof(wBuffer));
win32_chdir(const char *dir)
{
dTHXo;
+ if (!dir) {
+ errno = ENOENT;
+ return -1;
+ }
if (USING_WIDE()) {
WCHAR wBuffer[MAX_PATH+1];
A2WHELPER(dir, wBuffer, sizeof(wBuffer));
DllExport int
win32_access(const char *path, int mode)
{
- dTHXo;
+ dTHX;
if (USING_WIDE()) {
WCHAR wBuffer[MAX_PATH+1];
A2WHELPER(path, wBuffer, sizeof(wBuffer));
DllExport int
win32_chmod(const char *path, int mode)
{
- dTHXo;
+ dTHX;
if (USING_WIDE()) {
WCHAR wBuffer[MAX_PATH+1];
A2WHELPER(path, wBuffer, sizeof(wBuffer));
static char *
create_command_line(const char* command, const char * const *args)
{
- dTHXo;
+ dTHX;
int index;
char *cmd, *ptr, *arg;
STRLEN len = strlen(command) + 1;
static char *
qualified_path(const char *cmd)
{
- dTHXo;
+ dTHX;
char *pathstr;
char *fullcmd, *curfullcmd;
STRLEN cmdlen = 0;
char*
get_childdir(void)
{
- dTHXo;
+ dTHX;
char* ptr;
char szfilename[(MAX_PATH+1)*2];
if (USING_WIDE()) {
void
free_childdir(char* d)
{
- dTHXo;
+ dTHX;
Safefree(d);
}
#ifdef USE_RTL_SPAWNVP
return spawnvp(mode, cmdname, (char * const *)argv);
#else
- dTHXo;
+ dTHX;
int ret;
void* env;
char* dir;
win32_execv(const char *cmdname, const char *const *argv)
{
#ifdef USE_ITHREADS
- dTHXo;
+ dTHX;
/* if this is a pseudo-forked child, we just want to spawn
* the new program, and return */
if (w32_pseudo_id)
win32_execvp(const char *cmdname, const char *const *argv)
{
#ifdef USE_ITHREADS
- dTHXo;
+ dTHX;
/* if this is a pseudo-forked child, we just want to spawn
* the new program, and return */
if (w32_pseudo_id) {
DllExport void*
win32_dynaload(const char* filename)
{
- dTHXo;
+ dTHX;
HMODULE hModule;
char buf[MAX_PATH+1];
char *first;
sv_setpv(sv, ptr);
PerlEnv_free_childdir(ptr);
+#ifndef INCOMPLETE_TAINTS
+ SvTAINTED_on(sv);
+#endif
+
EXTEND(SP,1);
SvPOK_on(sv);
ST(0) = sv;
void
Perl_init_os_extras(void)
{
- dTHXo;
+ dTHX;
char *file = __FILE__;
dXSUB_SYS;
#ifdef HAVE_INTERP_INTERN
-# ifdef PERL_OBJECT
-# undef Perl_sys_intern_init
-# define Perl_sys_intern_init CPerlObj::Perl_sys_intern_init
-# undef Perl_sys_intern_dup
-# define Perl_sys_intern_dup CPerlObj::Perl_sys_intern_dup
-# undef Perl_sys_intern_clear
-# define Perl_sys_intern_clear CPerlObj::Perl_sys_intern_clear
-# define pPerl this
-# endif
-
void
Perl_sys_intern_init(pTHX)
{
# endif /* USE_ITHREADS */
#endif /* HAVE_INTERP_INTERN */
-#ifdef PERL_OBJECT
-# undef this
-# define this pPerl
-#endif
-
static void
-win32_free_argvw(pTHXo_ void *ptr)
+win32_free_argvw(pTHX_ void *ptr)
{
char** argv = (char**)ptr;
while(*argv) {
void
win32_argv2utf8(int argc, char** argv)
{
- dTHXo;
+ dTHX;
char* psz;
int length, wargc;
LPWSTR* lpwStr = CommandLineToArgvW(GetCommandLineW(), &wargc);