@powersync/web 0.0.0-dev-20251201150812 → 0.0.0-dev-20251203144301

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 (39) hide show
  1. package/dist/index.umd.js +2415 -58
  2. package/dist/index.umd.js.map +1 -1
  3. package/dist/worker/SharedSyncImplementation.umd.js +1884 -39
  4. package/dist/worker/SharedSyncImplementation.umd.js.map +1 -1
  5. package/dist/worker/WASQLiteDB.umd.js +1809 -8
  6. package/dist/worker/WASQLiteDB.umd.js.map +1 -1
  7. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_AccessHandlePoolVFS_js.umd.js +0 -1203
  8. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_AccessHandlePoolVFS_js.umd.js.map +1 -1
  9. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js.umd.js +0 -1203
  10. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_IDBBatchAtomicVFS_js.umd.js.map +1 -1
  11. package/lib/package.json +2 -2
  12. package/lib/src/db/adapters/LockedAsyncDatabaseAdapter.d.ts +4 -1
  13. package/lib/src/db/adapters/LockedAsyncDatabaseAdapter.js +52 -28
  14. package/lib/src/db/adapters/wa-sqlite/WASQLiteConnection.js +3 -3
  15. package/lib/src/db/adapters/wa-sqlite/WASQLiteOpenFactory.d.ts +1 -1
  16. package/lib/src/db/adapters/wa-sqlite/WASQLiteOpenFactory.js +2 -2
  17. package/lib/src/worker/db/WASQLiteDB.worker.js +0 -1
  18. package/lib/src/worker/db/opfs.d.ts +96 -0
  19. package/lib/src/worker/db/opfs.js +582 -0
  20. package/lib/src/worker/sync/SharedSyncImplementation.js +23 -4
  21. package/lib/tsconfig.tsbuildinfo +1 -1
  22. package/package.json +5 -5
  23. package/src/db/adapters/LockedAsyncDatabaseAdapter.ts +71 -48
  24. package/src/db/adapters/wa-sqlite/WASQLiteConnection.ts +3 -4
  25. package/src/db/adapters/wa-sqlite/WASQLiteOpenFactory.ts +3 -3
  26. package/src/worker/db/WASQLiteDB.worker.ts +0 -2
  27. package/src/worker/db/opfs.ts +623 -0
  28. package/src/worker/sync/SharedSyncImplementation.ts +29 -8
  29. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_OPFSCoopSyncVFS_js.umd.js +0 -1813
  30. package/dist/worker/node_modules_journeyapps_wa-sqlite_src_examples_OPFSCoopSyncVFS_js.umd.js.map +0 -1
  31. package/lib/src/worker/sync/MockSyncService.d.ts +0 -2
  32. package/lib/src/worker/sync/MockSyncService.js +0 -3
  33. package/lib/src/worker/sync/MockSyncServiceTypes.d.ts +0 -101
  34. package/lib/src/worker/sync/MockSyncServiceTypes.js +0 -1
  35. package/lib/src/worker/sync/MockSyncServiceWorker.d.ts +0 -56
  36. package/lib/src/worker/sync/MockSyncServiceWorker.js +0 -369
  37. package/src/worker/sync/MockSyncService.ts +0 -3
  38. package/src/worker/sync/MockSyncServiceTypes.ts +0 -71
  39. package/src/worker/sync/MockSyncServiceWorker.ts +0 -406
@@ -3,6 +3,1209 @@ var sdk_web;
3
3
  /******/ "use strict";
4
4
  /******/ var __webpack_modules__ = ({
5
5
 
6
+ /***/ "../../node_modules/@journeyapps/wa-sqlite/src/FacadeVFS.js":
7
+ /*!******************************************************************!*\
8
+ !*** ../../node_modules/@journeyapps/wa-sqlite/src/FacadeVFS.js ***!
9
+ \******************************************************************/
10
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
11
+
12
+ __webpack_require__.r(__webpack_exports__);
13
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
14
+ /* harmony export */ FacadeVFS: () => (/* binding */ FacadeVFS)
15
+ /* harmony export */ });
16
+ /* harmony import */ var _VFS_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./VFS.js */ "../../node_modules/@journeyapps/wa-sqlite/src/VFS.js");
17
+ // Copyright 2024 Roy T. Hashimoto. All Rights Reserved.
18
+
19
+
20
+ const AsyncFunction = Object.getPrototypeOf(async function(){}).constructor;
21
+
22
+ // Milliseconds since Julian epoch as a BigInt.
23
+ // https://github.com/sqlite/sqlite/blob/e57527c14f7b7cfa6e32eeab5c549d50c4fa3674/src/os_unix.c#L6872-L6882
24
+ const UNIX_EPOCH = 24405875n * 8640000n;
25
+
26
+ // Convenience base class for a JavaScript VFS.
27
+ // The raw xOpen, xRead, etc. function signatures receive only C primitives
28
+ // which aren't easy to work with. This class provides corresponding calls
29
+ // like jOpen, jRead, etc., which receive JavaScript-friendlier arguments
30
+ // such as string, Uint8Array, and DataView.
31
+ class FacadeVFS extends _VFS_js__WEBPACK_IMPORTED_MODULE_0__.Base {
32
+ /**
33
+ * @param {string} name
34
+ * @param {object} module
35
+ */
36
+ constructor(name, module) {
37
+ super(name, module);
38
+ }
39
+
40
+ /**
41
+ * Override to indicate which methods are asynchronous.
42
+ * @param {string} methodName
43
+ * @returns {boolean}
44
+ */
45
+ hasAsyncMethod(methodName) {
46
+ // The input argument is a string like "xOpen", so convert to "jOpen".
47
+ // Then check if the method exists and is async.
48
+ const jMethodName = `j${methodName.slice(1)}`;
49
+ return this[jMethodName] instanceof AsyncFunction;
50
+ }
51
+
52
+ /**
53
+ * Return the filename for a file id for use by mixins.
54
+ * @param {number} pFile
55
+ * @returns {string}
56
+ */
57
+ getFilename(pFile) {
58
+ throw new Error('unimplemented');
59
+ }
60
+
61
+ /**
62
+ * @param {string?} filename
63
+ * @param {number} pFile
64
+ * @param {number} flags
65
+ * @param {DataView} pOutFlags
66
+ * @returns {number|Promise<number>}
67
+ */
68
+ jOpen(filename, pFile, flags, pOutFlags) {
69
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CANTOPEN;
70
+ }
71
+
72
+ /**
73
+ * @param {string} filename
74
+ * @param {number} syncDir
75
+ * @returns {number|Promise<number>}
76
+ */
77
+ jDelete(filename, syncDir) {
78
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
79
+ }
80
+
81
+ /**
82
+ * @param {string} filename
83
+ * @param {number} flags
84
+ * @param {DataView} pResOut
85
+ * @returns {number|Promise<number>}
86
+ */
87
+ jAccess(filename, flags, pResOut) {
88
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
89
+ }
90
+
91
+ /**
92
+ * @param {string} filename
93
+ * @param {Uint8Array} zOut
94
+ * @returns {number|Promise<number>}
95
+ */
96
+ jFullPathname(filename, zOut) {
97
+ // Copy the filename to the output buffer.
98
+ const { read, written } = new TextEncoder().encodeInto(filename, zOut);
99
+ if (read < filename.length) return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR;
100
+ if (written >= zOut.length) return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR;
101
+ zOut[written] = 0;
102
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
103
+ }
104
+
105
+ /**
106
+ * @param {Uint8Array} zBuf
107
+ * @returns {number|Promise<number>}
108
+ */
109
+ jGetLastError(zBuf) {
110
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
111
+ }
112
+
113
+ /**
114
+ * @param {number} pFile
115
+ * @returns {number|Promise<number>}
116
+ */
117
+ jClose(pFile) {
118
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
119
+ }
120
+
121
+ /**
122
+ * @param {number} pFile
123
+ * @param {Uint8Array} pData
124
+ * @param {number} iOffset
125
+ * @returns {number|Promise<number>}
126
+ */
127
+ jRead(pFile, pData, iOffset) {
128
+ pData.fill(0);
129
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_SHORT_READ;
130
+ }
131
+
132
+ /**
133
+ * @param {number} pFile
134
+ * @param {Uint8Array} pData
135
+ * @param {number} iOffset
136
+ * @returns {number|Promise<number>}
137
+ */
138
+ jWrite(pFile, pData, iOffset) {
139
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_WRITE;
140
+ }
141
+
142
+ /**
143
+ * @param {number} pFile
144
+ * @param {number} size
145
+ * @returns {number|Promise<number>}
146
+ */
147
+ jTruncate(pFile, size) {
148
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
149
+ }
150
+
151
+ /**
152
+ * @param {number} pFile
153
+ * @param {number} flags
154
+ * @returns {number|Promise<number>}
155
+ */
156
+ jSync(pFile, flags) {
157
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
158
+ }
159
+
160
+ /**
161
+ * @param {number} pFile
162
+ * @param {DataView} pSize
163
+ * @returns {number|Promise<number>}
164
+ */
165
+ jFileSize(pFile, pSize) {
166
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
167
+ }
168
+
169
+ /**
170
+ * @param {number} pFile
171
+ * @param {number} lockType
172
+ * @returns {number|Promise<number>}
173
+ */
174
+ jLock(pFile, lockType) {
175
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
176
+ }
177
+
178
+ /**
179
+ * @param {number} pFile
180
+ * @param {number} lockType
181
+ * @returns {number|Promise<number>}
182
+ */
183
+ jUnlock(pFile, lockType) {
184
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
185
+ }
186
+
187
+ /**
188
+ * @param {number} pFile
189
+ * @param {DataView} pResOut
190
+ * @returns {number|Promise<number>}
191
+ */
192
+ jCheckReservedLock(pFile, pResOut) {
193
+ pResOut.setInt32(0, 0, true);
194
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
195
+ }
196
+
197
+ /**
198
+ * @param {number} pFile
199
+ * @param {number} op
200
+ * @param {DataView} pArg
201
+ * @returns {number|Promise<number>}
202
+ */
203
+ jFileControl(pFile, op, pArg) {
204
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTFOUND;
205
+ }
206
+
207
+ /**
208
+ * @param {number} pFile
209
+ * @returns {number|Promise<number>}
210
+ */
211
+ jSectorSize(pFile) {
212
+ return super.xSectorSize(pFile);
213
+ }
214
+
215
+ /**
216
+ * @param {number} pFile
217
+ * @returns {number|Promise<number>}
218
+ */
219
+ jDeviceCharacteristics(pFile) {
220
+ return 0;
221
+ }
222
+
223
+ /**
224
+ * @param {number} pVfs
225
+ * @param {number} zName
226
+ * @param {number} pFile
227
+ * @param {number} flags
228
+ * @param {number} pOutFlags
229
+ * @returns {number|Promise<number>}
230
+ */
231
+ xOpen(pVfs, zName, pFile, flags, pOutFlags) {
232
+ const filename = this.#decodeFilename(zName, flags);
233
+ const pOutFlagsView = this.#makeTypedDataView('Int32', pOutFlags);
234
+ this['log']?.('jOpen', filename, pFile, '0x' + flags.toString(16));
235
+ return this.jOpen(filename, pFile, flags, pOutFlagsView);
236
+ }
237
+
238
+ /**
239
+ * @param {number} pVfs
240
+ * @param {number} nByte
241
+ * @param {number} pCharOut
242
+ * @returns {number|Promise<number>}
243
+ */
244
+ xRandomness(pVfs, nByte, pCharOut) {
245
+ const randomArray = new Uint8Array(nByte);
246
+ crypto.getRandomValues(randomArray);
247
+ // Copy randomArray to the WebAssembly memory
248
+ const buffer = pCharOut; // Pointer to memory in WebAssembly
249
+ this._module.HEAPU8.set(randomArray, buffer); // Copy randomArray into memory starting at buffer
250
+ return nByte;
251
+ }
252
+
253
+ /**
254
+ * Gets the current time as milliseconds since Unix epoch
255
+ * @param {number} pVfs pointer to the VFS
256
+ * @param {number} pTime pointer to write the time value
257
+ * @returns {number} SQLite error code
258
+ */
259
+ xCurrentTimeInt64(pVfs, pTime) {
260
+ // Create a DataView to write the current time
261
+ const timeView = this.#makeTypedDataView('BigInt64', pTime);
262
+
263
+ const currentTime = BigInt(Date.now());
264
+ // Convert the current time to milliseconds since Unix epoch
265
+ const value = UNIX_EPOCH + currentTime;
266
+
267
+ // Write the time value to the pointer location
268
+ timeView.setBigInt64(0, value, true);
269
+
270
+ return _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
271
+ }
272
+
273
+ /**
274
+ * @param {number} pVfs
275
+ * @param {number} zName
276
+ * @param {number} syncDir
277
+ * @returns {number|Promise<number>}
278
+ */
279
+ xDelete(pVfs, zName, syncDir) {
280
+ const filename = this._module.UTF8ToString(zName);
281
+ this['log']?.('jDelete', filename, syncDir);
282
+ return this.jDelete(filename, syncDir);
283
+ }
284
+
285
+ /**
286
+ * @param {number} pVfs
287
+ * @param {number} zName
288
+ * @param {number} flags
289
+ * @param {number} pResOut
290
+ * @returns {number|Promise<number>}
291
+ */
292
+ xAccess(pVfs, zName, flags, pResOut) {
293
+ const filename = this._module.UTF8ToString(zName);
294
+ const pResOutView = this.#makeTypedDataView('Int32', pResOut);
295
+ this['log']?.('jAccess', filename, flags);
296
+ return this.jAccess(filename, flags, pResOutView);
297
+ }
298
+
299
+ /**
300
+ * @param {number} pVfs
301
+ * @param {number} zName
302
+ * @param {number} nOut
303
+ * @param {number} zOut
304
+ * @returns {number|Promise<number>}
305
+ */
306
+ xFullPathname(pVfs, zName, nOut, zOut) {
307
+ const filename = this._module.UTF8ToString(zName);
308
+ const zOutArray = this._module.HEAPU8.subarray(zOut, zOut + nOut);
309
+ this['log']?.('jFullPathname', filename, nOut);
310
+ return this.jFullPathname(filename, zOutArray);
311
+ }
312
+
313
+ /**
314
+ * @param {number} pVfs
315
+ * @param {number} nBuf
316
+ * @param {number} zBuf
317
+ * @returns {number|Promise<number>}
318
+ */
319
+ xGetLastError(pVfs, nBuf, zBuf) {
320
+ const zBufArray = this._module.HEAPU8.subarray(zBuf, zBuf + nBuf);
321
+ this['log']?.('jGetLastError', nBuf);
322
+ return this.jGetLastError(zBufArray);
323
+ }
324
+
325
+ /**
326
+ * @param {number} pFile
327
+ * @returns {number|Promise<number>}
328
+ */
329
+ xClose(pFile) {
330
+ this['log']?.('jClose', pFile);
331
+ return this.jClose(pFile);
332
+ }
333
+
334
+ /**
335
+ * @param {number} pFile
336
+ * @param {number} pData
337
+ * @param {number} iAmt
338
+ * @param {number} iOffsetLo
339
+ * @param {number} iOffsetHi
340
+ * @returns {number|Promise<number>}
341
+ */
342
+ xRead(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
343
+ const pDataArray = this.#makeDataArray(pData, iAmt);
344
+ const iOffset = delegalize(iOffsetLo, iOffsetHi);
345
+ this['log']?.('jRead', pFile, iAmt, iOffset);
346
+ return this.jRead(pFile, pDataArray, iOffset);
347
+ }
348
+
349
+ /**
350
+ * @param {number} pFile
351
+ * @param {number} pData
352
+ * @param {number} iAmt
353
+ * @param {number} iOffsetLo
354
+ * @param {number} iOffsetHi
355
+ * @returns {number|Promise<number>}
356
+ */
357
+ xWrite(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
358
+ const pDataArray = this.#makeDataArray(pData, iAmt);
359
+ const iOffset = delegalize(iOffsetLo, iOffsetHi);
360
+ this['log']?.('jWrite', pFile, pDataArray, iOffset);
361
+ return this.jWrite(pFile, pDataArray, iOffset);
362
+ }
363
+
364
+ /**
365
+ * @param {number} pFile
366
+ * @param {number} sizeLo
367
+ * @param {number} sizeHi
368
+ * @returns {number|Promise<number>}
369
+ */
370
+ xTruncate(pFile, sizeLo, sizeHi) {
371
+ const size = delegalize(sizeLo, sizeHi);
372
+ this['log']?.('jTruncate', pFile, size);
373
+ return this.jTruncate(pFile, size);
374
+ }
375
+
376
+ /**
377
+ * @param {number} pFile
378
+ * @param {number} flags
379
+ * @returns {number|Promise<number>}
380
+ */
381
+ xSync(pFile, flags) {
382
+ this['log']?.('jSync', pFile, flags);
383
+ return this.jSync(pFile, flags);
384
+ }
385
+
386
+ /**
387
+ *
388
+ * @param {number} pFile
389
+ * @param {number} pSize
390
+ * @returns {number|Promise<number>}
391
+ */
392
+ xFileSize(pFile, pSize) {
393
+ const pSizeView = this.#makeTypedDataView('BigInt64', pSize);
394
+ this['log']?.('jFileSize', pFile);
395
+ return this.jFileSize(pFile, pSizeView);
396
+ }
397
+
398
+ /**
399
+ * @param {number} pFile
400
+ * @param {number} lockType
401
+ * @returns {number|Promise<number>}
402
+ */
403
+ xLock(pFile, lockType) {
404
+ this['log']?.('jLock', pFile, lockType);
405
+ return this.jLock(pFile, lockType);
406
+ }
407
+
408
+ /**
409
+ * @param {number} pFile
410
+ * @param {number} lockType
411
+ * @returns {number|Promise<number>}
412
+ */
413
+ xUnlock(pFile, lockType) {
414
+ this['log']?.('jUnlock', pFile, lockType);
415
+ return this.jUnlock(pFile, lockType);
416
+ }
417
+
418
+ /**
419
+ * @param {number} pFile
420
+ * @param {number} pResOut
421
+ * @returns {number|Promise<number>}
422
+ */
423
+ xCheckReservedLock(pFile, pResOut) {
424
+ const pResOutView = this.#makeTypedDataView('Int32', pResOut);
425
+ this['log']?.('jCheckReservedLock', pFile);
426
+ return this.jCheckReservedLock(pFile, pResOutView);
427
+ }
428
+
429
+ /**
430
+ * @param {number} pFile
431
+ * @param {number} op
432
+ * @param {number} pArg
433
+ * @returns {number|Promise<number>}
434
+ */
435
+ xFileControl(pFile, op, pArg) {
436
+ const pArgView = new DataView(
437
+ this._module.HEAPU8.buffer,
438
+ this._module.HEAPU8.byteOffset + pArg);
439
+ this['log']?.('jFileControl', pFile, op, pArgView);
440
+ return this.jFileControl(pFile, op, pArgView);
441
+ }
442
+
443
+ /**
444
+ * @param {number} pFile
445
+ * @returns {number|Promise<number>}
446
+ */
447
+ xSectorSize(pFile) {
448
+ this['log']?.('jSectorSize', pFile);
449
+ return this.jSectorSize(pFile);
450
+ }
451
+
452
+ /**
453
+ * @param {number} pFile
454
+ * @returns {number|Promise<number>}
455
+ */
456
+ xDeviceCharacteristics(pFile) {
457
+ this['log']?.('jDeviceCharacteristics', pFile);
458
+ return this.jDeviceCharacteristics(pFile);
459
+ }
460
+
461
+ /**
462
+ * Wrapped DataView for pointer arguments.
463
+ * Pointers to a single value are passed using a DataView-like class.
464
+ * This wrapper class prevents use of incorrect type or endianness, and
465
+ * reacquires the underlying buffer when the WebAssembly memory is resized.
466
+ * @param {'Int32'|'BigInt64'} type
467
+ * @param {number} byteOffset
468
+ * @returns {DataView}
469
+ */
470
+ #makeTypedDataView(type, byteOffset) {
471
+ // @ts-ignore
472
+ return new DataViewProxy(this._module, byteOffset, type);
473
+ }
474
+
475
+ /**
476
+ * Wrapped Uint8Array for buffer arguments.
477
+ * Memory blocks are passed as a Uint8Array-like class. This wrapper
478
+ * class reacquires the underlying buffer when the WebAssembly memory
479
+ * is resized.
480
+ * @param {number} byteOffset
481
+ * @param {number} byteLength
482
+ * @returns {Uint8Array}
483
+ */
484
+ #makeDataArray(byteOffset, byteLength) {
485
+ // @ts-ignore
486
+ return new Uint8ArrayProxy(this._module, byteOffset, byteLength);
487
+ }
488
+
489
+ #decodeFilename(zName, flags) {
490
+ if (flags & _VFS_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_URI) {
491
+ // The first null-terminated string is the URI path. Subsequent
492
+ // strings are query parameter keys and values.
493
+ // https://www.sqlite.org/c3ref/open.html#urifilenamesinsqlite3open
494
+ let pName = zName;
495
+ let state = 1;
496
+ const charCodes = [];
497
+ while (state) {
498
+ const charCode = this._module.HEAPU8[pName++];
499
+ if (charCode) {
500
+ charCodes.push(charCode);
501
+ } else {
502
+ if (!this._module.HEAPU8[pName]) state = null;
503
+ switch (state) {
504
+ case 1: // path
505
+ charCodes.push('?'.charCodeAt(0));
506
+ state = 2;
507
+ break;
508
+ case 2: // key
509
+ charCodes.push('='.charCodeAt(0));
510
+ state = 3;
511
+ break;
512
+ case 3: // value
513
+ charCodes.push('&'.charCodeAt(0));
514
+ state = 2;
515
+ break;
516
+ }
517
+ }
518
+ }
519
+ return new TextDecoder().decode(new Uint8Array(charCodes));
520
+ }
521
+ return zName ? this._module.UTF8ToString(zName) : null;
522
+ }
523
+ }
524
+
525
+ // Emscripten "legalizes" 64-bit integer arguments by passing them as
526
+ // two 32-bit signed integers.
527
+ function delegalize(lo32, hi32) {
528
+ return (hi32 * 0x100000000) + lo32 + (lo32 < 0 ? 2**32 : 0);
529
+ }
530
+
531
+ // This class provides a Uint8Array-like interface for a WebAssembly memory
532
+ // buffer. It is used to access memory blocks passed as arguments to
533
+ // xRead, xWrite, etc. The class reacquires the underlying buffer when the
534
+ // WebAssembly memory is resized, which can happen when the memory is
535
+ // detached and resized by the WebAssembly module.
536
+ //
537
+ // Note that although this class implements the same methods as Uint8Array,
538
+ // it is not a real Uint8Array and passing it to functions that expect
539
+ // a Uint8Array may not work. Use subarray() to get a real Uint8Array
540
+ // if needed.
541
+ class Uint8ArrayProxy {
542
+ #module;
543
+
544
+ #_array = new Uint8Array()
545
+ get #array() {
546
+ if (this.#_array.buffer.byteLength === 0) {
547
+ // WebAssembly memory resize detached the buffer so re-create the
548
+ // array with the new buffer.
549
+ this.#_array = this.#module.HEAPU8.subarray(
550
+ this.byteOffset,
551
+ this.byteOffset + this.byteLength);
552
+ }
553
+ return this.#_array;
554
+ }
555
+
556
+ /**
557
+ * @param {*} module
558
+ * @param {number} byteOffset
559
+ * @param {number} byteLength
560
+ */
561
+ constructor(module, byteOffset, byteLength) {
562
+ this.#module = module;
563
+ this.byteOffset = byteOffset;
564
+ this.length = this.byteLength = byteLength;
565
+ }
566
+
567
+ get buffer() {
568
+ return this.#array.buffer;
569
+ }
570
+
571
+ at(index) {
572
+ return this.#array.at(index);
573
+ }
574
+ copyWithin(target, start, end) {
575
+ this.#array.copyWithin(target, start, end);
576
+ }
577
+ entries() {
578
+ return this.#array.entries();
579
+ }
580
+ every(predicate) {
581
+ return this.#array.every(predicate);
582
+ }
583
+ fill(value, start, end) {
584
+ this.#array.fill(value, start, end);
585
+ }
586
+ filter(predicate) {
587
+ return this.#array.filter(predicate);
588
+ }
589
+ find(predicate) {
590
+ return this.#array.find(predicate);
591
+ }
592
+ findIndex(predicate) {
593
+ return this.#array.findIndex(predicate);
594
+ }
595
+ findLast(predicate) {
596
+ return this.#array.findLast(predicate);
597
+ }
598
+ findLastIndex(predicate) {
599
+ return this.#array.findLastIndex(predicate);
600
+ }
601
+ forEach(callback) {
602
+ this.#array.forEach(callback);
603
+ }
604
+ includes(value, start) {
605
+ return this.#array.includes(value, start);
606
+ }
607
+ indexOf(value, start) {
608
+ return this.#array.indexOf(value, start);
609
+ }
610
+ join(separator) {
611
+ return this.#array.join(separator);
612
+ }
613
+ keys() {
614
+ return this.#array.keys();
615
+ }
616
+ lastIndexOf(value, start) {
617
+ return this.#array.lastIndexOf(value, start);
618
+ }
619
+ map(callback) {
620
+ return this.#array.map(callback);
621
+ }
622
+ reduce(callback, initialValue) {
623
+ return this.#array.reduce(callback, initialValue);
624
+ }
625
+ reduceRight(callback, initialValue) {
626
+ return this.#array.reduceRight(callback, initialValue);
627
+ }
628
+ reverse() {
629
+ this.#array.reverse();
630
+ }
631
+ set(array, offset) {
632
+ this.#array.set(array, offset);
633
+ }
634
+ slice(start, end) {
635
+ return this.#array.slice(start, end);
636
+ }
637
+ some(predicate) {
638
+ return this.#array.some(predicate);
639
+ }
640
+ sort(compareFn) {
641
+ this.#array.sort(compareFn);
642
+ }
643
+ subarray(begin, end) {
644
+ return this.#array.subarray(begin, end);
645
+ }
646
+ toLocaleString(locales, options) {
647
+ // @ts-ignore
648
+ return this.#array.toLocaleString(locales, options);
649
+ }
650
+ toReversed() {
651
+ return this.#array.toReversed();
652
+ }
653
+ toSorted(compareFn) {
654
+ return this.#array.toSorted(compareFn);
655
+ }
656
+ toString() {
657
+ return this.#array.toString();
658
+ }
659
+ values() {
660
+ return this.#array.values();
661
+ }
662
+ with(index, value) {
663
+ return this.#array.with(index, value);
664
+ }
665
+ [Symbol.iterator]() {
666
+ return this.#array[Symbol.iterator]();
667
+ }
668
+ }
669
+
670
+ // This class provides a DataView-like interface for a WebAssembly memory
671
+ // buffer, restricted to either Int32 or BigInt64 types. It also reacquires
672
+ // the underlying buffer when the WebAssembly memory is resized, which can
673
+ // happen when the memory is detached and resized by the WebAssembly module.
674
+ class DataViewProxy {
675
+ #module;
676
+ #type;
677
+
678
+ #_view = new DataView(new ArrayBuffer(0));
679
+ get #view() {
680
+ if (this.#_view.buffer.byteLength === 0) {
681
+ // WebAssembly memory resize detached the buffer so re-create the
682
+ // view with the new buffer.
683
+ this.#_view = new DataView(
684
+ this.#module.HEAPU8.buffer,
685
+ this.#module.HEAPU8.byteOffset + this.byteOffset);
686
+ }
687
+ return this.#_view;
688
+ }
689
+
690
+ /**
691
+ * @param {*} module
692
+ * @param {number} byteOffset
693
+ * @param {'Int32'|'BigInt64'} type
694
+ */
695
+ constructor(module, byteOffset, type) {
696
+ this.#module = module;
697
+ this.byteOffset = byteOffset;
698
+ this.#type = type;
699
+ }
700
+
701
+ get buffer() {
702
+ return this.#view.buffer;
703
+ }
704
+ get byteLength() {
705
+ return this.#type === 'Int32' ? 4 : 8;
706
+ }
707
+
708
+ getInt32(byteOffset, littleEndian) {
709
+ if (this.#type !== 'Int32') {
710
+ throw new Error('invalid type');
711
+ }
712
+ if (!littleEndian) throw new Error('must be little endian');
713
+ return this.#view.getInt32(byteOffset, littleEndian);
714
+ }
715
+ setInt32(byteOffset, value, littleEndian) {
716
+ if (this.#type !== 'Int32') {
717
+ throw new Error('invalid type');
718
+ }
719
+ if (!littleEndian) throw new Error('must be little endian');
720
+ this.#view.setInt32(byteOffset, value, littleEndian);
721
+ }
722
+ getBigInt64(byteOffset, littleEndian) {
723
+ if (this.#type !== 'BigInt64') {
724
+ throw new Error('invalid type');
725
+ }
726
+ if (!littleEndian) throw new Error('must be little endian');
727
+ return this.#view.getBigInt64(byteOffset, littleEndian);
728
+ }
729
+ setBigInt64(byteOffset, value, littleEndian) {
730
+ if (this.#type !== 'BigInt64') {
731
+ throw new Error('invalid type');
732
+ }
733
+ if (!littleEndian) throw new Error('must be little endian');
734
+ this.#view.setBigInt64(byteOffset, value, littleEndian);
735
+ }
736
+ }
737
+
738
+ /***/ }),
739
+
740
+ /***/ "../../node_modules/@journeyapps/wa-sqlite/src/VFS.js":
741
+ /*!************************************************************!*\
742
+ !*** ../../node_modules/@journeyapps/wa-sqlite/src/VFS.js ***!
743
+ \************************************************************/
744
+ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
745
+
746
+ __webpack_require__.r(__webpack_exports__);
747
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
748
+ /* harmony export */ Base: () => (/* binding */ Base),
749
+ /* harmony export */ FILE_TYPE_MASK: () => (/* binding */ FILE_TYPE_MASK),
750
+ /* harmony export */ SQLITE_ABORT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ABORT),
751
+ /* harmony export */ SQLITE_ACCESS_EXISTS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ACCESS_EXISTS),
752
+ /* harmony export */ SQLITE_ACCESS_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ACCESS_READ),
753
+ /* harmony export */ SQLITE_ACCESS_READWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ACCESS_READWRITE),
754
+ /* harmony export */ SQLITE_ALTER_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ALTER_TABLE),
755
+ /* harmony export */ SQLITE_ANALYZE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ANALYZE),
756
+ /* harmony export */ SQLITE_ATTACH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ATTACH),
757
+ /* harmony export */ SQLITE_AUTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_AUTH),
758
+ /* harmony export */ SQLITE_BLOB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_BLOB),
759
+ /* harmony export */ SQLITE_BUSY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_BUSY),
760
+ /* harmony export */ SQLITE_CANTOPEN: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CANTOPEN),
761
+ /* harmony export */ SQLITE_CONSTRAINT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT),
762
+ /* harmony export */ SQLITE_CONSTRAINT_CHECK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_CHECK),
763
+ /* harmony export */ SQLITE_CONSTRAINT_COMMITHOOK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_COMMITHOOK),
764
+ /* harmony export */ SQLITE_CONSTRAINT_FOREIGNKEY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_FOREIGNKEY),
765
+ /* harmony export */ SQLITE_CONSTRAINT_FUNCTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_FUNCTION),
766
+ /* harmony export */ SQLITE_CONSTRAINT_NOTNULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_NOTNULL),
767
+ /* harmony export */ SQLITE_CONSTRAINT_PINNED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_PINNED),
768
+ /* harmony export */ SQLITE_CONSTRAINT_PRIMARYKEY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_PRIMARYKEY),
769
+ /* harmony export */ SQLITE_CONSTRAINT_ROWID: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_ROWID),
770
+ /* harmony export */ SQLITE_CONSTRAINT_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_TRIGGER),
771
+ /* harmony export */ SQLITE_CONSTRAINT_UNIQUE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_UNIQUE),
772
+ /* harmony export */ SQLITE_CONSTRAINT_VTAB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CONSTRAINT_VTAB),
773
+ /* harmony export */ SQLITE_COPY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_COPY),
774
+ /* harmony export */ SQLITE_CORRUPT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CORRUPT),
775
+ /* harmony export */ SQLITE_CREATE_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_INDEX),
776
+ /* harmony export */ SQLITE_CREATE_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TABLE),
777
+ /* harmony export */ SQLITE_CREATE_TEMP_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_INDEX),
778
+ /* harmony export */ SQLITE_CREATE_TEMP_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_TABLE),
779
+ /* harmony export */ SQLITE_CREATE_TEMP_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_TRIGGER),
780
+ /* harmony export */ SQLITE_CREATE_TEMP_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TEMP_VIEW),
781
+ /* harmony export */ SQLITE_CREATE_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_TRIGGER),
782
+ /* harmony export */ SQLITE_CREATE_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_VIEW),
783
+ /* harmony export */ SQLITE_CREATE_VTABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CREATE_VTABLE),
784
+ /* harmony export */ SQLITE_DELETE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DELETE),
785
+ /* harmony export */ SQLITE_DENY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DENY),
786
+ /* harmony export */ SQLITE_DETACH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DETACH),
787
+ /* harmony export */ SQLITE_DETERMINISTIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DETERMINISTIC),
788
+ /* harmony export */ SQLITE_DIRECTONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DIRECTONLY),
789
+ /* harmony export */ SQLITE_DONE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DONE),
790
+ /* harmony export */ SQLITE_DROP_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_INDEX),
791
+ /* harmony export */ SQLITE_DROP_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TABLE),
792
+ /* harmony export */ SQLITE_DROP_TEMP_INDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_INDEX),
793
+ /* harmony export */ SQLITE_DROP_TEMP_TABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_TABLE),
794
+ /* harmony export */ SQLITE_DROP_TEMP_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_TRIGGER),
795
+ /* harmony export */ SQLITE_DROP_TEMP_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TEMP_VIEW),
796
+ /* harmony export */ SQLITE_DROP_TRIGGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_TRIGGER),
797
+ /* harmony export */ SQLITE_DROP_VIEW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_VIEW),
798
+ /* harmony export */ SQLITE_DROP_VTABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_DROP_VTABLE),
799
+ /* harmony export */ SQLITE_EMPTY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_EMPTY),
800
+ /* harmony export */ SQLITE_ERROR: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ERROR),
801
+ /* harmony export */ SQLITE_FCNTL_BEGIN_ATOMIC_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_BEGIN_ATOMIC_WRITE),
802
+ /* harmony export */ SQLITE_FCNTL_BUSYHANDLER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_BUSYHANDLER),
803
+ /* harmony export */ SQLITE_FCNTL_CHUNK_SIZE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_CHUNK_SIZE),
804
+ /* harmony export */ SQLITE_FCNTL_CKPT_DONE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_CKPT_DONE),
805
+ /* harmony export */ SQLITE_FCNTL_CKPT_START: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_CKPT_START),
806
+ /* harmony export */ SQLITE_FCNTL_COMMIT_ATOMIC_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_COMMIT_ATOMIC_WRITE),
807
+ /* harmony export */ SQLITE_FCNTL_COMMIT_PHASETWO: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_COMMIT_PHASETWO),
808
+ /* harmony export */ SQLITE_FCNTL_DATA_VERSION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_DATA_VERSION),
809
+ /* harmony export */ SQLITE_FCNTL_FILE_POINTER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_FILE_POINTER),
810
+ /* harmony export */ SQLITE_FCNTL_GET_LOCKPROXYFILE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_GET_LOCKPROXYFILE),
811
+ /* harmony export */ SQLITE_FCNTL_HAS_MOVED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_HAS_MOVED),
812
+ /* harmony export */ SQLITE_FCNTL_JOURNAL_POINTER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_JOURNAL_POINTER),
813
+ /* harmony export */ SQLITE_FCNTL_LAST_ERRNO: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_LAST_ERRNO),
814
+ /* harmony export */ SQLITE_FCNTL_LOCKSTATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_LOCKSTATE),
815
+ /* harmony export */ SQLITE_FCNTL_LOCK_TIMEOUT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_LOCK_TIMEOUT),
816
+ /* harmony export */ SQLITE_FCNTL_MMAP_SIZE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_MMAP_SIZE),
817
+ /* harmony export */ SQLITE_FCNTL_OVERWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_OVERWRITE),
818
+ /* harmony export */ SQLITE_FCNTL_PDB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_PDB),
819
+ /* harmony export */ SQLITE_FCNTL_PERSIST_WAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_PERSIST_WAL),
820
+ /* harmony export */ SQLITE_FCNTL_POWERSAFE_OVERWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_POWERSAFE_OVERWRITE),
821
+ /* harmony export */ SQLITE_FCNTL_PRAGMA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_PRAGMA),
822
+ /* harmony export */ SQLITE_FCNTL_RBU: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_RBU),
823
+ /* harmony export */ SQLITE_FCNTL_RESERVE_BYTES: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_RESERVE_BYTES),
824
+ /* harmony export */ SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_ROLLBACK_ATOMIC_WRITE),
825
+ /* harmony export */ SQLITE_FCNTL_SET_LOCKPROXYFILE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SET_LOCKPROXYFILE),
826
+ /* harmony export */ SQLITE_FCNTL_SIZE_HINT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SIZE_HINT),
827
+ /* harmony export */ SQLITE_FCNTL_SIZE_LIMIT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SIZE_LIMIT),
828
+ /* harmony export */ SQLITE_FCNTL_SYNC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SYNC),
829
+ /* harmony export */ SQLITE_FCNTL_SYNC_OMITTED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_SYNC_OMITTED),
830
+ /* harmony export */ SQLITE_FCNTL_TEMPFILENAME: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_TEMPFILENAME),
831
+ /* harmony export */ SQLITE_FCNTL_TRACE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_TRACE),
832
+ /* harmony export */ SQLITE_FCNTL_VFSNAME: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_VFSNAME),
833
+ /* harmony export */ SQLITE_FCNTL_VFS_POINTER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_VFS_POINTER),
834
+ /* harmony export */ SQLITE_FCNTL_WAL_BLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WAL_BLOCK),
835
+ /* harmony export */ SQLITE_FCNTL_WIN32_AV_RETRY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WIN32_AV_RETRY),
836
+ /* harmony export */ SQLITE_FCNTL_WIN32_GET_HANDLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WIN32_GET_HANDLE),
837
+ /* harmony export */ SQLITE_FCNTL_WIN32_SET_HANDLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_WIN32_SET_HANDLE),
838
+ /* harmony export */ SQLITE_FCNTL_ZIPVFS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FCNTL_ZIPVFS),
839
+ /* harmony export */ SQLITE_FLOAT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FLOAT),
840
+ /* harmony export */ SQLITE_FORMAT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FORMAT),
841
+ /* harmony export */ SQLITE_FULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FULL),
842
+ /* harmony export */ SQLITE_FUNCTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_FUNCTION),
843
+ /* harmony export */ SQLITE_IGNORE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IGNORE),
844
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_EQ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_EQ),
845
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_FUNCTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_FUNCTION),
846
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_GE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_GE),
847
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_GLOB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_GLOB),
848
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_GT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_GT),
849
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_IS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_IS),
850
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_ISNOT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_ISNOT),
851
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_ISNOTNULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_ISNOTNULL),
852
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_ISNULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_ISNULL),
853
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_LE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_LE),
854
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_LIKE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_LIKE),
855
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_LT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_LT),
856
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_MATCH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_MATCH),
857
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_NE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_NE),
858
+ /* harmony export */ SQLITE_INDEX_CONSTRAINT_REGEXP: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_CONSTRAINT_REGEXP),
859
+ /* harmony export */ SQLITE_INDEX_SCAN_UNIQUE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INDEX_SCAN_UNIQUE),
860
+ /* harmony export */ SQLITE_INNOCUOUS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INNOCUOUS),
861
+ /* harmony export */ SQLITE_INSERT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INSERT),
862
+ /* harmony export */ SQLITE_INTEGER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INTEGER),
863
+ /* harmony export */ SQLITE_INTERNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INTERNAL),
864
+ /* harmony export */ SQLITE_INTERRUPT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_INTERRUPT),
865
+ /* harmony export */ SQLITE_IOCAP_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC),
866
+ /* harmony export */ SQLITE_IOCAP_ATOMIC16K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC16K),
867
+ /* harmony export */ SQLITE_IOCAP_ATOMIC1K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC1K),
868
+ /* harmony export */ SQLITE_IOCAP_ATOMIC2K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC2K),
869
+ /* harmony export */ SQLITE_IOCAP_ATOMIC32K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC32K),
870
+ /* harmony export */ SQLITE_IOCAP_ATOMIC4K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC4K),
871
+ /* harmony export */ SQLITE_IOCAP_ATOMIC512: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC512),
872
+ /* harmony export */ SQLITE_IOCAP_ATOMIC64K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC64K),
873
+ /* harmony export */ SQLITE_IOCAP_ATOMIC8K: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_ATOMIC8K),
874
+ /* harmony export */ SQLITE_IOCAP_BATCH_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_BATCH_ATOMIC),
875
+ /* harmony export */ SQLITE_IOCAP_IMMUTABLE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_IMMUTABLE),
876
+ /* harmony export */ SQLITE_IOCAP_POWERSAFE_OVERWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_POWERSAFE_OVERWRITE),
877
+ /* harmony export */ SQLITE_IOCAP_SAFE_APPEND: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_SAFE_APPEND),
878
+ /* harmony export */ SQLITE_IOCAP_SEQUENTIAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_SEQUENTIAL),
879
+ /* harmony export */ SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOCAP_UNDELETABLE_WHEN_OPEN),
880
+ /* harmony export */ SQLITE_IOERR: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR),
881
+ /* harmony export */ SQLITE_IOERR_ACCESS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_ACCESS),
882
+ /* harmony export */ SQLITE_IOERR_BEGIN_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_BEGIN_ATOMIC),
883
+ /* harmony export */ SQLITE_IOERR_CHECKRESERVEDLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_CHECKRESERVEDLOCK),
884
+ /* harmony export */ SQLITE_IOERR_CLOSE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_CLOSE),
885
+ /* harmony export */ SQLITE_IOERR_COMMIT_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_COMMIT_ATOMIC),
886
+ /* harmony export */ SQLITE_IOERR_DATA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DATA),
887
+ /* harmony export */ SQLITE_IOERR_DELETE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DELETE),
888
+ /* harmony export */ SQLITE_IOERR_DELETE_NOENT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DELETE_NOENT),
889
+ /* harmony export */ SQLITE_IOERR_DIR_FSYNC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_DIR_FSYNC),
890
+ /* harmony export */ SQLITE_IOERR_FSTAT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_FSTAT),
891
+ /* harmony export */ SQLITE_IOERR_FSYNC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_FSYNC),
892
+ /* harmony export */ SQLITE_IOERR_GETTEMPPATH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_GETTEMPPATH),
893
+ /* harmony export */ SQLITE_IOERR_LOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_LOCK),
894
+ /* harmony export */ SQLITE_IOERR_NOMEM: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_NOMEM),
895
+ /* harmony export */ SQLITE_IOERR_RDLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_RDLOCK),
896
+ /* harmony export */ SQLITE_IOERR_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_READ),
897
+ /* harmony export */ SQLITE_IOERR_ROLLBACK_ATOMIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_ROLLBACK_ATOMIC),
898
+ /* harmony export */ SQLITE_IOERR_SEEK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_SEEK),
899
+ /* harmony export */ SQLITE_IOERR_SHORT_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_SHORT_READ),
900
+ /* harmony export */ SQLITE_IOERR_TRUNCATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_TRUNCATE),
901
+ /* harmony export */ SQLITE_IOERR_UNLOCK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_UNLOCK),
902
+ /* harmony export */ SQLITE_IOERR_VNODE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_VNODE),
903
+ /* harmony export */ SQLITE_IOERR_WRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_IOERR_WRITE),
904
+ /* harmony export */ SQLITE_LIMIT_ATTACHED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_ATTACHED),
905
+ /* harmony export */ SQLITE_LIMIT_COLUMN: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_COLUMN),
906
+ /* harmony export */ SQLITE_LIMIT_COMPOUND_SELECT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_COMPOUND_SELECT),
907
+ /* harmony export */ SQLITE_LIMIT_EXPR_DEPTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_EXPR_DEPTH),
908
+ /* harmony export */ SQLITE_LIMIT_FUNCTION_ARG: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_FUNCTION_ARG),
909
+ /* harmony export */ SQLITE_LIMIT_LENGTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_LENGTH),
910
+ /* harmony export */ SQLITE_LIMIT_LIKE_PATTERN_LENGTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_LIKE_PATTERN_LENGTH),
911
+ /* harmony export */ SQLITE_LIMIT_SQL_LENGTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_SQL_LENGTH),
912
+ /* harmony export */ SQLITE_LIMIT_TRIGGER_DEPTH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_TRIGGER_DEPTH),
913
+ /* harmony export */ SQLITE_LIMIT_VARIABLE_NUMBER: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_VARIABLE_NUMBER),
914
+ /* harmony export */ SQLITE_LIMIT_VDBE_OP: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_VDBE_OP),
915
+ /* harmony export */ SQLITE_LIMIT_WORKER_THREADS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LIMIT_WORKER_THREADS),
916
+ /* harmony export */ SQLITE_LOCKED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCKED),
917
+ /* harmony export */ SQLITE_LOCK_EXCLUSIVE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_EXCLUSIVE),
918
+ /* harmony export */ SQLITE_LOCK_NONE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_NONE),
919
+ /* harmony export */ SQLITE_LOCK_PENDING: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_PENDING),
920
+ /* harmony export */ SQLITE_LOCK_RESERVED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_RESERVED),
921
+ /* harmony export */ SQLITE_LOCK_SHARED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_LOCK_SHARED),
922
+ /* harmony export */ SQLITE_MISMATCH: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_MISMATCH),
923
+ /* harmony export */ SQLITE_MISUSE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_MISUSE),
924
+ /* harmony export */ SQLITE_NOLFS: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOLFS),
925
+ /* harmony export */ SQLITE_NOMEM: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOMEM),
926
+ /* harmony export */ SQLITE_NOTADB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTADB),
927
+ /* harmony export */ SQLITE_NOTFOUND: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTFOUND),
928
+ /* harmony export */ SQLITE_NOTICE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTICE),
929
+ /* harmony export */ SQLITE_NULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NULL),
930
+ /* harmony export */ SQLITE_OK: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK),
931
+ /* harmony export */ SQLITE_OPEN_AUTOPROXY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_AUTOPROXY),
932
+ /* harmony export */ SQLITE_OPEN_CREATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_CREATE),
933
+ /* harmony export */ SQLITE_OPEN_DELETEONCLOSE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_DELETEONCLOSE),
934
+ /* harmony export */ SQLITE_OPEN_EXCLUSIVE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_EXCLUSIVE),
935
+ /* harmony export */ SQLITE_OPEN_FULLMUTEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_FULLMUTEX),
936
+ /* harmony export */ SQLITE_OPEN_MAIN_DB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_DB),
937
+ /* harmony export */ SQLITE_OPEN_MAIN_JOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_JOURNAL),
938
+ /* harmony export */ SQLITE_OPEN_MEMORY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MEMORY),
939
+ /* harmony export */ SQLITE_OPEN_NOFOLLOW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_NOFOLLOW),
940
+ /* harmony export */ SQLITE_OPEN_NOMUTEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_NOMUTEX),
941
+ /* harmony export */ SQLITE_OPEN_PRIVATECACHE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_PRIVATECACHE),
942
+ /* harmony export */ SQLITE_OPEN_READONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_READONLY),
943
+ /* harmony export */ SQLITE_OPEN_READWRITE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_READWRITE),
944
+ /* harmony export */ SQLITE_OPEN_SHAREDCACHE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SHAREDCACHE),
945
+ /* harmony export */ SQLITE_OPEN_SUBJOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUBJOURNAL),
946
+ /* harmony export */ SQLITE_OPEN_SUPER_JOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUPER_JOURNAL),
947
+ /* harmony export */ SQLITE_OPEN_TEMP_DB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_DB),
948
+ /* harmony export */ SQLITE_OPEN_TEMP_JOURNAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_JOURNAL),
949
+ /* harmony export */ SQLITE_OPEN_TRANSIENT_DB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TRANSIENT_DB),
950
+ /* harmony export */ SQLITE_OPEN_URI: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_URI),
951
+ /* harmony export */ SQLITE_OPEN_WAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_WAL),
952
+ /* harmony export */ SQLITE_PERM: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PERM),
953
+ /* harmony export */ SQLITE_PRAGMA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PRAGMA),
954
+ /* harmony export */ SQLITE_PREPARE_NORMALIZED: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PREPARE_NORMALIZED),
955
+ /* harmony export */ SQLITE_PREPARE_NO_VTAB: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PREPARE_NO_VTAB),
956
+ /* harmony export */ SQLITE_PREPARE_PERSISTENT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PREPARE_PERSISTENT),
957
+ /* harmony export */ SQLITE_PROTOCOL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_PROTOCOL),
958
+ /* harmony export */ SQLITE_RANGE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_RANGE),
959
+ /* harmony export */ SQLITE_READ: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_READ),
960
+ /* harmony export */ SQLITE_READONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_READONLY),
961
+ /* harmony export */ SQLITE_RECURSIVE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_RECURSIVE),
962
+ /* harmony export */ SQLITE_REINDEX: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_REINDEX),
963
+ /* harmony export */ SQLITE_ROW: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_ROW),
964
+ /* harmony export */ SQLITE_SAVEPOINT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SAVEPOINT),
965
+ /* harmony export */ SQLITE_SCHEMA: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SCHEMA),
966
+ /* harmony export */ SQLITE_SELECT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SELECT),
967
+ /* harmony export */ SQLITE_STATIC: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_STATIC),
968
+ /* harmony export */ SQLITE_SUBTYPE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SUBTYPE),
969
+ /* harmony export */ SQLITE_SYNC_DATAONLY: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SYNC_DATAONLY),
970
+ /* harmony export */ SQLITE_SYNC_FULL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SYNC_FULL),
971
+ /* harmony export */ SQLITE_SYNC_NORMAL: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_SYNC_NORMAL),
972
+ /* harmony export */ SQLITE_TEXT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TEXT),
973
+ /* harmony export */ SQLITE_TOOBIG: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TOOBIG),
974
+ /* harmony export */ SQLITE_TRANSACTION: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TRANSACTION),
975
+ /* harmony export */ SQLITE_TRANSIENT: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_TRANSIENT),
976
+ /* harmony export */ SQLITE_UPDATE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UPDATE),
977
+ /* harmony export */ SQLITE_UTF16: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF16),
978
+ /* harmony export */ SQLITE_UTF16BE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF16BE),
979
+ /* harmony export */ SQLITE_UTF16LE: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF16LE),
980
+ /* harmony export */ SQLITE_UTF8: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_UTF8),
981
+ /* harmony export */ SQLITE_WARNING: () => (/* reexport safe */ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_WARNING)
982
+ /* harmony export */ });
983
+ /* harmony import */ var _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sqlite-constants.js */ "../../node_modules/@journeyapps/wa-sqlite/src/sqlite-constants.js");
984
+ // Copyright 2024 Roy T. Hashimoto. All Rights Reserved.
985
+
986
+
987
+
988
+ const DEFAULT_SECTOR_SIZE = 512;
989
+
990
+ // Base class for a VFS.
991
+ class Base {
992
+ name;
993
+ mxPathname = 64;
994
+ _module;
995
+
996
+ /**
997
+ * @param {string} name
998
+ * @param {object} module
999
+ */
1000
+ constructor(name, module) {
1001
+ this.name = name;
1002
+ this._module = module;
1003
+ }
1004
+
1005
+ /**
1006
+ * @returns {void|Promise<void>}
1007
+ */
1008
+ close() {
1009
+ }
1010
+
1011
+ /**
1012
+ * @returns {boolean|Promise<boolean>}
1013
+ */
1014
+ isReady() {
1015
+ return true;
1016
+ }
1017
+
1018
+ /**
1019
+ * Overload in subclasses to indicate which methods are asynchronous.
1020
+ * @param {string} methodName
1021
+ * @returns {boolean}
1022
+ */
1023
+ hasAsyncMethod(methodName) {
1024
+ return false;
1025
+ }
1026
+
1027
+ /**
1028
+ * @param {number} pVfs
1029
+ * @param {number} zName
1030
+ * @param {number} pFile
1031
+ * @param {number} flags
1032
+ * @param {number} pOutFlags
1033
+ * @returns {number|Promise<number>}
1034
+ */
1035
+ xOpen(pVfs, zName, pFile, flags, pOutFlags) {
1036
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_CANTOPEN;
1037
+ }
1038
+
1039
+ /**
1040
+ * @param {number} pVfs
1041
+ * @param {number} zName
1042
+ * @param {number} syncDir
1043
+ * @returns {number|Promise<number>}
1044
+ */
1045
+ xDelete(pVfs, zName, syncDir) {
1046
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1047
+ }
1048
+
1049
+ /**
1050
+ * @param {number} pVfs
1051
+ * @param {number} zName
1052
+ * @param {number} flags
1053
+ * @param {number} pResOut
1054
+ * @returns {number|Promise<number>}
1055
+ */
1056
+ xAccess(pVfs, zName, flags, pResOut) {
1057
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1058
+ }
1059
+
1060
+ /**
1061
+ * @param {number} pVfs
1062
+ * @param {number} zName
1063
+ * @param {number} nOut
1064
+ * @param {number} zOut
1065
+ * @returns {number|Promise<number>}
1066
+ */
1067
+ xFullPathname(pVfs, zName, nOut, zOut) {
1068
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1069
+ }
1070
+
1071
+ /**
1072
+ * @param {number} pVfs
1073
+ * @param {number} nBuf
1074
+ * @param {number} zBuf
1075
+ * @returns {number|Promise<number>}
1076
+ */
1077
+ xGetLastError(pVfs, nBuf, zBuf) {
1078
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1079
+ }
1080
+
1081
+ /**
1082
+ * @param {number} pFile
1083
+ * @returns {number|Promise<number>}
1084
+ */
1085
+ xClose(pFile) {
1086
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1087
+ }
1088
+
1089
+ /**
1090
+ * @param {number} pFile
1091
+ * @param {number} pData
1092
+ * @param {number} iAmt
1093
+ * @param {number} iOffsetLo
1094
+ * @param {number} iOffsetHi
1095
+ * @returns {number|Promise<number>}
1096
+ */
1097
+ xRead(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
1098
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1099
+ }
1100
+
1101
+ /**
1102
+ * @param {number} pFile
1103
+ * @param {number} pData
1104
+ * @param {number} iAmt
1105
+ * @param {number} iOffsetLo
1106
+ * @param {number} iOffsetHi
1107
+ * @returns {number|Promise<number>}
1108
+ */
1109
+ xWrite(pFile, pData, iAmt, iOffsetLo, iOffsetHi) {
1110
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1111
+ }
1112
+
1113
+ /**
1114
+ * @param {number} pFile
1115
+ * @param {number} sizeLo
1116
+ * @param {number} sizeHi
1117
+ * @returns {number|Promise<number>}
1118
+ */
1119
+ xTruncate(pFile, sizeLo, sizeHi) {
1120
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1121
+ }
1122
+
1123
+ /**
1124
+ * @param {number} pFile
1125
+ * @param {number} flags
1126
+ * @returns {number|Promise<number>}
1127
+ */
1128
+ xSync(pFile, flags) {
1129
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1130
+ }
1131
+
1132
+ /**
1133
+ *
1134
+ * @param {number} pFile
1135
+ * @param {number} pSize
1136
+ * @returns {number|Promise<number>}
1137
+ */
1138
+ xFileSize(pFile, pSize) {
1139
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1140
+ }
1141
+
1142
+ /**
1143
+ * @param {number} pFile
1144
+ * @param {number} lockType
1145
+ * @returns {number|Promise<number>}
1146
+ */
1147
+ xLock(pFile, lockType) {
1148
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1149
+ }
1150
+
1151
+ /**
1152
+ * @param {number} pFile
1153
+ * @param {number} lockType
1154
+ * @returns {number|Promise<number>}
1155
+ */
1156
+ xUnlock(pFile, lockType) {
1157
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1158
+ }
1159
+
1160
+ /**
1161
+ * @param {number} pFile
1162
+ * @param {number} pResOut
1163
+ * @returns {number|Promise<number>}
1164
+ */
1165
+ xCheckReservedLock(pFile, pResOut) {
1166
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OK;
1167
+ }
1168
+
1169
+ /**
1170
+ * @param {number} pFile
1171
+ * @param {number} op
1172
+ * @param {number} pArg
1173
+ * @returns {number|Promise<number>}
1174
+ */
1175
+ xFileControl(pFile, op, pArg) {
1176
+ return _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_NOTFOUND;
1177
+ }
1178
+
1179
+ /**
1180
+ * @param {number} pFile
1181
+ * @returns {number|Promise<number>}
1182
+ */
1183
+ xSectorSize(pFile) {
1184
+ return DEFAULT_SECTOR_SIZE;
1185
+ }
1186
+
1187
+ /**
1188
+ * @param {number} pFile
1189
+ * @returns {number|Promise<number>}
1190
+ */
1191
+ xDeviceCharacteristics(pFile) {
1192
+ return 0;
1193
+ }
1194
+ }
1195
+
1196
+ const FILE_TYPE_MASK = [
1197
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_DB,
1198
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_MAIN_JOURNAL,
1199
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_DB,
1200
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TEMP_JOURNAL,
1201
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_TRANSIENT_DB,
1202
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUBJOURNAL,
1203
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_SUPER_JOURNAL,
1204
+ _sqlite_constants_js__WEBPACK_IMPORTED_MODULE_0__.SQLITE_OPEN_WAL
1205
+ ].reduce((mask, element) => mask | element);
1206
+
1207
+ /***/ }),
1208
+
6
1209
  /***/ "../../node_modules/@journeyapps/wa-sqlite/src/sqlite-api.js":
7
1210
  /*!*******************************************************************!*\
8
1211
  !*** ../../node_modules/@journeyapps/wa-sqlite/src/sqlite-api.js ***!
@@ -14673,7 +15876,7 @@ The next upload iteration will be delayed.`);
14673
15876
  uploadError: ex
14674
15877
  }
14675
15878
  });
14676
- await this.delayRetry(controller.signal, this.options.crudUploadThrottleMs);
15879
+ await this.delayRetry(controller.signal);
14677
15880
  if (!this.isConnected) {
14678
15881
  // Exit the upload loop if the sync stream is no longer connected
14679
15882
  break;
@@ -15384,14 +16587,14 @@ The next upload iteration will be delayed.`);
15384
16587
  // trigger this for all updates
15385
16588
  this.iterateListeners((cb) => cb.statusUpdated?.(options));
15386
16589
  }
15387
- async delayRetry(signal, delayMs) {
16590
+ async delayRetry(signal) {
15388
16591
  return new Promise((resolve) => {
15389
16592
  if (signal?.aborted) {
15390
16593
  // If the signal is already aborted, resolve immediately
15391
16594
  resolve();
15392
16595
  return;
15393
16596
  }
15394
- const delay = delayMs ?? this.options.retryDelayMs;
16597
+ const { retryDelayMs } = this.options;
15395
16598
  let timeoutId;
15396
16599
  const endDelay = () => {
15397
16600
  resolve();
@@ -15402,7 +16605,7 @@ The next upload iteration will be delayed.`);
15402
16605
  signal?.removeEventListener('abort', endDelay);
15403
16606
  };
15404
16607
  signal?.addEventListener('abort', endDelay, { once: true });
15405
- timeoutId = setTimeout(endDelay, delay);
16608
+ timeoutId = setTimeout(endDelay, retryDelayMs);
15406
16609
  });
15407
16610
  }
15408
16611
  updateSubscriptions(subscriptions) {
@@ -17635,6 +18838,8 @@ __webpack_require__.r(__webpack_exports__);
17635
18838
  /* harmony import */ var _journeyapps_wa_sqlite__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @journeyapps/wa-sqlite */ "../../node_modules/@journeyapps/wa-sqlite/src/sqlite-api.js");
17636
18839
  /* harmony import */ var _powersync_common__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @powersync/common */ "../common/dist/bundle.mjs");
17637
18840
  /* harmony import */ var async_mutex__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! async-mutex */ "../../node_modules/async-mutex/index.mjs");
18841
+ /* harmony import */ var _worker_db_opfs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../worker/db/opfs */ "./lib/src/worker/db/opfs.js");
18842
+
17638
18843
 
17639
18844
 
17640
18845
 
@@ -17717,11 +18922,10 @@ const DEFAULT_MODULE_FACTORIES = {
17717
18922
  else {
17718
18923
  module = await SyncWASQLiteModuleFactory();
17719
18924
  }
17720
- // @ts-expect-error The types for this static method are missing upstream
17721
- const { OPFSCoopSyncVFS } = await __webpack_require__.e(/*! import() */ "node_modules_journeyapps_wa-sqlite_src_examples_OPFSCoopSyncVFS_js").then(__webpack_require__.bind(__webpack_require__, /*! @journeyapps/wa-sqlite/src/examples/OPFSCoopSyncVFS.js */ "../../node_modules/@journeyapps/wa-sqlite/src/examples/OPFSCoopSyncVFS.js"));
18925
+ const vfs = await _worker_db_opfs__WEBPACK_IMPORTED_MODULE_3__.OPFSCoopSyncVFS.create(options.dbFileName, module);
17722
18926
  return {
17723
18927
  module,
17724
- vfs: await OPFSCoopSyncVFS.create(options.dbFileName, module)
18928
+ vfs: vfs
17725
18929
  };
17726
18930
  }
17727
18931
  };
@@ -18181,6 +19385,604 @@ class WorkerWASQLiteConnection extends _db_adapters_wa_sqlite_WASQLiteConnection
18181
19385
  }
18182
19386
 
18183
19387
 
19388
+ /***/ }),
19389
+
19390
+ /***/ "./lib/src/worker/db/opfs.js":
19391
+ /*!***********************************!*\
19392
+ !*** ./lib/src/worker/db/opfs.js ***!
19393
+ \***********************************/
19394
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
19395
+
19396
+ __webpack_require__.r(__webpack_exports__);
19397
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
19398
+ /* harmony export */ OPFSCoopSyncVFS: () => (/* binding */ OPFSCoopSyncVFS)
19399
+ /* harmony export */ });
19400
+ /* harmony import */ var _journeyapps_wa_sqlite_src_FacadeVFS_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @journeyapps/wa-sqlite/src/FacadeVFS.js */ "../../node_modules/@journeyapps/wa-sqlite/src/FacadeVFS.js");
19401
+ /* harmony import */ var _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @journeyapps/wa-sqlite/src/VFS.js */ "../../node_modules/@journeyapps/wa-sqlite/src/VFS.js");
19402
+ // Copyright 2024 Roy T. Hashimoto. All Rights Reserved.
19403
+ // @ts-nocheck
19404
+
19405
+
19406
+ const DEFAULT_TEMPORARY_FILES = 10;
19407
+ const LOCK_NOTIFY_INTERVAL = 1000;
19408
+ const DB_RELATED_FILE_SUFFIXES = ['', '-journal', '-wal'];
19409
+ const finalizationRegistry = new FinalizationRegistry((releaser) => releaser());
19410
+ class File {
19411
+ /** @type {string} */ path;
19412
+ /** @type {number} */ flags;
19413
+ /** @type {FileSystemSyncAccessHandle} */ accessHandle;
19414
+ /** @type {PersistentFile?} */ persistentFile;
19415
+ constructor(path, flags) {
19416
+ this.path = path;
19417
+ this.flags = flags;
19418
+ }
19419
+ }
19420
+ class PersistentFile {
19421
+ /** @type {FileSystemFileHandle} */ fileHandle;
19422
+ /** @type {FileSystemSyncAccessHandle} */ accessHandle = null;
19423
+ // The following properties are for main database files.
19424
+ /** @type {boolean} */ isLockBusy = false;
19425
+ /** @type {boolean} */ isFileLocked = false;
19426
+ /** @type {boolean} */ isRequestInProgress = false;
19427
+ /** @type {function} */ handleLockReleaser = null;
19428
+ /** @type {BroadcastChannel} */ handleRequestChannel;
19429
+ /** @type {boolean} */ isHandleRequested = false;
19430
+ constructor(fileHandle) {
19431
+ this.fileHandle = fileHandle;
19432
+ }
19433
+ }
19434
+ class OPFSCoopSyncVFS extends _journeyapps_wa_sqlite_src_FacadeVFS_js__WEBPACK_IMPORTED_MODULE_0__.FacadeVFS {
19435
+ /** @type {Map<number, File>} */ mapIdToFile = new Map();
19436
+ lastError = null;
19437
+ log = null; //function(...args) { console.log(`[${contextName}]`, ...args) };
19438
+ /** @type {Map<string, PersistentFile>} */ persistentFiles = new Map();
19439
+ /** @type {Map<string, FileSystemSyncAccessHandle>} */ boundAccessHandles = new Map();
19440
+ /** @type {Set<FileSystemSyncAccessHandle>} */ unboundAccessHandles = new Set();
19441
+ /** @type {Set<string>} */ accessiblePaths = new Set();
19442
+ releaser = null;
19443
+ static async create(name, module) {
19444
+ const vfs = new OPFSCoopSyncVFS(name, module);
19445
+ await Promise.all([vfs.isReady(), vfs.#initialize(DEFAULT_TEMPORARY_FILES)]);
19446
+ return vfs;
19447
+ }
19448
+ constructor(name, module) {
19449
+ super(name, module);
19450
+ }
19451
+ async #initialize(nTemporaryFiles) {
19452
+ // Delete temporary directories no longer in use.
19453
+ const root = await navigator.storage.getDirectory();
19454
+ // @ts-ignore
19455
+ for await (const entry of root.values()) {
19456
+ if (entry.kind === 'directory' && entry.name.startsWith('.ahp-')) {
19457
+ // A lock with the same name as the directory protects it from
19458
+ // being deleted.
19459
+ await navigator.locks.request(entry.name, { ifAvailable: true }, async (lock) => {
19460
+ if (lock) {
19461
+ this.log?.(`Deleting temporary directory ${entry.name}`);
19462
+ await root.removeEntry(entry.name, { recursive: true });
19463
+ }
19464
+ else {
19465
+ this.log?.(`Temporary directory ${entry.name} is in use`);
19466
+ }
19467
+ });
19468
+ }
19469
+ }
19470
+ // Create our temporary directory.
19471
+ const tmpDirName = `.ahp-${Math.random().toString(36).slice(2)}`;
19472
+ this.releaser = await new Promise((resolve) => {
19473
+ navigator.locks.request(tmpDirName, () => {
19474
+ return new Promise((release) => {
19475
+ resolve(release);
19476
+ });
19477
+ });
19478
+ });
19479
+ const releaseHandle = async () => {
19480
+ await Promise.all(this.persistentFiles.values().map(async (file) => {
19481
+ try {
19482
+ await this.#releaseAccessHandle(file);
19483
+ }
19484
+ catch (e) {
19485
+ this.log?.('error releasing access handle', e);
19486
+ }
19487
+ finally {
19488
+ release();
19489
+ }
19490
+ }));
19491
+ };
19492
+ finalizationRegistry.register(this, releaseHandle);
19493
+ finalizationRegistry.register(this, this.releaser);
19494
+ const tmpDir = await root.getDirectoryHandle(tmpDirName, { create: true });
19495
+ // Populate temporary directory.
19496
+ for (let i = 0; i < nTemporaryFiles; i++) {
19497
+ const tmpFile = await tmpDir.getFileHandle(`${i}.tmp`, { create: true });
19498
+ const tmpAccessHandle = await tmpFile.createSyncAccessHandle();
19499
+ this.unboundAccessHandles.add(tmpAccessHandle);
19500
+ }
19501
+ }
19502
+ /**
19503
+ * @param {string?} zName
19504
+ * @param {number} fileId
19505
+ * @param {number} flags
19506
+ * @param {DataView} pOutFlags
19507
+ * @returns {number}
19508
+ */
19509
+ jOpen(zName, fileId, flags, pOutFlags) {
19510
+ try {
19511
+ const url = new URL(zName || Math.random().toString(36).slice(2), 'file://');
19512
+ const path = url.pathname;
19513
+ if (flags & _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_MAIN_DB) {
19514
+ const persistentFile = this.persistentFiles.get(path);
19515
+ if (persistentFile?.isRequestInProgress) {
19516
+ // Should not reach here unless SQLite itself retries an open.
19517
+ // Otherwise, asynchronous operations started on a previous
19518
+ // open try should have completed.
19519
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_BUSY;
19520
+ }
19521
+ else if (!persistentFile) {
19522
+ // This is the usual starting point for opening a database.
19523
+ // Register a Promise that resolves when the database and related
19524
+ // files are ready to be used.
19525
+ this.log?.(`creating persistent file for ${path}`);
19526
+ const create = !!(flags & _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_CREATE);
19527
+ this._module.retryOps.push((async () => {
19528
+ try {
19529
+ // Get the path directory handle.
19530
+ let dirHandle = await navigator.storage.getDirectory();
19531
+ const directories = path.split('/').filter((d) => d);
19532
+ const filename = directories.pop();
19533
+ for (const directory of directories) {
19534
+ dirHandle = await dirHandle.getDirectoryHandle(directory, { create });
19535
+ }
19536
+ // Get file handles for the database and related files,
19537
+ // and create persistent file instances.
19538
+ for (const suffix of DB_RELATED_FILE_SUFFIXES) {
19539
+ const fileHandle = await dirHandle.getFileHandle(filename + suffix, { create });
19540
+ await this.#createPersistentFile(fileHandle);
19541
+ }
19542
+ // Get access handles for the files.
19543
+ const file = new File(path, flags);
19544
+ file.persistentFile = this.persistentFiles.get(path);
19545
+ await this.#requestAccessHandle(file);
19546
+ }
19547
+ catch (e) {
19548
+ // Use an invalid persistent file to signal this error
19549
+ // for the retried open.
19550
+ const persistentFile = new PersistentFile(null);
19551
+ this.persistentFiles.set(path, persistentFile);
19552
+ console.error(e);
19553
+ }
19554
+ })());
19555
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_BUSY;
19556
+ }
19557
+ else if (!persistentFile.fileHandle) {
19558
+ // The asynchronous open operation failed.
19559
+ this.persistentFiles.delete(path);
19560
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_CANTOPEN;
19561
+ }
19562
+ else if (!persistentFile.accessHandle) {
19563
+ // This branch is reached if the database was previously opened
19564
+ // and closed.
19565
+ this._module.retryOps.push((async () => {
19566
+ const file = new File(path, flags);
19567
+ file.persistentFile = this.persistentFiles.get(path);
19568
+ await this.#requestAccessHandle(file);
19569
+ })());
19570
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_BUSY;
19571
+ }
19572
+ }
19573
+ if (!this.accessiblePaths.has(path) && !(flags & _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_CREATE)) {
19574
+ throw new Error(`File ${path} not found`);
19575
+ }
19576
+ const file = new File(path, flags);
19577
+ this.mapIdToFile.set(fileId, file);
19578
+ if (this.persistentFiles.has(path)) {
19579
+ file.persistentFile = this.persistentFiles.get(path);
19580
+ }
19581
+ else if (this.boundAccessHandles.has(path)) {
19582
+ // This temporary file was previously created and closed. Reopen
19583
+ // the same access handle.
19584
+ file.accessHandle = this.boundAccessHandles.get(path);
19585
+ }
19586
+ else if (this.unboundAccessHandles.size) {
19587
+ // Associate an unbound access handle to this file.
19588
+ file.accessHandle = this.unboundAccessHandles.values().next().value;
19589
+ file.accessHandle.truncate(0);
19590
+ this.unboundAccessHandles.delete(file.accessHandle);
19591
+ this.boundAccessHandles.set(path, file.accessHandle);
19592
+ }
19593
+ this.accessiblePaths.add(path);
19594
+ pOutFlags.setInt32(0, flags, true);
19595
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19596
+ }
19597
+ catch (e) {
19598
+ this.lastError = e;
19599
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_CANTOPEN;
19600
+ }
19601
+ }
19602
+ /**
19603
+ * @param {string} zName
19604
+ * @param {number} syncDir
19605
+ * @returns {number}
19606
+ */
19607
+ jDelete(zName, syncDir) {
19608
+ try {
19609
+ const url = new URL(zName, 'file://');
19610
+ const path = url.pathname;
19611
+ if (this.persistentFiles.has(path)) {
19612
+ const persistentFile = this.persistentFiles.get(path);
19613
+ persistentFile.accessHandle.truncate(0);
19614
+ }
19615
+ else {
19616
+ this.boundAccessHandles.get(path)?.truncate(0);
19617
+ }
19618
+ this.accessiblePaths.delete(path);
19619
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19620
+ }
19621
+ catch (e) {
19622
+ this.lastError = e;
19623
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_DELETE;
19624
+ }
19625
+ }
19626
+ /**
19627
+ * @param {string} zName
19628
+ * @param {number} flags
19629
+ * @param {DataView} pResOut
19630
+ * @returns {number}
19631
+ */
19632
+ jAccess(zName, flags, pResOut) {
19633
+ try {
19634
+ const url = new URL(zName, 'file://');
19635
+ const path = url.pathname;
19636
+ pResOut.setInt32(0, this.accessiblePaths.has(path) ? 1 : 0, true);
19637
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19638
+ }
19639
+ catch (e) {
19640
+ this.lastError = e;
19641
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_ACCESS;
19642
+ }
19643
+ }
19644
+ /**
19645
+ * @param {number} fileId
19646
+ * @returns {number}
19647
+ */
19648
+ jClose(fileId) {
19649
+ try {
19650
+ const file = this.mapIdToFile.get(fileId);
19651
+ this.mapIdToFile.delete(fileId);
19652
+ if (file?.flags & _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_MAIN_DB) {
19653
+ if (file.persistentFile?.accessHandle) {
19654
+ this.#releaseAccessHandle(file);
19655
+ }
19656
+ }
19657
+ else if (file?.flags & _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_DELETEONCLOSE) {
19658
+ file.accessHandle.truncate(0);
19659
+ this.accessiblePaths.delete(file.path);
19660
+ if (!this.persistentFiles.has(file.path)) {
19661
+ this.boundAccessHandles.delete(file.path);
19662
+ this.unboundAccessHandles.add(file.accessHandle);
19663
+ }
19664
+ }
19665
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19666
+ }
19667
+ catch (e) {
19668
+ this.lastError = e;
19669
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_CLOSE;
19670
+ }
19671
+ }
19672
+ /**
19673
+ * @param {number} fileId
19674
+ * @param {Uint8Array} pData
19675
+ * @param {number} iOffset
19676
+ * @returns {number}
19677
+ */
19678
+ jRead(fileId, pData, iOffset) {
19679
+ try {
19680
+ const file = this.mapIdToFile.get(fileId);
19681
+ // On Chrome (at least), passing pData to accessHandle.read() is
19682
+ // an error because pData is a Proxy of a Uint8Array. Calling
19683
+ // subarray() produces a real Uint8Array and that works.
19684
+ const accessHandle = file.accessHandle || file.persistentFile.accessHandle;
19685
+ const bytesRead = accessHandle.read(pData.subarray(), { at: iOffset });
19686
+ // Opening a database file performs one read without a xLock call.
19687
+ if (file.flags & _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OPEN_MAIN_DB && !file.persistentFile.isFileLocked) {
19688
+ this.#releaseAccessHandle(file);
19689
+ }
19690
+ if (bytesRead < pData.byteLength) {
19691
+ pData.fill(0, bytesRead);
19692
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_SHORT_READ;
19693
+ }
19694
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19695
+ }
19696
+ catch (e) {
19697
+ this.lastError = e;
19698
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_READ;
19699
+ }
19700
+ }
19701
+ /**
19702
+ * @param {number} fileId
19703
+ * @param {Uint8Array} pData
19704
+ * @param {number} iOffset
19705
+ * @returns {number}
19706
+ */
19707
+ jWrite(fileId, pData, iOffset) {
19708
+ try {
19709
+ const file = this.mapIdToFile.get(fileId);
19710
+ // On Chrome (at least), passing pData to accessHandle.write() is
19711
+ // an error because pData is a Proxy of a Uint8Array. Calling
19712
+ // subarray() produces a real Uint8Array and that works.
19713
+ const accessHandle = file.accessHandle || file.persistentFile.accessHandle;
19714
+ const nBytes = accessHandle.write(pData.subarray(), { at: iOffset });
19715
+ if (nBytes !== pData.byteLength)
19716
+ throw new Error('short write');
19717
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19718
+ }
19719
+ catch (e) {
19720
+ this.lastError = e;
19721
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_WRITE;
19722
+ }
19723
+ }
19724
+ /**
19725
+ * @param {number} fileId
19726
+ * @param {number} iSize
19727
+ * @returns {number}
19728
+ */
19729
+ jTruncate(fileId, iSize) {
19730
+ try {
19731
+ const file = this.mapIdToFile.get(fileId);
19732
+ const accessHandle = file.accessHandle || file.persistentFile.accessHandle;
19733
+ accessHandle.truncate(iSize);
19734
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19735
+ }
19736
+ catch (e) {
19737
+ this.lastError = e;
19738
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_TRUNCATE;
19739
+ }
19740
+ }
19741
+ /**
19742
+ * @param {number} fileId
19743
+ * @param {number} flags
19744
+ * @returns {number}
19745
+ */
19746
+ jSync(fileId, flags) {
19747
+ try {
19748
+ const file = this.mapIdToFile.get(fileId);
19749
+ const accessHandle = file.accessHandle || file.persistentFile.accessHandle;
19750
+ accessHandle.flush();
19751
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19752
+ }
19753
+ catch (e) {
19754
+ this.lastError = e;
19755
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_FSYNC;
19756
+ }
19757
+ }
19758
+ /**
19759
+ * @param {number} fileId
19760
+ * @param {DataView} pSize64
19761
+ * @returns {number}
19762
+ */
19763
+ jFileSize(fileId, pSize64) {
19764
+ try {
19765
+ const file = this.mapIdToFile.get(fileId);
19766
+ const accessHandle = file.accessHandle || file.persistentFile.accessHandle;
19767
+ const size = accessHandle.getSize();
19768
+ pSize64.setBigInt64(0, BigInt(size), true);
19769
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19770
+ }
19771
+ catch (e) {
19772
+ this.lastError = e;
19773
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR_FSTAT;
19774
+ }
19775
+ }
19776
+ /**
19777
+ * @param {number} fileId
19778
+ * @param {number} lockType
19779
+ * @returns {number}
19780
+ */
19781
+ jLock(fileId, lockType) {
19782
+ const file = this.mapIdToFile.get(fileId);
19783
+ if (file.persistentFile.isRequestInProgress) {
19784
+ file.persistentFile.isLockBusy = true;
19785
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_BUSY;
19786
+ }
19787
+ file.persistentFile.isFileLocked = true;
19788
+ if (!file.persistentFile.handleLockReleaser) {
19789
+ // Start listening for notifications from other connections.
19790
+ // This is before we actually get access handles, but waiting to
19791
+ // listen until then allows a race condition where notifications
19792
+ // are missed.
19793
+ file.persistentFile.handleRequestChannel.onmessage = () => {
19794
+ this.log?.(`received notification for ${file.path}`);
19795
+ if (file.persistentFile.isFileLocked) {
19796
+ // We're still using the access handle, so mark it to be
19797
+ // released when we're done.
19798
+ file.persistentFile.isHandleRequested = true;
19799
+ }
19800
+ else {
19801
+ // Release the access handles immediately.
19802
+ this.#releaseAccessHandle(file);
19803
+ }
19804
+ file.persistentFile.handleRequestChannel.onmessage = null;
19805
+ };
19806
+ this.#requestAccessHandle(file);
19807
+ this.log?.('returning SQLITE_BUSY');
19808
+ file.persistentFile.isLockBusy = true;
19809
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_BUSY;
19810
+ }
19811
+ file.persistentFile.isLockBusy = false;
19812
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19813
+ }
19814
+ /**
19815
+ * @param {number} fileId
19816
+ * @param {number} lockType
19817
+ * @returns {number}
19818
+ */
19819
+ jUnlock(fileId, lockType) {
19820
+ const file = this.mapIdToFile.get(fileId);
19821
+ if (lockType === _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_LOCK_NONE) {
19822
+ // Don't change any state if this unlock is because xLock returned
19823
+ // SQLITE_BUSY.
19824
+ if (!file.persistentFile.isLockBusy) {
19825
+ if (file.persistentFile.isHandleRequested) {
19826
+ // Another connection wants the access handle.
19827
+ this.#releaseAccessHandle(file);
19828
+ file.persistentFile.isHandleRequested = false;
19829
+ }
19830
+ file.persistentFile.isFileLocked = false;
19831
+ }
19832
+ }
19833
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19834
+ }
19835
+ /**
19836
+ * @param {number} fileId
19837
+ * @param {number} op
19838
+ * @param {DataView} pArg
19839
+ * @returns {number|Promise<number>}
19840
+ */
19841
+ jFileControl(fileId, op, pArg) {
19842
+ try {
19843
+ const file = this.mapIdToFile.get(fileId);
19844
+ switch (op) {
19845
+ case _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_FCNTL_PRAGMA:
19846
+ const key = extractString(pArg, 4);
19847
+ const value = extractString(pArg, 8);
19848
+ this.log?.('xFileControl', file.path, 'PRAGMA', key, value);
19849
+ switch (key.toLowerCase()) {
19850
+ case 'journal_mode':
19851
+ if (value && !['off', 'memory', 'delete', 'wal'].includes(value.toLowerCase())) {
19852
+ throw new Error('journal_mode must be "off", "memory", "delete", or "wal"');
19853
+ }
19854
+ break;
19855
+ }
19856
+ break;
19857
+ }
19858
+ }
19859
+ catch (e) {
19860
+ this.lastError = e;
19861
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_IOERR;
19862
+ }
19863
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_NOTFOUND;
19864
+ }
19865
+ /**
19866
+ * @param {Uint8Array} zBuf
19867
+ * @returns
19868
+ */
19869
+ jGetLastError(zBuf) {
19870
+ if (this.lastError) {
19871
+ console.error(this.lastError);
19872
+ const outputArray = zBuf.subarray(0, zBuf.byteLength - 1);
19873
+ const { written } = new TextEncoder().encodeInto(this.lastError.message, outputArray);
19874
+ zBuf[written] = 0;
19875
+ }
19876
+ return _journeyapps_wa_sqlite_src_VFS_js__WEBPACK_IMPORTED_MODULE_1__.SQLITE_OK;
19877
+ }
19878
+ /**
19879
+ * @param {FileSystemFileHandle} fileHandle
19880
+ * @returns {Promise<PersistentFile>}
19881
+ */
19882
+ async #createPersistentFile(fileHandle) {
19883
+ const persistentFile = new PersistentFile(fileHandle);
19884
+ const root = await navigator.storage.getDirectory();
19885
+ const relativePath = await root.resolve(fileHandle);
19886
+ const path = `/${relativePath.join('/')}`;
19887
+ persistentFile.handleRequestChannel = new BroadcastChannel(`ahp:${path}`);
19888
+ this.persistentFiles.set(path, persistentFile);
19889
+ const f = await fileHandle.getFile();
19890
+ if (f.size) {
19891
+ this.accessiblePaths.add(path);
19892
+ }
19893
+ return persistentFile;
19894
+ }
19895
+ /**
19896
+ * @param {File} file
19897
+ */
19898
+ #requestAccessHandle(file) {
19899
+ console.assert(!file.persistentFile.handleLockReleaser);
19900
+ if (!file.persistentFile.isRequestInProgress) {
19901
+ file.persistentFile.isRequestInProgress = true;
19902
+ this._module.retryOps.push((async () => {
19903
+ // Acquire the Web Lock.
19904
+ file.persistentFile.handleLockReleaser = await this.#acquireLock(file.persistentFile);
19905
+ try {
19906
+ // Get access handles for the database and releated files in parallel.
19907
+ this.log?.(`creating access handles for ${file.path}`);
19908
+ await Promise.all(DB_RELATED_FILE_SUFFIXES.map(async (suffix) => {
19909
+ const persistentFile = this.persistentFiles.get(file.path + suffix);
19910
+ if (persistentFile) {
19911
+ persistentFile.accessHandle = await persistentFile.fileHandle.createSyncAccessHandle();
19912
+ }
19913
+ }));
19914
+ }
19915
+ catch (e) {
19916
+ this.log?.(`failed to create access handles for ${file.path}`, e);
19917
+ // Close any of the potentially opened access handles
19918
+ DB_RELATED_FILE_SUFFIXES.forEach(async (suffix) => {
19919
+ const persistentFile = this.persistentFiles.get(file.path + suffix);
19920
+ if (persistentFile) {
19921
+ persistentFile.accessHandle?.close();
19922
+ }
19923
+ });
19924
+ // Release the lock, if we failed here, we'd need to obtain the lock later in order to retry
19925
+ file.persistentFile.handleLockReleaser();
19926
+ throw e;
19927
+ }
19928
+ finally {
19929
+ file.persistentFile.isRequestInProgress = false;
19930
+ }
19931
+ })());
19932
+ return this._module.retryOps.at(-1);
19933
+ }
19934
+ return Promise.resolve();
19935
+ }
19936
+ /**
19937
+ * @param {File} file
19938
+ */
19939
+ async #releaseAccessHandle(file) {
19940
+ DB_RELATED_FILE_SUFFIXES.forEach(async (suffix) => {
19941
+ const persistentFile = this.persistentFiles.get(file.path + suffix);
19942
+ if (persistentFile) {
19943
+ persistentFile.accessHandle?.close();
19944
+ persistentFile.accessHandle = null;
19945
+ }
19946
+ });
19947
+ this.log?.(`access handles closed for ${file.path}`);
19948
+ file.persistentFile.handleLockReleaser?.();
19949
+ file.persistentFile.handleLockReleaser = null;
19950
+ this.log?.(`lock released for ${file.path}`);
19951
+ }
19952
+ /**
19953
+ * @param {PersistentFile} persistentFile
19954
+ * @returns {Promise<function>} lock releaser
19955
+ */
19956
+ #acquireLock(persistentFile) {
19957
+ return new Promise((resolve) => {
19958
+ // Tell other connections we want the access handle.
19959
+ const lockName = persistentFile.handleRequestChannel.name;
19960
+ const notify = () => {
19961
+ this.log?.(`notifying for ${lockName}`);
19962
+ persistentFile.handleRequestChannel.postMessage(null);
19963
+ };
19964
+ const notifyId = setInterval(notify, LOCK_NOTIFY_INTERVAL);
19965
+ setTimeout(notify);
19966
+ this.log?.(`lock requested: ${lockName}`);
19967
+ navigator.locks.request(lockName, (lock) => {
19968
+ // We have the lock. Stop asking other connections for it.
19969
+ this.log?.(`lock acquired: ${lockName}`, lock);
19970
+ clearInterval(notifyId);
19971
+ return new Promise(resolve);
19972
+ });
19973
+ });
19974
+ }
19975
+ }
19976
+ function extractString(dataView, offset) {
19977
+ const p = dataView.getUint32(offset, true);
19978
+ if (p) {
19979
+ const chars = new Uint8Array(dataView.buffer, p);
19980
+ return new TextDecoder().decode(chars.subarray(0, chars.indexOf(0)));
19981
+ }
19982
+ return null;
19983
+ }
19984
+
19985
+
18184
19986
  /***/ })
18185
19987
 
18186
19988
  /******/ });
@@ -18369,7 +20171,6 @@ const DBMap = new Map();
18369
20171
  const OPEN_DB_LOCK = 'open-wasqlite-db';
18370
20172
  let nextClientId = 1;
18371
20173
  const openDBShared = async (options) => {
18372
- // Prevent multiple simultaneous opens from causing race conditions
18373
20174
  return (0,_shared_navigator__WEBPACK_IMPORTED_MODULE_2__.getNavigatorLocks)().request(OPEN_DB_LOCK, async () => {
18374
20175
  const clientId = nextClientId++;
18375
20176
  const { dbFilename, logLevel } = options;