#include "wx/osx/core/cfstring.h"
#include "wx/osx/core/cfdataref.h"
+// Define helper macros allowing to insert small snippets of code to be
+// compiled for high enough OS X version only: this shouldn't be abused for
+// anything big but it's handy for e.g. specifying OS X 10.6-only protocols in
+// the Objective C classes declarations when they're not supported under the
+// previous versions
+#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_6
+ #define wxOSX_10_6_AND_LATER(x) x
+#else
+ #define wxOSX_10_6_AND_LATER(x)
+#endif
+
#if wxOSX_USE_COCOA_OR_CARBON
WXDLLIMPEXP_BASE long UMAGetSystemVersion() ;
virtual WXWidget GetWXWidget() const = 0;
virtual void SetBackgroundColour( const wxColour& col ) = 0;
+ virtual bool SetBackgroundStyle(wxBackgroundStyle style) = 0;
// all coordinates in native parent widget relative coordinates
virtual void GetContentArea( int &left , int &top , int &width , int &height ) const = 0;
virtual void SetScrollThumb( wxInt32 value, wxInt32 thumbSize ) = 0;
virtual void SetFont( const wxFont & font , const wxColour& foreground , long windowStyle, bool ignoreBlack = true ) = 0;
+
+ virtual void SetToolTip(wxToolTip* WXUNUSED(tooltip)) { }
// is the clicked event sent AFTER the state already changed, so no additional
// state changing logic is required from the outside
virtual bool ButtonClickDidStateChange() = 0;
virtual void InstallEventHandler( WXWidget control = NULL ) = 0;
+
+ // Mechanism used to keep track of whether a change should send an event
+ // Do SendEvents(false) when starting actions that would trigger programmatic events
+ // and SendEvents(true) at the end of the block.
+ virtual void SendEvents(bool shouldSendEvents) { m_shouldSendEvents = shouldSendEvents; }
+ virtual bool ShouldSendEvents() { return m_shouldSendEvents; }
// static methods for associating native controls and their implementations
long style,
long extraStyle);
+#if wxOSX_USE_COCOA
+ static wxWidgetImplType* CreateComboBox( wxWindowMac* wxpeer,
+ wxWindowMac* parent,
+ wxWindowID id,
+ wxMenu* menu,
+ const wxPoint& pos,
+ const wxSize& size,
+ long style,
+ long extraStyle);
+#endif
+
// converts from Toplevel-Content relative to local
static void Convert( wxPoint *pt , wxWidgetImpl *from , wxWidgetImpl *to );
protected :
wxWindowMac* m_wxPeer;
bool m_needsFocusRect;
bool m_needsFrame;
+ bool m_shouldSendEvents;
DECLARE_ABSTRACT_CLASS(wxWidgetImpl)
};
virtual void GetSelection( long* from, long* to ) const = 0 ;
virtual void WriteText( const wxString& str ) = 0 ;
+ virtual bool GetStyle( long position, wxTextAttr& style);
virtual void SetStyle( long start, long end, const wxTextAttr& style ) ;
virtual void Copy() ;
virtual void Cut() ;
virtual int GetLineLength(long lineNo) const ;
virtual wxString GetLineText(long lineNo) const ;
virtual void CheckSpelling(bool WXUNUSED(check)) { }
+
+ virtual wxSize GetBestSize() const { return wxDefaultSize; }
+};
+
+// common interface for all implementations
+class WXDLLIMPEXP_CORE wxComboWidgetImpl
+
+{
+public :
+ wxComboWidgetImpl() {}
+
+ virtual ~wxComboWidgetImpl() {}
+
+ virtual int GetSelectedItem() const { return -1; };
+ virtual void SetSelectedItem(int WXUNUSED(item)) {};
+
+ virtual int GetNumberOfItems() const { return -1; };
+
+ virtual void InsertItem(int WXUNUSED(pos), const wxString& WXUNUSED(item)) {}
+
+ virtual void RemoveItem(int WXUNUSED(pos)) {}
+
+ virtual void Clear() {}
+
+ virtual wxString GetStringAtIndex(int WXUNUSED(pos)) const { return wxEmptyString; }
+
+ virtual int FindString(const wxString& WXUNUSED(text)) const { return -1; }
};
//
{
}
- virtual void Destroy()
+ virtual void WillBeDestroyed()
{
}
virtual void SetExtraStyle( long WXUNUSED(exStyle) )
{
}
-
+
+ virtual void SetWindowStyleFlag( long WXUNUSED(style) )
+ {
+ }
+
virtual bool SetBackgroundStyle(wxBackgroundStyle WXUNUSED(style))
{
return false ;
wxNonOwnedWindow* GetWXPeer() { return m_wxPeer; }
+ static wxNonOwnedWindowImpl*
+ FindFromWXWindow(WXWindow window);
+
+ static void RemoveAssociations( wxNonOwnedWindowImpl* impl);
+
+ static void Associate( WXWindow window, wxNonOwnedWindowImpl *impl );
+
// static creation methods, must be implemented by all toolkits
+ static wxNonOwnedWindowImpl* CreateNonOwnedWindow( wxNonOwnedWindow* wxpeer, wxWindow* parent, WXWindow native) ;
+
static wxNonOwnedWindowImpl* CreateNonOwnedWindow( wxNonOwnedWindow* wxpeer, wxWindow* parent, const wxPoint& pos, const wxSize& size,
long style, long extraStyle, const wxString& name ) ;
+
+ virtual void SetModified(bool WXUNUSED(modified)) { }
+ virtual bool IsModified() const { return false; }
protected :
wxNonOwnedWindow* m_wxPeer;