NotificationDaemon: fix typo in dealing with TrayIcon

Source was failing to determine if it was a tray icon, destroying
itself when the associated application was closed.

https://bugzilla.gnome.org/show_bug.cgi?id=645625
This commit is contained in:
Giovanni Campagna 2011-03-23 21:37:05 +01:00
parent 090d54516e
commit 9530048867

View File

@ -519,10 +519,13 @@ Source.prototype = {
_appStateChanged: function() { _appStateChanged: function() {
// Destroy notification sources when their apps exit. // Destroy notification sources when their apps exit.
// The app exiting would normally result in a tray icon being removed, // The app exiting would normally result in a tray icon being removed,
// so it should be ok to destroy the source associated with a tray icon // so the associated source would be destroyed through the code path
// here too, however we just let that happen through the code path // that handles the tray icon being removed. We should not destroy
// associated with the tray icon being removed. // the source associated with a tray icon when the application state
if (!this._isTrayIcon && this.app.get_state() == Shell.AppState.STOPPED) // is Shell.AppState.STOPPED because running applications that have
// no open windows would also have that state. This is often the case
// for applications that use tray icons.
if (!this._trayIcon && this.app.get_state() == Shell.AppState.STOPPED)
this.destroy(); this.destroy();
}, },