summaryrefslogtreecommitdiffstats
path: root/src/webenginewidgets/api
diff options
context:
space:
mode:
authorAllan Sandfeld Jensen <allan.jensen@qt.io>2021-09-10 16:22:25 +0200
committerKirill Burtsev <kirill.burtsev@qt.io>2021-09-30 18:32:13 +0200
commit26ef19e58ba458531e8320b666299f1a311984e6 (patch)
tree1a84f44497b26244a282b01741971189579dd68f /src/webenginewidgets/api
parentc4336ceb2e334aa3c43de4188cbf89537aacb659 (diff)
Disconnect safely
Pick-to: 6.2 Change-Id: Ic1c25724ea2d6c2241ab2665703380002efae8c3 Reviewed-by: Kirill Burtsev <kirill.burtsev@qt.io>
Diffstat (limited to 'src/webenginewidgets/api')
-rw-r--r--src/webenginewidgets/api/qwebengineview.cpp9
-rw-r--r--src/webenginewidgets/api/qwebengineview_p.h1
2 files changed, 8 insertions, 2 deletions
diff --git a/src/webenginewidgets/api/qwebengineview.cpp b/src/webenginewidgets/api/qwebengineview.cpp
index 635bb10ea..6414ac050 100644
--- a/src/webenginewidgets/api/qwebengineview.cpp
+++ b/src/webenginewidgets/api/qwebengineview.cpp
@@ -644,9 +644,14 @@ QWebEnginePage* QWebEngineView::page() const
void QWebEngineView::setPage(QWebEnginePage *newPage)
{
+ Q_D(QWebEngineView);
+ if (d->page) {
+ disconnect(d->m_pageConnection);
+ d->m_pageConnection = {};
+ }
QWebEngineViewPrivate::bindPageAndView(newPage, this);
- connect(newPage, &QWebEnginePage::_q_aboutToDelete, this,
- [newPage]() { QWebEngineViewPrivate::bindPageAndView(newPage, nullptr); });
+ d->m_pageConnection = connect(newPage, &QWebEnginePage::_q_aboutToDelete, this,
+ [newPage]() { QWebEngineViewPrivate::bindPageAndView(newPage, nullptr); });
auto profile = newPage->profile();
if (!profile->notificationPresenter())
profile->setNotificationPresenter(&defaultNotificationPresenter);
diff --git a/src/webenginewidgets/api/qwebengineview_p.h b/src/webenginewidgets/api/qwebengineview_p.h
index c34aec09a..b5d38a6c1 100644
--- a/src/webenginewidgets/api/qwebengineview_p.h
+++ b/src/webenginewidgets/api/qwebengineview_p.h
@@ -111,6 +111,7 @@ public:
bool isVisible() const override;
QRect viewportRect() const override;
QWebEnginePage *page;
+ QMetaObject::Connection m_pageConnection;
bool m_dragEntered;
mutable bool m_ownsPage;
QWebEngineContextMenuRequest *m_contextRequest;