X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/519cb848a8f4c91c73421bb75314754284e593a4..1d261710b8a6cf129d9670d640a4d5df3ca6c0cc:/src/mac/carbon/utils.cpp diff --git a/src/mac/carbon/utils.cpp b/src/mac/carbon/utils.cpp index 817138cb63..5d1e9faf41 100644 --- a/src/mac/carbon/utils.cpp +++ b/src/mac/carbon/utils.cpp @@ -18,6 +18,7 @@ #include "wx/setup.h" #include "wx/utils.h" #include "wx/app.h" +#include "wx/mac/uma.h" #include @@ -26,7 +27,16 @@ #include #include -// Get full hostname (eg. DoDo.BSn-Germany.crg.de) +#ifndef __UNIX__ +// defined in unix/utilsunx.cpp for Mac OS X + +// get full hostname (with domain name if possible) +bool wxGetFullHostName(wxChar *buf, int maxSize) +{ + return wxGetHostName(buf, maxSize); +} + +// Get hostname only (without domain name) bool wxGetHostName(char *buf, int maxSize) { // TODO @@ -40,6 +50,14 @@ bool wxGetUserId(char *buf, int maxSize) return FALSE; } +const wxChar* wxGetHomeDir(wxString *pstr) +{ + *pstr = wxMacFindFolder( (short) kOnSystemDisk, kPreferencesFolderType, kDontCreateFolder ) ; + return pstr->c_str() ; +} + + + // Get user name e.g. AUTHOR bool wxGetUserName(char *buf, int maxSize) { @@ -108,6 +126,7 @@ void wxFatalError(const wxString& msg, const wxString& title) { // TODO } +#endif // !__UNIX__ // Emit a beeeeeep void wxBell() @@ -227,7 +246,10 @@ void wxEndBusyCursor() if ( gMacStoredActiveCursor ) ::SetCursor( *gMacStoredActiveCursor ) ; else - ::SetCursor( &qd.arrow ) ; + { + Cursor MacArrow ; + ::SetCursor( GetQDGlobalsArrow( &MacArrow ) ) ; + } gMacStoredActiveCursor = NULL ; } } @@ -238,11 +260,32 @@ bool wxIsBusy() return (wxBusyCursorCount > 0); } +wxString wxMacFindFolder( short vol, + OSType folderType, + Boolean createFolder) +{ + short vRefNum ; + long dirID ; + wxString strDir ; + + if ( FindFolder( vol, folderType, createFolder, &vRefNum, &dirID) == noErr) + { + FSSpec file ; + if ( FSMakeFSSpec( vRefNum , dirID , "\p" , &file ) == noErr ) + { + strDir = wxMacFSSpec2UnixFilename( &file ) + "/" ; + } + } + return strDir ; +} + +#ifndef __UNIX__ char *wxGetUserHome (const wxString& user) { // TODO return NULL; } +#endif // Check whether this window wants to process messages, e.g. Stop button // in long calculations. @@ -271,23 +314,36 @@ bool wxColourDisplay() // Returns depth of screen int wxDisplayDepth() { - // get max pixel depth - CGrafPtr port ; - GetCWMgrPort( &port ) ; - GDHandle maxDevice ; + Rect globRect ; + SetRect(&globRect, -32760, -32760, 32760, 32760); + GDHandle theMaxDevice; + + int theDepth = 8; + theMaxDevice = GetMaxDevice(&globRect); + if (theMaxDevice != nil) + theDepth = (**(**theMaxDevice).gdPMap).pixelSize; - maxDevice = GetMaxDevice( &port->portRect ) ; - if ( maxDevice ) - return (**((**maxDevice).gdPMap)).pixelSize ; - else - return 8 ; + return theDepth ; } // Get size of display void wxDisplaySize(int *width, int *height) { - *width = qd.screenBits.bounds.right - qd.screenBits.bounds.left ; - *height = qd.screenBits.bounds.bottom - qd.screenBits.bounds.top ; - *height -= LMGetMBarHeight() ; + BitMap screenBits; + GetQDGlobalsScreenBits( &screenBits ); + + *width = screenBits.bounds.right - screenBits.bounds.left ; + *height = screenBits.bounds.bottom - screenBits.bounds.top ; +#if TARGET_CARBON + SInt16 mheight ; + GetThemeMenuBarHeight( &mheight ) ; + *height -= mheight ; +#else + *height -= LMGetMBarHeight() ; +#endif } +wxWindow* wxFindWindowAtPoint(const wxPoint& pt) +{ + return wxGenericFindWindowAtPoint(pt); +}