remoteSearch: Load remote search providers synchronously
As we only reload search providers on startup or when the sort order changes, and given the small number of search providers we'll actually load, I doubt we'll see any speed decrease. The simplicity of synchronous code is also much clearer, and fully avoids all the possible bugs about in-flight requests or similar. This also prevents issues with multiple search providers showing up at once, which happen when multiple requests to reload search providers get called immediately, with the existing in-flight async requests never cancelled. https://bugzilla.gnome.org/show_bug.cgi?id=700283
This commit is contained in:
parent
4efd363134
commit
be961cd60e
@ -7,7 +7,6 @@ const Lang = imports.lang;
|
|||||||
const St = imports.gi.St;
|
const St = imports.gi.St;
|
||||||
const Shell = imports.gi.Shell;
|
const Shell = imports.gi.Shell;
|
||||||
|
|
||||||
const FileUtils = imports.misc.fileUtils;
|
|
||||||
const Search = imports.ui.search;
|
const Search = imports.ui.search;
|
||||||
|
|
||||||
const KEY_FILE_GROUP = 'Shell Search Provider';
|
const KEY_FILE_GROUP = 'Shell Search Provider';
|
||||||
@ -60,17 +59,10 @@ var SearchProviderProxy = Gio.DBusProxy.makeProxyWrapper(SearchProviderIface);
|
|||||||
var SearchProvider2Proxy = Gio.DBusProxy.makeProxyWrapper(SearchProvider2Iface);
|
var SearchProvider2Proxy = Gio.DBusProxy.makeProxyWrapper(SearchProvider2Iface);
|
||||||
|
|
||||||
function loadRemoteSearchProviders(addProviderCallback) {
|
function loadRemoteSearchProviders(addProviderCallback) {
|
||||||
let data = { loadedProviders: [],
|
let objectPaths = {};
|
||||||
objectPaths: {},
|
let loadedProviders = [];
|
||||||
addProviderCallback: addProviderCallback };
|
|
||||||
FileUtils.collectFromDatadirsAsync('search-providers',
|
|
||||||
{ loadedCallback: remoteProvidersLoaded,
|
|
||||||
processFile: loadRemoteSearchProvider,
|
|
||||||
data: data
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function loadRemoteSearchProvider(file, info, data) {
|
function loadRemoteSearchProvider(file) {
|
||||||
let keyfile = new GLib.KeyFile();
|
let keyfile = new GLib.KeyFile();
|
||||||
let path = file.get_path();
|
let path = file.get_path();
|
||||||
|
|
||||||
@ -89,7 +81,7 @@ function loadRemoteSearchProvider(file, info, data) {
|
|||||||
let busName = keyfile.get_string(group, 'BusName');
|
let busName = keyfile.get_string(group, 'BusName');
|
||||||
let objectPath = keyfile.get_string(group, 'ObjectPath');
|
let objectPath = keyfile.get_string(group, 'ObjectPath');
|
||||||
|
|
||||||
if (data.objectPaths[objectPath])
|
if (objectPaths[objectPath])
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let appInfo = null;
|
let appInfo = null;
|
||||||
@ -113,22 +105,31 @@ function loadRemoteSearchProvider(file, info, data) {
|
|||||||
else
|
else
|
||||||
remoteProvider = new RemoteSearchProvider(appInfo, busName, objectPath);
|
remoteProvider = new RemoteSearchProvider(appInfo, busName, objectPath);
|
||||||
|
|
||||||
data.objectPaths[objectPath] = remoteProvider;
|
objectPaths[objectPath] = remoteProvider;
|
||||||
data.loadedProviders.push(remoteProvider);
|
loadedProviders.push(remoteProvider);
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
log('Failed to add search provider %s: %s'.format(path, e.toString()));
|
log('Failed to add search provider %s: %s'.format(path, e.toString()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function remoteProvidersLoaded(loadState) {
|
let dataDirs = GLib.get_system_data_dirs();
|
||||||
|
dataDirs.forEach(function(dataDir) {
|
||||||
|
let path = GLib.build_filenamev([dataDir, 'gnome-shell', 'search-providers']);
|
||||||
|
let dir = Gio.File.new_for_path(path);
|
||||||
|
let fileEnum = dir.enumerate_children('standard::name,standard::type',
|
||||||
|
Gio.FileQueryInfoFlags.NONE, null);
|
||||||
|
let info;
|
||||||
|
while ((info = fileEnum.next_file(null)))
|
||||||
|
loadRemoteSearchProvider(fileEnum.get_child(info));
|
||||||
|
});
|
||||||
|
|
||||||
let searchSettings = new Gio.Settings({ schema: Search.SEARCH_PROVIDERS_SCHEMA });
|
let searchSettings = new Gio.Settings({ schema: Search.SEARCH_PROVIDERS_SCHEMA });
|
||||||
let sortOrder = searchSettings.get_strv('sort-order');
|
let sortOrder = searchSettings.get_strv('sort-order');
|
||||||
|
|
||||||
// Special case gnome-control-center to be always active and always first
|
// Special case gnome-control-center to be always active and always first
|
||||||
sortOrder.unshift('gnome-control-center.desktop');
|
sortOrder.unshift('gnome-control-center.desktop');
|
||||||
|
|
||||||
loadState.loadedProviders.sort(
|
loadedProviders.sort(function(providerA, providerB) {
|
||||||
function(providerA, providerB) {
|
|
||||||
let idxA, idxB;
|
let idxA, idxB;
|
||||||
let appIdA, appIdB;
|
let appIdA, appIdB;
|
||||||
|
|
||||||
@ -158,10 +159,7 @@ function remoteProvidersLoaded(loadState) {
|
|||||||
return (idxA - idxB);
|
return (idxA - idxB);
|
||||||
});
|
});
|
||||||
|
|
||||||
loadState.loadedProviders.forEach(
|
loadedProviders.forEach(addProviderCallback);
|
||||||
function(provider) {
|
|
||||||
loadState.addProviderCallback(provider);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const RemoteSearchProvider = new Lang.Class({
|
const RemoteSearchProvider = new Lang.Class({
|
||||||
|
Loading…
Reference in New Issue
Block a user