[gnome-shell/wip/carlosg/osk-updates: 15/49] keyboard: Handle GNOME_SHELL_TEST_OSK_FILE environment variable
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell/wip/carlosg/osk-updates: 15/49] keyboard: Handle GNOME_SHELL_TEST_OSK_FILE environment variable
- Date: Tue, 5 Jul 2022 10:56:28 +0000 (UTC)
commit 6c2da4d89c0936a3f0f0cd25bc3da6e84af91c4c
Author: Carlos Garnacho <carlosg gnome org>
Date: Wed Apr 13 15:56:42 2022 +0200
keyboard: Handle GNOME_SHELL_TEST_OSK_FILE environment variable
This will be used to clobber the OSK model with the one defined by
the file given in that environment variable.
js/ui/keyboard.js | 18 ++++++++++++++----
1 file changed, 14 insertions(+), 4 deletions(-)
---
diff --git a/js/ui/keyboard.js b/js/ui/keyboard.js
index c215dca0e3..29a6c47651 100644
--- a/js/ui/keyboard.js
+++ b/js/ui/keyboard.js
@@ -542,6 +542,13 @@ var Key = GObject.registerClass({
var KeyboardModel = class {
constructor(groupName) {
+ const testFile = GLib.getenv('GNOME_SHELL_TEST_OSK_FILE');
+ if (testFile !== null) {
+ const file = Gio.File.new_for_path(testFile);
+ this._model = this._loadModelFile(file);
+ return;
+ }
+
let names = [groupName];
if (groupName.includes('+'))
names.push(groupName.replace(/\+.*/, ''));
@@ -556,15 +563,18 @@ var KeyboardModel = class {
}
}
- _loadModel(groupName) {
- const file = Gio.File.new_for_uri(
- `resource:///org/gnome/shell/osk-layouts/${groupName}.json`);
+ _loadModelFile(file) {
let [success_, contents] = file.load_contents(null);
-
const decoder = new TextDecoder();
return JSON.parse(decoder.decode(contents));
}
+ _loadModel(groupName) {
+ const file = Gio.File.new_for_uri(
+ `resource:///org/gnome/shell/osk-layouts/${groupName}.json`);
+ return this._loadModelFile(file);
+ }
+
getLevels() {
return this._model.levels;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]