extensionSystem: Allow changing extensions in ERROR state
While an extension's actual state can no longer change once it is in ERROR state, its requested state can. In fact, disabling an erroneous extension is highly recommended, so that it doesn't cause problems again on the next login. https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/7004 Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/3073>
This commit is contained in:
parent
02b19e3b5c
commit
f9e81284f8
@ -370,7 +370,6 @@ export class ExtensionManager extends Signals.EventEmitter {
|
|||||||
extension.errors.push(message);
|
extension.errors.push(message);
|
||||||
|
|
||||||
logError(error, `Extension ${uuid}`);
|
logError(error, `Extension ${uuid}`);
|
||||||
this._updateCanChange(extension);
|
|
||||||
this.emit('extension-state-changed', extension);
|
this.emit('extension-state-changed', extension);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -572,10 +571,6 @@ export class ExtensionManager extends Signals.EventEmitter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_updateCanChange(extension) {
|
_updateCanChange(extension) {
|
||||||
let hasError =
|
|
||||||
extension.state === ExtensionState.ERROR ||
|
|
||||||
extension.state === ExtensionState.OUT_OF_DATE;
|
|
||||||
|
|
||||||
let isMode = this._getModeExtensions().includes(extension.uuid);
|
let isMode = this._getModeExtensions().includes(extension.uuid);
|
||||||
let modeOnly = global.settings.get_boolean(DISABLE_USER_EXTENSIONS_KEY);
|
let modeOnly = global.settings.get_boolean(DISABLE_USER_EXTENSIONS_KEY);
|
||||||
|
|
||||||
@ -584,7 +579,6 @@ export class ExtensionManager extends Signals.EventEmitter {
|
|||||||
: ENABLED_EXTENSIONS_KEY;
|
: ENABLED_EXTENSIONS_KEY;
|
||||||
|
|
||||||
extension.canChange =
|
extension.canChange =
|
||||||
!hasError &&
|
|
||||||
global.settings.is_writable(changeKey) &&
|
global.settings.is_writable(changeKey) &&
|
||||||
(isMode || !modeOnly);
|
(isMode || !modeOnly);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user