Calendar: ignore timeouts starting the calendar-server
In certain cases the timeout for starting the calendar helper can be reached but the calendar helper still loads fine. If so, just ignore the timeout and wait until we get a notification from dbus of the successful start. https://bugzilla.gnome.org/show_bug.cgi?id=735308
This commit is contained in:
parent
b21f5c5566
commit
0592adead5
@ -233,12 +233,25 @@ const DBusEventSource = new Lang.Class({
|
|||||||
this._initialized = false;
|
this._initialized = false;
|
||||||
this._dbusProxy = new CalendarServer();
|
this._dbusProxy = new CalendarServer();
|
||||||
this._dbusProxy.init_async(GLib.PRIORITY_DEFAULT, null, Lang.bind(this, function(object, result) {
|
this._dbusProxy.init_async(GLib.PRIORITY_DEFAULT, null, Lang.bind(this, function(object, result) {
|
||||||
|
let loaded = false;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
this._dbusProxy.init_finish(result);
|
this._dbusProxy.init_finish(result);
|
||||||
|
loaded = true;
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
|
if (e.matches(Gio.DBusError, Gio.DBusError.TIMED_OUT)) {
|
||||||
|
// Ignore timeouts and install signals as normal, because with high
|
||||||
|
// probability the service will appear later on, and we will get a
|
||||||
|
// NameOwnerChanged which will finish loading
|
||||||
|
//
|
||||||
|
// (But still _initialized to false, because the proxy does not know
|
||||||
|
// about the HasCalendars property and would cause an exception trying
|
||||||
|
// to read it)
|
||||||
|
} else {
|
||||||
log('Error loading calendars: ' + e.message);
|
log('Error loading calendars: ' + e.message);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
this._dbusProxy.connectSignal('Changed', Lang.bind(this, this._onChanged));
|
this._dbusProxy.connectSignal('Changed', Lang.bind(this, this._onChanged));
|
||||||
|
|
||||||
@ -253,9 +266,11 @@ const DBusEventSource = new Lang.Class({
|
|||||||
this.emit('notify::has-calendars');
|
this.emit('notify::has-calendars');
|
||||||
}));
|
}));
|
||||||
|
|
||||||
this._initialized = true;
|
this._initialized = loaded;
|
||||||
|
if (loaded) {
|
||||||
this.emit('notify::has-calendars');
|
this.emit('notify::has-calendars');
|
||||||
this._onNameAppeared();
|
this._onNameAppeared();
|
||||||
|
}
|
||||||
}));
|
}));
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -277,6 +292,7 @@ const DBusEventSource = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onNameAppeared: function(owner) {
|
_onNameAppeared: function(owner) {
|
||||||
|
this._initialized = true;
|
||||||
this._resetCache();
|
this._resetCache();
|
||||||
this._loadEvents(true);
|
this._loadEvents(true);
|
||||||
},
|
},
|
||||||
|
Loading…
Reference in New Issue
Block a user