]> git.saurik.com Git - wxWidgets.git/blobdiff - src/common/docmdi.cpp
Committing modified version of jwiesemann's patch (see #11223):
[wxWidgets.git] / src / common / docmdi.cpp
index 4a9857983f84df5d1b5e134aa801af64287026e5..c8911d606ade00fac77d21b670060ab02946e503 100644 (file)
@@ -9,10 +9,6 @@
 // Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
-#ifdef __GNUG__
-#pragma implementation "docmdi.h"
-#endif
-
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
@@ -36,157 +32,62 @@ BEGIN_EVENT_TABLE(wxDocMDIParentFrame, wxMDIParentFrame)
     EVT_CLOSE(wxDocMDIParentFrame::OnCloseWindow)
 END_EVENT_TABLE()
 
-wxDocMDIParentFrame::wxDocMDIParentFrame(wxDocManager *manager, wxFrame *frame, wxWindowID id, const wxString& title,
-  const wxPoint& pos, const wxSize& size, long style, const wxString& name):
-  wxMDIParentFrame(frame, id, title, pos, size, style, name)
-{
-  m_docManager = manager;
-}
-
-void wxDocMDIParentFrame::OnExit(wxCommandEvent& WXUNUSED(event))
-{
-    Close();
-}
-
-void wxDocMDIParentFrame::OnMRUFile(wxCommandEvent& event)
-{
-      wxString f(m_docManager->GetHistoryFile(event.GetId() - wxID_FILE1));
-      if (f != wxT(""))
-        (void)m_docManager->CreateDocument(f, wxDOC_SILENT);
-}
-
-// Extend event processing to search the view's event table
-bool wxDocMDIParentFrame::ProcessEvent(wxEvent& event)
-{
-    // Try the document manager, then do default processing
-    if (!m_docManager || !m_docManager->ProcessEvent(event))
-        return wxEvtHandler::ProcessEvent(event);
-    else
-        return TRUE;
-}
-
-void wxDocMDIParentFrame::OnCloseWindow(wxCloseEvent& event)
+wxDocMDIParentFrame::wxDocMDIParentFrame()
 {
-  if (m_docManager->Clear(!event.CanVeto()))
-  {
-    this->Destroy();
-  }
-  else
-    event.Veto();
-}
-
-
-/*
- * Default document child frame for MDI children
- */
-
-IMPLEMENT_CLASS(wxDocMDIChildFrame, wxMDIChildFrame)
-
-BEGIN_EVENT_TABLE(wxDocMDIChildFrame, wxMDIChildFrame)
-    EVT_ACTIVATE(wxDocMDIChildFrame::OnActivate)
-    EVT_CLOSE(wxDocMDIChildFrame::OnCloseWindow)
-END_EVENT_TABLE()
-
-void wxDocMDIChildFrame::Init()
-{
-    m_childDocument = (wxDocument*)  NULL;
-    m_childView = (wxView*) NULL;
+    Init();
 }
 
-wxDocMDIChildFrame::wxDocMDIChildFrame()
+wxDocMDIParentFrame::wxDocMDIParentFrame(wxDocManager *manager, wxFrame *frame, wxWindowID id, const wxString& title,
+  const wxPoint& pos, const wxSize& size, long style, const wxString& name)
 {
     Init();
+    Create(manager, frame, id, title, pos, size, style, name);
 }
 
-wxDocMDIChildFrame::wxDocMDIChildFrame(wxDocument *doc, wxView *view, wxMDIParentFrame *frame, wxWindowID  id,
-  const wxString& title, const wxPoint& pos, const wxSize& size, long style, const wxString& name)
+bool wxDocMDIParentFrame::Create(wxDocManager *manager, wxFrame *frame, wxWindowID id, const wxString& title,
+  const wxPoint& pos, const wxSize& size, long style, const wxString& name)
 {
-    Init();
-    Create(doc, view, frame, id, title, pos, size, style, name);
+    m_docManager = manager;
+    return wxMDIParentFrame::Create(frame, id, title, pos, size, style, name);
 }
 
-bool wxDocMDIChildFrame::Create(wxDocument *doc, wxView *view, wxMDIParentFrame *frame, wxWindowID  id,
-  const wxString& title, const wxPoint& pos, const wxSize& size, long style, const wxString& name)
+void wxDocMDIParentFrame::OnExit(wxCommandEvent& WXUNUSED(event))
 {
-  m_childDocument = doc;
-  m_childView = view;
-    if (wxMDIChildFrame::Create(frame, id, title, pos, size, style, name)) {
-  if (view)
-    view->SetFrame(this);
-        return TRUE;
-    }
-
-    return FALSE;
+    Close();
 }
 
-wxDocMDIChildFrame::~wxDocMDIChildFrame(void)
+void wxDocMDIParentFrame::Init()
 {
-       m_childView = (wxView *) NULL;
+    m_docManager = NULL;
 }
 
-// Extend event processing to search the view's event table
-bool wxDocMDIChildFrame::ProcessEvent(wxEvent& event)
+void wxDocMDIParentFrame::OnMRUFile(wxCommandEvent& event)
 {
-    static wxEvent *ActiveEvent = NULL;
-
-    // Break recursion loops
-    if (ActiveEvent == &event)
-        return FALSE;
-
-    ActiveEvent = &event;
-
-    bool ret;
-       if ( !m_childView || ! m_childView->ProcessEvent(event) )
-    {
-        // Only hand up to the parent if it's a menu command
-        if (!event.IsKindOf(CLASSINFO(wxCommandEvent)) || !GetParent() || !GetParent()->ProcessEvent(event))
-            ret = wxEvtHandler::ProcessEvent(event);
-        else
-            ret = TRUE;
-    }
-       else
-        ret = TRUE;
-
-    ActiveEvent = NULL;
-    return ret;
+    wxString f(m_docManager->GetHistoryFile(event.GetId() - wxID_FILE1));
+    if (!f.empty())
+        (void)m_docManager->CreateDocument(f, wxDOC_SILENT);
 }
 
-void wxDocMDIChildFrame::OnActivate(wxActivateEvent& event)
+bool wxDocMDIParentFrame::TryBefore(wxEvent& event)
 {
-  wxMDIChildFrame::OnActivate(event);
+    if ( m_docManager && m_docManager->ProcessEventHere(event) )
+        return true;
 
-  if (event.GetActive() && m_childView)
-    m_childView->Activate(event.GetActive());
+    return wxMDIParentFrame::TryBefore(event);
 }
 
-void wxDocMDIChildFrame::OnCloseWindow(wxCloseEvent& event)
+void wxDocMDIParentFrame::OnCloseWindow(wxCloseEvent& event)
 {
-  // Close view but don't delete the frame while doing so!
-  // ...since it will be deleted by wxWindows if we return TRUE.
-  if (m_childView)
+  if (m_docManager->Clear(!event.CanVeto()))
   {
-    bool ans = FALSE;
-    if (!event.CanVeto())
-      ans = TRUE; // Must delete.
-    else
-      ans = m_childView->Close(FALSE); // FALSE means don't delete associated window
-
-    if (ans)
-    {
-      m_childView->Activate(FALSE);
-      delete m_childView;
-      m_childView = (wxView *) NULL;
-      m_childDocument = (wxDocument *) NULL;
-
-      this->Destroy();
-    }
-    else
-        event.Veto();
+    this->Destroy();
   }
   else
     event.Veto();
 }
 
-#endif
-    // wxUSE_DOC_VIEW_ARCHITECTURE
+
+IMPLEMENT_CLASS(wxDocMDIChildFrame, wxMDIChildFrame)
+
+#endif // wxUSE_DOC_VIEW_ARCHITECTURE