]> git.saurik.com Git - wxWidgets.git/blame_incremental - wxPython/src/helpers.h
added visual c++ makefiles
[wxWidgets.git] / wxPython / src / helpers.h
... / ...
CommitLineData
1////////////////////////////////////////////////////////////////////////////
2// Name: helpers.h
3// Purpose: Helper functions/classes for the wxPython extension module
4//
5// Author: Robin Dunn
6//
7// Created: 7/1/97
8// RCS-ID: $Id$
9// Copyright: (c) 1998 by Total Control Software
10// Licence: wxWindows license
11/////////////////////////////////////////////////////////////////////////////
12
13#ifndef __wxp_helpers__
14#define __wxp_helpers__
15
16#include <wx/wx.h>
17#include <wx/geometry.h>
18
19//---------------------------------------------------------------------------
20
21typedef unsigned char byte;
22
23void __wxPreStart(PyObject*);
24PyObject* __wxStart(PyObject*, PyObject* args);
25void __wxCleanup();
26
27//extern PyObject* wxPython_dict;
28PyObject* __wxSetDictionary(PyObject*, PyObject* args);
29
30void wxPyEventThunker(wxObject*, wxEvent& event);
31
32PyObject* wxPyConstructObject(void* ptr,
33 const wxString& className,
34 int setThisOwn=0);
35PyObject* wxPyConstructObject(void* ptr,
36 const wxString& className,
37 PyObject* klass,
38 int setThisOwn=0);
39
40PyObject* wx2PyString(const wxString& src);
41wxString Py2wxString(PyObject* source);
42
43PyObject* wxPyClassExists(const wxString& className);
44PyObject* wxPyMake_wxObject(wxObject* source, bool checkEvtHandler=TRUE);
45PyObject* wxPyMake_wxSizer(wxSizer* source);
46void wxPyPtrTypeMap_Add(const char* commonName, const char* ptrName);
47
48PyObject* wxPy_ConvertList(wxListBase* list, const char* className);
49long wxPyGetWinHandle(wxWindow* win);
50
51//----------------------------------------------------------------------
52
53// if we want to handle threads and Python threads are available...
54#if defined(WXP_USE_THREAD) && defined(WITH_THREAD)
55#define WXP_WITH_THREAD
56#else // no Python threads...
57#undef WXP_WITH_THREAD
58#endif
59
60
61// For Python --> C++
62PyThreadState* wxPyBeginAllowThreads();
63void wxPyEndAllowThreads(PyThreadState* state);
64
65// For C++ --> Python
66void wxPyBeginBlockThreads();
67void wxPyEndBlockThreads();
68
69#define wxPyBLOCK_THREADS(stmt) wxPyBeginBlockThreads(); stmt; wxPyEndBlockThreads()
70
71//----------------------------------------------------------------------
72// These are helpers used by the typemaps
73
74wxString* wxString_in_helper(PyObject* source);
75
76byte* byte_LIST_helper(PyObject* source);
77int* int_LIST_helper(PyObject* source);
78long* long_LIST_helper(PyObject* source);
79char** string_LIST_helper(PyObject* source);
80wxPoint* wxPoint_LIST_helper(PyObject* source, int* npoints);
81wxBitmap** wxBitmap_LIST_helper(PyObject* source);
82wxString* wxString_LIST_helper(PyObject* source);
83wxAcceleratorEntry* wxAcceleratorEntry_LIST_helper(PyObject* source);
84wxPen** wxPen_LIST_helper(PyObject* source);
85
86bool wxSize_helper(PyObject* source, wxSize** obj);
87bool wxPoint_helper(PyObject* source, wxPoint** obj);
88bool wxRealPoint_helper(PyObject* source, wxRealPoint** obj);
89bool wxRect_helper(PyObject* source, wxRect** obj);
90bool wxColour_helper(PyObject* source, wxColour** obj);
91
92bool wxPoint2DDouble_helper(PyObject* source, wxPoint2DDouble** obj);
93
94
95//----------------------------------------------------------------------
96// Other helpful stuff
97
98#if PYTHON_API_VERSION < 1009
99#define PySequence_Fast_GET_ITEM(o, i) \
100 (PyList_Check(o) ? PyList_GET_ITEM(o, i) : PyTuple_GET_ITEM(o, i))
101#endif
102
103bool wxPy2int_seq_helper(PyObject* source, int* i1, int* i2);
104bool wxPy4int_seq_helper(PyObject* source, int* i1, int* i2, int* i3, int* i4);
105
106
107PyObject* wxArrayString2PyList_helper(const wxArrayString& arr);
108PyObject* wxArrayInt2PyList_helper(const wxArrayInt& arr);
109
110#define RETURN_NONE() { Py_INCREF(Py_None); return Py_None; }
111#define DECLARE_DEF_STRING(name) static const wxString wxPy##name(wx##name)
112#define DECLARE_DEF_STRING2(name,val) static const wxString wxPy##name(val)
113
114//----------------------------------------------------------------------
115// functions used by the DrawXXXList enhancements added to wxDC
116
117typedef bool (*wxPyDrawListOp_t)(wxDC& dc, PyObject* coords);
118PyObject* wxPyDrawXXXList(wxDC& dc, wxPyDrawListOp_t doDraw,
119 PyObject* pyCoords, PyObject* pyPens, PyObject* pyBrushes);
120bool wxPyDrawXXXPoint(wxDC& dc, PyObject* coords);
121bool wxPyDrawXXXLine(wxDC& dc, PyObject* coords);
122bool wxPyDrawXXXRectangle(wxDC& dc, PyObject* coords);
123bool wxPyDrawXXXEllipse(wxDC& dc, PyObject* coords);
124bool wxPyDrawXXXPolygon(wxDC& dc, PyObject* coords);
125
126PyObject* wxPyDrawTextList(wxDC& dc, PyObject* textList, PyObject* pyPoints,
127 PyObject* foregroundList, PyObject* backgroundList);
128
129//----------------------------------------------------------------------
130
131#ifndef SWIGCODE
132extern "C" void SWIG_MakePtr(char *, void *, char *);
133extern "C" char *SWIG_GetPtr(char *, void **, char *);
134extern "C" char *SWIG_GetPtrObj(PyObject *obj, void **ptr, char *type);
135#endif
136
137
138#ifdef _MSC_VER
139# pragma warning(disable:4800)
140# pragma warning(disable:4190)
141#endif
142
143//----------------------------------------------------------------------
144
145class wxPyCallback : public wxObject {
146 DECLARE_ABSTRACT_CLASS(wxPyCallback);
147public:
148 wxPyCallback(PyObject* func);
149 wxPyCallback(const wxPyCallback& other);
150 ~wxPyCallback();
151
152 void EventThunker(wxEvent& event);
153
154 PyObject* m_func;
155};
156
157//---------------------------------------------------------------------------
158
159class wxPyTimer : public wxTimer {
160public:
161 wxPyTimer(PyObject* callback);
162 ~wxPyTimer();
163
164 void Notify();
165
166private:
167 PyObject* func;
168};
169
170//---------------------------------------------------------------------------
171//---------------------------------------------------------------------------
172// These Event classes can be derived from in Python and passed through the
173// event system without loosing anything. They do this by keeping a reference
174// to themselves and some special case handling in wxPyCallback::EventThunker.
175
176
177class wxPyEvtSelfRef {
178public:
179 wxPyEvtSelfRef();
180 ~wxPyEvtSelfRef();
181
182 void SetSelf(PyObject* self, bool clone=FALSE);
183 PyObject* GetSelf() const;
184
185protected:
186 PyObject* m_self;
187 bool m_cloned;
188};
189
190
191class wxPyEvent : public wxEvent, public wxPyEvtSelfRef {
192 DECLARE_ABSTRACT_CLASS(wxPyEvent)
193public:
194 wxPyEvent(int id=0);
195 wxPyEvent(const wxPyEvent& evt);
196 ~wxPyEvent();
197
198 virtual wxEvent* Clone() const { return new wxPyEvent(*this); }
199};
200
201
202class wxPyCommandEvent : public wxCommandEvent, public wxPyEvtSelfRef {
203 DECLARE_ABSTRACT_CLASS(wxPyCommandEvent)
204public:
205 wxPyCommandEvent(wxEventType commandType = wxEVT_NULL, int id=0);
206 wxPyCommandEvent(const wxPyCommandEvent& evt);
207 ~wxPyCommandEvent();
208
209 virtual wxEvent* Clone() const { return new wxPyCommandEvent(*this); }
210};
211
212
213
214//----------------------------------------------------------------------
215// Forward decalre a few things used in the exported API
216class wxPyClientData;
217class wxPyUserData;
218class wxPyOORClientData;
219class wxPyCBInputStream;
220
221void wxPyClientData_dtor(wxPyClientData* self);
222void wxPyUserData_dtor(wxPyUserData* self);
223void wxPyOORClientData_dtor(wxPyOORClientData* self);
224wxPyCBInputStream* wxPyCBInputStream_create(PyObject *py, bool block);
225
226
227//---------------------------------------------------------------------------
228// Export a C API in a struct. Other modules will be able to load this from
229// the wxc module and will then have safe access to these functions, even if
230// in another shared library.
231
232class wxPyCallbackHelper;
233
234
235// Make SunCC happy and make typedef's for these that are extern "C"
236typedef void (*p_SWIG_MakePtr_t)(char*, void*, char*);
237typedef char* (*p_SWIG_GetPtr_t)(char*, void**, char*);
238typedef char* (*p_SWIG_GetPtrObj_t)(PyObject*, void**, char*);
239typedef void (*p_SWIG_RegisterMapping_t)(char*, char*, void *(*cast)(void *));
240typedef void (*p_SWIG_addvarlink_t)(PyObject*, char*, PyObject *(*get_attr)(void), int (*set_attr)(PyObject *p));
241typedef PyObject* (*p_SWIG_newvarlink_t)(void);
242
243
244struct wxPyCoreAPI {
245
246 p_SWIG_MakePtr_t p_SWIG_MakePtr;
247 p_SWIG_GetPtr_t p_SWIG_GetPtr;
248 p_SWIG_GetPtrObj_t p_SWIG_GetPtrObj;
249 p_SWIG_RegisterMapping_t p_SWIG_RegisterMapping;
250 p_SWIG_addvarlink_t p_SWIG_addvarlink;
251 p_SWIG_newvarlink_t p_SWIG_newvarlink;
252
253 PyThreadState* (*p_wxPyBeginAllowThreads)();
254 void (*p_wxPyEndAllowThreads)(PyThreadState* state);
255 void (*p_wxPyBeginBlockThreads)();
256 void (*p_wxPyEndBlockThreads)();
257
258 PyObject* (*p_wxPyConstructObject)(void *, const wxString&, int);
259 PyObject* (*p_wxPy_ConvertList)(wxListBase* list, const char* className);
260
261 wxString* (*p_wxString_in_helper)(PyObject* source);
262 wxString (*p_Py2wxString)(PyObject* source);
263 PyObject* (*p_wx2PyString)(const wxString& src);
264
265 byte* (*p_byte_LIST_helper)(PyObject* source);
266 int* (*p_int_LIST_helper)(PyObject* source);
267 long* (*p_long_LIST_helper)(PyObject* source);
268 char** (*p_string_LIST_helper)(PyObject* source);
269 wxPoint* (*p_wxPoint_LIST_helper)(PyObject* source, int* npoints);
270 wxBitmap** (*p_wxBitmap_LIST_helper)(PyObject* source);
271 wxString* (*p_wxString_LIST_helper)(PyObject* source);
272 wxAcceleratorEntry* (*p_wxAcceleratorEntry_LIST_helper)(PyObject* source);
273
274 bool (*p_wxSize_helper)(PyObject* source, wxSize** obj);
275 bool (*p_wxPoint_helper)(PyObject* source, wxPoint** obj);
276 bool (*p_wxRealPoint_helper)(PyObject* source, wxRealPoint** obj);
277 bool (*p_wxRect_helper)(PyObject* source, wxRect** obj);
278 bool (*p_wxColour_helper)(PyObject* source, wxColour** obj);
279 bool (*p_wxPoint2DDouble_helper)(PyObject* source, wxPoint2DDouble** obj);
280
281 void (*p_wxPyCBH_setCallbackInfo)(wxPyCallbackHelper& cbh, PyObject* self, PyObject* klass, int incref);
282 bool (*p_wxPyCBH_findCallback)(const wxPyCallbackHelper& cbh, const char* name);
283 int (*p_wxPyCBH_callCallback)(const wxPyCallbackHelper& cbh, PyObject* argTuple);
284 PyObject* (*p_wxPyCBH_callCallbackObj)(const wxPyCallbackHelper& cbh, PyObject* argTuple);
285 void (*p_wxPyCBH_delete)(wxPyCallbackHelper* cbh);
286
287 PyObject* (*p_wxPyClassExists)(const wxString& className);
288 PyObject* (*p_wxPyMake_wxObject)(wxObject* source, bool checkEvtHandler);
289 PyObject* (*p_wxPyMake_wxSizer)(wxSizer* source);
290 void (*p_wxPyPtrTypeMap_Add)(const char* commonName, const char* ptrName);
291 PyObject* (*p_wxArrayString2PyList_helper)(const wxArrayString& arr);
292 PyObject* (*p_wxArrayInt2PyList_helper)(const wxArrayInt& arr);
293
294 void (*p_wxPyClientData_dtor)(wxPyClientData*);
295 void (*p_wxPyUserData_dtor)(wxPyUserData*);
296 void (*p_wxPyOORClientData_dtor)(wxPyOORClientData*);
297
298 wxPyCBInputStream* (*p_wxPyCBInputStream_create)(PyObject *py, bool block);
299
300};
301
302#ifdef wxPyUSE_EXPORT
303// Notice that this is static, not extern. This is by design, each module
304// needs one, but doesn't have to use it.
305static wxPyCoreAPI* wxPyCoreAPIPtr = NULL;
306#endif
307
308
309//---------------------------------------------------------------------------
310
311
312class wxPyUserData : public wxObject {
313public:
314 wxPyUserData(PyObject* obj) {
315 m_obj = obj;
316 Py_INCREF(m_obj);
317 }
318
319 ~wxPyUserData() {
320#ifdef wxPyUSE_EXPORT
321 wxPyCoreAPIPtr->p_wxPyUserData_dtor(this);
322#else
323 wxPyUserData_dtor(this);
324#endif
325 }
326 PyObject* m_obj;
327};
328
329
330class wxPyClientData : public wxClientData {
331public:
332 wxPyClientData(PyObject* obj) {
333 m_obj = obj;
334 Py_INCREF(m_obj);
335 }
336
337 ~wxPyClientData() {
338#ifdef wxPyUSE_EXPORT
339 wxPyCoreAPIPtr->p_wxPyClientData_dtor(this);
340#else
341 wxPyClientData_dtor(this);
342#endif
343 }
344 PyObject* m_obj;
345};
346
347
348class wxPyOORClientData : public wxPyClientData {
349public:
350 wxPyOORClientData(PyObject* obj)
351 : wxPyClientData(obj) {}
352
353 ~wxPyOORClientData() {
354#ifdef wxPyUSE_EXPORT
355 wxPyCoreAPIPtr->p_wxPyOORClientData_dtor(this);
356#else
357 wxPyOORClientData_dtor(this);
358#endif
359 }
360};
361
362//---------------------------------------------------------------------------
363// This class holds an instance of a Python Shadow Class object and assists
364// with looking up and invoking Python callback methods from C++ virtual
365// method redirections. For all classes which have virtuals which should be
366// overridable in wxPython, a new subclass is created that contains a
367// wxPyCallbackHelper.
368//
369
370class wxPyCallbackHelper {
371public:
372 wxPyCallbackHelper(const wxPyCallbackHelper& other);
373
374 wxPyCallbackHelper() {
375 m_class = NULL;
376 m_self = NULL;
377 m_lastFound = NULL;
378 m_incRef = FALSE;
379 }
380
381 ~wxPyCallbackHelper() {
382#ifdef wxPyUSE_EXPORT
383 wxPyCoreAPIPtr->p_wxPyCBH_delete(this);
384#else
385 wxPyCBH_delete(this);
386#endif
387 }
388
389 void setSelf(PyObject* self, PyObject* klass, int incref=TRUE);
390 bool findCallback(const char* name) const;
391 int callCallback(PyObject* argTuple) const;
392 PyObject* callCallbackObj(PyObject* argTuple) const;
393
394private:
395 PyObject* m_self;
396 PyObject* m_class;
397 PyObject* m_lastFound;
398 int m_incRef;
399
400 friend void wxPyCBH_delete(wxPyCallbackHelper* cbh);
401};
402
403
404void wxPyCBH_setCallbackInfo(wxPyCallbackHelper& cbh, PyObject* self, PyObject* klass, int incref);
405bool wxPyCBH_findCallback(const wxPyCallbackHelper& cbh, const char* name);
406int wxPyCBH_callCallback(const wxPyCallbackHelper& cbh, PyObject* argTuple);
407PyObject* wxPyCBH_callCallbackObj(const wxPyCallbackHelper& cbh, PyObject* argTuple);
408void wxPyCBH_delete(wxPyCallbackHelper* cbh);
409
410
411
412
413//---------------------------------------------------------------------------
414
415// This is used in C++ classes that need to be able to make callback to
416// "overloaded" python methods
417
418#define PYPRIVATE \
419 void _setCallbackInfo(PyObject* self, PyObject* _class, int incref=1) { \
420 wxPyCBH_setCallbackInfo(m_myInst, self, _class, incref); \
421 } \
422 private: wxPyCallbackHelper m_myInst
423
424
425//---------------------------------------------------------------------------
426
427enum {
428 wxPYAPP_ASSERT_SUPPRESS = 1,
429 wxPYAPP_ASSERT_EXCEPTION = 2,
430 wxPYAPP_ASSERT_DIALOG = 4,
431 wxPYAPP_ASSERT_LOG = 8
432};
433
434class wxPyApp: public wxApp
435{
436 DECLARE_ABSTRACT_CLASS(wxPyApp);
437
438public:
439 wxPyApp();
440 ~wxPyApp();
441 bool OnInit();
442 int MainLoop();
443
444 int GetAssertMode() { return m_assertMode; }
445 void SetAssertMode(int mode) { m_assertMode = mode; }
446
447 virtual bool OnInitGui();
448 virtual int OnExit();
449#ifdef __WXDEBUG__
450 virtual void OnAssert(const wxChar *file,
451 int line,
452 const wxChar *cond,
453 const wxChar *msg);
454#endif
455 // virtual int FilterEvent(wxEvent& event); // This one too????
456
457
458 static bool GetMacDefaultEncodingIsPC();
459 static bool GetMacSupportPCMenuShortcuts();
460 static long GetMacAboutMenuItemId();
461 static long GetMacPreferencesMenuItemId();
462 static long GetMacExitMenuItemId();
463 static wxString GetMacHelpMenuTitleName();
464
465 static void SetMacDefaultEncodingIsPC(bool val);
466 static void SetMacSupportPCMenuShortcuts(bool val);
467 static void SetMacAboutMenuItemId(long val);
468 static void SetMacPreferencesMenuItemId(long val);
469 static void SetMacExitMenuItemId(long val);
470 static void SetMacHelpMenuTitleName(const wxString& val);
471
472
473 PYPRIVATE;
474 int m_assertMode;
475};
476
477extern wxPyApp *wxPythonApp;
478
479
480//----------------------------------------------------------------------
481// These macros are used to implement the virtual methods that should
482// redirect to a Python method if one exists. The names designate the
483// return type, if any, as well as any parameter types.
484//---------------------------------------------------------------------------
485
486#define DEC_PYCALLBACK__(CBNAME) \
487 void CBNAME(); \
488 void base_##CBNAME();
489
490
491#define IMP_PYCALLBACK__(CLASS, PCLASS, CBNAME) \
492 void CLASS::CBNAME() { \
493 bool found; \
494 wxPyBeginBlockThreads(); \
495 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
496 wxPyCBH_callCallback(m_myInst, Py_BuildValue("()")); \
497 wxPyEndBlockThreads(); \
498 if (! found) \
499 PCLASS::CBNAME(); \
500 } \
501 void CLASS::base_##CBNAME() { \
502 PCLASS::CBNAME(); \
503 }
504
505//---------------------------------------------------------------------------
506
507#define DEC_PYCALLBACK_BOOL_INTINT(CBNAME) \
508 bool CBNAME(int a, int b); \
509 bool base_##CBNAME(int a, int b);
510
511
512#define IMP_PYCALLBACK_BOOL_INTINT(CLASS, PCLASS, CBNAME) \
513 bool CLASS::CBNAME(int a, int b) { \
514 bool rval=FALSE, found; \
515 wxPyBeginBlockThreads(); \
516 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
517 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(ii)",a,b)); \
518 wxPyEndBlockThreads(); \
519 if (! found) \
520 rval = PCLASS::CBNAME(a,b); \
521 return rval; \
522 } \
523 bool CLASS::base_##CBNAME(int a, int b) { \
524 return PCLASS::CBNAME(a,b); \
525 }
526
527//---------------------------------------------------------------------------
528
529#define DEC_PYCALLBACK_VOID_INTINT(CBNAME) \
530 void CBNAME(int a, int b); \
531 void base_##CBNAME(int a, int b);
532
533
534#define IMP_PYCALLBACK_VOID_INTINT(CLASS, PCLASS, CBNAME) \
535 void CLASS::CBNAME(int a, int b) { \
536 bool found; \
537 wxPyBeginBlockThreads(); \
538 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
539 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(ii)",a,b)); \
540 wxPyEndBlockThreads(); \
541 if (! found) \
542 PCLASS::CBNAME(a,b); \
543 } \
544 void CLASS::base_##CBNAME(int a, int b) { \
545 PCLASS::CBNAME(a,b); \
546 }
547
548//---------------------------------------------------------------------------
549
550#define DEC_PYCALLBACK_VOID_INT4(CBNAME) \
551 void CBNAME(int a, int b, int c, int d); \
552 void base_##CBNAME(int a, int b, int c, int d);
553
554
555#define IMP_PYCALLBACK_VOID_INT4(CLASS, PCLASS, CBNAME) \
556 void CLASS::CBNAME(int a, int b, int c, int d) { \
557 bool found; \
558 wxPyBeginBlockThreads(); \
559 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
560 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iiii)",a,b,c,d)); \
561 wxPyEndBlockThreads(); \
562 if (! found) \
563 PCLASS::CBNAME(a,b,c,d); \
564 } \
565 void CLASS::base_##CBNAME(int a, int b, int c, int d) { \
566 PCLASS::CBNAME(a,b,c,d); \
567 }
568
569//---------------------------------------------------------------------------
570#define DEC_PYCALLBACK_VOID_INT5(CBNAME) \
571 void CBNAME(int a, int b, int c, int d, int e); \
572 void base_##CBNAME(int a, int b, int c, int d, int e);
573
574
575#define IMP_PYCALLBACK_VOID_INT5(CLASS, PCLASS, CBNAME) \
576 void CLASS::CBNAME(int a, int b, int c, int d, int e) { \
577 bool found; \
578 wxPyBeginBlockThreads(); \
579 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
580 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iiiii)",a,b,c,d,e)); \
581 wxPyEndBlockThreads(); \
582 if (! found) \
583 PCLASS::CBNAME(a,b,c,d,e); \
584 } \
585 void CLASS::base_##CBNAME(int a, int b, int c, int d, int e) { \
586 PCLASS::CBNAME(a,b,c,d,e); \
587 }
588
589//---------------------------------------------------------------------------
590
591#define DEC_PYCALLBACK_VOID_INTPINTP_const(CBNAME) \
592 void CBNAME(int* a, int* b) const; \
593 void base_##CBNAME(int* a, int* b) const;
594
595
596#define IMP_PYCALLBACK_VOID_INTPINTP_const(CLASS, PCLASS, CBNAME) \
597 void CLASS::CBNAME(int* a, int* b) const { \
598 const char* errmsg = #CBNAME " should return a 2-tuple of integers."; \
599 bool found; \
600 wxPyBeginBlockThreads(); \
601 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
602 PyObject* ro; \
603 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
604 if (ro) { \
605 if (PySequence_Check(ro) && PyObject_Length(ro) == 2) { \
606 PyObject* o1 = PySequence_GetItem(ro, 0); \
607 PyObject* o2 = PySequence_GetItem(ro, 1); \
608 if (PyNumber_Check(o1) && PyNumber_Check(o2)) { \
609 *a = PyInt_AsLong(o1); *b = PyInt_AsLong(o2); \
610 } \
611 else \
612 PyErr_SetString(PyExc_TypeError, errmsg); \
613 Py_DECREF(o1); \
614 Py_DECREF(o2); \
615 } \
616 else { \
617 PyErr_SetString(PyExc_TypeError, errmsg); \
618 } \
619 Py_DECREF(ro); \
620 } \
621 } \
622 wxPyEndBlockThreads(); \
623 if (! found) \
624 PCLASS::CBNAME(a,b); \
625 } \
626 void CLASS::base_##CBNAME(int* a, int* b) const { \
627 PCLASS::CBNAME(a,b); \
628 }
629
630
631//---------------------------------------------------------------------------
632
633#define DEC_PYCALLBACK_SIZE_const(CBNAME) \
634 wxSize CBNAME() const; \
635 wxSize base_##CBNAME() const;
636
637
638#define IMP_PYCALLBACK_SIZE_const(CLASS, PCLASS, CBNAME) \
639 wxSize CLASS::CBNAME() const { \
640 const char* errmsg = #CBNAME " should return a 2-tuple of integers."; \
641 bool found; wxSize rval(0,0); \
642 wxPyBeginBlockThreads(); \
643 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
644 PyObject* ro; \
645 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
646 if (ro) { \
647 if (PySequence_Check(ro) && PyObject_Length(ro) == 2) { \
648 PyObject* o1 = PySequence_GetItem(ro, 0); \
649 PyObject* o2 = PySequence_GetItem(ro, 1); \
650 if (PyNumber_Check(o1) && PyNumber_Check(o2)) { \
651 rval = wxSize(PyInt_AsLong(o1), PyInt_AsLong(o2)); \
652 } \
653 else \
654 PyErr_SetString(PyExc_TypeError, errmsg); \
655 Py_DECREF(o1); \
656 Py_DECREF(o2); \
657 } \
658 else { \
659 PyErr_SetString(PyExc_TypeError, errmsg); \
660 } \
661 Py_DECREF(ro); \
662 } \
663 } \
664 wxPyEndBlockThreads(); \
665 if (! found) \
666 return PCLASS::CBNAME(); \
667 else \
668 return rval; \
669 } \
670 wxSize CLASS::base_##CBNAME() const { \
671 return PCLASS::CBNAME(); \
672 }
673
674
675//---------------------------------------------------------------------------
676
677#define DEC_PYCALLBACK_BOOL_INT(CBNAME) \
678 bool CBNAME(int a); \
679 bool base_##CBNAME(int a);
680
681
682#define IMP_PYCALLBACK_BOOL_INT(CLASS, PCLASS, CBNAME) \
683 bool CLASS::CBNAME(int a) { \
684 bool rval=FALSE, found; \
685 wxPyBeginBlockThreads(); \
686 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
687 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(i)",a));\
688 wxPyEndBlockThreads(); \
689 if (! found) \
690 rval = PCLASS::CBNAME(a); \
691 return rval; \
692 } \
693 bool CLASS::base_##CBNAME(int a) { \
694 return PCLASS::CBNAME(a); \
695 }
696
697//---------------------------------------------------------------------------
698
699#define DEC_PYCALLBACK_BOOL_INT_pure(CBNAME) \
700 bool CBNAME(int a);
701
702
703#define IMP_PYCALLBACK_BOOL_INT_pure(CLASS, PCLASS, CBNAME) \
704 bool CLASS::CBNAME(int a) { \
705 bool rval=FALSE; \
706 wxPyBeginBlockThreads(); \
707 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) \
708 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(i)",a)); \
709 else rval = FALSE; \
710 wxPyEndBlockThreads(); \
711 return rval; \
712 }
713
714
715//---------------------------------------------------------------------------
716
717#define DEC_PYCALLBACK__DC(CBNAME) \
718 void CBNAME(wxDC& a); \
719 void base_##CBNAME(wxDC& a);
720
721
722#define IMP_PYCALLBACK__DC(CLASS, PCLASS, CBNAME) \
723 void CLASS::CBNAME(wxDC& a) { \
724 bool found; \
725 wxPyBeginBlockThreads(); \
726 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
727 PyObject* obj = wxPyMake_wxObject(&a); \
728 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
729 Py_DECREF(obj); \
730 } \
731 wxPyEndBlockThreads(); \
732 if (! found) \
733 PCLASS::CBNAME(a); \
734 } \
735 void CLASS::base_##CBNAME(wxDC& a) { \
736 PCLASS::CBNAME(a); \
737 }
738
739
740
741//---------------------------------------------------------------------------
742
743#define DEC_PYCALLBACK__DCBOOL(CBNAME) \
744 void CBNAME(wxDC& a, bool b); \
745 void base_##CBNAME(wxDC& a, bool b);
746
747
748#define IMP_PYCALLBACK__DCBOOL(CLASS, PCLASS, CBNAME) \
749 void CLASS::CBNAME(wxDC& a, bool b) { \
750 bool found; \
751 wxPyBeginBlockThreads(); \
752 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
753 PyObject* obj = wxPyMake_wxObject(&a); \
754 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oi)", obj, (int)b)); \
755 Py_DECREF(obj); \
756 } \
757 wxPyEndBlockThreads(); \
758 if (! found) \
759 PCLASS::CBNAME(a, b); \
760 } \
761 void CLASS::base_##CBNAME(wxDC& a, bool b) { \
762 PCLASS::CBNAME(a, b); \
763 }
764
765//---------------------------------------------------------------------------
766
767#define DEC_PYCALLBACK__DCBOOL(CBNAME) \
768 void CBNAME(wxDC& a, bool b); \
769 void base_##CBNAME(wxDC& a, bool b);
770
771
772#define IMP_PYCALLBACK__DCBOOL(CLASS, PCLASS, CBNAME) \
773 void CLASS::CBNAME(wxDC& a, bool b) { \
774 bool found; \
775 wxPyBeginBlockThreads(); \
776 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
777 PyObject* obj = wxPyMake_wxObject(&a); \
778 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oi)", obj, (int)b)); \
779 Py_DECREF(obj); \
780 } \
781 wxPyEndBlockThreads(); \
782 if (! found) \
783 PCLASS::CBNAME(a, b); \
784 } \
785 void CLASS::base_##CBNAME(wxDC& a, bool b) { \
786 PCLASS::CBNAME(a, b); \
787 }
788
789//---------------------------------------------------------------------------
790
791#define DEC_PYCALLBACK__2DBL(CBNAME) \
792 void CBNAME(double a, double b); \
793 void base_##CBNAME(double a, double b);
794
795
796#define IMP_PYCALLBACK__2DBL(CLASS, PCLASS, CBNAME) \
797 void CLASS::CBNAME(double a, double b) { \
798 bool found; \
799 wxPyBeginBlockThreads(); \
800 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
801 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(dd)",a,b)); \
802 wxPyEndBlockThreads(); \
803 if (! found) \
804 PCLASS::CBNAME(a, b); \
805 } \
806 void CLASS::base_##CBNAME(double a, double b) { \
807 PCLASS::CBNAME(a, b); \
808 }
809
810//---------------------------------------------------------------------------
811
812#define DEC_PYCALLBACK__2DBL2INT(CBNAME) \
813 void CBNAME(double a, double b, int c, int d); \
814 void base_##CBNAME(double a, double b, int c, int d);
815
816
817#define IMP_PYCALLBACK__2DBL2INT(CLASS, PCLASS, CBNAME) \
818 void CLASS::CBNAME(double a, double b, int c, int d) { \
819 bool found; \
820 wxPyBeginBlockThreads(); \
821 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
822 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(ddii)", \
823 a,b,c,d)); \
824 wxPyEndBlockThreads(); \
825 if (! found) \
826 PCLASS::CBNAME(a, b, c, d); \
827 } \
828 void CLASS::base_##CBNAME(double a, double b, int c, int d) { \
829 PCLASS::CBNAME(a, b, c, d); \
830 }
831
832//---------------------------------------------------------------------------
833
834#define DEC_PYCALLBACK__DC4DBLBOOL(CBNAME) \
835 void CBNAME(wxDC& a, double b, double c, double d, double e, bool f); \
836 void base_##CBNAME(wxDC& a, double b, double c, double d, double e, bool f);
837
838
839#define IMP_PYCALLBACK__DC4DBLBOOL(CLASS, PCLASS, CBNAME) \
840 void CLASS::CBNAME(wxDC& a, double b, double c, double d, double e, bool f) { \
841 bool found; \
842 wxPyBeginBlockThreads(); \
843 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
844 PyObject* obj = wxPyMake_wxObject(&a); \
845 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oddddi)", obj, b, c, d, e, (int)f)); \
846 Py_DECREF(obj); \
847 } \
848 wxPyEndBlockThreads(); \
849 if (! found) \
850 PCLASS::CBNAME(a, b, c, d, e, f); \
851 } \
852 void CLASS::base_##CBNAME(wxDC& a, double b, double c, double d, double e, bool f) {\
853 PCLASS::CBNAME(a, b, c, d, e, f); \
854 }
855
856//---------------------------------------------------------------------------
857
858#define DEC_PYCALLBACK_BOOL_DC4DBLBOOL(CBNAME) \
859 bool CBNAME(wxDC& a, double b, double c, double d, double e, bool f); \
860 bool base_##CBNAME(wxDC& a, double b, double c, double d, double e, bool f);
861
862
863#define IMP_PYCALLBACK_BOOL_DC4DBLBOOL(CLASS, PCLASS, CBNAME) \
864 bool CLASS::CBNAME(wxDC& a, double b, double c, double d, double e, bool f) { \
865 bool found; \
866 wxPyBeginBlockThreads(); \
867 bool rval=FALSE; \
868 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
869 PyObject* obj = wxPyMake_wxObject(&a); \
870 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oddddi)", obj, b, c, d, e, (int)f));\
871 Py_DECREF(obj); \
872 } \
873 wxPyEndBlockThreads(); \
874 if (! found) \
875 rval = PCLASS::CBNAME(a, b, c, d, e, f); \
876 return rval; \
877 } \
878 bool CLASS::base_##CBNAME(wxDC& a, double b, double c, double d, double e, bool f) {\
879 return PCLASS::CBNAME(a, b, c, d, e, f); \
880 }
881
882//---------------------------------------------------------------------------
883
884#define DEC_PYCALLBACK__BOOL2DBL2INT(CBNAME) \
885 void CBNAME(bool a, double b, double c, int d, int e); \
886 void base_##CBNAME(bool a, double b, double c, int d, int e);
887
888
889#define IMP_PYCALLBACK__BOOL2DBL2INT(CLASS, PCLASS, CBNAME) \
890 void CLASS::CBNAME(bool a, double b, double c, int d, int e) { \
891 bool found; \
892 wxPyBeginBlockThreads(); \
893 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
894 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iddii)", \
895 (int)a,b,c,d,e)); \
896 wxPyEndBlockThreads(); \
897 if (! found) \
898 PCLASS::CBNAME(a, b, c, d, e); \
899 } \
900 void CLASS::base_##CBNAME(bool a, double b, double c, int d, int e) { \
901 PCLASS::CBNAME(a, b, c, d, e); \
902 }
903
904//---------------------------------------------------------------------------
905
906#define DEC_PYCALLBACK__DC4DBL(CBNAME) \
907 void CBNAME(wxDC& a, double b, double c, double d, double e); \
908 void base_##CBNAME(wxDC& a, double b, double c, double d, double e);
909
910
911#define IMP_PYCALLBACK__DC4DBL(CLASS, PCLASS, CBNAME) \
912 void CLASS::CBNAME(wxDC& a, double b, double c, double d, double e) { \
913 bool found; \
914 wxPyBeginBlockThreads(); \
915 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
916 PyObject* obj = wxPyMake_wxObject(&a); \
917 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Odddd)", obj, b, c, d, e)); \
918 Py_DECREF(obj); \
919 } \
920 wxPyEndBlockThreads(); \
921 if (! found) \
922 PCLASS::CBNAME(a, b, c, d, e); \
923 } \
924 void CLASS::base_##CBNAME(wxDC& a, double b, double c, double d, double e) {\
925 PCLASS::CBNAME(a, b, c, d, e); \
926 }
927
928//---------------------------------------------------------------------------
929
930#define DEC_PYCALLBACK__DCBOOL(CBNAME) \
931 void CBNAME(wxDC& a, bool b); \
932 void base_##CBNAME(wxDC& a, bool b);
933
934
935#define IMP_PYCALLBACK__DCBOOL(CLASS, PCLASS, CBNAME) \
936 void CLASS::CBNAME(wxDC& a, bool b) { \
937 bool found; \
938 wxPyBeginBlockThreads(); \
939 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
940 PyObject* obj = wxPyMake_wxObject(&a); \
941 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oi)", obj, (int)b)); \
942 Py_DECREF(obj); \
943 } \
944 wxPyEndBlockThreads(); \
945 if (! found) \
946 PCLASS::CBNAME(a, b); \
947 } \
948 void CLASS::base_##CBNAME(wxDC& a, bool b) { \
949 PCLASS::CBNAME(a, b); \
950 }
951
952//---------------------------------------------------------------------------
953
954#define DEC_PYCALLBACK__WXCPBOOL2DBL2INT(CBNAME) \
955 void CBNAME(wxControlPoint* a, bool b, double c, double d, int e, int f); \
956 void base_##CBNAME(wxControlPoint* a, bool b, double c, double d, int e, int f);
957
958
959#define IMP_PYCALLBACK__WXCPBOOL2DBL2INT(CLASS, PCLASS, CBNAME) \
960 void CLASS::CBNAME(wxControlPoint* a, bool b, double c, double d, \
961 int e, int f) { \
962 bool found; \
963 wxPyBeginBlockThreads(); \
964 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
965 PyObject* obj = wxPyMake_wxObject(a); \
966 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oiddii)", obj, (int)b, c, d, e, f));\
967 Py_DECREF(obj); \
968 } \
969 wxPyEndBlockThreads(); \
970 if (! found) \
971 PCLASS::CBNAME(a, b, c, d, e, f); \
972 } \
973 void CLASS::base_##CBNAME(wxControlPoint* a, bool b, double c, double d, \
974 int e, int f) { \
975 PCLASS::CBNAME(a, b, c, d, e, f); \
976 }
977
978//---------------------------------------------------------------------------
979
980#define DEC_PYCALLBACK__WXCP2DBL2INT(CBNAME) \
981 void CBNAME(wxControlPoint* a, double b, double c, int d, int e); \
982 void base_##CBNAME(wxControlPoint* a, double b, double c, int d, int e);
983
984
985#define IMP_PYCALLBACK__WXCP2DBL2INT(CLASS, PCLASS, CBNAME) \
986 void CLASS::CBNAME(wxControlPoint* a, double b, double c, int d, int e) { \
987 bool found; \
988 wxPyBeginBlockThreads(); \
989 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
990 PyObject* obj = wxPyMake_wxObject(a); \
991 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(Oddii)", obj, b, c, d, e)); \
992 Py_DECREF(obj); \
993 } \
994 wxPyEndBlockThreads(); \
995 if (! found) \
996 PCLASS::CBNAME(a, b, c, d, e); \
997 } \
998 void CLASS::base_##CBNAME(wxControlPoint* a, double b, double c, \
999 int d, int e) { \
1000 PCLASS::CBNAME(a, b, c, d, e); \
1001 }
1002
1003//---------------------------------------------------------------------------
1004
1005#define DEC_PYCALLBACK__2DBLINT(CBNAME) \
1006 void CBNAME(double a, double b, int c); \
1007 void base_##CBNAME(double a, double b, int c);
1008
1009
1010#define IMP_PYCALLBACK__2DBLINT(CLASS, PCLASS, CBNAME) \
1011 void CLASS::CBNAME(double a, double b, int c) { \
1012 bool found; \
1013 wxPyBeginBlockThreads(); \
1014 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
1015 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(ddi)", a,b,c)); \
1016 wxPyEndBlockThreads(); \
1017 if (! found) \
1018 PCLASS::CBNAME(a, b, c); \
1019 } \
1020 void CLASS::base_##CBNAME(double a, double b, int c) { \
1021 PCLASS::CBNAME(a, b, c); \
1022 }
1023
1024//---------------------------------------------------------------------------
1025
1026#define DEC_PYCALLBACK__BOOL2DBLINT(CBNAME) \
1027 void CBNAME(bool a, double b, double c, int d); \
1028 void base_##CBNAME(bool a, double b, double c, int d);
1029
1030
1031#define IMP_PYCALLBACK__BOOL2DBLINT(CLASS, PCLASS, CBNAME) \
1032 void CLASS::CBNAME(bool a, double b, double c, int d) { \
1033 bool found; \
1034 wxPyBeginBlockThreads(); \
1035 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
1036 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iddi)", (int)a,b,c,d));\
1037 wxPyEndBlockThreads(); \
1038 if (! found) \
1039 PCLASS::CBNAME(a, b, c, d); \
1040 } \
1041 void CLASS::base_##CBNAME(bool a, double b, double c, int d) { \
1042 PCLASS::CBNAME(a, b, c, d); \
1043 }
1044
1045//---------------------------------------------------------------------------
1046//---------------------------------------------------------------------------
1047
1048#define DEC_PYCALLBACK__STRING(CBNAME) \
1049 void CBNAME(const wxString& a); \
1050 void base_##CBNAME(const wxString& a);
1051
1052#define IMP_PYCALLBACK__STRING(CLASS, PCLASS, CBNAME) \
1053 void CLASS::CBNAME(const wxString& a) { \
1054 bool found; \
1055 wxPyBeginBlockThreads(); \
1056 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1057 PyObject* s = wx2PyString(a); \
1058 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", s)); \
1059 Py_DECREF(s); \
1060 } \
1061 wxPyEndBlockThreads(); \
1062 if (! found) \
1063 PCLASS::CBNAME(a); \
1064 } \
1065 void CLASS::base_##CBNAME(const wxString& a) { \
1066 PCLASS::CBNAME(a); \
1067 }
1068
1069//---------------------------------------------------------------------------
1070
1071#define DEC_PYCALLBACK_BOOL_STRING(CBNAME) \
1072 bool CBNAME(const wxString& a); \
1073 bool base_##CBNAME(const wxString& a);
1074
1075#define IMP_PYCALLBACK_BOOL_STRING(CLASS, PCLASS, CBNAME) \
1076 bool CLASS::CBNAME(const wxString& a) { \
1077 bool rval=FALSE; \
1078 bool found; \
1079 wxPyBeginBlockThreads(); \
1080 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1081 PyObject* s = wx2PyString(a); \
1082 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", s)); \
1083 Py_DECREF(s); \
1084 } \
1085 wxPyEndBlockThreads(); \
1086 if (! found) \
1087 rval = PCLASS::CBNAME(a); \
1088 return rval; \
1089 } \
1090 bool CLASS::base_##CBNAME(const wxString& a) { \
1091 return PCLASS::CBNAME(a); \
1092 }
1093
1094//---------------------------------------------------------------------------
1095
1096#define DEC_PYCALLBACK_BOOL_STRING_pure(CBNAME) \
1097 bool CBNAME(const wxString& a);
1098
1099#define IMP_PYCALLBACK_BOOL_STRING_pure(CLASS, PCLASS, CBNAME) \
1100 bool CLASS::CBNAME(const wxString& a) { \
1101 bool rval=FALSE; \
1102 wxPyBeginBlockThreads(); \
1103 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1104 PyObject* s = wx2PyString(a); \
1105 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", s)); \
1106 Py_DECREF(s); \
1107 } \
1108 wxPyEndBlockThreads(); \
1109 return rval; \
1110 } \
1111
1112//---------------------------------------------------------------------------
1113
1114#define DEC_PYCALLBACK_STRING_STRING_pure(CBNAME) \
1115 wxString CBNAME(const wxString& a); \
1116
1117#define IMP_PYCALLBACK_STRING_STRING_pure(CLASS, PCLASS, CBNAME) \
1118 wxString CLASS::CBNAME(const wxString& a) { \
1119 wxString rval; \
1120 wxPyBeginBlockThreads(); \
1121 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1122 PyObject* ro; \
1123 PyObject* s = wx2PyString(a); \
1124 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(O)", s)); \
1125 Py_DECREF(s); \
1126 if (ro) { \
1127 rval = Py2wxString(ro); \
1128 Py_DECREF(ro); \
1129 } \
1130 } \
1131 wxPyEndBlockThreads(); \
1132 return rval; \
1133 } \
1134
1135//---------------------------------------------------------------------------
1136
1137#define DEC_PYCALLBACK_STRING_STRING(CBNAME) \
1138 wxString CBNAME(const wxString& a); \
1139 wxString base_##CBNAME(const wxString& a);
1140
1141#define IMP_PYCALLBACK_STRING_STRING(CLASS, PCLASS, CBNAME) \
1142 wxString CLASS::CBNAME(const wxString& a) { \
1143 wxString rval; \
1144 bool found; \
1145 wxPyBeginBlockThreads(); \
1146 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1147 PyObject* ro; \
1148 PyObject* s = wx2PyString(a); \
1149 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(O)", s)); \
1150 Py_DECREF(s); \
1151 if (ro) { \
1152 rval = Py2wxString(ro); \
1153 Py_DECREF(ro); \
1154 } \
1155 } \
1156 if (! found) \
1157 rval = PCLASS::CBNAME(a); \
1158 wxPyEndBlockThreads(); \
1159 return rval; \
1160 } \
1161
1162//---------------------------------------------------------------------------
1163
1164#define DEC_PYCALLBACK_STRING_STRINGINT_pure(CBNAME) \
1165 wxString CBNAME(const wxString& a,int b); \
1166
1167#define IMP_PYCALLBACK_STRING_STRINGINT_pure(CLASS, PCLASS, CBNAME) \
1168 wxString CLASS::CBNAME(const wxString& a,int b) { \
1169 wxString rval; \
1170 wxPyBeginBlockThreads(); \
1171 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1172 PyObject* ro; \
1173 PyObject* s = wx2PyString(a); \
1174 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(Oi)",s,b)); \
1175 Py_DECREF(s); \
1176 if (ro) { \
1177 rval = Py2wxString(ro); \
1178 Py_DECREF(ro); \
1179 } \
1180 } \
1181 wxPyEndBlockThreads(); \
1182 return rval; \
1183 } \
1184
1185//---------------------------------------------------------------------------
1186
1187#define DEC_PYCALLBACK_BOOL_STRINGSTRING(CBNAME) \
1188 bool CBNAME(const wxString& a, const wxString& b); \
1189 bool base_##CBNAME(const wxString& a, const wxString& b);
1190
1191#define IMP_PYCALLBACK_BOOL_STRINGSTRING(CLASS, PCLASS, CBNAME) \
1192 bool CLASS::CBNAME(const wxString& a, const wxString& b) { \
1193 bool rval=FALSE; \
1194 bool found; \
1195 wxPyBeginBlockThreads(); \
1196 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1197 PyObject* s1 = wx2PyString(a); \
1198 PyObject* s2 = wx2PyString(b); \
1199 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(OO)",s1,s2)); \
1200 Py_DECREF(s1); \
1201 Py_DECREF(s2); \
1202 } \
1203 wxPyEndBlockThreads(); \
1204 if (! found) \
1205 rval = PCLASS::CBNAME(a, b); \
1206 return rval; \
1207 } \
1208 bool CLASS::base_##CBNAME(const wxString& a, const wxString& b) { \
1209 return PCLASS::CBNAME(a, b); \
1210 }
1211
1212//---------------------------------------------------------------------------
1213
1214#define DEC_PYCALLBACK_STRING_(CBNAME) \
1215 wxString CBNAME(); \
1216 wxString base_##CBNAME();
1217
1218#define IMP_PYCALLBACK_STRING_(CLASS, PCLASS, CBNAME) \
1219 wxString CLASS::CBNAME() { \
1220 wxString rval; \
1221 bool found; \
1222 wxPyBeginBlockThreads(); \
1223 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1224 PyObject* ro; \
1225 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1226 if (ro) { \
1227 rval = Py2wxString(ro); \
1228 Py_DECREF(ro); \
1229 } \
1230 } \
1231 wxPyEndBlockThreads(); \
1232 if (! found) \
1233 rval = PCLASS::CBNAME(); \
1234 return rval; \
1235 } \
1236 wxString CLASS::base_##CBNAME() { \
1237 return PCLASS::CBNAME(); \
1238 }
1239
1240//---------------------------------------------------------------------------
1241
1242#define DEC_PYCALLBACK_STRING__const(CBNAME) \
1243 wxString CBNAME() const; \
1244 wxString base_##CBNAME() const;
1245
1246#define IMP_PYCALLBACK_STRING__const(CLASS, PCLASS, CBNAME) \
1247 wxString CLASS::CBNAME() const { \
1248 wxString rval; \
1249 bool found; \
1250 wxPyBeginBlockThreads(); \
1251 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1252 PyObject* ro; \
1253 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1254 if (ro) { \
1255 rval = Py2wxString(ro); \
1256 Py_DECREF(ro); \
1257 } \
1258 } \
1259 wxPyEndBlockThreads(); \
1260 if (! found) \
1261 rval = PCLASS::CBNAME(); \
1262 return rval; \
1263 } \
1264 wxString CLASS::base_##CBNAME() const { \
1265 return PCLASS::CBNAME(); \
1266 }
1267
1268//---------------------------------------------------------------------------
1269
1270#define DEC_PYCALLBACK_STRING__pure(CBNAME) \
1271 wxString CBNAME();
1272
1273#define IMP_PYCALLBACK_STRING__pure(CLASS, PCLASS, CBNAME) \
1274 wxString CLASS::CBNAME() { \
1275 wxString rval; \
1276 wxPyBeginBlockThreads(); \
1277 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1278 PyObject* ro; \
1279 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1280 if (ro) { \
1281 rval = Py2wxString(ro); \
1282 Py_DECREF(ro); \
1283 } \
1284 } \
1285 wxPyEndBlockThreads(); \
1286 return rval; \
1287 }
1288
1289//---------------------------------------------------------------------------
1290
1291#define DEC_PYCALLBACK_STRING__constpure(CBNAME) \
1292 wxString CBNAME() const;
1293
1294#define IMP_PYCALLBACK_STRING__constpure(CLASS, PCLASS, CBNAME) \
1295 wxString CLASS::CBNAME() const { \
1296 wxString rval; \
1297 wxPyBeginBlockThreads(); \
1298 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1299 PyObject* ro; \
1300 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1301 if (ro) { \
1302 rval = Py2wxString(ro); \
1303 Py_DECREF(ro); \
1304 } \
1305 } \
1306 wxPyEndBlockThreads(); \
1307 return rval; \
1308 }
1309
1310//---------------------------------------------------------------------------
1311
1312#define DEC_PYCALLBACK_BOOL_TAG_pure(CBNAME) \
1313 bool CBNAME(const wxHtmlTag& a); \
1314
1315
1316#define IMP_PYCALLBACK_BOOL_TAG_pure(CLASS, PCLASS, CBNAME) \
1317 bool CLASS::CBNAME(const wxHtmlTag& a) { \
1318 bool rval=FALSE; \
1319 wxPyBeginBlockThreads(); \
1320 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1321 PyObject* obj = wxPyConstructObject((void*)&a, wxT("wxHtmlTag"), 0); \
1322 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
1323 Py_DECREF(obj); \
1324 } \
1325 wxPyEndBlockThreads(); \
1326 return rval; \
1327 }
1328
1329//---------------------------------------------------------------------------
1330
1331#define DEC_PYCALLBACK__CELLINTINT(CBNAME) \
1332 void CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y); \
1333 void base_##CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y);
1334
1335#define IMP_PYCALLBACK__CELLINTINT(CLASS, PCLASS, CBNAME) \
1336 void CLASS::CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y) { \
1337 bool found; \
1338 wxPyBeginBlockThreads(); \
1339 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1340 PyObject* obj = wxPyConstructObject((void*)cell, wxT("wxHtmlCell"), 0); \
1341 wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(Oii)",obj,x,y)); \
1342 Py_DECREF(obj); \
1343 } \
1344 wxPyEndBlockThreads(); \
1345 if (! found) \
1346 PCLASS::CBNAME(cell, x, y); \
1347 } \
1348 void CLASS::base_##CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y) { \
1349 PCLASS::CBNAME(cell, x, y); \
1350 }
1351
1352
1353//---------------------------------------------------------------------------
1354
1355#define DEC_PYCALLBACK__CELLINTINTME(CBNAME) \
1356 void CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y, const wxMouseEvent& e); \
1357 void base_##CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y, const wxMouseEvent& e);
1358
1359#define IMP_PYCALLBACK__CELLINTINTME(CLASS, PCLASS, CBNAME) \
1360 void CLASS::CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y, const wxMouseEvent& e) { \
1361 bool found; \
1362 wxPyBeginBlockThreads(); \
1363 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1364 PyObject* obj = wxPyConstructObject((void*)cell, wxT("wxHtmlCell"), 0); \
1365 PyObject* o2 = wxPyConstructObject((void*)&e, wxT("wxMouseEvent"), 0); \
1366 wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(OiiO)",obj,x,y,o2)); \
1367 Py_DECREF(obj); \
1368 Py_DECREF(o2); \
1369 } \
1370 wxPyEndBlockThreads(); \
1371 if (! found) \
1372 PCLASS::CBNAME(cell, x, y, e); \
1373 } \
1374 void CLASS::base_##CBNAME(wxHtmlCell *cell, wxCoord x, wxCoord y, const wxMouseEvent& e) { \
1375 PCLASS::CBNAME(cell, x, y, e); \
1376 }
1377
1378
1379
1380//---------------------------------------------------------------------------
1381
1382#define DEC_PYCALLBACK___pure(CBNAME) \
1383 void CBNAME(); \
1384
1385
1386#define IMP_PYCALLBACK___pure(CLASS, PCLASS, CBNAME) \
1387 void CLASS::CBNAME() { \
1388 wxPyBeginBlockThreads(); \
1389 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) \
1390 wxPyCBH_callCallback(m_myInst, Py_BuildValue("()")); \
1391 wxPyEndBlockThreads(); \
1392 }
1393
1394//---------------------------------------------------------------------------
1395
1396#define DEC_PYCALLBACK_wxSize__pure(CBNAME) \
1397 wxSize CBNAME(); \
1398
1399
1400#define IMP_PYCALLBACK_wxSize__pure(CLASS, PCLASS, CBNAME) \
1401 wxSize CLASS::CBNAME() { \
1402 const char* errmsg = #CBNAME " should return a 2-tuple of integers or a wxSize object."; \
1403 wxSize rval(0,0); \
1404 wxPyBeginBlockThreads(); \
1405 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1406 PyObject* ro; \
1407 wxSize* ptr; \
1408 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1409 if (ro) { \
1410 if (! SWIG_GetPtrObj(ro, (void **)&ptr, "_wxSize_p")) \
1411 rval = *ptr; \
1412 else if (PySequence_Check(ro) && PyObject_Length(ro) == 2) { \
1413 PyObject* o1 = PySequence_GetItem(ro, 0); \
1414 PyObject* o2 = PySequence_GetItem(ro, 1); \
1415 if (PyNumber_Check(o1) && PyNumber_Check(o2)) \
1416 rval = wxSize(PyInt_AsLong(o1), PyInt_AsLong(o2)); \
1417 else \
1418 PyErr_SetString(PyExc_TypeError, errmsg); \
1419 Py_DECREF(o1); \
1420 Py_DECREF(o2); \
1421 } \
1422 else { \
1423 PyErr_SetString(PyExc_TypeError, errmsg); \
1424 } \
1425 Py_DECREF(ro); \
1426 } \
1427 } \
1428 wxPyEndBlockThreads(); \
1429 return rval; \
1430 }
1431
1432//---------------------------------------------------------------------------
1433
1434#define DEC_PYCALLBACK_BOOL_WXWIN(CBNAME) \
1435 bool CBNAME(wxWindow* a); \
1436 bool base_##CBNAME(wxWindow* a);
1437
1438
1439#define IMP_PYCALLBACK_BOOL_WXWIN(CLASS, PCLASS, CBNAME) \
1440 bool CLASS::CBNAME(wxWindow* a) { \
1441 bool rval=FALSE; \
1442 bool found; \
1443 wxPyBeginBlockThreads(); \
1444 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1445 PyObject* obj = wxPyMake_wxObject(a); \
1446 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
1447 Py_DECREF(obj); \
1448 } \
1449 wxPyEndBlockThreads(); \
1450 if (! found) \
1451 rval = PCLASS::CBNAME(a); \
1452 return rval; \
1453 } \
1454 bool CLASS::base_##CBNAME(wxWindow* a) { \
1455 return PCLASS::CBNAME(a); \
1456 }
1457
1458//---------------------------------------------------------------------------
1459
1460#define DEC_PYCALLBACK_VOID_WXWINBASE(CBNAME) \
1461 void CBNAME(wxWindowBase* a); \
1462 void base_##CBNAME(wxWindowBase* a);
1463
1464
1465#define IMP_PYCALLBACK_VOID_WXWINBASE(CLASS, PCLASS, CBNAME) \
1466 void CLASS::CBNAME(wxWindowBase* a) { \
1467 bool found; \
1468 wxPyBeginBlockThreads(); \
1469 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1470 PyObject* obj = wxPyMake_wxObject(a); \
1471 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
1472 Py_DECREF(obj); \
1473 } \
1474 wxPyEndBlockThreads(); \
1475 if (! found) \
1476 PCLASS::CBNAME(a); \
1477 } \
1478 void CLASS::base_##CBNAME(wxWindowBase* a) { \
1479 PCLASS::CBNAME(a); \
1480 }
1481
1482//---------------------------------------------------------------------------
1483
1484#define DEC_PYCALLBACK_BOOL_(CBNAME) \
1485 bool CBNAME(); \
1486 bool base_##CBNAME();
1487
1488
1489#define IMP_PYCALLBACK_BOOL_(CLASS, PCLASS, CBNAME) \
1490 bool CLASS::CBNAME() { \
1491 bool rval=FALSE; \
1492 bool found; \
1493 wxPyBeginBlockThreads(); \
1494 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
1495 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("()")); \
1496 wxPyEndBlockThreads(); \
1497 if (! found) \
1498 rval = PCLASS::CBNAME(); \
1499 return rval; \
1500 } \
1501 bool CLASS::base_##CBNAME() { \
1502 return PCLASS::CBNAME(); \
1503 }
1504
1505//---------------------------------------------------------------------------
1506
1507#define DEC_PYCALLBACK_BOOL_const(CBNAME) \
1508 bool CBNAME() const; \
1509 bool base_##CBNAME() const;
1510
1511
1512#define IMP_PYCALLBACK_BOOL_const(CLASS, PCLASS, CBNAME) \
1513 bool CLASS::CBNAME() const { \
1514 bool rval=FALSE; \
1515 bool found; \
1516 wxPyBeginBlockThreads(); \
1517 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
1518 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("()")); \
1519 wxPyEndBlockThreads(); \
1520 if (! found) \
1521 rval = PCLASS::CBNAME(); \
1522 return rval; \
1523 } \
1524 bool CLASS::base_##CBNAME() const { \
1525 return PCLASS::CBNAME(); \
1526 }
1527
1528//---------------------------------------------------------------------------
1529
1530#define DEC_PYCALLBACK_DR_2WXCDR(CBNAME) \
1531 wxDragResult CBNAME(wxCoord x, wxCoord y, wxDragResult def); \
1532 wxDragResult base_##CBNAME(wxCoord x, wxCoord y, wxDragResult def);
1533
1534
1535#define IMP_PYCALLBACK_DR_2WXCDR(CLASS, PCLASS, CBNAME) \
1536 wxDragResult CLASS::CBNAME(wxCoord a, wxCoord b, wxDragResult c) { \
1537 int rval=0; \
1538 bool found; \
1539 wxPyBeginBlockThreads(); \
1540 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
1541 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iii)", a,b,c));\
1542 wxPyEndBlockThreads(); \
1543 if (! found) \
1544 rval = PCLASS::CBNAME(a, b, c); \
1545 return (wxDragResult)rval; \
1546 } \
1547 wxDragResult CLASS::base_##CBNAME(wxCoord a, wxCoord b, wxDragResult c) { \
1548 return PCLASS::CBNAME(a, b, c); \
1549 }
1550
1551//---------------------------------------------------------------------------
1552
1553#define DEC_PYCALLBACK_FSF_FSSTRING_pure(CBNAME) \
1554 wxFSFile* CBNAME(wxFileSystem& fs, const wxString& location); \
1555
1556#define IMP_PYCALLBACK_FSF_FSSTRING_pure(CLASS, PCLASS, CBNAME) \
1557 wxFSFile* CLASS::CBNAME(wxFileSystem& a,const wxString& b) { \
1558 wxPyBeginBlockThreads(); \
1559 wxFSFile* rval=0; \
1560 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1561 PyObject* ro; \
1562 PyObject* obj = wxPyMake_wxObject(&a); \
1563 PyObject* s = wx2PyString(b); \
1564 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(OO)",\
1565 obj, s)); \
1566 if (ro) { \
1567 SWIG_GetPtrObj(ro, (void **)&rval, "_wxFSFILE_p"); \
1568 Py_DECREF(ro); \
1569 } \
1570 Py_DECREF(obj); \
1571 Py_DECREF(s); \
1572 } \
1573 wxPyEndBlockThreads(); \
1574 return rval; \
1575 };
1576
1577//---------------------------------------------------------------------------
1578
1579#define DEC_PYCALLBACK_BOOL_DR(CBNAME) \
1580 bool CBNAME(wxDragResult a); \
1581 bool base_##CBNAME(wxDragResult a);
1582
1583
1584#define IMP_PYCALLBACK_BOOL_DR(CLASS, PCLASS, CBNAME) \
1585 bool CLASS::CBNAME(wxDragResult a) { \
1586 bool rval=FALSE; \
1587 bool found; \
1588 wxPyBeginBlockThreads(); \
1589 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
1590 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(i)", a));\
1591 wxPyEndBlockThreads(); \
1592 if (! found) \
1593 rval = PCLASS::CBNAME(a); \
1594 return rval; \
1595 } \
1596 bool CLASS::base_##CBNAME(wxDragResult a) { \
1597 return PCLASS::CBNAME(a); \
1598 }
1599
1600//---------------------------------------------------------------------------
1601
1602#define DEC_PYCALLBACK_DR_2WXCDR_pure(CBNAME) \
1603 wxDragResult CBNAME(wxCoord x, wxCoord y, wxDragResult def);
1604
1605
1606#define IMP_PYCALLBACK_DR_2WXCDR_pure(CLASS, PCLASS, CBNAME) \
1607 wxDragResult CLASS::CBNAME(wxCoord a, wxCoord b, wxDragResult c) { \
1608 wxPyBeginBlockThreads(); \
1609 int rval=0; \
1610 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) \
1611 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iii)", a,b,c));\
1612 wxPyEndBlockThreads(); \
1613 return (wxDragResult)rval; \
1614 } \
1615
1616//---------------------------------------------------------------------------
1617
1618#define DEC_PYCALLBACK_BOOL_INTINTSTR_pure(CBNAME) \
1619 bool CBNAME(int a, int b, const wxString& c);
1620
1621#define IMP_PYCALLBACK_BOOL_INTINTSTR_pure(CLASS, PCLASS, CBNAME) \
1622 bool CLASS::CBNAME(int a, int b, const wxString& c) { \
1623 bool rval=FALSE; \
1624 wxPyBeginBlockThreads(); \
1625 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1626 PyObject* s = wx2PyString(c); \
1627 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(iiO)",a,b,s));\
1628 Py_DECREF(s); \
1629 } \
1630 wxPyEndBlockThreads(); \
1631 return rval; \
1632 } \
1633
1634//---------------------------------------------------------------------------
1635
1636#define DEC_PYCALLBACK_SIZET_(CBNAME) \
1637 size_t CBNAME(); \
1638 size_t base_##CBNAME();
1639
1640
1641#define IMP_PYCALLBACK_SIZET_(CLASS, PCLASS, CBNAME) \
1642 size_t CLASS::CBNAME() { \
1643 size_t rval=0; \
1644 bool found; \
1645 wxPyBeginBlockThreads(); \
1646 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) \
1647 rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("()")); \
1648 wxPyEndBlockThreads(); \
1649 if (! found) \
1650 rval = PCLASS::CBNAME(); \
1651 return rval; \
1652 } \
1653 size_t CLASS::base_##CBNAME() { \
1654 return PCLASS::CBNAME(); \
1655 }
1656
1657//---------------------------------------------------------------------------
1658
1659#define DEC_PYCALLBACK_DATAFMT_SIZET(CBNAME) \
1660 wxDataFormat CBNAME(size_t a); \
1661 wxDataFormat base_##CBNAME(size_t a);
1662
1663
1664#define IMP_PYCALLBACK_DATAFMT_SIZET(CLASS, PCLASS, CBNAME) \
1665 wxDataFormat CLASS::CBNAME(size_t a) { \
1666 wxDataFormat rval=0; \
1667 bool found; \
1668 wxPyBeginBlockThreads(); \
1669 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1670 PyObject* ro; \
1671 wxDataFormat* ptr; \
1672 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(i)", a)); \
1673 if (ro) { \
1674 if (! SWIG_GetPtrObj(ro, (void **)&ptr, "_wxDataFormat_p")) \
1675 rval = *ptr; \
1676 Py_DECREF(ro); \
1677 } \
1678 } \
1679 wxPyEndBlockThreads(); \
1680 if (! found) \
1681 rval = PCLASS::CBNAME(a); \
1682 return rval; \
1683 } \
1684 wxDataFormat CLASS::base_##CBNAME(size_t a) { \
1685 return PCLASS::CBNAME(a); \
1686 }
1687
1688//---------------------------------------------------------------------------
1689
1690#define DEC_PYCALLBACK__constany(CBNAME, Type) \
1691 void CBNAME(const Type& a); \
1692 void base_##CBNAME(const Type& a);
1693
1694
1695#define IMP_PYCALLBACK__constany(CLASS, PCLASS, CBNAME, Type) \
1696 void CLASS::CBNAME(const Type& a) { \
1697 bool found; \
1698 wxPyBeginBlockThreads(); \
1699 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1700 PyObject* obj = wxPyConstructObject((void*)&a, wxT(#Type), 0); \
1701 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
1702 Py_DECREF(obj); \
1703 } \
1704 wxPyEndBlockThreads(); \
1705 if (! found) \
1706 PCLASS::CBNAME(a); \
1707 } \
1708 void CLASS::base_##CBNAME(const Type& a) { \
1709 PCLASS::CBNAME(a); \
1710 }
1711
1712
1713//---------------------------------------------------------------------------
1714
1715#define DEC_PYCALLBACK__any(CBNAME, Type) \
1716 void CBNAME(Type& a); \
1717 void base_##CBNAME(Type& a);
1718
1719
1720#define IMP_PYCALLBACK__any(CLASS, PCLASS, CBNAME, Type) \
1721 void CLASS::CBNAME(Type& a) { \
1722 bool found; \
1723 wxPyBeginBlockThreads(); \
1724 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1725 PyObject* obj = wxPyConstructObject((void*)&a, wxT(#Type), 0); \
1726 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
1727 Py_DECREF(obj); \
1728 } \
1729 wxPyEndBlockThreads(); \
1730 if (! found) \
1731 PCLASS::CBNAME(a); \
1732 } \
1733 void CLASS::base_##CBNAME(Type& a) { \
1734 PCLASS::CBNAME(a); \
1735 }
1736
1737//---------------------------------------------------------------------------
1738
1739#define DEC_PYCALLBACK_bool_any(CBNAME, Type) \
1740 bool CBNAME(Type& a); \
1741 bool base_##CBNAME(Type& a);
1742
1743
1744#define IMP_PYCALLBACK_bool_any(CLASS, PCLASS, CBNAME, Type) \
1745 bool CLASS::CBNAME(Type& a) { \
1746 bool rv=FALSE; \
1747 bool found; \
1748 wxPyBeginBlockThreads(); \
1749 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1750 PyObject* obj = wxPyConstructObject((void*)&a, wxT(#Type), 0); \
1751 rv = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
1752 Py_DECREF(obj); \
1753 } \
1754 wxPyEndBlockThreads(); \
1755 if (! found) \
1756 rv = PCLASS::CBNAME(a); \
1757 return rv; \
1758 } \
1759 bool CLASS::base_##CBNAME(Type& a) { \
1760 return PCLASS::CBNAME(a); \
1761 }
1762
1763//---------------------------------------------------------------------------
1764
1765#define DEC_PYCALLBACK_bool_anypure(CBNAME, Type) \
1766 bool CBNAME(Type& a);
1767
1768
1769#define IMP_PYCALLBACK_bool_anypure(CLASS, PCLASS, CBNAME, Type) \
1770 bool CLASS::CBNAME(Type& a) { \
1771 bool rv=FALSE; \
1772 wxPyBeginBlockThreads(); \
1773 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1774 PyObject* obj = wxPyConstructObject((void*)&a, wxT(#Type), 0); \
1775 rv = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
1776 Py_DECREF(obj); \
1777 } \
1778 wxPyEndBlockThreads(); \
1779 return rv; \
1780 } \
1781
1782//---------------------------------------------------------------------------
1783
1784#define DEC_PYCALLBACK_STRING_LONGLONG(CBNAME) \
1785 wxString CBNAME(long a, long b) const; \
1786 wxString base_##CBNAME(long a, long b)const ;
1787
1788#define IMP_PYCALLBACK_STRING_LONGLONG(CLASS, PCLASS, CBNAME) \
1789 wxString CLASS::CBNAME(long a, long b) const { \
1790 wxString rval; \
1791 bool found; \
1792 wxPyBeginBlockThreads(); \
1793 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1794 PyObject* ro; \
1795 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(ll)",a,b)); \
1796 if (ro) { \
1797 rval = Py2wxString(ro); \
1798 Py_DECREF(ro); \
1799 } \
1800 } \
1801 wxPyEndBlockThreads(); \
1802 if (! found) \
1803 rval = PCLASS::CBNAME(a,b); \
1804 return rval; \
1805 } \
1806 wxString CLASS::base_##CBNAME(long a, long b) const { \
1807 return PCLASS::CBNAME(a,b); \
1808 }
1809
1810//---------------------------------------------------------------------------
1811
1812#define DEC_PYCALLBACK_INT_LONG(CBNAME) \
1813 int CBNAME(long a) const; \
1814 int base_##CBNAME(long a)const ;
1815
1816
1817#define IMP_PYCALLBACK_INT_LONG(CLASS, PCLASS, CBNAME) \
1818 int CLASS::CBNAME(long a) const { \
1819 int rval=-1; \
1820 bool found; \
1821 wxPyBeginBlockThreads(); \
1822 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1823 PyObject* ro; \
1824 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(l)",a)); \
1825 if (ro) { \
1826 rval = PyInt_AsLong(ro); \
1827 Py_DECREF(ro); \
1828 } \
1829 } \
1830 wxPyEndBlockThreads(); \
1831 if (! found) \
1832 rval = PCLASS::CBNAME(a); \
1833 return rval; \
1834 } \
1835 int CLASS::base_##CBNAME(long a) const { \
1836 return PCLASS::CBNAME(a); \
1837 }
1838
1839
1840//---------------------------------------------------------------------------
1841
1842#define DEC_PYCALLBACK_LISTATTR_LONG(CBNAME) \
1843 wxListItemAttr* CBNAME(long a) const; \
1844 wxListItemAttr* base_##CBNAME(long a);
1845
1846
1847#define IMP_PYCALLBACK_LISTATTR_LONG(CLASS, PCLASS, CBNAME) \
1848 wxListItemAttr *CLASS::CBNAME(long a) const { \
1849 wxListItemAttr *rval = NULL; \
1850 bool found; \
1851 wxPyBeginBlockThreads(); \
1852 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1853 PyObject* ro; \
1854 wxListItemAttr* ptr; \
1855 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(i)", a)); \
1856 if (ro) { \
1857 if (! SWIG_GetPtrObj(ro, (void **)&ptr, "_wxListItemAttr_p")) \
1858 rval = ptr; \
1859 Py_DECREF(ro); \
1860 } \
1861 } \
1862 wxPyEndBlockThreads(); \
1863 if (! found) \
1864 rval = PCLASS::CBNAME(a); \
1865 return rval; \
1866 } \
1867 wxListItemAttr *CLASS::base_##CBNAME(long a) { \
1868 return PCLASS::CBNAME(a); \
1869 }
1870
1871//---------------------------------------------------------------------------
1872
1873#define DEC_PYCALLBACK_BOOL_ME(CBNAME) \
1874 bool CBNAME(wxMouseEvent& e); \
1875 bool base_##CBNAME(wxMouseEvent& e);
1876
1877#define IMP_PYCALLBACK_BOOL_ME(CLASS, PCLASS, CBNAME) \
1878 bool CLASS::CBNAME(wxMouseEvent& e) { \
1879 bool rval=FALSE; \
1880 bool found; \
1881 wxPyBeginBlockThreads(); \
1882 if ((found = wxPyCBH_findCallback(m_myInst, #CBNAME))) { \
1883 PyObject* ro; \
1884 PyObject* obj = wxPyConstructObject((void*)&e, wxT("wxMouseEvent"), 0); \
1885 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(O)",obj)); \
1886 if (ro) { \
1887 rval = PyInt_AsLong(ro); \
1888 Py_DECREF(ro); \
1889 } \
1890 Py_DECREF(obj); \
1891 } \
1892 wxPyEndBlockThreads(); \
1893 if (! found) \
1894 return PCLASS::CBNAME(e); \
1895 return rval; \
1896 } \
1897 bool CLASS::base_##CBNAME(wxMouseEvent& e) { \
1898 return PCLASS::CBNAME(e); \
1899 }
1900
1901
1902//---------------------------------------------------------------------------
1903
1904#define DEC_PYCALLBACK_WIZPG__pure(CBNAME) \
1905 wxWizardPage* CBNAME() const;
1906
1907#define IMP_PYCALLBACK_WIZPG__pure(CLASS, PCLASS, CBNAME) \
1908 wxWizardPage* CLASS::CBNAME() const { \
1909 wxWizardPage* rv = NULL; \
1910 wxPyBeginBlockThreads(); \
1911 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1912 PyObject* ro; \
1913 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1914 if (ro) { \
1915 SWIG_GetPtrObj(ro, (void **)&rv, "_wxWizardPage_p"); \
1916 Py_DECREF(ro); \
1917 } \
1918 } \
1919 wxPyEndBlockThreads(); \
1920 return rv; \
1921 }
1922
1923//---------------------------------------------------------------------------
1924
1925#define DEC_PYCALLBACK_BITMAP__pure(CBNAME) \
1926 wxBitmap CBNAME() const;
1927
1928#define IMP_PYCALLBACK_BITMAP__pure(CLASS, PCLASS, CBNAME) \
1929 wxBitmap CLASS::CBNAME() const { \
1930 wxBitmap rv; \
1931 wxPyBeginBlockThreads(); \
1932 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1933 PyObject* ro; \
1934 wxBitmap* ptr; \
1935 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1936 if (ro) { \
1937 if (! SWIG_GetPtrObj(ro, (void **)&ptr, "_wxBitmap_p")) \
1938 rv = *ptr; \
1939 Py_DECREF(ro); \
1940 } \
1941 } \
1942 wxPyEndBlockThreads(); \
1943 return rv; \
1944 }
1945
1946//---------------------------------------------------------------------------
1947
1948#define DEC_PYCALLBACK_OBJECT__pure(CBNAME) \
1949 wxObject* CBNAME();
1950
1951#define IMP_PYCALLBACK_OBJECT__pure(CLASS, PCLASS, CBNAME) \
1952 wxObject* CLASS::CBNAME() { \
1953 wxObject* rv = NULL; \
1954 wxPyBeginBlockThreads(); \
1955 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1956 PyObject* ro; \
1957 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("()")); \
1958 if (ro) { \
1959 SWIG_GetPtrObj(ro, (void **)&rv, "_wxObject_p"); \
1960 Py_DECREF(ro); \
1961 } \
1962 } \
1963 wxPyEndBlockThreads(); \
1964 return rv; \
1965 }
1966
1967//---------------------------------------------------------------------------
1968
1969#define DEC_PYCALLBACK_OBJECT_STRING_pure(CBNAME) \
1970 wxObject* CBNAME(const wxString& a);
1971
1972#define IMP_PYCALLBACK_OBJECT_STRING_pure(CLASS, PCLASS, CBNAME) \
1973 wxObject* CLASS::CBNAME(const wxString& a) { \
1974 wxObject* rv = NULL; \
1975 wxPyBeginBlockThreads(); \
1976 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
1977 PyObject* so = wx2PyString(a); \
1978 PyObject* ro; \
1979 ro = wxPyCBH_callCallbackObj(m_myInst, Py_BuildValue("(O)", so)); \
1980 if (ro) { \
1981 SWIG_GetPtrObj(ro, (void **)&rv, "_wxObject_p"); \
1982 Py_DECREF(ro); \
1983 } \
1984 Py_DECREF(so); \
1985 } \
1986 wxPyEndBlockThreads(); \
1987 return rv; \
1988 }
1989
1990//---------------------------------------------------------------------------
1991
1992#define DEC_PYCALLBACK_BOOL_NODE_pure(CBNAME) \
1993 bool CBNAME(wxXmlNode* a);
1994
1995
1996#define IMP_PYCALLBACK_BOOL_NODE_pure(CLASS, PCLASS, CBNAME) \
1997 bool CLASS::CBNAME(wxXmlNode* a) { \
1998 bool rv=FALSE; \
1999 wxPyBeginBlockThreads(); \
2000 if (wxPyCBH_findCallback(m_myInst, #CBNAME)) { \
2001 PyObject* obj = wxPyConstructObject((void*)a, wxT("wxXmlNode"), 0); \
2002 rv = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", obj)); \
2003 Py_DECREF(obj); \
2004 } \
2005 wxPyEndBlockThreads(); \
2006 return rv; \
2007 } \
2008
2009//---------------------------------------------------------------------------
2010#endif