X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ba7eb0a5a74280222fb2ad584b65195ac70cd956..89fcec9514fd890de58da83118363570e2482bc9:/src/mac/utils.cpp diff --git a/src/mac/utils.cpp b/src/mac/utils.cpp index 1a71c0c784..f234da7456 100644 --- a/src/mac/utils.cpp +++ b/src/mac/utils.cpp @@ -27,7 +27,12 @@ #include #include -#ifndef __UNIX__ +#ifndef __DARWIN__ +# include "morefile.h" +# include "moreextr.h" +#endif + +#ifndef __DARWIN__ // defined in unix/utilsunx.cpp for Mac OS X // get full hostname (with domain name if possible) @@ -178,7 +183,7 @@ void wxFatalError(const wxString& msg, const wxString& title) wxMessageBox(wxBuffer); wxExit(); } -#endif // !__UNIX__ +#endif // !__DARWIN__ // Emit a beeeeeep void wxBell() @@ -315,7 +320,7 @@ bool wxIsBusy() return (wxBusyCursorCount > 0); } -#ifndef __UNIX__ +#ifndef __DARWIN__ wxString wxMacFindFolder( short vol, OSType folderType, Boolean createFolder) @@ -336,7 +341,7 @@ wxString wxMacFindFolder( short vol, } #endif -#ifndef __UNIX__ +#ifndef __DARWIN__ char *wxGetUserHome (const wxString& user) { // TODO @@ -344,6 +349,42 @@ char *wxGetUserHome (const wxString& user) } #endif +#ifndef __DARWIN__ +bool wxGetDiskSpace(const wxString& path, wxLongLong *pTotal, wxLongLong *pFree) +{ + if ( path.empty() ) + return FALSE; + + wxString p = path ; + if (p[0] == ':' ) { + p = wxGetCwd() + p ; + } + + int pos = p.Find(':') ; + if ( pos != wxNOT_FOUND ) { + p = p.Mid(1,pos) ; + } + + p = p + ":" ; + + Str255 volumeName ; + XVolumeParam pb ; + + wxMacStringToPascal( p , volumeName ) ; + OSErr err = XGetVolumeInfoNoName( volumeName , 0 , &pb ) ; + if ( err == noErr ) { + if ( pTotal ) { + (*pTotal) = wxLongLong( pb.ioVTotalBytes ) ; + } + if ( pFree ) { + (*pFree) = wxLongLong( pb.ioVFreeBytes ) ; + } + } + + return err == noErr ; +} +#endif + // Check whether this window wants to process messages, e.g. Stop button // in long calculations. bool wxCheckForInterrupt(wxWindow *wnd)