+
+extern wxChar wxPanelClassName[];
+
+long wxExecute(
+ const wxString& rCommand
+, bool bSync
+, wxProcess* pHandler
+)
+{
+ wxCHECK_MSG(!!rCommand, 0, wxT("empty command in wxExecute"));
+
+ // create the process
+ UCHAR vLoadError[CCHMAXPATH] = {0};
+ RESULTCODES vResultCodes = {0};
+ ULONG ulExecFlag;
+ PSZ zArgs = NULL;
+ PSZ zEnvs = NULL;
+ ULONG ulWindowId;
+ APIRET rc;
+ PFNWP pOldProc;
+ TID vTID;
+
+ if (bSync)
+ ulExecFlag = EXEC_SYNC;
+ else
+ ulExecFlag = EXEC_ASYNCRESULT;
+
+ if (::DosExecPgm( (PCHAR)vLoadError
+ ,sizeof(vLoadError)
+ ,ulExecFlag
+ ,zArgs
+ ,zEnvs
+ ,&vResultCodes
+ ,rCommand
+ ))
+ {
+ wxLogSysError(_("Execution of command '%s' failed"), rCommand.c_str());
+ return 0;
+ }
+
+ // PM does not need non visible object windows to run console child processes
+/*
+ HWND hwnd = ::WinCreateWindow( HWND_DESKTOP
+ ,wxPanelClassName
+ ,NULL
+ ,0
+ ,0
+ ,0
+ ,0
+ ,0
+ ,NULLHANDLE
+ ,NULLHANDLE
+ ,ulWindowId
+ ,NULL
+ ,NULL
+ );
+ wxASSERT_MSG( hwnd, wxT("can't create a hidden window for wxExecute") );
+ pOldProc = ::WinSubclassWindow(hwnd, (PFNWP)&wxExecuteWindowCbk);
+
+*/
+ // Alloc data
+ wxExecuteData* pData = new wxExecuteData;
+
+ pData->vResultCodes = vResultCodes;
+ pData->hWnd = NULLHANDLE;
+ pData->bState = bSync;
+ if (bSync)
+ {
+ wxASSERT_MSG(!pHandler, wxT("wxProcess param ignored for sync execution"));
+ pData->pHandler = NULL;
+ }
+ else
+ {
+ // may be NULL or not
+ pData->pHandler = pHandler;
+ }
+
+ rc = ::DosCreateThread( &vTID
+ ,(PFNTHREAD)&wxExecuteThread
+ ,(ULONG)pData
+ ,CREATE_READY|STACK_SPARSE
+ ,8192
+ );
+ if (rc != NO_ERROR)
+ {
+ wxLogLastError("CreateThread in wxExecute");
+
+// ::WinDestroyWindow(hwnd);
+ delete pData;
+
+ // the process still started up successfully...
+ return vResultCodes.codeTerminate;
+ }
+ if (!bSync)
+ {
+ // clean up will be done when the process terminates
+
+ // return the pid
+ return vResultCodes.codeTerminate;
+ }
+ ::DosWaitThread(&vTID, DCWW_WAIT);
+
+ ULONG ulExitCode = pData->vResultCodes.codeResult;
+ delete pData;
+
+ // return the exit code
+ return (long)ulExitCode;
+}
+
+long wxExecute(
+ char** ppArgv
+, bool bSync
+, wxProcess* pHandler
+)
+{
+ wxString sCommand;
+
+ while (*ppArgv != NULL)
+ {
+ sCommand << *ppArgv++ << ' ';
+ }
+ sCommand.RemoveLast();
+ return wxExecute( sCommand
+ ,bSync
+ ,pHandler
+ );
+}
+
+bool wxGetFullHostName(
+ wxChar* zBuf
+, int nMaxSize
+)
+{
+#if wxUSE_NET_API
+ char zServer[256];
+ char zComputer[256];
+ unsigned short nLevel = 0;
+ unsigned char* zBuffer;
+ unsigned short nBuffer;
+ unsigned short* pnTotalAvail;
+
+ NetBios32GetInfo( (const unsigned char*)zServer
+ ,(const unsigned char*)zComputer
+ ,nLevel
+ ,zBuffer
+ ,nBuffer
+ ,pnTotalAvail
+ );
+ strncpy(zBuf, zComputer, nMaxSize);
+ zBuf[nMaxSize] = _T('\0');
+#else
+ strcpy(zBuf, "noname");
+#endif
+ return *zBuf ? TRUE : FALSE;
+ return TRUE;
+}
+