diff options
author | stephan <stephan@noemail.net> | 2022-08-22 21:37:17 +0000 |
---|---|---|
committer | stephan <stephan@noemail.net> | 2022-08-22 21:37:17 +0000 |
commit | ae708b2b018ac558b2f5c7626269415c86e85382 (patch) | |
tree | a1fafc97f0ae6b2c64349ddef9a09da0790d2adb /ext/wasm/api/sqlite3-api-prologue.js | |
parent | 7a8a0fceeca3ae88595c539bc2394ea8c74cf793 (diff) | |
download | sqlite-ae708b2b018ac558b2f5c7626269415c86e85382.tar.gz sqlite-ae708b2b018ac558b2f5c7626269415c86e85382.zip |
More experimentation with how client-side config state can be passed on to initialize the JS-side sqlite3 API.
FossilOrigin-Name: ea2acc454c012a62556f6d0623d6eff60736d24aa214a64462b423623ef44d47
Diffstat (limited to 'ext/wasm/api/sqlite3-api-prologue.js')
-rw-r--r-- | ext/wasm/api/sqlite3-api-prologue.js | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/ext/wasm/api/sqlite3-api-prologue.js b/ext/wasm/api/sqlite3-api-prologue.js index 87cc40b41..1a38f0343 100644 --- a/ext/wasm/api/sqlite3-api-prologue.js +++ b/ext/wasm/api/sqlite3-api-prologue.js @@ -134,7 +134,7 @@ self.sqlite3ApiBootstrap = function sqlite3ApiBootstrap(apiConfig){ return sqlite3ApiBootstrap.sqlite3; } - apiConfig = apiConfig||{}; + apiConfig = apiConfig || {}; const config = Object.create(null); { const configDefaults = { @@ -147,9 +147,15 @@ self.sqlite3ApiBootstrap = function sqlite3ApiBootstrap(apiConfig){ persistentDirName: '/persistent' }; Object.keys(configDefaults).forEach(function(k){ - config[k] = Object.prototype.hasOwnProperty.call(apiConfig, k) + config[k] = Object.getOwnPropertyDescriptor(apiConfig, k) ? apiConfig[k] : configDefaults[k]; }); + // Copy over any properties apiConfig defines but configDefaults does not... + Object.keys(apiConfig).forEach(function(k){ + if(!Object.getOwnPropertyDescriptor(config, k)){ + config[k] = apiConfig[k]; + } + }); } /** Throws a new Error, the message of which is the concatenation |