From 5e3353ef22f84d3f61d494e3171f5d4295308a6c Mon Sep 17 00:00:00 2001 From: Carlos Garnacho Date: Wed, 14 Sep 2022 20:20:14 +0200 Subject: [PATCH] status: Use fixed sorting of input sources on empty MRU When updating the MRU sources if there was no prior MRU, we want to go with the unmodified list of sources in visibility order. However iterating over object properties happens in an undetermined order, so the initial MRU list ends up picking a value at random. In order to prefer the sources list in the same order than they appear in the menu if there was no prior MRU, order the keys when accessing it and building the initial list of sources. Closes: https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/5873 --- js/ui/status/keyboard.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/js/ui/status/keyboard.js b/js/ui/status/keyboard.js index 76a42f6bd7..65b3962731 100644 --- a/js/ui/status/keyboard.js +++ b/js/ui/status/keyboard.js @@ -492,7 +492,7 @@ var InputSourceManager = class extends Signals.EventEmitter { _updateMruSources() { let sourcesList = []; - for (let i in this._inputSources) + for (let i of Object.keys(this._inputSources).sort((a, b) => a - b)) sourcesList.push(this._inputSources[i]); this._keyboardManager.setUserLayouts(sourcesList.map(x => x.xkbId)); -- GitLab