aboutsummaryrefslogtreecommitdiff
path: root/ext/wasm/api/sqlite3-api-prologue.js
diff options
context:
space:
mode:
authorstephan <stephan@noemail.net>2022-08-22 21:37:17 +0000
committerstephan <stephan@noemail.net>2022-08-22 21:37:17 +0000
commitae708b2b018ac558b2f5c7626269415c86e85382 (patch)
treea1fafc97f0ae6b2c64349ddef9a09da0790d2adb /ext/wasm/api/sqlite3-api-prologue.js
parent7a8a0fceeca3ae88595c539bc2394ea8c74cf793 (diff)
downloadsqlite-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.js10
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