From 935d9047fccb5101e3e5df0ac7436a7df50655ab Mon Sep 17 00:00:00 2001 From: Jonas Jenwald Date: Sat, 27 Jul 2024 13:53:50 +0200 Subject: [PATCH] Initialize all user-options upfront in AppOptions - Initialize all user-options upfront, to allow getting the options without having to check if they exist first. (This is easier to implement after PR 18475 landed.) - Move the user-options into a private field in `AppOptions`. (This code is old enough to pre-date general availability of that class feature.) - Move code/methods limited to GENERIC-builds into `AppOptions`. --- web/app_options.js | 77 +++++++++++++++++++++++----------------------- 1 file changed, 38 insertions(+), 39 deletions(-) diff --git a/web/app_options.js b/web/app_options.js index a4fe7105a9a1d..d849cc2d410af 100644 --- a/web/app_options.js +++ b/web/app_options.js @@ -484,15 +484,6 @@ if (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) { }; } -const userOptions = new Map(); - -if (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) { - // Apply any compatibility-values to the user-options. - for (const [name, value] of compatParams) { - userOptions.set(name, value); - } -} - if (typeof PDFJSDev === "undefined" || PDFJSDev.test("TESTING || LIB")) { // Ensure that the `defaultOptions` are correctly specified. for (const name in defaultOptions) { @@ -544,14 +535,44 @@ if (typeof PDFJSDev === "undefined" || PDFJSDev.test("TESTING || LIB")) { class AppOptions { static eventBus; + static #opts = new Map(); + + static { + // Initialize all the user-options. + for (const name in defaultOptions) { + this.#opts.set(name, defaultOptions[name].value); + } + + if (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) { + // Apply any compatibility-values to the user-options. + for (const [name, value] of compatParams) { + this.#opts.set(name, value); + } + this._hasInvokedSet = false; + + this._checkDisablePreferences = () => { + if (this.get("disablePreferences")) { + // Give custom implementations of the default viewer a simpler way to + // opt-out of having the `Preferences` override existing `AppOptions`. + return true; + } + if (this._hasInvokedSet) { + console.warn( + "The Preferences may override manually set AppOptions; " + + 'please use the "disablePreferences"-option to prevent that.' + ); + } + return false; + }; + } + } + constructor() { throw new Error("Cannot initialize AppOptions."); } static get(name) { - return userOptions.has(name) - ? userOptions.get(name) - : defaultOptions[name]?.value; + return this.#opts.get(name); } static getAll(kind = null, defaultOnly = false) { @@ -562,10 +583,7 @@ class AppOptions { if (kind && !(kind & defaultOpt.kind)) { continue; } - options[name] = - !defaultOnly && userOptions.has(name) - ? userOptions.get(name) - : defaultOpt.value; + options[name] = !defaultOnly ? this.#opts.get(name) : defaultOpt.value; } return options; } @@ -575,6 +593,9 @@ class AppOptions { } static setAll(options, prefs = false) { + if (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) { + this._hasInvokedSet ||= true; + } let events; for (const name in options) { @@ -601,7 +622,7 @@ class AppOptions { if (this.eventBus && kind & OptionKind.EVENT_DISPATCH) { (events ||= new Map()).set(name, userOpt); } - userOptions.set(name, userOpt); + this.#opts.set(name, userOpt); } if (events) { @@ -612,26 +633,4 @@ class AppOptions { } } -if (typeof PDFJSDev === "undefined" || PDFJSDev.test("GENERIC")) { - AppOptions._checkDisablePreferences = () => { - if (AppOptions.get("disablePreferences")) { - // Give custom implementations of the default viewer a simpler way to - // opt-out of having the `Preferences` override existing `AppOptions`. - return true; - } - for (const [name] of userOptions) { - // Ignore any compatibility-values in the user-options. - if (compatParams.has(name)) { - continue; - } - console.warn( - "The Preferences may override manually set AppOptions; " + - 'please use the "disablePreferences"-option to prevent that.' - ); - break; - } - return false; - }; -} - export { AppOptions, OptionKind };