diff options
author | Tor Arne Vestbø <tor.arne.vestbo@qt.io> | 2021-09-03 15:06:59 +0200 |
---|---|---|
committer | Tor Arne Vestbø <tor.arne.vestbo@qt.io> | 2021-09-17 14:56:19 +0200 |
commit | 28b14b966fe8535d7a81914b70759546b694e31b (patch) | |
tree | 707f4b0702242cf4a7e01e5003d9772e8bb1a703 /src/widgets/kernel/qapplication.cpp | |
parent | 1b0cb842129616d67ddf279e7e900fcdf433e390 (diff) |
Deduplicate maybeQuitOnLastWindowClosed handling
The functionality now lives in QGuiApplication, and is triggered
by QGuiApplication and QApplication after dispatching the close
event to the window.
The slight difference between how a Qt GUI and Qt Widget app
determines if a window should contribute to the close-on-quit
behavior has been abstracted into a QWindowPrivate helper.
The additional checks that were in place for skipping out of
the whole maybeQuitOnLastWindowClosed machinery have been kept.
Task-number: QTBUG-53286
Change-Id: I81bd474755f9adb3a2b082621e5ecaa1c4726808
Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
Reviewed-by: Volker Hilsheimer <volker.hilsheimer@qt.io>
Diffstat (limited to 'src/widgets/kernel/qapplication.cpp')
-rw-r--r-- | src/widgets/kernel/qapplication.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/widgets/kernel/qapplication.cpp b/src/widgets/kernel/qapplication.cpp index 9069b9005d..74868077b3 100644 --- a/src/widgets/kernel/qapplication.cpp +++ b/src/widgets/kernel/qapplication.cpp @@ -3342,6 +3342,10 @@ bool QApplication::notify(QObject *receiver, QEvent *e) break; } + // We don't call QGuiApplication::notify here, so we need to duplicate the logic + if (e->type() == QEvent::Close && receiver->isWindowType() && res) + d->maybeQuitOnLastWindowClosed(static_cast<QWindow *>(receiver)); + return res; } |