]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/src/windows.i
Added the PseudoDC class from Paul Lanier. It provides a way to
[wxWidgets.git] / wxPython / src / windows.i
index c245360dc643c7525199a7b7bbbdf2d43e8ea221..dc94478a1157c602e6ec08dfe3f4b3ecd078ef04 100644 (file)
 //
 // Author:      Robin Dunn
 //
-// Created:     6/24/97
+// Created:     24-June-1997
 // RCS-ID:      $Id$
-// Copyright:   (c) 1998 by Total Control Software
+// Copyright:   (c) 2003 by Total Control Software
 // Licence:     wxWindows license
 /////////////////////////////////////////////////////////////////////////////
 
-
-%module windows
-
-%{
-#include "helpers.h"
-#include <wx/menuitem.h>
-#include <wx/tooltip.h>
-%}
-
-//----------------------------------------------------------------------
-
-%include typemaps.i
-%include my_typemaps.i
-
-// Import some definitions of other classes, etc.
-%import _defs.i
-%import misc.i
-%import gdi.i
-%import clip_dnd.i
-
-%pragma(python) code = "import wx"
-
+%module(package="wx") _windows
 
 //---------------------------------------------------------------------------
 
-class wxEvtHandler : public wxObject {
-public:
-    wxEvtHandler();
-
-    bool ProcessEvent(wxEvent& event);
-    void AddPendingEvent(wxEvent& event);
-    //bool SearchEventTable(wxEventTable& table, wxEvent& event);
-
-    bool GetEvtHandlerEnabled();
-    void SetEvtHandlerEnabled(bool enabled);
-
-    wxEvtHandler* GetNextHandler();
-    wxEvtHandler* GetPreviousHandler();
-    void SetNextHandler(wxEvtHandler* handler);
-    void SetPreviousHandler(wxEvtHandler* handler);
-
-
-    %addmethods {
-        void Connect( int id, int lastId, int eventType, PyObject* func) {
-            if (PyCallable_Check(func)) {
-                self->Connect(id, lastId, eventType,
-                          (wxObjectEventFunction) &wxPyCallback::EventThunker,
-                          new wxPyCallback(func));
-            }
-            else if (func == Py_None) {
-                self->Disconnect(id, lastId, eventType,
-                                 (wxObjectEventFunction)
-                                 &wxPyCallback::EventThunker);
-            }
-            else {
-                PyErr_SetString(PyExc_TypeError, "Expected callable object or None.");
-            }
-        }
-
-        bool Disconnect(int id, int lastId = -1,
-                        wxEventType eventType = wxEVT_NULL) {
-            return self->Disconnect(id, lastId, eventType,
-                                   (wxObjectEventFunction)
-                                    &wxPyCallback::EventThunker);
-        }
-    }
-
-    %addmethods {
-        void _setOORInfo(PyObject* _self) {
-            self->SetClientObject(new wxPyClientData(_self));
-        }
-    }
-};
-
-
-//----------------------------------------------------------------------
-
-class wxValidator : public wxEvtHandler {
-public:
-    wxValidator();
-    //~wxValidator();
-
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-
-    wxValidator* Clone();
-    wxWindow* GetWindow();
-    void SetWindow(wxWindow* window);
-
-    static bool IsSilent();
-    static void SetBellOnError(int doIt = TRUE);
-
-};
-
-
-//----------------------------------------------------------------------
 %{
-class wxPyValidator : public wxValidator {
-    DECLARE_DYNAMIC_CLASS(wxPyValidator);
-public:
-    wxPyValidator() {
-    }
-
-    ~wxPyValidator() {
-    }
-
-    wxObject* Clone() const {
-        wxPyValidator* ptr = NULL;
-        wxPyValidator* self = (wxPyValidator*)this;
-
-        wxPyBeginBlockThreads();
-        if (self->m_myInst.findCallback("Clone")) {
-            PyObject* ro;
-            ro = self->m_myInst.callCallbackObj(Py_BuildValue("()"));
-            if (ro) {
-                SWIG_GetPtrObj(ro, (void **)&ptr, "_wxPyValidator_p");
-                Py_DECREF(ro);
-            }
-        }
-        wxPyEndBlockThreads();
-
-        // This is very dangerous!!! But is the only way I could find
-        // to squash a memory leak.  Currently it is okay, but if the
-        // validator architecture in wxWindows ever changes, problems
-        // could arise.
-        delete self;
-        return ptr;
-    }
-
-
-    DEC_PYCALLBACK_BOOL_WXWIN(Validate);
-    DEC_PYCALLBACK_BOOL_(TransferToWindow);
-    DEC_PYCALLBACK_BOOL_(TransferFromWindow);
-
-    PYPRIVATE;
-};
-
-IMP_PYCALLBACK_BOOL_WXWIN(wxPyValidator, wxValidator, Validate);
-IMP_PYCALLBACK_BOOL_(wxPyValidator, wxValidator, TransferToWindow);
-IMP_PYCALLBACK_BOOL_(wxPyValidator, wxValidator, TransferFromWindow);
-
-IMPLEMENT_DYNAMIC_CLASS(wxPyValidator, wxValidator);
-
+#include "wx/wxPython/wxPython.h"
+#include "wx/wxPython/pyclasses.h"
+    
 %}
 
-class wxPyValidator : public wxValidator {
-public:
-    wxPyValidator();
-
-    void _setCallbackInfo(PyObject* self, PyObject* _class, int incref=TRUE);
-    %pragma(python) addtomethod = "__init__:self._setCallbackInfo(self, wxPyValidator, 1)"
-
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-};
-
-//----------------------------------------------------------------------
-
-%apply int * INOUT { int* x, int* y };
-
-class wxWindow : public wxEvtHandler {
-public:
-    wxWindow(wxWindow* parent, const wxWindowID id,
-             const wxPoint& pos = wxDefaultPosition,
-             const wxSize& size = wxDefaultSize,
-             long style = 0,
-             char* name = "panel");
-    %name(wxPreWindow)wxWindow();
-
-    bool Create(wxWindow* parent, const wxWindowID id,
-                const wxPoint& pos = wxDefaultPosition,
-                const wxSize& size = wxDefaultSize,
-                long style = 0,
-                char* name = "panel");
-
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-    %pragma(python) addtomethod = "wxPreWindow:val._setOORInfo(val)"
-
-
-    void CaptureMouse();
-    void Center(int direction = wxBOTH);
-    void Centre(int direction = wxBOTH);
-    void CentreOnParent(int direction = wxBOTH );
-    void CenterOnParent(int direction = wxBOTH );
-    void CentreOnScreen(int direction = wxBOTH );
-    void CenterOnScreen(int direction = wxBOTH );
-
-    void Clear();
-
-    // (uses apply'ed INOUT typemap, see above)
-    %name(ClientToScreenXY)void ClientToScreen(int* x, int* y);
-    wxPoint ClientToScreen(const wxPoint& pt);
-
-    bool Close(int force = FALSE);
-    bool Destroy();
-    void DestroyChildren();
-    bool IsBeingDeleted();
-#ifdef __WXMSW__
-    void DragAcceptFiles(bool accept);
-#endif
-    void Enable(bool enable);
-    //bool FakePopupMenu(wxMenu* menu, int x, int y);
-    %name(FindWindowById) wxWindow* FindWindow(long id);
-    %name(FindWindowByName) wxWindow* FindWindow(const wxString& name);
-    void Fit();
-    wxColour GetBackgroundColour();
-    wxBorder GetBorder() const;
-
-    //wxList& GetChildren();
-    %addmethods {
-        PyObject* GetChildren() {
-            wxWindowList& list = self->GetChildren();
-            return wxPy_ConvertList(&list, "wxWindow");
-        }
-    }
-
-    int  GetCharHeight();
-    int  GetCharWidth();
-    %name(GetClientSizeTuple) void GetClientSize(int *OUTPUT, int *OUTPUT);
-    wxSize GetClientSize();
-
-    // get the origin of the client area of the window relative to the
-    // window top left corner (the client area may be shifted because of
-    // the borders, scrollbars, other decorations...)
-    wxPoint GetClientAreaOrigin() const;
-
-    // get the client rectangle in window (i.e. client) coordinates
-    wxRect GetClientRect() const;
-
-    wxLayoutConstraints * GetConstraints();
-    wxEvtHandler* GetEventHandler();
-
-    wxFont GetFont();
-    wxColour GetForegroundColour();
-    wxWindow * GetGrandParent();
-    %addmethods {
-        long GetHandle() {
-            return wxPyGetWinHandle(self); //(long)self->GetHandle();
-        }
-    }
-    int GetId();
-    wxString GetLabel();
-    void SetLabel(const wxString& label);
-    wxString GetName();
-    wxWindow * GetParent();
-    %name(GetPositionTuple) void GetPosition(int *OUTPUT, int *OUTPUT);
-    wxPoint GetPosition();
-    wxRect GetRect();
-    int GetScrollThumb(int orientation);
-    int GetScrollPos(int orientation);
-    int GetScrollRange(int orientation);
-    %name(GetSizeTuple) void GetSize(int *OUTPUT, int *OUTPUT);
-    wxSize GetSize();
-    void GetTextExtent(const wxString& string, int *OUTPUT, int *OUTPUT);
-    %name(GetFullTextExtent)void GetTextExtent(const wxString& string,
-                       int *OUTPUT, int *OUTPUT, int *OUTPUT, int* OUTPUT,
-                       const wxFont* font = NULL); //, bool use16 = FALSE)
-    wxString GetTitle();
-    wxRegion GetUpdateRegion();
-    long GetWindowStyleFlag();
-    void SetWindowStyleFlag(long style);
-    void SetWindowStyle(long style);
-    bool HasScrollbar(int orient) const;
-    bool Hide();
-    wxHitTest HitTest(const wxPoint& pt);
-    void InitDialog();
-    bool IsEnabled();
-    bool IsExposed( int x, int y, int w=0, int h=0 );
-    %name(IsExposedPoint) bool IsExposed( const wxPoint& pt );
-    %name(IsExposedRect)  bool IsExposed( const wxRect& rect );
-    bool IsRetained();
-    bool IsShown();
-    bool IsTopLevel();
-    void Layout();
-    bool LoadFromResource(wxWindow* parent, const wxString& resourceName, const wxResourceTable* resourceTable = NULL);
-    void Lower();
-    void MakeModal(bool flag=TRUE);
-    %name(MoveXY)void Move(int x, int y, int flags = wxSIZE_USE_EXISTING);
-    void Move(const wxPoint& point, int flags = wxSIZE_USE_EXISTING);
-
-    wxEvtHandler* PopEventHandler(bool deleteHandler = FALSE);
-    void PushEventHandler(wxEvtHandler* handler);
-
-        // find the given handler in the event handler chain and remove (but
-        // not delete) it from the event handler chain, return TRUE if it was
-        // found and FALSE otherwise (this also results in an assert failure so
-        // this function should only be called when the handler is supposed to
-        // be there)
-    bool RemoveEventHandler(wxEvtHandler *handler);
-
-    %name(PopupMenuXY)bool PopupMenu(wxMenu *menu, int x, int y);
-    bool PopupMenu(wxMenu *menu, const wxPoint& pos);
-
-    void Raise();
-    void Refresh(bool eraseBackground = TRUE, const wxRect* rect = NULL);
-    void RefreshRect(const wxRect& rect);
-
-    void ReleaseMouse();
-    void RemoveChild(wxWindow* child);
-    bool Reparent( wxWindow* newParent );
-
-    // (uses apply'ed INOUT typemap, see above)
-    %name(ScreenToClientXY)void ScreenToClient(int *x, int *y);
-    wxPoint ScreenToClient(const wxPoint& pt);
-
-    void ScrollWindow(int dx, int dy, const wxRect* rect = NULL);
-    void SetAutoLayout(bool autoLayout);
-    bool GetAutoLayout();
-    void SetBackgroundColour(const wxColour& colour);
-    void SetConstraints(wxLayoutConstraints *constraints);
-    void UnsetConstraints(wxLayoutConstraints *constraints);
-    void SetFocus();
-    bool AcceptsFocus();
-    void SetFont(const wxFont& font);
-    void SetForegroundColour(const wxColour& colour);
-    void SetId(int id);
-    void SetName(const wxString& name);
-    void SetScrollbar(int orientation, int position, int thumbSize, int range, int refresh = TRUE);
-    void SetScrollPos(int orientation, int pos, bool refresh = TRUE);
-
-    %name(SetDimensions) void SetSize(int x, int y, int width, int height, int sizeFlags=wxSIZE_AUTO);
-    %addmethods {
-        void SetSize(const wxSize& size) {
-            self->SetSize(size);
-        }
-
-        void SetPosition(const wxPoint& pos, int flags = wxSIZE_USE_EXISTING) {
-            self->Move(pos, flags);
-        }
-
-        void SetRect(const wxRect& rect, int sizeFlags=wxSIZE_AUTO) {
-            self->SetSize(rect, sizeFlags);
-        }
-    }
-
-    void SetSizeHints(int minW=-1, int minH=-1, int maxW=-1, int maxH=-1, int incW=-1, int incH=-1);
-    %name(SetClientSizeWH)void SetClientSize(int width, int height);
-    void SetClientSize(const wxSize& size);
-    //void SetPalette(wxPalette* palette);
-    void SetCursor(const wxCursor& cursor);
-    void SetEventHandler(wxEvtHandler* handler);
-    void SetExtraStyle(long exStyle);
-    void SetTitle(const wxString& title);
-    bool Show(bool show=TRUE);
-    bool TransferDataFromWindow();
-    bool TransferDataToWindow();
-    void UpdateWindowUI();
-    bool Validate();
-    void WarpPointer(int x, int y);
-
-    %name(ConvertDialogPointToPixels) wxPoint ConvertDialogToPixels(const wxPoint& pt);
-    %name(ConvertDialogSizeToPixels)  wxSize  ConvertDialogToPixels(const wxSize& sz);
-
-    %name(DLG_PNT) wxPoint ConvertDialogToPixels(const wxPoint& pt);
-    %name(DLG_SZE) wxSize  ConvertDialogToPixels(const wxSize& sz);
-
-    %name(ConvertPixelPointToDialog) wxPoint ConvertPixelsToDialog(const wxPoint& pt);
-    %name(ConvertPixelSizeToDialog)  wxSize  ConvertPixelsToDialog(const wxSize& sz);
-
-    %name(SetToolTipString)void SetToolTip(const wxString &tip);
-    void SetToolTip(wxToolTip *tooltip);
-    wxToolTip* GetToolTip();
-
-    void SetSizer(wxSizer* sizer, bool deleteOld=TRUE);
-    wxSizer* GetSizer();
-
-        // Track if this window is a member of a sizer
-    void SetContainingSizer(wxSizer* sizer);
-    wxSizer *GetContainingSizer() const;
-
-    wxValidator* GetValidator();
-    void SetValidator(const wxValidator& validator);
-
-#ifndef __WXMAC__
-    void SetDropTarget(wxDropTarget* target);
-    wxDropTarget* GetDropTarget();
-    %pragma(python) addtomethod = "SetDropTarget:_args[0].thisown = 0"
-#endif
-
-    wxSize GetBestSize();
-    wxSize GetMaxSize();
-
-    void SetCaret(wxCaret *caret);
-    wxCaret *GetCaret();
-    %pragma(python) addtoclass = "# replaces broken shadow method
-    def GetCaret(self, *_args, **_kwargs):
-        from misc2 import wxCaretPtr
-        val = apply(windowsc.wxWindow_GetCaret,(self,) + _args, _kwargs)
-        if val: val = wxCaretPtr(val)
-        return val
-    "
-
-    void Freeze();
-    void Thaw();
-    void Update();
-
-    wxString GetHelpText();
-    void SetHelpText(const wxString& helpText);
-    void SetHelpTextForId(const wxString& text);
-
-    bool ScrollLines(int lines);
-    bool ScrollPages(int pages);
-    bool LineUp();
-    bool LineDown();
-    bool PageUp();
-    bool PageDown();
-
-    static wxWindow* FindFocus();
-    static int NewControlId();
-    static int NextControlId(int id);
-    static int PrevControlId(int id);
-
-    void SetAcceleratorTable(const wxAcceleratorTable& accel);
-    wxAcceleratorTable *GetAcceleratorTable();
-
-#ifdef __WXMSW__
-    // A way to do the native draw first...  Too bad it isn't in wxGTK too.
-    void OnPaint(wxPaintEvent& event);
-#endif
-
-    wxWindow* GetDefaultItem();
-    wxWindow* SetDefaultItem(wxWindow *btn);
-};
-
-
-
-
-%pragma(python) code = "
-def wxDLG_PNT(win, point_or_x, y=None):
-    if y is None:
-        return win.ConvertDialogPointToPixels(point_or_x)
-    else:
-        return win.ConvertDialogPointToPixels(wxPoint(point_or_x, y))
-
-def wxDLG_SZE(win, size_width, height=None):
-    if height is None:
-        return win.ConvertDialogSizeToPixels(size_width)
-    else:
-        return win.ConvertDialogSizeToPixels(wxSize(size_width, height))
-"
-
-
-#ifdef __WXMSW__
-%inline %{
-wxWindow* wxWindow_FromHWND(unsigned long hWnd) {
-    wxWindow* win = new wxWindow;
-    win->SetHWND(hWnd);
-    win->SubclassWin(hWnd);
-    return win;
-}
-%}
-#endif
-
-
 //---------------------------------------------------------------------------
 
-class wxPanel : public wxWindow {
-public:
-    wxPanel(wxWindow* parent,
-            const wxWindowID id,
-            const wxPoint& pos = wxDefaultPosition,
-            const wxSize& size = wxDefaultSize,
-            long style = wxTAB_TRAVERSAL,
-            const char* name = "panel");
-    %name(wxPrePanel)wxPanel();
+%import core.i
+%pythoncode { wx = _core }
 
-    bool Create(wxWindow* parent,
-                const wxWindowID id,
-                const wxPoint& pos = wxDefaultPosition,
-                const wxSize& size = wxDefaultSize,
-                long style = wxTAB_TRAVERSAL,
-                const char* name = "panel");
 
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-    %pragma(python) addtomethod = "wxPrePanel:val._setOORInfo(val)"
+MAKE_CONST_WXSTRING_NOSWIG(EmptyString);
+MAKE_CONST_WXSTRING_NOSWIG(PanelNameStr);
 
-    void InitDialog();
 
-};
+// Include all the files that make up this module
+%include _panel.i
+%include _toplvl.i
+%include _statusbar.i
+%include _splitter.i
+%include _sashwin.i
+%include _popupwin.i
+%include _tipwin.i
+%include _vscroll.i
+%include _taskbar.i
+%include _cmndlgs.i
+%include _mdi.i
+%include _pywindows.i
+%include _printfw.i
 
 //---------------------------------------------------------------------------
-
-
-// TODO: Add wrappers for the wxScrollHelper class, make wxScrolledWindow
-//       derive from it and wxPanel.
-
-
-class wxScrolledWindow : public wxPanel {
-public:
-    wxScrolledWindow(wxWindow* parent,
-                     const wxWindowID id = -1,
-                     const wxPoint& pos = wxDefaultPosition,
-                     const wxSize& size = wxDefaultSize,
-                     long style = wxHSCROLL | wxVSCROLL,
-                     char* name = "scrolledWindow");
-    %name(wxPreScrolledWindow)wxScrolledWindow();
-
-    bool Create(wxWindow* parent,
-                const wxWindowID id = -1,
-                const wxPoint& pos = wxDefaultPosition,
-                const wxSize& size = wxDefaultSize,
-                long style = wxHSCROLL | wxVSCROLL,
-                char* name = "scrolledWindow");
-
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-    %pragma(python) addtomethod = "wxPreScrolledWindow:val._setOORInfo(val)"
-
-    void EnableScrolling(bool xScrolling, bool yScrolling);
-    int GetScrollPageSize(int orient);
-    void GetScrollPixelsPerUnit(int* OUTPUT, int* OUTPUT);
-    wxWindow* GetTargetWindow();
-    void GetVirtualSize(int* OUTPUT, int* OUTPUT);
-    bool IsRetained();
-    void PrepareDC(wxDC& dc);
-    void Scroll(int x, int y);
-    void SetScrollbars(int pixelsPerUnitX, int pixelsPerUnitY,
-                       int noUnitsX, int noUnitsY,
-                       int xPos = 0, int yPos = 0, int noRefresh=FALSE);
-    void SetScrollPageSize(int orient, int pageSize);
-    void SetTargetWindow(wxWindow* window);
-    void GetViewStart(int* OUTPUT, int* OUTPUT);
-    %pragma(python) addtoclass = "ViewStart = GetViewStart"
-
-    %name(CalcScrolledPosition1)wxPoint CalcScrolledPosition(const wxPoint& pt);
-    %name(CalcScrolledPosition2)void CalcScrolledPosition( int x, int y, int *OUTPUT, int *OUTPUT);
-
-    %name(CalcUnscrolledPosition1)wxPoint CalcUnscrolledPosition(const wxPoint& pt);
-    %name(CalcUnscrolledPosition2)void CalcUnscrolledPosition( int x, int y, int *OUTPUT, int *OUTPUT);
-
-    %pragma(python) addtoclass = "
-    def CalcScrolledPosition(self, *args):
-        if len(args) == 1:
-            return apply(self.CalcScrolledPosition1, args)
-        elif len(args) == 2:
-            return apply(self.CalcScrolledPosition2, args)
-        else:
-            raise TypeError, 'Invalid parameters: only (x,y) or (point) allowed'
-
-    def CalcUnscrolledPosition(self, *args):
-        if len(args) == 1:
-            return apply(self.CalcUnscrolledPosition1, args)
-        elif len(args) == 2:
-            return apply(self.CalcUnscrolledPosition2, args)
-        else:
-            raise TypeError, 'Invalid parameters: only (x,y) or (point) allowed'
-"
-
-    void SetScale(double xs, double ys);
-    double GetScaleX();
-    double GetScaleY();
-
-    void AdjustScrollbars();
-
-    bool Layout();
-};
-
-//----------------------------------------------------------------------
-
-
-class wxMenu : public wxEvtHandler {
-public:
-    wxMenu(const wxString& title = wxEmptyString, long style = 0);
-
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-
-    void Append(int id, const wxString& item,
-                const wxString& helpString = wxEmptyString,
-                wxItemKind kind = wxItem_Normal);
-    %name(AppendMenu)void Append(int id, const wxString& item, wxMenu *subMenu,
-                                 const wxString& helpString = wxEmptyString);
-    %name(AppendItem)void Append(const wxMenuItem* item);
-    void AppendCheckItem(int id,
-                         const wxString& text,
-                         const wxString& help = wxEmptyString);
-    void AppendRadioItem(int id,
-                         const wxString& text,
-                         const wxString& help = wxEmptyString);
-    void AppendSeparator();
-
-
-    void Insert(size_t pos,
-                int id,
-                const wxString& text,
-                const wxString& help = wxEmptyString,
-                wxItemKind kind = wxItem_Normal);
-    void InsertSeparator(size_t pos);
-    void InsertCheckItem(size_t pos,
-                         int id,
-                         const wxString& text,
-                         const wxString& help = wxEmptyString);
-    void InsertRadioItem(size_t pos,
-                         int id,
-                         const wxString& text,
-                         const wxString& help = wxEmptyString);
-    %name(InsertMenu)void Insert(size_t pos,
-                                 int id,
-                                 const wxString& text,
-                                 wxMenu *submenu,
-                                 const wxString& help = wxEmptyString);
-    %name(InsertItem)bool Insert(size_t pos, wxMenuItem *item);
-
-
-    void Prepend(int id,
-                 const wxString& text,
-                 const wxString& help = wxEmptyString,
-                 wxItemKind kind = wxItem_Normal);
-    void PrependSeparator();
-    void PrependCheckItem(int id,
-                          const wxString& text,
-                          const wxString& help = wxEmptyString);
-    void PrependRadioItem(int id,
-                          const wxString& text,
-                          const wxString& help = wxEmptyString);
-    %name(PrependMenu)void Prepend(int id,
-                                   const wxString& text,
-                                   wxMenu *submenu,
-                                   const wxString& help = wxEmptyString);
-    %name(PrependItem)void Prepend(wxMenuItem *item);
-
-
-    void Break();
-    void Check(int id, bool flag);
-    bool IsChecked(int id);
-    void Enable(int id, bool enable);
-    bool IsEnabled(int id);
-
-    int FindItem(const wxString& itemString);
-    %name(FindItemById)wxMenuItem* FindItem(int id/*, wxMenu **menu = NULL*/);
-
-    wxString GetTitle();
-    void SetTitle(const wxString& title);
-
-    wxString GetLabel(int id);
-    void SetLabel(int id, const wxString& label);
-
-    wxString GetHelpString(int id);
-    void SetHelpString(int id, const wxString& helpString);
-    void UpdateUI(wxEvtHandler* source = NULL);
-
-    bool Delete(int id);
-    %name(DeleteItem)bool Delete(wxMenuItem *item);
-    wxMenuItem *Remove(int id);
-    %name(RemoveItem) wxMenuItem *Remove(wxMenuItem *item);
-
-
-
-
-    %addmethods {
-        void Destroy() { delete self; }
-    }
-    %name(DestroyId)bool Destroy(int id);
-    %name(DestroyItem)bool Destroy(wxMenuItem *item);
-
-    size_t GetMenuItemCount();
-    //wxMenuItemList& GetMenuItems();
-    %addmethods {
-        PyObject* GetMenuItems() {
-            wxMenuItemList& list = self->GetMenuItems();
-            return wxPy_ConvertList(&list, "wxMenuItem");
-        }
-    }
-
-    void SetEventHandler(wxEvtHandler *handler);
-    wxEvtHandler *GetEventHandler();
-
-    void SetInvokingWindow(wxWindow *win);
-    wxWindow *GetInvokingWindow();
-
-    long GetStyle();
-
-    bool IsAttached();
-
-    void SetParent(wxMenu *parent);
-    wxMenu *GetParent();
-};
-
-
-//----------------------------------------------------------------------
-
-class wxMenuBar : public wxWindow {
-public:
-    wxMenuBar(long style = 0);
-
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-
-    bool Append(wxMenu *menu, const wxString& title);
-    bool Insert(size_t pos, wxMenu *menu, const wxString& title);
-    size_t GetMenuCount();
-    wxMenu *GetMenu(size_t pos);
-    wxMenu *Replace(size_t pos, wxMenu *menu, const wxString& title);
-    wxMenu *Remove(size_t pos);
-    void EnableTop(size_t pos, bool enable);
-    void SetLabelTop(size_t pos, const wxString& label);
-    wxString GetLabelTop(size_t pos);
-    int FindMenu(const wxString& title);
-    int FindMenuItem(const wxString& menuString, const wxString& itemString);
-    %name(FindItemById)wxMenuItem* FindItem(int id/*, wxMenu **menu = NULL*/);
-    void Enable(int id, bool enable);
-    void Check(int id, bool check);
-    bool IsChecked(int id);
-    bool IsEnabled(int id);
-
-    void SetLabel(int id, const wxString &label);
-    wxString GetLabel(int id);
-
-    void SetHelpString(int id, const wxString& helpString);
-    wxString GetHelpString(int id);
-
-};
-
-
-//----------------------------------------------------------------------
-
-class wxMenuItem : public wxObject {
-public:
-    wxMenuItem(wxMenu* parentMenu=NULL, int id=wxID_SEPARATOR,
-               const wxString& text = wxEmptyString,
-               const wxString& help = wxEmptyString,
-               wxItemKind kind = wxItem_Normal,
-               wxMenu* subMenu = NULL);
-
-
-    wxMenu *GetMenu();
-    void SetId(int id);
-    int  GetId();
-    bool IsSeparator();
-    void SetText(const wxString& str);
-    wxString GetLabel();
-    const wxString& GetText();
-    wxItemKind GetKind();
-    void SetCheckable(bool checkable);
-    bool IsCheckable();
-    bool IsSubMenu();
-    void SetSubMenu(wxMenu *menu);
-    wxMenu *GetSubMenu();
-    void Enable(bool enable = TRUE);
-    bool IsEnabled();
-    void Check(bool check = TRUE);
-    bool IsChecked();
-    void Toggle();
-    void SetHelp(const wxString& str);
-    const wxString& GetHelp();
-    wxAcceleratorEntry *GetAccel();
-    void SetAccel(wxAcceleratorEntry *accel);
-
-    static wxString GetLabelFromText(const wxString& text);
-//    static wxAcceleratorEntry *GetAccelFromString(const wxString& label);
-
-    // wxOwnerDrawn methods
-#ifdef __WXMSW__
-    void SetFont(const wxFont& font);
-    wxFont GetFont();
-    void SetTextColour(const wxColour& colText);
-    wxColour GetTextColour();
-    void SetBackgroundColour(const wxColour& colBack);
-    wxColour GetBackgroundColour();
-    void SetBitmaps(const wxBitmap& bmpChecked,
-                    const wxBitmap& bmpUnchecked = wxNullBitmap);
-    void SetBitmap(const wxBitmap& bmpChecked);
-    wxBitmap GetBitmap(bool bChecked = TRUE);
-    void SetMarginWidth(int nWidth);
-    int GetMarginWidth();
-    static int GetDefaultMarginWidth();
-    //void SetName(const wxString& strName);
-    //const wxString& GetName();
-    //void SetCheckable(bool checkable);
-    //bool IsCheckable();
-    bool IsOwnerDrawn();
-    void ResetOwnerDrawn();
-#endif
-};
-
-//---------------------------------------------------------------------------
-
-
-