From fab352c81ce8be5b84826c4496ac16cf7e0c9056 Mon Sep 17 00:00:00 2001 From: Arin Alexander Date: Thu, 21 Apr 2016 17:53:31 +0300 Subject: [PATCH] Fix #30 Destroying a report engine does not destroy all it's windows and lead to crash --- limereport/lrreportengine.cpp | 27 +++++++++++++++++++-------- limereport/lrreportengine_p.h | 2 ++ 2 files changed, 21 insertions(+), 8 deletions(-) diff --git a/limereport/lrreportengine.cpp b/limereport/lrreportengine.cpp index 81d0fb8..06793af 100644 --- a/limereport/lrreportengine.cpp +++ b/limereport/lrreportengine.cpp @@ -67,6 +67,9 @@ ReportEnginePrivate::ReportEnginePrivate(QObject *parent) : ReportEnginePrivate::~ReportEnginePrivate() { + if (m_designerWindow) { + m_designerWindow->close(); + } if (m_activePreview){ m_activePreview->close(); } @@ -392,20 +395,28 @@ void ReportEnginePrivate::designReport() w->setAttribute(Qt::WA_DeleteOnClose,true); w->setWindowIcon(QIcon(":report/images/logo32")); w->setShowProgressDialog(m_showProgressDialog); + + if (!m_designerWindow) { + m_designerWindow = new LimeReport::ReportDesignWindow(this,QApplication::activeWindow(),settings()); + m_designerWindow->setAttribute(Qt::WA_DeleteOnClose,true); + m_designerWindow->setWindowIcon(QIcon(":report/images/logo32")); + m_designerWindow->setShowProgressDialog(m_showProgressDialog); + } + #if defined(Q_OS_MAC) - //w->showModal(); + //m_designerWindow->showModal(); #elif defined(Q_OS_UNIX) - //w->showModal(); + //m_designerWindow->showModal(); #endif -#ifdef Q_OS_WIN - //w->setWindowFlags(Qt::Window|Qt::WindowMaximizeButtonHint|Qt::WindowCloseButtonHint|Qt::WindowMinimizeButtonHint); - w->setWindowModality(Qt::ApplicationModal); - //w->showModal(); +#ifdef Q_OS_WIN + //m_designerWindow->setWindowFlags(Qt::Window|Qt::WindowMaximizeButtonHint|Qt::WindowCloseButtonHint|Qt::WindowMinimizeButtonHint); + m_designerWindow->setWindowModality(Qt::ApplicationModal); + //m_designerWindow->showModal(); #endif if (QApplication::activeWindow()==0){ - w->show(); + m_designerWindow->show();; } else { - w->showModal(); + m_designerWindow->showModal(); } } diff --git a/limereport/lrreportengine_p.h b/limereport/lrreportengine_p.h index c86fd69..da9ce08 100644 --- a/limereport/lrreportengine_p.h +++ b/limereport/lrreportengine_p.h @@ -46,6 +46,7 @@ namespace LimeReport{ class PageDesignIntf; class PrintRange; +class ReportDesignWindow; //TODO: Add on render callback @@ -156,6 +157,7 @@ private: QMainWindow* m_activePreview; QIcon m_previewWindowIcon; QString m_previewWindowTitle; + QPointer m_designerWindow; }; }