4.2 KiB
SQLite WebAssembly build
This directory contains Docker-based build script, make.sh, that builds
a custom version of sql.js. It allows sqliteviz to have more recent
version of SQLite build with a number of useful extensions.
Makefile from sql.js is rewritten as more comprehensible configure.py
and build.py Python scripts that run in emscripten/emsdk Docker container.
Extension
SQLite amalgamation extensions included:
- FTS5 -- virtual table module that provides full-text search functionality
- FTS3/FTS4 -- older virtual table modules for full-text search
- JSON1 -- scalar, aggregate and table-valued functions for managing JSON data
SQLite contribution extensions:
-
extension-functions -- mathematical and string extension functions for SQL queries.
Math:
acos,asin,atan,atn2,atan2,acosh,asinh,atanh,difference,degrees,radians,cos,sin,tan,cot,cosh,sinh,tanh,coth,exp,log,log10,power,sign,sqrt,square,ceil,floor,pi.String:
replicate,charindex,leftstr,rightstr,ltrim,rtrim,trim,replace,reverse,proper,padl,padr,padc,strfilter.Aggregate:
stdev,variance,mode,median,lower_quartile,upper_quartile.
SQLite miscellaneous extensions included:
generate_seriestable-valued series function (series.c)transitive_closurevirtual table for Querying Tree Structures in SQLite (closure.c)uuid,uuid_stranduuid_blobRFC-4122 UUID functions (uuid.c)regexp(henceREGEXPoperator) andregexpifunctions (regexp.c)percentilefunction (percentile.c)decimal,decimal_cmp,decimal_add,decimal_subanddecimal_mulfunctions (decimal.c)
SQLite 3rd party extensions included:
- pivot_vtab -- a pivot virtual table
To ease the step to have working clone locally, the build is committed into the repository.
Examples of queries involving these extensions can be found in the test suite in sqliteExtensions.spec.js.
Build method
Basically it's extended amalgamation and SQLITE_EXTRA_INIT concisely
described in this message from SQLite Forum:
Simply append it to the end of the amalgamation file. The real problem is how you get the init function called. The easiest way (to me at any rate) is to append a function (after the extensions you want to add are all appended) that adds the init function for each extension to the auto extension list for new connections, and set the pre-processor symbol SQLITE_EXTRA_INIT to the name of this function. [...]
An example
SQLITE_EXTRA_INITfunction looks like this:int core_init(const char* dummy) { int nErr = 0; nErr += sqlite3_auto_extension((void*)sqlite3_autobusy_init); nErr += sqlite3_auto_extension((void*)sqlite3_ipaddress_init); return nErr ? SQLITE_ERROR : SQLITE_OK; }so you would then define
SQLITE_EXTRA_INIT=core_initwhen compiling the amalgamation code and the extensions would thereafter be automatically initialized on each connection.