2024-05-27 15:46:15 +00:00
|
|
|
# Embeddable Wasm build of SQLite
|
|
|
|
|
2025-01-14 18:30:55 +00:00
|
|
|
This folder includes an embeddable Wasm build of SQLite 3.48.0 for use with
|
2024-05-27 15:46:15 +00:00
|
|
|
[`github.com/ncruces/go-sqlite3`](https://pkg.go.dev/github.com/ncruces/go-sqlite3).
|
|
|
|
|
|
|
|
The following optional features are compiled in:
|
|
|
|
- [math functions](https://sqlite.org/lang_mathfunc.html)
|
|
|
|
- [FTS5](https://sqlite.org/fts5.html)
|
|
|
|
- [JSON](https://sqlite.org/json1.html)
|
|
|
|
- [R*Tree](https://sqlite.org/rtree.html)
|
|
|
|
- [GeoPoly](https://sqlite.org/geopoly.html)
|
2024-10-08 09:15:09 +00:00
|
|
|
- [Spellfix1](https://sqlite.org/spellfix1.html)
|
2024-05-27 15:46:15 +00:00
|
|
|
- [soundex](https://sqlite.org/lang_corefunc.html#soundex)
|
|
|
|
- [stat4](https://sqlite.org/compile.html#enable_stat4)
|
|
|
|
- [base64](https://github.com/sqlite/sqlite/blob/master/ext/misc/base64.c)
|
|
|
|
- [decimal](https://github.com/sqlite/sqlite/blob/master/ext/misc/decimal.c)
|
|
|
|
- [ieee754](https://github.com/sqlite/sqlite/blob/master/ext/misc/ieee754.c)
|
|
|
|
- [regexp](https://github.com/sqlite/sqlite/blob/master/ext/misc/regexp.c)
|
|
|
|
- [series](https://github.com/sqlite/sqlite/blob/master/ext/misc/series.c)
|
|
|
|
- [uint](https://github.com/sqlite/sqlite/blob/master/ext/misc/uint.c)
|
|
|
|
- [time](../sqlite3/time.c)
|
|
|
|
|
2024-08-15 00:30:58 +00:00
|
|
|
See the [configuration options](../sqlite3/sqlite_opt.h),
|
2024-05-27 15:46:15 +00:00
|
|
|
and [patches](../sqlite3) applied.
|
|
|
|
|
|
|
|
Built using [`wasi-sdk`](https://github.com/WebAssembly/wasi-sdk),
|
2024-06-22 09:59:29 +00:00
|
|
|
and [`binaryen`](https://github.com/WebAssembly/binaryen).
|
|
|
|
|
|
|
|
The build is easily reproducible, and verifiable, using
|
2024-08-15 00:30:58 +00:00
|
|
|
[Artifact Attestations](https://github.com/ncruces/go-sqlite3/attestations).
|
|
|
|
|
|
|
|
### Customizing the build
|
|
|
|
|
|
|
|
You can use your own custom build of SQLite.
|
|
|
|
|
|
|
|
Examples of custom builds of SQLite are:
|
|
|
|
- [`github.com/ncruces/go-sqlite3/embed/bcw2`](https://github.com/ncruces/go-sqlite3/tree/main/embed/bcw2)
|
|
|
|
built from a branch supporting [`BEGIN CONCURRENT`](https://sqlite.org/src/doc/begin-concurrent/doc/begin_concurrent.md)
|
2024-10-25 16:09:18 +00:00
|
|
|
and [Wal2](https://sqlite.org/cgi/src/doc/wal2/doc/wal2.md).
|
2024-08-15 00:30:58 +00:00
|
|
|
- [`github.com/asg017/sqlite-vec-go-bindings/ncruces`](https://github.com/asg017/sqlite-vec-go-bindings)
|
|
|
|
which includes the [`sqlite-vec`](https://github.com/asg017/sqlite-vec) vector search extension.
|