diff options
author | EuAndreh <eu@euandre.org> | 2024-08-14 17:31:36 -0300 |
---|---|---|
committer | EuAndreh <eu@euandre.org> | 2024-08-14 17:31:36 -0300 |
commit | 0b8d97f96dd4db0e50a1cb68a0740a55017c469b (patch) | |
tree | aeb75b31cec46c6de5a8e28aceabeb10143d98f2 /doc/examples/mod_regexp/sqlite3_mod_regexp.c | |
parent | Remove most files from _example/ (diff) | |
download | golite-0b8d97f96dd4db0e50a1cb68a0740a55017c469b.tar.gz golite-0b8d97f96dd4db0e50a1cb68a0740a55017c469b.tar.xz |
git mv _example doc/examples/
Diffstat (limited to 'doc/examples/mod_regexp/sqlite3_mod_regexp.c')
-rw-r--r-- | doc/examples/mod_regexp/sqlite3_mod_regexp.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/doc/examples/mod_regexp/sqlite3_mod_regexp.c b/doc/examples/mod_regexp/sqlite3_mod_regexp.c new file mode 100644 index 0000000..d3ad149 --- /dev/null +++ b/doc/examples/mod_regexp/sqlite3_mod_regexp.c @@ -0,0 +1,35 @@ +#include <pcre.h> +#include <string.h> +#include <stdio.h> +#include <sqlite3ext.h> + +SQLITE_EXTENSION_INIT1 +static void regexp_func(sqlite3_context *context, int argc, sqlite3_value **argv) { + if (argc >= 2) { + const char *target = (const char *)sqlite3_value_text(argv[1]); + const char *pattern = (const char *)sqlite3_value_text(argv[0]); + const char* errstr = NULL; + int erroff = 0; + int vec[500]; + int n, rc; + pcre* re = pcre_compile(pattern, 0, &errstr, &erroff, NULL); + if (!re) { + sqlite3_result_error(context, errstr, 0); + return; + } + rc = pcre_exec(re, NULL, target, strlen(target), 0, 0, vec, 500); + if (rc <= 0) { + sqlite3_result_int(context, 0); + return; + } + sqlite3_result_int(context, 1); + } +} + +#ifdef _WIN32 +__declspec(dllexport) +#endif +int sqlite3_extension_init(sqlite3 *db, char **errmsg, const sqlite3_api_routines *api) { + SQLITE_EXTENSION_INIT2(api); + return sqlite3_create_function(db, "regexp", 2, SQLITE_UTF8, (void*)db, regexp_func, NULL, NULL); +} |