From: Robert Roebling Date: Wed, 25 Oct 2006 17:51:28 +0000 (+0000) Subject: Prevent accession of to-be-deleted mdi X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/3811dacb398d9fdf89440fdf61991776412bb1e4 Prevent accession of to-be-deleted mdi child window. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@42403 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/include/wx/gtk/mdi.h b/include/wx/gtk/mdi.h index 4338c2c39f..051987ad7e 100644 --- a/include/wx/gtk/mdi.h +++ b/include/wx/gtk/mdi.h @@ -150,6 +150,8 @@ public: virtual bool IsTopLevel() const { return false; } + virtual bool Destroy(); + void OnActivate( wxActivateEvent& event ); void OnMenuHighlight( wxMenuEvent& event ); diff --git a/src/gtk/mdi.cpp b/src/gtk/mdi.cpp index 031eae9e19..bcbaad2c53 100644 --- a/src/gtk/mdi.cpp +++ b/src/gtk/mdi.cpp @@ -250,19 +250,24 @@ wxMDIChildFrame *wxMDIParentFrame::GetActiveChild() const gint i = gtk_notebook_get_current_page( notebook ); if (i < 0) return (wxMDIChildFrame*) NULL; - + GtkNotebookPage* page = (GtkNotebookPage*) (g_list_nth(notebook->children,i)->data); if (!page) return (wxMDIChildFrame*) NULL; wxWindowList::compatibility_iterator node = m_clientWindow->GetChildren().GetFirst(); while (node) { + if ( wxPendingDelete.Member(node->GetData()) ) + return (wxMDIChildFrame*) NULL; + wxMDIChildFrame *child_frame = wxDynamicCast( node->GetData(), wxMDIChildFrame ); - wxASSERT_MSG( child_frame, _T("child is not a wxMDIChildFrame") ); + if (!child_frame) + return (wxMDIChildFrame*) NULL; if (child_frame->m_page == page) return child_frame; + node = node->GetNext(); } @@ -335,6 +340,19 @@ bool wxMDIChildFrame::Create( wxMDIParentFrame *parent, return wxWindow::Create( parent->GetClientWindow(), id, wxDefaultPosition, size, style, name ); } +bool wxMDIChildFrame::Destroy() +{ + // delayed destruction: the frame will be deleted during + // the next idle loop iteration. + // I'm not sure if delayed destruction really makes so + // much sense for MDI child frames, actually, but hiding + // it doesn't make any sense. + if ( !wxPendingDelete.Member(this) ) + wxPendingDelete.Append(this); + + return true; +} + void wxMDIChildFrame::DoSetSize( int x, int y, int width, int height, int sizeFlags ) { wxWindow::DoSetSize( x, y, width, height, sizeFlags );