]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/contrib/glcanvas/glcanvas.i
SWIG patch for "autodoc" and "docstring" %features
[wxWidgets.git] / wxPython / contrib / glcanvas / glcanvas.i
index 3b15de59f96d5dcf1dbf1c298fccc66673ce77d3..826f0c071f2416c26db5336214b722eb8f81694e 100644 (file)
 %module glcanvas
 
 %{
 %module glcanvas
 
 %{
-#include "wxPython.h"
-#ifdef __WXMSW__
-#include "myglcanvas.h"
-#else
+#include "wx/wxPython/wxPython.h"
+#include "wx/wxPython/pyclasses.h"
+
 #include <wx/glcanvas.h>
 #include <wx/glcanvas.h>
-#endif
 
 
+    static const wxString wxPyGLCanvasNameStr(wxT("GLCanvas"));
+    static const wxString wxPyEmptyString(wxT(""));
 %}
 
 //---------------------------------------------------------------------------
 
 %}
 
 //---------------------------------------------------------------------------
 
-%include typemaps.i
-%include my_typemaps.i
-
-%extern wx.i
-%extern windows.i
-%extern windows2.i
-%extern windows3.i
-%extern frames.i
-%extern _defs.i
-%extern misc.i
-%extern gdi.i
-%extern controls.i
-%extern events.i
-
-
-%pragma(python) code = "import wx"
-
-//----------------------------------------------------------------------
+%import core.i
+%pythoncode { wx = core }
 
 
-%{
-    // Put some wx default wxChar* values into wxStrings.
-    static const wxString wxPyGLCanvasNameStr(wxT("GLCanvas"));
-    static const wxString wxPyEmptyString(wxT(""));
-%}
+%include _glcanvas_rename.i
 
 //---------------------------------------------------------------------------
 
 class wxPalette;
 
 //---------------------------------------------------------------------------
 
 class wxPalette;
-class wxWindow;
-class wxSize;
-class wxPoint;
-class wxGLCanvas;
 
 //---------------------------------------------------------------------------
 
 class wxGLContext : public wxObject {
 public:
 
 //---------------------------------------------------------------------------
 
 class wxGLContext : public wxObject {
 public:
-#ifndef __WXMAC__  //  fix this?
+#ifndef __WXMAC__  
     wxGLContext(bool isRGB, wxGLCanvas *win,
     wxGLContext(bool isRGB, wxGLCanvas *win,
-                const wxPalette& palette = wxNullPalette);
+                const wxPalette& palette = wxNullPalette,
+                const wxGLContext* other = NULL);
+#else
+    %extend {
+        wxGLContext(bool isRGB, wxGLCanvas *win,
+                    const wxPalette& palette = wxNullPalette,
+                    const wxGLContext* other = NULL) {
+            AGLPixelFormat fmt;  // TODO: How should this be initialized?
+            return new wxGLContext(fmt, win, palette, other);
+        }
+    }
+
 #endif
     ~wxGLContext();
 
     void SetCurrent();
 #endif
     ~wxGLContext();
 
     void SetCurrent();
-    void SetColour(const char *colour);
+    void SetColour(const wxString& colour);
     void SwapBuffers();
 
 #ifdef __WXGTK__
     void SwapBuffers();
 
 #ifdef __WXGTK__
@@ -104,28 +91,29 @@ enum {
 };
 
 
 };
 
 
-%typemap(python, in) int *attribList (int *temp) {
+%typemap(in) int *attribList (int *temp) {
     int i;
     int i;
-    if (PySequence_Check($source)) {
-        int size = PyObject_Length($source);
+    if (PySequence_Check($input)) {
+        int size = PyObject_Length($input);
         temp = new int[size+1]; // (int*)malloc((size + 1) * sizeof(int));
         for (i = 0; i < size; i++) {
         temp = new int[size+1]; // (int*)malloc((size + 1) * sizeof(int));
         for (i = 0; i < size; i++) {
-            temp[i] = PyInt_AsLong(PySequence_GetItem($source, i));
+            temp[i] = PyInt_AsLong(PySequence_GetItem($input, i));
         }
         temp[size] = 0;
         }
         temp[size] = 0;
-        $target = temp;
+        $1 = temp;
     }
 }
 
     }
 }
 
-%typemap(python, freearg) int *attribList
+%typemap(freearg) int *attribList
 {
 {
-    delete [] $source;
+    delete [] $1;
 }
 
 
 
 class wxGLCanvas : public wxWindow {
 public:
 }
 
 
 
 class wxGLCanvas : public wxWindow {
 public:
+    %addtofunc wxGLCanvas   "self._setOORInfo(self)"
     wxGLCanvas(wxWindow *parent, wxWindowID id = -1,
                const wxPoint& pos = wxDefaultPosition,
                const wxSize& size = wxDefaultSize, long style = 0,
     wxGLCanvas(wxWindow *parent, wxWindowID id = -1,
                const wxPoint& pos = wxDefaultPosition,
                const wxSize& size = wxDefaultSize, long style = 0,
@@ -133,6 +121,7 @@ public:
                int *attribList = NULL,
                const wxPalette& palette = wxNullPalette);
 
                int *attribList = NULL,
                const wxPalette& palette = wxNullPalette);
 
+    %addtofunc wxGLCanvas   "val._setOORInfo(val)"
     %name(wxGLCanvasWithContext)
         wxGLCanvas( wxWindow *parent,
                     const wxGLContext *shared = NULL,
     %name(wxGLCanvasWithContext)
         wxGLCanvas( wxWindow *parent,
                     const wxGLContext *shared = NULL,
@@ -144,14 +133,9 @@ public:
                     int *attribList = NULL,
                     const wxPalette& palette = wxNullPalette );
 
                     int *attribList = NULL,
                     const wxPalette& palette = wxNullPalette );
 
-//      bool Create(wxWindow *parent, wxWindowID id,
-//                  const wxPoint& pos, const wxSize& size, long style, const wxString& name);
-
-    %pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
-    %pragma(python) addtomethod = "wxGLCanvasWithContext:val._setOORInfo(self)"
 
     void SetCurrent();
 
     void SetCurrent();
-    void SetColour(const char *colour);
+    void SetColour(const wxString& colour);
     void SwapBuffers();
 
     wxGLContext* GetContext();
     void SwapBuffers();
 
     wxGLContext* GetContext();
@@ -169,9 +153,6 @@ public:
 
 %init %{
 
 
 %init %{
 
-    wxClassInfo::CleanUpClasses();
-    wxClassInfo::InitializeClasses();
-
 %}
 
 //---------------------------------------------------------------------------
 %}
 
 //---------------------------------------------------------------------------