| 
							
							
								 stephan | d6cb2ccee6 | JS/WASM: Expose sqlite3_db_status64(), sqlite3changeset_apply_v3(), sqlite3changeset_apply_v3_strm(), and SQLITE_DBSTATUS_TEMPBUF_SPILL. FossilOrigin-Name: b13eafc9b6820517b450041a7e2be573a896b5b9e88b2b28df9f15e3cb91e23d | 2025-10-14 18:23:32 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 0df9db4921 | Make use of the new SQLITE_ENABLE_PERCENTILE in the wasm build. FossilOrigin-Name: 937c084c2d9b20fde2d54e48257cb7018bd8c36d6f00ed6f1659b5ecc2f48ed4 | 2025-10-08 18:17:19 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3e205eff8e | Add missing sqlite3_vtab::xIntegrity wasm mapping. Correct signatures for the (unused) xDlOpen and xDlError bindings. Disable OPFS-related tests in tester1.js in 64-bit builds. FossilOrigin-Name: a106be90a2dba7476e54dbb4bdf47d0999031dae0ca82d73e51a48dadd6bcdc0 | 2025-09-20 22:10:59 +00:00 |  | 
			
				
					| 
							
							
								 stephan | bd5d297fec | Get the wasm tests running in a 64-bit build up through (but not including) the oo1 bits. FossilOrigin-Name: a5af46174a05e1414370884d1a99827af9286a60eff1c8ae1551e7fad3903f7a | 2025-09-20 11:09:20 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 22f9ca64db | Get about 1/3rd of the tests running with MEMORY64=1, but the code noise level added by the BigInt/Number discrepancy is making this very unattractive. There are apparently irreconcilable differences between MEMORY64=1 and 2, in that they have different argument type expectations for methods such as WebAssembly.Table.get(), where MEMORY64=1 requires a BigInt a MEMORY64=2 requires a Number. We have no way to make that distinction from the JS code, and don't know what other APIs are affected by that quirk. FossilOrigin-Name: 1e3b003ff99d2788d93e179504b711cb78846605774bf472589440d0136f20fa | 2025-09-20 03:02:36 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 78202b9a3b | Add some comments describing the ways in which building sqlite3.wasm with -sMEMORY64=(non-zero) fails. FossilOrigin-Name: 0b14fd35ca37075bb65b2ab398f3324dc851347b1c042566eac23724013653f8 | 2025-09-19 20:10:05 +00:00 |  | 
			
				
					| 
							
							
								 stephan | d4cc844a2b | Diverse cleanups and docs in the JS and kvvfs pieces. Functional changes: (A) ensure that the 'i32' JS/WASM func arg/result conversion works properly with a 64-bit-memory WASM build (which we neither use nor test but [https://webassembly.org/news/2025-09-17-wasm-3.0/ | the newly-ratified WASM 3.0] brings within potential reach). (B) Fix sqlite3_js_posix_create_file() to not deallocate its input array if the client passes in raw memory (the library has never used it that way but the API permits it). FossilOrigin-Name: 79af65a694fbbb3d501fb2ebd835c259ca644e0dafdd71eeb9f0a7c0e9128a1e | 2025-09-19 17:24:47 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 194d6edeb6 | Wasm: (A) diverse internal doc updates. (B) when generating automated JS-to-WASM function proxies for converters which require an additional middle-man proxy, e.g. sqlite3_exec(), use the client-provided function, not the proxy function, as the cache key, to keep from re-generating the conversion in some common use patterns. FossilOrigin-Name: 5e5139c2a162562cee0071d03954ebc0b8938da0b045ec3f5eba32dc8e19604d | 2025-09-19 14:21:09 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6b8d7ac599 | Expose the new sqlite3_set_errmsg() to wasm. Refactor JS's sqlite3__wasm_db_error() to wrap that instead of the WASM-specific routine which previously did that job. This resolves the TODO added in [ead8a3a94e]. FossilOrigin-Name: e447a50f3a3791c264a68000948daa64edb1857d51d256fbd1ff0f2c2b330d5e | 2025-09-14 12:14:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | a248d84fbe | Add a TODO regarding replacing the internal sqlite3__wasm_db_error() with the new [34eda113c8819d | sqlite3_set_errmsg()], which serves the same role. FossilOrigin-Name: ead8a3a94e0f349bcdced6a62af0349b0b7b731137c8d33e2ef0e7eecd107c1f | 2025-09-12 17:36:23 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 1f436ad563 | Add SQLITE_SELFORDER1 to JS's sqlite3.capi namespace. It's only useful when built with an sqlite3.c which itself was created with -DSQLITE_ENABLE_ORDERED_SET_AGGREGATES, which the canonical build does not do but custom builds may. FossilOrigin-Name: fdd15e938ccfac9e871d781d1c8fe8be6dbd9e8cbbcb8b7f0b035e5ceebb8746 | 2025-07-18 22:18:41 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 2be0a700ff | Export the column-metadata APIs to WASM. Doing so requires a non-default build of sqlite3.c, so this is a proof-of-concept branch saved just in case SQLITE_ENABLE_COLUMN_METADATA ever becomes the default for sqlite3.c. FossilOrigin-Name: 59db3f639d1073678805dea26a4686eddfb238f055aa90bd429fc7fd33241502 | 2025-06-18 15:37:04 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 0148820fd7 | Squelch an interesting but harmless struct initialization warning emitted after an emsdk update. Fix JS breakage introduced by changes in Emscripten 4.0.7: manually export the HEAPxyz symbols which used to be exposed by default. FossilOrigin-Name: 10d0897cc9a5998fe1344cfbb242a78b59012e29aa3b1993895dfac26721b053 | 2025-05-30 10:18:09 +00:00 |  | 
			
				
					| 
							
							
								 stephan | c9cc6a5474 | Use SQLITE_EXTRA_INIT_MUTEXED instead of SQLITE_EXTRA_INIT for the SQLITE_WASM_EXTRA_INIT feature, as suggested in [forum:14183b98fc0b1dea|forum post 14183b98fc0b1dea]. This doesn't make a functional difference now - this is in the name of future-proofing against eventual threading support in wasm. FossilOrigin-Name: 46479c2e30b9676e0fa8da117ba67f673671fb340c9bea38ece19a1b2371a57b | 2025-03-01 23:44:11 +00:00 |  | 
			
				
					| 
							
							
								 stephan | da5f813878 | Approximately 100 typo corrections spanning the whole tree, submitted via [forum:0db9827f0464bc33|forum post 0db9827f0464bc33] and individually audited and verified. Affects only code comments, innocuous test strings, error message text in tool (not library) code, and configure-level help text. FossilOrigin-Name: f50c21484d3cac73589da0376c423de39ae8b842218105786c5aa3726e4dcaed | 2025-02-27 21:17:55 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 5d60f47001 | Approximately 50 typo fixes, spanning the whole tree, contributed via [forum:006c8fa165083ac3|forum post 006c8fa165083ac3] and individually checked for correctness. Affects only code comments, docs, and a single line of debug output in a test app. FossilOrigin-Name: af928818a030924060ee0762431dae0f16d53a62f4e1132754d052eb9c621ac2 | 2025-02-25 20:55:14 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 82f3052e61 | Expose the new SQLITE_DBCONFIG_ENABLE_ATTACH_CREATE/WRITE and SQLITE_DBCONFIG_ENABLE_COMMENTS (from [325e547a21955]) to JS/WASM. FossilOrigin-Name: 8da1a9af66f905c683e9c3445d609b5c0e11ac912be192c468ddd79f237837f4 | 2025-01-31 18:45:03 +00:00 |  | 
			
				
					| 
							
							
								 drh | 010f9f8704 | Remove a few more traces of long double from the code. FossilOrigin-Name: 11d6a89e4a25c3f884ff617036d239dc42522859400cd1f4674634f6c7adbb02 | 2024-10-02 11:34:11 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 1f2faa647f | Another comment about the LONGDOUBLE wasm topic. No code changes. FossilOrigin-Name: 1755831cb1ac58241e0b11d8d003b5eca39b65aa3cb84229b215662028b1b3c0 | 2024-10-01 17:57:55 +00:00 |  | 
			
				
					| 
							
							
								 stephan | c9c1b65698 | Use the new SQLITE_USE_LONG_DOUBLE to disable long-double support in WASM builds, as they cannot be represented in JS and this saves approximately 5.5kb in the resulting wasm file. FossilOrigin-Name: fa7b56f776b715d061581fad6f04b871504ff5d808e7364419d1d6cdef82c5ee | 2024-10-01 17:08:23 +00:00 |  | 
			
				
					| 
							
							
								 stephan | ed94e0e677 | Add an #if'd-out block to sqlite3-wasm.c mentioning the LONGDOUBLE_TYPE, as brought up in [forum:cbfb0d0ac0a4e349 | forum post cbfb0d0ac]. No functional changes. FossilOrigin-Name: 0b83e8f1ef53b35a9dda0740b4922b8691428f7484f3058833a961f3f8d0b178 | 2024-10-01 10:49:30 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e7840ce681 | Strip progress handlers and window functions from the wasm bare-bones (formerly 'minimal') JS bits, noting that we can't yet use OMIT_WINDOWFUNC (for the C parts) without a custom amalgamation. Currently at 604kb. FossilOrigin-Name: ec02e9237e1ef81c4196fa630822cb109eab926143ad09593a24273eb0668601 | 2024-07-25 16:21:19 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 520d1a8486 | More work on the minimal-mode wasm build (now 603kb uncompressed). Remove the hard-coded feature-enable flags from sqlite3-wasm.c and rely on the build to provide them. Some wasm build cleanup, but attempts to completely overhaul it have been thwarted by my inability to make script-generated makefile code more legible/maintainable than the current eval spaghetti. FossilOrigin-Name: b029c4067943e366a9b25b8303136fab10822bd771ea4658ac4cd716ff4a0d8f | 2024-07-25 14:00:26 +00:00 |  | 
			
				
					| 
							
							
								 stephan | b16c2980b3 | wasm minimal build: strip authorizers and JSON support (saves approx 35kb). Strip vtab support from the JS bits but cannot yet strip it from the C bits because that requires a custom-configured sqlite3.c. FossilOrigin-Name: eb64d106551718467e0f6c6b53695410bf4c566901008e4cda8580d0f7efa7b0 | 2024-07-24 23:58:28 +00:00 |  | 
			
				
					| 
							
							
								 stephan | fe225745fc | Restructuring of the wasm build to support an experimental 'minimal' build mode which elides all non-core APIs. FossilOrigin-Name: ee2191f7302210100fa0b29ace8156531ad995bf61aa2642e526e0901d0c6862 | 2024-07-24 22:07:18 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3ac612dd7d | Remove some dead WASM-side code. FossilOrigin-Name: 0a07ee27bd6021a6fc1d81133012592351530ffcf6ae09322ea74624cff910df | 2024-04-23 06:49:47 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 0a42e9913b | Extend the JS/WASM SEE build support by (A) filtering SEE-related bits out of the JS when not building with SEE and (B) accepting an optional key/textkey/hexkey option to the sqlite3.oo1.DB and subclass constructors to create/open SEE-encrypted databases with. Demonstrate SEE in the test app using the kvvfs. This obviates the changes made in [5c505ee8a7]. FossilOrigin-Name: 8fbda563d2f56f8dd3f695a5711e4356de79035f332270db45d4b33ed52fdfd2 | 2024-04-22 16:46:37 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 006a9b51aa | Add comments (only, no code) to the JS sqlite3_config() bindings reminding us why SQLITE_CONFIG_ROWID_IN_VIEW is specifically not included. JNI does not need this treatment because it explicitly supports only a very small subset of config options. FossilOrigin-Name: 4fea396221e84f9532f9327226691621a23bd966a860329fc579141c69cf7f64 | 2024-03-21 15:52:52 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6b36d0b461 | Make explicit which JS APIs are for internal use only by moving the JS-bound internal-use-only functions out of client-visible reach and renaming the WASM-exported ones from sqlite3_wasm... to sqlite3__wasm... (with two underscores). These have always been documented as internal-use-only, so this is not a breaking change except for clients which have ignored the docs. FossilOrigin-Name: 0eddc20f37988df6bce5f407b69e4a315e5cca4af104586e6fe942f0d656cccd | 2024-01-08 07:52:47 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3d4d3fb59d | Update and clean up the in-makefile docs for ext/wasm. FossilOrigin-Name: 7a7b295e6d7e95ee4a46cc42761895d11700ab295870c5a4380072bb4a5b7099 | 2024-01-02 09:03:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | fe1d8210c7 | Back out [99d11e6d0ae6] (enabling of STAT4 in WASM/JNI), per /chat discussion. FossilOrigin-Name: cd7929ee2e2c305475fa5a4dff2edaccf90067126ef04a1c2714cf464925453f | 2024-01-01 23:28:02 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 7a482b3bcd | Use SQLITE_ENABLE_STAT4 in both the WASM and JNI builds. FossilOrigin-Name: 99d11e6d0ae687ff6bac5119027f7b04d5e7185214e79cf8c56289cfa809b0f9 | 2023-12-31 04:01:36 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e982385619 | Use SQLITE_STRICT_SUBTYPE=1 by default for the JNI and WASM builds unless they're explicitly built with SQLITE_STRICT_SUBTYPE=0. FossilOrigin-Name: 990211357badf0ab08bd34cf6d25b58849d0fd8503e289c1839fc837a74e1909 | 2023-12-14 22:01:55 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 9d60c3c256 | Expose the missing SQLITE_SUBTYPE to wasm. FossilOrigin-Name: ac9534b2ceb8185b1fc03282f881cd3e4aea64af75a02ebded1e07d4d8278739 | 2023-11-10 15:00:26 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6db0b11e07 | Expose SQLITE_RESULT_SUBTYPE to wasm. FossilOrigin-Name: 6d2fe9848beb35a8206e49c2ffae29a3eb2fe6411d77f366e962ced3f83e4749 | 2023-11-09 17:53:44 +00:00 |  | 
			
				
					| 
							
							
								 stephan | a9fea28761 | Remove the SQLITE_MAX_ALLOCATION_SIZE flag (set to 536mb) from the WASM and JNI builds because it can unduly limit db exports via sqlite3_serialize(), as reported in [forum:75524f7342c1ba45|forum post 75524f7342c1ba45]. It now defaults to whatever sqlite3.c uses, which is currently just shy of 2gb. FossilOrigin-Name: f6e1137919243c5ce86725df64b40b7e12e82cbceaff210ca41616d620f0dd1b | 2023-10-28 03:54:28 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6a0f297da9 | Unconditionally force use of SQLITE_ENABLE_API_ARMOR in the WASM and JNI builds. Their corresponding test suites still work. FossilOrigin-Name: c11394b50d0687b6d6abad9c80d5cd3cdce77e9b9c278f40601c460f463744a1 | 2023-10-11 20:37:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | aa15047796 | JS SQLTestRunner can now run the Java impl's core-most sanity tests, missing only support for directives. FossilOrigin-Name: 5e798369375ce1b0c9cdf831f835d931fbd562ff7b4db09a06d1bdca2ac1b975 | 2023-08-29 20:01:01 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6043947eee | Ensure that db mutex is held when using sqlite3ErrorWithMessage() to avoid a potential assertion in debug builds. FossilOrigin-Name: b8f6a50a4bf9478324f0272d79f2fe6992a49b753e79e39a268c6afb261bb01e | 2023-08-24 14:17:30 +00:00 |  | 
			
				
					| 
							
							
								 stephan | b949244ea1 | Add sqlite3.capi.sqlite3_js_posix_create_file() and oo1.OpfsDb.importDb() as alternatives for the newly-deprecated sqlite3_js_vfs_create_file(). FossilOrigin-Name: da6eaf8d8258f3e2c8633fd7faf4e90c3307b5c60bd8b69c626b3c82b19dbdef | 2023-08-11 17:38:17 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 7e13152952 | Deprecate sqlite3_js_vfs_create_file() because, it was discovered today, its out-of-scope use of the sqlite3_vfs, sqlite3_file, and sqlite3_io_methods APIs triggers unresolvable assertions in the core when built with SQLITE_DEBUG. FossilOrigin-Name: f3647a3ac8eca8c821b0b1e403da7bfb0feabd0eb5ee83709cd4956dfc56a492 | 2023-08-11 14:31:20 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 2bf2ff605f | Change wasm build's -DSQLITE_TEMP_STORE=3 to -DSQLITE_TEMP_STORE=2, primarily so that clients can optionally shift temp files from memory to OPFS storage. FossilOrigin-Name: 764430e804332b8f7b2f63a3c0c8acf8f6cc92534858d89de2d310938c1c0d27 | 2023-07-17 07:13:44 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 043353483e | Expose the SQLITE_DBCONFIG_STMT_SCANSTATUS and SQLITE_DBCONFIG_REVERSE_SCANORDER sqlite3_db_config() options to JS. FossilOrigin-Name: 0a7024af3f0e1dddc1a60c67bc4084e46b297dc16fe753bd5e6a45a59fd1cfa4 | 2023-05-01 15:42:59 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 20537f0dc7 | Expose the new SQLITE_VTAB_USES_ALL_SCHEMAS to JS. FossilOrigin-Name: b7ef09be667dd349e195842304c03cbebb1693164e1c3587a5d7c96baa713edf | 2023-04-04 17:35:38 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 17bbbde537 | Export SQLITE_FCNTL_RESET_CACHE to JS. FossilOrigin-Name: 6195cfc86b15614b8db0e0dc5cc79b8d1acaf483f0131c8526992dc8ca075630 | 2023-03-10 11:57:23 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 99ace82634 | Export the new SQLITE_CHANGESETAPPLY_IGNORENOOP flag to JS. FossilOrigin-Name: ac7359b2633ead74a53b2796fe038ca285aacad45b45980db2a76a87154e66e3 | 2023-03-08 18:05:57 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 248c1abdf4 | Extend wasm build to support a custom sqlite3.c to support building against sqlite3-see.c. The JS code now binds the SEE-specific functions if it detects an SEE build. FossilOrigin-Name: dd8612c8adbaf9d06bf0d7319b9afc9bd8ca3d0fcfa1cb591a7a2fcb86480048 | 2023-03-08 10:05:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 9885c76c4c | Extend wasm build to enable inclusion of client-custom C code, initialized via the SQLITE_EXTRA_INIT mechanism, per discussion in [forum:1e1c04f3ed1bc96b|forum post 1e1c04f3ed1bc96b]. FossilOrigin-Name: 68a52cafff60f19c9c998133d04f192b1e8b23f78b8cee13807d76845ef5e13d | 2023-02-27 07:12:28 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 5d2a25b254 | Remove the JS-side SQLITE_WASM_DEALLOC sanity check which triggers the problem mentioned in [688c5c13d156] and [ae0196d86ee8], for reasons covered in the code comments, per discussion in [forum:e5b20e1feb|forum post e5b20e1feb]. FossilOrigin-Name: 65ff3200c6009a1649fc108d7ce36f5c014185ba46bbf98471ec86eaeb572656 | 2023-01-04 03:14:06 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e364a9da72 | Add some docs explaining a particular piece of [ae0196d86ee8]. No code changes. FossilOrigin-Name: 7f96803c1cbd0633367173ab0a67a8b301b9e0746e460c50d506b536c15db0a0 | 2023-01-02 20:52:46 +00:00 |  |