]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/mac/combobox.h
submenu preparation in two methods encapsulated
[wxWidgets.git] / include / wx / mac / combobox.h
index 6fda37448e5c5a472171bc40a4d3e907f5b714b9..c4f07f114bd2ef104d9ad222309b9f182e082af0 100644 (file)
@@ -1,21 +1,22 @@
 /////////////////////////////////////////////////////////////////////////////
 // Name:        combobox.h
 // Purpose:     wxComboBox class
 /////////////////////////////////////////////////////////////////////////////
 // Name:        combobox.h
 // Purpose:     wxComboBox class
-// Author:      AUTHOR
+// Author:      Stefan Csomor
 // Modified by:
 // Modified by:
-// Created:     ??/??/98
+// Created:     1998-01-01
 // RCS-ID:      $Id$
 // RCS-ID:      $Id$
-// Copyright:   (c) AUTHOR
-// Licence:    wxWindows licence
+// Copyright:   (c) Stefan Csomor
+// Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
 #ifndef _WX_COMBOBOX_H_
 #define _WX_COMBOBOX_H_
 
 /////////////////////////////////////////////////////////////////////////////
 
 #ifndef _WX_COMBOBOX_H_
 #define _WX_COMBOBOX_H_
 
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(__APPLE__)
 #pragma interface "combobox.h"
 #endif
 
 #pragma interface "combobox.h"
 #endif
 
+#include "wx/textctrl.h"
 #include "wx/choice.h"
 
 WXDLLEXPORT_DATA(extern const char*) wxComboBoxNameStr;
 #include "wx/choice.h"
 
 WXDLLEXPORT_DATA(extern const char*) wxComboBoxNameStr;
@@ -28,6 +29,19 @@ class WXDLLEXPORT wxComboBox: public wxChoice
 
  public:
   inline wxComboBox() {}
 
  public:
   inline wxComboBox() {}
+    virtual ~wxComboBox();
+    // override the base class virtuals involved in geometry calculations
+    virtual wxSize DoGetBestSize() const;
+    virtual void DoMoveWindow(int x, int y, int width, int height);
+
+    // forward these functions to all subcontrols
+    virtual bool Enable(bool enable = TRUE);
+    virtual bool Show(bool show = TRUE);
+    virtual void SetFocus();
+
+    // callback functions
+    virtual void DelegateTextChanged( const wxString& value );
+    virtual void DelegateChoice( const wxString& value );
 
   inline wxComboBox(wxWindow *parent, wxWindowID id,
            const wxString& value = wxEmptyString,
 
   inline wxComboBox(wxWindow *parent, wxWindowID id,
            const wxString& value = wxEmptyString,
@@ -60,7 +74,6 @@ class WXDLLEXPORT wxComboBox: public wxChoice
   virtual wxString GetString(int n) const ;
   virtual wxString GetStringSelection() const ;
   virtual bool SetStringSelection(const wxString& sel);
   virtual wxString GetString(int n) const ;
   virtual wxString GetStringSelection() const ;
   virtual bool SetStringSelection(const wxString& sel);
-  virtual inline int Number() const { return m_noStrings; }
   
   // Text field functions
   virtual wxString GetValue() const ;
   
   // Text field functions
   virtual wxString GetValue() const ;
@@ -78,10 +91,12 @@ class WXDLLEXPORT wxComboBox: public wxChoice
   virtual void Remove(long from, long to);
   virtual void SetSelection(long from, long to);
   virtual void SetEditable(bool editable);
   virtual void Remove(long from, long to);
   virtual void SetSelection(long from, long to);
   virtual void SetEditable(bool editable);
-       void            MacHandleControlClick( ControlHandle control , SInt16 controlpart ) ;
+  virtual int GetCount() const { return m_choice->GetCount() ; }
+  void MacHandleControlClick( WXWidget control , wxInt16 controlpart ) ;
 protected:
 protected:
-  int m_noStrings;
-  MenuHandle   m_macPopUpMenuHandle ;
+    // the subcontrols
+    wxTextCtrl*     m_text;
+    wxChoice*       m_choice;
 };
 
 #endif
 };
 
 #endif