@powersync/web 1.12.3 → 1.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (62) hide show
  1. package/README.md +33 -0
  2. package/dist/3cb48be086dd9edd02ff.wasm +0 -0
  3. package/dist/{_journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-async-mutex-c-3cff7d0.index.umd.js → _journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-_powersync_co-780aa20.index.umd.js} +18 -8
  4. package/dist/_journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-_powersync_co-780aa20.index.umd.js.map +1 -0
  5. package/dist/{_journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-async-mutex-c-3cff7d1.index.umd.js → _journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-_powersync_co-780aa21.index.umd.js} +18 -8
  6. package/dist/_journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-_powersync_co-780aa21.index.umd.js.map +1 -0
  7. package/dist/df958358cadf945bd0fe.wasm +0 -0
  8. package/dist/f9c8ada26c59f5bf4339.wasm +0 -0
  9. package/dist/index.umd.js +3707 -497
  10. package/dist/index.umd.js.map +1 -1
  11. package/dist/worker/SharedSyncImplementation.umd.js +246 -2171
  12. package/dist/worker/SharedSyncImplementation.umd.js.map +1 -1
  13. package/dist/worker/WASQLiteDB.umd.js +767 -196
  14. package/dist/worker/WASQLiteDB.umd.js.map +1 -1
  15. package/dist/worker/node_modules_journeyapps_wa-sqlite_dist_mc-wa-sqlite-async_mjs.umd.js +45 -0
  16. package/dist/worker/node_modules_journeyapps_wa-sqlite_dist_mc-wa-sqlite-async_mjs.umd.js.map +1 -0
  17. package/dist/worker/node_modules_journeyapps_wa-sqlite_dist_mc-wa-sqlite_mjs.umd.js +45 -0
  18. package/dist/worker/node_modules_journeyapps_wa-sqlite_dist_mc-wa-sqlite_mjs.umd.js.map +1 -0
  19. package/dist/worker/node_modules_journeyapps_wa-sqlite_dist_wa-sqlite_mjs.umd.js +45 -0
  20. package/dist/worker/node_modules_journeyapps_wa-sqlite_dist_wa-sqlite_mjs.umd.js.map +1 -0
  21. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_AccessHandlePoolVFS_js.umd.js +1509 -0
  22. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_AccessHandlePoolVFS_js.umd.js.map +1 -0
  23. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_OPFSCoopSyncVFS_js.umd.js +1641 -0
  24. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_OPFSCoopSyncVFS_js.umd.js.map +1 -0
  25. package/lib/package.json +2 -2
  26. package/lib/src/db/PowerSyncDatabase.d.ts +10 -2
  27. package/lib/src/db/PowerSyncDatabase.js +20 -4
  28. package/lib/src/db/adapters/AbstractWebSQLOpenFactory.d.ts +2 -0
  29. package/lib/src/db/adapters/AbstractWebSQLOpenFactory.js +3 -0
  30. package/lib/src/db/adapters/AsyncDatabaseConnection.d.ts +26 -0
  31. package/lib/src/db/adapters/LockedAsyncDatabaseAdapter.d.ts +82 -0
  32. package/lib/src/db/adapters/LockedAsyncDatabaseAdapter.js +239 -0
  33. package/lib/src/db/adapters/WebDBAdapter.d.ts +17 -0
  34. package/lib/src/db/adapters/WebDBAdapter.js +1 -0
  35. package/lib/src/db/adapters/WorkerWrappedAsyncDatabaseConnection.d.ts +39 -0
  36. package/lib/src/db/adapters/WorkerWrappedAsyncDatabaseConnection.js +46 -0
  37. package/lib/src/db/adapters/wa-sqlite/WASQLiteConnection.d.ts +127 -0
  38. package/lib/src/db/adapters/wa-sqlite/WASQLiteConnection.js +343 -0
  39. package/lib/src/db/adapters/wa-sqlite/WASQLiteDBAdapter.d.ts +10 -42
  40. package/lib/src/db/adapters/wa-sqlite/WASQLiteDBAdapter.js +36 -212
  41. package/lib/src/db/adapters/wa-sqlite/WASQLiteOpenFactory.d.ts +12 -0
  42. package/lib/src/db/adapters/wa-sqlite/WASQLiteOpenFactory.js +81 -4
  43. package/lib/src/db/adapters/web-sql-flags.d.ts +17 -0
  44. package/lib/src/db/sync/SharedWebStreamingSyncImplementation.d.ts +9 -2
  45. package/lib/src/db/sync/SharedWebStreamingSyncImplementation.js +16 -10
  46. package/lib/src/db/sync/WebStreamingSyncImplementation.d.ts +0 -5
  47. package/lib/src/index.d.ts +8 -7
  48. package/lib/src/index.js +8 -7
  49. package/lib/src/worker/db/WASQLiteDB.worker.js +38 -20
  50. package/lib/src/worker/db/open-worker-database.d.ts +5 -4
  51. package/lib/src/worker/db/open-worker-database.js +5 -3
  52. package/lib/src/worker/sync/AbstractSharedSyncClientProvider.d.ts +1 -0
  53. package/lib/src/worker/sync/SharedSyncImplementation.d.ts +20 -3
  54. package/lib/src/worker/sync/SharedSyncImplementation.js +40 -11
  55. package/lib/tsconfig.tsbuildinfo +1 -1
  56. package/package.json +2 -2
  57. package/dist/_journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-async-mutex-c-3cff7d0.index.umd.js.map +0 -1
  58. package/dist/_journeyapps_wa-sqlite-_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js-async-mutex-c-3cff7d1.index.umd.js.map +0 -1
  59. package/lib/src/shared/open-db.d.ts +0 -5
  60. package/lib/src/shared/open-db.js +0 -193
  61. package/lib/src/shared/types.d.ts +0 -22
  62. /package/lib/src/{shared/types.js → db/adapters/AsyncDatabaseConnection.js} +0 -0
@@ -0,0 +1,1509 @@
1
+ "use strict";
2
+ (self["webpackChunksdk_web"] = self["webpackChunksdk_web"] || []).push([["node_modules_journeyapps_wa-sqlite_src_examples_AccessHandlePoolVFS_js"],{
3
+
4
+ /***/ "../../node_modules/@journeyapps/wa-sqlite/src/FacadeVFS.js":
5
+ /*!******************************************************************!*\
6
+ !*** ../../node_modules/@journeyapps/wa-sqlite/src/FacadeVFS.js ***!
7
+ \******************************************************************/
8
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
9
+
10
+ __webpack_require__.r(__webpack_exports__);
11
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
12
+ /* harmony export */ FacadeVFS: () => (/* binding */ FacadeVFS)
13
+ /* harmony export */ });
14
+ /* harmony import */ var _VFS_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./VFS.js */ "../../node_modules/@journeyapps/wa-sqlite/src/VFS.js");
15
+ // Copyright 2024 Roy T. Hashimoto. All Rights Reserved.
16
+
17
+
18
+ const AsyncFunction = Object.getPrototypeOf(async function(){}).constructor;
19
+
20
+ // Milliseconds since Julian epoch as a BigInt.
21
+ // https://github.com/sqlite/sqlite/blob/e57527c14f7b7cfa6e32eeab5c549d50c4fa3674/src/os_unix.c#L6872-L6882
22
+ const UNIX_EPOCH = 24405875n * 8640000n;
23
+
24
+ // Convenience base class for a JavaScript VFS.
25
+ // The raw xOpen, xRead, etc. function signatures receive only C primitives
26
+ // which aren't easy to work with. This class provides corresponding calls
27
+ // like jOpen, jRead, etc., which receive JavaScript-friendlier arguments
28
+ // such as string, Uint8Array, and DataView.
29
+ class FacadeVFS extends _VFS_js__WEBPACK_IMPORTED_MODULE_0__.Base {
30
+ /**
31
+ * @param {string} name
32
+ * @param {object} module
33
+ */
34
+ constructor(name, module) {
35
+ super(name, module);
36
+ }
37
+
38
+ /**
39
+ * Override to indicate which methods are asynchronous.
40
+ * @param {string} methodName
41
+ * @returns {boolean}
42
+ */
43
+ hasAsyncMethod(methodName) {
44
+ // The input argument is a string like "xOpen", so convert to "jOpen".
45
+ // Then check if the method exists and is async.
46
+ const jMethodName = `j${methodName.slice(1)}`;
47
+ return this[jMethodName] instanceof AsyncFunction;
48
+ }
49
+
50
+ /**
51
+ * Return the filename for a file id for use by mixins.
52
+ * @param {number} pFile
53
+ * @returns {string}
54
+ */
55
+ getFilename(pFile) {
56
+ throw new Error('unimplemented');
57
+ }
58
+
59
+ /**
60
+ * @param {string?} filename
61
+ * @param {number} pFile
62
+ * @param {number} flags
63
+ * @param {DataView} pOutFlags
64
+ * @returns {number|Promise<number>}
65
+ */
66
+ jOpen(filename, pFile, flags, pOutFlags) {
67
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CANTOPEN;
68
+ }
69
+
70
+ /**
71
+ * @param {string} filename
72
+ * @param {number} syncDir
73
+ * @returns {number|Promise<number>}
74
+ */
75
+ jDelete(filename, syncDir) {
76
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
77
+ }
78
+
79
+ /**
80
+ * @param {string} filename
81
+ * @param {number} flags
82
+ * @param {DataView} pResOut
83
+ * @returns {number|Promise<number>}
84
+ */
85
+ jAccess(filename, flags, pResOut) {
86
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
87
+ }
88
+
89
+ /**
90
+ * @param {string} filename
91
+ * @param {Uint8Array} zOut
92
+ * @returns {number|Promise<number>}
93
+ */
94
+ jFullPathname(filename, zOut) {
95
+ // Copy the filename to the output buffer.
96
+ const { read, written } = new TextEncoder().encodeInto(filename, zOut);
97
+ if (read < filename.length) return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR;
98
+ if (written >= zOut.length) return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR;
99
+ zOut[written] = 0;
100
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
101
+ }
102
+
103
+ /**
104
+ * @param {Uint8Array} zBuf
105
+ * @returns {number|Promise<number>}
106
+ */
107
+ jGetLastError(zBuf) {
108
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
109
+ }
110
+
111
+ /**
112
+ * @param {number} pFile
113
+ * @returns {number|Promise<number>}
114
+ */
115
+ jClose(pFile) {
116
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
117
+ }
118
+
119
+ /**
120
+ * @param {number} pFile
121
+ * @param {Uint8Array} pData
122
+ * @param {number} iOffset
123
+ * @returns {number|Promise<number>}
124
+ */
125
+ jRead(pFile, pData, iOffset) {
126
+ pData.fill(0);
127
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_SHORT_READ;
128
+ }
129
+
130
+ /**
131
+ * @param {number} pFile
132
+ * @param {Uint8Array} pData
133
+ * @param {number} iOffset
134
+ * @returns {number|Promise<number>}
135
+ */
136
+ jWrite(pFile, pData, iOffset) {
137
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_WRITE;
138
+ }
139
+
140
+ /**
141
+ * @param {number} pFile
142
+ * @param {number} size
143
+ * @returns {number|Promise<number>}
144
+ */
145
+ jTruncate(pFile, size) {
146
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
147
+ }
148
+
149
+ /**
150
+ * @param {number} pFile
151
+ * @param {number} flags
152
+ * @returns {number|Promise<number>}
153
+ */
154
+ jSync(pFile, flags) {
155
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
156
+ }
157
+
158
+ /**
159
+ * @param {number} pFile
160
+ * @param {DataView} pSize
161
+ * @returns {number|Promise<number>}
162
+ */
163
+ jFileSize(pFile, pSize) {
164
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
165
+ }
166
+
167
+ /**
168
+ * @param {number} pFile
169
+ * @param {number} lockType
170
+ * @returns {number|Promise<number>}
171
+ */
172
+ jLock(pFile, lockType) {
173
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
174
+ }
175
+
176
+ /**
177
+ * @param {number} pFile
178
+ * @param {number} lockType
179
+ * @returns {number|Promise<number>}
180
+ */
181
+ jUnlock(pFile, lockType) {
182
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
183
+ }
184
+
185
+ /**
186
+ * @param {number} pFile
187
+ * @param {DataView} pResOut
188
+ * @returns {number|Promise<number>}
189
+ */
190
+ jCheckReservedLock(pFile, pResOut) {
191
+ pResOut.setInt32(0, 0, true);
192
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
193
+ }
194
+
195
+ /**
196
+ * @param {number} pFile
197
+ * @param {number} op
198
+ * @param {DataView} pArg
199
+ * @returns {number|Promise<number>}
200
+ */
201
+ jFileControl(pFile, op, pArg) {
202
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTFOUND;
203
+ }
204
+
205
+ /**
206
+ * @param {number} pFile
207
+ * @returns {number|Promise<number>}
208
+ */
209
+ jSectorSize(pFile) {
210
+ return super.xSectorSize(pFile);
211
+ }
212
+
213
+ /**
214
+ * @param {number} pFile
215
+ * @returns {number|Promise<number>}
216
+ */
217
+ jDeviceCharacteristics(pFile) {
218
+ return 0;
219
+ }
220
+
221
+ /**
222
+ * @param {number} pVfs
223
+ * @param {number} zName
224
+ * @param {number} pFile
225
+ * @param {number} flags
226
+ * @param {number} pOutFlags
227
+ * @returns {number|Promise<number>}
228
+ */
229
+ xOpen(pVfs, zName, pFile, flags, pOutFlags) {
230
+ const filename = this.#decodeFilename(zName, flags);
231
+ const pOutFlagsView = this.#makeTypedDataView('Int32', pOutFlags);
232
+ this['log']?.('jOpen', filename, pFile, '0x' + flags.toString(16));
233
+ return this.jOpen(filename, pFile, flags, pOutFlagsView);
234
+ }
235
+
236
+ /**
237
+ * @param {number} pVfs
238
+ * @param {number} nByte
239
+ * @param {number} pCharOut
240
+ * @returns {number|Promise<number>}
241
+ */
242
+ xRandomness(pVfs, nByte, pCharOut) {
243
+ const randomArray = new Uint8Array(nByte);
244
+ crypto.getRandomValues(randomArray);
245
+ // Copy randomArray to the WebAssembly memory
246
+ const buffer = pCharOut; // Pointer to memory in WebAssembly
247
+ this._module.HEAPU8.set(randomArray, buffer); // Copy randomArray into memory starting at buffer
248
+ return nByte;
249
+ }
250
+
251
+ /**
252
+ * Gets the current time as milliseconds since Unix epoch
253
+ * @param {number} pVfs pointer to the VFS
254
+ * @param {number} pTime pointer to write the time value
255
+ * @returns {number} SQLite error code
256
+ */
257
+ xCurrentTimeInt64(pVfs, pTime) {
258
+ // Create a DataView to write the current time
259
+ const timeView = this.#makeTypedDataView('BigInt64', pTime);
260
+
261
+ const currentTime = BigInt(Date.now());
262
+ // Convert the current time to milliseconds since Unix epoch
263
+ const value = UNIX_EPOCH + currentTime;
264
+
265
+ // Write the time value to the pointer location
266
+ timeView.setBigInt64(0, value, true);
267
+
268
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
269
+ }
270
+
271
+ /**
272
+ * @param {number} pVfs
273
+ * @param {number} zName
274
+ * @param {number} syncDir
275
+ * @returns {number|Promise<number>}
276
+ */
277
+ xDelete(pVfs, zName, syncDir) {
278
+ const filename = this._module.UTF8ToString(zName);
279
+ this['log']?.('jDelete', filename, syncDir);
280
+ return this.jDelete(filename, syncDir);
281
+ }
282
+
283
+ /**
284
+ * @param {number} pVfs
285
+ * @param {number} zName
286
+ * @param {number} flags
287
+ * @param {number} pResOut
288
+ * @returns {number|Promise<number>}
289
+ */
290
+ xAccess(pVfs, zName, flags, pResOut) {
291
+ const filename = this._module.UTF8ToString(zName);
292
+ const pResOutView = this.#makeTypedDataView('Int32', pResOut);
293
+ this['log']?.('jAccess', filename, flags);
294
+ return this.jAccess(filename, flags, pResOutView);
295
+ }
296
+
297
+ /**
298
+ * @param {number} pVfs
299
+ * @param {number} zName
300
+ * @param {number} nOut
301
+ * @param {number} zOut
302
+ * @returns {number|Promise<number>}
303
+ */
304
+ xFullPathname(pVfs, zName, nOut, zOut) {
305
+ const filename = this._module.UTF8ToString(zName);
306
+ const zOutArray = this._module.HEAPU8.subarray(zOut, zOut + nOut);
307
+ this['log']?.('jFullPathname', filename, nOut);
308
+ return this.jFullPathname(filename, zOutArray);
309
+ }
310
+
311
+ /**
312
+ * @param {number} pVfs
313
+ * @param {number} nBuf
314
+ * @param {number} zBuf
315
+ * @returns {number|Promise<number>}
316
+ */
317
+ xGetLastError(pVfs, nBuf, zBuf) {
318
+ const zBufArray = this._module.HEAPU8.subarray(zBuf, zBuf + nBuf);
319
+ this['log']?.('jGetLastError', nBuf);
320
+ return this.jGetLastError(zBufArray);
321
+ }
322
+
323
+ /**
324
+ * @param {number} pFile
325
+ * @returns {number|Promise<number>}
326
+ */
327
+ xClose(pFile) {
328
+ this['log']?.('jClose', pFile);
329
+ return this.jClose(pFile);
330
+ }
331
+
332
+ /**
333
+ * @param {number} pFile
334
+ * @param {number} pData
335
+ * @param {number} iAmt
336
+ * @param {number} iOffsetLo
337
+ * @param {number} iOffsetHi
338
+ * @returns {number|Promise<number>}
339
+ */
340
+ xRead(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
341
+ const pDataArray = this.#makeDataArray(pData, iAmt);
342
+ const iOffset = delegalize(iOffsetLo, iOffsetHi);
343
+ this['log']?.('jRead', pFile, iAmt, iOffset);
344
+ return this.jRead(pFile, pDataArray, iOffset);
345
+ }
346
+
347
+ /**
348
+ * @param {number} pFile
349
+ * @param {number} pData
350
+ * @param {number} iAmt
351
+ * @param {number} iOffsetLo
352
+ * @param {number} iOffsetHi
353
+ * @returns {number|Promise<number>}
354
+ */
355
+ xWrite(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
356
+ const pDataArray = this.#makeDataArray(pData, iAmt);
357
+ const iOffset = delegalize(iOffsetLo, iOffsetHi);
358
+ this['log']?.('jWrite', pFile, pDataArray, iOffset);
359
+ return this.jWrite(pFile, pDataArray, iOffset);
360
+ }
361
+
362
+ /**
363
+ * @param {number} pFile
364
+ * @param {number} sizeLo
365
+ * @param {number} sizeHi
366
+ * @returns {number|Promise<number>}
367
+ */
368
+ xTruncate(pFile, sizeLo, sizeHi) {
369
+ const size = delegalize(sizeLo, sizeHi);
370
+ this['log']?.('jTruncate', pFile, size);
371
+ return this.jTruncate(pFile, size);
372
+ }
373
+
374
+ /**
375
+ * @param {number} pFile
376
+ * @param {number} flags
377
+ * @returns {number|Promise<number>}
378
+ */
379
+ xSync(pFile, flags) {
380
+ this['log']?.('jSync', pFile, flags);
381
+ return this.jSync(pFile, flags);
382
+ }
383
+
384
+ /**
385
+ *
386
+ * @param {number} pFile
387
+ * @param {number} pSize
388
+ * @returns {number|Promise<number>}
389
+ */
390
+ xFileSize(pFile, pSize) {
391
+ const pSizeView = this.#makeTypedDataView('BigInt64', pSize);
392
+ this['log']?.('jFileSize', pFile);
393
+ return this.jFileSize(pFile, pSizeView);
394
+ }
395
+
396
+ /**
397
+ * @param {number} pFile
398
+ * @param {number} lockType
399
+ * @returns {number|Promise<number>}
400
+ */
401
+ xLock(pFile, lockType) {
402
+ this['log']?.('jLock', pFile, lockType);
403
+ return this.jLock(pFile, lockType);
404
+ }
405
+
406
+ /**
407
+ * @param {number} pFile
408
+ * @param {number} lockType
409
+ * @returns {number|Promise<number>}
410
+ */
411
+ xUnlock(pFile, lockType) {
412
+ this['log']?.('jUnlock', pFile, lockType);
413
+ return this.jUnlock(pFile, lockType);
414
+ }
415
+
416
+ /**
417
+ * @param {number} pFile
418
+ * @param {number} pResOut
419
+ * @returns {number|Promise<number>}
420
+ */
421
+ xCheckReservedLock(pFile, pResOut) {
422
+ const pResOutView = this.#makeTypedDataView('Int32', pResOut);
423
+ this['log']?.('jCheckReservedLock', pFile);
424
+ return this.jCheckReservedLock(pFile, pResOutView);
425
+ }
426
+
427
+ /**
428
+ * @param {number} pFile
429
+ * @param {number} op
430
+ * @param {number} pArg
431
+ * @returns {number|Promise<number>}
432
+ */
433
+ xFileControl(pFile, op, pArg) {
434
+ const pArgView = new DataView(
435
+ this._module.HEAPU8.buffer,
436
+ this._module.HEAPU8.byteOffset + pArg);
437
+ this['log']?.('jFileControl', pFile, op, pArgView);
438
+ return this.jFileControl(pFile, op, pArgView);
439
+ }
440
+
441
+ /**
442
+ * @param {number} pFile
443
+ * @returns {number|Promise<number>}
444
+ */
445
+ xSectorSize(pFile) {
446
+ this['log']?.('jSectorSize', pFile);
447
+ return this.jSectorSize(pFile);
448
+ }
449
+
450
+ /**
451
+ * @param {number} pFile
452
+ * @returns {number|Promise<number>}
453
+ */
454
+ xDeviceCharacteristics(pFile) {
455
+ this['log']?.('jDeviceCharacteristics', pFile);
456
+ return this.jDeviceCharacteristics(pFile);
457
+ }
458
+
459
+ /**
460
+ * Wrapped DataView for pointer arguments.
461
+ * Pointers to a single value are passed using DataView. A Proxy
462
+ * wrapper prevents use of incorrect type or endianness.
463
+ * @param {'Int32'|'BigInt64'} type
464
+ * @param {number} byteOffset
465
+ * @returns {DataView}
466
+ */
467
+ #makeTypedDataView(type, byteOffset) {
468
+ const byteLength = type === 'Int32' ? 4 : 8;
469
+ const getter = `get${type}`;
470
+ const setter = `set${type}`;
471
+ const makeDataView = () => new DataView(
472
+ this._module.HEAPU8.buffer,
473
+ this._module.HEAPU8.byteOffset + byteOffset,
474
+ byteLength);
475
+ let dataView = makeDataView();
476
+ return new Proxy(dataView, {
477
+ get(_, prop) {
478
+ if (dataView.buffer.byteLength === 0) {
479
+ // WebAssembly memory resize detached the buffer.
480
+ dataView = makeDataView();
481
+ }
482
+ if (prop === getter) {
483
+ return function(byteOffset, littleEndian) {
484
+ if (!littleEndian) throw new Error('must be little endian');
485
+ return dataView[prop](byteOffset, littleEndian);
486
+ }
487
+ }
488
+ if (prop === setter) {
489
+ return function(byteOffset, value, littleEndian) {
490
+ if (!littleEndian) throw new Error('must be little endian');
491
+ return dataView[prop](byteOffset, value, littleEndian);
492
+ }
493
+ }
494
+ if (typeof prop === 'string' && (prop.match(/^(get)|(set)/))) {
495
+ throw new Error('invalid type');
496
+ }
497
+ const result = dataView[prop];
498
+ return typeof result === 'function' ? result.bind(dataView) : result;
499
+ }
500
+ });
501
+ }
502
+
503
+ /**
504
+ * @param {number} byteOffset
505
+ * @param {number} byteLength
506
+ */
507
+ #makeDataArray(byteOffset, byteLength) {
508
+ let target = this._module.HEAPU8.subarray(byteOffset, byteOffset + byteLength);
509
+ return new Proxy(target, {
510
+ get: (_, prop, receiver) => {
511
+ if (target.buffer.byteLength === 0) {
512
+ // WebAssembly memory resize detached the buffer.
513
+ target = this._module.HEAPU8.subarray(byteOffset, byteOffset + byteLength);
514
+ }
515
+ const result = target[prop];
516
+ return typeof result === 'function' ? result.bind(target) : result;
517
+ }
518
+ });
519
+ }
520
+
521
+ #decodeFilename(zName, flags) {
522
+ if (flags & _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_URI) {
523
+ // The first null-terminated string is the URI path. Subsequent
524
+ // strings are query parameter keys and values.
525
+ // https://www.sqlite.org/c3ref/open.html#urifilenamesinsqlite3open
526
+ let pName = zName;
527
+ let state = 1;
528
+ const charCodes = [];
529
+ while (state) {
530
+ const charCode = this._module.HEAPU8[pName++];
531
+ if (charCode) {
532
+ charCodes.push(charCode);
533
+ } else {
534
+ if (!this._module.HEAPU8[pName]) state = null;
535
+ switch (state) {
536
+ case 1: // path
537
+ charCodes.push('?'.charCodeAt(0));
538
+ state = 2;
539
+ break;
540
+ case 2: // key
541
+ charCodes.push('='.charCodeAt(0));
542
+ state = 3;
543
+ break;
544
+ case 3: // value
545
+ charCodes.push('&'.charCodeAt(0));
546
+ state = 2;
547
+ break;
548
+ }
549
+ }
550
+ }
551
+ return new TextDecoder().decode(new Uint8Array(charCodes));
552
+ }
553
+ return zName ? this._module.UTF8ToString(zName) : null;
554
+ }
555
+ }
556
+
557
+ // Emscripten "legalizes" 64-bit integer arguments by passing them as
558
+ // two 32-bit signed integers.
559
+ function delegalize(lo32, hi32) {
560
+ return (hi32 * 0x100000000) + lo32 + (lo32 < 0 ? 2**32 : 0);
561
+ }
562
+
563
+
564
+ /***/ }),
565
+
566
+ /***/ "../../node_modules/@journeyapps/wa-sqlite/src/VFS.js":
567
+ /*!************************************************************!*\
568
+ !*** ../../node_modules/@journeyapps/wa-sqlite/src/VFS.js ***!
569
+ \************************************************************/
570
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
571
+
572
+ __webpack_require__.r(__webpack_exports__);
573
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
574
+ /* harmony export */ Base: () => (/* binding */ Base),
575
+ /* harmony export */ FILE_TYPE_MASK: () => (/* binding */ FILE_TYPE_MASK),
576
+ /* harmony export */ SQLITE_ABORT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ABORT),
577
+ /* harmony export */ SQLITE_ACCESS_EXISTS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ACCESS_EXISTS),
578
+ /* harmony export */ SQLITE_ACCESS_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ACCESS_READ),
579
+ /* harmony export */ SQLITE_ACCESS_READWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ACCESS_READWRITE),
580
+ /* harmony export */ SQLITE_ALTER_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ALTER_TABLE),
581
+ /* harmony export */ SQLITE_ANALYZE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ANALYZE),
582
+ /* harmony export */ SQLITE_ATTACH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ATTACH),
583
+ /* harmony export */ SQLITE_AUTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_AUTH),
584
+ /* harmony export */ SQLITE_BLOB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_BLOB),
585
+ /* harmony export */ SQLITE_BUSY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_BUSY),
586
+ /* harmony export */ SQLITE_CANTOPEN: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CANTOPEN),
587
+ /* harmony export */ SQLITE_CONSTRAINT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT),
588
+ /* harmony export */ SQLITE_CONSTRAINT_CHECK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_CHECK),
589
+ /* harmony export */ SQLITE_CONSTRAINT_COMMITHOOK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_COMMITHOOK),
590
+ /* harmony export */ SQLITE_CONSTRAINT_FOREIGNKEY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_FOREIGNKEY),
591
+ /* harmony export */ SQLITE_CONSTRAINT_FUNCTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_FUNCTION),
592
+ /* harmony export */ SQLITE_CONSTRAINT_NOTNULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_NOTNULL),
593
+ /* harmony export */ SQLITE_CONSTRAINT_PINNED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_PINNED),
594
+ /* harmony export */ SQLITE_CONSTRAINT_PRIMARYKEY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_PRIMARYKEY),
595
+ /* harmony export */ SQLITE_CONSTRAINT_ROWID: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_ROWID),
596
+ /* harmony export */ SQLITE_CONSTRAINT_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_TRIGGER),
597
+ /* harmony export */ SQLITE_CONSTRAINT_UNIQUE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_UNIQUE),
598
+ /* harmony export */ SQLITE_CONSTRAINT_VTAB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_VTAB),
599
+ /* harmony export */ SQLITE_COPY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_COPY),
600
+ /* harmony export */ SQLITE_CORRUPT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CORRUPT),
601
+ /* harmony export */ SQLITE_CREATE_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_INDEX),
602
+ /* harmony export */ SQLITE_CREATE_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TABLE),
603
+ /* harmony export */ SQLITE_CREATE_TEMP_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_INDEX),
604
+ /* harmony export */ SQLITE_CREATE_TEMP_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_TABLE),
605
+ /* harmony export */ SQLITE_CREATE_TEMP_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_TRIGGER),
606
+ /* harmony export */ SQLITE_CREATE_TEMP_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_VIEW),
607
+ /* harmony export */ SQLITE_CREATE_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TRIGGER),
608
+ /* harmony export */ SQLITE_CREATE_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_VIEW),
609
+ /* harmony export */ SQLITE_CREATE_VTABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_VTABLE),
610
+ /* harmony export */ SQLITE_DELETE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DELETE),
611
+ /* harmony export */ SQLITE_DENY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DENY),
612
+ /* harmony export */ SQLITE_DETACH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DETACH),
613
+ /* harmony export */ SQLITE_DETERMINISTIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DETERMINISTIC),
614
+ /* harmony export */ SQLITE_DIRECTONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DIRECTONLY),
615
+ /* harmony export */ SQLITE_DONE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DONE),
616
+ /* harmony export */ SQLITE_DROP_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_INDEX),
617
+ /* harmony export */ SQLITE_DROP_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TABLE),
618
+ /* harmony export */ SQLITE_DROP_TEMP_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_INDEX),
619
+ /* harmony export */ SQLITE_DROP_TEMP_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_TABLE),
620
+ /* harmony export */ SQLITE_DROP_TEMP_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_TRIGGER),
621
+ /* harmony export */ SQLITE_DROP_TEMP_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_VIEW),
622
+ /* harmony export */ SQLITE_DROP_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TRIGGER),
623
+ /* harmony export */ SQLITE_DROP_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_VIEW),
624
+ /* harmony export */ SQLITE_DROP_VTABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_VTABLE),
625
+ /* harmony export */ SQLITE_EMPTY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_EMPTY),
626
+ /* harmony export */ SQLITE_ERROR: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ERROR),
627
+ /* harmony export */ SQLITE_FCNTL_BEGIN_ATOMIC_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_BEGIN_ATOMIC_WRITE),
628
+ /* harmony export */ SQLITE_FCNTL_BUSYHANDLER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_BUSYHANDLER),
629
+ /* harmony export */ SQLITE_FCNTL_CHUNK_SIZE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_CHUNK_SIZE),
630
+ /* harmony export */ SQLITE_FCNTL_CKPT_DONE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_CKPT_DONE),
631
+ /* harmony export */ SQLITE_FCNTL_CKPT_START: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_CKPT_START),
632
+ /* harmony export */ SQLITE_FCNTL_COMMIT_ATOMIC_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_COMMIT_ATOMIC_WRITE),
633
+ /* harmony export */ SQLITE_FCNTL_COMMIT_PHASETWO: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_COMMIT_PHASETWO),
634
+ /* harmony export */ SQLITE_FCNTL_DATA_VERSION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_DATA_VERSION),
635
+ /* harmony export */ SQLITE_FCNTL_FILE_POINTER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_FILE_POINTER),
636
+ /* harmony export */ SQLITE_FCNTL_GET_LOCKPROXYFILE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_GET_LOCKPROXYFILE),
637
+ /* harmony export */ SQLITE_FCNTL_HAS_MOVED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_HAS_MOVED),
638
+ /* harmony export */ SQLITE_FCNTL_JOURNAL_POINTER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_JOURNAL_POINTER),
639
+ /* harmony export */ SQLITE_FCNTL_LAST_ERRNO: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_LAST_ERRNO),
640
+ /* harmony export */ SQLITE_FCNTL_LOCKSTATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_LOCKSTATE),
641
+ /* harmony export */ SQLITE_FCNTL_LOCK_TIMEOUT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_LOCK_TIMEOUT),
642
+ /* harmony export */ SQLITE_FCNTL_MMAP_SIZE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_MMAP_SIZE),
643
+ /* harmony export */ SQLITE_FCNTL_OVERWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_OVERWRITE),
644
+ /* harmony export */ SQLITE_FCNTL_PDB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_PDB),
645
+ /* harmony export */ SQLITE_FCNTL_PERSIST_WAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_PERSIST_WAL),
646
+ /* harmony export */ SQLITE_FCNTL_POWERSAFE_OVERWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_POWERSAFE_OVERWRITE),
647
+ /* harmony export */ SQLITE_FCNTL_PRAGMA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_PRAGMA),
648
+ /* harmony export */ SQLITE_FCNTL_RBU: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_RBU),
649
+ /* harmony export */ SQLITE_FCNTL_RESERVE_BYTES: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_RESERVE_BYTES),
650
+ /* harmony export */ SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE),
651
+ /* harmony export */ SQLITE_FCNTL_SET_LOCKPROXYFILE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SET_LOCKPROXYFILE),
652
+ /* harmony export */ SQLITE_FCNTL_SIZE_HINT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SIZE_HINT),
653
+ /* harmony export */ SQLITE_FCNTL_SIZE_LIMIT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SIZE_LIMIT),
654
+ /* harmony export */ SQLITE_FCNTL_SYNC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SYNC),
655
+ /* harmony export */ SQLITE_FCNTL_SYNC_OMITTED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SYNC_OMITTED),
656
+ /* harmony export */ SQLITE_FCNTL_TEMPFILENAME: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_TEMPFILENAME),
657
+ /* harmony export */ SQLITE_FCNTL_TRACE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_TRACE),
658
+ /* harmony export */ SQLITE_FCNTL_VFSNAME: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_VFSNAME),
659
+ /* harmony export */ SQLITE_FCNTL_VFS_POINTER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_VFS_POINTER),
660
+ /* harmony export */ SQLITE_FCNTL_WAL_BLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WAL_BLOCK),
661
+ /* harmony export */ SQLITE_FCNTL_WIN32_AV_RETRY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WIN32_AV_RETRY),
662
+ /* harmony export */ SQLITE_FCNTL_WIN32_GET_HANDLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WIN32_GET_HANDLE),
663
+ /* harmony export */ SQLITE_FCNTL_WIN32_SET_HANDLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WIN32_SET_HANDLE),
664
+ /* harmony export */ SQLITE_FCNTL_ZIPVFS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_ZIPVFS),
665
+ /* harmony export */ SQLITE_FLOAT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FLOAT),
666
+ /* harmony export */ SQLITE_FORMAT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FORMAT),
667
+ /* harmony export */ SQLITE_FULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FULL),
668
+ /* harmony export */ SQLITE_FUNCTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FUNCTION),
669
+ /* harmony export */ SQLITE_IGNORE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IGNORE),
670
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_EQ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_EQ),
671
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_FUNCTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_FUNCTION),
672
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_GE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_GE),
673
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_GLOB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_GLOB),
674
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_GT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_GT),
675
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_IS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_IS),
676
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_ISNOT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_ISNOT),
677
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_ISNOTNULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_ISNOTNULL),
678
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_ISNULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_ISNULL),
679
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_LE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_LE),
680
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_LIKE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_LIKE),
681
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_LT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_LT),
682
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_MATCH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_MATCH),
683
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_NE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_NE),
684
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_REGEXP: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_REGEXP),
685
+ /* harmony export */ SQLITE_INDEX_SCAN_UNIQUE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_SCAN_UNIQUE),
686
+ /* harmony export */ SQLITE_INNOCUOUS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INNOCUOUS),
687
+ /* harmony export */ SQLITE_INSERT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INSERT),
688
+ /* harmony export */ SQLITE_INTEGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INTEGER),
689
+ /* harmony export */ SQLITE_INTERNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INTERNAL),
690
+ /* harmony export */ SQLITE_INTERRUPT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INTERRUPT),
691
+ /* harmony export */ SQLITE_IOCAP_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC),
692
+ /* harmony export */ SQLITE_IOCAP_ATOMIC16K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC16K),
693
+ /* harmony export */ SQLITE_IOCAP_ATOMIC1K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC1K),
694
+ /* harmony export */ SQLITE_IOCAP_ATOMIC2K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC2K),
695
+ /* harmony export */ SQLITE_IOCAP_ATOMIC32K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC32K),
696
+ /* harmony export */ SQLITE_IOCAP_ATOMIC4K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC4K),
697
+ /* harmony export */ SQLITE_IOCAP_ATOMIC512: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC512),
698
+ /* harmony export */ SQLITE_IOCAP_ATOMIC64K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC64K),
699
+ /* harmony export */ SQLITE_IOCAP_ATOMIC8K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC8K),
700
+ /* harmony export */ SQLITE_IOCAP_BATCH_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_BATCH_ATOMIC),
701
+ /* harmony export */ SQLITE_IOCAP_IMMUTABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_IMMUTABLE),
702
+ /* harmony export */ SQLITE_IOCAP_POWERSAFE_OVERWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_POWERSAFE_OVERWRITE),
703
+ /* harmony export */ SQLITE_IOCAP_SAFE_APPEND: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_SAFE_APPEND),
704
+ /* harmony export */ SQLITE_IOCAP_SEQUENTIAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_SEQUENTIAL),
705
+ /* harmony export */ SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN),
706
+ /* harmony export */ SQLITE_IOERR: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR),
707
+ /* harmony export */ SQLITE_IOERR_ACCESS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_ACCESS),
708
+ /* harmony export */ SQLITE_IOERR_BEGIN_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_BEGIN_ATOMIC),
709
+ /* harmony export */ SQLITE_IOERR_CHECKRESERVEDLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_CHECKRESERVEDLOCK),
710
+ /* harmony export */ SQLITE_IOERR_CLOSE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_CLOSE),
711
+ /* harmony export */ SQLITE_IOERR_COMMIT_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_COMMIT_ATOMIC),
712
+ /* harmony export */ SQLITE_IOERR_DATA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DATA),
713
+ /* harmony export */ SQLITE_IOERR_DELETE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DELETE),
714
+ /* harmony export */ SQLITE_IOERR_DELETE_NOENT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DELETE_NOENT),
715
+ /* harmony export */ SQLITE_IOERR_DIR_FSYNC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DIR_FSYNC),
716
+ /* harmony export */ SQLITE_IOERR_FSTAT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_FSTAT),
717
+ /* harmony export */ SQLITE_IOERR_FSYNC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_FSYNC),
718
+ /* harmony export */ SQLITE_IOERR_GETTEMPPATH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_GETTEMPPATH),
719
+ /* harmony export */ SQLITE_IOERR_LOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_LOCK),
720
+ /* harmony export */ SQLITE_IOERR_NOMEM: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_NOMEM),
721
+ /* harmony export */ SQLITE_IOERR_RDLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_RDLOCK),
722
+ /* harmony export */ SQLITE_IOERR_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_READ),
723
+ /* harmony export */ SQLITE_IOERR_ROLLBACK_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_ROLLBACK_ATOMIC),
724
+ /* harmony export */ SQLITE_IOERR_SEEK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_SEEK),
725
+ /* harmony export */ SQLITE_IOERR_SHORT_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_SHORT_READ),
726
+ /* harmony export */ SQLITE_IOERR_TRUNCATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_TRUNCATE),
727
+ /* harmony export */ SQLITE_IOERR_UNLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_UNLOCK),
728
+ /* harmony export */ SQLITE_IOERR_VNODE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_VNODE),
729
+ /* harmony export */ SQLITE_IOERR_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_WRITE),
730
+ /* harmony export */ SQLITE_LIMIT_ATTACHED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_ATTACHED),
731
+ /* harmony export */ SQLITE_LIMIT_COLUMN: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_COLUMN),
732
+ /* harmony export */ SQLITE_LIMIT_COMPOUND_SELECT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_COMPOUND_SELECT),
733
+ /* harmony export */ SQLITE_LIMIT_EXPR_DEPTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_EXPR_DEPTH),
734
+ /* harmony export */ SQLITE_LIMIT_FUNCTION_ARG: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_FUNCTION_ARG),
735
+ /* harmony export */ SQLITE_LIMIT_LENGTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_LENGTH),
736
+ /* harmony export */ SQLITE_LIMIT_LIKE_PATTERN_LENGTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_LIKE_PATTERN_LENGTH),
737
+ /* harmony export */ SQLITE_LIMIT_SQL_LENGTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_SQL_LENGTH),
738
+ /* harmony export */ SQLITE_LIMIT_TRIGGER_DEPTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_TRIGGER_DEPTH),
739
+ /* harmony export */ SQLITE_LIMIT_VARIABLE_NUMBER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_VARIABLE_NUMBER),
740
+ /* harmony export */ SQLITE_LIMIT_VDBE_OP: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_VDBE_OP),
741
+ /* harmony export */ SQLITE_LIMIT_WORKER_THREADS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_WORKER_THREADS),
742
+ /* harmony export */ SQLITE_LOCKED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCKED),
743
+ /* harmony export */ SQLITE_LOCK_EXCLUSIVE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_EXCLUSIVE),
744
+ /* harmony export */ SQLITE_LOCK_NONE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_NONE),
745
+ /* harmony export */ SQLITE_LOCK_PENDING: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_PENDING),
746
+ /* harmony export */ SQLITE_LOCK_RESERVED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_RESERVED),
747
+ /* harmony export */ SQLITE_LOCK_SHARED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_SHARED),
748
+ /* harmony export */ SQLITE_MISMATCH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_MISMATCH),
749
+ /* harmony export */ SQLITE_MISUSE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_MISUSE),
750
+ /* harmony export */ SQLITE_NOLFS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOLFS),
751
+ /* harmony export */ SQLITE_NOMEM: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOMEM),
752
+ /* harmony export */ SQLITE_NOTADB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTADB),
753
+ /* harmony export */ SQLITE_NOTFOUND: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTFOUND),
754
+ /* harmony export */ SQLITE_NOTICE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTICE),
755
+ /* harmony export */ SQLITE_NULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NULL),
756
+ /* harmony export */ SQLITE_OK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK),
757
+ /* harmony export */ SQLITE_OPEN_AUTOPROXY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_AUTOPROXY),
758
+ /* harmony export */ SQLITE_OPEN_CREATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_CREATE),
759
+ /* harmony export */ SQLITE_OPEN_DELETEONCLOSE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_DELETEONCLOSE),
760
+ /* harmony export */ SQLITE_OPEN_EXCLUSIVE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_EXCLUSIVE),
761
+ /* harmony export */ SQLITE_OPEN_FULLMUTEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_FULLMUTEX),
762
+ /* harmony export */ SQLITE_OPEN_MAIN_DB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_DB),
763
+ /* harmony export */ SQLITE_OPEN_MAIN_JOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_JOURNAL),
764
+ /* harmony export */ SQLITE_OPEN_MEMORY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MEMORY),
765
+ /* harmony export */ SQLITE_OPEN_NOFOLLOW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_NOFOLLOW),
766
+ /* harmony export */ SQLITE_OPEN_NOMUTEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_NOMUTEX),
767
+ /* harmony export */ SQLITE_OPEN_PRIVATECACHE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_PRIVATECACHE),
768
+ /* harmony export */ SQLITE_OPEN_READONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_READONLY),
769
+ /* harmony export */ SQLITE_OPEN_READWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_READWRITE),
770
+ /* harmony export */ SQLITE_OPEN_SHAREDCACHE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SHAREDCACHE),
771
+ /* harmony export */ SQLITE_OPEN_SUBJOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUBJOURNAL),
772
+ /* harmony export */ SQLITE_OPEN_SUPER_JOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUPER_JOURNAL),
773
+ /* harmony export */ SQLITE_OPEN_TEMP_DB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_DB),
774
+ /* harmony export */ SQLITE_OPEN_TEMP_JOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_JOURNAL),
775
+ /* harmony export */ SQLITE_OPEN_TRANSIENT_DB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TRANSIENT_DB),
776
+ /* harmony export */ SQLITE_OPEN_URI: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_URI),
777
+ /* harmony export */ SQLITE_OPEN_WAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_WAL),
778
+ /* harmony export */ SQLITE_PERM: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PERM),
779
+ /* harmony export */ SQLITE_PRAGMA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PRAGMA),
780
+ /* harmony export */ SQLITE_PREPARE_NORMALIZED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PREPARE_NORMALIZED),
781
+ /* harmony export */ SQLITE_PREPARE_NO_VTAB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PREPARE_NO_VTAB),
782
+ /* harmony export */ SQLITE_PREPARE_PERSISTENT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PREPARE_PERSISTENT),
783
+ /* harmony export */ SQLITE_PROTOCOL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PROTOCOL),
784
+ /* harmony export */ SQLITE_RANGE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_RANGE),
785
+ /* harmony export */ SQLITE_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_READ),
786
+ /* harmony export */ SQLITE_READONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_READONLY),
787
+ /* harmony export */ SQLITE_RECURSIVE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_RECURSIVE),
788
+ /* harmony export */ SQLITE_REINDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_REINDEX),
789
+ /* harmony export */ SQLITE_ROW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ROW),
790
+ /* harmony export */ SQLITE_SAVEPOINT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SAVEPOINT),
791
+ /* harmony export */ SQLITE_SCHEMA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SCHEMA),
792
+ /* harmony export */ SQLITE_SELECT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SELECT),
793
+ /* harmony export */ SQLITE_STATIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_STATIC),
794
+ /* harmony export */ SQLITE_SUBTYPE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SUBTYPE),
795
+ /* harmony export */ SQLITE_SYNC_DATAONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SYNC_DATAONLY),
796
+ /* harmony export */ SQLITE_SYNC_FULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SYNC_FULL),
797
+ /* harmony export */ SQLITE_SYNC_NORMAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SYNC_NORMAL),
798
+ /* harmony export */ SQLITE_TEXT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TEXT),
799
+ /* harmony export */ SQLITE_TOOBIG: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TOOBIG),
800
+ /* harmony export */ SQLITE_TRANSACTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TRANSACTION),
801
+ /* harmony export */ SQLITE_TRANSIENT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TRANSIENT),
802
+ /* harmony export */ SQLITE_UPDATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UPDATE),
803
+ /* harmony export */ SQLITE_UTF16: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF16),
804
+ /* harmony export */ SQLITE_UTF16BE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF16BE),
805
+ /* harmony export */ SQLITE_UTF16LE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF16LE),
806
+ /* harmony export */ SQLITE_UTF8: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF8),
807
+ /* harmony export */ SQLITE_WARNING: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_WARNING)
808
+ /* harmony export */ });
809
+ /* harmony import */ var _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sqlite-constants.js */ "../../node_modules/@journeyapps/wa-sqlite/src/sqlite-constants.js");
810
+ // Copyright 2024 Roy T. Hashimoto. All Rights Reserved.
811
+
812
+
813
+
814
+ const DEFAULT_SECTOR_SIZE = 512;
815
+
816
+ // Base class for a VFS.
817
+ class Base {
818
+ name;
819
+ mxPathname = 64;
820
+ _module;
821
+
822
+ /**
823
+ * @param {string} name
824
+ * @param {object} module
825
+ */
826
+ constructor(name, module) {
827
+ this.name = name;
828
+ this._module = module;
829
+ }
830
+
831
+ /**
832
+ * @returns {void|Promise<void>}
833
+ */
834
+ close() {
835
+ }
836
+
837
+ /**
838
+ * @returns {boolean|Promise<boolean>}
839
+ */
840
+ isReady() {
841
+ return true;
842
+ }
843
+
844
+ /**
845
+ * Overload in subclasses to indicate which methods are asynchronous.
846
+ * @param {string} methodName
847
+ * @returns {boolean}
848
+ */
849
+ hasAsyncMethod(methodName) {
850
+ return false;
851
+ }
852
+
853
+ /**
854
+ * @param {number} pVfs
855
+ * @param {number} zName
856
+ * @param {number} pFile
857
+ * @param {number} flags
858
+ * @param {number} pOutFlags
859
+ * @returns {number|Promise<number>}
860
+ */
861
+ xOpen(pVfs, zName, pFile, flags, pOutFlags) {
862
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CANTOPEN;
863
+ }
864
+
865
+ /**
866
+ * @param {number} pVfs
867
+ * @param {number} zName
868
+ * @param {number} syncDir
869
+ * @returns {number|Promise<number>}
870
+ */
871
+ xDelete(pVfs, zName, syncDir) {
872
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
873
+ }
874
+
875
+ /**
876
+ * @param {number} pVfs
877
+ * @param {number} zName
878
+ * @param {number} flags
879
+ * @param {number} pResOut
880
+ * @returns {number|Promise<number>}
881
+ */
882
+ xAccess(pVfs, zName, flags, pResOut) {
883
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
884
+ }
885
+
886
+ /**
887
+ * @param {number} pVfs
888
+ * @param {number} zName
889
+ * @param {number} nOut
890
+ * @param {number} zOut
891
+ * @returns {number|Promise<number>}
892
+ */
893
+ xFullPathname(pVfs, zName, nOut, zOut) {
894
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
895
+ }
896
+
897
+ /**
898
+ * @param {number} pVfs
899
+ * @param {number} nBuf
900
+ * @param {number} zBuf
901
+ * @returns {number|Promise<number>}
902
+ */
903
+ xGetLastError(pVfs, nBuf, zBuf) {
904
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
905
+ }
906
+
907
+ /**
908
+ * @param {number} pFile
909
+ * @returns {number|Promise<number>}
910
+ */
911
+ xClose(pFile) {
912
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
913
+ }
914
+
915
+ /**
916
+ * @param {number} pFile
917
+ * @param {number} pData
918
+ * @param {number} iAmt
919
+ * @param {number} iOffsetLo
920
+ * @param {number} iOffsetHi
921
+ * @returns {number|Promise<number>}
922
+ */
923
+ xRead(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
924
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
925
+ }
926
+
927
+ /**
928
+ * @param {number} pFile
929
+ * @param {number} pData
930
+ * @param {number} iAmt
931
+ * @param {number} iOffsetLo
932
+ * @param {number} iOffsetHi
933
+ * @returns {number|Promise<number>}
934
+ */
935
+ xWrite(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
936
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
937
+ }
938
+
939
+ /**
940
+ * @param {number} pFile
941
+ * @param {number} sizeLo
942
+ * @param {number} sizeHi
943
+ * @returns {number|Promise<number>}
944
+ */
945
+ xTruncate(pFile, sizeLo, sizeHi) {
946
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
947
+ }
948
+
949
+ /**
950
+ * @param {number} pFile
951
+ * @param {number} flags
952
+ * @returns {number|Promise<number>}
953
+ */
954
+ xSync(pFile, flags) {
955
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
956
+ }
957
+
958
+ /**
959
+ *
960
+ * @param {number} pFile
961
+ * @param {number} pSize
962
+ * @returns {number|Promise<number>}
963
+ */
964
+ xFileSize(pFile, pSize) {
965
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
966
+ }
967
+
968
+ /**
969
+ * @param {number} pFile
970
+ * @param {number} lockType
971
+ * @returns {number|Promise<number>}
972
+ */
973
+ xLock(pFile, lockType) {
974
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
975
+ }
976
+
977
+ /**
978
+ * @param {number} pFile
979
+ * @param {number} lockType
980
+ * @returns {number|Promise<number>}
981
+ */
982
+ xUnlock(pFile, lockType) {
983
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
984
+ }
985
+
986
+ /**
987
+ * @param {number} pFile
988
+ * @param {number} pResOut
989
+ * @returns {number|Promise<number>}
990
+ */
991
+ xCheckReservedLock(pFile, pResOut) {
992
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
993
+ }
994
+
995
+ /**
996
+ * @param {number} pFile
997
+ * @param {number} op
998
+ * @param {number} pArg
999
+ * @returns {number|Promise<number>}
1000
+ */
1001
+ xFileControl(pFile, op, pArg) {
1002
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTFOUND;
1003
+ }
1004
+
1005
+ /**
1006
+ * @param {number} pFile
1007
+ * @returns {number|Promise<number>}
1008
+ */
1009
+ xSectorSize(pFile) {
1010
+ return DEFAULT_SECTOR_SIZE;
1011
+ }
1012
+
1013
+ /**
1014
+ * @param {number} pFile
1015
+ * @returns {number|Promise<number>}
1016
+ */
1017
+ xDeviceCharacteristics(pFile) {
1018
+ return 0;
1019
+ }
1020
+ }
1021
+
1022
+ const FILE_TYPE_MASK = [
1023
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_DB,
1024
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_JOURNAL,
1025
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_DB,
1026
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_JOURNAL,
1027
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TRANSIENT_DB,
1028
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUBJOURNAL,
1029
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUPER_JOURNAL,
1030
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_WAL
1031
+ ].reduce((mask, element) => mask | element);
1032
+
1033
+ /***/ }),
1034
+
1035
+ /***/ "../../node_modules/@journeyapps/wa-sqlite/src/examples/AccessHandlePoolVFS.js":
1036
+ /*!*************************************************************************************!*\
1037
+ !*** ../../node_modules/@journeyapps/wa-sqlite/src/examples/AccessHandlePoolVFS.js ***!
1038
+ \*************************************************************************************/
1039
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1040
+
1041
+ __webpack_require__.r(__webpack_exports__);
1042
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
1043
+ /* harmony export */ AccessHandlePoolVFS: () => (/* binding */ AccessHandlePoolVFS)
1044
+ /* harmony export */ });
1045
+ /* harmony import */ var _FacadeVFS_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../FacadeVFS.js */ "../../node_modules/@journeyapps/wa-sqlite/src/FacadeVFS.js");
1046
+ /* harmony import */ var _VFS_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../VFS.js */ "../../node_modules/@journeyapps/wa-sqlite/src/VFS.js");
1047
+ // Copyright 2023 Roy T. Hashimoto. All Rights Reserved.
1048
+
1049
+
1050
+
1051
+ const SECTOR_SIZE = 4096;
1052
+
1053
+ // Each OPFS file begins with a fixed-size header with metadata. The
1054
+ // contents of the file follow immediately after the header.
1055
+ const HEADER_MAX_PATH_SIZE = 512;
1056
+ const HEADER_FLAGS_SIZE = 4;
1057
+ const HEADER_DIGEST_SIZE = 8;
1058
+ const HEADER_CORPUS_SIZE = HEADER_MAX_PATH_SIZE + HEADER_FLAGS_SIZE;
1059
+ const HEADER_OFFSET_FLAGS = HEADER_MAX_PATH_SIZE;
1060
+ const HEADER_OFFSET_DIGEST = HEADER_CORPUS_SIZE;
1061
+ const HEADER_OFFSET_DATA = SECTOR_SIZE;
1062
+
1063
+ // These file types are expected to persist in the file system outside
1064
+ // a session. Other files will be removed on VFS start.
1065
+ const PERSISTENT_FILE_TYPES =
1066
+ _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_MAIN_DB |
1067
+ _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_MAIN_JOURNAL |
1068
+ _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_SUPER_JOURNAL |
1069
+ _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_WAL;
1070
+
1071
+ const DEFAULT_CAPACITY = 6;
1072
+
1073
+ /**
1074
+ * This VFS uses the updated Access Handle API with all synchronous methods
1075
+ * on FileSystemSyncAccessHandle (instead of just read and write). It will
1076
+ * work with the regular SQLite WebAssembly build, i.e. the one without
1077
+ * Asyncify.
1078
+ */
1079
+ class AccessHandlePoolVFS extends _FacadeVFS_js__WEBPACK_IMPORTED_MODULE_0__.FacadeVFS {
1080
+ log = null; //function(...args) { console.log(`[${contextName}]`, ...args) };
1081
+
1082
+ // All the OPFS files the VFS uses are contained in one flat directory
1083
+ // specified in the constructor. No other files should be written here.
1084
+ #directoryPath;
1085
+ #directoryHandle;
1086
+
1087
+ // The OPFS files all have randomly-generated names that do not match
1088
+ // the SQLite files whose data they contain. This map links those names
1089
+ // with their respective OPFS access handles.
1090
+ #mapAccessHandleToName = new Map();
1091
+
1092
+ // When a SQLite file is associated with an OPFS file, that association
1093
+ // is kept in #mapPathToAccessHandle. Each access handle is in exactly
1094
+ // one of #mapPathToAccessHandle or #availableAccessHandles.
1095
+ #mapPathToAccessHandle = new Map();
1096
+ #availableAccessHandles = new Set();
1097
+
1098
+ #mapIdToFile = new Map();
1099
+
1100
+ static async create(name, module) {
1101
+ const vfs = new AccessHandlePoolVFS(name, module);
1102
+ await vfs.isReady();
1103
+ return vfs;
1104
+ }
1105
+
1106
+ constructor(name, module) {
1107
+ super(name, module);
1108
+ this.#directoryPath = name;
1109
+ }
1110
+
1111
+ /**
1112
+ * @param {string?} zName
1113
+ * @param {number} fileId
1114
+ * @param {number} flags
1115
+ * @param {DataView} pOutFlags
1116
+ * @returns {number}
1117
+ */
1118
+ jOpen(zName, fileId, flags, pOutFlags) {
1119
+ try {
1120
+ // First try to open a path that already exists in the file system.
1121
+ const path = zName ? this.#getPath(zName) : Math.random().toString(36);
1122
+ let accessHandle = this.#mapPathToAccessHandle.get(path);
1123
+ if (!accessHandle && (flags & _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_CREATE)) {
1124
+ // File not found so try to create it.
1125
+ if (this.getSize() < this.getCapacity()) {
1126
+ // Choose an unassociated OPFS file from the pool.
1127
+ ([accessHandle] = this.#availableAccessHandles.keys());
1128
+ this.#setAssociatedPath(accessHandle, path, flags);
1129
+ } else {
1130
+ // Out of unassociated files. This can be fixed by calling
1131
+ // addCapacity() from the application.
1132
+ throw new Error('cannot create file');
1133
+ }
1134
+ }
1135
+ if (!accessHandle) {
1136
+ throw new Error('file not found');
1137
+ }
1138
+ // Subsequent methods are only passed the fileId, so make sure we have
1139
+ // a way to get the file resources.
1140
+ const file = { path, flags, accessHandle };
1141
+ this.#mapIdToFile.set(fileId, file);
1142
+
1143
+ pOutFlags.setInt32(0, flags, true);
1144
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1145
+ } catch (e) {
1146
+ console.error(e.message);
1147
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_CANTOPEN;
1148
+ }
1149
+ }
1150
+
1151
+ /**
1152
+ * @param {number} fileId
1153
+ * @returns {number}
1154
+ */
1155
+ jClose(fileId) {
1156
+ const file = this.#mapIdToFile.get(fileId);
1157
+ if (file) {
1158
+ file.accessHandle.flush();
1159
+ this.#mapIdToFile.delete(fileId);
1160
+ if (file.flags & _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_DELETEONCLOSE) {
1161
+ this.#deletePath(file.path);
1162
+ }
1163
+ }
1164
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1165
+ }
1166
+
1167
+ /**
1168
+ * @param {number} fileId
1169
+ * @param {Uint8Array} pData
1170
+ * @param {number} iOffset
1171
+ * @returns {number}
1172
+ */
1173
+ jRead(fileId, pData, iOffset) {
1174
+ const file = this.#mapIdToFile.get(fileId);
1175
+ const nBytes = file.accessHandle.read(
1176
+ pData.subarray(),
1177
+ { at: HEADER_OFFSET_DATA + iOffset });
1178
+ if (nBytes < pData.byteLength) {
1179
+ pData.fill(0, nBytes, pData.byteLength);
1180
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_SHORT_READ;
1181
+ }
1182
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1183
+ }
1184
+
1185
+ /**
1186
+ * @param {number} fileId
1187
+ * @param {Uint8Array} pData
1188
+ * @param {number} iOffset
1189
+ * @returns {number}
1190
+ */
1191
+ jWrite(fileId, pData, iOffset) {
1192
+ const file = this.#mapIdToFile.get(fileId);
1193
+ const nBytes = file.accessHandle.write(
1194
+ pData.subarray(),
1195
+ { at: HEADER_OFFSET_DATA + iOffset });
1196
+ return nBytes === pData.byteLength ? _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK : _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR;
1197
+ }
1198
+
1199
+ /**
1200
+ * @param {number} fileId
1201
+ * @param {number} iSize
1202
+ * @returns {number}
1203
+ */
1204
+ jTruncate(fileId, iSize) {
1205
+ const file = this.#mapIdToFile.get(fileId);
1206
+ file.accessHandle.truncate(HEADER_OFFSET_DATA + iSize);
1207
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1208
+ }
1209
+
1210
+ /**
1211
+ * @param {number} fileId
1212
+ * @param {number} flags
1213
+ * @returns {number}
1214
+ */
1215
+ jSync(fileId, flags) {
1216
+ const file = this.#mapIdToFile.get(fileId);
1217
+ file.accessHandle.flush();
1218
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1219
+ }
1220
+
1221
+ /**
1222
+ * @param {number} fileId
1223
+ * @param {DataView} pSize64
1224
+ * @returns {number}
1225
+ */
1226
+ jFileSize(fileId, pSize64) {
1227
+ const file = this.#mapIdToFile.get(fileId);
1228
+ const size = file.accessHandle.getSize() - HEADER_OFFSET_DATA;
1229
+ pSize64.setBigInt64(0, BigInt(size), true);
1230
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1231
+ }
1232
+
1233
+ jSectorSize(fileId) {
1234
+ return SECTOR_SIZE;
1235
+ }
1236
+
1237
+ jDeviceCharacteristics(fileId) {
1238
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN;
1239
+ }
1240
+
1241
+ /**
1242
+ * @param {string} zName
1243
+ * @param {number} flags
1244
+ * @param {DataView} pResOut
1245
+ * @returns {number}
1246
+ */
1247
+ jAccess(zName, flags, pResOut) {
1248
+ const path = this.#getPath(zName);
1249
+ pResOut.setInt32(0, this.#mapPathToAccessHandle.has(path) ? 1 : 0, true);
1250
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1251
+ }
1252
+
1253
+ /**
1254
+ * @param {string} zName
1255
+ * @param {number} syncDir
1256
+ * @returns {number}
1257
+ */
1258
+ jDelete(zName, syncDir) {
1259
+ const path = this.#getPath(zName);
1260
+ this.#deletePath(path);
1261
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
1262
+ }
1263
+
1264
+ async close() {
1265
+ await this.#releaseAccessHandles();
1266
+ }
1267
+
1268
+ async isReady() {
1269
+ if (!this.#directoryHandle) {
1270
+ // All files are stored in a single directory.
1271
+ let handle = await navigator.storage.getDirectory();
1272
+ for (const d of this.#directoryPath.split('/')) {
1273
+ if (d) {
1274
+ handle = await handle.getDirectoryHandle(d, { create: true });
1275
+ }
1276
+ }
1277
+ this.#directoryHandle = handle;
1278
+
1279
+ await this.#acquireAccessHandles();
1280
+ if (this.getCapacity() === 0) {
1281
+ await this.addCapacity(DEFAULT_CAPACITY);
1282
+ }
1283
+ }
1284
+ return true;
1285
+ }
1286
+
1287
+ /**
1288
+ * Returns the number of SQLite files in the file system.
1289
+ * @returns {number}
1290
+ */
1291
+ getSize() {
1292
+ return this.#mapPathToAccessHandle.size;
1293
+ }
1294
+
1295
+ /**
1296
+ * Returns the maximum number of SQLite files the file system can hold.
1297
+ * @returns {number}
1298
+ */
1299
+ getCapacity() {
1300
+ return this.#mapAccessHandleToName.size;
1301
+ }
1302
+
1303
+ /**
1304
+ * Increase the capacity of the file system by n.
1305
+ * @param {number} n
1306
+ * @returns {Promise<number>}
1307
+ */
1308
+ async addCapacity(n) {
1309
+ for (let i = 0; i < n; ++i) {
1310
+ const name = Math.random().toString(36).replace('0.', '');
1311
+ const handle = await this.#directoryHandle.getFileHandle(name, { create: true });
1312
+ const accessHandle = await handle.createSyncAccessHandle();
1313
+ this.#mapAccessHandleToName.set(accessHandle, name);
1314
+
1315
+ this.#setAssociatedPath(accessHandle, '', 0);
1316
+ }
1317
+ return n;
1318
+ }
1319
+
1320
+ /**
1321
+ * Decrease the capacity of the file system by n. The capacity cannot be
1322
+ * decreased to fewer than the current number of SQLite files in the
1323
+ * file system.
1324
+ * @param {number} n
1325
+ * @returns {Promise<number>}
1326
+ */
1327
+ async removeCapacity(n) {
1328
+ let nRemoved = 0;
1329
+ for (const accessHandle of Array.from(this.#availableAccessHandles)) {
1330
+ if (nRemoved == n || this.getSize() === this.getCapacity()) return nRemoved;
1331
+
1332
+ const name = this.#mapAccessHandleToName.get(accessHandle);
1333
+ await accessHandle.close();
1334
+ await this.#directoryHandle.removeEntry(name);
1335
+ this.#mapAccessHandleToName.delete(accessHandle);
1336
+ this.#availableAccessHandles.delete(accessHandle);
1337
+ ++nRemoved;
1338
+ }
1339
+ return nRemoved;
1340
+ }
1341
+
1342
+ async #acquireAccessHandles() {
1343
+ // Enumerate all the files in the directory.
1344
+ const files = [];
1345
+ for await (const [name, handle] of this.#directoryHandle) {
1346
+ if (handle.kind === 'file') {
1347
+ files.push([name, handle]);
1348
+ }
1349
+ }
1350
+
1351
+ // Open access handles in parallel, separating associated and unassociated.
1352
+ await Promise.all(files.map(async ([name, handle]) => {
1353
+ const accessHandle = await handle.createSyncAccessHandle();
1354
+ this.#mapAccessHandleToName.set(accessHandle, name);
1355
+ const path = this.#getAssociatedPath(accessHandle);
1356
+ if (path) {
1357
+ this.#mapPathToAccessHandle.set(path, accessHandle);
1358
+ } else {
1359
+ this.#availableAccessHandles.add(accessHandle);
1360
+ }
1361
+ }));
1362
+ }
1363
+
1364
+ #releaseAccessHandles() {
1365
+ for (const accessHandle of this.#mapAccessHandleToName.keys()) {
1366
+ accessHandle.close();
1367
+ }
1368
+ this.#mapAccessHandleToName.clear();
1369
+ this.#mapPathToAccessHandle.clear();
1370
+ this.#availableAccessHandles.clear();
1371
+ }
1372
+
1373
+ /**
1374
+ * Read and return the associated path from an OPFS file header.
1375
+ * Empty string is returned for an unassociated OPFS file.
1376
+ * @param accessHandle FileSystemSyncAccessHandle
1377
+ * @returns {string} path or empty string
1378
+ */
1379
+ #getAssociatedPath(accessHandle) {
1380
+ // Read the path and digest of the path from the file.
1381
+ const corpus = new Uint8Array(HEADER_CORPUS_SIZE);
1382
+ accessHandle.read(corpus, { at: 0 })
1383
+
1384
+ // Delete files not expected to be present.
1385
+ const dataView = new DataView(corpus.buffer, corpus.byteOffset);
1386
+ const flags = dataView.getUint32(HEADER_OFFSET_FLAGS);
1387
+ if (corpus[0] &&
1388
+ ((flags & _VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_DELETEONCLOSE) ||
1389
+ (flags & PERSISTENT_FILE_TYPES) === 0)) {
1390
+ console.warn(`Remove file with unexpected flags ${flags.toString(16)}`);
1391
+ this.#setAssociatedPath(accessHandle, '', 0);
1392
+ return '';
1393
+ }
1394
+
1395
+ const fileDigest = new Uint32Array(HEADER_DIGEST_SIZE / 4);
1396
+ accessHandle.read(fileDigest, { at: HEADER_OFFSET_DIGEST });
1397
+
1398
+ // Verify the digest.
1399
+ const computedDigest = this.#computeDigest(corpus);
1400
+ if (fileDigest.every((value, i) => value === computedDigest[i])) {
1401
+ // Good digest. Decode the null-terminated path string.
1402
+ const pathBytes = corpus.findIndex(value => value === 0);
1403
+ if (pathBytes === 0) {
1404
+ // Ensure that unassociated files are empty. Unassociated files are
1405
+ // truncated in #setAssociatedPath after the header is written. If
1406
+ // an interruption occurs right before the truncation then garbage
1407
+ // may remain in the file.
1408
+ accessHandle.truncate(HEADER_OFFSET_DATA);
1409
+ }
1410
+ return new TextDecoder().decode(corpus.subarray(0, pathBytes));
1411
+ } else {
1412
+ // Bad digest. Repair this header.
1413
+ console.warn('Disassociating file with bad digest.');
1414
+ this.#setAssociatedPath(accessHandle, '', 0);
1415
+ return '';
1416
+ }
1417
+ }
1418
+
1419
+ /**
1420
+ * Set the path on an OPFS file header.
1421
+ * @param accessHandle FileSystemSyncAccessHandle
1422
+ * @param {string} path
1423
+ * @param {number} flags
1424
+ */
1425
+ #setAssociatedPath(accessHandle, path, flags) {
1426
+ // Convert the path string to UTF-8.
1427
+ const corpus = new Uint8Array(HEADER_CORPUS_SIZE);
1428
+ const encodedResult = new TextEncoder().encodeInto(path, corpus);
1429
+ if (encodedResult.written >= HEADER_MAX_PATH_SIZE) {
1430
+ throw new Error('path too long');
1431
+ }
1432
+
1433
+ // Add the creation flags.
1434
+ const dataView = new DataView(corpus.buffer, corpus.byteOffset);
1435
+ dataView.setUint32(HEADER_OFFSET_FLAGS, flags);
1436
+
1437
+ // Write the OPFS file header, including the digest.
1438
+ const digest = this.#computeDigest(corpus);
1439
+ accessHandle.write(corpus, { at: 0 });
1440
+ accessHandle.write(digest, { at: HEADER_OFFSET_DIGEST });
1441
+ accessHandle.flush();
1442
+
1443
+ if (path) {
1444
+ this.#mapPathToAccessHandle.set(path, accessHandle);
1445
+ this.#availableAccessHandles.delete(accessHandle);
1446
+ } else {
1447
+ // This OPFS file doesn't represent any SQLite file so it doesn't
1448
+ // need to keep any data.
1449
+ accessHandle.truncate(HEADER_OFFSET_DATA);
1450
+ this.#availableAccessHandles.add(accessHandle);
1451
+ }
1452
+ }
1453
+
1454
+ /**
1455
+ * We need a synchronous digest function so can't use WebCrypto.
1456
+ * Adapted from https://github.com/bryc/code/blob/master/jshash/experimental/cyrb53.js
1457
+ * @param {Uint8Array} corpus
1458
+ * @returns {ArrayBuffer} 64-bit digest
1459
+ */
1460
+ #computeDigest(corpus) {
1461
+ if (!corpus[0]) {
1462
+ // Optimization for deleted file.
1463
+ return new Uint32Array([0xfecc5f80, 0xaccec037]);
1464
+ }
1465
+
1466
+ let h1 = 0xdeadbeef;
1467
+ let h2 = 0x41c6ce57;
1468
+
1469
+ for (const value of corpus) {
1470
+ h1 = Math.imul(h1 ^ value, 2654435761);
1471
+ h2 = Math.imul(h2 ^ value, 1597334677);
1472
+ }
1473
+
1474
+ h1 = Math.imul(h1 ^ (h1 >>> 16), 2246822507) ^ Math.imul(h2 ^ (h2 >>> 13), 3266489909);
1475
+ h2 = Math.imul(h2 ^ (h2 >>> 16), 2246822507) ^ Math.imul(h1 ^ (h1 >>> 13), 3266489909);
1476
+
1477
+ return new Uint32Array([h1 >>> 0, h2 >>> 0]);
1478
+ };
1479
+
1480
+ /**
1481
+ * Convert a bare filename, path, or URL to a UNIX-style path.
1482
+ * @param {string|URL} nameOrURL
1483
+ * @returns {string} path
1484
+ */
1485
+ #getPath(nameOrURL) {
1486
+ const url = typeof nameOrURL === 'string' ?
1487
+ new URL(nameOrURL, 'file://localhost/') :
1488
+ nameOrURL;
1489
+ return url.pathname;
1490
+ }
1491
+
1492
+ /**
1493
+ * Remove the association between a path and an OPFS file.
1494
+ * @param {string} path
1495
+ */
1496
+ #deletePath(path) {
1497
+ const accessHandle = this.#mapPathToAccessHandle.get(path);
1498
+ if (accessHandle) {
1499
+ // Un-associate the SQLite path from the OPFS file.
1500
+ this.#mapPathToAccessHandle.delete(path);
1501
+ this.#setAssociatedPath(accessHandle, '', 0);
1502
+ }
1503
+ }
1504
+ }
1505
+
1506
+ /***/ })
1507
+
1508
+ }]);
1509
+ //# sourceMappingURL=node_modules_journeyapps_wa-sqlite_src_examples_AccessHandlePoolVFS_js.umd.js.map