Fix an edge-case related to compatibility-values in various AppOptions-methods

Given how the compatibility-values are being handled, it's not actually possible to override a *truthy* default-value with a *falsy* compatibility-value.
This is a simple oversight on my part, and with modern ECMAScript features this is very easy to support.
This commit is contained in:
Jonas Jenwald 2021-03-19 16:10:31 +01:00
parent 18bc59eb34
commit 7bcfabc43c

View File

@ -297,7 +297,7 @@ class AppOptions {
}
const defaultOption = defaultOptions[name];
if (defaultOption !== undefined) {
return defaultOption.compatibility || defaultOption.value;
return defaultOption.compatibility ?? defaultOption.value;
}
return undefined;
}
@ -329,7 +329,7 @@ class AppOptions {
options[name] =
userOption !== undefined
? userOption
: defaultOption.compatibility || defaultOption.value;
: defaultOption.compatibility ?? defaultOption.value;
}
return options;
}