| 
							
							
								 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 |  | 
			
				
					| 
							
							
								 stephan | a4d04c59ba | Update wasmfs.make to get WASMFS building again, but changes made to OPFS-over-WASMFS since we last tested it have made it incompatible with how we used it. It can now only be used from worker threads, eliminating the one benefit it had over the sqlite3_vfs OPFS implementation. Remove/amend references to WASMFS in the docs and remove all WASMFS-specific test app links from index.html. FossilOrigin-Name: 32dc98c8001387b1970623192ec6cb89445000fa49bda5f4bd7c525bbe20bb5b | 2022-12-17 11:14:35 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 3c9749ab74 | Document the role of the sqlite3.client JS API property. FossilOrigin-Name: 5f11f1c7d5f8b627acd2ace277521d39fe2ffb0ef1dfe532e65fb56ea3dfb4d8 | 2022-12-13 10:54:12 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 124fc52d96 | Move JS-to-C binding signatures from sqlite3-api-prologue.js to sqlite3-api-glue.js to allow for use of the new/experimental sqlite3.wasm.xWrap() feature which automatically binds JS functions to WASM/C as needed, which simplifies creation of bindings which take C function pointers. Reimplement sqlite3_exec(), sqlite3_create_collation(), sqlite3_progress_handler() to use this new feature. FossilOrigin-Name: 9386d6f634680b4e0fa5487c34c63acb29f0b7a6ae738b8f6164ad084a229b62 | 2022-12-12 14:31:38 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 13e5512b28 | ext/wasm/module-symbols.html: add a hyperlink to the API docs for each exported sqlite3_...() function. FossilOrigin-Name: 01d3a9bba3120cfec3f752048281f18ce7ab48fa7584750c097233a9ce095a20 | 2022-12-12 11:22:05 +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 | 9cb6ff2792 | Expose sqlite3_column_value() to WASM and add sqlite3_column_js(). FossilOrigin-Name: 7783aa4af1331190fd1f42a71bb724041e2e82b51745f9740926e4ead83a97ed | 2022-12-10 15:13:29 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 5c99d91e53 | Refactor the internal JS routines for converting UDF results and errors to JS into public APIs. FossilOrigin-Name: 35d1d63c7d60119b64341c561294890812837d5432d1d7bed3ed88d6212fbfa0 | 2022-12-10 10:24:46 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 8ccef8f27f | Export sqlite3_result_subtype() and sqlite3_value_dup/free/subtype() to WASM. FossilOrigin-Name: 4600a7bbdc4cbe14591d48ea19fe5f7de3a0c10a14cdd97fd51e263a13163d10 | 2022-12-09 15:26:58 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 706780fbd9 | Expose sqlite3_value_frombind/nochange/numeric_type() to WASM. Add a flag to sqlite3_value_to_js() to cause it to return undefined, instead of throwing, if no conversion can be found. FossilOrigin-Name: de8fc4bf34f80f320012a0e506ed8e3e24806daf67845d5dabb00b916108f6ef | 2022-12-09 15:12:07 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 99f30f1cd4 | Refactor the sqlite3_value-to-JS conversion from an internal detail to sqlite3.capi.sqlite3_value_to_js() for use with routines like sqlite3_module::xFilter(). FossilOrigin-Name: f6dbf280f99809a80c99337e4c22a86dea7a35ae41ae9a69144c4502385a0a1f | 2022-12-09 14:46:24 +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 | 81a3683174 | Rename the oft-used, verbose sqlite3.wasm.get/setMemValue() and get/setPtrValue() to peek/poke() and peek/pokePtr(). The old names are retained as aliases just in case any client code actually uses them, but they are now deprecated. FossilOrigin-Name: ad0a8139b0b025f8e9d2eca0c303557ef10fdfab8c8b65afb08c510a804073d5 | 2022-12-09 09:23:27 +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 | 735dd03377 | Expose sqlite3_table_column_metadata() to wasm. FossilOrigin-Name: c31eb509e5cb1025de058132ee9a45d70c84ee47a6abe18811a65ce339f062a0 | 2022-12-09 02:12:43 +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 | 1eb1b59b89 | Work on an alternate (slightly simpler) approach to binding JS vtabs. Non-eponymous vtabs are not working, for reasons as yet unknown. FossilOrigin-Name: 6a0fefb93bcccd950df211cf5c2f49660c7b92115dd01b2b508a4ab9e3ab3d23 | 2022-12-07 07:22:34 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 75435f8b2d | Rename wasm.cstringToJs() to wasm.cstrToJs() for consistency with other wasm.cstr... APIs. FossilOrigin-Name: cbf483ea0ba3e6dc08ad7ed654380f818544b4c3cedfdb8aa848a83298268ceb | 2022-12-06 08:46:39 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6b271abc98 | Add a demonstration sqlite3_vtab/module implemented in JS, based on ext/misc/templatevtab.c. Add oo1.selectArrays() and selectObjects(). FossilOrigin-Name: 60482c97e02bc4cafefef281be0cf0bc8c5c53232162829c137f3f7a80cdc534 | 2022-12-06 06:09:03 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e1d25177c2 | Expose sqlite3_get/set_auxdata() to wasm. Minor test app CSS tweaks. FossilOrigin-Name: 44659ad32a9fe6363badfc5dbb0bd51d6fb2ee1c8aa47b71e9cf3dbd631fde9e | 2022-12-05 14:13:55 +00:00 |  | 
			
				
					| 
							
							
								 stephan | e0818715b7 | Export collation-related APIs and strncmp()/strnicmp() to wasm. FossilOrigin-Name: c3c56d9b944fd0d806d8dad9f0c7be3d7a5441765310908872cc525d82ab6a33 | 2022-12-05 13:33:42 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 9a49a97487 | Export sqlite3_vtab_collation() to wasm. Rename 'flexible-string' JS argument adapter to 'string:flexible' for consistency. FossilOrigin-Name: 15f8042fddaeabab43dd187c463d3ccc56758cbf19bf2ca4837d9087a4850c1a | 2022-12-05 13:12:48 +00:00 |  | 
			
				
					| 
							
							
								 stephan | cf8f0d2046 | Rename 'static-string' argument adapter to 'string:static'. Replace JS unit tests which were lost via editing a generated copy of tester1.js instead of the original tester1.c-pp.js input file. FossilOrigin-Name: 9d81d51d5a255b42f8416da850c992a9e4c8eebc940e0702a9262cfcaa6d7b2f | 2022-12-05 11:54:13 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 0adef09374 | Export sqlite3_bind/value/result_pointer() to wasm. Add 'static-string' argument converter to support the lifetime requirements of bind/result_pointer()'s string argument. Correct an endless loop in wasm.cstrlen() when passed a non-C-string argument. FossilOrigin-Name: a94552434a657376d5ce1831de05c1b15fb153020848cd825fb0df413c3baa70 | 2022-12-05 11:30:39 +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 | a81c5b3a88 | Export sqlite3_result_zeroblob/zeroblob64() to wasm. FossilOrigin-Name: a60e56627fc0ef8831429941d429ee02c6ee51ce5a2c1af581dc5bc5a00d911e | 2022-12-04 08:16:33 +00:00 |  | 
			
				
					| 
							
							
								 stephan | cbcc08ddc4 | sqlite3.wasm.allocFromTypedArray() now optionally accepts an ArrayBuffer as its argument. FossilOrigin-Name: 75a1a796f86d289c7275666fab19013934775dcccaed44a1a61d1749a6cb99c9 | 2022-12-03 14:58:45 +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 | 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 | 919dbc846a | sqlite3_js_create_file() now accepts an ArrayBuffer data source. Add test for OPFS-based export/re-import. The (sqlite3*) argument converter now optionally accepts sqlite3.oo1.DB instances. FossilOrigin-Name: 14a84b67fb17e16a5691ea4bf7f374123ac73a361a5d3d0efca53788d2001e3a | 2022-12-01 15:22:03 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 9ec1a7a7a0 | Reformulate and simplify some JS tests related to the previous checkin. FossilOrigin-Name: 9ea2d3dcf798393a7fd231e199c0e2c6302949fe2a7f2573178fb0e50c78a2f4 | 2022-12-01 04:45:51 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 2b2199570d | Expand "sqlite3_vfs*" JS-to-WASM function argument conversions to accept VFS names (JS strings) and capi.sqlite3_vfs instances. Implement sqlite3_js_vfs_create_file() to facilitate creation of file-upload features which store the file in VFS-specific storage (where possible, e.g. "unix" and "opfs" VFSes). Correct an argument type check in the SQLite3Error and WasmAllocError constructors. FossilOrigin-Name: e1009b16d351b23676ad7bffab0c91b373a92132eb855c9af61991b50cd237ed | 2022-12-01 03:55:28 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 8ae9545577 | Install sqlite3_malloc/sqlite3_free() as the JS-side WASM allocator (as opposed to replacing C-level's malloc()/free() with them). All tests work and this eliminates the potential for allocator discrepancies when using the (de)serialize APIs. FossilOrigin-Name: 95c78f6b46e0d8efa4313061f47677479f48610b7a7261dc8d0fb1859aca2ad9 | 2022-11-30 11:50:16 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 36a0163e40 | Rename some OPFS JS files. Prevent JS bindings of sqlite3_uri_...() from performing JS-to-C-string argument conversion on their first argument, as doing so is specifically illegal. FossilOrigin-Name: 79832808de2cbdba140ed9e0558f1502b51d131ab4315265315922cda7b748cb | 2022-11-30 07:17:29 +00:00 |  | 
			
				
					| 
							
							
								 stephan | ad4f782815 | Refactor a significant chunk of the OPFS sqlite3_vfs init code into sqlite3.VfsHelper, and internal-use-only API encapsulating code relevant to creating new VFSes in JS. Intended to assist in pending experimentation with an alternative OPFS VFS. FossilOrigin-Name: e25d7b080a807e35b32cb885ea75b384130e5c6e936dfef783c5b45d9bfe77d8 | 2022-11-30 05:27:36 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 6b86b33793 | JS documentation cleanups. No code changes. FossilOrigin-Name: 18e89a436daa18a8c972caf06b298da43c97a6ea3e2e5229dccb6920c27bfdb9 | 2022-11-24 16:03:49 +00:00 |  | 
			
				
					| 
							
							
								 stephan | f1ce4f40c7 | Minor JS doc updates. FossilOrigin-Name: 27efd63ad7fb3bf8d0d07f2c9f48652c8cacc4e697c229c8085120a8e6b50a39 | 2022-11-23 21:09:51 +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 | 27c4cd183d | Add test app for experimenting with multi-worker OPFS concurrency. Tweak OPFS VFS to significantly improve the otherwise "unfortunate" concurrency situation. FossilOrigin-Name: 96f76e7616f8157a342b9e1c42f7b1feab200d182268871a2b25f67d4ee2564c | 2022-11-21 03:50:52 +00:00 |  | 
			
				
					| 
							
							
								 stephan | 690d4c545d | Add sqlite3.wasm.alloc.impl() as a "public back door" into the low-level non-throwing allocator. Correct sqlite3.WasmAllocError constructor to behave like its usages expect it to and add tests for that. FossilOrigin-Name: cea8bf9a144d842c4755c3130273524926e8c4831d7f21c4e34d4e8c74109c8c | 2022-11-07 13:06:20 +00:00 |  | 
			
				
					| 
							
							
								 stephan | c0a18d6a5a | Minor wasm doc touchups. No code changes. FossilOrigin-Name: 2c448368913a844bdb5e69f8fa3bad91a2b6612ba3b7f3f650dd07b81db25a77 | 2022-11-07 12:12:27 +00:00 |  |