X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c8023fed763ccd02964dc5b5201371b7d3cfda55..adf2eb2d343159326a68ba1a9b1a76f60f30d937:/src/unix/utilsunx.cpp diff --git a/src/unix/utilsunx.cpp b/src/unix/utilsunx.cpp index 5c76164d10..be66b6c9e4 100644 --- a/src/unix/utilsunx.cpp +++ b/src/unix/utilsunx.cpp @@ -28,6 +28,11 @@ #include "wx/wfstream.h" +#if defined( __MWERKS__ ) && defined(__MACH__) +#define WXWIN_OS_DESCRIPTION "MacOS X" +#define HAVE_NANOSLEEP +#endif + // not only the statfs syscall is called differently depending on platform, but // one of its incarnations, statvfs(), takes different arguments under // different platforms and even different versions of the same system (Solaris @@ -544,7 +549,7 @@ long wxExecute(wxChar **argv, wxChar **mb_argv = argv; #endif // Unicode/ANSI -#if wxUSE_GUI && !defined(__DARWIN__) +#if wxUSE_GUI && !(defined(__DARWIN__) && defined(__WXMAC__)) // create pipes wxPipe pipeEndProcDetect; if ( !pipeEndProcDetect.Create() ) @@ -555,7 +560,7 @@ long wxExecute(wxChar **argv, return ERROR_RETURN_CODE; } -#endif // wxUSE_GUI && !defined(__DARWIN__) +#endif // wxUSE_GUI && !(defined(__DARWIN__) && defined(__WXMAC__)) // pipes for inter process communication wxPipe pipeIn, // stdin @@ -606,9 +611,9 @@ long wxExecute(wxChar **argv, if ( fd == pipeIn[wxPipe::Read] || fd == pipeOut[wxPipe::Write] || fd == pipeErr[wxPipe::Write] -#if wxUSE_GUI && !defined(__DARWIN__) +#if wxUSE_GUI && !(defined(__DARWIN__) && defined(__WXMAC__)) || fd == pipeEndProcDetect[wxPipe::Write] -#endif // wxUSE_GUI && !defined(__DARWIN__) +#endif // wxUSE_GUI && !(defined(__DARWIN__) && defined(__WXMAC__)) ) { // don't close this one, we still need it @@ -630,12 +635,12 @@ long wxExecute(wxChar **argv, } #endif // !__VMS -#if wxUSE_GUI && !defined(__DARWIN__) +#if wxUSE_GUI && !(defined(__DARWIN__) && defined(__WXMAC__)) // reading side can be safely closed but we should keep the write one // opened pipeEndProcDetect.Detach(wxPipe::Write); pipeEndProcDetect.Close(); -#endif // wxUSE_GUI && !defined(__DARWIN__) +#endif // wxUSE_GUI && !(defined(__DARWIN__) && defined(__WXMAC__)) // redirect stdin, stdout and stderr if ( pipeIn.IsOk() ) @@ -655,8 +660,9 @@ long wxExecute(wxChar **argv, execvp (*mb_argv, mb_argv); fprintf(stderr, "execvp("); - for ( char **ppc = mb_argv; *ppc; ppc++ ) - fprintf(stderr, "%s%s", ppc == mb_argv ? "" : ", ", *ppc); + // CS changed ppc to ppc_ as ppc is not available under mac os CW Mach-O + for ( char **ppc_ = mb_argv; *ppc_; ppc_++ ) + fprintf(stderr, "%s%s", ppc_ == mb_argv ? "" : ", ", *ppc_); fprintf(stderr, ") failed with error %d!\n", errno); // there is no return after successful exec() @@ -736,7 +742,7 @@ long wxExecute(wxChar **argv, } -#if defined(__DARWIN__) +#if defined(__DARWIN__) && defined(__WXMAC__) data->tag = wxAddProcessCallbackForPid(data,pid); #else data->tag = wxAddProcessCallback @@ -746,7 +752,7 @@ long wxExecute(wxChar **argv, ); pipeEndProcDetect.Close(); -#endif // defined(__DARWIN__) +#endif // defined(__DARWIN__) && defined(__WXMAC__) if ( flags & wxEXEC_SYNC ) {