X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/5fbecd9925bd4bfb4751b722577605779e1d7dd7..0f66a9f39d0d48f3e0da6641fa66d1b3db305732:/src/unix/utilsunx.cpp diff --git a/src/unix/utilsunx.cpp b/src/unix/utilsunx.cpp index bb8b4b33e9..e9510f7235 100644 --- a/src/unix/utilsunx.cpp +++ b/src/unix/utilsunx.cpp @@ -58,15 +58,26 @@ #if !defined(HAVE_USLEEP) && \ (defined(__SUN__) && !defined(__SunOs_5_6) && \ !defined(__SunOs_5_7) && !defined(__SUNPRO_CC)) || \ - defined(__osf__) + defined(__osf__) || defined(__EMX__) extern "C" { #ifdef __SUN__ int usleep(unsigned int usec); #else // !Sun - void usleep(unsigned long usec); - #endif // Sun/!Sun + #ifdef __EMX + /* I copied this from the XFree86 diffs. AV. */ + #define INCL_DOSPROCESS + #include + void usleep(unsigned long delay) + { + DosSleep(delay ? (delay/1000l) : 1l); + } + #else + void usleep(unsigned long usec); + #endif + #endif // Sun/EMX/Something else }; +#define HAVE_USLEEP 1 #endif // Unices without usleep() // ============================================================================ @@ -244,7 +255,7 @@ long wxExecute( wxChar **argv, bool sync, wxProcess *process ) char *mb_argv[WXEXECUTE_NARGS]; while (argv[mb_argc]) { - wxWX2MBbuf mb_arg = wxConv_libc.cWX2MB(argv[mb_argc]); + wxWX2MBbuf mb_arg = wxConvCurrent->cWX2MB(argv[mb_argc]); mb_argv[mb_argc] = strdup(mb_arg); mb_argc++; } @@ -266,7 +277,7 @@ long wxExecute( wxChar **argv, bool sync, wxProcess *process ) } // fork the process -#ifdef HAVE_VFORK +#if HAVE_VFORK pid_t pid = vfork(); #else pid_t pid = fork(); @@ -393,7 +404,7 @@ char *wxGetUserHome( const wxString &user ) } if ((ptr = wxGetenv(_T("USER"))) != NULL || (ptr = wxGetenv(_T("LOGNAME"))) != NULL) { - who = getpwnam(wxConv_libc.cWX2MB(ptr)); + who = getpwnam(wxConvCurrent->cWX2MB(ptr)); } // We now make sure the the user exists! @@ -408,7 +419,7 @@ char *wxGetUserHome( const wxString &user ) } #if wxUSE_UNICODE - return who ? wxConv_libc.cMB2WX(who->pw_dir) : (wxMB2WXbuf)((wxChar*)NULL); + return who ? wxConvCurrent->cMB2WX(who->pw_dir) : (wxMB2WXbuf)((wxChar*)NULL); #else return who ? who->pw_dir : ((char*)NULL); #endif @@ -433,7 +444,7 @@ static bool wxGetHostNameInternal(wxChar *buf, int sz) bool ok = uname(&uts) != -1; if ( ok ) { - wxStrncpy(buf, wxConv_libc.cMB2WX(uts.nodename), sz - 1); + wxStrncpy(buf, wxConvCurrent->cMB2WX(uts.nodename), sz - 1); buf[sz] = _T('\0'); } #elif defined(HAVE_GETHOSTNAME) @@ -479,7 +490,7 @@ bool wxGetFullHostName(wxChar *buf, int sz) { if ( !wxStrchr(buf, _T('.')) ) { - struct hostent *host = gethostbyname(wxConv_libc.cWX2MB(buf)); + struct hostent *host = gethostbyname(wxConvCurrent->cWX2MB(buf)); if ( !host ) { wxLogSysError(_("Cannot get the official hostname")); @@ -489,7 +500,7 @@ bool wxGetFullHostName(wxChar *buf, int sz) else { // the canonical name - wxStrncpy(buf, wxConv_libc.cMB2WX(host->h_name), sz); + wxStrncpy(buf, wxConvCurrent->cMB2WX(host->h_name), sz); } } //else: it's already a FQDN (BSD behaves this way) @@ -505,7 +516,7 @@ bool wxGetUserId(wxChar *buf, int sz) *buf = _T('\0'); if ((who = getpwuid(getuid ())) != NULL) { - wxStrncpy (buf, wxConv_libc.cMB2WX(who->pw_name), sz - 1); + wxStrncpy (buf, wxConvCurrent->cMB2WX(who->pw_name), sz - 1); return TRUE; } @@ -522,7 +533,7 @@ bool wxGetUserName(wxChar *buf, int sz) comma = strchr(who->pw_gecos, ','); if (comma) *comma = '\0'; // cut off non-name comment fields - wxStrncpy (buf, wxConv_libc.cMB2WX(who->pw_gecos), sz - 1); + wxStrncpy (buf, wxConvCurrent->cMB2WX(who->pw_gecos), sz - 1); return TRUE; }