-class wxPyValidator : public wxValidator {
- DECLARE_DYNAMIC_CLASS(wxPyValidator);
-public:
- wxPyValidator() {
- }
-// wxPyValidator(const wxPyValidator& other);
-
- ~wxPyValidator() {
- }
-
- wxObject* wxPyValidator::Clone() const {
- wxPyValidator* ptr = NULL;
- wxPyValidator* self = (wxPyValidator*)this;
-
- bool doSave = wxPyRestoreThread();
- 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);
- }
- }
- // 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;
-
- wxPySaveThread(doSave);
- return ptr;
- }
-
- DEC_PYCALLBACK_BOOL_WXWIN(Validate);
- DEC_PYCALLBACK_BOOL_(TransferToWindow);
- DEC_PYCALLBACK_BOOL_(TransferFromWindow);
-
- PYPRIVATE;
-// PyObject* m_data;
-};
-
-IMP_PYCALLBACK_BOOL_WXWIN(wxPyValidator, wxValidator, Validate);
-IMP_PYCALLBACK_BOOL_(wxPyValidator, wxValidator, TransferToWindow);
-IMP_PYCALLBACK_BOOL_(wxPyValidator, wxValidator, TransferFromWindow);
-
-IMPLEMENT_DYNAMIC_CLASS(wxPyValidator, wxValidator);
-
-%}
-
-class wxPyValidator : public wxValidator {
-public:
- wxPyValidator();
-// ~wxPyValidator();
-
- %addmethods { void Destroy() { delete self; } }
-
- void _setSelf(PyObject* self, PyObject* _class, int incref=TRUE);
- %pragma(python) addtomethod = "__init__:self._setSelf(self, wxPyValidator, 0)"
-
-};
-
-//----------------------------------------------------------------------
-
-%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");
-
- %pragma(python) addtomethod = "__init__:#wx._StdWindowCallbacks(self)"
-
- 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 );
-
- // (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();
-#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();
-
- //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();
- 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 Hide();
- 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);
- %name(MoveXY)void Move(int x, int y);
- void Move(const wxPoint& point);
-
- wxEvtHandler* PopEventHandler(bool deleteHandler = FALSE);
- void PushEventHandler(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 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 SetAcceleratorTable(const wxAcceleratorTable& accel);
- 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) {
- self->Move(pos);
- }
-
- 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);
- bool TransferDataFromWindow();
- bool TransferDataToWindow();
- 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);
- wxSizer* GetSizer();
-
- wxValidator* GetValidator();
- void SetValidator(const wxValidator& validator);
-
- void SetDropTarget(wxDropTarget* target);
- wxDropTarget* GetDropTarget();
- %pragma(python) addtomethod = "SetDropTarget:_args[0].thisown = 0"
-
- wxSize GetBestSize();
-
- void SetCaret(wxCaret *caret);
- wxCaret *GetCaret();
- %pragma(python) addtoclass = "# replaces broken shadow methods
- def GetCaret(self, *_args, **_kwargs):
- from misc2 import wxCaretPtr
- val = apply(windowsc.wxWindow_GetCaret,(self,) + _args, _kwargs)
- if val: val = wxCaretPtr(val)
- return val
-
- def GetSizer(self, *_args, **_kwargs):
- from sizers import wxSizerPtr
- val = apply(windowsc.wxWindow_GetSizer,(self,) + _args, _kwargs)
- if val: val = wxSizerPtr(val)
- return val
-
- def GetToolTip(self, *_args, **_kwargs):
- from misc2 import wxToolTipPtr
- val = apply(windowsc.wxWindow_GetToolTip,(self,) + _args, _kwargs)
- if val: val = wxToolTipPtr(val)
- return val
- "
-
-
-// // Properties list
-// %pragma(python) addtoclass = "
-// _prop_list_ = {
-// 'size' : ('GetSize', 'SetSize'),
-// 'enabled' : ('IsEnabled', 'Enable'),
-// 'background' : ('GetBackgroundColour', 'SetBackgroundColour'),
-// 'foreground' : ('GetForegroundColour', 'SetForegroundColour'),
-// 'children' : ('GetChildren', None),
-// 'charHeight' : ('GetCharHeight', None),
-// 'charWidth' : ('GetCharWidth', None),
-// 'clientSize' : ('GetClientSize', 'SetClientSize'),
-// 'font' : ('GetFont', 'SetFont'),
-// 'grandParent' : ('GetGrandParent', None),
-// 'handle' : ('GetHandle', None),
-// 'label' : ('GetLabel', 'SetLabel'),
-// 'name' : ('GetName', 'SetName'),
-// 'parent' : ('GetParent', None),
-// 'position' : ('GetPosition', 'SetPosition'),
-// 'title' : ('GetTitle', 'SetTitle'),
-// 'style' : ('GetWindowStyleFlag', 'SetWindowStyleFlag'),
-// 'visible' : ('IsShown', 'Show'),
-// 'toolTip' : ('GetToolTip', 'SetToolTip'),
-// 'sizer' : ('GetSizer', 'SetSizer'),
-// 'validator' : ('GetValidator', 'SetValidator'),
-// 'dropTarget' : ('GetDropTarget', 'SetDropTarget'),
-// 'caret' : ('GetCaret', 'SetCaret'),
-// 'autoLayout' : ('GetAutoLayout', 'SetAutoLayout'),
-// 'constraints' : ('GetConstraints', 'SetConstraints'),
-
-// }
-// _prop_list_.update(wxEvtHandler._prop_list_)
-// "
-};
-
-
-
-
-%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))
-"
-
-%inline %{
- wxWindow* wxWindow_FindFocus() {
- return wxWindow::FindFocus();
- }
-%}
-
-
-#ifdef __WXMSW__
-%inline %{
-wxWindow* wxWindow_FromHWND(unsigned long hWnd) {
- wxWindow* win = new wxWindow;
- win->SetHWND(hWnd);
- win->SubclassWin(hWnd);
- return win;
-}