X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/5ea105e0ba20c15e4d83f829e1c4faeb0a4952f0..4cb122de97b40f0b6c8896f40847a7aaf762abb5:/src/msw/utilsexc.cpp diff --git a/src/msw/utilsexc.cpp b/src/msw/utilsexc.cpp index bcb9faf6a3..0c566962da 100644 --- a/src/msw/utilsexc.cpp +++ b/src/msw/utilsexc.cpp @@ -106,7 +106,7 @@ static DWORD wxExecuteThread(wxExecuteData *data) } wxASSERT_MSG( data->dwExitCode != STILL_ACTIVE, - "process should have terminated" ); + _T("process should have terminated") ); // send a message indicating process termination to the window SendMessage(data->hWnd, wxWM_PROC_TERMINATED, 0, (LPARAM)data); @@ -147,11 +147,11 @@ LRESULT APIENTRY _EXPORT wxExecuteWindowCbk(HWND hWnd, UINT message, return 0; } -extern char wxPanelClassName[]; +extern wxChar wxPanelClassName[]; long wxExecute(const wxString& command, bool sync, wxProcess *handler) { - wxCHECK_MSG( !!command, 0, "empty command in wxExecute" ); + wxCHECK_MSG( !!command, 0, _T("empty command in wxExecute") ); #if defined(__WIN32__) && !defined(__TWIN32__) // the old code is disabled because we really need a process handle @@ -223,7 +223,7 @@ long wxExecute(const wxString& command, bool sync, wxProcess *handler) if ( ::CreateProcess( NULL, // application name (use only cmd line) - (char *)command.c_str(), // full command line + (wxChar *)command.c_str(), // full command line NULL, // security attributes: defaults for both NULL, // the process and its main thread FALSE, // don't inherit handles @@ -247,7 +247,7 @@ long wxExecute(const wxString& command, bool sync, wxProcess *handler) // termination HWND hwnd = ::CreateWindow(wxPanelClassName, NULL, 0, 0, 0, 0, 0, NULL, (HMENU)NULL, wxGetInstance(), 0); - wxASSERT_MSG( hwnd, "can't create a hidden window for wxExecute" ); + wxASSERT_MSG( hwnd, _T("can't create a hidden window for wxExecute") ); FARPROC ExecuteWindowInstance = MakeProcInstance((FARPROC)wxExecuteWindowCbk, wxGetInstance()); @@ -262,7 +262,7 @@ long wxExecute(const wxString& command, bool sync, wxProcess *handler) data->state = sync; if ( sync ) { - wxASSERT_MSG( !handler, "wxProcess param ignored for sync execution" ); + wxASSERT_MSG( !handler, _T("wxProcess param ignored for sync execution") ); data->handler = NULL; } @@ -317,7 +317,7 @@ long wxExecute(const wxString& command, bool sync, wxProcess *handler) int running; do { wxYield(); - running = GetModuleUsage((HANDLE)instanceID); + running = GetModuleUsage((HINSTANCE)instanceID); } while (running); } @@ -338,3 +338,34 @@ long wxExecute(char **argv, bool sync, wxProcess *handler) return wxExecute(command, sync, handler); } + +bool wxGetFullHostName(wxChar *buf, int maxSize) +{ +#if defined(__WIN32__) && !defined(__TWIN32__) + DWORD nSize = maxSize ; + if ( !::GetComputerName(buf, &nSize) ) + { + wxLogLastError("GetComputerName"); + + return FALSE; + } +#else + char *sysname; + const char *default_host = "noname"; +static const char WX_SECTION[] = "wxWindows"; +static const char eHOSTNAME[] = "HostName"; + + if ((sysname = getenv("SYSTEM_NAME")) == NULL) { + GetProfileString(WX_SECTION, eHOSTNAME, default_host, buf, maxSize - 1); + } else + strncpy(buf, sysname, maxSize - 1); + buf[maxSize] = '\0'; + if ( *buf == '\0' ) + { + wxLogLastError("GetComputerName"); + + return FALSE; + } +#endif + return TRUE; +}