Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gilzoide/idbvfs
WebAssembly SQLite VFS for web browsers, powered by IndexedDB
https://github.com/gilzoide/idbvfs
emscripten indexed-db indexeddb sqlite sqlite-vfs sqlite3 web webassembly
Last synced: about 1 month ago
JSON representation
WebAssembly SQLite VFS for web browsers, powered by IndexedDB
- Host: GitHub
- URL: https://github.com/gilzoide/idbvfs
- Owner: gilzoide
- License: unlicense
- Created: 2024-07-07T12:59:43.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-09-29T15:01:05.000Z (4 months ago)
- Last Synced: 2024-12-13T21:40:59.620Z (about 1 month ago)
- Topics: emscripten, indexed-db, indexeddb, sqlite, sqlite-vfs, sqlite3, web, webassembly
- Language: C
- Homepage: https://gilzoide.github.io/idbvfs/
- Size: 4.01 MB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
# idbvfs
WebAssembly + Emscripten [SQLite](https://sqlite.org/) [VFS](https://www.sqlite.org/vfs.html) for web browsers, powered by [IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API).Checkout the live demo: https://gilzoide.github.io/idbvfs/
### This project is for...
- Web browser applications that use SQLite directly from WebAssembly-compiled code, for example apps built using C/C++ game engines### This project is NOT for...
- Web browser applications that use SQLite from JavaScript, like users of [sqlite3.wasm](https://sqlite.org/wasm) or [sql.js](https://sql.js.org/)## Caveats
- This project implements only the SQLite VFS that uses IndexedDB for persistence.
You must compile and link SQLite with your app yourself.
This project is supposed to be statically linked to your WebAssembly applications.
- This VFS does not implement any file locking mechanism.
Just make sure there's a single database connection to each file and you should be fine.## How to use
TL;DR: call `idbvfs_register` before opening your SQLite databases and that's it!
```c
// 1. Include `idbvfs.h`
#include// 2. Somewhere in your app's initialization, register idbvfs.
// Pass `1` to make idbvfs the default VFS for new connections.
int result = idbvfs_register(1);
if (restult != SQLITE_OK) {
// handle errors if necessary...
}// 3. Just use SQLite normally
sqlite3 *db;
int result = sqlite3_open_v2(
"mydb", &db,
SQLITE_OPEN_CREATE | SQLITE_OPEN_READWRITE,
IDBVFS_NAME
);
// The above is the same as below, if idbvfs is the default VFS
// int result = sqlite3_open("mydb", &db);
```### Linking idbvfs in CMake builds:
```cmake
# 1. Import `idbvfs` as a subdirectory
# This will build idbvfs as a static library
add_subdirectory(path/to/idbvfs)# 2. Link your library/executable to the `idbvfs` library
# This will also add the necessary includes for `idbvfs.h`
# as well as link the IDBFS library
target_link_libraries(my-wasm-app PUBLIC idbvfs)
```### Linking idbvfs in non-CMake builds:
```sh
# 1. Compile idbvfs using CMake, from the project root
# This will output a static library at `build/libidbvfs.a`
emcmake cmake . -B build -DCMAKE_BUILD_TYPE=Release
cmake --build build# 2. Link your app with `build/libidbvfs.a`.
# Don't forget to add `-lidbfs.js` link option or idbvfs will not work!
emcc -o my-wasm-app my-wasm-app.o \
-lidbfs.js \
-Lidbvfs/build -lidbvfs
```