]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/src/_menu.i
reswigged
[wxWidgets.git] / wxPython / src / _menu.i
index 1bbb3a56e403fc8a81a0efce67a41f6f76a31ee6..c19a3048623ca14d70272eba224649db959ac912 100644 (file)
@@ -133,8 +133,19 @@ public:
     // deleting it!)
     %newobject Remove;
     wxMenuItem *Remove(int id);
-    %Rename(RemoveItem,  wxMenuItem*, Remove(wxMenuItem *item));
 
+    %feature("shadow") Remove(wxMenuItem *item) %{
+        def RemoveItem(self, item):
+            """RemoveItem(self, MenuItem item) -> MenuItem"""
+            #// The return object is always the parameter, so return that 
+            #// proxy instead of the new one
+            val = _core_.Menu_RemoveItem(self, item)
+            item.this.own(val.this.own())
+            val.this.disown()
+            return item
+    %}
+    %Rename(RemoveItem,  wxMenuItem*, Remove(wxMenuItem *item));
+    
     // delete an item from the menu (submenus are not destroyed by this
     // function, see Destroy)
     bool Delete(int id);
@@ -369,7 +380,7 @@ public:
     // turn off this typemap
     %typemap(out) wxMenuItem*;    
 
-    wxMenuItem(wxMenu* parentMenu=NULL, int id=wxID_ANY,
+    wxMenuItem(wxMenu* parentMenu=NULL, int id=wxID_SEPARATOR,
                const wxString& text = wxPyEmptyString,
                const wxString& help = wxPyEmptyString,
                wxItemKind kind = wxITEM_NORMAL,
@@ -377,7 +388,10 @@ public:
     ~wxMenuItem();
 
     // Turn it back on again
-    %typemap(out) wxEvtHandler* { $result = wxPyMake_wxObject($1, $owner); }
+    %typemap(out) wxMenuItem* { $result = wxPyMake_wxObject($1, $owner); }
+
+    // Make Destroy a NOP.  The destruction will be handled by SWIG.
+    %pythoncode { def Destroy(self): pass }
 
     
     // the menu we're in