forked from teamnwah/openmw-tes3coop
Remove document when closing the last view. Should resolve Bug #1292.
This commit is contained in:
parent
ad8d722763
commit
84f5784575
3 changed files with 14 additions and 4 deletions
|
@ -24,6 +24,11 @@ void CSVDoc::View::closeEvent (QCloseEvent *event)
|
|||
{
|
||||
if (!mViewManager.closeRequest (this))
|
||||
event->ignore();
|
||||
else
|
||||
{
|
||||
// closeRequest() returns true if last document
|
||||
mViewManager.removeDocument(mDocument);
|
||||
}
|
||||
}
|
||||
|
||||
void CSVDoc::View::setupFileMenu()
|
||||
|
|
|
@ -192,6 +192,12 @@ bool CSVDoc::ViewManager::closeRequest (View *view)
|
|||
return continueWithClose;
|
||||
}
|
||||
|
||||
void CSVDoc::ViewManager::removeDocument (CSMDoc::Document *document)
|
||||
{
|
||||
if(document)
|
||||
mDocumentManager.removeDocument(document);
|
||||
}
|
||||
|
||||
bool CSVDoc::ViewManager::notifySaveOnClose (CSVDoc::View *view)
|
||||
{
|
||||
bool result = true;
|
||||
|
@ -349,8 +355,7 @@ void CSVDoc::ViewManager::exitApplication (CSVDoc::View *view)
|
|||
else
|
||||
{
|
||||
CSMDoc::Document * document = view->getDocument();
|
||||
if(document)
|
||||
mDocumentManager.removeDocument(document);
|
||||
removeDocument(document);
|
||||
view->setVisible(false);
|
||||
|
||||
// attempt to close all other documents
|
||||
|
@ -364,8 +369,7 @@ void CSVDoc::ViewManager::exitApplication (CSVDoc::View *view)
|
|||
else
|
||||
{
|
||||
document = mViews.back()->getDocument();
|
||||
if(document)
|
||||
mDocumentManager.removeDocument(document);
|
||||
removeDocument(document);
|
||||
mViews.back()->setVisible(false);
|
||||
mViews.pop_back();
|
||||
}
|
||||
|
|
|
@ -55,6 +55,7 @@ namespace CSVDoc
|
|||
///< Return number of views for \a document.
|
||||
|
||||
bool closeRequest (View *view);
|
||||
void removeDocument (CSMDoc::Document *document);
|
||||
|
||||
signals:
|
||||
|
||||
|
|
Loading…
Reference in a new issue