2011-09-28 09:16:26 -04:00
|
|
|
// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*-
|
2019-11-25 22:54:44 +01:00
|
|
|
/* exported collectFromDatadirs, recursivelyDeleteDir,
|
2020-04-23 20:46:44 +02:00
|
|
|
recursivelyMoveDir, loadInterfaceXML, loadSubInterfaceXML */
|
2011-09-28 09:16:26 -04:00
|
|
|
|
2019-02-09 04:21:36 +01:00
|
|
|
const { Gio, GLib } = imports.gi;
|
2022-07-05 03:25:02 -04:00
|
|
|
|
|
|
|
var { loadInterfaceXML } = imports.misc.dbusUtils;
|
2010-10-01 01:08:22 +04:00
|
|
|
|
2022-11-29 20:17:20 -06:00
|
|
|
/**
|
|
|
|
* @typedef {object} SubdirInfo
|
|
|
|
* @property {Gio.File} dir the file object for the subdir
|
|
|
|
* @property {Gio.FileInfo} info the file descriptor for the subdir
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} subdir the subdirectory to search within the data directories
|
|
|
|
* @param {boolean} includeUserDir whether the user's data directory should also be searched in addition
|
|
|
|
* to the system data directories
|
|
|
|
* @returns {Generator<SubdirInfo, void, void>} a generator which yields file info for subdirectories named
|
|
|
|
* `subdir` within data directories
|
|
|
|
*/
|
|
|
|
function* collectFromDatadirs(subdir, includeUserDir) {
|
2012-11-30 16:36:12 +01:00
|
|
|
let dataDirs = GLib.get_system_data_dirs();
|
2013-11-04 10:07:44 -05:00
|
|
|
if (includeUserDir)
|
2012-11-30 16:36:12 +01:00
|
|
|
dataDirs.unshift(GLib.get_user_data_dir());
|
|
|
|
|
|
|
|
for (let i = 0; i < dataDirs.length; i++) {
|
|
|
|
let path = GLib.build_filenamev([dataDirs[i], 'gnome-shell', subdir]);
|
|
|
|
let dir = Gio.File.new_for_path(path);
|
|
|
|
|
2013-11-04 10:07:44 -05:00
|
|
|
let fileEnum;
|
|
|
|
try {
|
|
|
|
fileEnum = dir.enumerate_children('standard::name,standard::type',
|
2022-11-29 20:17:20 -06:00
|
|
|
Gio.FileQueryInfoFlags.NONE, null);
|
2013-11-04 10:07:44 -05:00
|
|
|
} catch (e) {
|
|
|
|
fileEnum = null;
|
|
|
|
}
|
|
|
|
if (fileEnum != null) {
|
|
|
|
let info;
|
|
|
|
while ((info = fileEnum.next_file(null)))
|
2022-11-29 20:17:20 -06:00
|
|
|
yield {dir: fileEnum.get_child(info), info};
|
2013-11-04 10:07:44 -05:00
|
|
|
}
|
2012-11-30 16:36:12 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-26 20:47:44 -04:00
|
|
|
function recursivelyDeleteDir(dir, deleteParent) {
|
2011-09-10 17:10:50 -04:00
|
|
|
let children = dir.enumerate_children('standard::name,standard::type',
|
2022-12-05 13:56:57 +01:00
|
|
|
Gio.FileQueryInfoFlags.NOFOLLOW_SYMLINKS, null);
|
2011-09-10 17:10:50 -04:00
|
|
|
|
2019-01-31 15:04:56 +01:00
|
|
|
let info;
|
2011-09-10 17:10:50 -04:00
|
|
|
while ((info = children.next_file(null)) != null) {
|
|
|
|
let type = info.get_file_type();
|
|
|
|
let child = dir.get_child(info.get_name());
|
|
|
|
if (type == Gio.FileType.REGULAR)
|
2019-11-25 22:54:44 +01:00
|
|
|
child.delete(null);
|
2011-11-30 21:46:52 -05:00
|
|
|
else if (type == Gio.FileType.DIRECTORY)
|
2012-06-26 20:47:44 -04:00
|
|
|
recursivelyDeleteDir(child, true);
|
2011-09-10 17:10:50 -04:00
|
|
|
}
|
|
|
|
|
2012-06-26 20:47:44 -04:00
|
|
|
if (deleteParent)
|
2019-11-25 22:54:44 +01:00
|
|
|
dir.delete(null);
|
2012-06-26 20:47:44 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function recursivelyMoveDir(srcDir, destDir) {
|
|
|
|
let children = srcDir.enumerate_children('standard::name,standard::type',
|
2022-12-05 13:56:57 +01:00
|
|
|
Gio.FileQueryInfoFlags.NOFOLLOW_SYMLINKS, null);
|
2012-06-26 20:47:44 -04:00
|
|
|
|
|
|
|
if (!destDir.query_exists(null))
|
|
|
|
destDir.make_directory_with_parents(null);
|
|
|
|
|
2019-01-31 15:04:56 +01:00
|
|
|
let info;
|
2012-06-26 20:47:44 -04:00
|
|
|
while ((info = children.next_file(null)) != null) {
|
|
|
|
let type = info.get_file_type();
|
|
|
|
let srcChild = srcDir.get_child(info.get_name());
|
|
|
|
let destChild = destDir.get_child(info.get_name());
|
|
|
|
if (type == Gio.FileType.REGULAR)
|
|
|
|
srcChild.move(destChild, Gio.FileCopyFlags.NONE, null, null);
|
|
|
|
else if (type == Gio.FileType.DIRECTORY)
|
|
|
|
recursivelyMoveDir(srcChild, destChild);
|
|
|
|
}
|
2011-09-10 17:10:50 -04:00
|
|
|
}
|