diff options
author | John Turner <jturner.usa@gmail.com> | 2025-09-14 00:16:10 -0400 |
---|---|---|
committer | John Turner <jturner.usa@gmail.com> | 2025-09-14 00:16:10 -0400 |
commit | 13e0821fd783a1d5083d825af53cf20e8dcbfd76 (patch) | |
tree | 1ea363b0f13b3e87d177100e6ae6b9f30a2de1b8 /subprojects/boost-sqlite/doc/extensions.adoc | |
parent | aa55cb93036a89c64c08e08f4e1de4fa1fd5a775 (diff) | |
parent | efcea3a80da7c4479d5fe168435ecc9fd06bdc72 (diff) | |
download | sqlite-kv-bench-13e0821fd783a1d5083d825af53cf20e8dcbfd76.tar.gz |
Merge commit 'efcea3a80da7c4479d5fe168435ecc9fd06bdc72' as 'subprojects/boost-sqlite'
Diffstat (limited to 'subprojects/boost-sqlite/doc/extensions.adoc')
-rw-r--r-- | subprojects/boost-sqlite/doc/extensions.adoc | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/subprojects/boost-sqlite/doc/extensions.adoc b/subprojects/boost-sqlite/doc/extensions.adoc new file mode 100644 index 0000000..528fb39 --- /dev/null +++ b/subprojects/boost-sqlite/doc/extensions.adoc @@ -0,0 +1,41 @@ += Extension Modules + +This library can also be used to https://www.sqlite.org/loadext.html::[run-time loadable extensions] +that can be used by other applications, e.g. the `sqlite3` CLI. + +In order to write this, you'll need to include `boost/sqlite/extension.hpp`, +and write a named module like so: + +[source,cpp] +---- +BOOST_SQLITE_EXTENSION(testlibrary, conn) +{ + // create a function that can be used in the plugin + create_scalar_function( + conn, "assert", + [](boost::sqlite::context<>, boost::span<boost::sqlite::value, 1u> sp) + { + if (sp.front().get_int() == 0) + throw std::logic_error("assertion failed"); + }); +} +---- + +[source,sqlite] +---- +SELECT load_extension('./test_library'); + +select assert((3 * 4) = 12); +---- + +In order to build this, you'll to link against `Boost::sqlite_ext` +instead of `Boost::sqlite`. + +Including the `extension.hpp` header will also define +`BOOST_SQLITE_COMPILE_EXTENSION`, which will include `sqlite3ext.h` +instead of `sqlite3.h` and create an inline namespace `ext` inside +`boost::sqlite`. + +This prevents linker issues, but will not allow you to mix extension +and non-extension code in one translation unit. + |