X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4acff284f9516e2a4f0fcfa7bcfa3f497b8005cc..2fa9ab8174120441e96d8e1031a57fb6ffd34441:/wxPython/contrib/ogl/ogl.i diff --git a/wxPython/contrib/ogl/ogl.i b/wxPython/contrib/ogl/ogl.i index dfa1a664a2..2bf13628ec 100644 --- a/wxPython/contrib/ogl/ogl.i +++ b/wxPython/contrib/ogl/ogl.i @@ -14,30 +14,47 @@ %module ogl %{ -#include "export.h" +#include "wx/wxPython/wxPython.h" +#include "wx/wxPython/pyclasses.h" #include "oglhelpers.h" + + + static const wxString wxPyEmptyString(wxT("")); %} //--------------------------------------------------------------------------- -%include typemaps.i -%include my_typemaps.i - -%extern wx.i %import windows.i -%extern _defs.i -%extern misc.i -%extern gdi.i -%include _ogldefs.i +%pythoncode { wx = core } -%import oglbasic.i -%import oglshapes.i -%import oglshapes2.i -%import oglcanvas.i +%include _ogl_rename.i +%include _ogldefs.i +%include _oglbasic.i +%include _oglshapes.i +%include _oglshapes2.i +%include _oglcanvas.i + +%pythoncode { +%# Aliases +ShapeCanvas = PyShapeCanvas +ShapeEvtHandler = PyShapeEvtHandler +Shape = PyShape +RectangleShape = PyRectangleShape +BitmapShape = PyBitmapShape +DrawnShape = PyDrawnShape +CompositeShape = PyCompositeShape +DividedShape = PyDividedShape +DivisionShape = PyDivisionShape +EllipseShape = PyEllipseShape +CircleShape = PyCircleShape +LineShape = PyLineShape +PolygonShape = PyPolygonShape +TextShape = PyTextShape +ControlPoint = PyControlPoint +} -%pragma(python) code = "import wx" //--------------------------------------------------------------------------- @@ -135,10 +152,11 @@ void wxOGLCleanUp(); %{ //--------------------------------------------------------------------------- -// This one will work for any class for the VERY generic cases, but beyond that -// the helper needs to know more about the type. -wxList* wxPy_wxListHelper(PyObject* pyList, char* className) { +// Convert from a Python list to a list of className objects. This one will +// work for any class for the VERY generic cases, but beyond that the helper +// needs to know more about the type. +wxList* wxPy_wxListHelper(PyObject* pyList, const wxChar* className) { wxPyBeginBlockThreads(); if (!PyList_Check(pyList)) { PyErr_SetString(PyExc_TypeError, "Expected a list object."); @@ -156,10 +174,10 @@ wxList* wxPy_wxListHelper(PyObject* pyList, char* className) { PyObject* pyo = PyList_GetItem(pyList, x); wxObject* wxo = NULL; - if (SWIG_GetPtrObj(pyo, (void **)&wxo, className)) { - char errmsg[1024]; - sprintf(errmsg, "Type error, expected list of %s objects", className); - PyErr_SetString(PyExc_TypeError, errmsg); + if ( !wxPyConvertSwigPtr(pyo, (void **)&wxo, className) ) { + wxString errmsg; + errmsg.Printf(wxT("Type error, expected list of %s objects"), className); + PyErr_SetString(PyExc_TypeError, errmsg.mb_str()); wxPyEndBlockThreads(); return NULL; } @@ -199,7 +217,7 @@ wxList* wxPy_wxRealPoint_ListHelper(PyObject* pyList) { } else { wxRealPoint* wxo = NULL; - if (SWIG_GetPtrObj(pyo, (void **)&wxo, "_wxRealPoint_p")) { + if (wxPyConvertSwigPtr(pyo, (void **)&wxo, wxT("wxRealPoint"))) { PyErr_SetString(PyExc_TypeError, "Type error, expected list of wxRealPoint objects or 2-tuples"); wxPyEndBlockThreads(); return NULL; @@ -235,6 +253,26 @@ PyObject* wxPyMake_wxShapeEvtHandler(wxShapeEvtHandler* source) { return target; } +//--------------------------------------------------------------------------- + +PyObject* wxPy_ConvertShapeList(wxListBase* listbase) { + wxList* list = (wxList*)listbase; + PyObject* pyList; + PyObject* pyObj; + wxObject* wxObj; + wxNode* node = list->GetFirst(); + + wxPyBeginBlockThreads(); + pyList = PyList_New(0); + while (node) { + wxObj = node->GetData(); + pyObj = wxPyMake_wxShapeEvtHandler((wxShapeEvtHandler*)wxObj); + PyList_Append(pyList, pyObj); + node = node->GetNext(); + } + wxPyEndBlockThreads(); + return pyList; +} //--------------------------------------------------------------------------- @@ -257,24 +295,21 @@ IMPLEMENT_DYNAMIC_CLASS(wxPyTextShape, wxTextShape); //--------------------------------------------------------------------------- -extern "C" SWIGEXPORT(void) initoglbasicc(); -extern "C" SWIGEXPORT(void) initoglshapesc(); -extern "C" SWIGEXPORT(void) initoglshapes2c(); -extern "C" SWIGEXPORT(void) initoglcanvasc(); +// extern "C" SWIGEXPORT(void) initoglbasicc(); +// extern "C" SWIGEXPORT(void) initoglshapesc(); +// extern "C" SWIGEXPORT(void) initoglshapes2c(); +// extern "C" SWIGEXPORT(void) initoglcanvasc(); %} %init %{ - initoglbasicc(); - initoglshapesc(); - initoglshapes2c(); - initoglcanvasc(); +// initoglbasicc(); +// initoglshapesc(); +// initoglshapes2c(); +// initoglcanvasc(); - wxClassInfo::CleanUpClasses(); - wxClassInfo::InitializeClasses(); - wxPyPtrTypeMap_Add("wxControlPoint", "wxPyControlPoint"); wxPyPtrTypeMap_Add("wxShapeCanvas", "wxPyShapeCanvas"); wxPyPtrTypeMap_Add("wxShapeEvtHandler", "wxPyShapeEvtHandler"); @@ -292,11 +327,5 @@ extern "C" SWIGEXPORT(void) initoglcanvasc(); %} -//---------------------------------------------------------------------- -// And this gets appended to the shadow class file. -//---------------------------------------------------------------------- - -%pragma(python) include="_oglextras.py"; - //--------------------------------------------------------------------------- //---------------------------------------------------------------------------