fix: don't do self-destroy in LibnotifyNotification::Dismiss() (#41708)

Callers of Notification::Dismiss() assume that the notification
instance is not deleted after the call, but this was not the case
for LibnotifyNotification:
- Destroy() would get `this` deleted.
- notify_notification_close() in portal environment triggers
LibnotifyNotification::OnNotificationClosed(), and finally calls
Destroy()

This patch removes all Destroy() in Dismiss(), and adds a boolean
to tell whether notify_notification_close() is running, to avoid crash
under portal environment.

Fixes #40461.

Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com>
Co-authored-by: taoky <me@taoky.moe>
This commit is contained in:
trop[bot] 2024-03-28 12:09:59 +01:00 committed by GitHub
parent 5655b68c37
commit 9ebeeb40ac
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 4 additions and 3 deletions

View file

@ -159,21 +159,21 @@ void LibnotifyNotification::Show(const NotificationOptions& options) {
void LibnotifyNotification::Dismiss() { void LibnotifyNotification::Dismiss() {
if (!notification_) { if (!notification_) {
Destroy();
return; return;
} }
GError* error = nullptr; GError* error = nullptr;
on_dismissing_ = true;
libnotify_loader_.notify_notification_close(notification_, &error); libnotify_loader_.notify_notification_close(notification_, &error);
if (error) { if (error) {
log_and_clear_error(error, "notify_notification_close"); log_and_clear_error(error, "notify_notification_close");
Destroy();
} }
on_dismissing_ = false;
} }
void LibnotifyNotification::OnNotificationClosed( void LibnotifyNotification::OnNotificationClosed(
NotifyNotification* notification) { NotifyNotification* notification) {
NotificationDismissed(); NotificationDismissed(!on_dismissing_);
} }
void LibnotifyNotification::OnNotificationView(NotifyNotification* notification, void LibnotifyNotification::OnNotificationView(NotifyNotification* notification,

View file

@ -33,6 +33,7 @@ class LibnotifyNotification : public Notification {
RAW_PTR_EXCLUSION NotifyNotification* notification_ = nullptr; RAW_PTR_EXCLUSION NotifyNotification* notification_ = nullptr;
ScopedGSignal signal_; ScopedGSignal signal_;
bool on_dismissing_ = false;
}; };
} // namespace electron } // namespace electron