| 
							
							
								 stephan | d6403a2d2e | Initial experimentation with a -sMEMORY64=1 wasm build (full 64-bit). This compiles but does not pass tests due to friction between BigInt and Number types (e.g. Number(null)===0 but BigInt(null) throws, many functions are fussy about which of those types they'll take, and we cannot simply mix and match the two types transparently (1n+1 is not legal (but 1n>=1 is), so we can no longer do pointer arithmatic without hoop-jumping)). The library bootstraps but it's failing early on in tests due to this friction. FossilOrigin-Name: cfd5c746a6111f49c9c83a56c3ef65223456306f2de6e20b36b1ca0c98b593e9 | 2025-09-19 23:21:00 +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 | c35f07ec2f | Diverse internal cleanups in the JS/WASM pieces. A potential fix for a hypothetical db-close-time resource leak of a subset of automated JS-to-WASM function conversions in Safari. That browser exposes WASM-exported functions via nullary wrappers, which causes a handful of them to misbehave (not clean up) at sqlite3_close_v2()-time. FossilOrigin-Name: fabbc8b6d184d52a513e80fabd900f578424fc8a8055e3d64fac54b9e28ea18a | 2025-09-15 14:11:55 +00:00 |  | 
			
				
					| 
							
							
								 stephan | c066f2af9c | Do not export the numerous Emscripten HEAPxy symbols and remove the last remaining JS code which references them. They have long-since been replaced by internal equivalents and a specific feature check on one of them (which is also no longer needed) is triggering an exception from Emscripten. More details are in [https://github.com/emscripten-core/emscripten/issues/24656 | Emscripten ticket #24656], noting that this is not an Emscripten bug but an Emscripten behavior change brought it to light. FossilOrigin-Name: b9462dc1461c830466f4e1de4a4d3bf249e3f81aea363f13462ea915769878d9 | 2025-07-11 10:27:06 +00:00 |  | 
			
				
					| 
							
							
								 drh | 8a6f89c845 | Remove unnecessary "www." prefixes on domain names in URLs. FossilOrigin-Name: 20acd630b91609725794ce84f9eda01d5f3c898407f0948264830851d25ccaa6 | 2025-04-10 10:18:07 +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 | 00bc96c05c | wasm: when building in -O0 mode (typical dev mode), use -sASSERTIONS=2, else -sASSERTIONS=0, in response [ 7e3e35cbff|Emscripten checkin 7e3e35cbff9], which adds assertions to check for the condition reported in [https://github.com/emscripten-core/emscripten/issues/23420|Emscripten ticket 23420]. Update some unrelated JS-side internal docs.FossilOrigin-Name: 1f554610ba5d9d474ec4570bb7ca09125fd2cdfb4976530a4227cc6ebdf3a962 | 2025-02-09 03:24:00 +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 |  | 
			
				
					| 
							
							
								 stephan | 3202b11f66 | Replace use of Emscripten's Module.postRun() with a custom callback so that we get consistent library init timing with both Emscripten 3.1.x and 4.0.x. Details and discussion are in [https://github.com/emscripten-core/emscripten/issues/23420|Emscripten ticket #23420]. FossilOrigin-Name: 4863a70ac61ff6f868429f16f0141484ea98f973fde1a9aff879252d0f1dbb6b | 2025-01-16 09:27:40 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 8bd5ff4f32 | Doc typo fix. No code changes. FossilOrigin-Name: 8d558ad25bfbdea04de87616d4e3f664b5749a7d23643d1a0238e991b4bb337e | 2024-07-22 21:46:55 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 79dac84b31 | JS error message and doc typos reported in the forum. No code changes. FossilOrigin-Name: 1a073f9acfb691eebf4a8cc78a72ff47ebbb6aba4acede6755fa3faefae48f2b | 2024-05-18 15:21:45 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 642e950e63 | Minor touchups in JS docs and exception messages. FossilOrigin-Name: 9e7fc9370dfca121244f7a2941e8de629b277f1799f8de08a43ff1d86f94b6f5 | 2024-04-23 06:36:28 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 2775f10ebc | Document why the wasm build does not use Emscripten's -sSTRICT=1 flag and account for a behaviour change in emsdk 3.1.55 regarding the HEAPxyz symbols. FossilOrigin-Name: f6e887203365b30cea6e9c145366345e48256a347388577edf2bada65e0655b7 | 2024-03-04 09:56:47 +00:00 |  | 
			
				
					| 
							
							
								 stephan | bae55a7685 | When warning about multiple invocations of JS's sqlite3ApiBootstrap(), use the warning logger installed by the first invocation, rather than console.warn. FossilOrigin-Name: d162af2d9941cd8c53e3928efb42aaaf4e59454f7d39aebf980a30b1427ea75b | 2024-03-04 09:23:52 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e6af60c14f | After wasm bootstrapping has read the optional global-scope config objects, delete those objects because any further changes would not have any useful effect. Expand the docs regarding the sqlite3ApiBootstrap() config object and explain the necessary evil of a separate global-scope object for that configuration. FossilOrigin-Name: e6b14f73136aae4c1a92d6d6ab8c5d1510db5244d0b0f168eed5b4b257c99064 | 2024-03-04 06:54:41 +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 | 24c32c2e39 | Add a JS implementation of Java's SQLTester. FossilOrigin-Name: b530792a514d95c4e8f93cf2170d9fc4de367055fa1704fc171551c946024fa9 | 2023-08-30 13:07:35 +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 | 69a55ca17d | Get the JS SQLTester command handlers in place sans those which have to run SQL. FossilOrigin-Name: d21b1217964a53f33b7ba3958b34aa8560dff8ede33e66f54aa0afbab7099ec3 | 2023-08-29 15:39:57 +00:00 |  | 
			
				
					| 
							
							
								 stephan | ccbfe97cd5 | Extend the importDb() method of both OPFS VFSes to (A) support reading in an async streaming fashion via a callback and (B) automatically disable WAL mode in the imported db. FossilOrigin-Name: 9b1398c96a4fd0b59e65faa8d5c98de4129f0f0357732f12cb2f5c53a08acdc2 | 2023-08-18 14:16:26 +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 | e98fa205f8 | Fix a discrepancy between sqlite3_values_to_js() and its API docs/intended behavior. FossilOrigin-Name: 7b85c68fe252c0aa69724c82a95a4432e33ebdfb879b4b1b2ee2f9b98e9b792a | 2023-08-03 16:22:59 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3068d6622e | Internal cleanups in the async part of the JS library bootstrap phase. FossilOrigin-Name: b6d57ab63793241a500ea527c5b3216c54b3ff1972d3adbbf42a9a53bfec0aa1 | 2023-07-21 09:10:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 35325a37ce | Minor internal cleanups in JS code. FossilOrigin-Name: 21a2ca9fc46bf746874579897872e2a45cb07f278abb670dd22b122f7d6a9a6c | 2023-07-20 23:25:32 +00:00 |  | 
			
				
					| 
							
							
								 stephan | b0dd9d427f | Further refactoring of opfs-sahpool and start integrating it into tester1.c-pp.js. FossilOrigin-Name: 91c789234963b660ae900f0738906b28a477993709e286d8125b2f4d6101601c | 2023-07-18 18:52:41 +00:00 |  | 
			
				
					| 
							
							
								 stephan | da6a42a921 | Move SAH pool configuration options from the library-level config to a config passed to the VFS install routine. Extend and document the PoolUtil object. FossilOrigin-Name: d2ed99556fa1f40994c1c6bd90d1d5733bebc824b1ebfabe978fae9e18948437 | 2023-07-16 16:52:09 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 88af76f62d | opfs-sahpool VFS now seems to work, in that it runs fine (and blazingly fast) in speedtest1. Add sqlite3.config options for the high-level configurable parts of opfs-sahpool. FossilOrigin-Name: 5d92d5f4d8ac4cfa37ba473e5cc861628b783bbf1ae4d138bcae8b9d6cc6e798 | 2023-07-15 11:23:57 +00:00 |  | 
			
				
					| 
							
							
								 stephan | d655290c99 | Minor cleanups related to reintroducing wasmfs support. FossilOrigin-Name: 6918a927b5ecd1df5916b70d52d8d5ce289869c3f323e577b7dfc7c939084400 | 2023-07-13 18:13:52 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 01bdff7a1c | Get wasmfs build and its bare-bones test app working again, albeit currently in ES6 mode only. FossilOrigin-Name: 647761ed422f196f94facc88bbddd7219a2c1a6301a5f847b0a32d3e405233a7 | 2023-07-13 04:26:13 +00:00 |  | 
			
				
					| 
							
							
								 stephan | b3b64179df | Internal JS doc fix. FossilOrigin-Name: 7c5ea02205a360a11fa9043be12c678eb7fe6f6a0b63b09a3dc976beae881e3f | 2023-07-12 09:30:13 +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 | 2255d89f0a | Internal cleanups in JS code. No functional changes. FossilOrigin-Name: 8fbdf7d10400c4f54fc3d8bc823f97818de860deeeed35ab6ad717260cd301e0 | 2023-03-22 19:57:19 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 4214cc32ba | Replace use of 'self' in JS code with 'globalThis', as that works in browsers and node environments. Avoid using globalThis.location if it's not set (e.g. in node). Based on feedback in [forum:ac7a94d4f77db235|forum post ac7a94d4f77db235]. Minor JS build tweaks. FossilOrigin-Name: dbbe8f25e58738c10b6192d41f1e3886983871f17631cbc45ce626d3f05a6e26 | 2023-03-07 19:12:06 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3ff812aa94 | Add capability to override the JS's use of console.log/debug/warn/error() with client-provided versions via the bootstrap-time config object. FossilOrigin-Name: c54f29d8e55419eaa9168e799dab5030e89063b13d8390a50616606422d164dc | 2023-02-06 14:01:19 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 0bcded30e5 | Minor API doc cleanups and JS code simplification. FossilOrigin-Name: f608a3a45609693c1c0237f12c394275ec9a6225fa986e62345f21af763293a0 | 2023-01-21 16:53:01 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 010ffff8d7 | Add sqlite3changeset_new/old_js(), which work like sqlite3_preupdate_new/old_js() but on changesets. FossilOrigin-Name: e8afad630b085a9208491e0516a6a30c9cda77a20b1aa2cba49b2f44eb9fa2f8 | 2022-12-27 22:46:49 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 294968e030 | Expose sqlite3_preupdate_hook() and friends to the JS API. FossilOrigin-Name: cc02783a1210a083683320fae1ec1519e45b8e3003a9e32809d808513a2ce06b | 2022-12-27 14:34:32 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 64fa85bb5e | Document sqlite3.capi.sqlite3_prepare_v3() as accepting an ArrayBuffer and ensure that it can. FossilOrigin-Name: ae3ae92ec45d3d5de92e70876502f8108fc3fcd87848e86c2b83f8842f1ff139 | 2022-12-26 15:08:48 +00:00 |  | 
			
				
					| 
							
							
								 stephan | d9cfd0f339 | Correct some internal-use JS docs and update the 'string:flexible' type conversion to accept an ArrayBuffer (as it was recently documented to). FossilOrigin-Name: eff5d3bec29043cc1182bbb5229040dac5ff50264d025e354736bb63b4bc97a0 | 2022-12-26 14:55:00 +00:00 |  | 
			
				
					| 
							
							
								 stephan | ec35e92d1d | Rename the new wasm.irSizeof() to sizeofIR() because that seems clearer. FossilOrigin-Name: 49a83ca3ba46d3ae8021fbdd72b48ce9181eea6845fa7bb7aa83b16fad1728be | 2022-12-25 22:55:45 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3caf13f1cb | Merge wasm-session-api branch into trunk, adding the session API to the JS/WASM components. FossilOrigin-Name: dfb8b651fa4faef2d3307a05512cdc479398484c3a59715827179c363861a777 | 2022-12-25 20:25:44 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 7d59d90a5b | Add sqlite3.wasm.irSizeof() and extend certain allocation functions to make use of it. FossilOrigin-Name: 1cbc7b1875e8611b9db7a747b4c9499501450deaf90c929d212511837d6f72b6 | 2022-12-25 20:05:11 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 73bf9d5fed | Replace the "manual" implementation of sqlite3.capi.sqlite3_exec() with a briefer "automated" one via the [7f9ace1b11a67] feature addition. Minor code-adjacent internal cleanups. FossilOrigin-Name: 4888957baf18c6763f959fbba998a74156ff656368779107f502b926e9e9d949 | 2022-12-25 17:09:34 +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 | 75c04ba89c | Simplify the signature for JS functions, as opposed to function pointers, passed to sqlite3_exec(), eliminating the superfluous initial two arguments. Update related tests to demonstrate both function-passing approaches. FossilOrigin-Name: e7cc70cdda426863f82ebe1305f4c3053824c5a605b1516b0b7f205f1203178b | 2022-12-25 10:22:27 +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 | 027afccdcd | Reimplement JS's sqlite3_bind_text/blob() with hand-written bindings to permit more flexible inputs. Add automated JS-to-C function conversion to sqlite3_busy_handler(). sqlite3.wasm.xWrap()'s '*' argument conversion no longer treats JS strings as C-strings: those conversions require explicit opt-in via the 'string' converter (or equivalent). FossilOrigin-Name: 96ba44946b3e88b6aa305c4363cbbfeab0d9120b3d8c4d2587d68b9293ea7cc6 | 2022-12-23 23:46:33 +00:00 |  | 
			
				
					| 
							
							
								 stephan | ab9c2d571e | Internal JS cleanups. Correct part of [ac136925a645] to account for the eTextRep flag being able to hold flags other than the encoding. FossilOrigin-Name: 1dfc03ab1e0269807beef27bf884ab9ead7553d4a5f6ed213f812d7fa052045f | 2022-12-23 21:10:49 +00:00 |  |