Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/timlrx/sqlite-extension-template
Template for building a SQLite extension in C/C++. Builds a loadable module, static extension, python package and WebAssembly distribution.
https://github.com/timlrx/sqlite-extension-template
c cpp python sqlite template wasm
Last synced: 3 months ago
JSON representation
Template for building a SQLite extension in C/C++. Builds a loadable module, static extension, python package and WebAssembly distribution.
- Host: GitHub
- URL: https://github.com/timlrx/sqlite-extension-template
- Owner: timlrx
- License: mit
- Created: 2023-08-10T15:18:36.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-08-17T15:12:04.000Z (over 1 year ago)
- Last Synced: 2024-10-04T19:44:32.743Z (3 months ago)
- Topics: c, cpp, python, sqlite, template, wasm
- Language: Makefile
- Homepage:
- Size: 38.1 KB
- Stars: 6
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SQLite Custom Extension Template
This repository contains a template for building custom [SQLite] extensions in C / C++. It supports the following targets:
- Loadable module
- Static library
- WebAssembly build with fiddle
- Python packageCredits goes to [Alex Garcia](https://github.com/asg017/sqlite-ecosystem) for his numerous repositories which I adapted to create this scaffold. Check out his repositories for other build targets. I added a WASM target based on the official SQLite build (more info at my [blog post](https://www.timlrx.com/blog/sqlite-wasm-with-custom-extensions)). The WASM build requires compiling from the raw source tree, instead of relying on the amalgamation distribution.
The scaffold creates 2 functions (`rot13()` and `rot13_version()`), and a virtual table module with no implementation logic (`rot13`) as an SQLite extension.
The WASM build copies the contents in `src/` and the pre-processed header files to `sqlite/ext/wasm` and builds it over there. `sqlite_wasm_extra_init.c` is required to initialize the extension and `fiddle.make` overrides the default file and adds the extension to the fiddle.
If you encounter any issues, it might help to run `git clean -df` in the sqlite submodule before re-running the build process.
## Pre-requisites
In addition to platform specific build tools (e.g. llvm or build-essentials), the following tools are required:
- [CMake](https://cmake.org/)
- [Python](https://www.python.org/) with `pip install wheel`
- [Emscripten](https://github.com/emscripten-core/emsdk.git)
- [WASM Binary Toolkit](https://github.com/WebAssembly/wabt)## Getting Started
Run the following command:
1. Clone the repository: `git clone --recurse-submodules https://github.com/username/rot13.git`
2. Build the loadable module: `make loadable`
3. Build the static library: `make static`
4. Build the Python package: `make python`
5. Build the WebAssembly module and fiddle: `make wasm`
6. Add your own files to the `src/` directory and update the code in the folders accordingly.## Repository Structure
```
.
├── src/ # Source code for the SQLite extension
│ ├── rot13.c
│ ├── rot13.h.in
| |── fiddle.make # Overrides the default make file to add the extension to the fiddle
│ └── sqlite_wasm_extra_init.c # Required for WASM build
├── tests/ # Contains the test suite for the SQLite extension
│ ├── test_loadable.sql # Contains the SQL test cases for the loadable module
│ └── test_rot13.py # Contains the Python test cases for the rot13 virtual table module
├── build/ # Intermediate build files
├── build_release/ # Intermediate build files when making the release targets
├── vendor/
│ └── sqlite/ # Git submodule for the SQLite library
├── dist/
│ ├── debug/ # Debug build artifacts
│ └── release/ # Release build artifacts
├── scripts/
| └── rename_wheels.py
├── bindings/ # Bindings for other builds
│ └── python/
├── CMakeLists.txt
├── Makefile
└── README.md
```Running `make python` will generate an installable wheels in `dist/debug/wheels`.
The output of `make wasm` is located at `dist/debug/wasm` and includes a fiddle with the extension built-in. Test it out by running `python -m http.server` and browsing the directory content.
## Makefile
The Makefile in this repository contains the following targets:
- `loadable`: builds a loadable version of the extension. The module will be located in `dist/debug`, with file extensions `.dylib`, `.so`, or `.dll` depending on your operating system
- `loadable-release`: release version of the loadable module located in `dist/release`
- `static`: builds the static version of the extension. `.a` and `.h` files are located in `dist/debug` and can be used to statically link with other projects.
- `static-release`: release version of the static library located in `dist/release`
- `wasm`: builds the WebAssembly module including SQLite fiddle. Built files and demos are copied to `dist/debug/wasm`.
- `wasm-release`: builds the WebAssembly module for release. Built files are copied to `dist/release/wasm`.
- `python`: builds the Python wheels in debug mode. Built files are located at `dist/debug/wheels`.
- `python-release`: builds the Python wheels for release. Built files are located at `dist/release/wheels`.
- `python-versions`: updates the version file for the Python package
- `test-loadable`: test the Python loadable module
- `test-python`: test the Python package (requires installation)
- `test`: runs both the loadable module test and the Python package test
- `clean`: removes all dist files[SQLite]: https://sqlite.org/index.html