X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/018e2f1300b726936e8afa41fcc3e2a85d2ed456..ef3a5e0aae003c29941c7d41ed6becea4287752d:/src/unix/utilsunx.cpp?ds=inline diff --git a/src/unix/utilsunx.cpp b/src/unix/utilsunx.cpp index 888eb203af..ffbde3589f 100644 --- a/src/unix/utilsunx.cpp +++ b/src/unix/utilsunx.cpp @@ -29,9 +29,20 @@ #include "wx/stream.h" #ifdef HAVE_STATFS - #include +# ifdef __BSD__ +# include +# include +# else +# include +# endif #endif // HAVE_STATFS +#ifdef HAVE_STATVFS + #include + + #define statfs statvfs +#endif // HAVE_STATVFS + #if wxUSE_GUI #include "wx/unix/execute.h" #endif @@ -283,32 +294,12 @@ bool wxShell(const wxString& command, wxArrayString& output) void wxHandleProcessTermination(wxEndProcessData *proc_data) { - int pid = (proc_data->pid > 0) ? proc_data->pid : -(proc_data->pid); - - // waitpid is POSIX so should be available everywhere, however on older - // systems wait() might be used instead in a loop (until the right pid - // terminates) - int status = 0; - int rc; - - // wait for child termination and if waitpid() was interrupted, try again - do - { - rc = waitpid(pid, &status, 0); - } - while ( rc == -1 && errno == EINTR ); - // notify user about termination if required if ( proc_data->process ) { - proc_data->process->OnTerminate - ( - proc_data->pid, - (rc == 0) && WIFEXITED(status) - ? WEXITSTATUS(status) - : -1 - ); + proc_data->process->OnTerminate(proc_data->pid, proc_data->exitcode); } + // clean up if ( proc_data->pid > 0 ) { @@ -316,9 +307,7 @@ void wxHandleProcessTermination(wxEndProcessData *proc_data) } else { - // wxExecute() will know about it - proc_data->exitcode = status; - + // let wxExecute() know that the process has terminated proc_data->pid = 0; } } @@ -1024,8 +1013,7 @@ long wxGetFreeMemory() bool wxGetDiskSpace(const wxString& path, wxLongLong *pTotal, wxLongLong *pFree) { -#ifdef HAVE_STATFS - +#if defined(HAVE_STATFS) || defined(HAVE_STATVFS) struct statfs fs; if ( statfs(path, &fs) != 0 ) { @@ -1034,6 +1022,9 @@ bool wxGetDiskSpace(const wxString& path, wxLongLong *pTotal, wxLongLong *pFree) return FALSE; } + // under Solaris we might have to use fs.f_frsize instead as I think it + // may be a multiple of the block size in general (TODO) + if ( pTotal ) { *pTotal = wxLongLong(fs.f_blocks) * fs.f_bsize;