From: Harco de Hilster Date: Wed, 21 Jul 1999 21:21:01 +0000 (+0000) Subject: Minor and silly fix. X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/5d55595cb67337c56f02e26db2bd51f514af0d9a Minor and silly fix. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3081 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/samples/minifram/test.cpp b/samples/minifram/test.cpp index e7ee047849..a6d0889355 100644 --- a/samples/minifram/test.cpp +++ b/samples/minifram/test.cpp @@ -44,6 +44,7 @@ IMPLEMENT_APP(MyApp) MyMainFrame *main_frame = (MyMainFrame*) NULL; MyMiniFrame *mini_frame = (MyMiniFrame*) NULL; +bool mini_frame_exists = FALSE; wxButton *button = (wxButton*) NULL; // The `main program' equivalent, creating the windows and returning the @@ -53,6 +54,7 @@ bool MyApp::OnInit(void) // Create the mini frame window mini_frame = new MyMiniFrame((wxFrame *) NULL, -1, "wxMiniFrame sample", wxPoint(100, 100), wxSize(205, 100)); + mini_frame_exists = TRUE; mini_frame->CreateToolBar(wxNO_BORDER|wxHORIZONTAL|wxTB_FLAT, ID_TOOLBAR); InitToolbar(mini_frame->GetToolBar()); @@ -163,6 +165,8 @@ MyMiniFrame::MyMiniFrame(wxFrame* parent, wxWindowID id, const wxString& title, void MyMiniFrame::OnCloseWindow(wxCloseEvent& WXUNUSED(event)) { + // make it known that the miniframe is no more + mini_frame_exists = FALSE; Destroy(); } @@ -191,7 +195,14 @@ void MyMainFrame::OnCloseWindow(wxCloseEvent& WXUNUSED(event)) void MyMainFrame::OnReparent(wxCommandEvent& WXUNUSED(event)) { - button->Reparent( mini_frame ); + // practical jokers might find satisfaction in reparenting the button + // after closing the mini_frame. We'll have the last laugh. + if (! mini_frame_exists) + wxMessageBox("The miniframe no longer exists.\n" + "You don't want to make this button an orphan, do you?", + "You got to be kidding"); + else + button->Reparent( mini_frame ); }