| 
							
							
								 stephan | b1cc895c92 | Another reformulation of SQLITE_WASM_DEALLOC to attempt to work around a Safari-specific quirk reported in [forum:5489305f601b8c3f|forum post 5489305f601b8c3f]. FossilOrigin-Name: ae0196d86ee8ca424b5ef5a43c32988f4ab5131ea146669bc1467e31a2384901 | 2023-01-02 20:07:30 +00:00 |  | 
			
				
					| 
							
							
								 stephan | a347927d60 | An alternative solution to mapping SQLITE_WASM_DEALLOC to the proper function pointer in JS, to account for a Safari-specific quirk reported in [forum:e5b20e1feb|forum post e5b20e1feb]. FossilOrigin-Name: 688c5c13d156f987b895df1d5a5b770616b0d9caec4726e03ba122eb8539e7b2 | 2023-01-01 12:22:16 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 04071524ae | Merge trunk into wasm-session-api branch. FossilOrigin-Name: 7f8f1acd82be7dc2eb2147d96299b1b443e86774dfe0b0a8d32669a0500fc9c6 | 2022-12-25 14:13:52 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 7015aa9f49 | Add missing sqlite3_context_db_handle() JS binding. Reimplement sqlite3_set_authorizer() and sqlite3_set_auxdata() JS bindings to take advantage of [7f9ace1b11a67]. Teach FuncPtrAdapter to emit a console.warn() message if it is invoked after the library is bootstrapped, the goal being to inform users that it's an internal API and should not be invoked from client-side code. FossilOrigin-Name: 8e3d4f6294037396e388ec21abb18bf0201a6bec6ff004730cc5d11b705a6d2b | 2022-12-25 14:04:06 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 4099b3cab3 | Replace JS-side use of SQLITE_TRANSIENT with the new SQLITE_WASM_DEALLOC, reducing the amount allocation/copying required by sqlite3_bind_blob/text() and sqlite3_result_blob/text(). Remove the 'experimental' log message from the virtual table tests. FossilOrigin-Name: ffe2999a91a7dec129a38afb675fe9e539d7c347886bfea85cba55f6367d54d1 | 2022-12-24 15:28:45 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 77eac0507c | Merge trunk into wasm-session-api branch. FossilOrigin-Name: f1decc831fe0dc8523956e74474d9663852b0e5b56240dd8504952726e713a97 | 2022-12-23 19:33:22 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 7298c2e099 | Add SQLITE_ENABLE_MATH_FUNCTIONS to the list of feature flags in sqlite3-wasm.c. FossilOrigin-Name: 58503cd148c9613abfaf7c1386c34806150bd521966864ccbb821ea7dede8e5a | 2022-12-23 18:25:48 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 0f29f17bf6 | Add sqlite3.capi JS bindings for the sqlite3session_...(), sqlite3changeset_...() and sqlite3changegroup_...() APIs, noting that they are completely untested. Aside from missing tests, these bindings reveal a slight string-argument-type shortcoming in the callback function pointer "reverse binding" which should ideally be resolved before publishing them. FossilOrigin-Name: 0a39172ee134816f5ce17a403b960e9c22bb56efd5bcf77ecde465efe0d88b1d | 2022-12-23 14:11:54 +00:00 |  | 
			
				
					| 
							
							
								 stephan | cc1cc9d7b7 | Initial pieces for binding the session API to JS. Far from complete. See [forum:210e36a1e3 | forum post 210e36a1e3] for the discussion. FossilOrigin-Name: cd8c100808da1043fcf63555f48f30c90272c48c6627321ceb0a0995b34733d1 | 2022-12-23 11:46:26 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e9f740e484 | Expose a JS-friendly subset of sqlite3_config() to JS, with the notable caveats that (1) setting up the JS bindings requires starting the library, making sqlite3_config() illegal to call and (2) calling sqlite3_shutdown() in order to make it legal to call sqlite3_config() may undo certain JS-side library initialization. Move sqlite3_(de)serialize() into the int64-mode-only bindings because of their int64 args. FossilOrigin-Name: 62e0c931ac952219f68e22d64e20836781bf330b4581e4662266172a97c9289b | 2022-12-16 13:04:21 +00:00 |  | 
			
				
					| 
							
							
								 stephan | d83ab0cf85 | Add sqlite3_set_authorizer() support and related tests to JS. FossilOrigin-Name: 551b848894c249cb3c9d237643d2ed53ffcb3b003d0cf3f797a535df1731ce39 | 2022-12-16 11:13:32 +00:00 |  | 
			
				
					| 
							
							
								 stephan | a51e044a5b | Added a couple missing 'not part of the public API' tags on functions in sqlite3-wasm.c. No code changes. FossilOrigin-Name: eb27feecea508f3491a09699f2339951facd2345d479cfd3020183dc2af703b2 | 2022-12-15 18:50:30 +00:00 |  | 
			
				
					| 
							
							
								 stephan | fda3c30b7d | Expose sqlite3_txn_state() to wasm. FossilOrigin-Name: f6f3397a4667b15a96bdf4189c54789d622fd90351405e963d7f56ac93a9344c | 2022-12-12 07:31:37 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 9bda4c53c1 | Expose a number of infrequently-used sqlite3_...() functions to wasm whose absences were noticed while documenting. FossilOrigin-Name: 3144e7c0b8633d99daa07d75dabfe6e115ad401110f6f3c85f768e973299f3d9 | 2022-12-12 07:27:22 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3ec44736b5 | Remove some unused sqlite3_status() codes from the JS API. Add custom JS wrappers for sqlite3_create_collation/_v2() which accept JS functions (plus tests). Expand the argument options for sqlite3_wasm_db_error() to enable it to translate exception objects to C-level errors. FossilOrigin-Name: 073a2f1eb006230ae0995a5ea6c789407bcaa819ec15b5064c66d8973ed4671a | 2022-12-09 12:12:49 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 464c80d4c2 | Export sqlite3_status() and sqlite3_stmt_status() to wasm. Expand the arg/return semantics of wasm.get/setPtrValue() and get/setMemValue() to simplify handling of multiple pointers. FossilOrigin-Name: e144fd5c88fa4151429a2fef3daf389588402e158267f0afa0dfd142527d76b9 | 2022-12-09 05:47:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6ca03e14e9 | Expose sqlite3_db_status() and sqlite3_db_config() to wasm, noting that the latter requires several internal wrappers to account for the various varidic forms (C varargs cannot be bound to wasm). FossilOrigin-Name: d5753668915c1db204fa80153614653243081ffaddea22f26ad59bb1836948b9 | 2022-12-09 01:49:17 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 16bf97b507 | More work on the JS vtable tests. FossilOrigin-Name: 51e3c3b569dce2097063d39dc484f44b2f98cad0a902ef66765ca4cdc3e06f47 | 2022-12-08 10:06:07 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 08fc64ea04 | More work on the JS side of the virtual table APIs. FossilOrigin-Name: cb9881ec001b0e2faf047e57acfd1722d2b546255a54e0f850f568edfe2df1cd | 2022-12-05 07:51:25 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e177447972 | Initial infrastructure for adding virtual table/table-valued function support to WASM. FossilOrigin-Name: c202d7a0398b9aabc2babba5c4c91a313f32bbf37549d419775642bb4aa3936a | 2022-12-05 05:30:03 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 09c27a59db | Rename wasm.xWrap.resultAdapter() X:free entries to X:dealloc for consistency with wasm.dealloc(). Add an undocumented feature to replace wasm.alloc/dealloc/realloc() with the C-standard allocators (after an allocator misuse led down a several-hour rabbit hole trying to discover a mis-free() violation). Related test updates. FossilOrigin-Name: d9807656f8a7c2a893d3f68ee5592f44826b8e999ae66f7d9000674b5c1b0207 | 2022-12-03 13:10:58 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 85ef4e4344 | JavaScript: add sqlite3.wasm.realloc(), sqlite3.capi.SQLITE_MAX_ALLOCATION_SIZE, and related tests. FossilOrigin-Name: eeb84ba5de1152ef0f42105b8b285fdee9f5ad58281e60a4e0c8b1d6de1dead8 | 2022-12-03 11:16:55 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 1078ee0959 | Correct the problem which triggered the rollback in [7eec635562f6]: an incorrect default db page size (not a multiple of 512 bytes). FossilOrigin-Name: e06e490c240aa56b616e6f0380b5d08abf06f35f9e683e5150c5ac464eae9e55 | 2022-12-02 08:51:22 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 20f0128acc | Roll back the SQLITE_DEFAULT_PAGE_SIZE part of [c260895faacb34] because kvvfs does not work at all with a page size of 8kb. FossilOrigin-Name: 7eec635562f65592121d7ff0a31a7b4ff6cdfe38e657f326302ef851b3b37c3f | 2022-12-02 08:38:04 +00:00 |  | 
			
				
					| 
							
							
								 stephan | f3409db2d1 | sqlite3-wasm.c: code legibility and coding style tweaks. Increase SQLITE_DEFAULT_PAGE_SIZE from 4k to 8k, as that improves OPFS speedtest1 performance by roughly 12%. FossilOrigin-Name: c260895faacb3458c557778630756d02a8520c0f1864bddcf86cdd27ef4a42bd | 2022-12-02 08:29:03 +00:00 |  | 
			
				
					| 
							
							
								 stephan | cc70dfe679 | Expand JS tests for db export/import and document reason it cannot currently work with kvvfs. Fix a minor JS build dependencies bug. Update page title with PASS/FAIL prefix for tester1.js to improve overview when launching multiple test tabs. Add ability of tester1 should-run-test predicates to report why a given test is disabled. FossilOrigin-Name: 75f610d3a4cf3d972220f9abc27cdf5990451e3835ceb9cf66973934004dfc5c | 2022-12-02 07:14:56 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 875db41afc | Add optional zSchema argument to sqlite3_js_db_export(). FossilOrigin-Name: 9c23644b1e5bf44bfb431a35fd1674c11ccb99e9eb0989f10175b0cb2a858eaa | 2022-11-23 21:03:22 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 8d7b41302f | Remove some outdated code comments. No code changes. FossilOrigin-Name: 80ff592a9d0157bfa8bd1f9959c3aa26cab0ec16fdccf7b58a7523b8912c1a8c | 2022-11-13 19:29:51 +00:00 |  | 
			
				
					| 
							
							
								 stephan | c75445087f | Correct sqlite3-wasm.c's SQLITE_DEFAULT_CACHE_SIZE (it's measured in kb, not bytes). FossilOrigin-Name: 479ad980dfe509403e184e39a5aa441171e47b3297e05039f85516e72e9f15be | 2022-11-04 09:02:21 +00:00 |  | 
			
				
					| 
							
							
								 stephan | de6186e04f | Minor build cleanups and fix a harmless race condition in the OPFS part of tester1.js. FossilOrigin-Name: 70ee6ee014bc4e2c1daa9b4a8909cf76ccecf32de1eb39055f20d3d0b1daa1bd | 2022-11-02 14:08:59 +00:00 |  | 
			
				
					| 
							
							
								 stephan | f45c33701d | Add sqlite3_wasm_vfs_create_file() to replace Emscripten's FS.createDataFile() in a (mostly) VFS-agnostic way. Add a test for worker1's export (to bytearray) support. Re-add worker1 open-from-bytearray using sqlite3_wasm_vfs_create_file() but it's untested (requires a new interactive test app or maybe reconsideration). FossilOrigin-Name: b35e1225c91a3cadc0d25af1e4e790237256d194990faa13190e343ed03e11c5 | 2022-11-02 11:53:31 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 1fc6ffccc5 | Minor WASM build cleanups. Enable custom Module.instantiateWasm() when not in WASMFS mode (where it doesn't work). Add sqlite3.debugModule URL param to enable some module-init-time debugging output. FossilOrigin-Name: 50f678846a2b3c3d0818f0bae89f2ee86252a2e6a9c7029ebaae3953ca0fa14c | 2022-10-30 09:47:33 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3725af73b9 | Add SQLITE_DQS to the compileoptions_used list, per request in [forum post 8b1060122b|forum:8b1060122b]. Force DQS=0 in sqlite3-wasm.c. FossilOrigin-Name: fcd9e0dbe3226f3f7ccc15b11fc3aa3b8058571bef274c25a33e9753e22f7551 | 2022-10-21 17:48:49 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 96b6371d70 | Add more JS tests. Flesh out the aggregate UDF tests to use sqlite3_aggregate_context() so that they can each be used multiple times in the same statement. Add sqlite3_js_aggregate_context() convenience helper. FossilOrigin-Name: 9d034ef5e1bab7c9651c2450dc85765fa6365d3f1414c711550de858ff8b3ece | 2022-10-20 21:28:31 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 842c5ee849 | Rework sqlite3_wasm_vfs_unlink(), add sqlite3_wasm_db_vfs(), update some docs. FossilOrigin-Name: cdd46858f0e63bc7bfce8e339b3db9efdec43b6443ee76563a847f53d0176831 | 2022-10-20 05:14:37 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 71de8e0241 | Considerable wasm/js build cleanups and reworking. Remove wasmfs builds from the end-user deliverables and disable the wasmfs build by default, per /chat discussion, as it doubles our deliverable count for only marginal gain. Attempt to move the sqlite3.js/wasm files into subdirectories but rediscovered that that breaks loading in Worker mode because URI resolution of the wasm files differs depending on whether the main script is loaded from a script tag or a Worker. FossilOrigin-Name: 5b23e0675efdd2f1ea7b4f5836a579e8d6aa8a25b3f1a6a950520ad845ff01bb | 2022-10-19 01:07:30 +00:00 |  | 
			
				
					| 
							
							
								 stephan | d92c652ac1 | Move the rest of testing1.js into tester1.js and eliminate the dependency on jaccwabyt_test.c. Extend the list of default config-related #defines in sqlite3-wasm.c and reorganize them for maintainability. FossilOrigin-Name: 4e2a8aff2dd4b6e148f45184e2523ebe47815257eca97fa3d32bcbf9625f0def | 2022-10-13 16:48:35 +00:00 |  | 
			
				
					| 
							
							
								 stephan | b75971e6e9 | Minor doc cleanups and corrections in sqlite3-wasm.c FossilOrigin-Name: 5144c122a921e4240901cf4eb46347b92213273eec7cf0977952ab2b60722c27 | 2022-10-12 15:40:16 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 4fbf90ee11 | Refactor kvvfs JS bits to make use of [ea370b9b05f7ed7eaa]. At main-thread startup, if kvvfs is available, replace the kvvfs I/O methods with JS impls. Checkin part 2 of 2, to account for cherrypicking [ea370b9b05f7ed7eaa] into the kv-vfs branch. FossilOrigin-Name: a9047e020a097b2259bc9935b63ca1c538a3a7f1d050e15f0d0a08cfb84acc7c | 2022-10-09 13:26:15 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 2b776ee2d6 | Minor cleanups and additions in sqlite3.capi.wasm.pstack. FossilOrigin-Name: 97bd670d3859bd3f2e62c15065b238b85ef614f26479e56a14be42c5784aedf4 | 2022-10-04 01:11:10 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 88838f6b95 | Set default page cache size to 16mb in wasm builds. Fix an off-by-one counter in sqlite3_wasm_enum_json(). Minor coding style conformance tweaks. FossilOrigin-Name: 72a9e589cc318ec50941739e2edf2c0636284b316c3bf87b71fd363b37619da3 | 2022-10-03 23:13:05 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 4b074692f4 | Omit WAL mode from the wasm build. FossilOrigin-Name: 88efe2a62b81e5ee9119f54204e397fda59666a327158c7b7c972e84a716869e | 2022-10-03 18:05:27 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 4f5bbedb3a | Export sqlite3_trace_v2() to wasm and use it to ensure that the new per-VFS post-open SQL support in the DB ctor works. Default opfs vfs to journal_mode=truncate, as it's faster in that mode. Add 't' DB open-mode flag to enable SQL tracing to console.log(). FossilOrigin-Name: 508f7f6d63e52f61fae5abe817579a4e130fa7fbd18733d741d521a5bdabb7ce | 2022-10-03 13:03:41 +00:00 |  | 
			
				
					| 
							
							
								 stephan | bdfd7ea03a | Partial revert of [a82e6faaa642] to remove the 'I' alias for 'j' wasm function signature letter. In hindsight, that change seems premature. FossilOrigin-Name: dcd46af9141f4edf816010923941a76d0edd3f18cfe429c52f599ad2a0d52651 | 2022-10-03 08:30:22 +00:00 |  | 
			
				
					| 
							
							
								 stephan | ef9cd12ec4 | Minor JS API tweaks prompted by documenting them. FossilOrigin-Name: a82e6faaa642b09d241232c4daa67134d4dfa24bf3ca3725740346ca5269b381 | 2022-10-03 08:21:06 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 63e9ec2f9c | More fleshing out of sqlite3.capi.wasm.pstack. FossilOrigin-Name: eb5726677a727a958df11f1fba078d30c7c0ba2a9bdb158e8641b35b5f971af3 | 2022-10-02 03:11:13 +00:00 |  | 
			
				
					| 
							
							
								 stephan | f446af57b5 | Pedantic constness tweak. FossilOrigin-Name: c8a173cf16d2567bf9b13f52904077a2e7209776c76613c7bff59cd66e24bf11 | 2022-10-01 18:55:10 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3afad4d432 | wasm: correct a memleak caused by a shadowed var in the previous checkin. Add a stack-like allocator, sqlite3.capi.wasm.pstack, as a faster way of managing short-lived pointers (like the one which got shadowed). FossilOrigin-Name: 1fa019c88deac6b6e5155b620bdab1d7145846290daafb9adbefcf4f0fe542cf | 2022-10-01 18:47:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 32781427d7 | Fiddle: fix makefile dependency issue and duplicate inclusion of post-js.js. Reimplement db export using sqlite3_serialize(). FossilOrigin-Name: 29db7de79232c21d19b91bb0fc253114e02e21dd9bf90619453dbe72a4c8bf7f | 2022-10-01 16:01:41 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 53d4e01d06 | wasm: expose sqlite3_de/serialize(), sqlite3_malloc/free() and friends, noting that the former explicitly lies on use of the latter for memory management so is not generically safe for use in wasm. FossilOrigin-Name: fbc0edb5d31aa0dea92460e853f15f08c642451a7878994116b530cf172325cc | 2022-09-30 10:55:28 +00:00 |  |