X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6b941b35c028915cd04b5b3843e437ab2e274ed8..8850cbd3c3f4e714e6883d3ff8e4ac58144427bc:/include/wx/mac/carbon/private.h diff --git a/include/wx/mac/carbon/private.h b/include/wx/mac/carbon/private.h index 2f0c5cb7e0..8e8badb6ac 100644 --- a/include/wx/mac/carbon/private.h +++ b/include/wx/mac/carbon/private.h @@ -1,7 +1,7 @@ ///////////////////////////////////////////////////////////////////////////// // Name: private.h // Purpose: Private declarations: as this header is only included by -// wxWindows itself, it may contain identifiers which don't start +// wxWidgets itself, it may contain identifiers which don't start // with "wx". // Author: Stefan Csomor // Modified by: @@ -20,6 +20,7 @@ #ifdef __DARWIN__ # include #else +# include # include # include # include @@ -33,6 +34,10 @@ #error "please update to Apple's lastest universal headers from http://developer.apple.com/sdk/" #endif +#ifndef MAC_OS_X_VERSION_10_3 + #define MAC_OS_X_VERSION_10_3 1030 +#endif + #if wxUSE_GUI #include "wx/window.h" @@ -62,6 +67,24 @@ private: short m_textMode ; } ; +class WXDLLEXPORT wxMacPortSaver +{ + DECLARE_NO_COPY_CLASS(wxMacPortSaver) + +public: + wxMacPortSaver( GrafPtr port ) + { + ::GetPort( &m_port ) ; + ::SetPort( port ) ; + } + ~wxMacPortSaver() + { + ::SetPort( m_port ) ; + } +private : + GrafPtr m_port ; +} ; + class WXDLLEXPORT wxMacPortSetter { DECLARE_NO_COPY_CLASS(wxMacPortSetter) @@ -74,7 +97,11 @@ private: const wxDC* m_dc ; } ; -class WXDLLEXPORT wxMacWindowClipper +/* + Clips to the visible region of a control within the current port + */ + +class WXDLLEXPORT wxMacWindowClipper : public wxMacPortSaver { DECLARE_NO_COPY_CLASS(wxMacWindowClipper) @@ -82,10 +109,24 @@ public: wxMacWindowClipper( const wxWindow* win ) ; ~wxMacWindowClipper() ; private: + GrafPtr m_newPort ; RgnHandle m_formerClip ; RgnHandle m_newClip ; } ; +class WXDLLEXPORT wxMacWindowStateSaver : public wxMacWindowClipper +{ + DECLARE_NO_COPY_CLASS(wxMacWindowStateSaver) + +public: + wxMacWindowStateSaver( const wxWindow* win ) ; + ~wxMacWindowStateSaver() ; +private: + GrafPtr m_newPort ; + ThemeDrawingState m_themeDrawingState ; +} ; + +/* class wxMacDrawingHelper { DECLARE_NO_COPY_CLASS(wxMacDrawingHelper) @@ -105,6 +146,7 @@ private: PenState m_savedPenState ; bool m_ok ; } ; +*/ // app.h bool wxMacConvertEventToRecord( EventRef event , EventRecord *rec) ; @@ -113,15 +155,7 @@ bool wxMacConvertEventToRecord( EventRef event , EventRecord *rec) ; // filefn.h WXDLLEXPORT wxString wxMacFSSpec2MacFilename( const FSSpec *spec ) ; -WXDLLEXPORT void wxMacFilename2FSSpec( const char *path , FSSpec *spec ) ; -WXDLLEXPORT void wxMacFilename2FSSpec( const wxChar *path , FSSpec *spec ) ; -# ifndef __DARWIN__ -// Mac file names are POSIX (Unix style) under Darwin, so these are not needed -WXDLLEXPORT wxString wxMacFSSpec2UnixFilename( const FSSpec *spec ) ; -WXDLLEXPORT void wxUnixFilename2FSSpec( const wxChar *path , FSSpec *spec ) ; -WXDLLEXPORT wxString wxMac2UnixFilename( const wxChar *s) ; -WXDLLEXPORT wxString wxUnix2MacFilename( const wxChar *s); -# endif +WXDLLEXPORT void wxMacFilename2FSSpec( const wxString &path , FSSpec *spec ) ; // utils.h WXDLLEXPORT wxString wxMacFindFolder(short vRefNum, @@ -149,6 +183,290 @@ void wxMacCreateBitmapButton( ControlButtonContentInfo*info , const wxBitmap& bi #define MAC_WXPOINTPTR(a) ((Point*)a) #define MAC_WXHMENU(a) ((MenuHandle)a) +struct wxOpaqueWindowRef +{ + wxOpaqueWindowRef( WindowRef ref ) { m_data = ref ; } + operator WindowRef() { return m_data ; } +private : + WindowRef m_data ; +} ; + +wxWindow * wxFindControlFromMacControl(ControlRef inControl ) ; +wxTopLevelWindowMac* wxFindWinFromMacWindow( WindowRef inWindow ) ; +wxMenu* wxFindMenuFromMacMenu(MenuRef inMenuRef) ; + +extern wxWindow* g_MacLastWindow ; +pascal OSStatus wxMacTopLevelMouseEventHandler( EventHandlerCallRef handler , EventRef event , void *data ) ; +Rect wxMacGetBoundsForControl( wxWindow* window , const wxPoint& pos , const wxSize &size , bool adjustForOrigin = true ) ; + +template EventParamType wxMacGetEventParamType() { wxFAIL_MSG( wxT("Unknown Param Type") ) ; return 0 ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeQDRgnHandle ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeControlRef ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeWindowRef ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeMenuRef ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeEventRef ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeQDPoint ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeQDRectangle ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeBoolean ; } +#if TARGET_API_MAC_OSX +template<> inline EventParamType wxMacGetEventParamType() { return typeHICommand ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeHIPoint ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeHISize ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeHIRect ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeVoidPtr ; } +#endif +template<> inline EventParamType wxMacGetEventParamType() { return typeCollection ; } +template<> inline EventParamType wxMacGetEventParamType() { return typeCGContextRef ; } +/* +These are ambiguous +template<> EventParamType wxMacGetEventParamType() { return typeGrafPtr ; } +template<> EventParamType wxMacGetEventParamType() { return typeOSStatus ; } +template<> EventParamType wxMacGetEventParamType() { return typeCFIndex ; } +template<> EventParamType wxMacGetEventParamType() { return typeGWorldPtr ; } +*/ + +class wxMacCarbonEvent +{ + +public : + wxMacCarbonEvent( EventRef event , bool release = false ) + { + m_eventRef = event ; + m_release = release ; + } + wxMacCarbonEvent(UInt32 inClassID,UInt32 inKind,EventTime inWhen = 0 /*now*/,EventAttributes inAttributes=kEventAttributeNone) + { + m_eventRef = NULL ; + verify_noerr( MacCreateEvent( NULL , inClassID, inKind,inWhen,inAttributes,&m_eventRef) ) ; + m_release = true ; + } + ~wxMacCarbonEvent() + { + if ( m_release ) + ReleaseEvent( m_eventRef ) ; + } + + OSStatus GetParameter( EventParamName inName, EventParamType inDesiredType, UInt32 inBufferSize, void * outData) ; + + template OSStatus GetParameter( EventParamName inName, EventParamType type , T *data ) + { + return GetParameter( inName, type , sizeof( T ) , data ) ; + } + template OSStatus GetParameter( EventParamName inName, T *data ) + { + return GetParameter( inName, wxMacGetEventParamType() , data ) ; + } + + template T GetParameter( EventParamName inName ) + { + T value ; + verify_noerr( GetParameter( inName, &value ) ) ; + return value ; + } + template T GetParameter( EventParamName inName, EventParamType inDesiredType ) + { + T value ; + verify_noerr( GetParameter( inName, inDesiredType , &value ) ) ; + return value ; + } + + OSStatus SetParameter( EventParamName inName, EventParamType inType, UInt32 inSize, const void * inData) ; + template OSStatus SetParameter( EventParamName inName, EventParamType inDesiredType , const T *data ) + { + return SetParameter( inName, inDesiredType , sizeof( T ) , data ) ; + } + template OSStatus SetParameter( EventParamName inName, EventParamType inDesiredType , const T& data ) + { + return SetParameter( inName, inDesiredType , &data ) ; + } + template OSStatus SetParameter( EventParamName inName, const T *data ) + { + return SetParameter( inName, wxMacGetEventParamType() , data ) ; + } + template OSStatus SetParameter( EventParamName inName, const T& data ) + { + return SetParameter( inName, wxMacGetEventParamType() , &data ) ; + } + UInt32 GetClass() + { + return ::GetEventClass( m_eventRef ) ; + } + UInt32 GetKind() + { + return ::GetEventKind( m_eventRef ) ; + } + EventTime GetTime() + { + return ::GetEventTime( m_eventRef ) ; + } + UInt32 GetTicks() + { + return EventTimeToTicks( GetTime() ) ; + } + operator EventRef () { return m_eventRef; } +protected : + EventRef m_eventRef ; + bool m_release ; +} ; + +class wxMacControl +{ +public : + wxMacControl() + { + m_controlRef = NULL ; + } + + wxMacControl( ControlRef control ) + { + m_controlRef = control ; + } + wxMacControl( WXWidget control ) + { + m_controlRef = (ControlRef) control ; + } + virtual ~wxMacControl() + { + } + + virtual void Dispose() ; + + bool Ok() const { return GetControlRef() != NULL ; } + + virtual ControlRef * GetControlRefAddr() { return &m_controlRef; } + virtual ControlRef GetControlRef() const { return m_controlRef ; } + + virtual void SetReference( SInt32 data ) ; + /* + void operator= (ControlRef c) { m_controlRef = c ; } + operator ControlRef () { return m_controlRef; } + operator ControlRef * () { return &m_controlRef; } + */ + // accessing data and values + + virtual OSStatus SetData( ControlPartCode inPartCode , ResType inTag , Size inSize , const void * inData ) ; + virtual OSStatus GetData( ControlPartCode inPartCode , ResType inTag , Size inBufferSize , void * inOutBuffer , Size * outActualSize ) const ; + virtual OSStatus GetDataSize( ControlPartCode inPartCode , ResType inTag , Size * outActualSize ) const ; + virtual OSStatus SendEvent( EventRef ref , OptionBits inOptions = 0 ) ; + virtual OSStatus SendHICommand( HICommand &command , OptionBits inOptions = 0 ) ; + + virtual OSStatus SendHICommand( UInt32 commandID , OptionBits inOptions = 0 ) ; + + virtual SInt32 GetValue() const ; + virtual SInt32 GetMaximum() const ; + virtual SInt32 GetMinimum() const ; + + virtual void SetValue( SInt32 v ) ; + virtual void SetMinimum( SInt32 v ) ; + virtual void SetMaximum( SInt32 v ) ; + + virtual void SetValueAndRange( SInt32 value , SInt32 minimum , SInt32 maximum ) ; + virtual void SetRange( SInt32 minimum , SInt32 maximum ) ; + + virtual OSStatus SetFocus( ControlFocusPart focusPart ) ; + virtual bool HasFocus() const ; + virtual bool NeedsFocusRect() const ; + + // templated helpers + + Size GetDataSize( ControlPartCode inPartCode , ResType inTag ) const + { + Size sz ; + verify_noerr( GetDataSize( inPartCode , inTag , &sz ) ) ; + return sz ; + } + template OSStatus SetData( ControlPartCode inPartCode , ResType inTag , const T *data ) + { + return SetData( inPartCode , inTag , sizeof( T ) , data ) ; + } + template OSStatus SetData( ControlPartCode inPartCode , ResType inTag , const T& data ) + { + return SetData( inPartCode , inTag , sizeof( T ) , &data ) ; + } + template OSStatus GetData( ControlPartCode inPartCode , ResType inTag , T *data ) const + { + Size dummy ; + return GetData( inPartCode , inTag , sizeof( T ) , data , &dummy ) ; + } + template T GetData( ControlPartCode inPartCode , ResType inTag ) const + { + T value ; + verify_noerr( GetData( inPartCode , inTag , &value ) ) ; + return value ; + } + + // Flash the control for the specified amount of time + virtual void Flash( ControlPartCode part , UInt32 ticks = 8 ) ; + virtual void VisibilityChanged( bool shown ) ; + virtual void SetFont( const wxFont & font , const wxColour& foreground , long windowStyle ) ; + virtual void SetBackground( const wxBrush &brush ) ; + virtual ControlPartCode HandleKey( SInt16 keyCode, SInt16 charCode, EventModifiers modifiers ) ; + void SetActionProc( ControlActionUPP actionProc ) ; + void SetViewSize( SInt32 viewSize ) ; + SInt32 GetViewSize() const ; + + virtual bool IsVisible() const ; + virtual void SetVisibility( bool visible , bool redraw ) ; + virtual bool IsEnabled() const ; + virtual bool IsActive() const ; + virtual void Enable( bool enable ) ; + + // invalidates this control and all children + virtual void InvalidateWithChildren() ; + virtual void SetDrawingEnabled( bool enable ) ; + virtual bool GetNeedsDisplay() const ; + virtual void SetNeedsDisplay( bool needsDisplay , RgnHandle where = NULL ) ; + + virtual void ScrollRect( const wxRect &rect , int dx , int dy ) ; + + virtual void GetRect( Rect *r ) ; + virtual void SetRect( Rect *r ) ; + virtual void GetRectInWindowCoords( Rect *r ) ; + virtual void GetBestRect( Rect *r ) ; + virtual void SetTitle( const wxString &title ) ; + // converts from Toplevel-Content relative to local + static void Convert( wxPoint *pt , wxMacControl *convert , wxMacControl *to ) ; + + virtual void GetFeatures( UInt32 *features ) ; + virtual OSStatus GetRegion( ControlPartCode partCode , RgnHandle region ) ; + virtual OSStatus SetZOrder( bool above , wxMacControl* other ) ; + // to be moved into a databrowser subclass + + virtual OSStatus SetSelectionFlags( DataBrowserSelectionFlags ) ; + virtual OSStatus AddListViewColumn( DataBrowserListViewColumnDesc *columnDesc, + DataBrowserTableViewColumnIndex position ) ; + virtual OSStatus AutoSizeListViewColumns() ; + virtual OSStatus SetHasScrollBars( bool horiz , bool vert ) ; + virtual OSStatus SetTableViewHiliteStyle( DataBrowserTableViewHiliteStyle hiliteStyle ) ; + virtual OSStatus SetListViewHeaderBtnHeight(UInt16 height) ; + virtual OSStatus SetCallbacks(const DataBrowserCallbacks * callbacks) ; + virtual OSStatus UpdateItems( DataBrowserItemID container, UInt32 numItems, + const DataBrowserItemID* items, + DataBrowserPropertyID preSortProperty, + DataBrowserPropertyID propertyID ) ; + virtual OSStatus AddItems( DataBrowserItemID container, UInt32 numItems, + const DataBrowserItemID* items, + DataBrowserPropertyID preSortProperty ) ; + virtual OSStatus RemoveItems( DataBrowserItemID container, UInt32 numItems, + const DataBrowserItemID* items, + DataBrowserPropertyID preSortProperty ) ; + virtual OSStatus RevealItem( DataBrowserItemID item, + DataBrowserPropertyID propertyID, + DataBrowserRevealOptions options ) ; + virtual bool IsItemSelected( DataBrowserItemID item ) ; + virtual OSStatus SetSelectedItems(UInt32 numItems, + const DataBrowserItemID * items, + DataBrowserSetOption operation ) ; + + // to be moved into a tab control class + + virtual OSStatus SetTabEnabled( SInt16 tabNo , bool enable ) ; +protected : + ControlRef m_controlRef ; + wxFont m_font ; + long m_windowStyle ; +} ; + #endif // wxUSE_GUI //--------------------------------------------------------------------------- @@ -228,11 +546,21 @@ private: #endif - +// utils.cpp wxUint32 wxMacGetSystemEncFromFontEnc(wxFontEncoding encoding) ; wxFontEncoding wxMacGetFontEncFromSystemEnc(wxUint32 encoding) ; +void wxMacWakeUp() ; + +// toplevel.cpp + +ControlRef wxMacFindControlUnderMouse( Point location , WindowRef window , ControlPartCode *outPart ) ; + +// filefn.cpp +wxString wxMacFSRefToPath( const FSRef *fsRef , CFStringRef additionalPathComponent = NULL ) ; +OSStatus wxMacPathToFSRef( const wxString&path , FSRef *fsRef ) ; +wxString wxMacHFSUniStrToString( ConstHFSUniStr255Param uniname ) ; #endif // _WX_PRIVATE_H_