|         |      1 /* | 
|         |      2 ** 2001 September 15 | 
|         |      3 ** | 
|         |      4 ** The author disclaims copyright to this source code.  In place of | 
|         |      5 ** a legal notice, here is a blessing: | 
|         |      6 ** | 
|         |      7 **    May you do good and not evil. | 
|         |      8 **    May you find forgiveness for yourself and forgive others. | 
|         |      9 **    May you share freely, never taking more than you give. | 
|         |     10 ** | 
|         |     11 ************************************************************************* | 
|         |     12 ** This header file defines the interface that the SQLite library | 
|         |     13 ** presents to client programs.  If a C-function, structure, datatype, | 
|         |     14 ** or constant definition does not appear in this file, then it is | 
|         |     15 ** not a published API of SQLite, is subject to change without | 
|         |     16 ** notice, and should not be referenced by programs that use SQLite. | 
|         |     17 ** | 
|         |     18 ** Some of the definitions that are in this file are marked as | 
|         |     19 ** "experimental".  Experimental interfaces are normally new | 
|         |     20 ** features recently added to SQLite.  We do not anticipate changes | 
|         |     21 ** to experimental interfaces but reserve to make minor changes if | 
|         |     22 ** experience from use "in the wild" suggest such changes are prudent. | 
|         |     23 ** | 
|         |     24 ** The official C-language API documentation for SQLite is derived | 
|         |     25 ** from comments in this file.  This file is the authoritative source | 
|         |     26 ** on how SQLite interfaces are suppose to operate. | 
|         |     27 ** | 
|         |     28 ** The name of this file under configuration management is "sqlite.h.in". | 
|         |     29 ** The makefile makes some minor changes to this file (such as inserting | 
|         |     30 ** the version number) and changes its name to "sqlite3.h" as | 
|         |     31 ** part of the build process. | 
|         |     32 ** | 
|         |     33 ** @(#) $Id: sqlite.h.in,v 1.400 2008/10/02 14:33:57 drh Exp $ | 
|         |     34 */ | 
|         |     35 #ifndef _SQLITE3_H_ | 
|         |     36 #define _SQLITE3_H_ | 
|         |     37 #include <stdarg.h>     /* Needed for the definition of va_list */ | 
|         |     38 #include <e32def.h> | 
|         |     39  | 
|         |     40 #ifdef SQLITE_DLL | 
|         |     41 #	define SQLITE_EXPORT EXPORT_C | 
|         |     42 #else | 
|         |     43 #	define SQLITE_EXPORT | 
|         |     44 #endif | 
|         |     45  | 
|         |     46 /* | 
|         |     47 ** Make sure we can call this stuff from C++. | 
|         |     48 */ | 
|         |     49 #ifdef __cplusplus | 
|         |     50 extern "C" { | 
|         |     51 #endif | 
|         |     52  | 
|         |     53  | 
|         |     54 /* | 
|         |     55 ** Add the ability to override 'extern' | 
|         |     56 */ | 
|         |     57 #ifndef SQLITE_EXTERN | 
|         |     58 # define SQLITE_EXTERN extern | 
|         |     59 #endif | 
|         |     60  | 
|         |     61 /* | 
|         |     62 ** These no-op macros are used in front of interfaces to mark those | 
|         |     63 ** interfaces as either deprecated or experimental.  New applications | 
|         |     64 ** should not use deprecated intrfaces - they are support for backwards | 
|         |     65 ** compatibility only.  Application writers should be aware that | 
|         |     66 ** experimental interfaces are subject to change in point releases. | 
|         |     67 ** | 
|         |     68 ** These macros used to resolve to various kinds of compiler magic that | 
|         |     69 ** would generate warning messages when they were used.  But that | 
|         |     70 ** compiler magic ended up generating such a flurry of bug reports | 
|         |     71 ** that we have taken it all out and gone back to using simple | 
|         |     72 ** noop macros. | 
|         |     73 */ | 
|         |     74 #define SQLITE_DEPRECATED | 
|         |     75 #define SQLITE_EXPERIMENTAL | 
|         |     76  | 
|         |     77 /* | 
|         |     78 ** Ensure these symbols were not defined by some previous header file. | 
|         |     79 */ | 
|         |     80 #ifdef SQLITE_VERSION | 
|         |     81 # undef SQLITE_VERSION | 
|         |     82 #endif | 
|         |     83 #ifdef SQLITE_VERSION_NUMBER | 
|         |     84 # undef SQLITE_VERSION_NUMBER | 
|         |     85 #endif | 
|         |     86  | 
|         |     87 /* | 
|         |     88 ** CAPI3REF: Compile-Time Library Version Numbers {H10010} <S60100> | 
|         |     89 ** | 
|         |     90 ** The SQLITE_VERSION and SQLITE_VERSION_NUMBER #defines in | 
|         |     91 ** the sqlite3.h file specify the version of SQLite with which | 
|         |     92 ** that header file is associated. | 
|         |     93 ** | 
|         |     94 ** The "version" of SQLite is a string of the form "X.Y.Z". | 
|         |     95 ** The phrase "alpha" or "beta" might be appended after the Z. | 
|         |     96 ** The X value is major version number always 3 in SQLite3. | 
|         |     97 ** The X value only changes when backwards compatibility is | 
|         |     98 ** broken and we intend to never break backwards compatibility. | 
|         |     99 ** The Y value is the minor version number and only changes when | 
|         |    100 ** there are major feature enhancements that are forwards compatible | 
|         |    101 ** but not backwards compatible. | 
|         |    102 ** The Z value is the release number and is incremented with | 
|         |    103 ** each release but resets back to 0 whenever Y is incremented. | 
|         |    104 ** | 
|         |    105 ** See also: [sqlite3_libversion()] and [sqlite3_libversion_number()]. | 
|         |    106 ** | 
|         |    107 ** INVARIANTS: | 
|         |    108 ** | 
|         |    109 ** {H10011} The SQLITE_VERSION #define in the sqlite3.h header file shall | 
|         |    110 **          evaluate to a string literal that is the SQLite version | 
|         |    111 **          with which the header file is associated. | 
|         |    112 ** | 
|         |    113 ** {H10014} The SQLITE_VERSION_NUMBER #define shall resolve to an integer | 
|         |    114 **          with the value (X*1000000 + Y*1000 + Z) where X, Y, and Z | 
|         |    115 **          are the major version, minor version, and release number. | 
|         |    116 */ | 
|         |    117 #define SQLITE_VERSION         "3.6.3" | 
|         |    118 #define SQLITE_VERSION_NUMBER  3006003 | 
|         |    119  | 
|         |    120 /* | 
|         |    121 ** CAPI3REF: Run-Time Library Version Numbers {H10020} <S60100> | 
|         |    122 ** KEYWORDS: sqlite3_version | 
|         |    123 ** | 
|         |    124 ** These features provide the same information as the [SQLITE_VERSION] | 
|         |    125 ** and [SQLITE_VERSION_NUMBER] #defines in the header, but are associated | 
|         |    126 ** with the library instead of the header file.  Cautious programmers might | 
|         |    127 ** include a check in their application to verify that | 
|         |    128 ** sqlite3_libversion_number() always returns the value | 
|         |    129 ** [SQLITE_VERSION_NUMBER]. | 
|         |    130 ** | 
|         |    131 ** The sqlite3_libversion() function returns the same information as is | 
|         |    132 ** in the sqlite3_version[] string constant.  The function is provided | 
|         |    133 ** for use in DLLs since DLL users usually do not have direct access to string | 
|         |    134 ** constants within the DLL. | 
|         |    135 ** | 
|         |    136 ** INVARIANTS: | 
|         |    137 ** | 
|         |    138 ** {H10021} The [sqlite3_libversion_number()] interface shall return | 
|         |    139 **          an integer equal to [SQLITE_VERSION_NUMBER]. | 
|         |    140 ** | 
|         |    141 ** {H10022} The [sqlite3_version] string constant shall contain | 
|         |    142 **          the text of the [SQLITE_VERSION] string. | 
|         |    143 ** | 
|         |    144 ** {H10023} The [sqlite3_libversion()] function shall return | 
|         |    145 **          a pointer to the [sqlite3_version] string constant. | 
|         |    146 */ | 
|         |    147 SQLITE_EXTERN const char sqlite3_version[]; | 
|         |    148 IMPORT_C const char *sqlite3_libversion(void); | 
|         |    149 IMPORT_C int sqlite3_libversion_number(void); | 
|         |    150  | 
|         |    151 /* | 
|         |    152 ** CAPI3REF: Test To See If The Library Is Threadsafe {H10100} <S60100> | 
|         |    153 ** | 
|         |    154 ** SQLite can be compiled with or without mutexes.  When | 
|         |    155 ** the [SQLITE_THREADSAFE] C preprocessor macro 1 or 2, mutexes | 
|         |    156 ** are enabled and SQLite is threadsafe.  When the | 
|         |    157 ** [SQLITE_THREADSAFE] macro is 0,  | 
|         |    158 ** the mutexes are omitted.  Without the mutexes, it is not safe | 
|         |    159 ** to use SQLite concurrently from more than one thread. | 
|         |    160 ** | 
|         |    161 ** Enabling mutexes incurs a measurable performance penalty. | 
|         |    162 ** So if speed is of utmost importance, it makes sense to disable | 
|         |    163 ** the mutexes.  But for maximum safety, mutexes should be enabled. | 
|         |    164 ** The default behavior is for mutexes to be enabled. | 
|         |    165 ** | 
|         |    166 ** This interface can be used by a program to make sure that the | 
|         |    167 ** version of SQLite that it is linking against was compiled with | 
|         |    168 ** the desired setting of the [SQLITE_THREADSAFE] macro. | 
|         |    169 ** | 
|         |    170 ** This interface only reports on the compile-time mutex setting | 
|         |    171 ** of the [SQLITE_THREADSAFE] flag.  If SQLite is compiled with | 
|         |    172 ** SQLITE_THREADSAFE=1 then mutexes are enabled by default but | 
|         |    173 ** can be fully or partially disabled using a call to [sqlite3_config()] | 
|         |    174 ** with the verbs [SQLITE_CONFIG_SINGLETHREAD], [SQLITE_CONFIG_MULTITHREAD], | 
|         |    175 ** or [SQLITE_CONFIG_MUTEX].  The return value of this function shows | 
|         |    176 ** only the default compile-time setting, not any run-time changes | 
|         |    177 ** to that setting. | 
|         |    178 ** | 
|         |    179 ** See the [threading mode] documentation for additional information. | 
|         |    180 ** | 
|         |    181 ** INVARIANTS: | 
|         |    182 ** | 
|         |    183 ** {H10101} The [sqlite3_threadsafe()] function shall return nonzero if | 
|         |    184 **          and only if | 
|         |    185 **          SQLite was compiled with the its mutexes enabled by default. | 
|         |    186 ** | 
|         |    187 ** {H10102} The value returned by the [sqlite3_threadsafe()] function | 
|         |    188 **          shall not change when mutex setting are modified at | 
|         |    189 **          runtime using the [sqlite3_config()] interface and  | 
|         |    190 **          especially the [SQLITE_CONFIG_SINGLETHREAD], | 
|         |    191 **          [SQLITE_CONFIG_MULTITHREAD], [SQLITE_CONFIG_SERIALIZED], | 
|         |    192 **          and [SQLITE_CONFIG_MUTEX] verbs. | 
|         |    193 */ | 
|         |    194 IMPORT_C int sqlite3_threadsafe(void); | 
|         |    195  | 
|         |    196 /* | 
|         |    197 ** CAPI3REF: Database Connection Handle {H12000} <S40200> | 
|         |    198 ** KEYWORDS: {database connection} {database connections} | 
|         |    199 ** | 
|         |    200 ** Each open SQLite database is represented by a pointer to an instance of | 
|         |    201 ** the opaque structure named "sqlite3".  It is useful to think of an sqlite3 | 
|         |    202 ** pointer as an object.  The [sqlite3_open()], [sqlite3_open16()], and | 
|         |    203 ** [sqlite3_open_v2()] interfaces are its constructors, and [sqlite3_close()] | 
|         |    204 ** is its destructor.  There are many other interfaces (such as | 
|         |    205 ** [sqlite3_prepare_v2()], [sqlite3_create_function()], and | 
|         |    206 ** [sqlite3_busy_timeout()] to name but three) that are methods on an | 
|         |    207 ** sqlite3 object. | 
|         |    208 */ | 
|         |    209 typedef struct sqlite3 sqlite3; | 
|         |    210  | 
|         |    211 /* | 
|         |    212 ** CAPI3REF: 64-Bit Integer Types {H10200} <S10110> | 
|         |    213 ** KEYWORDS: sqlite_int64 sqlite_uint64 | 
|         |    214 ** | 
|         |    215 ** Because there is no cross-platform way to specify 64-bit integer types | 
|         |    216 ** SQLite includes typedefs for 64-bit signed and unsigned integers. | 
|         |    217 ** | 
|         |    218 ** The sqlite3_int64 and sqlite3_uint64 are the preferred type definitions. | 
|         |    219 ** The sqlite_int64 and sqlite_uint64 types are supported for backwards | 
|         |    220 ** compatibility only. | 
|         |    221 ** | 
|         |    222 ** INVARIANTS: | 
|         |    223 ** | 
|         |    224 ** {H10201} The [sqlite_int64] and [sqlite3_int64] type shall specify | 
|         |    225 **          a 64-bit signed integer. | 
|         |    226 ** | 
|         |    227 ** {H10202} The [sqlite_uint64] and [sqlite3_uint64] type shall specify | 
|         |    228 **          a 64-bit unsigned integer. | 
|         |    229 */ | 
|         |    230 #ifdef SQLITE_INT64_TYPE | 
|         |    231   typedef SQLITE_INT64_TYPE sqlite_int64; | 
|         |    232   typedef unsigned SQLITE_INT64_TYPE sqlite_uint64; | 
|         |    233 #elif defined(_MSC_VER) || defined(__BORLANDC__) | 
|         |    234   typedef __int64 sqlite_int64; | 
|         |    235   typedef unsigned __int64 sqlite_uint64; | 
|         |    236 #else | 
|         |    237   typedef long long int sqlite_int64; | 
|         |    238   typedef unsigned long long int sqlite_uint64; | 
|         |    239 #endif | 
|         |    240 typedef sqlite_int64 sqlite3_int64; | 
|         |    241 typedef sqlite_uint64 sqlite3_uint64; | 
|         |    242  | 
|         |    243 /* | 
|         |    244 ** If compiling for a processor that lacks floating point support, | 
|         |    245 ** substitute integer for floating-point. | 
|         |    246 */ | 
|         |    247 #ifdef SQLITE_OMIT_FLOATING_POINT | 
|         |    248 # define double sqlite3_int64 | 
|         |    249 #endif | 
|         |    250  | 
|         |    251 /* | 
|         |    252 ** CAPI3REF: Closing A Database Connection {H12010} <S30100><S40200> | 
|         |    253 ** | 
|         |    254 ** This routine is the destructor for the [sqlite3] object. | 
|         |    255 ** | 
|         |    256 ** Applications should [sqlite3_finalize | finalize] all [prepared statements] | 
|         |    257 ** and [sqlite3_blob_close | close] all [BLOB handles] associated with | 
|         |    258 ** the [sqlite3] object prior to attempting to close the object. | 
|         |    259 ** The [sqlite3_next_stmt()] interface can be used to locate all | 
|         |    260 ** [prepared statements] associated with a [database connection] if desired. | 
|         |    261 ** Typical code might look like this: | 
|         |    262 ** | 
|         |    263 ** <blockquote><pre> | 
|         |    264 ** sqlite3_stmt *pStmt; | 
|         |    265 ** while( (pStmt = sqlite3_next_stmt(db, 0))!=0 ){ | 
|         |    266 **     sqlite3_finalize(pStmt); | 
|         |    267 ** } | 
|         |    268 ** </pre></blockquote> | 
|         |    269 ** | 
|         |    270 ** If [sqlite3_close()] is invoked while a transaction is open, | 
|         |    271 ** the transaction is automatically rolled back. | 
|         |    272 ** | 
|         |    273 ** INVARIANTS: | 
|         |    274 ** | 
|         |    275 ** {H12011} A successful call to [sqlite3_close(C)] shall destroy the | 
|         |    276 **          [database connection] object C. | 
|         |    277 ** | 
|         |    278 ** {H12012} A successful call to [sqlite3_close(C)] shall return SQLITE_OK. | 
|         |    279 ** | 
|         |    280 ** {H12013} A successful call to [sqlite3_close(C)] shall release all | 
|         |    281 **          memory and system resources associated with [database connection] | 
|         |    282 **          C. | 
|         |    283 ** | 
|         |    284 ** {H12014} A call to [sqlite3_close(C)] on a [database connection] C that | 
|         |    285 **          has one or more open [prepared statements] shall fail with | 
|         |    286 **          an [SQLITE_BUSY] error code. | 
|         |    287 ** | 
|         |    288 ** {H12015} A call to [sqlite3_close(C)] where C is a NULL pointer shall | 
|         |    289 **          return SQLITE_OK. | 
|         |    290 ** | 
|         |    291 ** {H12019} When [sqlite3_close(C)] is invoked on a [database connection] C | 
|         |    292 **          that has a pending transaction, the transaction shall be | 
|         |    293 **          rolled back. | 
|         |    294 ** | 
|         |    295 ** ASSUMPTIONS: | 
|         |    296 ** | 
|         |    297 ** {A12016} The C parameter to [sqlite3_close(C)] must be either a NULL | 
|         |    298 **          pointer or an [sqlite3] object pointer obtained | 
|         |    299 **          from [sqlite3_open()], [sqlite3_open16()], or | 
|         |    300 **          [sqlite3_open_v2()], and not previously closed. | 
|         |    301 */ | 
|         |    302 IMPORT_C int sqlite3_close(sqlite3 *); | 
|         |    303  | 
|         |    304 /* | 
|         |    305 ** The type for a callback function. | 
|         |    306 ** This is legacy and deprecated.  It is included for historical | 
|         |    307 ** compatibility and is not documented. | 
|         |    308 */ | 
|         |    309 typedef int (*sqlite3_callback)(void*,int,char**, char**); | 
|         |    310  | 
|         |    311 /* | 
|         |    312 ** CAPI3REF: One-Step Query Execution Interface {H12100} <S10000> | 
|         |    313 ** | 
|         |    314 ** The sqlite3_exec() interface is a convenient way of running one or more | 
|         |    315 ** SQL statements without having to write a lot of C code.  The UTF-8 encoded | 
|         |    316 ** SQL statements are passed in as the second parameter to sqlite3_exec(). | 
|         |    317 ** The statements are evaluated one by one until either an error or | 
|         |    318 ** an interrupt is encountered, or until they are all done.  The 3rd parameter | 
|         |    319 ** is an optional callback that is invoked once for each row of any query | 
|         |    320 ** results produced by the SQL statements.  The 5th parameter tells where | 
|         |    321 ** to write any error messages. | 
|         |    322 ** | 
|         |    323 ** The error message passed back through the 5th parameter is held | 
|         |    324 ** in memory obtained from [sqlite3_malloc()].  To avoid a memory leak, | 
|         |    325 ** the calling application should call [sqlite3_free()] on any error | 
|         |    326 ** message returned through the 5th parameter when it has finished using | 
|         |    327 ** the error message. | 
|         |    328 ** | 
|         |    329 ** If the SQL statement in the 2nd parameter is NULL or an empty string | 
|         |    330 ** or a string containing only whitespace and comments, then no SQL | 
|         |    331 ** statements are evaluated and the database is not changed. | 
|         |    332 ** | 
|         |    333 ** The sqlite3_exec() interface is implemented in terms of | 
|         |    334 ** [sqlite3_prepare_v2()], [sqlite3_step()], and [sqlite3_finalize()]. | 
|         |    335 ** The sqlite3_exec() routine does nothing to the database that cannot be done | 
|         |    336 ** by [sqlite3_prepare_v2()], [sqlite3_step()], and [sqlite3_finalize()]. | 
|         |    337 ** | 
|         |    338 ** INVARIANTS: | 
|         |    339 ** | 
|         |    340 ** {H12101} A successful invocation of [sqlite3_exec(D,S,C,A,E)] | 
|         |    341 **          shall sequentially evaluate all of the UTF-8 encoded, | 
|         |    342 **          semicolon-separated SQL statements in the zero-terminated | 
|         |    343 **          string S within the context of the [database connection] D. | 
|         |    344 ** | 
|         |    345 ** {H12102} If the S parameter to [sqlite3_exec(D,S,C,A,E)] is NULL then | 
|         |    346 **          the actions of the interface shall be the same as if the | 
|         |    347 **          S parameter were an empty string. | 
|         |    348 ** | 
|         |    349 ** {H12104} The return value of [sqlite3_exec()] shall be [SQLITE_OK] if all | 
|         |    350 **          SQL statements run successfully and to completion. | 
|         |    351 ** | 
|         |    352 ** {H12105} The return value of [sqlite3_exec()] shall be an appropriate | 
|         |    353 **          non-zero [error code] if any SQL statement fails. | 
|         |    354 ** | 
|         |    355 ** {H12107} If one or more of the SQL statements handed to [sqlite3_exec()] | 
|         |    356 **          return results and the 3rd parameter is not NULL, then | 
|         |    357 **          the callback function specified by the 3rd parameter shall be | 
|         |    358 **          invoked once for each row of result. | 
|         |    359 ** | 
|         |    360 ** {H12110} If the callback returns a non-zero value then [sqlite3_exec()] | 
|         |    361 **          shall abort the SQL statement it is currently evaluating, | 
|         |    362 **          skip all subsequent SQL statements, and return [SQLITE_ABORT]. | 
|         |    363 ** | 
|         |    364 ** {H12113} The [sqlite3_exec()] routine shall pass its 4th parameter through | 
|         |    365 **          as the 1st parameter of the callback. | 
|         |    366 ** | 
|         |    367 ** {H12116} The [sqlite3_exec()] routine shall set the 2nd parameter of its | 
|         |    368 **          callback to be the number of columns in the current row of | 
|         |    369 **          result. | 
|         |    370 ** | 
|         |    371 ** {H12119} The [sqlite3_exec()] routine shall set the 3rd parameter of its | 
|         |    372 **          callback to be an array of pointers to strings holding the | 
|         |    373 **          values for each column in the current result set row as | 
|         |    374 **          obtained from [sqlite3_column_text()]. | 
|         |    375 ** | 
|         |    376 ** {H12122} The [sqlite3_exec()] routine shall set the 4th parameter of its | 
|         |    377 **          callback to be an array of pointers to strings holding the | 
|         |    378 **          names of result columns as obtained from [sqlite3_column_name()]. | 
|         |    379 ** | 
|         |    380 ** {H12125} If the 3rd parameter to [sqlite3_exec()] is NULL then | 
|         |    381 **          [sqlite3_exec()] shall silently discard query results. | 
|         |    382 ** | 
|         |    383 ** {H12131} If an error occurs while parsing or evaluating any of the SQL | 
|         |    384 **          statements in the S parameter of [sqlite3_exec(D,S,C,A,E)] and if | 
|         |    385 **          the E parameter is not NULL, then [sqlite3_exec()] shall store | 
|         |    386 **          in *E an appropriate error message written into memory obtained | 
|         |    387 **          from [sqlite3_malloc()]. | 
|         |    388 ** | 
|         |    389 ** {H12134} The [sqlite3_exec(D,S,C,A,E)] routine shall set the value of | 
|         |    390 **          *E to NULL if E is not NULL and there are no errors. | 
|         |    391 ** | 
|         |    392 ** {H12137} The [sqlite3_exec(D,S,C,A,E)] function shall set the [error code] | 
|         |    393 **          and message accessible via [sqlite3_errcode()], | 
|         |    394 **          [sqlite3_errmsg()], and [sqlite3_errmsg16()]. | 
|         |    395 ** | 
|         |    396 ** {H12138} If the S parameter to [sqlite3_exec(D,S,C,A,E)] is NULL or an | 
|         |    397 **          empty string or contains nothing other than whitespace, comments, | 
|         |    398 **          and/or semicolons, then results of [sqlite3_errcode()], | 
|         |    399 **          [sqlite3_errmsg()], and [sqlite3_errmsg16()] | 
|         |    400 **          shall reset to indicate no errors. | 
|         |    401 ** | 
|         |    402 ** ASSUMPTIONS: | 
|         |    403 ** | 
|         |    404 ** {A12141} The first parameter to [sqlite3_exec()] must be an valid and open | 
|         |    405 **          [database connection]. | 
|         |    406 ** | 
|         |    407 ** {A12142} The database connection must not be closed while | 
|         |    408 **          [sqlite3_exec()] is running. | 
|         |    409 ** | 
|         |    410 ** {A12143} The calling function should use [sqlite3_free()] to free | 
|         |    411 **          the memory that *errmsg is left pointing at once the error | 
|         |    412 **          message is no longer needed. | 
|         |    413 ** | 
|         |    414 ** {A12145} The SQL statement text in the 2nd parameter to [sqlite3_exec()] | 
|         |    415 **          must remain unchanged while [sqlite3_exec()] is running. | 
|         |    416 */ | 
|         |    417 IMPORT_C int sqlite3_exec( | 
|         |    418   sqlite3*,                                  /* An open database */ | 
|         |    419   const char *sql,                           /* SQL to be evaluated */ | 
|         |    420   int (*callback)(void*,int,char**,char**),  /* Callback function */ | 
|         |    421   void *,                                    /* 1st argument to callback */ | 
|         |    422   char **errmsg                              /* Error msg written here */ | 
|         |    423 ); | 
|         |    424  | 
|         |    425 /* | 
|         |    426 ** CAPI3REF: Result Codes {H10210} <S10700> | 
|         |    427 ** KEYWORDS: SQLITE_OK {error code} {error codes} | 
|         |    428 ** KEYWORDS: {result code} {result codes} | 
|         |    429 ** | 
|         |    430 ** Many SQLite functions return an integer result code from the set shown | 
|         |    431 ** here in order to indicates success or failure. | 
|         |    432 ** | 
|         |    433 ** New error codes may be added in future versions of SQLite. | 
|         |    434 ** | 
|         |    435 ** See also: [SQLITE_IOERR_READ | extended result codes] | 
|         |    436 */ | 
|         |    437 #define SQLITE_OK           0   /* Successful result */ | 
|         |    438 /* beginning-of-error-codes */ | 
|         |    439 #define SQLITE_ERROR        1   /* SQL error or missing database */ | 
|         |    440 #define SQLITE_INTERNAL     2   /* Internal logic error in SQLite */ | 
|         |    441 #define SQLITE_PERM         3   /* Access permission denied */ | 
|         |    442 #define SQLITE_ABORT        4   /* Callback routine requested an abort */ | 
|         |    443 #define SQLITE_BUSY         5   /* The database file is locked */ | 
|         |    444 #define SQLITE_LOCKED       6   /* A table in the database is locked */ | 
|         |    445 #define SQLITE_NOMEM        7   /* A malloc() failed */ | 
|         |    446 #define SQLITE_READONLY     8   /* Attempt to write a readonly database */ | 
|         |    447 #define SQLITE_INTERRUPT    9   /* Operation terminated by sqlite3_interrupt()*/ | 
|         |    448 #define SQLITE_IOERR       10   /* Some kind of disk I/O error occurred */ | 
|         |    449 #define SQLITE_CORRUPT     11   /* The database disk image is malformed */ | 
|         |    450 #define SQLITE_NOTFOUND    12   /* NOT USED. Table or record not found */ | 
|         |    451 #define SQLITE_FULL        13   /* Insertion failed because database is full */ | 
|         |    452 #define SQLITE_CANTOPEN    14   /* Unable to open the database file */ | 
|         |    453 #define SQLITE_PROTOCOL    15   /* NOT USED. Database lock protocol error */ | 
|         |    454 #define SQLITE_EMPTY       16   /* Database is empty */ | 
|         |    455 #define SQLITE_SCHEMA      17   /* The database schema changed */ | 
|         |    456 #define SQLITE_TOOBIG      18   /* String or BLOB exceeds size limit */ | 
|         |    457 #define SQLITE_CONSTRAINT  19   /* Abort due to constraint violation */ | 
|         |    458 #define SQLITE_MISMATCH    20   /* Data type mismatch */ | 
|         |    459 #define SQLITE_MISUSE      21   /* Library used incorrectly */ | 
|         |    460 #define SQLITE_NOLFS       22   /* Uses OS features not supported on host */ | 
|         |    461 #define SQLITE_AUTH        23   /* Authorization denied */ | 
|         |    462 #define SQLITE_FORMAT      24   /* Auxiliary database format error */ | 
|         |    463 #define SQLITE_RANGE       25   /* 2nd parameter to sqlite3_bind out of range */ | 
|         |    464 #define SQLITE_NOTADB      26   /* File opened that is not a database file */ | 
|         |    465 #define SQLITE_ROW         100  /* sqlite3_step() has another row ready */ | 
|         |    466 #define SQLITE_DONE        101  /* sqlite3_step() has finished executing */ | 
|         |    467 /* end-of-error-codes */ | 
|         |    468  | 
|         |    469 /* | 
|         |    470 ** CAPI3REF: Extended Result Codes {H10220} <S10700> | 
|         |    471 ** KEYWORDS: {extended error code} {extended error codes} | 
|         |    472 ** KEYWORDS: {extended result code} {extended result codes} | 
|         |    473 ** | 
|         |    474 ** In its default configuration, SQLite API routines return one of 26 integer | 
|         |    475 ** [SQLITE_OK | result codes].  However, experience has shown that many of | 
|         |    476 ** these result codes are too coarse-grained.  They do not provide as | 
|         |    477 ** much information about problems as programmers might like.  In an effort to | 
|         |    478 ** address this, newer versions of SQLite (version 3.3.8 and later) include | 
|         |    479 ** support for additional result codes that provide more detailed information | 
|         |    480 ** about errors. The extended result codes are enabled or disabled | 
|         |    481 ** on a per database connection basis using the | 
|         |    482 ** [sqlite3_extended_result_codes()] API. | 
|         |    483 ** | 
|         |    484 ** Some of the available extended result codes are listed here. | 
|         |    485 ** One may expect the number of extended result codes will be expand | 
|         |    486 ** over time.  Software that uses extended result codes should expect | 
|         |    487 ** to see new result codes in future releases of SQLite. | 
|         |    488 ** | 
|         |    489 ** The SQLITE_OK result code will never be extended.  It will always | 
|         |    490 ** be exactly zero. | 
|         |    491 ** | 
|         |    492 ** INVARIANTS: | 
|         |    493 ** | 
|         |    494 ** {H10223} The symbolic name for an extended result code shall contains | 
|         |    495 **          a related primary result code as a prefix. | 
|         |    496 ** | 
|         |    497 ** {H10224} Primary result code names shall contain a single "_" character. | 
|         |    498 ** | 
|         |    499 ** {H10225} Extended result code names shall contain two or more "_" characters. | 
|         |    500 ** | 
|         |    501 ** {H10226} The numeric value of an extended result code shall contain the | 
|         |    502 **          numeric value of its corresponding primary result code in | 
|         |    503 **          its least significant 8 bits. | 
|         |    504 */ | 
|         |    505 #define SQLITE_IOERR_READ              (SQLITE_IOERR | (1<<8)) | 
|         |    506 #define SQLITE_IOERR_SHORT_READ        (SQLITE_IOERR | (2<<8)) | 
|         |    507 #define SQLITE_IOERR_WRITE             (SQLITE_IOERR | (3<<8)) | 
|         |    508 #define SQLITE_IOERR_FSYNC             (SQLITE_IOERR | (4<<8)) | 
|         |    509 #define SQLITE_IOERR_DIR_FSYNC         (SQLITE_IOERR | (5<<8)) | 
|         |    510 #define SQLITE_IOERR_TRUNCATE          (SQLITE_IOERR | (6<<8)) | 
|         |    511 #define SQLITE_IOERR_FSTAT             (SQLITE_IOERR | (7<<8)) | 
|         |    512 #define SQLITE_IOERR_UNLOCK            (SQLITE_IOERR | (8<<8)) | 
|         |    513 #define SQLITE_IOERR_RDLOCK            (SQLITE_IOERR | (9<<8)) | 
|         |    514 #define SQLITE_IOERR_DELETE            (SQLITE_IOERR | (10<<8)) | 
|         |    515 #define SQLITE_IOERR_BLOCKED           (SQLITE_IOERR | (11<<8)) | 
|         |    516 #define SQLITE_IOERR_NOMEM             (SQLITE_IOERR | (12<<8)) | 
|         |    517 #define SQLITE_IOERR_ACCESS            (SQLITE_IOERR | (13<<8)) | 
|         |    518 #define SQLITE_IOERR_CHECKRESERVEDLOCK (SQLITE_IOERR | (14<<8)) | 
|         |    519 #define SQLITE_IOERR_LOCK              (SQLITE_IOERR | (15<<8)) | 
|         |    520  | 
|         |    521 /* | 
|         |    522 ** CAPI3REF: Flags For File Open Operations {H10230} <H11120> <H12700> | 
|         |    523 ** | 
|         |    524 ** These bit values are intended for use in the | 
|         |    525 ** 3rd parameter to the [sqlite3_open_v2()] interface and | 
|         |    526 ** in the 4th parameter to the xOpen method of the | 
|         |    527 ** [sqlite3_vfs] object. | 
|         |    528 */ | 
|         |    529 #define SQLITE_OPEN_READONLY         0x00000001 | 
|         |    530 #define SQLITE_OPEN_READWRITE        0x00000002 | 
|         |    531 #define SQLITE_OPEN_CREATE           0x00000004 | 
|         |    532 #define SQLITE_OPEN_DELETEONCLOSE    0x00000008 | 
|         |    533 #define SQLITE_OPEN_EXCLUSIVE        0x00000010 | 
|         |    534 #define SQLITE_OPEN_MAIN_DB          0x00000100 | 
|         |    535 #define SQLITE_OPEN_TEMP_DB          0x00000200 | 
|         |    536 #define SQLITE_OPEN_TRANSIENT_DB     0x00000400 | 
|         |    537 #define SQLITE_OPEN_MAIN_JOURNAL     0x00000800 | 
|         |    538 #define SQLITE_OPEN_TEMP_JOURNAL     0x00001000 | 
|         |    539 #define SQLITE_OPEN_SUBJOURNAL       0x00002000 | 
|         |    540 #define SQLITE_OPEN_MASTER_JOURNAL   0x00004000 | 
|         |    541 #define SQLITE_OPEN_NOMUTEX          0x00008000 | 
|         |    542 #define SQLITE_OPEN_FULLMUTEX        0x00010000 | 
|         |    543  | 
|         |    544 /* | 
|         |    545 ** CAPI3REF: Device Characteristics {H10240} <H11120> | 
|         |    546 ** | 
|         |    547 ** The xDeviceCapabilities method of the [sqlite3_io_methods] | 
|         |    548 ** object returns an integer which is a vector of the these | 
|         |    549 ** bit values expressing I/O characteristics of the mass storage | 
|         |    550 ** device that holds the file that the [sqlite3_io_methods] | 
|         |    551 ** refers to. | 
|         |    552 ** | 
|         |    553 ** The SQLITE_IOCAP_ATOMIC property means that all writes of | 
|         |    554 ** any size are atomic.  The SQLITE_IOCAP_ATOMICnnn values | 
|         |    555 ** mean that writes of blocks that are nnn bytes in size and | 
|         |    556 ** are aligned to an address which is an integer multiple of | 
|         |    557 ** nnn are atomic.  The SQLITE_IOCAP_SAFE_APPEND value means | 
|         |    558 ** that when data is appended to a file, the data is appended | 
|         |    559 ** first then the size of the file is extended, never the other | 
|         |    560 ** way around.  The SQLITE_IOCAP_SEQUENTIAL property means that | 
|         |    561 ** information is written to disk in the same order as calls | 
|         |    562 ** to xWrite(). | 
|         |    563 */ | 
|         |    564 #define SQLITE_IOCAP_ATOMIC          0x00000001 | 
|         |    565 #define SQLITE_IOCAP_ATOMIC512       0x00000002 | 
|         |    566 #define SQLITE_IOCAP_ATOMIC1K        0x00000004 | 
|         |    567 #define SQLITE_IOCAP_ATOMIC2K        0x00000008 | 
|         |    568 #define SQLITE_IOCAP_ATOMIC4K        0x00000010 | 
|         |    569 #define SQLITE_IOCAP_ATOMIC8K        0x00000020 | 
|         |    570 #define SQLITE_IOCAP_ATOMIC16K       0x00000040 | 
|         |    571 #define SQLITE_IOCAP_ATOMIC32K       0x00000080 | 
|         |    572 #define SQLITE_IOCAP_ATOMIC64K       0x00000100 | 
|         |    573 #define SQLITE_IOCAP_SAFE_APPEND     0x00000200 | 
|         |    574 #define SQLITE_IOCAP_SEQUENTIAL      0x00000400 | 
|         |    575  | 
|         |    576 /* | 
|         |    577 ** CAPI3REF: File Locking Levels {H10250} <H11120> <H11310> | 
|         |    578 ** | 
|         |    579 ** SQLite uses one of these integer values as the second | 
|         |    580 ** argument to calls it makes to the xLock() and xUnlock() methods | 
|         |    581 ** of an [sqlite3_io_methods] object. | 
|         |    582 */ | 
|         |    583 #define SQLITE_LOCK_NONE          0 | 
|         |    584 #define SQLITE_LOCK_SHARED        1 | 
|         |    585 #define SQLITE_LOCK_RESERVED      2 | 
|         |    586 #define SQLITE_LOCK_PENDING       3 | 
|         |    587 #define SQLITE_LOCK_EXCLUSIVE     4 | 
|         |    588  | 
|         |    589 /* | 
|         |    590 ** CAPI3REF: Synchronization Type Flags {H10260} <H11120> | 
|         |    591 ** | 
|         |    592 ** When SQLite invokes the xSync() method of an | 
|         |    593 ** [sqlite3_io_methods] object it uses a combination of | 
|         |    594 ** these integer values as the second argument. | 
|         |    595 ** | 
|         |    596 ** When the SQLITE_SYNC_DATAONLY flag is used, it means that the | 
|         |    597 ** sync operation only needs to flush data to mass storage.  Inode | 
|         |    598 ** information need not be flushed. The SQLITE_SYNC_NORMAL flag means | 
|         |    599 ** to use normal fsync() semantics. The SQLITE_SYNC_FULL flag means | 
|         |    600 ** to use Mac OS-X style fullsync instead of fsync(). | 
|         |    601 */ | 
|         |    602 #define SQLITE_SYNC_NORMAL        0x00002 | 
|         |    603 #define SQLITE_SYNC_FULL          0x00003 | 
|         |    604 #define SQLITE_SYNC_DATAONLY      0x00010 | 
|         |    605  | 
|         |    606 /* | 
|         |    607 ** CAPI3REF: OS Interface Open File Handle {H11110} <S20110> | 
|         |    608 ** | 
|         |    609 ** An [sqlite3_file] object represents an open file in the OS | 
|         |    610 ** interface layer.  Individual OS interface implementations will | 
|         |    611 ** want to subclass this object by appending additional fields | 
|         |    612 ** for their own use.  The pMethods entry is a pointer to an | 
|         |    613 ** [sqlite3_io_methods] object that defines methods for performing | 
|         |    614 ** I/O operations on the open file. | 
|         |    615 */ | 
|         |    616 typedef struct sqlite3_file sqlite3_file; | 
|         |    617 struct sqlite3_file { | 
|         |    618   const struct sqlite3_io_methods *pMethods;  /* Methods for an open file */ | 
|         |    619 }; | 
|         |    620  | 
|         |    621 /* | 
|         |    622 ** CAPI3REF: OS Interface File Virtual Methods Object {H11120} <S20110> | 
|         |    623 ** | 
|         |    624 ** Every file opened by the [sqlite3_vfs] xOpen method populates an | 
|         |    625 ** [sqlite3_file] object (or, more commonly, a subclass of the | 
|         |    626 ** [sqlite3_file] object) with a pointer to an instance of this object. | 
|         |    627 ** This object defines the methods used to perform various operations | 
|         |    628 ** against the open file represented by the [sqlite3_file] object. | 
|         |    629 ** | 
|         |    630 ** The flags argument to xSync may be one of [SQLITE_SYNC_NORMAL] or | 
|         |    631 ** [SQLITE_SYNC_FULL].  The first choice is the normal fsync(). | 
|         |    632 ** The second choice is a Mac OS-X style fullsync.  The [SQLITE_SYNC_DATAONLY] | 
|         |    633 ** flag may be ORed in to indicate that only the data of the file | 
|         |    634 ** and not its inode needs to be synced. | 
|         |    635 ** | 
|         |    636 ** The integer values to xLock() and xUnlock() are one of | 
|         |    637 ** <ul> | 
|         |    638 ** <li> [SQLITE_LOCK_NONE], | 
|         |    639 ** <li> [SQLITE_LOCK_SHARED], | 
|         |    640 ** <li> [SQLITE_LOCK_RESERVED], | 
|         |    641 ** <li> [SQLITE_LOCK_PENDING], or | 
|         |    642 ** <li> [SQLITE_LOCK_EXCLUSIVE]. | 
|         |    643 ** </ul> | 
|         |    644 ** xLock() increases the lock. xUnlock() decreases the lock. | 
|         |    645 ** The xCheckReservedLock() method checks whether any database connection, | 
|         |    646 ** either in this process or in some other process, is holding a RESERVED, | 
|         |    647 ** PENDING, or EXCLUSIVE lock on the file.  It returns true | 
|         |    648 ** if such a lock exists and false otherwise. | 
|         |    649 ** | 
|         |    650 ** The xFileControl() method is a generic interface that allows custom | 
|         |    651 ** VFS implementations to directly control an open file using the | 
|         |    652 ** [sqlite3_file_control()] interface.  The second "op" argument is an | 
|         |    653 ** integer opcode.  The third argument is a generic pointer intended to | 
|         |    654 ** point to a structure that may contain arguments or space in which to | 
|         |    655 ** write return values.  Potential uses for xFileControl() might be | 
|         |    656 ** functions to enable blocking locks with timeouts, to change the | 
|         |    657 ** locking strategy (for example to use dot-file locks), to inquire | 
|         |    658 ** about the status of a lock, or to break stale locks.  The SQLite | 
|         |    659 ** core reserves all opcodes less than 100 for its own use. | 
|         |    660 ** A [SQLITE_FCNTL_LOCKSTATE | list of opcodes] less than 100 is available. | 
|         |    661 ** Applications that define a custom xFileControl method should use opcodes | 
|         |    662 ** greater than 100 to avoid conflicts. | 
|         |    663 ** | 
|         |    664 ** The xSectorSize() method returns the sector size of the | 
|         |    665 ** device that underlies the file.  The sector size is the | 
|         |    666 ** minimum write that can be performed without disturbing | 
|         |    667 ** other bytes in the file.  The xDeviceCharacteristics() | 
|         |    668 ** method returns a bit vector describing behaviors of the | 
|         |    669 ** underlying device: | 
|         |    670 ** | 
|         |    671 ** <ul> | 
|         |    672 ** <li> [SQLITE_IOCAP_ATOMIC] | 
|         |    673 ** <li> [SQLITE_IOCAP_ATOMIC512] | 
|         |    674 ** <li> [SQLITE_IOCAP_ATOMIC1K] | 
|         |    675 ** <li> [SQLITE_IOCAP_ATOMIC2K] | 
|         |    676 ** <li> [SQLITE_IOCAP_ATOMIC4K] | 
|         |    677 ** <li> [SQLITE_IOCAP_ATOMIC8K] | 
|         |    678 ** <li> [SQLITE_IOCAP_ATOMIC16K] | 
|         |    679 ** <li> [SQLITE_IOCAP_ATOMIC32K] | 
|         |    680 ** <li> [SQLITE_IOCAP_ATOMIC64K] | 
|         |    681 ** <li> [SQLITE_IOCAP_SAFE_APPEND] | 
|         |    682 ** <li> [SQLITE_IOCAP_SEQUENTIAL] | 
|         |    683 ** </ul> | 
|         |    684 ** | 
|         |    685 ** The SQLITE_IOCAP_ATOMIC property means that all writes of | 
|         |    686 ** any size are atomic.  The SQLITE_IOCAP_ATOMICnnn values | 
|         |    687 ** mean that writes of blocks that are nnn bytes in size and | 
|         |    688 ** are aligned to an address which is an integer multiple of | 
|         |    689 ** nnn are atomic.  The SQLITE_IOCAP_SAFE_APPEND value means | 
|         |    690 ** that when data is appended to a file, the data is appended | 
|         |    691 ** first then the size of the file is extended, never the other | 
|         |    692 ** way around.  The SQLITE_IOCAP_SEQUENTIAL property means that | 
|         |    693 ** information is written to disk in the same order as calls | 
|         |    694 ** to xWrite(). | 
|         |    695 */ | 
|         |    696 typedef struct sqlite3_io_methods sqlite3_io_methods; | 
|         |    697 struct sqlite3_io_methods { | 
|         |    698   int iVersion; | 
|         |    699   int (*xClose)(sqlite3_file*); | 
|         |    700   int (*xRead)(sqlite3_file*, void*, int iAmt, sqlite3_int64 iOfst); | 
|         |    701   int (*xWrite)(sqlite3_file*, const void*, int iAmt, sqlite3_int64 iOfst); | 
|         |    702   int (*xTruncate)(sqlite3_file*, sqlite3_int64 size); | 
|         |    703   int (*xSync)(sqlite3_file*, int flags); | 
|         |    704   int (*xFileSize)(sqlite3_file*, sqlite3_int64 *pSize); | 
|         |    705   int (*xLock)(sqlite3_file*, int); | 
|         |    706   int (*xUnlock)(sqlite3_file*, int); | 
|         |    707   int (*xCheckReservedLock)(sqlite3_file*, int *pResOut); | 
|         |    708   int (*xFileControl)(sqlite3_file*, int op, void *pArg); | 
|         |    709   int (*xSectorSize)(sqlite3_file*); | 
|         |    710   int (*xDeviceCharacteristics)(sqlite3_file*); | 
|         |    711   /* Additional methods may be added in future releases */ | 
|         |    712 }; | 
|         |    713  | 
|         |    714 /* | 
|         |    715 ** CAPI3REF: Standard File Control Opcodes {H11310} <S30800> | 
|         |    716 ** | 
|         |    717 ** These integer constants are opcodes for the xFileControl method | 
|         |    718 ** of the [sqlite3_io_methods] object and for the [sqlite3_file_control()] | 
|         |    719 ** interface. | 
|         |    720 ** | 
|         |    721 ** The [SQLITE_FCNTL_LOCKSTATE] opcode is used for debugging.  This | 
|         |    722 ** opcode causes the xFileControl method to write the current state of | 
|         |    723 ** the lock (one of [SQLITE_LOCK_NONE], [SQLITE_LOCK_SHARED], | 
|         |    724 ** [SQLITE_LOCK_RESERVED], [SQLITE_LOCK_PENDING], or [SQLITE_LOCK_EXCLUSIVE]) | 
|         |    725 ** into an integer that the pArg argument points to. This capability | 
|         |    726 ** is used during testing and only needs to be supported when SQLITE_TEST | 
|         |    727 ** is defined. | 
|         |    728 */ | 
|         |    729 #define SQLITE_FCNTL_LOCKSTATE        1 | 
|         |    730  | 
|         |    731 /* | 
|         |    732 ** CAPI3REF: Mutex Handle {H17110} <S20130> | 
|         |    733 ** | 
|         |    734 ** The mutex module within SQLite defines [sqlite3_mutex] to be an | 
|         |    735 ** abstract type for a mutex object.  The SQLite core never looks | 
|         |    736 ** at the internal representation of an [sqlite3_mutex].  It only | 
|         |    737 ** deals with pointers to the [sqlite3_mutex] object. | 
|         |    738 ** | 
|         |    739 ** Mutexes are created using [sqlite3_mutex_alloc()]. | 
|         |    740 */ | 
|         |    741 typedef struct sqlite3_mutex sqlite3_mutex; | 
|         |    742  | 
|         |    743 /* | 
|         |    744 ** CAPI3REF: OS Interface Object {H11140} <S20100> | 
|         |    745 ** | 
|         |    746 ** An instance of the sqlite3_vfs object defines the interface between | 
|         |    747 ** the SQLite core and the underlying operating system.  The "vfs" | 
|         |    748 ** in the name of the object stands for "virtual file system". | 
|         |    749 ** | 
|         |    750 ** The value of the iVersion field is initially 1 but may be larger in | 
|         |    751 ** future versions of SQLite.  Additional fields may be appended to this | 
|         |    752 ** object when the iVersion value is increased.  Note that the structure | 
|         |    753 ** of the sqlite3_vfs object changes in the transaction between | 
|         |    754 ** SQLite version 3.5.9 and 3.6.0 and yet the iVersion field was not | 
|         |    755 ** modified. | 
|         |    756 ** | 
|         |    757 ** The szOsFile field is the size of the subclassed [sqlite3_file] | 
|         |    758 ** structure used by this VFS.  mxPathname is the maximum length of | 
|         |    759 ** a pathname in this VFS. | 
|         |    760 ** | 
|         |    761 ** Registered sqlite3_vfs objects are kept on a linked list formed by | 
|         |    762 ** the pNext pointer.  The [sqlite3_vfs_register()] | 
|         |    763 ** and [sqlite3_vfs_unregister()] interfaces manage this list | 
|         |    764 ** in a thread-safe way.  The [sqlite3_vfs_find()] interface | 
|         |    765 ** searches the list.  Neither the application code nor the VFS | 
|         |    766 ** implementation should use the pNext pointer. | 
|         |    767 ** | 
|         |    768 ** The pNext field is the only field in the sqlite3_vfs | 
|         |    769 ** structure that SQLite will ever modify.  SQLite will only access | 
|         |    770 ** or modify this field while holding a particular static mutex. | 
|         |    771 ** The application should never modify anything within the sqlite3_vfs | 
|         |    772 ** object once the object has been registered. | 
|         |    773 ** | 
|         |    774 ** The zName field holds the name of the VFS module.  The name must | 
|         |    775 ** be unique across all VFS modules. | 
|         |    776 ** | 
|         |    777 ** {H11141} SQLite will guarantee that the zFilename parameter to xOpen | 
|         |    778 ** is either a NULL pointer or string obtained | 
|         |    779 ** from xFullPathname().  SQLite further guarantees that | 
|         |    780 ** the string will be valid and unchanged until xClose() is | 
|         |    781 ** called. {END}  Because of the previous sentense, | 
|         |    782 ** the [sqlite3_file] can safely store a pointer to the | 
|         |    783 ** filename if it needs to remember the filename for some reason. | 
|         |    784 ** If the zFilename parameter is xOpen is a NULL pointer then xOpen | 
|         |    785 ** must invite its own temporary name for the file.  Whenever the  | 
|         |    786 ** xFilename parameter is NULL it will also be the case that the | 
|         |    787 ** flags parameter will include [SQLITE_OPEN_DELETEONCLOSE]. | 
|         |    788 ** | 
|         |    789 ** {H11142} The flags argument to xOpen() includes all bits set in | 
|         |    790 ** the flags argument to [sqlite3_open_v2()].  Or if [sqlite3_open()] | 
|         |    791 ** or [sqlite3_open16()] is used, then flags includes at least | 
|         |    792 ** [SQLITE_OPEN_READWRITE] | [SQLITE_OPEN_CREATE]. {END} | 
|         |    793 ** If xOpen() opens a file read-only then it sets *pOutFlags to | 
|         |    794 ** include [SQLITE_OPEN_READONLY].  Other bits in *pOutFlags may be set. | 
|         |    795 ** | 
|         |    796 ** {H11143} SQLite will also add one of the following flags to the xOpen() | 
|         |    797 ** call, depending on the object being opened: | 
|         |    798 ** | 
|         |    799 ** <ul> | 
|         |    800 ** <li>  [SQLITE_OPEN_MAIN_DB] | 
|         |    801 ** <li>  [SQLITE_OPEN_MAIN_JOURNAL] | 
|         |    802 ** <li>  [SQLITE_OPEN_TEMP_DB] | 
|         |    803 ** <li>  [SQLITE_OPEN_TEMP_JOURNAL] | 
|         |    804 ** <li>  [SQLITE_OPEN_TRANSIENT_DB] | 
|         |    805 ** <li>  [SQLITE_OPEN_SUBJOURNAL] | 
|         |    806 ** <li>  [SQLITE_OPEN_MASTER_JOURNAL] | 
|         |    807 ** </ul> {END} | 
|         |    808 ** | 
|         |    809 ** The file I/O implementation can use the object type flags to | 
|         |    810 ** change the way it deals with files.  For example, an application | 
|         |    811 ** that does not care about crash recovery or rollback might make | 
|         |    812 ** the open of a journal file a no-op.  Writes to this journal would | 
|         |    813 ** also be no-ops, and any attempt to read the journal would return | 
|         |    814 ** SQLITE_IOERR.  Or the implementation might recognize that a database | 
|         |    815 ** file will be doing page-aligned sector reads and writes in a random | 
|         |    816 ** order and set up its I/O subsystem accordingly. | 
|         |    817 ** | 
|         |    818 ** SQLite might also add one of the following flags to the xOpen method: | 
|         |    819 ** | 
|         |    820 ** <ul> | 
|         |    821 ** <li> [SQLITE_OPEN_DELETEONCLOSE] | 
|         |    822 ** <li> [SQLITE_OPEN_EXCLUSIVE] | 
|         |    823 ** </ul> | 
|         |    824 ** | 
|         |    825 ** {H11145} The [SQLITE_OPEN_DELETEONCLOSE] flag means the file should be | 
|         |    826 ** deleted when it is closed.  {H11146} The [SQLITE_OPEN_DELETEONCLOSE] | 
|         |    827 ** will be set for TEMP  databases, journals and for subjournals. | 
|         |    828 ** | 
|         |    829 ** {H11147} The [SQLITE_OPEN_EXCLUSIVE] flag means the file should be opened | 
|         |    830 ** for exclusive access.  This flag is set for all files except | 
|         |    831 ** for the main database file. | 
|         |    832 ** | 
|         |    833 ** {H11148} At least szOsFile bytes of memory are allocated by SQLite | 
|         |    834 ** to hold the  [sqlite3_file] structure passed as the third | 
|         |    835 ** argument to xOpen. {END}  The xOpen method does not have to | 
|         |    836 ** allocate the structure; it should just fill it in. | 
|         |    837 ** | 
|         |    838 ** {H11149} The flags argument to xAccess() may be [SQLITE_ACCESS_EXISTS] | 
|         |    839 ** to test for the existence of a file, or [SQLITE_ACCESS_READWRITE] to | 
|         |    840 ** test whether a file is readable and writable, or [SQLITE_ACCESS_READ] | 
|         |    841 ** to test whether a file is at least readable. {END}  The file can be a | 
|         |    842 ** directory. | 
|         |    843 ** | 
|         |    844 ** {H11150} SQLite will always allocate at least mxPathname+1 bytes for the | 
|         |    845 ** output buffer xFullPathname. {H11151} The exact size of the output buffer | 
|         |    846 ** is also passed as a parameter to both  methods. {END}  If the output buffer | 
|         |    847 ** is not large enough, [SQLITE_CANTOPEN] should be returned. Since this is | 
|         |    848 ** handled as a fatal error by SQLite, vfs implementations should endeavor | 
|         |    849 ** to prevent this by setting mxPathname to a sufficiently large value. | 
|         |    850 ** | 
|         |    851 ** The xRandomness(), xSleep(), and xCurrentTime() interfaces | 
|         |    852 ** are not strictly a part of the filesystem, but they are | 
|         |    853 ** included in the VFS structure for completeness. | 
|         |    854 ** The xRandomness() function attempts to return nBytes bytes | 
|         |    855 ** of good-quality randomness into zOut.  The return value is | 
|         |    856 ** the actual number of bytes of randomness obtained. | 
|         |    857 ** The xSleep() method causes the calling thread to sleep for at | 
|         |    858 ** least the number of microseconds given.  The xCurrentTime() | 
|         |    859 ** method returns a Julian Day Number for the current date and time. | 
|         |    860 */ | 
|         |    861 typedef struct sqlite3_vfs sqlite3_vfs; | 
|         |    862 struct sqlite3_vfs { | 
|         |    863   int iVersion;            /* Structure version number */ | 
|         |    864   int szOsFile;            /* Size of subclassed sqlite3_file */ | 
|         |    865   int mxPathname;          /* Maximum file pathname length */ | 
|         |    866   sqlite3_vfs *pNext;      /* Next registered VFS */ | 
|         |    867   const char *zName;       /* Name of this virtual file system */ | 
|         |    868   void *pAppData;          /* Pointer to application-specific data */ | 
|         |    869   int (*xOpen)(sqlite3_vfs*, const char *zName, sqlite3_file*, | 
|         |    870                int flags, int *pOutFlags); | 
|         |    871   int (*xDelete)(sqlite3_vfs*, const char *zName, int syncDir); | 
|         |    872   int (*xAccess)(sqlite3_vfs*, const char *zName, int flags, int *pResOut); | 
|         |    873   int (*xFullPathname)(sqlite3_vfs*, const char *zName, int nOut, char *zOut); | 
|         |    874   void *(*xDlOpen)(sqlite3_vfs*, const char *zFilename); | 
|         |    875   void (*xDlError)(sqlite3_vfs*, int nByte, char *zErrMsg); | 
|         |    876   void *(*xDlSym)(sqlite3_vfs*,void*, const char *zSymbol); | 
|         |    877   void (*xDlClose)(sqlite3_vfs*, void*); | 
|         |    878   int (*xRandomness)(sqlite3_vfs*, int nByte, char *zOut); | 
|         |    879   int (*xSleep)(sqlite3_vfs*, int microseconds); | 
|         |    880   int (*xCurrentTime)(sqlite3_vfs*, double*); | 
|         |    881   int (*xGetLastError)(sqlite3_vfs*, int, char *); | 
|         |    882   /* New fields may be appended in figure versions.  The iVersion | 
|         |    883   ** value will increment whenever this happens. */ | 
|         |    884 }; | 
|         |    885  | 
|         |    886 /* | 
|         |    887 ** CAPI3REF: Flags for the xAccess VFS method {H11190} <H11140> | 
|         |    888 ** | 
|         |    889 ** {H11191} These integer constants can be used as the third parameter to | 
|         |    890 ** the xAccess method of an [sqlite3_vfs] object. {END}  They determine | 
|         |    891 ** what kind of permissions the xAccess method is looking for. | 
|         |    892 ** {H11192} With SQLITE_ACCESS_EXISTS, the xAccess method | 
|         |    893 ** simply checks whether the file exists. | 
|         |    894 ** {H11193} With SQLITE_ACCESS_READWRITE, the xAccess method | 
|         |    895 ** checks whether the file is both readable and writable. | 
|         |    896 ** {H11194} With SQLITE_ACCESS_READ, the xAccess method | 
|         |    897 ** checks whether the file is readable. | 
|         |    898 */ | 
|         |    899 #define SQLITE_ACCESS_EXISTS    0 | 
|         |    900 #define SQLITE_ACCESS_READWRITE 1 | 
|         |    901 #define SQLITE_ACCESS_READ      2 | 
|         |    902  | 
|         |    903 /* | 
|         |    904 ** CAPI3REF: Initialize The SQLite Library {H10130} <S20000><S30100> | 
|         |    905 ** | 
|         |    906 ** The sqlite3_initialize() routine initializes the | 
|         |    907 ** SQLite library.  The sqlite3_shutdown() routine | 
|         |    908 ** deallocates any resources that were allocated by sqlite3_initialize(). | 
|         |    909 ** | 
|         |    910 ** A call to sqlite3_initialize() is an "effective" call if it is | 
|         |    911 ** the first time sqlite3_initialize() is invoked during the lifetime of | 
|         |    912 ** the process, or if it is the first time sqlite3_initialize() is invoked | 
|         |    913 ** following a call to sqlite3_shutdown().  Only an effective call | 
|         |    914 ** of sqlite3_initialize() does any initialization.  All other calls | 
|         |    915 ** are harmless no-ops. | 
|         |    916 ** | 
|         |    917 ** Among other things, sqlite3_initialize() shall invoke | 
|         |    918 ** sqlite3_os_init().  Similarly, sqlite3_shutdown() | 
|         |    919 ** shall invoke sqlite3_os_end(). | 
|         |    920 ** | 
|         |    921 ** The sqlite3_initialize() routine returns SQLITE_OK on success. | 
|         |    922 ** If for some reason, sqlite3_initialize() is unable to initialize | 
|         |    923 ** the library (perhaps it is unable to allocate a needed resource such | 
|         |    924 ** as a mutex) it returns an [error code] other than SQLITE_OK. | 
|         |    925 ** | 
|         |    926 ** The sqlite3_initialize() routine is called internally by many other | 
|         |    927 ** SQLite interfaces so that an application usually does not need to | 
|         |    928 ** invoke sqlite3_initialize() directly.  For example, [sqlite3_open()] | 
|         |    929 ** calls sqlite3_initialize() so the SQLite library will be automatically | 
|         |    930 ** initialized when [sqlite3_open()] is called if it has not be initialized | 
|         |    931 ** already.  However, if SQLite is compiled with the SQLITE_OMIT_AUTOINIT | 
|         |    932 ** compile-time option, then the automatic calls to sqlite3_initialize() | 
|         |    933 ** are omitted and the application must call sqlite3_initialize() directly | 
|         |    934 ** prior to using any other SQLite interface.  For maximum portability, | 
|         |    935 ** it is recommended that applications always invoke sqlite3_initialize() | 
|         |    936 ** directly prior to using any other SQLite interface.  Future releases | 
|         |    937 ** of SQLite may require this.  In other words, the behavior exhibited | 
|         |    938 ** when SQLite is compiled with SQLITE_OMIT_AUTOINIT might become the | 
|         |    939 ** default behavior in some future release of SQLite. | 
|         |    940 ** | 
|         |    941 ** The sqlite3_os_init() routine does operating-system specific | 
|         |    942 ** initialization of the SQLite library.  The sqlite3_os_end() | 
|         |    943 ** routine undoes the effect of sqlite3_os_init().  Typical tasks | 
|         |    944 ** performed by these routines include allocation or deallocation | 
|         |    945 ** of static resources, initialization of global variables, | 
|         |    946 ** setting up a default [sqlite3_vfs] module, or setting up | 
|         |    947 ** a default configuration using [sqlite3_config()]. | 
|         |    948 ** | 
|         |    949 ** The application should never invoke either sqlite3_os_init() | 
|         |    950 ** or sqlite3_os_end() directly.  The application should only invoke | 
|         |    951 ** sqlite3_initialize() and sqlite3_shutdown().  The sqlite3_os_init() | 
|         |    952 ** interface is called automatically by sqlite3_initialize() and | 
|         |    953 ** sqlite3_os_end() is called by sqlite3_shutdown().  Appropriate | 
|         |    954 ** implementations for sqlite3_os_init() and sqlite3_os_end() | 
|         |    955 ** are built into SQLite when it is compiled for unix, windows, or os/2. | 
|         |    956 ** When built for other platforms (using the SQLITE_OS_OTHER=1 compile-time | 
|         |    957 ** option) the application must supply a suitable implementation for | 
|         |    958 ** sqlite3_os_init() and sqlite3_os_end().  An application-supplied | 
|         |    959 ** implementation of sqlite3_os_init() or sqlite3_os_end() | 
|         |    960 ** must return SQLITE_OK on success and some other [error code] upon | 
|         |    961 ** failure. | 
|         |    962 */ | 
|         |    963 IMPORT_C int sqlite3_initialize(void); | 
|         |    964 IMPORT_C int sqlite3_shutdown(void); | 
|         |    965 IMPORT_C int sqlite3_os_init(void); | 
|         |    966 IMPORT_C int sqlite3_os_end(void); | 
|         |    967  | 
|         |    968 /* | 
|         |    969 ** CAPI3REF: Configuring The SQLite Library {H10145} <S20000><S30200> | 
|         |    970 ** EXPERIMENTAL | 
|         |    971 ** | 
|         |    972 ** The sqlite3_config() interface is used to make global configuration | 
|         |    973 ** changes to SQLite in order to tune SQLite to the specific needs of | 
|         |    974 ** the application.  The default configuration is recommended for most | 
|         |    975 ** applications and so this routine is usually not necessary.  It is | 
|         |    976 ** provided to support rare applications with unusual needs. | 
|         |    977 ** | 
|         |    978 ** The sqlite3_config() interface is not threadsafe.  The application | 
|         |    979 ** must insure that no other SQLite interfaces are invoked by other | 
|         |    980 ** threads while sqlite3_config() is running.  Furthermore, sqlite3_config() | 
|         |    981 ** may only be invoked prior to library initialization using | 
|         |    982 ** [sqlite3_initialize()] or after shutdown by [sqlite3_shutdown()]. | 
|         |    983 ** Note, however, that sqlite3_config() can be called as part of the | 
|         |    984 ** implementation of an application-defined [sqlite3_os_init()]. | 
|         |    985 ** | 
|         |    986 ** The first argument to sqlite3_config() is an integer | 
|         |    987 ** [SQLITE_CONFIG_SINGLETHREAD | configuration option] that determines | 
|         |    988 ** what property of SQLite is to be configured.  Subsequent arguments | 
|         |    989 ** vary depending on the [SQLITE_CONFIG_SINGLETHREAD | configuration option] | 
|         |    990 ** in the first argument. | 
|         |    991 ** | 
|         |    992 ** When a configuration option is set, sqlite3_config() returns SQLITE_OK. | 
|         |    993 ** If the option is unknown or SQLite is unable to set the option | 
|         |    994 ** then this routine returns a non-zero [error code]. | 
|         |    995 */ | 
|         |    996 IMPORT_C int sqlite3_config(int, ...); | 
|         |    997  | 
|         |    998 /* | 
|         |    999 ** CAPI3REF: Configure database connections  {H10180} <S20000> | 
|         |   1000 ** EXPERIMENTAL | 
|         |   1001 ** | 
|         |   1002 ** The sqlite3_db_config() interface is used to make configuration | 
|         |   1003 ** changes to a [database connection].  The interface is similar to | 
|         |   1004 ** [sqlite3_config()] except that the changes apply to a single | 
|         |   1005 ** [database connection] (specified in the first argument).  The | 
|         |   1006 ** sqlite3_db_config() interface can only be used immediately after | 
|         |   1007 ** the database connection is created using [sqlite3_open()], | 
|         |   1008 ** [sqlite3_open16()], or [sqlite3_open_v2()].   | 
|         |   1009 ** | 
|         |   1010 ** The second argument to sqlite3_db_config(D,V,...)  is the | 
|         |   1011 ** configuration verb - an integer code that indicates what | 
|         |   1012 ** aspect of the [database connection] is being configured. | 
|         |   1013 ** The only choice for this value is [SQLITE_DBCONFIG_LOOKASIDE]. | 
|         |   1014 ** New verbs are likely to be added in future releases of SQLite. | 
|         |   1015 ** Additional arguments depend on the verb. | 
|         |   1016 */ | 
|         |   1017 IMPORT_C int sqlite3_db_config(sqlite3*, int op, ...); | 
|         |   1018  | 
|         |   1019 /* | 
|         |   1020 ** CAPI3REF: Memory Allocation Routines {H10155} <S20120> | 
|         |   1021 ** EXPERIMENTAL | 
|         |   1022 ** | 
|         |   1023 ** An instance of this object defines the interface between SQLite | 
|         |   1024 ** and low-level memory allocation routines. | 
|         |   1025 ** | 
|         |   1026 ** This object is used in only one place in the SQLite interface. | 
|         |   1027 ** A pointer to an instance of this object is the argument to | 
|         |   1028 ** [sqlite3_config()] when the configuration option is | 
|         |   1029 ** [SQLITE_CONFIG_MALLOC].  By creating an instance of this object | 
|         |   1030 ** and passing it to [sqlite3_config()] during configuration, an | 
|         |   1031 ** application can specify an alternative memory allocation subsystem | 
|         |   1032 ** for SQLite to use for all of its dynamic memory needs. | 
|         |   1033 ** | 
|         |   1034 ** Note that SQLite comes with a built-in memory allocator that is | 
|         |   1035 ** perfectly adequate for the overwhelming majority of applications | 
|         |   1036 ** and that this object is only useful to a tiny minority of applications | 
|         |   1037 ** with specialized memory allocation requirements.  This object is | 
|         |   1038 ** also used during testing of SQLite in order to specify an alternative | 
|         |   1039 ** memory allocator that simulates memory out-of-memory conditions in | 
|         |   1040 ** order to verify that SQLite recovers gracefully from such | 
|         |   1041 ** conditions. | 
|         |   1042 ** | 
|         |   1043 ** The xMalloc, xFree, and xRealloc methods must work like the | 
|         |   1044 ** malloc(), free(), and realloc() functions from the standard library. | 
|         |   1045 ** | 
|         |   1046 ** xSize should return the allocated size of a memory allocation | 
|         |   1047 ** previously obtained from xMalloc or xRealloc.  The allocated size | 
|         |   1048 ** is always at least as big as the requested size but may be larger. | 
|         |   1049 ** | 
|         |   1050 ** The xRoundup method returns what would be the allocated size of | 
|         |   1051 ** a memory allocation given a particular requested size.  Most memory | 
|         |   1052 ** allocators round up memory allocations at least to the next multiple | 
|         |   1053 ** of 8.  Some allocators round up to a larger multiple or to a power of 2. | 
|         |   1054 ** | 
|         |   1055 ** The xInit method initializes the memory allocator.  (For example, | 
|         |   1056 ** it might allocate any require mutexes or initialize internal data | 
|         |   1057 ** structures.  The xShutdown method is invoked (indirectly) by | 
|         |   1058 ** [sqlite3_shutdown()] and should deallocate any resources acquired | 
|         |   1059 ** by xInit.  The pAppData pointer is used as the only parameter to | 
|         |   1060 ** xInit and xShutdown. | 
|         |   1061 */ | 
|         |   1062 typedef struct sqlite3_mem_methods sqlite3_mem_methods; | 
|         |   1063 struct sqlite3_mem_methods { | 
|         |   1064   void *(*xMalloc)(int);         /* Memory allocation function */ | 
|         |   1065   void (*xFree)(void*);          /* Free a prior allocation */ | 
|         |   1066   void *(*xRealloc)(void*,int);  /* Resize an allocation */ | 
|         |   1067   int (*xSize)(void*);           /* Return the size of an allocation */ | 
|         |   1068   int (*xRoundup)(int);          /* Round up request size to allocation size */ | 
|         |   1069   int (*xInit)(void*);           /* Initialize the memory allocator */ | 
|         |   1070   void (*xShutdown)(void*);      /* Deinitialize the memory allocator */ | 
|         |   1071   void *pAppData;                /* Argument to xInit() and xShutdown() */ | 
|         |   1072 }; | 
|         |   1073  | 
|         |   1074 /* | 
|         |   1075 ** CAPI3REF: Configuration Options {H10160} <S20000> | 
|         |   1076 ** EXPERIMENTAL | 
|         |   1077 ** | 
|         |   1078 ** These constants are the available integer configuration options that | 
|         |   1079 ** can be passed as the first argument to the [sqlite3_config()] interface. | 
|         |   1080 ** | 
|         |   1081 ** New configuration options may be added in future releases of SQLite. | 
|         |   1082 ** Existing configuration options might be discontinued.  Applications | 
|         |   1083 ** should check the return code from [sqlite3_config()] to make sure that | 
|         |   1084 ** the call worked.  The [sqlite3_config()] interface will return a | 
|         |   1085 ** non-zero [error code] if a discontinued or unsupported configuration option | 
|         |   1086 ** is invoked. | 
|         |   1087 ** | 
|         |   1088 ** <dl> | 
|         |   1089 ** <dt>SQLITE_CONFIG_SINGLETHREAD</dt> | 
|         |   1090 ** <dd>There are no arguments to this option.  This option disables | 
|         |   1091 ** all mutexing and puts SQLite into a mode where it can only be used | 
|         |   1092 ** by a single thread.</dd> | 
|         |   1093 ** | 
|         |   1094 ** <dt>SQLITE_CONFIG_MULTITHREAD</dt> | 
|         |   1095 ** <dd>There are no arguments to this option.  This option disables | 
|         |   1096 ** mutexing on [database connection] and [prepared statement] objects. | 
|         |   1097 ** The application is responsible for serializing access to | 
|         |   1098 ** [database connections] and [prepared statements].  But other mutexes | 
|         |   1099 ** are enabled so that SQLite will be safe to use in a multi-threaded | 
|         |   1100 ** environment as long as no two threads attempt to use the same | 
|         |   1101 ** [database connection] at the same time.  See the [threading mode] | 
|         |   1102 ** documentation for additional information.</dd> | 
|         |   1103 ** | 
|         |   1104 ** <dt>SQLITE_CONFIG_SERIALIZED</dt> | 
|         |   1105 ** <dd>There are no arguments to this option.  This option enables | 
|         |   1106 ** all mutexes including the recursive | 
|         |   1107 ** mutexes on [database connection] and [prepared statement] objects. | 
|         |   1108 ** In this mode (which is the default when SQLite is compiled with | 
|         |   1109 ** [SQLITE_THREADSAFE=1]) the SQLite library will itself serialize access | 
|         |   1110 ** to [database connections] and [prepared statements] so that the | 
|         |   1111 ** application is free to use the same [database connection] or the | 
|         |   1112 ** same [prepared statement] in different threads at the same time. | 
|         |   1113 ** See the [threading mode] documentation for additional information.</dd> | 
|         |   1114 ** | 
|         |   1115 ** <dt>SQLITE_CONFIG_MALLOC</dt> | 
|         |   1116 ** <dd>This option takes a single argument which is a pointer to an | 
|         |   1117 ** instance of the [sqlite3_mem_methods] structure.  The argument specifies | 
|         |   1118 ** alternative low-level memory allocation routines to be used in place of | 
|         |   1119 ** the memory allocation routines built into SQLite.</dd> | 
|         |   1120 ** | 
|         |   1121 ** <dt>SQLITE_CONFIG_GETMALLOC</dt> | 
|         |   1122 ** <dd>This option takes a single argument which is a pointer to an | 
|         |   1123 ** instance of the [sqlite3_mem_methods] structure.  The [sqlite3_mem_methods] | 
|         |   1124 ** structure is filled with the currently defined memory allocation routines. | 
|         |   1125 ** This option can be used to overload the default memory allocation | 
|         |   1126 ** routines with a wrapper that simulations memory allocation failure or | 
|         |   1127 ** tracks memory usage, for example.</dd> | 
|         |   1128 ** | 
|         |   1129 ** <dt>SQLITE_CONFIG_MEMSTATUS</dt> | 
|         |   1130 ** <dd>This option takes single argument of type int, interpreted as a  | 
|         |   1131 ** boolean, which enables or disables the collection of memory allocation  | 
|         |   1132 ** statistics. When disabled, the following SQLite interfaces become  | 
|         |   1133 ** non-operational: | 
|         |   1134 **   <ul> | 
|         |   1135 **   <li> [sqlite3_memory_used()] | 
|         |   1136 **   <li> [sqlite3_memory_highwater()] | 
|         |   1137 **   <li> [sqlite3_soft_heap_limit()] | 
|         |   1138 **   <li> [sqlite3_status()] | 
|         |   1139 **   </ul> | 
|         |   1140 ** </dd> | 
|         |   1141 ** | 
|         |   1142 ** <dt>SQLITE_CONFIG_SCRATCH</dt> | 
|         |   1143 ** <dd>This option specifies a static memory buffer that SQLite can use for | 
|         |   1144 ** scratch memory.  There are three arguments:  A pointer to the memory, the | 
|         |   1145 ** size of each scratch buffer (sz), and the number of buffers (N).  The sz | 
|         |   1146 ** argument must be a multiple of 16. The sz parameter should be a few bytes | 
|         |   1147 ** larger than the actual scratch space required due internal overhead. | 
|         |   1148 ** The first | 
|         |   1149 ** argument should point to an allocation of at least sz*N bytes of memory. | 
|         |   1150 ** SQLite will use no more than one scratch buffer at once per thread, so | 
|         |   1151 ** N should be set to the expected maximum number of threads.  The sz | 
|         |   1152 ** parameter should be 6 times the size of the largest database page size. | 
|         |   1153 ** Scratch buffers are used as part of the btree balance operation.  If | 
|         |   1154 ** The btree balancer needs additional memory beyond what is provided by | 
|         |   1155 ** scratch buffers or if no scratch buffer space is specified, then SQLite | 
|         |   1156 ** goes to [sqlite3_malloc()] to obtain the memory it needs.</dd> | 
|         |   1157 ** | 
|         |   1158 ** <dt>SQLITE_CONFIG_PAGECACHE</dt> | 
|         |   1159 ** <dd>This option specifies a static memory buffer that SQLite can use for | 
|         |   1160 ** the database page cache.  There are three arguments: A pointer to the | 
|         |   1161 ** memory, the size of each page buffer (sz), and the number of pages (N). | 
|         |   1162 ** The sz argument must be a power of two between 512 and 32768.  The first | 
|         |   1163 ** argument should point to an allocation of at least sz*N bytes of memory. | 
|         |   1164 ** SQLite will use the memory provided by the first argument to satisfy its | 
|         |   1165 ** memory needs for the first N pages that it adds to cache.  If additional | 
|         |   1166 ** page cache memory is needed beyond what is provided by this option, then | 
|         |   1167 ** SQLite goes to [sqlite3_malloc()] for the additional storage space. | 
|         |   1168 ** The implementation might use one or more of the N buffers to hold  | 
|         |   1169 ** memory accounting information. </dd> | 
|         |   1170 ** | 
|         |   1171 ** <dt>SQLITE_CONFIG_HEAP</dt> | 
|         |   1172 ** <dd>This option specifies a static memory buffer that SQLite will use | 
|         |   1173 ** for all of its dynamic memory allocation needs beyond those provided | 
|         |   1174 ** for by [SQLITE_CONFIG_SCRATCH] and [SQLITE_CONFIG_PAGECACHE]. | 
|         |   1175 ** There are three arguments: A pointer to the memory, the number of | 
|         |   1176 ** bytes in the memory buffer, and the minimum allocation size.  If | 
|         |   1177 ** the first pointer (the memory pointer) is NULL, then SQLite reverts | 
|         |   1178 ** to using its default memory allocator (the system malloc() implementation), | 
|         |   1179 ** undoing any prior invocation of [SQLITE_CONFIG_MALLOC].  If the | 
|         |   1180 ** memory pointer is not NULL and either [SQLITE_ENABLE_MEMSYS3] or | 
|         |   1181 ** [SQLITE_ENABLE_MEMSYS5] are defined, then the alternative memory | 
|         |   1182 ** allocator is engaged to handle all of SQLites memory allocation needs.</dd> | 
|         |   1183 ** | 
|         |   1184 ** <dt>SQLITE_CONFIG_MUTEX</dt> | 
|         |   1185 ** <dd>This option takes a single argument which is a pointer to an | 
|         |   1186 ** instance of the [sqlite3_mutex_methods] structure.  The argument specifies | 
|         |   1187 ** alternative low-level mutex routines to be used in place | 
|         |   1188 ** the mutex routines built into SQLite.</dd> | 
|         |   1189 ** | 
|         |   1190 ** <dt>SQLITE_CONFIG_GETMUTEX</dt> | 
|         |   1191 ** <dd>This option takes a single argument which is a pointer to an | 
|         |   1192 ** instance of the [sqlite3_mutex_methods] structure.  The | 
|         |   1193 ** [sqlite3_mutex_methods] | 
|         |   1194 ** structure is filled with the currently defined mutex routines. | 
|         |   1195 ** This option can be used to overload the default mutex allocation | 
|         |   1196 ** routines with a wrapper used to track mutex usage for performance | 
|         |   1197 ** profiling or testing, for example.</dd> | 
|         |   1198 ** | 
|         |   1199 ** <dt>SQLITE_CONFIG_LOOKASIDE</dt> | 
|         |   1200 ** <dd>This option takes two arguments that determine the default | 
|         |   1201 ** memory allcation lookaside optimization.  The first argument is the | 
|         |   1202 ** size of each lookaside buffer slot and the second is the number of | 
|         |   1203 ** slots allocated to each database connection.</dd> | 
|         |   1204 ** | 
|         |   1205 ** </dl> | 
|         |   1206 */ | 
|         |   1207 #define SQLITE_CONFIG_SINGLETHREAD  1  /* nil */ | 
|         |   1208 #define SQLITE_CONFIG_MULTITHREAD   2  /* nil */ | 
|         |   1209 #define SQLITE_CONFIG_SERIALIZED    3  /* nil */ | 
|         |   1210 #define SQLITE_CONFIG_MALLOC        4  /* sqlite3_mem_methods* */ | 
|         |   1211 #define SQLITE_CONFIG_GETMALLOC     5  /* sqlite3_mem_methods* */ | 
|         |   1212 #define SQLITE_CONFIG_SCRATCH       6  /* void*, int sz, int N */ | 
|         |   1213 #define SQLITE_CONFIG_PAGECACHE     7  /* void*, int sz, int N */ | 
|         |   1214 #define SQLITE_CONFIG_HEAP          8  /* void*, int nByte, int min */ | 
|         |   1215 #define SQLITE_CONFIG_MEMSTATUS     9  /* boolean */ | 
|         |   1216 #define SQLITE_CONFIG_MUTEX        10  /* sqlite3_mutex_methods* */ | 
|         |   1217 #define SQLITE_CONFIG_GETMUTEX     11  /* sqlite3_mutex_methods* */ | 
|         |   1218 #define SQLITE_CONFIG_CHUNKALLOC   12  /* int threshold */ | 
|         |   1219 #define SQLITE_CONFIG_LOOKASIDE    13  /* int int */ | 
|         |   1220  | 
|         |   1221 /* | 
|         |   1222 ** CAPI3REF: Configuration Options {H10170} <S20000> | 
|         |   1223 ** EXPERIMENTAL | 
|         |   1224 ** | 
|         |   1225 ** These constants are the available integer configuration options that | 
|         |   1226 ** can be passed as the second argument to the [sqlite3_db_config()] interface. | 
|         |   1227 ** | 
|         |   1228 ** New configuration options may be added in future releases of SQLite. | 
|         |   1229 ** Existing configuration options might be discontinued.  Applications | 
|         |   1230 ** should check the return code from [sqlite3_db_config()] to make sure that | 
|         |   1231 ** the call worked.  The [sqlite3_db_config()] interface will return a | 
|         |   1232 ** non-zero [error code] if a discontinued or unsupported configuration option | 
|         |   1233 ** is invoked. | 
|         |   1234 ** | 
|         |   1235 ** <dl> | 
|         |   1236 ** <dt>SQLITE_DBCONFIG_LOOKASIDE</dt> | 
|         |   1237 ** <dd>This option takes three additional arguments that determine the  | 
|         |   1238 ** [lookaside memory allocator] configuration for the [database connection]. | 
|         |   1239 ** The first argument (the third parameter to [sqlite3_db_config()] is a | 
|         |   1240 ** pointer to a memory buffer to use for lookaside memory.  The first | 
|         |   1241 ** argument may be NULL in which case SQLite will allocate the lookaside | 
|         |   1242 ** buffer itself using [sqlite3_malloc()].  The second argument is the | 
|         |   1243 ** size of each lookaside buffer slot and the third argument is the number of | 
|         |   1244 ** slots.  The size of the buffer in the first argument must be greater than | 
|         |   1245 ** or equal to the product of the second and third arguments.</dd> | 
|         |   1246 ** | 
|         |   1247 ** </dl> | 
|         |   1248 */ | 
|         |   1249 #define SQLITE_DBCONFIG_LOOKASIDE    1001  /* void* int int */ | 
|         |   1250  | 
|         |   1251  | 
|         |   1252 /* | 
|         |   1253 ** CAPI3REF: Enable Or Disable Extended Result Codes {H12200} <S10700> | 
|         |   1254 ** | 
|         |   1255 ** The sqlite3_extended_result_codes() routine enables or disables the | 
|         |   1256 ** [extended result codes] feature of SQLite. The extended result | 
|         |   1257 ** codes are disabled by default for historical compatibility considerations. | 
|         |   1258 ** | 
|         |   1259 ** INVARIANTS: | 
|         |   1260 ** | 
|         |   1261 ** {H12201} Each new [database connection] shall have the | 
|         |   1262 **          [extended result codes] feature disabled by default. | 
|         |   1263 ** | 
|         |   1264 ** {H12202} The [sqlite3_extended_result_codes(D,F)] interface shall enable | 
|         |   1265 **          [extended result codes] for the  [database connection] D | 
|         |   1266 **          if the F parameter is true, or disable them if F is false. | 
|         |   1267 */ | 
|         |   1268 IMPORT_C int sqlite3_extended_result_codes(sqlite3*, int onoff); | 
|         |   1269  | 
|         |   1270 /* | 
|         |   1271 ** CAPI3REF: Last Insert Rowid {H12220} <S10700> | 
|         |   1272 ** | 
|         |   1273 ** Each entry in an SQLite table has a unique 64-bit signed | 
|         |   1274 ** integer key called the "rowid". The rowid is always available | 
|         |   1275 ** as an undeclared column named ROWID, OID, or _ROWID_ as long as those | 
|         |   1276 ** names are not also used by explicitly declared columns. If | 
|         |   1277 ** the table has a column of type INTEGER PRIMARY KEY then that column | 
|         |   1278 ** is another alias for the rowid. | 
|         |   1279 ** | 
|         |   1280 ** This routine returns the rowid of the most recent | 
|         |   1281 ** successful INSERT into the database from the [database connection] | 
|         |   1282 ** in the first argument.  If no successful INSERTs | 
|         |   1283 ** have ever occurred on that database connection, zero is returned. | 
|         |   1284 ** | 
|         |   1285 ** If an INSERT occurs within a trigger, then the rowid of the inserted | 
|         |   1286 ** row is returned by this routine as long as the trigger is running. | 
|         |   1287 ** But once the trigger terminates, the value returned by this routine | 
|         |   1288 ** reverts to the last value inserted before the trigger fired. | 
|         |   1289 ** | 
|         |   1290 ** An INSERT that fails due to a constraint violation is not a | 
|         |   1291 ** successful INSERT and does not change the value returned by this | 
|         |   1292 ** routine.  Thus INSERT OR FAIL, INSERT OR IGNORE, INSERT OR ROLLBACK, | 
|         |   1293 ** and INSERT OR ABORT make no changes to the return value of this | 
|         |   1294 ** routine when their insertion fails.  When INSERT OR REPLACE | 
|         |   1295 ** encounters a constraint violation, it does not fail.  The | 
|         |   1296 ** INSERT continues to completion after deleting rows that caused | 
|         |   1297 ** the constraint problem so INSERT OR REPLACE will always change | 
|         |   1298 ** the return value of this interface. | 
|         |   1299 ** | 
|         |   1300 ** For the purposes of this routine, an INSERT is considered to | 
|         |   1301 ** be successful even if it is subsequently rolled back. | 
|         |   1302 ** | 
|         |   1303 ** INVARIANTS: | 
|         |   1304 ** | 
|         |   1305 ** {H12221} The [sqlite3_last_insert_rowid()] function returns the rowid | 
|         |   1306 **          of the most recent successful INSERT performed on the same | 
|         |   1307 **          [database connection] and within the same or higher level | 
|         |   1308 **          trigger context, or zero if there have been no qualifying inserts. | 
|         |   1309 ** | 
|         |   1310 ** {H12223} The [sqlite3_last_insert_rowid()] function returns the | 
|         |   1311 **          same value when called from the same trigger context | 
|         |   1312 **          immediately before and after a ROLLBACK. | 
|         |   1313 ** | 
|         |   1314 ** ASSUMPTIONS: | 
|         |   1315 ** | 
|         |   1316 ** {A12232} If a separate thread performs a new INSERT on the same | 
|         |   1317 **          database connection while the [sqlite3_last_insert_rowid()] | 
|         |   1318 **          function is running and thus changes the last insert rowid, | 
|         |   1319 **          then the value returned by [sqlite3_last_insert_rowid()] is | 
|         |   1320 **          unpredictable and might not equal either the old or the new | 
|         |   1321 **          last insert rowid. | 
|         |   1322 */ | 
|         |   1323 IMPORT_C sqlite3_int64 sqlite3_last_insert_rowid(sqlite3*); | 
|         |   1324  | 
|         |   1325 /* | 
|         |   1326 ** CAPI3REF: Count The Number Of Rows Modified {H12240} <S10600> | 
|         |   1327 ** | 
|         |   1328 ** This function returns the number of database rows that were changed | 
|         |   1329 ** or inserted or deleted by the most recently completed SQL statement | 
|         |   1330 ** on the [database connection] specified by the first parameter. | 
|         |   1331 ** Only changes that are directly specified by the INSERT, UPDATE, | 
|         |   1332 ** or DELETE statement are counted.  Auxiliary changes caused by | 
|         |   1333 ** triggers are not counted. Use the [sqlite3_total_changes()] function | 
|         |   1334 ** to find the total number of changes including changes caused by triggers. | 
|         |   1335 ** | 
|         |   1336 ** A "row change" is a change to a single row of a single table | 
|         |   1337 ** caused by an INSERT, DELETE, or UPDATE statement.  Rows that | 
|         |   1338 ** are changed as side effects of REPLACE constraint resolution, | 
|         |   1339 ** rollback, ABORT processing, DROP TABLE, or by any other | 
|         |   1340 ** mechanisms do not count as direct row changes. | 
|         |   1341 ** | 
|         |   1342 ** A "trigger context" is a scope of execution that begins and | 
|         |   1343 ** ends with the script of a trigger.  Most SQL statements are | 
|         |   1344 ** evaluated outside of any trigger.  This is the "top level" | 
|         |   1345 ** trigger context.  If a trigger fires from the top level, a | 
|         |   1346 ** new trigger context is entered for the duration of that one | 
|         |   1347 ** trigger.  Subtriggers create subcontexts for their duration. | 
|         |   1348 ** | 
|         |   1349 ** Calling [sqlite3_exec()] or [sqlite3_step()] recursively does | 
|         |   1350 ** not create a new trigger context. | 
|         |   1351 ** | 
|         |   1352 ** This function returns the number of direct row changes in the | 
|         |   1353 ** most recent INSERT, UPDATE, or DELETE statement within the same | 
|         |   1354 ** trigger context. | 
|         |   1355 ** | 
|         |   1356 ** Thus, when called from the top level, this function returns the | 
|         |   1357 ** number of changes in the most recent INSERT, UPDATE, or DELETE | 
|         |   1358 ** that also occurred at the top level.  Within the body of a trigger, | 
|         |   1359 ** the sqlite3_changes() interface can be called to find the number of | 
|         |   1360 ** changes in the most recently completed INSERT, UPDATE, or DELETE | 
|         |   1361 ** statement within the body of the same trigger. | 
|         |   1362 ** However, the number returned does not include changes | 
|         |   1363 ** caused by subtriggers since those have their own context. | 
|         |   1364 ** | 
|         |   1365 ** SQLite implements the command "DELETE FROM table" without a WHERE clause | 
|         |   1366 ** by dropping and recreating the table.  (This is much faster than going | 
|         |   1367 ** through and deleting individual elements from the table.)  Because of this | 
|         |   1368 ** optimization, the deletions in "DELETE FROM table" are not row changes and | 
|         |   1369 ** will not be counted by the sqlite3_changes() or [sqlite3_total_changes()] | 
|         |   1370 ** functions, regardless of the number of elements that were originally | 
|         |   1371 ** in the table.  To get an accurate count of the number of rows deleted, use | 
|         |   1372 ** "DELETE FROM table WHERE 1" instead. | 
|         |   1373 ** | 
|         |   1374 ** INVARIANTS: | 
|         |   1375 ** | 
|         |   1376 ** {H12241} The [sqlite3_changes()] function shall return the number of | 
|         |   1377 **          row changes caused by the most recent INSERT, UPDATE, | 
|         |   1378 **          or DELETE statement on the same database connection and | 
|         |   1379 **          within the same or higher trigger context, or zero if there have | 
|         |   1380 **          not been any qualifying row changes. | 
|         |   1381 ** | 
|         |   1382 ** {H12243} Statements of the form "DELETE FROM tablename" with no | 
|         |   1383 **          WHERE clause shall cause subsequent calls to | 
|         |   1384 **          [sqlite3_changes()] to return zero, regardless of the | 
|         |   1385 **          number of rows originally in the table. | 
|         |   1386 ** | 
|         |   1387 ** ASSUMPTIONS: | 
|         |   1388 ** | 
|         |   1389 ** {A12252} If a separate thread makes changes on the same database connection | 
|         |   1390 **          while [sqlite3_changes()] is running then the value returned | 
|         |   1391 **          is unpredictable and not meaningful. | 
|         |   1392 */ | 
|         |   1393 IMPORT_C int sqlite3_changes(sqlite3*); | 
|         |   1394  | 
|         |   1395 /* | 
|         |   1396 ** CAPI3REF: Total Number Of Rows Modified {H12260} <S10600> | 
|         |   1397 ** | 
|         |   1398 ** This function returns the number of row changes caused by INSERT, | 
|         |   1399 ** UPDATE or DELETE statements since the [database connection] was opened. | 
|         |   1400 ** The count includes all changes from all trigger contexts.  However, | 
|         |   1401 ** the count does not include changes used to implement REPLACE constraints, | 
|         |   1402 ** do rollbacks or ABORT processing, or DROP table processing. | 
|         |   1403 ** The changes are counted as soon as the statement that makes them is | 
|         |   1404 ** completed (when the statement handle is passed to [sqlite3_reset()] or | 
|         |   1405 ** [sqlite3_finalize()]). | 
|         |   1406 ** | 
|         |   1407 ** SQLite implements the command "DELETE FROM table" without a WHERE clause | 
|         |   1408 ** by dropping and recreating the table.  (This is much faster than going | 
|         |   1409 ** through and deleting individual elements from the table.)  Because of this | 
|         |   1410 ** optimization, the deletions in "DELETE FROM table" are not row changes and | 
|         |   1411 ** will not be counted by the sqlite3_changes() or [sqlite3_total_changes()] | 
|         |   1412 ** functions, regardless of the number of elements that were originally | 
|         |   1413 ** in the table.  To get an accurate count of the number of rows deleted, use | 
|         |   1414 ** "DELETE FROM table WHERE 1" instead. | 
|         |   1415 ** | 
|         |   1416 ** See also the [sqlite3_changes()] interface. | 
|         |   1417 ** | 
|         |   1418 ** INVARIANTS: | 
|         |   1419 ** | 
|         |   1420 ** {H12261} The [sqlite3_total_changes()] returns the total number | 
|         |   1421 **          of row changes caused by INSERT, UPDATE, and/or DELETE | 
|         |   1422 **          statements on the same [database connection], in any | 
|         |   1423 **          trigger context, since the database connection was created. | 
|         |   1424 ** | 
|         |   1425 ** {H12263} Statements of the form "DELETE FROM tablename" with no | 
|         |   1426 **          WHERE clause shall not change the value returned | 
|         |   1427 **          by [sqlite3_total_changes()]. | 
|         |   1428 ** | 
|         |   1429 ** ASSUMPTIONS: | 
|         |   1430 ** | 
|         |   1431 ** {A12264} If a separate thread makes changes on the same database connection | 
|         |   1432 **          while [sqlite3_total_changes()] is running then the value | 
|         |   1433 **          returned is unpredictable and not meaningful. | 
|         |   1434 */ | 
|         |   1435 IMPORT_C int sqlite3_total_changes(sqlite3*); | 
|         |   1436  | 
|         |   1437 /* | 
|         |   1438 ** CAPI3REF: Interrupt A Long-Running Query {H12270} <S30500> | 
|         |   1439 ** | 
|         |   1440 ** This function causes any pending database operation to abort and | 
|         |   1441 ** return at its earliest opportunity. This routine is typically | 
|         |   1442 ** called in response to a user action such as pressing "Cancel" | 
|         |   1443 ** or Ctrl-C where the user wants a long query operation to halt | 
|         |   1444 ** immediately. | 
|         |   1445 ** | 
|         |   1446 ** It is safe to call this routine from a thread different from the | 
|         |   1447 ** thread that is currently running the database operation.  But it | 
|         |   1448 ** is not safe to call this routine with a [database connection] that | 
|         |   1449 ** is closed or might close before sqlite3_interrupt() returns. | 
|         |   1450 ** | 
|         |   1451 ** If an SQL operation is very nearly finished at the time when | 
|         |   1452 ** sqlite3_interrupt() is called, then it might not have an opportunity | 
|         |   1453 ** to be interrupted and might continue to completion. | 
|         |   1454 ** | 
|         |   1455 ** An SQL operation that is interrupted will return [SQLITE_INTERRUPT]. | 
|         |   1456 ** If the interrupted SQL operation is an INSERT, UPDATE, or DELETE | 
|         |   1457 ** that is inside an explicit transaction, then the entire transaction | 
|         |   1458 ** will be rolled back automatically. | 
|         |   1459 ** | 
|         |   1460 ** A call to sqlite3_interrupt() has no effect on SQL statements | 
|         |   1461 ** that are started after sqlite3_interrupt() returns. | 
|         |   1462 ** | 
|         |   1463 ** INVARIANTS: | 
|         |   1464 ** | 
|         |   1465 ** {H12271} The [sqlite3_interrupt()] interface will force all running | 
|         |   1466 **          SQL statements associated with the same database connection | 
|         |   1467 **          to halt after processing at most one additional row of data. | 
|         |   1468 ** | 
|         |   1469 ** {H12272} Any SQL statement that is interrupted by [sqlite3_interrupt()] | 
|         |   1470 **          will return [SQLITE_INTERRUPT]. | 
|         |   1471 ** | 
|         |   1472 ** ASSUMPTIONS: | 
|         |   1473 ** | 
|         |   1474 ** {A12279} If the database connection closes while [sqlite3_interrupt()] | 
|         |   1475 **          is running then bad things will likely happen. | 
|         |   1476 */ | 
|         |   1477 IMPORT_C void sqlite3_interrupt(sqlite3*); | 
|         |   1478  | 
|         |   1479 /* | 
|         |   1480 ** CAPI3REF: Determine If An SQL Statement Is Complete {H10510} <S70200> | 
|         |   1481 ** | 
|         |   1482 ** These routines are useful for command-line input to determine if the | 
|         |   1483 ** currently entered text seems to form complete a SQL statement or | 
|         |   1484 ** if additional input is needed before sending the text into | 
|         |   1485 ** SQLite for parsing.  These routines return true if the input string | 
|         |   1486 ** appears to be a complete SQL statement.  A statement is judged to be | 
|         |   1487 ** complete if it ends with a semicolon token and is not a fragment of a | 
|         |   1488 ** CREATE TRIGGER statement.  Semicolons that are embedded within | 
|         |   1489 ** string literals or quoted identifier names or comments are not | 
|         |   1490 ** independent tokens (they are part of the token in which they are | 
|         |   1491 ** embedded) and thus do not count as a statement terminator. | 
|         |   1492 ** | 
|         |   1493 ** These routines do not parse the SQL statements thus | 
|         |   1494 ** will not detect syntactically incorrect SQL. | 
|         |   1495 ** | 
|         |   1496 ** INVARIANTS: | 
|         |   1497 ** | 
|         |   1498 ** {H10511} A successful evaluation of [sqlite3_complete()] or | 
|         |   1499 **          [sqlite3_complete16()] functions shall | 
|         |   1500 **          return a numeric 1 if and only if the last non-whitespace | 
|         |   1501 **          token in their input is a semicolon that is not in between | 
|         |   1502 **          the BEGIN and END of a CREATE TRIGGER statement. | 
|         |   1503 ** | 
|         |   1504 ** {H10512} If a memory allocation error occurs during an invocation | 
|         |   1505 **          of [sqlite3_complete()] or [sqlite3_complete16()] then the | 
|         |   1506 **          routine shall return [SQLITE_NOMEM]. | 
|         |   1507 ** | 
|         |   1508 ** ASSUMPTIONS: | 
|         |   1509 ** | 
|         |   1510 ** {A10512} The input to [sqlite3_complete()] must be a zero-terminated | 
|         |   1511 **          UTF-8 string. | 
|         |   1512 ** | 
|         |   1513 ** {A10513} The input to [sqlite3_complete16()] must be a zero-terminated | 
|         |   1514 **          UTF-16 string in native byte order. | 
|         |   1515 */ | 
|         |   1516 IMPORT_C int sqlite3_complete(const char *sql); | 
|         |   1517 IMPORT_C int sqlite3_complete16(const void *sql); | 
|         |   1518  | 
|         |   1519 /* | 
|         |   1520 ** CAPI3REF: Register A Callback To Handle SQLITE_BUSY Errors {H12310} <S40400> | 
|         |   1521 ** | 
|         |   1522 ** This routine sets a callback function that might be invoked whenever | 
|         |   1523 ** an attempt is made to open a database table that another thread | 
|         |   1524 ** or process has locked. | 
|         |   1525 ** | 
|         |   1526 ** If the busy callback is NULL, then [SQLITE_BUSY] or [SQLITE_IOERR_BLOCKED] | 
|         |   1527 ** is returned immediately upon encountering the lock. If the busy callback | 
|         |   1528 ** is not NULL, then the callback will be invoked with two arguments. | 
|         |   1529 ** | 
|         |   1530 ** The first argument to the handler is a copy of the void* pointer which | 
|         |   1531 ** is the third argument to sqlite3_busy_handler().  The second argument to | 
|         |   1532 ** the handler callback is the number of times that the busy handler has | 
|         |   1533 ** been invoked for this locking event.  If the | 
|         |   1534 ** busy callback returns 0, then no additional attempts are made to | 
|         |   1535 ** access the database and [SQLITE_BUSY] or [SQLITE_IOERR_BLOCKED] is returned. | 
|         |   1536 ** If the callback returns non-zero, then another attempt | 
|         |   1537 ** is made to open the database for reading and the cycle repeats. | 
|         |   1538 ** | 
|         |   1539 ** The presence of a busy handler does not guarantee that it will be invoked | 
|         |   1540 ** when there is lock contention. If SQLite determines that invoking the busy | 
|         |   1541 ** handler could result in a deadlock, it will go ahead and return [SQLITE_BUSY] | 
|         |   1542 ** or [SQLITE_IOERR_BLOCKED] instead of invoking the busy handler. | 
|         |   1543 ** Consider a scenario where one process is holding a read lock that | 
|         |   1544 ** it is trying to promote to a reserved lock and | 
|         |   1545 ** a second process is holding a reserved lock that it is trying | 
|         |   1546 ** to promote to an exclusive lock.  The first process cannot proceed | 
|         |   1547 ** because it is blocked by the second and the second process cannot | 
|         |   1548 ** proceed because it is blocked by the first.  If both processes | 
|         |   1549 ** invoke the busy handlers, neither will make any progress.  Therefore, | 
|         |   1550 ** SQLite returns [SQLITE_BUSY] for the first process, hoping that this | 
|         |   1551 ** will induce the first process to release its read lock and allow | 
|         |   1552 ** the second process to proceed. | 
|         |   1553 ** | 
|         |   1554 ** The default busy callback is NULL. | 
|         |   1555 ** | 
|         |   1556 ** The [SQLITE_BUSY] error is converted to [SQLITE_IOERR_BLOCKED] | 
|         |   1557 ** when SQLite is in the middle of a large transaction where all the | 
|         |   1558 ** changes will not fit into the in-memory cache.  SQLite will | 
|         |   1559 ** already hold a RESERVED lock on the database file, but it needs | 
|         |   1560 ** to promote this lock to EXCLUSIVE so that it can spill cache | 
|         |   1561 ** pages into the database file without harm to concurrent | 
|         |   1562 ** readers.  If it is unable to promote the lock, then the in-memory | 
|         |   1563 ** cache will be left in an inconsistent state and so the error | 
|         |   1564 ** code is promoted from the relatively benign [SQLITE_BUSY] to | 
|         |   1565 ** the more severe [SQLITE_IOERR_BLOCKED].  This error code promotion | 
|         |   1566 ** forces an automatic rollback of the changes.  See the | 
|         |   1567 ** <a href="/cvstrac/wiki?p=CorruptionFollowingBusyError"> | 
|         |   1568 ** CorruptionFollowingBusyError</a> wiki page for a discussion of why | 
|         |   1569 ** this is important. | 
|         |   1570 ** | 
|         |   1571 ** There can only be a single busy handler defined for each | 
|         |   1572 ** [database connection].  Setting a new busy handler clears any | 
|         |   1573 ** previously set handler.  Note that calling [sqlite3_busy_timeout()] | 
|         |   1574 ** will also set or clear the busy handler. | 
|         |   1575 ** | 
|         |   1576 ** The busy callback should not take any actions which modify the | 
|         |   1577 ** database connection that invoked the busy handler.  Any such actions | 
|         |   1578 ** result in undefined behavior. | 
|         |   1579 **  | 
|         |   1580 ** INVARIANTS: | 
|         |   1581 ** | 
|         |   1582 ** {H12311} The [sqlite3_busy_handler(D,C,A)] function shall replace | 
|         |   1583 **          busy callback in the [database connection] D with a new | 
|         |   1584 **          a new busy handler C and application data pointer A. | 
|         |   1585 ** | 
|         |   1586 ** {H12312} Newly created [database connections] shall have a busy | 
|         |   1587 **          handler of NULL. | 
|         |   1588 ** | 
|         |   1589 ** {H12314} When two or more [database connections] share a | 
|         |   1590 **          [sqlite3_enable_shared_cache | common cache], | 
|         |   1591 **          the busy handler for the database connection currently using | 
|         |   1592 **          the cache shall be invoked when the cache encounters a lock. | 
|         |   1593 ** | 
|         |   1594 ** {H12316} If a busy handler callback returns zero, then the SQLite interface | 
|         |   1595 **          that provoked the locking event shall return [SQLITE_BUSY]. | 
|         |   1596 ** | 
|         |   1597 ** {H12318} SQLite shall invokes the busy handler with two arguments which | 
|         |   1598 **          are a copy of the pointer supplied by the 3rd parameter to | 
|         |   1599 **          [sqlite3_busy_handler()] and a count of the number of prior | 
|         |   1600 **          invocations of the busy handler for the same locking event. | 
|         |   1601 ** | 
|         |   1602 ** ASSUMPTIONS: | 
|         |   1603 ** | 
|         |   1604 ** {A12319} A busy handler must not close the database connection | 
|         |   1605 **          or [prepared statement] that invoked the busy handler. | 
|         |   1606 */ | 
|         |   1607 IMPORT_C int sqlite3_busy_handler(sqlite3*, int(*)(void*,int), void*); | 
|         |   1608  | 
|         |   1609 /* | 
|         |   1610 ** CAPI3REF: Set A Busy Timeout {H12340} <S40410> | 
|         |   1611 ** | 
|         |   1612 ** This routine sets a [sqlite3_busy_handler | busy handler] that sleeps | 
|         |   1613 ** for a specified amount of time when a table is locked.  The handler | 
|         |   1614 ** will sleep multiple times until at least "ms" milliseconds of sleeping | 
|         |   1615 ** have accumulated. {H12343} After "ms" milliseconds of sleeping, | 
|         |   1616 ** the handler returns 0 which causes [sqlite3_step()] to return | 
|         |   1617 ** [SQLITE_BUSY] or [SQLITE_IOERR_BLOCKED]. | 
|         |   1618 ** | 
|         |   1619 ** Calling this routine with an argument less than or equal to zero | 
|         |   1620 ** turns off all busy handlers. | 
|         |   1621 ** | 
|         |   1622 ** There can only be a single busy handler for a particular | 
|         |   1623 ** [database connection] any any given moment.  If another busy handler | 
|         |   1624 ** was defined  (using [sqlite3_busy_handler()]) prior to calling | 
|         |   1625 ** this routine, that other busy handler is cleared. | 
|         |   1626 ** | 
|         |   1627 ** INVARIANTS: | 
|         |   1628 ** | 
|         |   1629 ** {H12341} The [sqlite3_busy_timeout()] function shall override any prior | 
|         |   1630 **          [sqlite3_busy_timeout()] or [sqlite3_busy_handler()] setting | 
|         |   1631 **          on the same [database connection]. | 
|         |   1632 ** | 
|         |   1633 ** {H12343} If the 2nd parameter to [sqlite3_busy_timeout()] is less than | 
|         |   1634 **          or equal to zero, then the busy handler shall be cleared so that | 
|         |   1635 **          all subsequent locking events immediately return [SQLITE_BUSY]. | 
|         |   1636 ** | 
|         |   1637 ** {H12344} If the 2nd parameter to [sqlite3_busy_timeout()] is a positive | 
|         |   1638 **          number N, then a busy handler shall be set that repeatedly calls | 
|         |   1639 **          the xSleep() method in the [sqlite3_vfs | VFS interface] until | 
|         |   1640 **          either the lock clears or until the cumulative sleep time | 
|         |   1641 **          reported back by xSleep() exceeds N milliseconds. | 
|         |   1642 */ | 
|         |   1643 IMPORT_C int sqlite3_busy_timeout(sqlite3*, int ms); | 
|         |   1644  | 
|         |   1645 /* | 
|         |   1646 ** CAPI3REF: Convenience Routines For Running Queries {H12370} <S10000> | 
|         |   1647 ** | 
|         |   1648 ** Definition: A <b>result table</b> is memory data structure created by the | 
|         |   1649 ** [sqlite3_get_table()] interface.  A result table records the | 
|         |   1650 ** complete query results from one or more queries. | 
|         |   1651 ** | 
|         |   1652 ** The table conceptually has a number of rows and columns.  But | 
|         |   1653 ** these numbers are not part of the result table itself.  These | 
|         |   1654 ** numbers are obtained separately.  Let N be the number of rows | 
|         |   1655 ** and M be the number of columns. | 
|         |   1656 ** | 
|         |   1657 ** A result table is an array of pointers to zero-terminated UTF-8 strings. | 
|         |   1658 ** There are (N+1)*M elements in the array.  The first M pointers point | 
|         |   1659 ** to zero-terminated strings that  contain the names of the columns. | 
|         |   1660 ** The remaining entries all point to query results.  NULL values result | 
|         |   1661 ** in NULL pointers.  All other values are in their UTF-8 zero-terminated | 
|         |   1662 ** string representation as returned by [sqlite3_column_text()]. | 
|         |   1663 ** | 
|         |   1664 ** A result table might consist of one or more memory allocations. | 
|         |   1665 ** It is not safe to pass a result table directly to [sqlite3_free()]. | 
|         |   1666 ** A result table should be deallocated using [sqlite3_free_table()]. | 
|         |   1667 ** | 
|         |   1668 ** As an example of the result table format, suppose a query result | 
|         |   1669 ** is as follows: | 
|         |   1670 ** | 
|         |   1671 ** <blockquote><pre> | 
|         |   1672 **        Name        | Age | 
|         |   1673 **        ----------------------- | 
|         |   1674 **        Alice       | 43 | 
|         |   1675 **        Bob         | 28 | 
|         |   1676 **        Cindy       | 21 | 
|         |   1677 ** </pre></blockquote> | 
|         |   1678 ** | 
|         |   1679 ** There are two column (M==2) and three rows (N==3).  Thus the | 
|         |   1680 ** result table has 8 entries.  Suppose the result table is stored | 
|         |   1681 ** in an array names azResult.  Then azResult holds this content: | 
|         |   1682 ** | 
|         |   1683 ** <blockquote><pre> | 
|         |   1684 **        azResult[0] = "Name"; | 
|         |   1685 **        azResult[1] = "Age"; | 
|         |   1686 **        azResult[2] = "Alice"; | 
|         |   1687 **        azResult[3] = "43"; | 
|         |   1688 **        azResult[4] = "Bob"; | 
|         |   1689 **        azResult[5] = "28"; | 
|         |   1690 **        azResult[6] = "Cindy"; | 
|         |   1691 **        azResult[7] = "21"; | 
|         |   1692 ** </pre></blockquote> | 
|         |   1693 ** | 
|         |   1694 ** The sqlite3_get_table() function evaluates one or more | 
|         |   1695 ** semicolon-separated SQL statements in the zero-terminated UTF-8 | 
|         |   1696 ** string of its 2nd parameter.  It returns a result table to the | 
|         |   1697 ** pointer given in its 3rd parameter. | 
|         |   1698 ** | 
|         |   1699 ** After the calling function has finished using the result, it should | 
|         |   1700 ** pass the pointer to the result table to sqlite3_free_table() in order to | 
|         |   1701 ** release the memory that was malloced.  Because of the way the | 
|         |   1702 ** [sqlite3_malloc()] happens within sqlite3_get_table(), the calling | 
|         |   1703 ** function must not try to call [sqlite3_free()] directly.  Only | 
|         |   1704 ** [sqlite3_free_table()] is able to release the memory properly and safely. | 
|         |   1705 ** | 
|         |   1706 ** The sqlite3_get_table() interface is implemented as a wrapper around | 
|         |   1707 ** [sqlite3_exec()].  The sqlite3_get_table() routine does not have access | 
|         |   1708 ** to any internal data structures of SQLite.  It uses only the public | 
|         |   1709 ** interface defined here.  As a consequence, errors that occur in the | 
|         |   1710 ** wrapper layer outside of the internal [sqlite3_exec()] call are not | 
|         |   1711 ** reflected in subsequent calls to [sqlite3_errcode()] or [sqlite3_errmsg()]. | 
|         |   1712 ** | 
|         |   1713 ** INVARIANTS: | 
|         |   1714 ** | 
|         |   1715 ** {H12371} If a [sqlite3_get_table()] fails a memory allocation, then | 
|         |   1716 **          it shall free the result table under construction, abort the | 
|         |   1717 **          query in process, skip any subsequent queries, set the | 
|         |   1718 **          *pazResult output pointer to NULL and return [SQLITE_NOMEM]. | 
|         |   1719 ** | 
|         |   1720 ** {H12373} If the pnColumn parameter to [sqlite3_get_table()] is not NULL | 
|         |   1721 **          then a successful invocation of [sqlite3_get_table()] shall | 
|         |   1722 **          write the number of columns in the | 
|         |   1723 **          result set of the query into *pnColumn. | 
|         |   1724 ** | 
|         |   1725 ** {H12374} If the pnRow parameter to [sqlite3_get_table()] is not NULL | 
|         |   1726 **          then a successful invocation of [sqlite3_get_table()] shall | 
|         |   1727 **          writes the number of rows in the | 
|         |   1728 **          result set of the query into *pnRow. | 
|         |   1729 ** | 
|         |   1730 ** {H12376} A successful invocation of [sqlite3_get_table()] that computes | 
|         |   1731 **          N rows of result with C columns per row shall make *pazResult | 
|         |   1732 **          point to an array of pointers to (N+1)*C strings where the first | 
|         |   1733 **          C strings are column names as obtained from | 
|         |   1734 **          [sqlite3_column_name()] and the rest are column result values | 
|         |   1735 **          obtained from [sqlite3_column_text()]. | 
|         |   1736 ** | 
|         |   1737 ** {H12379} The values in the pazResult array returned by [sqlite3_get_table()] | 
|         |   1738 **          shall remain valid until cleared by [sqlite3_free_table()]. | 
|         |   1739 ** | 
|         |   1740 ** {H12382} When an error occurs during evaluation of [sqlite3_get_table()] | 
|         |   1741 **          the function shall set *pazResult to NULL, write an error message | 
|         |   1742 **          into memory obtained from [sqlite3_malloc()], make | 
|         |   1743 **          **pzErrmsg point to that error message, and return a | 
|         |   1744 **          appropriate [error code]. | 
|         |   1745 */ | 
|         |   1746 IMPORT_C int sqlite3_get_table( | 
|         |   1747   sqlite3 *db,          /* An open database */ | 
|         |   1748   const char *zSql,     /* SQL to be evaluated */ | 
|         |   1749   char ***pazResult,    /* Results of the query */ | 
|         |   1750   int *pnRow,           /* Number of result rows written here */ | 
|         |   1751   int *pnColumn,        /* Number of result columns written here */ | 
|         |   1752   char **pzErrmsg       /* Error msg written here */ | 
|         |   1753 ); | 
|         |   1754 IMPORT_C void sqlite3_free_table(char **result); | 
|         |   1755  | 
|         |   1756 /* | 
|         |   1757 ** CAPI3REF: Formatted String Printing Functions {H17400} <S70000><S20000> | 
|         |   1758 ** | 
|         |   1759 ** These routines are workalikes of the "printf()" family of functions | 
|         |   1760 ** from the standard C library. | 
|         |   1761 ** | 
|         |   1762 ** The sqlite3_mprintf() and sqlite3_vmprintf() routines write their | 
|         |   1763 ** results into memory obtained from [sqlite3_malloc()]. | 
|         |   1764 ** The strings returned by these two routines should be | 
|         |   1765 ** released by [sqlite3_free()].  Both routines return a | 
|         |   1766 ** NULL pointer if [sqlite3_malloc()] is unable to allocate enough | 
|         |   1767 ** memory to hold the resulting string. | 
|         |   1768 ** | 
|         |   1769 ** In sqlite3_snprintf() routine is similar to "snprintf()" from | 
|         |   1770 ** the standard C library.  The result is written into the | 
|         |   1771 ** buffer supplied as the second parameter whose size is given by | 
|         |   1772 ** the first parameter. Note that the order of the | 
|         |   1773 ** first two parameters is reversed from snprintf().  This is an | 
|         |   1774 ** historical accident that cannot be fixed without breaking | 
|         |   1775 ** backwards compatibility.  Note also that sqlite3_snprintf() | 
|         |   1776 ** returns a pointer to its buffer instead of the number of | 
|         |   1777 ** characters actually written into the buffer.  We admit that | 
|         |   1778 ** the number of characters written would be a more useful return | 
|         |   1779 ** value but we cannot change the implementation of sqlite3_snprintf() | 
|         |   1780 ** now without breaking compatibility. | 
|         |   1781 ** | 
|         |   1782 ** As long as the buffer size is greater than zero, sqlite3_snprintf() | 
|         |   1783 ** guarantees that the buffer is always zero-terminated.  The first | 
|         |   1784 ** parameter "n" is the total size of the buffer, including space for | 
|         |   1785 ** the zero terminator.  So the longest string that can be completely | 
|         |   1786 ** written will be n-1 characters. | 
|         |   1787 ** | 
|         |   1788 ** These routines all implement some additional formatting | 
|         |   1789 ** options that are useful for constructing SQL statements. | 
|         |   1790 ** All of the usual printf() formatting options apply.  In addition, there | 
|         |   1791 ** is are "%q", "%Q", and "%z" options. | 
|         |   1792 ** | 
|         |   1793 ** The %q option works like %s in that it substitutes a null-terminated | 
|         |   1794 ** string from the argument list.  But %q also doubles every '\'' character. | 
|         |   1795 ** %q is designed for use inside a string literal.  By doubling each '\'' | 
|         |   1796 ** character it escapes that character and allows it to be inserted into | 
|         |   1797 ** the string. | 
|         |   1798 ** | 
|         |   1799 ** For example, assume the string variable zText contains text as follows: | 
|         |   1800 ** | 
|         |   1801 ** <blockquote><pre> | 
|         |   1802 **  char *zText = "It's a happy day!"; | 
|         |   1803 ** </pre></blockquote> | 
|         |   1804 ** | 
|         |   1805 ** One can use this text in an SQL statement as follows: | 
|         |   1806 ** | 
|         |   1807 ** <blockquote><pre> | 
|         |   1808 **  char *zSQL = sqlite3_mprintf("INSERT INTO table VALUES('%q')", zText); | 
|         |   1809 **  sqlite3_exec(db, zSQL, 0, 0, 0); | 
|         |   1810 **  sqlite3_free(zSQL); | 
|         |   1811 ** </pre></blockquote> | 
|         |   1812 ** | 
|         |   1813 ** Because the %q format string is used, the '\'' character in zText | 
|         |   1814 ** is escaped and the SQL generated is as follows: | 
|         |   1815 ** | 
|         |   1816 ** <blockquote><pre> | 
|         |   1817 **  INSERT INTO table1 VALUES('It''s a happy day!') | 
|         |   1818 ** </pre></blockquote> | 
|         |   1819 ** | 
|         |   1820 ** This is correct.  Had we used %s instead of %q, the generated SQL | 
|         |   1821 ** would have looked like this: | 
|         |   1822 ** | 
|         |   1823 ** <blockquote><pre> | 
|         |   1824 **  INSERT INTO table1 VALUES('It's a happy day!'); | 
|         |   1825 ** </pre></blockquote> | 
|         |   1826 ** | 
|         |   1827 ** This second example is an SQL syntax error.  As a general rule you should | 
|         |   1828 ** always use %q instead of %s when inserting text into a string literal. | 
|         |   1829 ** | 
|         |   1830 ** The %Q option works like %q except it also adds single quotes around | 
|         |   1831 ** the outside of the total string.  Additionally, if the parameter in the | 
|         |   1832 ** argument list is a NULL pointer, %Q substitutes the text "NULL" (without | 
|         |   1833 ** single quotes) in place of the %Q option.  So, for example, one could say: | 
|         |   1834 ** | 
|         |   1835 ** <blockquote><pre> | 
|         |   1836 **  char *zSQL = sqlite3_mprintf("INSERT INTO table VALUES(%Q)", zText); | 
|         |   1837 **  sqlite3_exec(db, zSQL, 0, 0, 0); | 
|         |   1838 **  sqlite3_free(zSQL); | 
|         |   1839 ** </pre></blockquote> | 
|         |   1840 ** | 
|         |   1841 ** The code above will render a correct SQL statement in the zSQL | 
|         |   1842 ** variable even if the zText variable is a NULL pointer. | 
|         |   1843 ** | 
|         |   1844 ** The "%z" formatting option works exactly like "%s" with the | 
|         |   1845 ** addition that after the string has been read and copied into | 
|         |   1846 ** the result, [sqlite3_free()] is called on the input string. {END} | 
|         |   1847 ** | 
|         |   1848 ** INVARIANTS: | 
|         |   1849 ** | 
|         |   1850 ** {H17403}  The [sqlite3_mprintf()] and [sqlite3_vmprintf()] interfaces | 
|         |   1851 **           return either pointers to zero-terminated UTF-8 strings held in | 
|         |   1852 **           memory obtained from [sqlite3_malloc()] or NULL pointers if | 
|         |   1853 **           a call to [sqlite3_malloc()] fails. | 
|         |   1854 ** | 
|         |   1855 ** {H17406}  The [sqlite3_snprintf()] interface writes a zero-terminated | 
|         |   1856 **           UTF-8 string into the buffer pointed to by the second parameter | 
|         |   1857 **           provided that the first parameter is greater than zero. | 
|         |   1858 ** | 
|         |   1859 ** {H17407}  The [sqlite3_snprintf()] interface does not write slots of | 
|         |   1860 **           its output buffer (the second parameter) outside the range | 
|         |   1861 **           of 0 through N-1 (where N is the first parameter) | 
|         |   1862 **           regardless of the length of the string | 
|         |   1863 **           requested by the format specification. | 
|         |   1864 */ | 
|         |   1865 IMPORT_C char *sqlite3_mprintf(const char*,...); | 
|         |   1866 IMPORT_C char *sqlite3_vmprintf(const char*, va_list); | 
|         |   1867 IMPORT_C char *sqlite3_snprintf(int,char*,const char*, ...); | 
|         |   1868  | 
|         |   1869 /* | 
|         |   1870 ** CAPI3REF: Memory Allocation Subsystem {H17300} <S20000> | 
|         |   1871 ** | 
|         |   1872 ** The SQLite core  uses these three routines for all of its own | 
|         |   1873 ** internal memory allocation needs. "Core" in the previous sentence | 
|         |   1874 ** does not include operating-system specific VFS implementation.  The | 
|         |   1875 ** Windows VFS uses native malloc() and free() for some operations. | 
|         |   1876 ** | 
|         |   1877 ** The sqlite3_malloc() routine returns a pointer to a block | 
|         |   1878 ** of memory at least N bytes in length, where N is the parameter. | 
|         |   1879 ** If sqlite3_malloc() is unable to obtain sufficient free | 
|         |   1880 ** memory, it returns a NULL pointer.  If the parameter N to | 
|         |   1881 ** sqlite3_malloc() is zero or negative then sqlite3_malloc() returns | 
|         |   1882 ** a NULL pointer. | 
|         |   1883 ** | 
|         |   1884 ** Calling sqlite3_free() with a pointer previously returned | 
|         |   1885 ** by sqlite3_malloc() or sqlite3_realloc() releases that memory so | 
|         |   1886 ** that it might be reused.  The sqlite3_free() routine is | 
|         |   1887 ** a no-op if is called with a NULL pointer.  Passing a NULL pointer | 
|         |   1888 ** to sqlite3_free() is harmless.  After being freed, memory | 
|         |   1889 ** should neither be read nor written.  Even reading previously freed | 
|         |   1890 ** memory might result in a segmentation fault or other severe error. | 
|         |   1891 ** Memory corruption, a segmentation fault, or other severe error | 
|         |   1892 ** might result if sqlite3_free() is called with a non-NULL pointer that | 
|         |   1893 ** was not obtained from sqlite3_malloc() or sqlite3_free(). | 
|         |   1894 ** | 
|         |   1895 ** The sqlite3_realloc() interface attempts to resize a | 
|         |   1896 ** prior memory allocation to be at least N bytes, where N is the | 
|         |   1897 ** second parameter.  The memory allocation to be resized is the first | 
|         |   1898 ** parameter.  If the first parameter to sqlite3_realloc() | 
|         |   1899 ** is a NULL pointer then its behavior is identical to calling | 
|         |   1900 ** sqlite3_malloc(N) where N is the second parameter to sqlite3_realloc(). | 
|         |   1901 ** If the second parameter to sqlite3_realloc() is zero or | 
|         |   1902 ** negative then the behavior is exactly the same as calling | 
|         |   1903 ** sqlite3_free(P) where P is the first parameter to sqlite3_realloc(). | 
|         |   1904 ** sqlite3_realloc() returns a pointer to a memory allocation | 
|         |   1905 ** of at least N bytes in size or NULL if sufficient memory is unavailable. | 
|         |   1906 ** If M is the size of the prior allocation, then min(N,M) bytes | 
|         |   1907 ** of the prior allocation are copied into the beginning of buffer returned | 
|         |   1908 ** by sqlite3_realloc() and the prior allocation is freed. | 
|         |   1909 ** If sqlite3_realloc() returns NULL, then the prior allocation | 
|         |   1910 ** is not freed. | 
|         |   1911 ** | 
|         |   1912 ** The memory returned by sqlite3_malloc() and sqlite3_realloc() | 
|         |   1913 ** is always aligned to at least an 8 byte boundary. {END} | 
|         |   1914 ** | 
|         |   1915 ** The default implementation of the memory allocation subsystem uses | 
|         |   1916 ** the malloc(), realloc() and free() provided by the standard C library. | 
|         |   1917 ** {H17382} However, if SQLite is compiled with the | 
|         |   1918 ** SQLITE_MEMORY_SIZE=<i>NNN</i> C preprocessor macro (where <i>NNN</i> | 
|         |   1919 ** is an integer), then SQLite create a static array of at least | 
|         |   1920 ** <i>NNN</i> bytes in size and uses that array for all of its dynamic | 
|         |   1921 ** memory allocation needs. {END}  Additional memory allocator options | 
|         |   1922 ** may be added in future releases. | 
|         |   1923 ** | 
|         |   1924 ** In SQLite version 3.5.0 and 3.5.1, it was possible to define | 
|         |   1925 ** the SQLITE_OMIT_MEMORY_ALLOCATION which would cause the built-in | 
|         |   1926 ** implementation of these routines to be omitted.  That capability | 
|         |   1927 ** is no longer provided.  Only built-in memory allocators can be used. | 
|         |   1928 ** | 
|         |   1929 ** The Windows OS interface layer calls | 
|         |   1930 ** the system malloc() and free() directly when converting | 
|         |   1931 ** filenames between the UTF-8 encoding used by SQLite | 
|         |   1932 ** and whatever filename encoding is used by the particular Windows | 
|         |   1933 ** installation.  Memory allocation errors are detected, but | 
|         |   1934 ** they are reported back as [SQLITE_CANTOPEN] or | 
|         |   1935 ** [SQLITE_IOERR] rather than [SQLITE_NOMEM]. | 
|         |   1936 ** | 
|         |   1937 ** INVARIANTS: | 
|         |   1938 ** | 
|         |   1939 ** {H17303}  The [sqlite3_malloc(N)] interface returns either a pointer to | 
|         |   1940 **           a newly checked-out block of at least N bytes of memory | 
|         |   1941 **           that is 8-byte aligned, or it returns NULL if it is unable | 
|         |   1942 **           to fulfill the request. | 
|         |   1943 ** | 
|         |   1944 ** {H17304}  The [sqlite3_malloc(N)] interface returns a NULL pointer if | 
|         |   1945 **           N is less than or equal to zero. | 
|         |   1946 ** | 
|         |   1947 ** {H17305}  The [sqlite3_free(P)] interface releases memory previously | 
|         |   1948 **           returned from [sqlite3_malloc()] or [sqlite3_realloc()], | 
|         |   1949 **           making it available for reuse. | 
|         |   1950 ** | 
|         |   1951 ** {H17306}  A call to [sqlite3_free(NULL)] is a harmless no-op. | 
|         |   1952 ** | 
|         |   1953 ** {H17310}  A call to [sqlite3_realloc(0,N)] is equivalent to a call | 
|         |   1954 **           to [sqlite3_malloc(N)]. | 
|         |   1955 ** | 
|         |   1956 ** {H17312}  A call to [sqlite3_realloc(P,0)] is equivalent to a call | 
|         |   1957 **           to [sqlite3_free(P)]. | 
|         |   1958 ** | 
|         |   1959 ** {H17315}  The SQLite core uses [sqlite3_malloc()], [sqlite3_realloc()], | 
|         |   1960 **           and [sqlite3_free()] for all of its memory allocation and | 
|         |   1961 **           deallocation needs. | 
|         |   1962 ** | 
|         |   1963 ** {H17318}  The [sqlite3_realloc(P,N)] interface returns either a pointer | 
|         |   1964 **           to a block of checked-out memory of at least N bytes in size | 
|         |   1965 **           that is 8-byte aligned, or a NULL pointer. | 
|         |   1966 ** | 
|         |   1967 ** {H17321}  When [sqlite3_realloc(P,N)] returns a non-NULL pointer, it first | 
|         |   1968 **           copies the first K bytes of content from P into the newly | 
|         |   1969 **           allocated block, where K is the lesser of N and the size of | 
|         |   1970 **           the buffer P. | 
|         |   1971 ** | 
|         |   1972 ** {H17322}  When [sqlite3_realloc(P,N)] returns a non-NULL pointer, it first | 
|         |   1973 **           releases the buffer P. | 
|         |   1974 ** | 
|         |   1975 ** {H17323}  When [sqlite3_realloc(P,N)] returns NULL, the buffer P is | 
|         |   1976 **           not modified or released. | 
|         |   1977 ** | 
|         |   1978 ** ASSUMPTIONS: | 
|         |   1979 ** | 
|         |   1980 ** {A17350}  The pointer arguments to [sqlite3_free()] and [sqlite3_realloc()] | 
|         |   1981 **           must be either NULL or else pointers obtained from a prior | 
|         |   1982 **           invocation of [sqlite3_malloc()] or [sqlite3_realloc()] that have | 
|         |   1983 **           not yet been released. | 
|         |   1984 ** | 
|         |   1985 ** {A17351}  The application must not read or write any part of | 
|         |   1986 **           a block of memory after it has been released using | 
|         |   1987 **           [sqlite3_free()] or [sqlite3_realloc()]. | 
|         |   1988 */ | 
|         |   1989 IMPORT_C void *sqlite3_malloc(int); | 
|         |   1990 IMPORT_C void *sqlite3_realloc(void*, int); | 
|         |   1991 IMPORT_C void sqlite3_free(void*); | 
|         |   1992  | 
|         |   1993 /* | 
|         |   1994 ** CAPI3REF: Memory Allocator Statistics {H17370} <S30210> | 
|         |   1995 ** | 
|         |   1996 ** SQLite provides these two interfaces for reporting on the status | 
|         |   1997 ** of the [sqlite3_malloc()], [sqlite3_free()], and [sqlite3_realloc()] | 
|         |   1998 ** routines, which form the built-in memory allocation subsystem. | 
|         |   1999 ** | 
|         |   2000 ** INVARIANTS: | 
|         |   2001 ** | 
|         |   2002 ** {H17371} The [sqlite3_memory_used()] routine returns the number of bytes | 
|         |   2003 **          of memory currently outstanding (malloced but not freed). | 
|         |   2004 ** | 
|         |   2005 ** {H17373} The [sqlite3_memory_highwater()] routine returns the maximum | 
|         |   2006 **          value of [sqlite3_memory_used()] since the high-water mark | 
|         |   2007 **          was last reset. | 
|         |   2008 ** | 
|         |   2009 ** {H17374} The values returned by [sqlite3_memory_used()] and | 
|         |   2010 **          [sqlite3_memory_highwater()] include any overhead | 
|         |   2011 **          added by SQLite in its implementation of [sqlite3_malloc()], | 
|         |   2012 **          but not overhead added by the any underlying system library | 
|         |   2013 **          routines that [sqlite3_malloc()] may call. | 
|         |   2014 ** | 
|         |   2015 ** {H17375} The memory high-water mark is reset to the current value of | 
|         |   2016 **          [sqlite3_memory_used()] if and only if the parameter to | 
|         |   2017 **          [sqlite3_memory_highwater()] is true.  The value returned | 
|         |   2018 **          by [sqlite3_memory_highwater(1)] is the high-water mark | 
|         |   2019 **          prior to the reset. | 
|         |   2020 */ | 
|         |   2021 IMPORT_C sqlite3_int64 sqlite3_memory_used(void); | 
|         |   2022 IMPORT_C sqlite3_int64 sqlite3_memory_highwater(int resetFlag); | 
|         |   2023  | 
|         |   2024 /* | 
|         |   2025 ** CAPI3REF: Pseudo-Random Number Generator {H17390} <S20000> | 
|         |   2026 ** | 
|         |   2027 ** SQLite contains a high-quality pseudo-random number generator (PRNG) used to | 
|         |   2028 ** select random ROWIDs when inserting new records into a table that | 
|         |   2029 ** already uses the largest possible ROWID.  The PRNG is also used for | 
|         |   2030 ** the build-in random() and randomblob() SQL functions.  This interface allows | 
|         |   2031 ** applications to access the same PRNG for other purposes. | 
|         |   2032 ** | 
|         |   2033 ** A call to this routine stores N bytes of randomness into buffer P. | 
|         |   2034 ** | 
|         |   2035 ** The first time this routine is invoked (either internally or by | 
|         |   2036 ** the application) the PRNG is seeded using randomness obtained | 
|         |   2037 ** from the xRandomness method of the default [sqlite3_vfs] object. | 
|         |   2038 ** On all subsequent invocations, the pseudo-randomness is generated | 
|         |   2039 ** internally and without recourse to the [sqlite3_vfs] xRandomness | 
|         |   2040 ** method. | 
|         |   2041 ** | 
|         |   2042 ** INVARIANTS: | 
|         |   2043 ** | 
|         |   2044 ** {H17392} The [sqlite3_randomness(N,P)] interface writes N bytes of | 
|         |   2045 **          high-quality pseudo-randomness into buffer P. | 
|         |   2046 */ | 
|         |   2047 IMPORT_C void sqlite3_randomness(int N, void *P); | 
|         |   2048  | 
|         |   2049 /* | 
|         |   2050 ** CAPI3REF: Compile-Time Authorization Callbacks {H12500} <S70100> | 
|         |   2051 ** | 
|         |   2052 ** This routine registers a authorizer callback with a particular | 
|         |   2053 ** [database connection], supplied in the first argument. | 
|         |   2054 ** The authorizer callback is invoked as SQL statements are being compiled | 
|         |   2055 ** by [sqlite3_prepare()] or its variants [sqlite3_prepare_v2()], | 
|         |   2056 ** [sqlite3_prepare16()] and [sqlite3_prepare16_v2()].  At various | 
|         |   2057 ** points during the compilation process, as logic is being created | 
|         |   2058 ** to perform various actions, the authorizer callback is invoked to | 
|         |   2059 ** see if those actions are allowed.  The authorizer callback should | 
|         |   2060 ** return [SQLITE_OK] to allow the action, [SQLITE_IGNORE] to disallow the | 
|         |   2061 ** specific action but allow the SQL statement to continue to be | 
|         |   2062 ** compiled, or [SQLITE_DENY] to cause the entire SQL statement to be | 
|         |   2063 ** rejected with an error.  If the authorizer callback returns | 
|         |   2064 ** any value other than [SQLITE_IGNORE], [SQLITE_OK], or [SQLITE_DENY] | 
|         |   2065 ** then the [sqlite3_prepare_v2()] or equivalent call that triggered | 
|         |   2066 ** the authorizer will fail with an error message. | 
|         |   2067 ** | 
|         |   2068 ** When the callback returns [SQLITE_OK], that means the operation | 
|         |   2069 ** requested is ok.  When the callback returns [SQLITE_DENY], the | 
|         |   2070 ** [sqlite3_prepare_v2()] or equivalent call that triggered the | 
|         |   2071 ** authorizer will fail with an error message explaining that | 
|         |   2072 ** access is denied.  If the authorizer code is [SQLITE_READ] | 
|         |   2073 ** and the callback returns [SQLITE_IGNORE] then the | 
|         |   2074 ** [prepared statement] statement is constructed to substitute | 
|         |   2075 ** a NULL value in place of the table column that would have | 
|         |   2076 ** been read if [SQLITE_OK] had been returned.  The [SQLITE_IGNORE] | 
|         |   2077 ** return can be used to deny an untrusted user access to individual | 
|         |   2078 ** columns of a table. | 
|         |   2079 ** | 
|         |   2080 ** The first parameter to the authorizer callback is a copy of the third | 
|         |   2081 ** parameter to the sqlite3_set_authorizer() interface. The second parameter | 
|         |   2082 ** to the callback is an integer [SQLITE_COPY | action code] that specifies | 
|         |   2083 ** the particular action to be authorized. The third through sixth parameters | 
|         |   2084 ** to the callback are zero-terminated strings that contain additional | 
|         |   2085 ** details about the action to be authorized. | 
|         |   2086 ** | 
|         |   2087 ** An authorizer is used when [sqlite3_prepare | preparing] | 
|         |   2088 ** SQL statements from an untrusted source, to ensure that the SQL statements | 
|         |   2089 ** do not try to access data they are not allowed to see, or that they do not | 
|         |   2090 ** try to execute malicious statements that damage the database.  For | 
|         |   2091 ** example, an application may allow a user to enter arbitrary | 
|         |   2092 ** SQL queries for evaluation by a database.  But the application does | 
|         |   2093 ** not want the user to be able to make arbitrary changes to the | 
|         |   2094 ** database.  An authorizer could then be put in place while the | 
|         |   2095 ** user-entered SQL is being [sqlite3_prepare | prepared] that | 
|         |   2096 ** disallows everything except [SELECT] statements. | 
|         |   2097 ** | 
|         |   2098 ** Applications that need to process SQL from untrusted sources | 
|         |   2099 ** might also consider lowering resource limits using [sqlite3_limit()] | 
|         |   2100 ** and limiting database size using the [max_page_count] [PRAGMA] | 
|         |   2101 ** in addition to using an authorizer. | 
|         |   2102 ** | 
|         |   2103 ** Only a single authorizer can be in place on a database connection | 
|         |   2104 ** at a time.  Each call to sqlite3_set_authorizer overrides the | 
|         |   2105 ** previous call.  Disable the authorizer by installing a NULL callback. | 
|         |   2106 ** The authorizer is disabled by default. | 
|         |   2107 ** | 
|         |   2108 ** The authorizer callback must not do anything that will modify | 
|         |   2109 ** the database connection that invoked the authorizer callback. | 
|         |   2110 ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their | 
|         |   2111 ** database connections for the meaning of "modify" in this paragraph. | 
|         |   2112 ** | 
|         |   2113 ** When [sqlite3_prepare_v2()] is used to prepare a statement, the | 
|         |   2114 ** statement might be reprepared during [sqlite3_step()] due to a  | 
|         |   2115 ** schema change.  Hence, the application should ensure that the | 
|         |   2116 ** correct authorizer callback remains in place during the [sqlite3_step()]. | 
|         |   2117 ** | 
|         |   2118 ** Note that the authorizer callback is invoked only during | 
|         |   2119 ** [sqlite3_prepare()] or its variants.  Authorization is not | 
|         |   2120 ** performed during statement evaluation in [sqlite3_step()]. | 
|         |   2121 ** | 
|         |   2122 ** INVARIANTS: | 
|         |   2123 ** | 
|         |   2124 ** {H12501} The [sqlite3_set_authorizer(D,...)] interface registers a | 
|         |   2125 **          authorizer callback with database connection D. | 
|         |   2126 ** | 
|         |   2127 ** {H12502} The authorizer callback is invoked as SQL statements are | 
|         |   2128 **          being parseed and compiled. | 
|         |   2129 ** | 
|         |   2130 ** {H12503} If the authorizer callback returns any value other than | 
|         |   2131 **          [SQLITE_IGNORE], [SQLITE_OK], or [SQLITE_DENY], then | 
|         |   2132 **          the application interface call that caused | 
|         |   2133 **          the authorizer callback to run shall fail with an | 
|         |   2134 **          [SQLITE_ERROR] error code and an appropriate error message. | 
|         |   2135 ** | 
|         |   2136 ** {H12504} When the authorizer callback returns [SQLITE_OK], the operation | 
|         |   2137 **          described is processed normally. | 
|         |   2138 ** | 
|         |   2139 ** {H12505} When the authorizer callback returns [SQLITE_DENY], the | 
|         |   2140 **          application interface call that caused the | 
|         |   2141 **          authorizer callback to run shall fail | 
|         |   2142 **          with an [SQLITE_ERROR] error code and an error message | 
|         |   2143 **          explaining that access is denied. | 
|         |   2144 ** | 
|         |   2145 ** {H12506} If the authorizer code (the 2nd parameter to the authorizer | 
|         |   2146 **          callback) is [SQLITE_READ] and the authorizer callback returns | 
|         |   2147 **          [SQLITE_IGNORE], then the prepared statement is constructed to | 
|         |   2148 **          insert a NULL value in place of the table column that would have | 
|         |   2149 **          been read if [SQLITE_OK] had been returned. | 
|         |   2150 ** | 
|         |   2151 ** {H12507} If the authorizer code (the 2nd parameter to the authorizer | 
|         |   2152 **          callback) is anything other than [SQLITE_READ], then | 
|         |   2153 **          a return of [SQLITE_IGNORE] has the same effect as [SQLITE_DENY]. | 
|         |   2154 ** | 
|         |   2155 ** {H12510} The first parameter to the authorizer callback is a copy of | 
|         |   2156 **          the third parameter to the [sqlite3_set_authorizer()] interface. | 
|         |   2157 ** | 
|         |   2158 ** {H12511} The second parameter to the callback is an integer | 
|         |   2159 **          [SQLITE_COPY | action code] that specifies the particular action | 
|         |   2160 **          to be authorized. | 
|         |   2161 ** | 
|         |   2162 ** {H12512} The third through sixth parameters to the callback are | 
|         |   2163 **          zero-terminated strings that contain | 
|         |   2164 **          additional details about the action to be authorized. | 
|         |   2165 ** | 
|         |   2166 ** {H12520} Each call to [sqlite3_set_authorizer()] overrides | 
|         |   2167 **          any previously installed authorizer. | 
|         |   2168 ** | 
|         |   2169 ** {H12521} A NULL authorizer means that no authorization | 
|         |   2170 **          callback is invoked. | 
|         |   2171 ** | 
|         |   2172 ** {H12522} The default authorizer is NULL. | 
|         |   2173 */ | 
|         |   2174 IMPORT_C int sqlite3_set_authorizer( | 
|         |   2175   sqlite3*, | 
|         |   2176   int (*xAuth)(void*,int,const char*,const char*,const char*,const char*), | 
|         |   2177   void *pUserData | 
|         |   2178 ); | 
|         |   2179  | 
|         |   2180 /* | 
|         |   2181 ** CAPI3REF: Authorizer Return Codes {H12590} <H12500> | 
|         |   2182 ** | 
|         |   2183 ** The [sqlite3_set_authorizer | authorizer callback function] must | 
|         |   2184 ** return either [SQLITE_OK] or one of these two constants in order | 
|         |   2185 ** to signal SQLite whether or not the action is permitted.  See the | 
|         |   2186 ** [sqlite3_set_authorizer | authorizer documentation] for additional | 
|         |   2187 ** information. | 
|         |   2188 */ | 
|         |   2189 #define SQLITE_DENY   1   /* Abort the SQL statement with an error */ | 
|         |   2190 #define SQLITE_IGNORE 2   /* Don't allow access, but don't generate an error */ | 
|         |   2191  | 
|         |   2192 /* | 
|         |   2193 ** CAPI3REF: Authorizer Action Codes {H12550} <H12500> | 
|         |   2194 ** | 
|         |   2195 ** The [sqlite3_set_authorizer()] interface registers a callback function | 
|         |   2196 ** that is invoked to authorize certain SQL statement actions.  The | 
|         |   2197 ** second parameter to the callback is an integer code that specifies | 
|         |   2198 ** what action is being authorized.  These are the integer action codes that | 
|         |   2199 ** the authorizer callback may be passed. | 
|         |   2200 ** | 
|         |   2201 ** These action code values signify what kind of operation is to be | 
|         |   2202 ** authorized.  The 3rd and 4th parameters to the authorization | 
|         |   2203 ** callback function will be parameters or NULL depending on which of these | 
|         |   2204 ** codes is used as the second parameter.  The 5th parameter to the | 
|         |   2205 ** authorizer callback is the name of the database ("main", "temp", | 
|         |   2206 ** etc.) if applicable.  The 6th parameter to the authorizer callback | 
|         |   2207 ** is the name of the inner-most trigger or view that is responsible for | 
|         |   2208 ** the access attempt or NULL if this access attempt is directly from | 
|         |   2209 ** top-level SQL code. | 
|         |   2210 ** | 
|         |   2211 ** INVARIANTS: | 
|         |   2212 ** | 
|         |   2213 ** {H12551} The second parameter to an | 
|         |   2214 **          [sqlite3_set_authorizer | authorizer callback] shall be an integer | 
|         |   2215 **          [SQLITE_COPY | authorizer code] that specifies what action | 
|         |   2216 **          is being authorized. | 
|         |   2217 ** | 
|         |   2218 ** {H12552} The 3rd and 4th parameters to the | 
|         |   2219 **          [sqlite3_set_authorizer | authorization callback] | 
|         |   2220 **          shall be parameters or NULL depending on which | 
|         |   2221 **          [SQLITE_COPY | authorizer code] is used as the second parameter. | 
|         |   2222 ** | 
|         |   2223 ** {H12553} The 5th parameter to the | 
|         |   2224 **          [sqlite3_set_authorizer | authorizer callback] shall be the name | 
|         |   2225 **          of the database (example: "main", "temp", etc.) if applicable. | 
|         |   2226 ** | 
|         |   2227 ** {H12554} The 6th parameter to the | 
|         |   2228 **          [sqlite3_set_authorizer | authorizer callback] shall be the name | 
|         |   2229 **          of the inner-most trigger or view that is responsible for | 
|         |   2230 **          the access attempt or NULL if this access attempt is directly from | 
|         |   2231 **          top-level SQL code. | 
|         |   2232 */ | 
|         |   2233 /******************************************* 3rd ************ 4th ***********/ | 
|         |   2234 #define SQLITE_CREATE_INDEX          1   /* Index Name      Table Name      */ | 
|         |   2235 #define SQLITE_CREATE_TABLE          2   /* Table Name      NULL            */ | 
|         |   2236 #define SQLITE_CREATE_TEMP_INDEX     3   /* Index Name      Table Name      */ | 
|         |   2237 #define SQLITE_CREATE_TEMP_TABLE     4   /* Table Name      NULL            */ | 
|         |   2238 #define SQLITE_CREATE_TEMP_TRIGGER   5   /* Trigger Name    Table Name      */ | 
|         |   2239 #define SQLITE_CREATE_TEMP_VIEW      6   /* View Name       NULL            */ | 
|         |   2240 #define SQLITE_CREATE_TRIGGER        7   /* Trigger Name    Table Name      */ | 
|         |   2241 #define SQLITE_CREATE_VIEW           8   /* View Name       NULL            */ | 
|         |   2242 #define SQLITE_DELETE                9   /* Table Name      NULL            */ | 
|         |   2243 #define SQLITE_DROP_INDEX           10   /* Index Name      Table Name      */ | 
|         |   2244 #define SQLITE_DROP_TABLE           11   /* Table Name      NULL            */ | 
|         |   2245 #define SQLITE_DROP_TEMP_INDEX      12   /* Index Name      Table Name      */ | 
|         |   2246 #define SQLITE_DROP_TEMP_TABLE      13   /* Table Name      NULL            */ | 
|         |   2247 #define SQLITE_DROP_TEMP_TRIGGER    14   /* Trigger Name    Table Name      */ | 
|         |   2248 #define SQLITE_DROP_TEMP_VIEW       15   /* View Name       NULL            */ | 
|         |   2249 #define SQLITE_DROP_TRIGGER         16   /* Trigger Name    Table Name      */ | 
|         |   2250 #define SQLITE_DROP_VIEW            17   /* View Name       NULL            */ | 
|         |   2251 #define SQLITE_INSERT               18   /* Table Name      NULL            */ | 
|         |   2252 #define SQLITE_PRAGMA               19   /* Pragma Name     1st arg or NULL */ | 
|         |   2253 #define SQLITE_READ                 20   /* Table Name      Column Name     */ | 
|         |   2254 #define SQLITE_SELECT               21   /* NULL            NULL            */ | 
|         |   2255 #define SQLITE_TRANSACTION          22   /* NULL            NULL            */ | 
|         |   2256 #define SQLITE_UPDATE               23   /* Table Name      Column Name     */ | 
|         |   2257 #define SQLITE_ATTACH               24   /* Filename        NULL            */ | 
|         |   2258 #define SQLITE_DETACH               25   /* Database Name   NULL            */ | 
|         |   2259 #define SQLITE_ALTER_TABLE          26   /* Database Name   Table Name      */ | 
|         |   2260 #define SQLITE_REINDEX              27   /* Index Name      NULL            */ | 
|         |   2261 #define SQLITE_ANALYZE              28   /* Table Name      NULL            */ | 
|         |   2262 #define SQLITE_CREATE_VTABLE        29   /* Table Name      Module Name     */ | 
|         |   2263 #define SQLITE_DROP_VTABLE          30   /* Table Name      Module Name     */ | 
|         |   2264 #define SQLITE_FUNCTION             31   /* Function Name   NULL            */ | 
|         |   2265 #define SQLITE_COPY                  0   /* No longer used */ | 
|         |   2266  | 
|         |   2267 /* | 
|         |   2268 ** CAPI3REF: Tracing And Profiling Functions {H12280} <S60400> | 
|         |   2269 ** EXPERIMENTAL | 
|         |   2270 ** | 
|         |   2271 ** These routines register callback functions that can be used for | 
|         |   2272 ** tracing and profiling the execution of SQL statements. | 
|         |   2273 ** | 
|         |   2274 ** The callback function registered by sqlite3_trace() is invoked at | 
|         |   2275 ** various times when an SQL statement is being run by [sqlite3_step()]. | 
|         |   2276 ** The callback returns a UTF-8 rendering of the SQL statement text | 
|         |   2277 ** as the statement first begins executing.  Additional callbacks occur | 
|         |   2278 ** as each triggered subprogram is entered.  The callbacks for triggers | 
|         |   2279 ** contain a UTF-8 SQL comment that identifies the trigger. | 
|         |   2280 ** | 
|         |   2281 ** The callback function registered by sqlite3_profile() is invoked | 
|         |   2282 ** as each SQL statement finishes.  The profile callback contains | 
|         |   2283 ** the original statement text and an estimate of wall-clock time | 
|         |   2284 ** of how long that statement took to run. | 
|         |   2285 ** | 
|         |   2286 ** INVARIANTS: | 
|         |   2287 ** | 
|         |   2288 ** {H12281} The callback function registered by [sqlite3_trace()]  | 
|         |   2289 **          shall be invoked | 
|         |   2290 **          whenever an SQL statement first begins to execute and | 
|         |   2291 **          whenever a trigger subprogram first begins to run. | 
|         |   2292 ** | 
|         |   2293 ** {H12282} Each call to [sqlite3_trace()] shall override the previously | 
|         |   2294 **          registered trace callback. | 
|         |   2295 ** | 
|         |   2296 ** {H12283} A NULL trace callback shall disable tracing. | 
|         |   2297 ** | 
|         |   2298 ** {H12284} The first argument to the trace callback shall be a copy of | 
|         |   2299 **          the pointer which was the 3rd argument to [sqlite3_trace()]. | 
|         |   2300 ** | 
|         |   2301 ** {H12285} The second argument to the trace callback is a | 
|         |   2302 **          zero-terminated UTF-8 string containing the original text | 
|         |   2303 **          of the SQL statement as it was passed into [sqlite3_prepare_v2()] | 
|         |   2304 **          or the equivalent, or an SQL comment indicating the beginning | 
|         |   2305 **          of a trigger subprogram. | 
|         |   2306 ** | 
|         |   2307 ** {H12287} The callback function registered by [sqlite3_profile()] is invoked | 
|         |   2308 **          as each SQL statement finishes. | 
|         |   2309 ** | 
|         |   2310 ** {H12288} The first parameter to the profile callback is a copy of | 
|         |   2311 **          the 3rd parameter to [sqlite3_profile()]. | 
|         |   2312 ** | 
|         |   2313 ** {H12289} The second parameter to the profile callback is a | 
|         |   2314 **          zero-terminated UTF-8 string that contains the complete text of | 
|         |   2315 **          the SQL statement as it was processed by [sqlite3_prepare_v2()] | 
|         |   2316 **          or the equivalent. | 
|         |   2317 ** | 
|         |   2318 ** {H12290} The third parameter to the profile callback is an estimate | 
|         |   2319 **          of the number of nanoseconds of wall-clock time required to | 
|         |   2320 **          run the SQL statement from start to finish. | 
|         |   2321 */ | 
|         |   2322 IMPORT_C void *sqlite3_trace(sqlite3*, void(*xTrace)(void*,const char*), void*); | 
|         |   2323 IMPORT_C void *sqlite3_profile(sqlite3*, | 
|         |   2324    void(*xProfile)(void*,const char*,sqlite3_uint64), void*); | 
|         |   2325  | 
|         |   2326 /* | 
|         |   2327 ** CAPI3REF: Query Progress Callbacks {H12910} <S60400> | 
|         |   2328 ** | 
|         |   2329 ** This routine configures a callback function - the | 
|         |   2330 ** progress callback - that is invoked periodically during long | 
|         |   2331 ** running calls to [sqlite3_exec()], [sqlite3_step()] and | 
|         |   2332 ** [sqlite3_get_table()].  An example use for this | 
|         |   2333 ** interface is to keep a GUI updated during a large query. | 
|         |   2334 ** | 
|         |   2335 ** If the progress callback returns non-zero, the operation is | 
|         |   2336 ** interrupted.  This feature can be used to implement a | 
|         |   2337 ** "Cancel" button on a GUI progress dialog box. | 
|         |   2338 ** | 
|         |   2339 ** The progress handler must not do anything that will modify | 
|         |   2340 ** the database connection that invoked the progress handler. | 
|         |   2341 ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their | 
|         |   2342 ** database connections for the meaning of "modify" in this paragraph. | 
|         |   2343 ** | 
|         |   2344 ** INVARIANTS: | 
|         |   2345 ** | 
|         |   2346 ** {H12911} The callback function registered by sqlite3_progress_handler() | 
|         |   2347 **          is invoked periodically during long running calls to | 
|         |   2348 **          [sqlite3_step()]. | 
|         |   2349 ** | 
|         |   2350 ** {H12912} The progress callback is invoked once for every N virtual | 
|         |   2351 **          machine opcodes, where N is the second argument to | 
|         |   2352 **          the [sqlite3_progress_handler()] call that registered | 
|         |   2353 **          the callback.  If N is less than 1, sqlite3_progress_handler() | 
|         |   2354 **          acts as if a NULL progress handler had been specified. | 
|         |   2355 ** | 
|         |   2356 ** {H12913} The progress callback itself is identified by the third | 
|         |   2357 **          argument to sqlite3_progress_handler(). | 
|         |   2358 ** | 
|         |   2359 ** {H12914} The fourth argument to sqlite3_progress_handler() is a | 
|         |   2360 **          void pointer passed to the progress callback | 
|         |   2361 **          function each time it is invoked. | 
|         |   2362 ** | 
|         |   2363 ** {H12915} If a call to [sqlite3_step()] results in fewer than N opcodes | 
|         |   2364 **          being executed, then the progress callback is never invoked. | 
|         |   2365 ** | 
|         |   2366 ** {H12916} Every call to [sqlite3_progress_handler()] | 
|         |   2367 **          overwrites any previously registered progress handler. | 
|         |   2368 ** | 
|         |   2369 ** {H12917} If the progress handler callback is NULL then no progress | 
|         |   2370 **          handler is invoked. | 
|         |   2371 ** | 
|         |   2372 ** {H12918} If the progress callback returns a result other than 0, then | 
|         |   2373 **          the behavior is a if [sqlite3_interrupt()] had been called. | 
|         |   2374 **          <S30500> | 
|         |   2375 */ | 
|         |   2376 IMPORT_C void sqlite3_progress_handler(sqlite3*, int, int(*)(void*), void*); | 
|         |   2377  | 
|         |   2378 /* | 
|         |   2379 ** CAPI3REF: Opening A New Database Connection {H12700} <S40200> | 
|         |   2380 ** | 
|         |   2381 ** These routines open an SQLite database file whose name is given by the | 
|         |   2382 ** filename argument. The filename argument is interpreted as UTF-8 for | 
|         |   2383 ** sqlite3_open() and sqlite3_open_v2() and as UTF-16 in the native byte | 
|         |   2384 ** order for sqlite3_open16(). A [database connection] handle is usually | 
|         |   2385 ** returned in *ppDb, even if an error occurs.  The only exception is that | 
|         |   2386 ** if SQLite is unable to allocate memory to hold the [sqlite3] object, | 
|         |   2387 ** a NULL will be written into *ppDb instead of a pointer to the [sqlite3] | 
|         |   2388 ** object. If the database is opened (and/or created) successfully, then | 
|         |   2389 ** [SQLITE_OK] is returned.  Otherwise an [error code] is returned.  The | 
|         |   2390 ** [sqlite3_errmsg()] or [sqlite3_errmsg16()] routines can be used to obtain | 
|         |   2391 ** an English language description of the error. | 
|         |   2392 ** | 
|         |   2393 ** The default encoding for the database will be UTF-8 if | 
|         |   2394 ** sqlite3_open() or sqlite3_open_v2() is called and | 
|         |   2395 ** UTF-16 in the native byte order if sqlite3_open16() is used. | 
|         |   2396 ** | 
|         |   2397 ** Whether or not an error occurs when it is opened, resources | 
|         |   2398 ** associated with the [database connection] handle should be released by | 
|         |   2399 ** passing it to [sqlite3_close()] when it is no longer required. | 
|         |   2400 ** | 
|         |   2401 ** The sqlite3_open_v2() interface works like sqlite3_open() | 
|         |   2402 ** except that it accepts two additional parameters for additional control | 
|         |   2403 ** over the new database connection.  The flags parameter can take one of | 
|         |   2404 ** the following three values, optionally combined with the  | 
|         |   2405 ** [SQLITE_OPEN_NOMUTEX] or [SQLITE_OPEN_FULLMUTEX] flags: | 
|         |   2406 ** | 
|         |   2407 ** <dl> | 
|         |   2408 ** <dt>[SQLITE_OPEN_READONLY]</dt> | 
|         |   2409 ** <dd>The database is opened in read-only mode.  If the database does not | 
|         |   2410 ** already exist, an error is returned.</dd> | 
|         |   2411 ** | 
|         |   2412 ** <dt>[SQLITE_OPEN_READWRITE]</dt> | 
|         |   2413 ** <dd>The database is opened for reading and writing if possible, or reading | 
|         |   2414 ** only if the file is write protected by the operating system.  In either | 
|         |   2415 ** case the database must already exist, otherwise an error is returned.</dd> | 
|         |   2416 ** | 
|         |   2417 ** <dt>[SQLITE_OPEN_READWRITE] | [SQLITE_OPEN_CREATE]</dt> | 
|         |   2418 ** <dd>The database is opened for reading and writing, and is creates it if | 
|         |   2419 ** it does not already exist. This is the behavior that is always used for | 
|         |   2420 ** sqlite3_open() and sqlite3_open16().</dd> | 
|         |   2421 ** </dl> | 
|         |   2422 ** | 
|         |   2423 ** If the 3rd parameter to sqlite3_open_v2() is not one of the | 
|         |   2424 ** combinations shown above or one of the combinations shown above combined | 
|         |   2425 ** with the [SQLITE_OPEN_NOMUTEX] or [SQLITE_OPEN_FULLMUTEX] flags, | 
|         |   2426 ** then the behavior is undefined. | 
|         |   2427 ** | 
|         |   2428 ** If the [SQLITE_OPEN_NOMUTEX] flag is set, then the database connection | 
|         |   2429 ** opens in the multi-thread [threading mode] as long as the single-thread | 
|         |   2430 ** mode has not been set at compile-time or start-time.  If the | 
|         |   2431 ** [SQLITE_OPEN_FULLMUTEX] flag is set then the database connection opens | 
|         |   2432 ** in the serialized [threading mode] unless single-thread was | 
|         |   2433 ** previously selected at compile-time or start-time. | 
|         |   2434 ** | 
|         |   2435 ** If the filename is ":memory:", then a private, temporary in-memory database | 
|         |   2436 ** is created for the connection.  This in-memory database will vanish when | 
|         |   2437 ** the database connection is closed.  Future versions of SQLite might | 
|         |   2438 ** make use of additional special filenames that begin with the ":" character. | 
|         |   2439 ** It is recommended that when a database filename actually does begin with | 
|         |   2440 ** a ":" character you should prefix the filename with a pathname such as | 
|         |   2441 ** "./" to avoid ambiguity. | 
|         |   2442 ** | 
|         |   2443 ** If the filename is an empty string, then a private, temporary | 
|         |   2444 ** on-disk database will be created.  This private database will be | 
|         |   2445 ** automatically deleted as soon as the database connection is closed. | 
|         |   2446 ** | 
|         |   2447 ** The fourth parameter to sqlite3_open_v2() is the name of the | 
|         |   2448 ** [sqlite3_vfs] object that defines the operating system interface that | 
|         |   2449 ** the new database connection should use.  If the fourth parameter is | 
|         |   2450 ** a NULL pointer then the default [sqlite3_vfs] object is used. | 
|         |   2451 ** | 
|         |   2452 ** <b>Note to Windows users:</b>  The encoding used for the filename argument | 
|         |   2453 ** of sqlite3_open() and sqlite3_open_v2() must be UTF-8, not whatever | 
|         |   2454 ** codepage is currently defined.  Filenames containing international | 
|         |   2455 ** characters must be converted to UTF-8 prior to passing them into | 
|         |   2456 ** sqlite3_open() or sqlite3_open_v2(). | 
|         |   2457 ** | 
|         |   2458 ** INVARIANTS: | 
|         |   2459 ** | 
|         |   2460 ** {H12701} The [sqlite3_open()], [sqlite3_open16()], and | 
|         |   2461 **          [sqlite3_open_v2()] interfaces create a new | 
|         |   2462 **          [database connection] associated with | 
|         |   2463 **          the database file given in their first parameter. | 
|         |   2464 ** | 
|         |   2465 ** {H12702} The filename argument is interpreted as UTF-8 | 
|         |   2466 **          for [sqlite3_open()] and [sqlite3_open_v2()] and as UTF-16 | 
|         |   2467 **          in the native byte order for [sqlite3_open16()]. | 
|         |   2468 ** | 
|         |   2469 ** {H12703} A successful invocation of [sqlite3_open()], [sqlite3_open16()], | 
|         |   2470 **          or [sqlite3_open_v2()] writes a pointer to a new | 
|         |   2471 **          [database connection] into *ppDb. | 
|         |   2472 ** | 
|         |   2473 ** {H12704} The [sqlite3_open()], [sqlite3_open16()], and | 
|         |   2474 **          [sqlite3_open_v2()] interfaces return [SQLITE_OK] upon success, | 
|         |   2475 **          or an appropriate [error code] on failure. | 
|         |   2476 ** | 
|         |   2477 ** {H12706} The default text encoding for a new database created using | 
|         |   2478 **          [sqlite3_open()] or [sqlite3_open_v2()] will be UTF-8. | 
|         |   2479 ** | 
|         |   2480 ** {H12707} The default text encoding for a new database created using | 
|         |   2481 **          [sqlite3_open16()] will be UTF-16. | 
|         |   2482 ** | 
|         |   2483 ** {H12709} The [sqlite3_open(F,D)] interface is equivalent to | 
|         |   2484 **          [sqlite3_open_v2(F,D,G,0)] where the G parameter is | 
|         |   2485 **          [SQLITE_OPEN_READWRITE]|[SQLITE_OPEN_CREATE]. | 
|         |   2486 ** | 
|         |   2487 ** {H12711} If the G parameter to [sqlite3_open_v2(F,D,G,V)] contains the | 
|         |   2488 **          bit value [SQLITE_OPEN_READONLY] then the database is opened | 
|         |   2489 **          for reading only. | 
|         |   2490 ** | 
|         |   2491 ** {H12712} If the G parameter to [sqlite3_open_v2(F,D,G,V)] contains the | 
|         |   2492 **          bit value [SQLITE_OPEN_READWRITE] then the database is opened | 
|         |   2493 **          reading and writing if possible, or for reading only if the | 
|         |   2494 **          file is write protected by the operating system. | 
|         |   2495 ** | 
|         |   2496 ** {H12713} If the G parameter to [sqlite3_open_v2(F,D,G,V)] omits the | 
|         |   2497 **          bit value [SQLITE_OPEN_CREATE] and the database does not | 
|         |   2498 **          previously exist, an error is returned. | 
|         |   2499 ** | 
|         |   2500 ** {H12714} If the G parameter to [sqlite3_open_v2(F,D,G,V)] contains the | 
|         |   2501 **          bit value [SQLITE_OPEN_CREATE] and the database does not | 
|         |   2502 **          previously exist, then an attempt is made to create and | 
|         |   2503 **          initialize the database. | 
|         |   2504 ** | 
|         |   2505 ** {H12717} If the filename argument to [sqlite3_open()], [sqlite3_open16()], | 
|         |   2506 **          or [sqlite3_open_v2()] is ":memory:", then an private, | 
|         |   2507 **          ephemeral, in-memory database is created for the connection. | 
|         |   2508 **          <todo>Is SQLITE_OPEN_CREATE|SQLITE_OPEN_READWRITE required | 
|         |   2509 **          in sqlite3_open_v2()?</todo> | 
|         |   2510 ** | 
|         |   2511 ** {H12719} If the filename is NULL or an empty string, then a private, | 
|         |   2512 **          ephemeral on-disk database will be created. | 
|         |   2513 **          <todo>Is SQLITE_OPEN_CREATE|SQLITE_OPEN_READWRITE required | 
|         |   2514 **          in sqlite3_open_v2()?</todo> | 
|         |   2515 ** | 
|         |   2516 ** {H12721} The [database connection] created by [sqlite3_open_v2(F,D,G,V)] | 
|         |   2517 **          will use the [sqlite3_vfs] object identified by the V parameter, | 
|         |   2518 **          or the default [sqlite3_vfs] object if V is a NULL pointer. | 
|         |   2519 ** | 
|         |   2520 ** {H12723} Two [database connections] will share a common cache if both were | 
|         |   2521 **          opened with the same VFS while [shared cache mode] was enabled and | 
|         |   2522 **          if both filenames compare equal using memcmp() after having been | 
|         |   2523 **          processed by the [sqlite3_vfs | xFullPathname] method of the VFS. | 
|         |   2524 */ | 
|         |   2525 IMPORT_C int sqlite3_open( | 
|         |   2526   const char *filename,   /* Database filename (UTF-8) */ | 
|         |   2527   sqlite3 **ppDb          /* OUT: SQLite db handle */ | 
|         |   2528 ); | 
|         |   2529 IMPORT_C int sqlite3_open16( | 
|         |   2530   const void *filename,   /* Database filename (UTF-16) */ | 
|         |   2531   sqlite3 **ppDb          /* OUT: SQLite db handle */ | 
|         |   2532 ); | 
|         |   2533 IMPORT_C int sqlite3_open_v2( | 
|         |   2534   const char *filename,   /* Database filename (UTF-8) */ | 
|         |   2535   sqlite3 **ppDb,         /* OUT: SQLite db handle */ | 
|         |   2536   int flags,              /* Flags */ | 
|         |   2537   const char *zVfs        /* Name of VFS module to use */ | 
|         |   2538 ); | 
|         |   2539  | 
|         |   2540 /* | 
|         |   2541 ** CAPI3REF: Error Codes And Messages {H12800} <S60200> | 
|         |   2542 ** | 
|         |   2543 ** The sqlite3_errcode() interface returns the numeric [result code] or | 
|         |   2544 ** [extended result code] for the most recent failed sqlite3_* API call | 
|         |   2545 ** associated with a [database connection]. If a prior API call failed | 
|         |   2546 ** but the most recent API call succeeded, the return value from | 
|         |   2547 ** sqlite3_errcode() is undefined. | 
|         |   2548 ** | 
|         |   2549 ** The sqlite3_errmsg() and sqlite3_errmsg16() return English-language | 
|         |   2550 ** text that describes the error, as either UTF-8 or UTF-16 respectively. | 
|         |   2551 ** Memory to hold the error message string is managed internally. | 
|         |   2552 ** The application does not need to worry about freeing the result. | 
|         |   2553 ** However, the error string might be overwritten or deallocated by | 
|         |   2554 ** subsequent calls to other SQLite interface functions. | 
|         |   2555 ** | 
|         |   2556 ** If an interface fails with SQLITE_MISUSE, that means the interface | 
|         |   2557 ** was invoked incorrectly by the application.  In that case, the | 
|         |   2558 ** error code and message may or may not be set. | 
|         |   2559 ** | 
|         |   2560 ** INVARIANTS: | 
|         |   2561 ** | 
|         |   2562 ** {H12801} The [sqlite3_errcode(D)] interface returns the numeric | 
|         |   2563 **          [result code] or [extended result code] for the most recently | 
|         |   2564 **          failed interface call associated with the [database connection] D. | 
|         |   2565 ** | 
|         |   2566 ** {H12803} The [sqlite3_errmsg(D)] and [sqlite3_errmsg16(D)] | 
|         |   2567 **          interfaces return English-language text that describes | 
|         |   2568 **          the error in the mostly recently failed interface call, | 
|         |   2569 **          encoded as either UTF-8 or UTF-16 respectively. | 
|         |   2570 ** | 
|         |   2571 ** {H12807} The strings returned by [sqlite3_errmsg()] and [sqlite3_errmsg16()] | 
|         |   2572 **          are valid until the next SQLite interface call. | 
|         |   2573 ** | 
|         |   2574 ** {H12808} Calls to API routines that do not return an error code | 
|         |   2575 **          (example: [sqlite3_data_count()]) do not | 
|         |   2576 **          change the error code or message returned by | 
|         |   2577 **          [sqlite3_errcode()], [sqlite3_errmsg()], or [sqlite3_errmsg16()]. | 
|         |   2578 ** | 
|         |   2579 ** {H12809} Interfaces that are not associated with a specific | 
|         |   2580 **          [database connection] (examples: | 
|         |   2581 **          [sqlite3_mprintf()] or [sqlite3_enable_shared_cache()] | 
|         |   2582 **          do not change the values returned by | 
|         |   2583 **          [sqlite3_errcode()], [sqlite3_errmsg()], or [sqlite3_errmsg16()]. | 
|         |   2584 */ | 
|         |   2585 IMPORT_C int sqlite3_errcode(sqlite3 *db); | 
|         |   2586 IMPORT_C const char *sqlite3_errmsg(sqlite3*); | 
|         |   2587 IMPORT_C const void *sqlite3_errmsg16(sqlite3*); | 
|         |   2588  | 
|         |   2589 /* | 
|         |   2590 ** CAPI3REF: SQL Statement Object {H13000} <H13010> | 
|         |   2591 ** KEYWORDS: {prepared statement} {prepared statements} | 
|         |   2592 ** | 
|         |   2593 ** An instance of this object represents a single SQL statement. | 
|         |   2594 ** This object is variously known as a "prepared statement" or a | 
|         |   2595 ** "compiled SQL statement" or simply as a "statement". | 
|         |   2596 ** | 
|         |   2597 ** The life of a statement object goes something like this: | 
|         |   2598 ** | 
|         |   2599 ** <ol> | 
|         |   2600 ** <li> Create the object using [sqlite3_prepare_v2()] or a related | 
|         |   2601 **      function. | 
|         |   2602 ** <li> Bind values to [host parameters] using the sqlite3_bind_*() | 
|         |   2603 **      interfaces. | 
|         |   2604 ** <li> Run the SQL by calling [sqlite3_step()] one or more times. | 
|         |   2605 ** <li> Reset the statement using [sqlite3_reset()] then go back | 
|         |   2606 **      to step 2.  Do this zero or more times. | 
|         |   2607 ** <li> Destroy the object using [sqlite3_finalize()]. | 
|         |   2608 ** </ol> | 
|         |   2609 ** | 
|         |   2610 ** Refer to documentation on individual methods above for additional | 
|         |   2611 ** information. | 
|         |   2612 */ | 
|         |   2613 typedef struct sqlite3_stmt sqlite3_stmt; | 
|         |   2614  | 
|         |   2615 /* | 
|         |   2616 ** CAPI3REF: Run-time Limits {H12760} <S20600> | 
|         |   2617 ** | 
|         |   2618 ** This interface allows the size of various constructs to be limited | 
|         |   2619 ** on a connection by connection basis.  The first parameter is the | 
|         |   2620 ** [database connection] whose limit is to be set or queried.  The | 
|         |   2621 ** second parameter is one of the [limit categories] that define a | 
|         |   2622 ** class of constructs to be size limited.  The third parameter is the | 
|         |   2623 ** new limit for that construct.  The function returns the old limit. | 
|         |   2624 ** | 
|         |   2625 ** If the new limit is a negative number, the limit is unchanged. | 
|         |   2626 ** For the limit category of SQLITE_LIMIT_XYZ there is a hard upper | 
|         |   2627 ** bound set by a compile-time C preprocessor macro named SQLITE_MAX_XYZ. | 
|         |   2628 ** (The "_LIMIT_" in the name is changed to "_MAX_".) | 
|         |   2629 ** Attempts to increase a limit above its hard upper bound are | 
|         |   2630 ** silently truncated to the hard upper limit. | 
|         |   2631 ** | 
|         |   2632 ** Run time limits are intended for use in applications that manage | 
|         |   2633 ** both their own internal database and also databases that are controlled | 
|         |   2634 ** by untrusted external sources.  An example application might be a | 
|         |   2635 ** webbrowser that has its own databases for storing history and | 
|         |   2636 ** separate databases controlled by JavaScript applications downloaded | 
|         |   2637 ** off the Internet.  The internal databases can be given the | 
|         |   2638 ** large, default limits.  Databases managed by external sources can | 
|         |   2639 ** be given much smaller limits designed to prevent a denial of service | 
|         |   2640 ** attack.  Developers might also want to use the [sqlite3_set_authorizer()] | 
|         |   2641 ** interface to further control untrusted SQL.  The size of the database | 
|         |   2642 ** created by an untrusted script can be contained using the | 
|         |   2643 ** [max_page_count] [PRAGMA]. | 
|         |   2644 ** | 
|         |   2645 ** New run-time limit categories may be added in future releases. | 
|         |   2646 ** | 
|         |   2647 ** INVARIANTS: | 
|         |   2648 ** | 
|         |   2649 ** {H12762} A successful call to [sqlite3_limit(D,C,V)] where V is | 
|         |   2650 **          positive changes the limit on the size of construct C in the | 
|         |   2651 **          [database connection] D to the lesser of V and the hard upper | 
|         |   2652 **          bound on the size of C that is set at compile-time. | 
|         |   2653 ** | 
|         |   2654 ** {H12766} A successful call to [sqlite3_limit(D,C,V)] where V is negative | 
|         |   2655 **          leaves the state of the [database connection] D unchanged. | 
|         |   2656 ** | 
|         |   2657 ** {H12769} A successful call to [sqlite3_limit(D,C,V)] returns the | 
|         |   2658 **          value of the limit on the size of construct C in the | 
|         |   2659 **          [database connection] D as it was prior to the call. | 
|         |   2660 */ | 
|         |   2661 IMPORT_C int sqlite3_limit(sqlite3*, int id, int newVal); | 
|         |   2662  | 
|         |   2663 /* | 
|         |   2664 ** CAPI3REF: Run-Time Limit Categories {H12790} <H12760> | 
|         |   2665 ** KEYWORDS: {limit category} {limit categories} | 
|         |   2666 ** | 
|         |   2667 ** These constants define various aspects of a [database connection] | 
|         |   2668 ** that can be limited in size by calls to [sqlite3_limit()]. | 
|         |   2669 ** The meanings of the various limits are as follows: | 
|         |   2670 ** | 
|         |   2671 ** <dl> | 
|         |   2672 ** <dt>SQLITE_LIMIT_LENGTH</dt> | 
|         |   2673 ** <dd>The maximum size of any string or BLOB or table row.<dd> | 
|         |   2674 ** | 
|         |   2675 ** <dt>SQLITE_LIMIT_SQL_LENGTH</dt> | 
|         |   2676 ** <dd>The maximum length of an SQL statement.</dd> | 
|         |   2677 ** | 
|         |   2678 ** <dt>SQLITE_LIMIT_COLUMN</dt> | 
|         |   2679 ** <dd>The maximum number of columns in a table definition or in the | 
|         |   2680 ** result set of a SELECT or the maximum number of columns in an index | 
|         |   2681 ** or in an ORDER BY or GROUP BY clause.</dd> | 
|         |   2682 ** | 
|         |   2683 ** <dt>SQLITE_LIMIT_EXPR_DEPTH</dt> | 
|         |   2684 ** <dd>The maximum depth of the parse tree on any expression.</dd> | 
|         |   2685 ** | 
|         |   2686 ** <dt>SQLITE_LIMIT_COMPOUND_SELECT</dt> | 
|         |   2687 ** <dd>The maximum number of terms in a compound SELECT statement.</dd> | 
|         |   2688 ** | 
|         |   2689 ** <dt>SQLITE_LIMIT_VDBE_OP</dt> | 
|         |   2690 ** <dd>The maximum number of instructions in a virtual machine program | 
|         |   2691 ** used to implement an SQL statement.</dd> | 
|         |   2692 ** | 
|         |   2693 ** <dt>SQLITE_LIMIT_FUNCTION_ARG</dt> | 
|         |   2694 ** <dd>The maximum number of arguments on a function.</dd> | 
|         |   2695 ** | 
|         |   2696 ** <dt>SQLITE_LIMIT_ATTACHED</dt> | 
|         |   2697 ** <dd>The maximum number of attached databases.</dd> | 
|         |   2698 ** | 
|         |   2699 ** <dt>SQLITE_LIMIT_LIKE_PATTERN_LENGTH</dt> | 
|         |   2700 ** <dd>The maximum length of the pattern argument to the LIKE or | 
|         |   2701 ** GLOB operators.</dd> | 
|         |   2702 ** | 
|         |   2703 ** <dt>SQLITE_LIMIT_VARIABLE_NUMBER</dt> | 
|         |   2704 ** <dd>The maximum number of variables in an SQL statement that can | 
|         |   2705 ** be bound.</dd> | 
|         |   2706 ** </dl> | 
|         |   2707 */ | 
|         |   2708 #define SQLITE_LIMIT_LENGTH                    0 | 
|         |   2709 #define SQLITE_LIMIT_SQL_LENGTH                1 | 
|         |   2710 #define SQLITE_LIMIT_COLUMN                    2 | 
|         |   2711 #define SQLITE_LIMIT_EXPR_DEPTH                3 | 
|         |   2712 #define SQLITE_LIMIT_COMPOUND_SELECT           4 | 
|         |   2713 #define SQLITE_LIMIT_VDBE_OP                   5 | 
|         |   2714 #define SQLITE_LIMIT_FUNCTION_ARG              6 | 
|         |   2715 #define SQLITE_LIMIT_ATTACHED                  7 | 
|         |   2716 #define SQLITE_LIMIT_LIKE_PATTERN_LENGTH       8 | 
|         |   2717 #define SQLITE_LIMIT_VARIABLE_NUMBER           9 | 
|         |   2718  | 
|         |   2719 /* | 
|         |   2720 ** CAPI3REF: Compiling An SQL Statement {H13010} <S10000> | 
|         |   2721 ** KEYWORDS: {SQL statement compiler} | 
|         |   2722 ** | 
|         |   2723 ** To execute an SQL query, it must first be compiled into a byte-code | 
|         |   2724 ** program using one of these routines. | 
|         |   2725 ** | 
|         |   2726 ** The first argument, "db", is a [database connection] obtained from a | 
|         |   2727 ** prior call to [sqlite3_open()], [sqlite3_open_v2()] or [sqlite3_open16()]. | 
|         |   2728 ** | 
|         |   2729 ** The second argument, "zSql", is the statement to be compiled, encoded | 
|         |   2730 ** as either UTF-8 or UTF-16.  The sqlite3_prepare() and sqlite3_prepare_v2() | 
|         |   2731 ** interfaces use UTF-8, and sqlite3_prepare16() and sqlite3_prepare16_v2() | 
|         |   2732 ** use UTF-16. | 
|         |   2733 ** | 
|         |   2734 ** If the nByte argument is less than zero, then zSql is read up to the | 
|         |   2735 ** first zero terminator. If nByte is non-negative, then it is the maximum | 
|         |   2736 ** number of  bytes read from zSql.  When nByte is non-negative, the | 
|         |   2737 ** zSql string ends at either the first '\000' or '\u0000' character or | 
|         |   2738 ** the nByte-th byte, whichever comes first. If the caller knows | 
|         |   2739 ** that the supplied string is nul-terminated, then there is a small | 
|         |   2740 ** performance advantage to be gained by passing an nByte parameter that | 
|         |   2741 ** is equal to the number of bytes in the input string <i>including</i> | 
|         |   2742 ** the nul-terminator bytes. | 
|         |   2743 ** | 
|         |   2744 ** *pzTail is made to point to the first byte past the end of the | 
|         |   2745 ** first SQL statement in zSql.  These routines only compile the first | 
|         |   2746 ** statement in zSql, so *pzTail is left pointing to what remains | 
|         |   2747 ** uncompiled. | 
|         |   2748 ** | 
|         |   2749 ** *ppStmt is left pointing to a compiled [prepared statement] that can be | 
|         |   2750 ** executed using [sqlite3_step()].  If there is an error, *ppStmt is set | 
|         |   2751 ** to NULL.  If the input text contains no SQL (if the input is an empty | 
|         |   2752 ** string or a comment) then *ppStmt is set to NULL. | 
|         |   2753 ** {A13018} The calling procedure is responsible for deleting the compiled | 
|         |   2754 ** SQL statement using [sqlite3_finalize()] after it has finished with it. | 
|         |   2755 ** | 
|         |   2756 ** On success, [SQLITE_OK] is returned, otherwise an [error code] is returned. | 
|         |   2757 ** | 
|         |   2758 ** The sqlite3_prepare_v2() and sqlite3_prepare16_v2() interfaces are | 
|         |   2759 ** recommended for all new programs. The two older interfaces are retained | 
|         |   2760 ** for backwards compatibility, but their use is discouraged. | 
|         |   2761 ** In the "v2" interfaces, the prepared statement | 
|         |   2762 ** that is returned (the [sqlite3_stmt] object) contains a copy of the | 
|         |   2763 ** original SQL text. This causes the [sqlite3_step()] interface to | 
|         |   2764 ** behave a differently in two ways: | 
|         |   2765 ** | 
|         |   2766 ** <ol> | 
|         |   2767 ** <li> | 
|         |   2768 ** If the database schema changes, instead of returning [SQLITE_SCHEMA] as it | 
|         |   2769 ** always used to do, [sqlite3_step()] will automatically recompile the SQL | 
|         |   2770 ** statement and try to run it again.  If the schema has changed in | 
|         |   2771 ** a way that makes the statement no longer valid, [sqlite3_step()] will still | 
|         |   2772 ** return [SQLITE_SCHEMA].  But unlike the legacy behavior, [SQLITE_SCHEMA] is | 
|         |   2773 ** now a fatal error.  Calling [sqlite3_prepare_v2()] again will not make the | 
|         |   2774 ** error go away.  Note: use [sqlite3_errmsg()] to find the text | 
|         |   2775 ** of the parsing error that results in an [SQLITE_SCHEMA] return. | 
|         |   2776 ** </li> | 
|         |   2777 ** | 
|         |   2778 ** <li> | 
|         |   2779 ** When an error occurs, [sqlite3_step()] will return one of the detailed | 
|         |   2780 ** [error codes] or [extended error codes].  The legacy behavior was that | 
|         |   2781 ** [sqlite3_step()] would only return a generic [SQLITE_ERROR] result code | 
|         |   2782 ** and you would have to make a second call to [sqlite3_reset()] in order | 
|         |   2783 ** to find the underlying cause of the problem. With the "v2" prepare | 
|         |   2784 ** interfaces, the underlying reason for the error is returned immediately. | 
|         |   2785 ** </li> | 
|         |   2786 ** </ol> | 
|         |   2787 ** | 
|         |   2788 ** INVARIANTS: | 
|         |   2789 ** | 
|         |   2790 ** {H13011} The [sqlite3_prepare(db,zSql,...)] and | 
|         |   2791 **          [sqlite3_prepare_v2(db,zSql,...)] interfaces interpret the | 
|         |   2792 **          text in their zSql parameter as UTF-8. | 
|         |   2793 ** | 
|         |   2794 ** {H13012} The [sqlite3_prepare16(db,zSql,...)] and | 
|         |   2795 **          [sqlite3_prepare16_v2(db,zSql,...)] interfaces interpret the | 
|         |   2796 **          text in their zSql parameter as UTF-16 in the native byte order. | 
|         |   2797 ** | 
|         |   2798 ** {H13013} If the nByte argument to [sqlite3_prepare_v2(db,zSql,nByte,...)] | 
|         |   2799 **          and its variants is less than zero, the SQL text is | 
|         |   2800 **          read from zSql is read up to the first zero terminator. | 
|         |   2801 ** | 
|         |   2802 ** {H13014} If the nByte argument to [sqlite3_prepare_v2(db,zSql,nByte,...)] | 
|         |   2803 **          and its variants is non-negative, then at most nBytes bytes of | 
|         |   2804 **          SQL text is read from zSql. | 
|         |   2805 ** | 
|         |   2806 ** {H13015} In [sqlite3_prepare_v2(db,zSql,N,P,pzTail)] and its variants | 
|         |   2807 **          if the zSql input text contains more than one SQL statement | 
|         |   2808 **          and pzTail is not NULL, then *pzTail is made to point to the | 
|         |   2809 **          first byte past the end of the first SQL statement in zSql. | 
|         |   2810 **          <todo>What does *pzTail point to if there is one statement?</todo> | 
|         |   2811 ** | 
|         |   2812 ** {H13016} A successful call to [sqlite3_prepare_v2(db,zSql,N,ppStmt,...)] | 
|         |   2813 **          or one of its variants writes into *ppStmt a pointer to a new | 
|         |   2814 **          [prepared statement] or a pointer to NULL if zSql contains | 
|         |   2815 **          nothing other than whitespace or comments. | 
|         |   2816 ** | 
|         |   2817 ** {H13019} The [sqlite3_prepare_v2()] interface and its variants return | 
|         |   2818 **          [SQLITE_OK] or an appropriate [error code] upon failure. | 
|         |   2819 ** | 
|         |   2820 ** {H13021} Before [sqlite3_prepare(db,zSql,nByte,ppStmt,pzTail)] or its | 
|         |   2821 **          variants returns an error (any value other than [SQLITE_OK]), | 
|         |   2822 **          they first set *ppStmt to NULL. | 
|         |   2823 */ | 
|         |   2824 IMPORT_C int sqlite3_prepare( | 
|         |   2825   sqlite3 *db,            /* Database handle */ | 
|         |   2826   const char *zSql,       /* SQL statement, UTF-8 encoded */ | 
|         |   2827   int nByte,              /* Maximum length of zSql in bytes. */ | 
|         |   2828   sqlite3_stmt **ppStmt,  /* OUT: Statement handle */ | 
|         |   2829   const char **pzTail     /* OUT: Pointer to unused portion of zSql */ | 
|         |   2830 ); | 
|         |   2831 IMPORT_C int sqlite3_prepare_v2( | 
|         |   2832   sqlite3 *db,            /* Database handle */ | 
|         |   2833   const char *zSql,       /* SQL statement, UTF-8 encoded */ | 
|         |   2834   int nByte,              /* Maximum length of zSql in bytes. */ | 
|         |   2835   sqlite3_stmt **ppStmt,  /* OUT: Statement handle */ | 
|         |   2836   const char **pzTail     /* OUT: Pointer to unused portion of zSql */ | 
|         |   2837 ); | 
|         |   2838 IMPORT_C int sqlite3_prepare16( | 
|         |   2839   sqlite3 *db,            /* Database handle */ | 
|         |   2840   const void *zSql,       /* SQL statement, UTF-16 encoded */ | 
|         |   2841   int nByte,              /* Maximum length of zSql in bytes. */ | 
|         |   2842   sqlite3_stmt **ppStmt,  /* OUT: Statement handle */ | 
|         |   2843   const void **pzTail     /* OUT: Pointer to unused portion of zSql */ | 
|         |   2844 ); | 
|         |   2845 IMPORT_C int sqlite3_prepare16_v2( | 
|         |   2846   sqlite3 *db,            /* Database handle */ | 
|         |   2847   const void *zSql,       /* SQL statement, UTF-16 encoded */ | 
|         |   2848   int nByte,              /* Maximum length of zSql in bytes. */ | 
|         |   2849   sqlite3_stmt **ppStmt,  /* OUT: Statement handle */ | 
|         |   2850   const void **pzTail     /* OUT: Pointer to unused portion of zSql */ | 
|         |   2851 ); | 
|         |   2852  | 
|         |   2853 /* | 
|         |   2854 ** CAPI3REF: Retrieving Statement SQL {H13100} <H13000> | 
|         |   2855 ** | 
|         |   2856 ** This interface can be used to retrieve a saved copy of the original | 
|         |   2857 ** SQL text used to create a [prepared statement] if that statement was | 
|         |   2858 ** compiled using either [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()]. | 
|         |   2859 ** | 
|         |   2860 ** INVARIANTS: | 
|         |   2861 ** | 
|         |   2862 ** {H13101} If the [prepared statement] passed as the argument to | 
|         |   2863 **          [sqlite3_sql()] was compiled using either [sqlite3_prepare_v2()] or | 
|         |   2864 **          [sqlite3_prepare16_v2()], then [sqlite3_sql()] returns | 
|         |   2865 **          a pointer to a zero-terminated string containing a UTF-8 rendering | 
|         |   2866 **          of the original SQL statement. | 
|         |   2867 ** | 
|         |   2868 ** {H13102} If the [prepared statement] passed as the argument to | 
|         |   2869 **          [sqlite3_sql()] was compiled using either [sqlite3_prepare()] or | 
|         |   2870 **          [sqlite3_prepare16()], then [sqlite3_sql()] returns a NULL pointer. | 
|         |   2871 ** | 
|         |   2872 ** {H13103} The string returned by [sqlite3_sql(S)] is valid until the | 
|         |   2873 **          [prepared statement] S is deleted using [sqlite3_finalize(S)]. | 
|         |   2874 */ | 
|         |   2875 IMPORT_C const char *sqlite3_sql(sqlite3_stmt *pStmt); | 
|         |   2876  | 
|         |   2877 /* | 
|         |   2878 ** CAPI3REF: Dynamically Typed Value Object {H15000} <S20200> | 
|         |   2879 ** KEYWORDS: {protected sqlite3_value} {unprotected sqlite3_value} | 
|         |   2880 ** | 
|         |   2881 ** SQLite uses the sqlite3_value object to represent all values | 
|         |   2882 ** that can be stored in a database table. SQLite uses dynamic typing | 
|         |   2883 ** for the values it stores. Values stored in sqlite3_value objects | 
|         |   2884 ** can be integers, floating point values, strings, BLOBs, or NULL. | 
|         |   2885 ** | 
|         |   2886 ** An sqlite3_value object may be either "protected" or "unprotected". | 
|         |   2887 ** Some interfaces require a protected sqlite3_value.  Other interfaces | 
|         |   2888 ** will accept either a protected or an unprotected sqlite3_value. | 
|         |   2889 ** Every interface that accepts sqlite3_value arguments specifies | 
|         |   2890 ** whether or not it requires a protected sqlite3_value. | 
|         |   2891 ** | 
|         |   2892 ** The terms "protected" and "unprotected" refer to whether or not | 
|         |   2893 ** a mutex is held.  A internal mutex is held for a protected | 
|         |   2894 ** sqlite3_value object but no mutex is held for an unprotected | 
|         |   2895 ** sqlite3_value object.  If SQLite is compiled to be single-threaded | 
|         |   2896 ** (with [SQLITE_THREADSAFE=0] and with [sqlite3_threadsafe()] returning 0) | 
|         |   2897 ** or if SQLite is run in one of reduced mutex modes  | 
|         |   2898 ** [SQLITE_CONFIG_SINGLETHREAD] or [SQLITE_CONFIG_MULTITHREAD] | 
|         |   2899 ** then there is no distinction between protected and unprotected | 
|         |   2900 ** sqlite3_value objects and they can be used interchangeably.  However, | 
|         |   2901 ** for maximum code portability it is recommended that applications | 
|         |   2902 ** still make the distinction between between protected and unprotected | 
|         |   2903 ** sqlite3_value objects even when not strictly required. | 
|         |   2904 ** | 
|         |   2905 ** The sqlite3_value objects that are passed as parameters into the | 
|         |   2906 ** implementation of [application-defined SQL functions] are protected. | 
|         |   2907 ** The sqlite3_value object returned by | 
|         |   2908 ** [sqlite3_column_value()] is unprotected. | 
|         |   2909 ** Unprotected sqlite3_value objects may only be used with | 
|         |   2910 ** [sqlite3_result_value()] and [sqlite3_bind_value()]. | 
|         |   2911 ** The [sqlite3_value_blob | sqlite3_value_type()] family of | 
|         |   2912 ** interfaces require protected sqlite3_value objects. | 
|         |   2913 */ | 
|         |   2914 typedef struct Mem sqlite3_value; | 
|         |   2915  | 
|         |   2916 /* | 
|         |   2917 ** CAPI3REF: SQL Function Context Object {H16001} <S20200> | 
|         |   2918 ** | 
|         |   2919 ** The context in which an SQL function executes is stored in an | 
|         |   2920 ** sqlite3_context object.  A pointer to an sqlite3_context object | 
|         |   2921 ** is always first parameter to [application-defined SQL functions]. | 
|         |   2922 ** The application-defined SQL function implementation will pass this | 
|         |   2923 ** pointer through into calls to [sqlite3_result_int | sqlite3_result()], | 
|         |   2924 ** [sqlite3_aggregate_context()], [sqlite3_user_data()], | 
|         |   2925 ** [sqlite3_context_db_handle()], [sqlite3_get_auxdata()], | 
|         |   2926 ** and/or [sqlite3_set_auxdata()]. | 
|         |   2927 */ | 
|         |   2928 typedef struct sqlite3_context sqlite3_context; | 
|         |   2929  | 
|         |   2930 /* | 
|         |   2931 ** CAPI3REF: Binding Values To Prepared Statements {H13500} <S70300> | 
|         |   2932 ** KEYWORDS: {host parameter} {host parameters} {host parameter name} | 
|         |   2933 ** KEYWORDS: {SQL parameter} {SQL parameters} {parameter binding} | 
|         |   2934 ** | 
|         |   2935 ** In the SQL strings input to [sqlite3_prepare_v2()] and its variants, | 
|         |   2936 ** literals may be replaced by a parameter in one of these forms: | 
|         |   2937 ** | 
|         |   2938 ** <ul> | 
|         |   2939 ** <li>  ? | 
|         |   2940 ** <li>  ?NNN | 
|         |   2941 ** <li>  :VVV | 
|         |   2942 ** <li>  @VVV | 
|         |   2943 ** <li>  $VVV | 
|         |   2944 ** </ul> | 
|         |   2945 ** | 
|         |   2946 ** In the parameter forms shown above NNN is an integer literal, | 
|         |   2947 ** and VVV is an alpha-numeric parameter name. The values of these | 
|         |   2948 ** parameters (also called "host parameter names" or "SQL parameters") | 
|         |   2949 ** can be set using the sqlite3_bind_*() routines defined here. | 
|         |   2950 ** | 
|         |   2951 ** The first argument to the sqlite3_bind_*() routines is always | 
|         |   2952 ** a pointer to the [sqlite3_stmt] object returned from | 
|         |   2953 ** [sqlite3_prepare_v2()] or its variants. | 
|         |   2954 ** | 
|         |   2955 ** The second argument is the index of the SQL parameter to be set. | 
|         |   2956 ** The leftmost SQL parameter has an index of 1.  When the same named | 
|         |   2957 ** SQL parameter is used more than once, second and subsequent | 
|         |   2958 ** occurrences have the same index as the first occurrence. | 
|         |   2959 ** The index for named parameters can be looked up using the | 
|         |   2960 ** [sqlite3_bind_parameter_index()] API if desired.  The index | 
|         |   2961 ** for "?NNN" parameters is the value of NNN. | 
|         |   2962 ** The NNN value must be between 1 and the [sqlite3_limit()] | 
|         |   2963 ** parameter [SQLITE_LIMIT_VARIABLE_NUMBER] (default value: 999). | 
|         |   2964 ** | 
|         |   2965 ** The third argument is the value to bind to the parameter. | 
|         |   2966 ** | 
|         |   2967 ** In those routines that have a fourth argument, its value is the | 
|         |   2968 ** number of bytes in the parameter.  To be clear: the value is the | 
|         |   2969 ** number of <u>bytes</u> in the value, not the number of characters. | 
|         |   2970 ** If the fourth parameter is negative, the length of the string is | 
|         |   2971 ** the number of bytes up to the first zero terminator. | 
|         |   2972 ** | 
|         |   2973 ** The fifth argument to sqlite3_bind_blob(), sqlite3_bind_text(), and | 
|         |   2974 ** sqlite3_bind_text16() is a destructor used to dispose of the BLOB or | 
|         |   2975 ** string after SQLite has finished with it. If the fifth argument is | 
|         |   2976 ** the special value [SQLITE_STATIC], then SQLite assumes that the | 
|         |   2977 ** information is in static, unmanaged space and does not need to be freed. | 
|         |   2978 ** If the fifth argument has the value [SQLITE_TRANSIENT], then | 
|         |   2979 ** SQLite makes its own private copy of the data immediately, before | 
|         |   2980 ** the sqlite3_bind_*() routine returns. | 
|         |   2981 ** | 
|         |   2982 ** The sqlite3_bind_zeroblob() routine binds a BLOB of length N that | 
|         |   2983 ** is filled with zeroes.  A zeroblob uses a fixed amount of memory | 
|         |   2984 ** (just an integer to hold its size) while it is being processed. | 
|         |   2985 ** Zeroblobs are intended to serve as placeholders for BLOBs whose | 
|         |   2986 ** content is later written using | 
|         |   2987 ** [sqlite3_blob_open | incremental BLOB I/O] routines. | 
|         |   2988 ** A negative value for the zeroblob results in a zero-length BLOB. | 
|         |   2989 ** | 
|         |   2990 ** The sqlite3_bind_*() routines must be called after | 
|         |   2991 ** [sqlite3_prepare_v2()] (and its variants) or [sqlite3_reset()] and | 
|         |   2992 ** before [sqlite3_step()]. | 
|         |   2993 ** Bindings are not cleared by the [sqlite3_reset()] routine. | 
|         |   2994 ** Unbound parameters are interpreted as NULL. | 
|         |   2995 ** | 
|         |   2996 ** These routines return [SQLITE_OK] on success or an error code if | 
|         |   2997 ** anything goes wrong.  [SQLITE_RANGE] is returned if the parameter | 
|         |   2998 ** index is out of range.  [SQLITE_NOMEM] is returned if malloc() fails. | 
|         |   2999 ** [SQLITE_MISUSE] might be returned if these routines are called on a | 
|         |   3000 ** virtual machine that is the wrong state or which has already been finalized. | 
|         |   3001 ** Detection of misuse is unreliable.  Applications should not depend | 
|         |   3002 ** on SQLITE_MISUSE returns.  SQLITE_MISUSE is intended to indicate a | 
|         |   3003 ** a logic error in the application.  Future versions of SQLite might | 
|         |   3004 ** panic rather than return SQLITE_MISUSE. | 
|         |   3005 ** | 
|         |   3006 ** See also: [sqlite3_bind_parameter_count()], | 
|         |   3007 ** [sqlite3_bind_parameter_name()], and [sqlite3_bind_parameter_index()]. | 
|         |   3008 ** | 
|         |   3009 ** INVARIANTS: | 
|         |   3010 ** | 
|         |   3011 ** {H13506} The [SQL statement compiler] recognizes tokens of the forms | 
|         |   3012 **          "?", "?NNN", "$VVV", ":VVV", and "@VVV" as SQL parameters, | 
|         |   3013 **          where NNN is any sequence of one or more digits | 
|         |   3014 **          and where VVV is any sequence of one or more alphanumeric | 
|         |   3015 **          characters or "::" optionally followed by a string containing | 
|         |   3016 **          no spaces and contained within parentheses. | 
|         |   3017 ** | 
|         |   3018 ** {H13509} The initial value of an SQL parameter is NULL. | 
|         |   3019 ** | 
|         |   3020 ** {H13512} The index of an "?" SQL parameter is one larger than the | 
|         |   3021 **          largest index of SQL parameter to the left, or 1 if | 
|         |   3022 **          the "?" is the leftmost SQL parameter. | 
|         |   3023 ** | 
|         |   3024 ** {H13515} The index of an "?NNN" SQL parameter is the integer NNN. | 
|         |   3025 ** | 
|         |   3026 ** {H13518} The index of an ":VVV", "$VVV", or "@VVV" SQL parameter is | 
|         |   3027 **          the same as the index of leftmost occurrences of the same | 
|         |   3028 **          parameter, or one more than the largest index over all | 
|         |   3029 **          parameters to the left if this is the first occurrence | 
|         |   3030 **          of this parameter, or 1 if this is the leftmost parameter. | 
|         |   3031 ** | 
|         |   3032 ** {H13521} The [SQL statement compiler] fails with an [SQLITE_RANGE] | 
|         |   3033 **          error if the index of an SQL parameter is less than 1 | 
|         |   3034 **          or greater than the compile-time SQLITE_MAX_VARIABLE_NUMBER | 
|         |   3035 **          parameter. | 
|         |   3036 ** | 
|         |   3037 ** {H13524} Calls to [sqlite3_bind_text | sqlite3_bind(S,N,V,...)] | 
|         |   3038 **          associate the value V with all SQL parameters having an | 
|         |   3039 **          index of N in the [prepared statement] S. | 
|         |   3040 ** | 
|         |   3041 ** {H13527} Calls to [sqlite3_bind_text | sqlite3_bind(S,N,...)] | 
|         |   3042 **          override prior calls with the same values of S and N. | 
|         |   3043 ** | 
|         |   3044 ** {H13530} Bindings established by [sqlite3_bind_text | sqlite3_bind(S,...)] | 
|         |   3045 **          persist across calls to [sqlite3_reset(S)]. | 
|         |   3046 ** | 
|         |   3047 ** {H13533} In calls to [sqlite3_bind_blob(S,N,V,L,D)], | 
|         |   3048 **          [sqlite3_bind_text(S,N,V,L,D)], or | 
|         |   3049 **          [sqlite3_bind_text16(S,N,V,L,D)] SQLite binds the first L | 
|         |   3050 **          bytes of the BLOB or string pointed to by V, when L | 
|         |   3051 **          is non-negative. | 
|         |   3052 ** | 
|         |   3053 ** {H13536} In calls to [sqlite3_bind_text(S,N,V,L,D)] or | 
|         |   3054 **          [sqlite3_bind_text16(S,N,V,L,D)] SQLite binds characters | 
|         |   3055 **          from V through the first zero character when L is negative. | 
|         |   3056 ** | 
|         |   3057 ** {H13539} In calls to [sqlite3_bind_blob(S,N,V,L,D)], | 
|         |   3058 **          [sqlite3_bind_text(S,N,V,L,D)], or | 
|         |   3059 **          [sqlite3_bind_text16(S,N,V,L,D)] when D is the special | 
|         |   3060 **          constant [SQLITE_STATIC], SQLite assumes that the value V | 
|         |   3061 **          is held in static unmanaged space that will not change | 
|         |   3062 **          during the lifetime of the binding. | 
|         |   3063 ** | 
|         |   3064 ** {H13542} In calls to [sqlite3_bind_blob(S,N,V,L,D)], | 
|         |   3065 **          [sqlite3_bind_text(S,N,V,L,D)], or | 
|         |   3066 **          [sqlite3_bind_text16(S,N,V,L,D)] when D is the special | 
|         |   3067 **          constant [SQLITE_TRANSIENT], the routine makes a | 
|         |   3068 **          private copy of the value V before it returns. | 
|         |   3069 ** | 
|         |   3070 ** {H13545} In calls to [sqlite3_bind_blob(S,N,V,L,D)], | 
|         |   3071 **          [sqlite3_bind_text(S,N,V,L,D)], or | 
|         |   3072 **          [sqlite3_bind_text16(S,N,V,L,D)] when D is a pointer to | 
|         |   3073 **          a function, SQLite invokes that function to destroy the | 
|         |   3074 **          value V after it has finished using the value V. | 
|         |   3075 ** | 
|         |   3076 ** {H13548} In calls to [sqlite3_bind_zeroblob(S,N,V,L)] the value bound | 
|         |   3077 **          is a BLOB of L bytes, or a zero-length BLOB if L is negative. | 
|         |   3078 ** | 
|         |   3079 ** {H13551} In calls to [sqlite3_bind_value(S,N,V)] the V argument may | 
|         |   3080 **          be either a [protected sqlite3_value] object or an | 
|         |   3081 **          [unprotected sqlite3_value] object. | 
|         |   3082 */ | 
|         |   3083 IMPORT_C int sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int n, void(*)(void*)); | 
|         |   3084 IMPORT_C int sqlite3_bind_double(sqlite3_stmt*, int, double); | 
|         |   3085 IMPORT_C int sqlite3_bind_int(sqlite3_stmt*, int, int); | 
|         |   3086 IMPORT_C int sqlite3_bind_int64(sqlite3_stmt*, int, sqlite3_int64); | 
|         |   3087 IMPORT_C int sqlite3_bind_null(sqlite3_stmt*, int); | 
|         |   3088 IMPORT_C int sqlite3_bind_text(sqlite3_stmt*, int, const char*, int n, void(*)(void*)); | 
|         |   3089 IMPORT_C int sqlite3_bind_text16(sqlite3_stmt*, int, const void*, int, void(*)(void*)); | 
|         |   3090 IMPORT_C int sqlite3_bind_value(sqlite3_stmt*, int, const sqlite3_value*); | 
|         |   3091 IMPORT_C int sqlite3_bind_zeroblob(sqlite3_stmt*, int, int n); | 
|         |   3092  | 
|         |   3093 /* | 
|         |   3094 ** CAPI3REF: Number Of SQL Parameters {H13600} <S70300> | 
|         |   3095 ** | 
|         |   3096 ** This routine can be used to find the number of [SQL parameters] | 
|         |   3097 ** in a [prepared statement].  SQL parameters are tokens of the | 
|         |   3098 ** form "?", "?NNN", ":AAA", "$AAA", or "@AAA" that serve as | 
|         |   3099 ** placeholders for values that are [sqlite3_bind_blob | bound] | 
|         |   3100 ** to the parameters at a later time. | 
|         |   3101 ** | 
|         |   3102 ** This routine actually returns the index of the largest (rightmost) | 
|         |   3103 ** parameter. For all forms except ?NNN, this will correspond to the | 
|         |   3104 ** number of unique parameters.  If parameters of the ?NNN are used, | 
|         |   3105 ** there may be gaps in the list. | 
|         |   3106 ** | 
|         |   3107 ** See also: [sqlite3_bind_blob|sqlite3_bind()], | 
|         |   3108 ** [sqlite3_bind_parameter_name()], and | 
|         |   3109 ** [sqlite3_bind_parameter_index()]. | 
|         |   3110 ** | 
|         |   3111 ** INVARIANTS: | 
|         |   3112 ** | 
|         |   3113 ** {H13601} The [sqlite3_bind_parameter_count(S)] interface returns | 
|         |   3114 **          the largest index of all SQL parameters in the | 
|         |   3115 **          [prepared statement] S, or 0 if S contains no SQL parameters. | 
|         |   3116 */ | 
|         |   3117 IMPORT_C int sqlite3_bind_parameter_count(sqlite3_stmt*); | 
|         |   3118  | 
|         |   3119 /* | 
|         |   3120 ** CAPI3REF: Name Of A Host Parameter {H13620} <S70300> | 
|         |   3121 ** | 
|         |   3122 ** This routine returns a pointer to the name of the n-th | 
|         |   3123 ** [SQL parameter] in a [prepared statement]. | 
|         |   3124 ** SQL parameters of the form "?NNN" or ":AAA" or "@AAA" or "$AAA" | 
|         |   3125 ** have a name which is the string "?NNN" or ":AAA" or "@AAA" or "$AAA" | 
|         |   3126 ** respectively. | 
|         |   3127 ** In other words, the initial ":" or "$" or "@" or "?" | 
|         |   3128 ** is included as part of the name. | 
|         |   3129 ** Parameters of the form "?" without a following integer have no name | 
|         |   3130 ** and are also referred to as "anonymous parameters". | 
|         |   3131 ** | 
|         |   3132 ** The first host parameter has an index of 1, not 0. | 
|         |   3133 ** | 
|         |   3134 ** If the value n is out of range or if the n-th parameter is | 
|         |   3135 ** nameless, then NULL is returned.  The returned string is | 
|         |   3136 ** always in UTF-8 encoding even if the named parameter was | 
|         |   3137 ** originally specified as UTF-16 in [sqlite3_prepare16()] or | 
|         |   3138 ** [sqlite3_prepare16_v2()]. | 
|         |   3139 ** | 
|         |   3140 ** See also: [sqlite3_bind_blob|sqlite3_bind()], | 
|         |   3141 ** [sqlite3_bind_parameter_count()], and | 
|         |   3142 ** [sqlite3_bind_parameter_index()]. | 
|         |   3143 ** | 
|         |   3144 ** INVARIANTS: | 
|         |   3145 ** | 
|         |   3146 ** {H13621} The [sqlite3_bind_parameter_name(S,N)] interface returns | 
|         |   3147 **          a UTF-8 rendering of the name of the SQL parameter in | 
|         |   3148 **          the [prepared statement] S having index N, or | 
|         |   3149 **          NULL if there is no SQL parameter with index N or if the | 
|         |   3150 **          parameter with index N is an anonymous parameter "?". | 
|         |   3151 */ | 
|         |   3152 IMPORT_C const char *sqlite3_bind_parameter_name(sqlite3_stmt*, int); | 
|         |   3153  | 
|         |   3154 /* | 
|         |   3155 ** CAPI3REF: Index Of A Parameter With A Given Name {H13640} <S70300> | 
|         |   3156 ** | 
|         |   3157 ** Return the index of an SQL parameter given its name.  The | 
|         |   3158 ** index value returned is suitable for use as the second | 
|         |   3159 ** parameter to [sqlite3_bind_blob|sqlite3_bind()].  A zero | 
|         |   3160 ** is returned if no matching parameter is found.  The parameter | 
|         |   3161 ** name must be given in UTF-8 even if the original statement | 
|         |   3162 ** was prepared from UTF-16 text using [sqlite3_prepare16_v2()]. | 
|         |   3163 ** | 
|         |   3164 ** See also: [sqlite3_bind_blob|sqlite3_bind()], | 
|         |   3165 ** [sqlite3_bind_parameter_count()], and | 
|         |   3166 ** [sqlite3_bind_parameter_index()]. | 
|         |   3167 ** | 
|         |   3168 ** INVARIANTS: | 
|         |   3169 ** | 
|         |   3170 ** {H13641} The [sqlite3_bind_parameter_index(S,N)] interface returns | 
|         |   3171 **          the index of SQL parameter in the [prepared statement] | 
|         |   3172 **          S whose name matches the UTF-8 string N, or 0 if there is | 
|         |   3173 **          no match. | 
|         |   3174 */ | 
|         |   3175 IMPORT_C int sqlite3_bind_parameter_index(sqlite3_stmt*, const char *zName); | 
|         |   3176  | 
|         |   3177 /* | 
|         |   3178 ** CAPI3REF: Reset All Bindings On A Prepared Statement {H13660} <S70300> | 
|         |   3179 ** | 
|         |   3180 ** Contrary to the intuition of many, [sqlite3_reset()] does not reset | 
|         |   3181 ** the [sqlite3_bind_blob | bindings] on a [prepared statement]. | 
|         |   3182 ** Use this routine to reset all host parameters to NULL. | 
|         |   3183 ** | 
|         |   3184 ** INVARIANTS: | 
|         |   3185 ** | 
|         |   3186 ** {H13661} The [sqlite3_clear_bindings(S)] interface resets all SQL | 
|         |   3187 **          parameter bindings in the [prepared statement] S back to NULL. | 
|         |   3188 */ | 
|         |   3189 IMPORT_C int sqlite3_clear_bindings(sqlite3_stmt*); | 
|         |   3190  | 
|         |   3191 /* | 
|         |   3192 ** CAPI3REF: Number Of Columns In A Result Set {H13710} <S10700> | 
|         |   3193 ** | 
|         |   3194 ** Return the number of columns in the result set returned by the | 
|         |   3195 ** [prepared statement]. This routine returns 0 if pStmt is an SQL | 
|         |   3196 ** statement that does not return data (for example an [UPDATE]). | 
|         |   3197 ** | 
|         |   3198 ** INVARIANTS: | 
|         |   3199 ** | 
|         |   3200 ** {H13711} The [sqlite3_column_count(S)] interface returns the number of | 
|         |   3201 **          columns in the result set generated by the [prepared statement] S, | 
|         |   3202 **          or 0 if S does not generate a result set. | 
|         |   3203 */ | 
|         |   3204 IMPORT_C int sqlite3_column_count(sqlite3_stmt *pStmt); | 
|         |   3205  | 
|         |   3206 /* | 
|         |   3207 ** CAPI3REF: Column Names In A Result Set {H13720} <S10700> | 
|         |   3208 ** | 
|         |   3209 ** These routines return the name assigned to a particular column | 
|         |   3210 ** in the result set of a [SELECT] statement.  The sqlite3_column_name() | 
|         |   3211 ** interface returns a pointer to a zero-terminated UTF-8 string | 
|         |   3212 ** and sqlite3_column_name16() returns a pointer to a zero-terminated | 
|         |   3213 ** UTF-16 string.  The first parameter is the [prepared statement] | 
|         |   3214 ** that implements the [SELECT] statement. The second parameter is the | 
|         |   3215 ** column number.  The leftmost column is number 0. | 
|         |   3216 ** | 
|         |   3217 ** The returned string pointer is valid until either the [prepared statement] | 
|         |   3218 ** is destroyed by [sqlite3_finalize()] or until the next call to | 
|         |   3219 ** sqlite3_column_name() or sqlite3_column_name16() on the same column. | 
|         |   3220 ** | 
|         |   3221 ** If sqlite3_malloc() fails during the processing of either routine | 
|         |   3222 ** (for example during a conversion from UTF-8 to UTF-16) then a | 
|         |   3223 ** NULL pointer is returned. | 
|         |   3224 ** | 
|         |   3225 ** The name of a result column is the value of the "AS" clause for | 
|         |   3226 ** that column, if there is an AS clause.  If there is no AS clause | 
|         |   3227 ** then the name of the column is unspecified and may change from | 
|         |   3228 ** one release of SQLite to the next. | 
|         |   3229 ** | 
|         |   3230 ** INVARIANTS: | 
|         |   3231 ** | 
|         |   3232 ** {H13721} A successful invocation of the [sqlite3_column_name(S,N)] | 
|         |   3233 **          interface returns the name of the Nth column (where 0 is | 
|         |   3234 **          the leftmost column) for the result set of the | 
|         |   3235 **          [prepared statement] S as a zero-terminated UTF-8 string. | 
|         |   3236 ** | 
|         |   3237 ** {H13723} A successful invocation of the [sqlite3_column_name16(S,N)] | 
|         |   3238 **          interface returns the name of the Nth column (where 0 is | 
|         |   3239 **          the leftmost column) for the result set of the | 
|         |   3240 **          [prepared statement] S as a zero-terminated UTF-16 string | 
|         |   3241 **          in the native byte order. | 
|         |   3242 ** | 
|         |   3243 ** {H13724} The [sqlite3_column_name()] and [sqlite3_column_name16()] | 
|         |   3244 **          interfaces return a NULL pointer if they are unable to | 
|         |   3245 **          allocate memory to hold their normal return strings. | 
|         |   3246 ** | 
|         |   3247 ** {H13725} If the N parameter to [sqlite3_column_name(S,N)] or | 
|         |   3248 **          [sqlite3_column_name16(S,N)] is out of range, then the | 
|         |   3249 **          interfaces return a NULL pointer. | 
|         |   3250 ** | 
|         |   3251 ** {H13726} The strings returned by [sqlite3_column_name(S,N)] and | 
|         |   3252 **          [sqlite3_column_name16(S,N)] are valid until the next | 
|         |   3253 **          call to either routine with the same S and N parameters | 
|         |   3254 **          or until [sqlite3_finalize(S)] is called. | 
|         |   3255 ** | 
|         |   3256 ** {H13727} When a result column of a [SELECT] statement contains | 
|         |   3257 **          an AS clause, the name of that column is the identifier | 
|         |   3258 **          to the right of the AS keyword. | 
|         |   3259 */ | 
|         |   3260 IMPORT_C const char *sqlite3_column_name(sqlite3_stmt*, int N); | 
|         |   3261 IMPORT_C const void *sqlite3_column_name16(sqlite3_stmt*, int N); | 
|         |   3262  | 
|         |   3263 /* | 
|         |   3264 ** CAPI3REF: Source Of Data In A Query Result {H13740} <S10700> | 
|         |   3265 ** | 
|         |   3266 ** These routines provide a means to determine what column of what | 
|         |   3267 ** table in which database a result of a [SELECT] statement comes from. | 
|         |   3268 ** The name of the database or table or column can be returned as | 
|         |   3269 ** either a UTF-8 or UTF-16 string.  The _database_ routines return | 
|         |   3270 ** the database name, the _table_ routines return the table name, and | 
|         |   3271 ** the origin_ routines return the column name. | 
|         |   3272 ** The returned string is valid until the [prepared statement] is destroyed | 
|         |   3273 ** using [sqlite3_finalize()] or until the same information is requested | 
|         |   3274 ** again in a different encoding. | 
|         |   3275 ** | 
|         |   3276 ** The names returned are the original un-aliased names of the | 
|         |   3277 ** database, table, and column. | 
|         |   3278 ** | 
|         |   3279 ** The first argument to the following calls is a [prepared statement]. | 
|         |   3280 ** These functions return information about the Nth column returned by | 
|         |   3281 ** the statement, where N is the second function argument. | 
|         |   3282 ** | 
|         |   3283 ** If the Nth column returned by the statement is an expression or | 
|         |   3284 ** subquery and is not a column value, then all of these functions return | 
|         |   3285 ** NULL.  These routine might also return NULL if a memory allocation error | 
|         |   3286 ** occurs.  Otherwise, they return the name of the attached database, table | 
|         |   3287 ** and column that query result column was extracted from. | 
|         |   3288 ** | 
|         |   3289 ** As with all other SQLite APIs, those postfixed with "16" return | 
|         |   3290 ** UTF-16 encoded strings, the other functions return UTF-8. {END} | 
|         |   3291 ** | 
|         |   3292 ** These APIs are only available if the library was compiled with the | 
|         |   3293 ** [SQLITE_ENABLE_COLUMN_METADATA] C-preprocessor symbol defined. | 
|         |   3294 ** | 
|         |   3295 ** {A13751} | 
|         |   3296 ** If two or more threads call one or more of these routines against the same | 
|         |   3297 ** prepared statement and column at the same time then the results are | 
|         |   3298 ** undefined. | 
|         |   3299 ** | 
|         |   3300 ** INVARIANTS: | 
|         |   3301 ** | 
|         |   3302 ** {H13741} The [sqlite3_column_database_name(S,N)] interface returns either | 
|         |   3303 **          the UTF-8 zero-terminated name of the database from which the | 
|         |   3304 **          Nth result column of the [prepared statement] S is extracted, | 
|         |   3305 **          or NULL if the Nth column of S is a general expression | 
|         |   3306 **          or if unable to allocate memory to store the name. | 
|         |   3307 ** | 
|         |   3308 ** {H13742} The [sqlite3_column_database_name16(S,N)] interface returns either | 
|         |   3309 **          the UTF-16 native byte order zero-terminated name of the database | 
|         |   3310 **          from which the Nth result column of the [prepared statement] S is | 
|         |   3311 **          extracted, or NULL if the Nth column of S is a general expression | 
|         |   3312 **          or if unable to allocate memory to store the name. | 
|         |   3313 ** | 
|         |   3314 ** {H13743} The [sqlite3_column_table_name(S,N)] interface returns either | 
|         |   3315 **          the UTF-8 zero-terminated name of the table from which the | 
|         |   3316 **          Nth result column of the [prepared statement] S is extracted, | 
|         |   3317 **          or NULL if the Nth column of S is a general expression | 
|         |   3318 **          or if unable to allocate memory to store the name. | 
|         |   3319 ** | 
|         |   3320 ** {H13744} The [sqlite3_column_table_name16(S,N)] interface returns either | 
|         |   3321 **          the UTF-16 native byte order zero-terminated name of the table | 
|         |   3322 **          from which the Nth result column of the [prepared statement] S is | 
|         |   3323 **          extracted, or NULL if the Nth column of S is a general expression | 
|         |   3324 **          or if unable to allocate memory to store the name. | 
|         |   3325 ** | 
|         |   3326 ** {H13745} The [sqlite3_column_origin_name(S,N)] interface returns either | 
|         |   3327 **          the UTF-8 zero-terminated name of the table column from which the | 
|         |   3328 **          Nth result column of the [prepared statement] S is extracted, | 
|         |   3329 **          or NULL if the Nth column of S is a general expression | 
|         |   3330 **          or if unable to allocate memory to store the name. | 
|         |   3331 ** | 
|         |   3332 ** {H13746} The [sqlite3_column_origin_name16(S,N)] interface returns either | 
|         |   3333 **          the UTF-16 native byte order zero-terminated name of the table | 
|         |   3334 **          column from which the Nth result column of the | 
|         |   3335 **          [prepared statement] S is extracted, or NULL if the Nth column | 
|         |   3336 **          of S is a general expression or if unable to allocate memory | 
|         |   3337 **          to store the name. | 
|         |   3338 ** | 
|         |   3339 ** {H13748} The return values from | 
|         |   3340 **          [sqlite3_column_database_name | column metadata interfaces] | 
|         |   3341 **          are valid for the lifetime of the [prepared statement] | 
|         |   3342 **          or until the encoding is changed by another metadata | 
|         |   3343 **          interface call for the same prepared statement and column. | 
|         |   3344 ** | 
|         |   3345 ** ASSUMPTIONS: | 
|         |   3346 ** | 
|         |   3347 ** {A13751} If two or more threads call one or more | 
|         |   3348 **          [sqlite3_column_database_name | column metadata interfaces] | 
|         |   3349 **          for the same [prepared statement] and result column | 
|         |   3350 **          at the same time then the results are undefined. | 
|         |   3351 */ | 
|         |   3352 IMPORT_C const char *sqlite3_column_database_name(sqlite3_stmt*,int); | 
|         |   3353 IMPORT_C const void *sqlite3_column_database_name16(sqlite3_stmt*,int); | 
|         |   3354 IMPORT_C const char *sqlite3_column_table_name(sqlite3_stmt*,int); | 
|         |   3355 IMPORT_C const void *sqlite3_column_table_name16(sqlite3_stmt*,int); | 
|         |   3356 IMPORT_C const char *sqlite3_column_origin_name(sqlite3_stmt*,int); | 
|         |   3357 IMPORT_C const void *sqlite3_column_origin_name16(sqlite3_stmt*,int); | 
|         |   3358  | 
|         |   3359 /* | 
|         |   3360 ** CAPI3REF: Declared Datatype Of A Query Result {H13760} <S10700> | 
|         |   3361 ** | 
|         |   3362 ** The first parameter is a [prepared statement]. | 
|         |   3363 ** If this statement is a [SELECT] statement and the Nth column of the | 
|         |   3364 ** returned result set of that [SELECT] is a table column (not an | 
|         |   3365 ** expression or subquery) then the declared type of the table | 
|         |   3366 ** column is returned.  If the Nth column of the result set is an | 
|         |   3367 ** expression or subquery, then a NULL pointer is returned. | 
|         |   3368 ** The returned string is always UTF-8 encoded. {END} | 
|         |   3369 ** | 
|         |   3370 ** For example, given the database schema: | 
|         |   3371 ** | 
|         |   3372 ** CREATE TABLE t1(c1 VARIANT); | 
|         |   3373 ** | 
|         |   3374 ** and the following statement to be compiled: | 
|         |   3375 ** | 
|         |   3376 ** SELECT c1 + 1, c1 FROM t1; | 
|         |   3377 ** | 
|         |   3378 ** this routine would return the string "VARIANT" for the second result | 
|         |   3379 ** column (i==1), and a NULL pointer for the first result column (i==0). | 
|         |   3380 ** | 
|         |   3381 ** SQLite uses dynamic run-time typing.  So just because a column | 
|         |   3382 ** is declared to contain a particular type does not mean that the | 
|         |   3383 ** data stored in that column is of the declared type.  SQLite is | 
|         |   3384 ** strongly typed, but the typing is dynamic not static.  Type | 
|         |   3385 ** is associated with individual values, not with the containers | 
|         |   3386 ** used to hold those values. | 
|         |   3387 ** | 
|         |   3388 ** INVARIANTS: | 
|         |   3389 ** | 
|         |   3390 ** {H13761}  A successful call to [sqlite3_column_decltype(S,N)] returns a | 
|         |   3391 **           zero-terminated UTF-8 string containing the declared datatype | 
|         |   3392 **           of the table column that appears as the Nth column (numbered | 
|         |   3393 **           from 0) of the result set to the [prepared statement] S. | 
|         |   3394 ** | 
|         |   3395 ** {H13762}  A successful call to [sqlite3_column_decltype16(S,N)] | 
|         |   3396 **           returns a zero-terminated UTF-16 native byte order string | 
|         |   3397 **           containing the declared datatype of the table column that appears | 
|         |   3398 **           as the Nth column (numbered from 0) of the result set to the | 
|         |   3399 **           [prepared statement] S. | 
|         |   3400 ** | 
|         |   3401 ** {H13763}  If N is less than 0 or N is greater than or equal to | 
|         |   3402 **           the number of columns in the [prepared statement] S, | 
|         |   3403 **           or if the Nth column of S is an expression or subquery rather | 
|         |   3404 **           than a table column, or if a memory allocation failure | 
|         |   3405 **           occurs during encoding conversions, then | 
|         |   3406 **           calls to [sqlite3_column_decltype(S,N)] or | 
|         |   3407 **           [sqlite3_column_decltype16(S,N)] return NULL. | 
|         |   3408 */ | 
|         |   3409 IMPORT_C const char *sqlite3_column_decltype(sqlite3_stmt*,int); | 
|         |   3410 IMPORT_C const void *sqlite3_column_decltype16(sqlite3_stmt*,int); | 
|         |   3411  | 
|         |   3412 /* | 
|         |   3413 ** CAPI3REF: Evaluate An SQL Statement {H13200} <S10000> | 
|         |   3414 ** | 
|         |   3415 ** After a [prepared statement] has been prepared using either | 
|         |   3416 ** [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()] or one of the legacy | 
|         |   3417 ** interfaces [sqlite3_prepare()] or [sqlite3_prepare16()], this function | 
|         |   3418 ** must be called one or more times to evaluate the statement. | 
|         |   3419 ** | 
|         |   3420 ** The details of the behavior of the sqlite3_step() interface depend | 
|         |   3421 ** on whether the statement was prepared using the newer "v2" interface | 
|         |   3422 ** [sqlite3_prepare_v2()] and [sqlite3_prepare16_v2()] or the older legacy | 
|         |   3423 ** interface [sqlite3_prepare()] and [sqlite3_prepare16()].  The use of the | 
|         |   3424 ** new "v2" interface is recommended for new applications but the legacy | 
|         |   3425 ** interface will continue to be supported. | 
|         |   3426 ** | 
|         |   3427 ** In the legacy interface, the return value will be either [SQLITE_BUSY], | 
|         |   3428 ** [SQLITE_DONE], [SQLITE_ROW], [SQLITE_ERROR], or [SQLITE_MISUSE]. | 
|         |   3429 ** With the "v2" interface, any of the other [result codes] or | 
|         |   3430 ** [extended result codes] might be returned as well. | 
|         |   3431 ** | 
|         |   3432 ** [SQLITE_BUSY] means that the database engine was unable to acquire the | 
|         |   3433 ** database locks it needs to do its job.  If the statement is a [COMMIT] | 
|         |   3434 ** or occurs outside of an explicit transaction, then you can retry the | 
|         |   3435 ** statement.  If the statement is not a [COMMIT] and occurs within a | 
|         |   3436 ** explicit transaction then you should rollback the transaction before | 
|         |   3437 ** continuing. | 
|         |   3438 ** | 
|         |   3439 ** [SQLITE_DONE] means that the statement has finished executing | 
|         |   3440 ** successfully.  sqlite3_step() should not be called again on this virtual | 
|         |   3441 ** machine without first calling [sqlite3_reset()] to reset the virtual | 
|         |   3442 ** machine back to its initial state. | 
|         |   3443 ** | 
|         |   3444 ** If the SQL statement being executed returns any data, then [SQLITE_ROW] | 
|         |   3445 ** is returned each time a new row of data is ready for processing by the | 
|         |   3446 ** caller. The values may be accessed using the [column access functions]. | 
|         |   3447 ** sqlite3_step() is called again to retrieve the next row of data. | 
|         |   3448 ** | 
|         |   3449 ** [SQLITE_ERROR] means that a run-time error (such as a constraint | 
|         |   3450 ** violation) has occurred.  sqlite3_step() should not be called again on | 
|         |   3451 ** the VM. More information may be found by calling [sqlite3_errmsg()]. | 
|         |   3452 ** With the legacy interface, a more specific error code (for example, | 
|         |   3453 ** [SQLITE_INTERRUPT], [SQLITE_SCHEMA], [SQLITE_CORRUPT], and so forth) | 
|         |   3454 ** can be obtained by calling [sqlite3_reset()] on the | 
|         |   3455 ** [prepared statement].  In the "v2" interface, | 
|         |   3456 ** the more specific error code is returned directly by sqlite3_step(). | 
|         |   3457 ** | 
|         |   3458 ** [SQLITE_MISUSE] means that the this routine was called inappropriately. | 
|         |   3459 ** Perhaps it was called on a [prepared statement] that has | 
|         |   3460 ** already been [sqlite3_finalize | finalized] or on one that had | 
|         |   3461 ** previously returned [SQLITE_ERROR] or [SQLITE_DONE].  Or it could | 
|         |   3462 ** be the case that the same database connection is being used by two or | 
|         |   3463 ** more threads at the same moment in time. | 
|         |   3464 ** | 
|         |   3465 ** <b>Goofy Interface Alert:</b> In the legacy interface, the sqlite3_step() | 
|         |   3466 ** API always returns a generic error code, [SQLITE_ERROR], following any | 
|         |   3467 ** error other than [SQLITE_BUSY] and [SQLITE_MISUSE].  You must call | 
|         |   3468 ** [sqlite3_reset()] or [sqlite3_finalize()] in order to find one of the | 
|         |   3469 ** specific [error codes] that better describes the error. | 
|         |   3470 ** We admit that this is a goofy design.  The problem has been fixed | 
|         |   3471 ** with the "v2" interface.  If you prepare all of your SQL statements | 
|         |   3472 ** using either [sqlite3_prepare_v2()] or [sqlite3_prepare16_v2()] instead | 
|         |   3473 ** of the legacy [sqlite3_prepare()] and [sqlite3_prepare16()] interfaces, | 
|         |   3474 ** then the more specific [error codes] are returned directly | 
|         |   3475 ** by sqlite3_step().  The use of the "v2" interface is recommended. | 
|         |   3476 ** | 
|         |   3477 ** INVARIANTS: | 
|         |   3478 ** | 
|         |   3479 ** {H13202}  If the [prepared statement] S is ready to be run, then | 
|         |   3480 **           [sqlite3_step(S)] advances that prepared statement until | 
|         |   3481 **           completion or until it is ready to return another row of the | 
|         |   3482 **           result set, or until an [sqlite3_interrupt | interrupt] | 
|         |   3483 **           or a run-time error occurs. | 
|         |   3484 ** | 
|         |   3485 ** {H15304}  When a call to [sqlite3_step(S)] causes the [prepared statement] | 
|         |   3486 **           S to run to completion, the function returns [SQLITE_DONE]. | 
|         |   3487 ** | 
|         |   3488 ** {H15306}  When a call to [sqlite3_step(S)] stops because it is ready to | 
|         |   3489 **           return another row of the result set, it returns [SQLITE_ROW]. | 
|         |   3490 ** | 
|         |   3491 ** {H15308}  If a call to [sqlite3_step(S)] encounters an | 
|         |   3492 **           [sqlite3_interrupt | interrupt] or a run-time error, | 
|         |   3493 **           it returns an appropriate error code that is not one of | 
|         |   3494 **           [SQLITE_OK], [SQLITE_ROW], or [SQLITE_DONE]. | 
|         |   3495 ** | 
|         |   3496 ** {H15310}  If an [sqlite3_interrupt | interrupt] or a run-time error | 
|         |   3497 **           occurs during a call to [sqlite3_step(S)] | 
|         |   3498 **           for a [prepared statement] S created using | 
|         |   3499 **           legacy interfaces [sqlite3_prepare()] or | 
|         |   3500 **           [sqlite3_prepare16()], then the function returns either | 
|         |   3501 **           [SQLITE_ERROR], [SQLITE_BUSY], or [SQLITE_MISUSE]. | 
|         |   3502 */ | 
|         |   3503 IMPORT_C int sqlite3_step(sqlite3_stmt*); | 
|         |   3504  | 
|         |   3505 /* | 
|         |   3506 ** CAPI3REF: Number of columns in a result set {H13770} <S10700> | 
|         |   3507 ** | 
|         |   3508 ** Returns the number of values in the current row of the result set. | 
|         |   3509 ** | 
|         |   3510 ** INVARIANTS: | 
|         |   3511 ** | 
|         |   3512 ** {H13771}  After a call to [sqlite3_step(S)] that returns [SQLITE_ROW], | 
|         |   3513 **           the [sqlite3_data_count(S)] routine will return the same value | 
|         |   3514 **           as the [sqlite3_column_count(S)] function. | 
|         |   3515 ** | 
|         |   3516 ** {H13772}  After [sqlite3_step(S)] has returned any value other than | 
|         |   3517 **           [SQLITE_ROW] or before [sqlite3_step(S)] has been called on the | 
|         |   3518 **           [prepared statement] for the first time since it was | 
|         |   3519 **           [sqlite3_prepare | prepared] or [sqlite3_reset | reset], | 
|         |   3520 **           the [sqlite3_data_count(S)] routine returns zero. | 
|         |   3521 */ | 
|         |   3522 IMPORT_C int sqlite3_data_count(sqlite3_stmt *pStmt); | 
|         |   3523  | 
|         |   3524 /* | 
|         |   3525 ** CAPI3REF: Fundamental Datatypes {H10265} <S10110><S10120> | 
|         |   3526 ** KEYWORDS: SQLITE_TEXT | 
|         |   3527 ** | 
|         |   3528 ** {H10266} Every value in SQLite has one of five fundamental datatypes: | 
|         |   3529 ** | 
|         |   3530 ** <ul> | 
|         |   3531 ** <li> 64-bit signed integer | 
|         |   3532 ** <li> 64-bit IEEE floating point number | 
|         |   3533 ** <li> string | 
|         |   3534 ** <li> BLOB | 
|         |   3535 ** <li> NULL | 
|         |   3536 ** </ul> {END} | 
|         |   3537 ** | 
|         |   3538 ** These constants are codes for each of those types. | 
|         |   3539 ** | 
|         |   3540 ** Note that the SQLITE_TEXT constant was also used in SQLite version 2 | 
|         |   3541 ** for a completely different meaning.  Software that links against both | 
|         |   3542 ** SQLite version 2 and SQLite version 3 should use SQLITE3_TEXT, not | 
|         |   3543 ** SQLITE_TEXT. | 
|         |   3544 */ | 
|         |   3545 #define SQLITE_INTEGER  1 | 
|         |   3546 #define SQLITE_FLOAT    2 | 
|         |   3547 #define SQLITE_BLOB     4 | 
|         |   3548 #define SQLITE_NULL     5 | 
|         |   3549 #ifdef SQLITE_TEXT | 
|         |   3550 # undef SQLITE_TEXT | 
|         |   3551 #else | 
|         |   3552 # define SQLITE_TEXT     3 | 
|         |   3553 #endif | 
|         |   3554 #define SQLITE3_TEXT     3 | 
|         |   3555  | 
|         |   3556 /* | 
|         |   3557 ** CAPI3REF: Result Values From A Query {H13800} <S10700> | 
|         |   3558 ** KEYWORDS: {column access functions} | 
|         |   3559 ** | 
|         |   3560 ** These routines form the "result set query" interface. | 
|         |   3561 ** | 
|         |   3562 ** These routines return information about a single column of the current | 
|         |   3563 ** result row of a query.  In every case the first argument is a pointer | 
|         |   3564 ** to the [prepared statement] that is being evaluated (the [sqlite3_stmt*] | 
|         |   3565 ** that was returned from [sqlite3_prepare_v2()] or one of its variants) | 
|         |   3566 ** and the second argument is the index of the column for which information | 
|         |   3567 ** should be returned.  The leftmost column of the result set has the index 0. | 
|         |   3568 ** | 
|         |   3569 ** If the SQL statement does not currently point to a valid row, or if the | 
|         |   3570 ** column index is out of range, the result is undefined. | 
|         |   3571 ** These routines may only be called when the most recent call to | 
|         |   3572 ** [sqlite3_step()] has returned [SQLITE_ROW] and neither | 
|         |   3573 ** [sqlite3_reset()] nor [sqlite3_finalize()] have been called subsequently. | 
|         |   3574 ** If any of these routines are called after [sqlite3_reset()] or | 
|         |   3575 ** [sqlite3_finalize()] or after [sqlite3_step()] has returned | 
|         |   3576 ** something other than [SQLITE_ROW], the results are undefined. | 
|         |   3577 ** If [sqlite3_step()] or [sqlite3_reset()] or [sqlite3_finalize()] | 
|         |   3578 ** are called from a different thread while any of these routines | 
|         |   3579 ** are pending, then the results are undefined. | 
|         |   3580 ** | 
|         |   3581 ** The sqlite3_column_type() routine returns the | 
|         |   3582 ** [SQLITE_INTEGER | datatype code] for the initial data type | 
|         |   3583 ** of the result column.  The returned value is one of [SQLITE_INTEGER], | 
|         |   3584 ** [SQLITE_FLOAT], [SQLITE_TEXT], [SQLITE_BLOB], or [SQLITE_NULL].  The value | 
|         |   3585 ** returned by sqlite3_column_type() is only meaningful if no type | 
|         |   3586 ** conversions have occurred as described below.  After a type conversion, | 
|         |   3587 ** the value returned by sqlite3_column_type() is undefined.  Future | 
|         |   3588 ** versions of SQLite may change the behavior of sqlite3_column_type() | 
|         |   3589 ** following a type conversion. | 
|         |   3590 ** | 
|         |   3591 ** If the result is a BLOB or UTF-8 string then the sqlite3_column_bytes() | 
|         |   3592 ** routine returns the number of bytes in that BLOB or string. | 
|         |   3593 ** If the result is a UTF-16 string, then sqlite3_column_bytes() converts | 
|         |   3594 ** the string to UTF-8 and then returns the number of bytes. | 
|         |   3595 ** If the result is a numeric value then sqlite3_column_bytes() uses | 
|         |   3596 ** [sqlite3_snprintf()] to convert that value to a UTF-8 string and returns | 
|         |   3597 ** the number of bytes in that string. | 
|         |   3598 ** The value returned does not include the zero terminator at the end | 
|         |   3599 ** of the string.  For clarity: the value returned is the number of | 
|         |   3600 ** bytes in the string, not the number of characters. | 
|         |   3601 ** | 
|         |   3602 ** Strings returned by sqlite3_column_text() and sqlite3_column_text16(), | 
|         |   3603 ** even empty strings, are always zero terminated.  The return | 
|         |   3604 ** value from sqlite3_column_blob() for a zero-length BLOB is an arbitrary | 
|         |   3605 ** pointer, possibly even a NULL pointer. | 
|         |   3606 ** | 
|         |   3607 ** The sqlite3_column_bytes16() routine is similar to sqlite3_column_bytes() | 
|         |   3608 ** but leaves the result in UTF-16 in native byte order instead of UTF-8. | 
|         |   3609 ** The zero terminator is not included in this count. | 
|         |   3610 ** | 
|         |   3611 ** The object returned by [sqlite3_column_value()] is an | 
|         |   3612 ** [unprotected sqlite3_value] object.  An unprotected sqlite3_value object | 
|         |   3613 ** may only be used with [sqlite3_bind_value()] and [sqlite3_result_value()]. | 
|         |   3614 ** If the [unprotected sqlite3_value] object returned by | 
|         |   3615 ** [sqlite3_column_value()] is used in any other way, including calls | 
|         |   3616 ** to routines like [sqlite3_value_int()], [sqlite3_value_text()], | 
|         |   3617 ** or [sqlite3_value_bytes()], then the behavior is undefined. | 
|         |   3618 ** | 
|         |   3619 ** These routines attempt to convert the value where appropriate.  For | 
|         |   3620 ** example, if the internal representation is FLOAT and a text result | 
|         |   3621 ** is requested, [sqlite3_snprintf()] is used internally to perform the | 
|         |   3622 ** conversion automatically.  The following table details the conversions | 
|         |   3623 ** that are applied: | 
|         |   3624 ** | 
|         |   3625 ** <blockquote> | 
|         |   3626 ** <table border="1"> | 
|         |   3627 ** <tr><th> Internal<br>Type <th> Requested<br>Type <th>  Conversion | 
|         |   3628 ** | 
|         |   3629 ** <tr><td>  NULL    <td> INTEGER   <td> Result is 0 | 
|         |   3630 ** <tr><td>  NULL    <td>  FLOAT    <td> Result is 0.0 | 
|         |   3631 ** <tr><td>  NULL    <td>   TEXT    <td> Result is NULL pointer | 
|         |   3632 ** <tr><td>  NULL    <td>   BLOB    <td> Result is NULL pointer | 
|         |   3633 ** <tr><td> INTEGER  <td>  FLOAT    <td> Convert from integer to float | 
|         |   3634 ** <tr><td> INTEGER  <td>   TEXT    <td> ASCII rendering of the integer | 
|         |   3635 ** <tr><td> INTEGER  <td>   BLOB    <td> Same as INTEGER->TEXT | 
|         |   3636 ** <tr><td>  FLOAT   <td> INTEGER   <td> Convert from float to integer | 
|         |   3637 ** <tr><td>  FLOAT   <td>   TEXT    <td> ASCII rendering of the float | 
|         |   3638 ** <tr><td>  FLOAT   <td>   BLOB    <td> Same as FLOAT->TEXT | 
|         |   3639 ** <tr><td>  TEXT    <td> INTEGER   <td> Use atoi() | 
|         |   3640 ** <tr><td>  TEXT    <td>  FLOAT    <td> Use atof() | 
|         |   3641 ** <tr><td>  TEXT    <td>   BLOB    <td> No change | 
|         |   3642 ** <tr><td>  BLOB    <td> INTEGER   <td> Convert to TEXT then use atoi() | 
|         |   3643 ** <tr><td>  BLOB    <td>  FLOAT    <td> Convert to TEXT then use atof() | 
|         |   3644 ** <tr><td>  BLOB    <td>   TEXT    <td> Add a zero terminator if needed | 
|         |   3645 ** </table> | 
|         |   3646 ** </blockquote> | 
|         |   3647 ** | 
|         |   3648 ** The table above makes reference to standard C library functions atoi() | 
|         |   3649 ** and atof().  SQLite does not really use these functions.  It has its | 
|         |   3650 ** own equivalent internal routines.  The atoi() and atof() names are | 
|         |   3651 ** used in the table for brevity and because they are familiar to most | 
|         |   3652 ** C programmers. | 
|         |   3653 ** | 
|         |   3654 ** Note that when type conversions occur, pointers returned by prior | 
|         |   3655 ** calls to sqlite3_column_blob(), sqlite3_column_text(), and/or | 
|         |   3656 ** sqlite3_column_text16() may be invalidated. | 
|         |   3657 ** Type conversions and pointer invalidations might occur | 
|         |   3658 ** in the following cases: | 
|         |   3659 ** | 
|         |   3660 ** <ul> | 
|         |   3661 ** <li> The initial content is a BLOB and sqlite3_column_text() or | 
|         |   3662 **      sqlite3_column_text16() is called.  A zero-terminator might | 
|         |   3663 **      need to be added to the string.</li> | 
|         |   3664 ** <li> The initial content is UTF-8 text and sqlite3_column_bytes16() or | 
|         |   3665 **      sqlite3_column_text16() is called.  The content must be converted | 
|         |   3666 **      to UTF-16.</li> | 
|         |   3667 ** <li> The initial content is UTF-16 text and sqlite3_column_bytes() or | 
|         |   3668 **      sqlite3_column_text() is called.  The content must be converted | 
|         |   3669 **      to UTF-8.</li> | 
|         |   3670 ** </ul> | 
|         |   3671 ** | 
|         |   3672 ** Conversions between UTF-16be and UTF-16le are always done in place and do | 
|         |   3673 ** not invalidate a prior pointer, though of course the content of the buffer | 
|         |   3674 ** that the prior pointer points to will have been modified.  Other kinds | 
|         |   3675 ** of conversion are done in place when it is possible, but sometimes they | 
|         |   3676 ** are not possible and in those cases prior pointers are invalidated. | 
|         |   3677 ** | 
|         |   3678 ** The safest and easiest to remember policy is to invoke these routines | 
|         |   3679 ** in one of the following ways: | 
|         |   3680 ** | 
|         |   3681 ** <ul> | 
|         |   3682 **  <li>sqlite3_column_text() followed by sqlite3_column_bytes()</li> | 
|         |   3683 **  <li>sqlite3_column_blob() followed by sqlite3_column_bytes()</li> | 
|         |   3684 **  <li>sqlite3_column_text16() followed by sqlite3_column_bytes16()</li> | 
|         |   3685 ** </ul> | 
|         |   3686 ** | 
|         |   3687 ** In other words, you should call sqlite3_column_text(), | 
|         |   3688 ** sqlite3_column_blob(), or sqlite3_column_text16() first to force the result | 
|         |   3689 ** into the desired format, then invoke sqlite3_column_bytes() or | 
|         |   3690 ** sqlite3_column_bytes16() to find the size of the result.  Do not mix calls | 
|         |   3691 ** to sqlite3_column_text() or sqlite3_column_blob() with calls to | 
|         |   3692 ** sqlite3_column_bytes16(), and do not mix calls to sqlite3_column_text16() | 
|         |   3693 ** with calls to sqlite3_column_bytes(). | 
|         |   3694 ** | 
|         |   3695 ** The pointers returned are valid until a type conversion occurs as | 
|         |   3696 ** described above, or until [sqlite3_step()] or [sqlite3_reset()] or | 
|         |   3697 ** [sqlite3_finalize()] is called.  The memory space used to hold strings | 
|         |   3698 ** and BLOBs is freed automatically.  Do <b>not</b> pass the pointers returned | 
|         |   3699 ** [sqlite3_column_blob()], [sqlite3_column_text()], etc. into | 
|         |   3700 ** [sqlite3_free()]. | 
|         |   3701 ** | 
|         |   3702 ** If a memory allocation error occurs during the evaluation of any | 
|         |   3703 ** of these routines, a default value is returned.  The default value | 
|         |   3704 ** is either the integer 0, the floating point number 0.0, or a NULL | 
|         |   3705 ** pointer.  Subsequent calls to [sqlite3_errcode()] will return | 
|         |   3706 ** [SQLITE_NOMEM]. | 
|         |   3707 ** | 
|         |   3708 ** INVARIANTS: | 
|         |   3709 ** | 
|         |   3710 ** {H13803} The [sqlite3_column_blob(S,N)] interface converts the | 
|         |   3711 **          Nth column in the current row of the result set for | 
|         |   3712 **          the [prepared statement] S into a BLOB and then returns a | 
|         |   3713 **          pointer to the converted value. | 
|         |   3714 ** | 
|         |   3715 ** {H13806} The [sqlite3_column_bytes(S,N)] interface returns the | 
|         |   3716 **          number of bytes in the BLOB or string (exclusive of the | 
|         |   3717 **          zero terminator on the string) that was returned by the | 
|         |   3718 **          most recent call to [sqlite3_column_blob(S,N)] or | 
|         |   3719 **          [sqlite3_column_text(S,N)]. | 
|         |   3720 ** | 
|         |   3721 ** {H13809} The [sqlite3_column_bytes16(S,N)] interface returns the | 
|         |   3722 **          number of bytes in the string (exclusive of the | 
|         |   3723 **          zero terminator on the string) that was returned by the | 
|         |   3724 **          most recent call to [sqlite3_column_text16(S,N)]. | 
|         |   3725 ** | 
|         |   3726 ** {H13812} The [sqlite3_column_double(S,N)] interface converts the | 
|         |   3727 **          Nth column in the current row of the result set for the | 
|         |   3728 **          [prepared statement] S into a floating point value and | 
|         |   3729 **          returns a copy of that value. | 
|         |   3730 ** | 
|         |   3731 ** {H13815} The [sqlite3_column_int(S,N)] interface converts the | 
|         |   3732 **          Nth column in the current row of the result set for the | 
|         |   3733 **          [prepared statement] S into a 64-bit signed integer and | 
|         |   3734 **          returns the lower 32 bits of that integer. | 
|         |   3735 ** | 
|         |   3736 ** {H13818} The [sqlite3_column_int64(S,N)] interface converts the | 
|         |   3737 **          Nth column in the current row of the result set for the | 
|         |   3738 **          [prepared statement] S into a 64-bit signed integer and | 
|         |   3739 **          returns a copy of that integer. | 
|         |   3740 ** | 
|         |   3741 ** {H13821} The [sqlite3_column_text(S,N)] interface converts the | 
|         |   3742 **          Nth column in the current row of the result set for | 
|         |   3743 **          the [prepared statement] S into a zero-terminated UTF-8 | 
|         |   3744 **          string and returns a pointer to that string. | 
|         |   3745 ** | 
|         |   3746 ** {H13824} The [sqlite3_column_text16(S,N)] interface converts the | 
|         |   3747 **          Nth column in the current row of the result set for the | 
|         |   3748 **          [prepared statement] S into a zero-terminated 2-byte | 
|         |   3749 **          aligned UTF-16 native byte order string and returns | 
|         |   3750 **          a pointer to that string. | 
|         |   3751 ** | 
|         |   3752 ** {H13827} The [sqlite3_column_type(S,N)] interface returns | 
|         |   3753 **          one of [SQLITE_NULL], [SQLITE_INTEGER], [SQLITE_FLOAT], | 
|         |   3754 **          [SQLITE_TEXT], or [SQLITE_BLOB] as appropriate for | 
|         |   3755 **          the Nth column in the current row of the result set for | 
|         |   3756 **          the [prepared statement] S. | 
|         |   3757 ** | 
|         |   3758 ** {H13830} The [sqlite3_column_value(S,N)] interface returns a | 
|         |   3759 **          pointer to an [unprotected sqlite3_value] object for the | 
|         |   3760 **          Nth column in the current row of the result set for | 
|         |   3761 **          the [prepared statement] S. | 
|         |   3762 */ | 
|         |   3763 IMPORT_C const void *sqlite3_column_blob(sqlite3_stmt*, int iCol); | 
|         |   3764 IMPORT_C int sqlite3_column_bytes(sqlite3_stmt*, int iCol); | 
|         |   3765 IMPORT_C int sqlite3_column_bytes16(sqlite3_stmt*, int iCol); | 
|         |   3766 IMPORT_C double sqlite3_column_double(sqlite3_stmt*, int iCol); | 
|         |   3767 IMPORT_C int sqlite3_column_int(sqlite3_stmt*, int iCol); | 
|         |   3768 IMPORT_C sqlite3_int64 sqlite3_column_int64(sqlite3_stmt*, int iCol); | 
|         |   3769 IMPORT_C const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol); | 
|         |   3770 IMPORT_C const void *sqlite3_column_text16(sqlite3_stmt*, int iCol); | 
|         |   3771 IMPORT_C int sqlite3_column_type(sqlite3_stmt*, int iCol); | 
|         |   3772 IMPORT_C sqlite3_value *sqlite3_column_value(sqlite3_stmt*, int iCol); | 
|         |   3773  | 
|         |   3774 /* | 
|         |   3775 ** CAPI3REF: Destroy A Prepared Statement Object {H13300} <S70300><S30100> | 
|         |   3776 ** | 
|         |   3777 ** The sqlite3_finalize() function is called to delete a [prepared statement]. | 
|         |   3778 ** If the statement was executed successfully or not executed at all, then | 
|         |   3779 ** SQLITE_OK is returned. If execution of the statement failed then an | 
|         |   3780 ** [error code] or [extended error code] is returned. | 
|         |   3781 ** | 
|         |   3782 ** This routine can be called at any point during the execution of the | 
|         |   3783 ** [prepared statement].  If the virtual machine has not | 
|         |   3784 ** completed execution when this routine is called, that is like | 
|         |   3785 ** encountering an error or an [sqlite3_interrupt | interrupt]. | 
|         |   3786 ** Incomplete updates may be rolled back and transactions canceled, | 
|         |   3787 ** depending on the circumstances, and the | 
|         |   3788 ** [error code] returned will be [SQLITE_ABORT]. | 
|         |   3789 ** | 
|         |   3790 ** INVARIANTS: | 
|         |   3791 ** | 
|         |   3792 ** {H11302} The [sqlite3_finalize(S)] interface destroys the | 
|         |   3793 **          [prepared statement] S and releases all | 
|         |   3794 **          memory and file resources held by that object. | 
|         |   3795 ** | 
|         |   3796 ** {H11304} If the most recent call to [sqlite3_step(S)] for the | 
|         |   3797 **          [prepared statement] S returned an error, | 
|         |   3798 **          then [sqlite3_finalize(S)] returns that same error. | 
|         |   3799 */ | 
|         |   3800 IMPORT_C int sqlite3_finalize(sqlite3_stmt *pStmt); | 
|         |   3801  | 
|         |   3802 /* | 
|         |   3803 ** CAPI3REF: Reset A Prepared Statement Object {H13330} <S70300> | 
|         |   3804 ** | 
|         |   3805 ** The sqlite3_reset() function is called to reset a [prepared statement] | 
|         |   3806 ** object back to its initial state, ready to be re-executed. | 
|         |   3807 ** Any SQL statement variables that had values bound to them using | 
|         |   3808 ** the [sqlite3_bind_blob | sqlite3_bind_*() API] retain their values. | 
|         |   3809 ** Use [sqlite3_clear_bindings()] to reset the bindings. | 
|         |   3810 ** | 
|         |   3811 ** {H11332} The [sqlite3_reset(S)] interface resets the [prepared statement] S | 
|         |   3812 **          back to the beginning of its program. | 
|         |   3813 ** | 
|         |   3814 ** {H11334} If the most recent call to [sqlite3_step(S)] for the | 
|         |   3815 **          [prepared statement] S returned [SQLITE_ROW] or [SQLITE_DONE], | 
|         |   3816 **          or if [sqlite3_step(S)] has never before been called on S, | 
|         |   3817 **          then [sqlite3_reset(S)] returns [SQLITE_OK]. | 
|         |   3818 ** | 
|         |   3819 ** {H11336} If the most recent call to [sqlite3_step(S)] for the | 
|         |   3820 **          [prepared statement] S indicated an error, then | 
|         |   3821 **          [sqlite3_reset(S)] returns an appropriate [error code]. | 
|         |   3822 ** | 
|         |   3823 ** {H11338} The [sqlite3_reset(S)] interface does not change the values | 
|         |   3824 **          of any [sqlite3_bind_blob|bindings] on the [prepared statement] S. | 
|         |   3825 */ | 
|         |   3826 IMPORT_C int sqlite3_reset(sqlite3_stmt *pStmt); | 
|         |   3827  | 
|         |   3828 /* | 
|         |   3829 ** CAPI3REF: Create Or Redefine SQL Functions {H16100} <S20200> | 
|         |   3830 ** KEYWORDS: {function creation routines} | 
|         |   3831 ** KEYWORDS: {application-defined SQL function} | 
|         |   3832 ** KEYWORDS: {application-defined SQL functions} | 
|         |   3833 ** | 
|         |   3834 ** These two functions (collectively known as "function creation routines") | 
|         |   3835 ** are used to add SQL functions or aggregates or to redefine the behavior | 
|         |   3836 ** of existing SQL functions or aggregates.  The only difference between the | 
|         |   3837 ** two is that the second parameter, the name of the (scalar) function or | 
|         |   3838 ** aggregate, is encoded in UTF-8 for sqlite3_create_function() and UTF-16 | 
|         |   3839 ** for sqlite3_create_function16(). | 
|         |   3840 ** | 
|         |   3841 ** The first parameter is the [database connection] to which the SQL | 
|         |   3842 ** function is to be added.  If a single program uses more than one database | 
|         |   3843 ** connection internally, then SQL functions must be added individually to | 
|         |   3844 ** each database connection. | 
|         |   3845 ** | 
|         |   3846 ** The second parameter is the name of the SQL function to be created or | 
|         |   3847 ** redefined.  The length of the name is limited to 255 bytes, exclusive of | 
|         |   3848 ** the zero-terminator.  Note that the name length limit is in bytes, not | 
|         |   3849 ** characters.  Any attempt to create a function with a longer name | 
|         |   3850 ** will result in [SQLITE_ERROR] being returned. | 
|         |   3851 ** | 
|         |   3852 ** The third parameter (nArg) | 
|         |   3853 ** is the number of arguments that the SQL function or | 
|         |   3854 ** aggregate takes. If this parameter is negative, then the SQL function or | 
|         |   3855 ** aggregate may take any number of arguments. | 
|         |   3856 ** | 
|         |   3857 ** The fourth parameter, eTextRep, specifies what | 
|         |   3858 ** [SQLITE_UTF8 | text encoding] this SQL function prefers for | 
|         |   3859 ** its parameters.  Any SQL function implementation should be able to work | 
|         |   3860 ** work with UTF-8, UTF-16le, or UTF-16be.  But some implementations may be | 
|         |   3861 ** more efficient with one encoding than another.  It is allowed to | 
|         |   3862 ** invoke sqlite3_create_function() or sqlite3_create_function16() multiple | 
|         |   3863 ** times with the same function but with different values of eTextRep. | 
|         |   3864 ** When multiple implementations of the same function are available, SQLite | 
|         |   3865 ** will pick the one that involves the least amount of data conversion. | 
|         |   3866 ** If there is only a single implementation which does not care what text | 
|         |   3867 ** encoding is used, then the fourth argument should be [SQLITE_ANY]. | 
|         |   3868 ** | 
|         |   3869 ** The fifth parameter is an arbitrary pointer.  The implementation of the | 
|         |   3870 ** function can gain access to this pointer using [sqlite3_user_data()]. | 
|         |   3871 ** | 
|         |   3872 ** The seventh, eighth and ninth parameters, xFunc, xStep and xFinal, are | 
|         |   3873 ** pointers to C-language functions that implement the SQL function or | 
|         |   3874 ** aggregate. A scalar SQL function requires an implementation of the xFunc | 
|         |   3875 ** callback only, NULL pointers should be passed as the xStep and xFinal | 
|         |   3876 ** parameters. An aggregate SQL function requires an implementation of xStep | 
|         |   3877 ** and xFinal and NULL should be passed for xFunc. To delete an existing | 
|         |   3878 ** SQL function or aggregate, pass NULL for all three function callbacks. | 
|         |   3879 ** | 
|         |   3880 ** It is permitted to register multiple implementations of the same | 
|         |   3881 ** functions with the same name but with either differing numbers of | 
|         |   3882 ** arguments or differing preferred text encodings.  SQLite will use | 
|         |   3883 ** the implementation most closely matches the way in which the | 
|         |   3884 ** SQL function is used.  A function implementation with a non-negative | 
|         |   3885 ** nArg parameter is a better match than a function implementation with | 
|         |   3886 ** a negative nArg.  A function where the preferred text encoding | 
|         |   3887 ** matches the database encoding is a better | 
|         |   3888 ** match than a function where the encoding is different.   | 
|         |   3889 ** A function where the encoding difference is between UTF16le and UTF16be | 
|         |   3890 ** is a closer match than a function where the encoding difference is | 
|         |   3891 ** between UTF8 and UTF16. | 
|         |   3892 ** | 
|         |   3893 ** Built-in functions may be overloaded by new application-defined functions. | 
|         |   3894 ** The first application-defined function with a given name overrides all | 
|         |   3895 ** built-in functions in the same [database connection] with the same name. | 
|         |   3896 ** Subsequent application-defined functions of the same name only override  | 
|         |   3897 ** prior application-defined functions that are an exact match for the | 
|         |   3898 ** number of parameters and preferred encoding. | 
|         |   3899 ** | 
|         |   3900 ** An application-defined function is permitted to call other | 
|         |   3901 ** SQLite interfaces.  However, such calls must not | 
|         |   3902 ** close the database connection nor finalize or reset the prepared | 
|         |   3903 ** statement in which the function is running. | 
|         |   3904 ** | 
|         |   3905 ** INVARIANTS: | 
|         |   3906 ** | 
|         |   3907 ** {H16103} The [sqlite3_create_function16(D,X,...)] interface shall behave | 
|         |   3908 **          as [sqlite3_create_function(D,X,...)] in every way except that it | 
|         |   3909 **          interprets the X argument as zero-terminated UTF-16 | 
|         |   3910 **          native byte order instead of as zero-terminated UTF-8. | 
|         |   3911 ** | 
|         |   3912 ** {H16106} A successful invocation of the | 
|         |   3913 **          [sqlite3_create_function(D,X,N,E,...)] interface shall register | 
|         |   3914 **          or replaces callback functions in the [database connection] D | 
|         |   3915 **          used to implement the SQL function named X with N parameters | 
|         |   3916 **          and having a preferred text encoding of E. | 
|         |   3917 ** | 
|         |   3918 ** {H16109} A successful call to [sqlite3_create_function(D,X,N,E,P,F,S,L)] | 
|         |   3919 **          shall replace the P, F, S, and L values from any prior calls with | 
|         |   3920 **          the same D, X, N, and E values. | 
|         |   3921 ** | 
|         |   3922 ** {H16112} The [sqlite3_create_function(D,X,...)] interface shall fail | 
|         |   3923 **          if the SQL function name X is | 
|         |   3924 **          longer than 255 bytes exclusive of the zero terminator. | 
|         |   3925 ** | 
|         |   3926 ** {H16118} The [sqlite3_create_function(D,X,N,E,P,F,S,L)] interface | 
|         |   3927 **          shall fail unless either F is NULL and S and L are non-NULL or | 
|         |   3928 ***         F is non-NULL and S and L are NULL. | 
|         |   3929 ** | 
|         |   3930 ** {H16121} The [sqlite3_create_function(D,...)] interface shall fails with an | 
|         |   3931 **          error code of [SQLITE_BUSY] if there exist [prepared statements] | 
|         |   3932 **          associated with the [database connection] D. | 
|         |   3933 ** | 
|         |   3934 ** {H16124} The [sqlite3_create_function(D,X,N,...)] interface shall fail with | 
|         |   3935 **          an error code of [SQLITE_ERROR] if parameter N is less | 
|         |   3936 **          than -1 or greater than 127. | 
|         |   3937 ** | 
|         |   3938 ** {H16127} When N is non-negative, the [sqlite3_create_function(D,X,N,...)] | 
|         |   3939 **          interface shall register callbacks to be invoked for the | 
|         |   3940 **          SQL function | 
|         |   3941 **          named X when the number of arguments to the SQL function is | 
|         |   3942 **          exactly N. | 
|         |   3943 ** | 
|         |   3944 ** {H16130} When N is -1, the [sqlite3_create_function(D,X,N,...)] | 
|         |   3945 **          interface shall register callbacks to be invoked for the SQL | 
|         |   3946 **          function named X with any number of arguments. | 
|         |   3947 ** | 
|         |   3948 ** {H16133} When calls to [sqlite3_create_function(D,X,N,...)] | 
|         |   3949 **          specify multiple implementations of the same function X | 
|         |   3950 **          and when one implementation has N>=0 and the other has N=(-1) | 
|         |   3951 **          the implementation with a non-zero N shall be preferred. | 
|         |   3952 ** | 
|         |   3953 ** {H16136} When calls to [sqlite3_create_function(D,X,N,E,...)] | 
|         |   3954 **          specify multiple implementations of the same function X with | 
|         |   3955 **          the same number of arguments N but with different | 
|         |   3956 **          encodings E, then the implementation where E matches the | 
|         |   3957 **          database encoding shall preferred. | 
|         |   3958 ** | 
|         |   3959 ** {H16139} For an aggregate SQL function created using | 
|         |   3960 **          [sqlite3_create_function(D,X,N,E,P,0,S,L)] the finalizer | 
|         |   3961 **          function L shall always be invoked exactly once if the | 
|         |   3962 **          step function S is called one or more times. | 
|         |   3963 ** | 
|         |   3964 ** {H16142} When SQLite invokes either the xFunc or xStep function of | 
|         |   3965 **          an application-defined SQL function or aggregate created | 
|         |   3966 **          by [sqlite3_create_function()] or [sqlite3_create_function16()], | 
|         |   3967 **          then the array of [sqlite3_value] objects passed as the | 
|         |   3968 **          third parameter shall be [protected sqlite3_value] objects. | 
|         |   3969 */ | 
|         |   3970 IMPORT_C int sqlite3_create_function( | 
|         |   3971   sqlite3 *db, | 
|         |   3972   const char *zFunctionName, | 
|         |   3973   int nArg, | 
|         |   3974   int eTextRep, | 
|         |   3975   void *pApp, | 
|         |   3976   void (*xFunc)(sqlite3_context*,int,sqlite3_value**), | 
|         |   3977   void (*xStep)(sqlite3_context*,int,sqlite3_value**), | 
|         |   3978   void (*xFinal)(sqlite3_context*) | 
|         |   3979 ); | 
|         |   3980 IMPORT_C int sqlite3_create_function16( | 
|         |   3981   sqlite3 *db, | 
|         |   3982   const void *zFunctionName, | 
|         |   3983   int nArg, | 
|         |   3984   int eTextRep, | 
|         |   3985   void *pApp, | 
|         |   3986   void (*xFunc)(sqlite3_context*,int,sqlite3_value**), | 
|         |   3987   void (*xStep)(sqlite3_context*,int,sqlite3_value**), | 
|         |   3988   void (*xFinal)(sqlite3_context*) | 
|         |   3989 ); | 
|         |   3990  | 
|         |   3991 /* | 
|         |   3992 ** CAPI3REF: Text Encodings {H10267} <S50200> <H16100> | 
|         |   3993 ** | 
|         |   3994 ** These constant define integer codes that represent the various | 
|         |   3995 ** text encodings supported by SQLite. | 
|         |   3996 */ | 
|         |   3997 #define SQLITE_UTF8           1 | 
|         |   3998 #define SQLITE_UTF16LE        2 | 
|         |   3999 #define SQLITE_UTF16BE        3 | 
|         |   4000 #define SQLITE_UTF16          4    /* Use native byte order */ | 
|         |   4001 #define SQLITE_ANY            5    /* sqlite3_create_function only */ | 
|         |   4002 #define SQLITE_UTF16_ALIGNED  8    /* sqlite3_create_collation only */ | 
|         |   4003  | 
|         |   4004 /* | 
|         |   4005 ** CAPI3REF: Deprecated Functions | 
|         |   4006 ** DEPRECATED | 
|         |   4007 ** | 
|         |   4008 ** These functions are [deprecated].  In order to maintain | 
|         |   4009 ** backwards compatibility with older code, these functions continue  | 
|         |   4010 ** to be supported.  However, new applications should avoid | 
|         |   4011 ** the use of these functions.  To help encourage people to avoid | 
|         |   4012 ** using these functions, we are not going to tell you want they do. | 
|         |   4013 */ | 
|         |   4014 IMPORT_C int sqlite3_aggregate_count(sqlite3_context*); | 
|         |   4015 IMPORT_C int sqlite3_expired(sqlite3_stmt*); | 
|         |   4016 IMPORT_C int sqlite3_transfer_bindings(sqlite3_stmt*, sqlite3_stmt*); | 
|         |   4017 IMPORT_C int sqlite3_global_recover(void); | 
|         |   4018 IMPORT_C void sqlite3_thread_cleanup(void); | 
|         |   4019 IMPORT_C int sqlite3_memory_alarm(void(*)(void*,sqlite3_int64,int),void*,sqlite3_int64); | 
|         |   4020  | 
|         |   4021 /* | 
|         |   4022 ** CAPI3REF: Obtaining SQL Function Parameter Values {H15100} <S20200> | 
|         |   4023 ** | 
|         |   4024 ** The C-language implementation of SQL functions and aggregates uses | 
|         |   4025 ** this set of interface routines to access the parameter values on | 
|         |   4026 ** the function or aggregate. | 
|         |   4027 ** | 
|         |   4028 ** The xFunc (for scalar functions) or xStep (for aggregates) parameters | 
|         |   4029 ** to [sqlite3_create_function()] and [sqlite3_create_function16()] | 
|         |   4030 ** define callbacks that implement the SQL functions and aggregates. | 
|         |   4031 ** The 4th parameter to these callbacks is an array of pointers to | 
|         |   4032 ** [protected sqlite3_value] objects.  There is one [sqlite3_value] object for | 
|         |   4033 ** each parameter to the SQL function.  These routines are used to | 
|         |   4034 ** extract values from the [sqlite3_value] objects. | 
|         |   4035 ** | 
|         |   4036 ** These routines work only with [protected sqlite3_value] objects. | 
|         |   4037 ** Any attempt to use these routines on an [unprotected sqlite3_value] | 
|         |   4038 ** object results in undefined behavior. | 
|         |   4039 ** | 
|         |   4040 ** These routines work just like the corresponding [column access functions] | 
|         |   4041 ** except that  these routines take a single [protected sqlite3_value] object | 
|         |   4042 ** pointer instead of a [sqlite3_stmt*] pointer and an integer column number. | 
|         |   4043 ** | 
|         |   4044 ** The sqlite3_value_text16() interface extracts a UTF-16 string | 
|         |   4045 ** in the native byte-order of the host machine.  The | 
|         |   4046 ** sqlite3_value_text16be() and sqlite3_value_text16le() interfaces | 
|         |   4047 ** extract UTF-16 strings as big-endian and little-endian respectively. | 
|         |   4048 ** | 
|         |   4049 ** The sqlite3_value_numeric_type() interface attempts to apply | 
|         |   4050 ** numeric affinity to the value.  This means that an attempt is | 
|         |   4051 ** made to convert the value to an integer or floating point.  If | 
|         |   4052 ** such a conversion is possible without loss of information (in other | 
|         |   4053 ** words, if the value is a string that looks like a number) | 
|         |   4054 ** then the conversion is performed.  Otherwise no conversion occurs. | 
|         |   4055 ** The [SQLITE_INTEGER | datatype] after conversion is returned. | 
|         |   4056 ** | 
|         |   4057 ** Please pay particular attention to the fact that the pointer returned | 
|         |   4058 ** from [sqlite3_value_blob()], [sqlite3_value_text()], or | 
|         |   4059 ** [sqlite3_value_text16()] can be invalidated by a subsequent call to | 
|         |   4060 ** [sqlite3_value_bytes()], [sqlite3_value_bytes16()], [sqlite3_value_text()], | 
|         |   4061 ** or [sqlite3_value_text16()]. | 
|         |   4062 ** | 
|         |   4063 ** These routines must be called from the same thread as | 
|         |   4064 ** the SQL function that supplied the [sqlite3_value*] parameters. | 
|         |   4065 ** | 
|         |   4066 ** INVARIANTS: | 
|         |   4067 ** | 
|         |   4068 ** {H15103} The [sqlite3_value_blob(V)] interface converts the | 
|         |   4069 **          [protected sqlite3_value] object V into a BLOB and then | 
|         |   4070 **          returns a pointer to the converted value. | 
|         |   4071 ** | 
|         |   4072 ** {H15106} The [sqlite3_value_bytes(V)] interface returns the | 
|         |   4073 **          number of bytes in the BLOB or string (exclusive of the | 
|         |   4074 **          zero terminator on the string) that was returned by the | 
|         |   4075 **          most recent call to [sqlite3_value_blob(V)] or | 
|         |   4076 **          [sqlite3_value_text(V)]. | 
|         |   4077 ** | 
|         |   4078 ** {H15109} The [sqlite3_value_bytes16(V)] interface returns the | 
|         |   4079 **          number of bytes in the string (exclusive of the | 
|         |   4080 **          zero terminator on the string) that was returned by the | 
|         |   4081 **          most recent call to [sqlite3_value_text16(V)], | 
|         |   4082 **          [sqlite3_value_text16be(V)], or [sqlite3_value_text16le(V)]. | 
|         |   4083 ** | 
|         |   4084 ** {H15112} The [sqlite3_value_double(V)] interface converts the | 
|         |   4085 **          [protected sqlite3_value] object V into a floating point value and | 
|         |   4086 **          returns a copy of that value. | 
|         |   4087 ** | 
|         |   4088 ** {H15115} The [sqlite3_value_int(V)] interface converts the | 
|         |   4089 **          [protected sqlite3_value] object V into a 64-bit signed integer and | 
|         |   4090 **          returns the lower 32 bits of that integer. | 
|         |   4091 ** | 
|         |   4092 ** {H15118} The [sqlite3_value_int64(V)] interface converts the | 
|         |   4093 **          [protected sqlite3_value] object V into a 64-bit signed integer and | 
|         |   4094 **          returns a copy of that integer. | 
|         |   4095 ** | 
|         |   4096 ** {H15121} The [sqlite3_value_text(V)] interface converts the | 
|         |   4097 **          [protected sqlite3_value] object V into a zero-terminated UTF-8 | 
|         |   4098 **          string and returns a pointer to that string. | 
|         |   4099 ** | 
|         |   4100 ** {H15124} The [sqlite3_value_text16(V)] interface converts the | 
|         |   4101 **          [protected sqlite3_value] object V into a zero-terminated 2-byte | 
|         |   4102 **          aligned UTF-16 native byte order | 
|         |   4103 **          string and returns a pointer to that string. | 
|         |   4104 ** | 
|         |   4105 ** {H15127} The [sqlite3_value_text16be(V)] interface converts the | 
|         |   4106 **          [protected sqlite3_value] object V into a zero-terminated 2-byte | 
|         |   4107 **          aligned UTF-16 big-endian | 
|         |   4108 **          string and returns a pointer to that string. | 
|         |   4109 ** | 
|         |   4110 ** {H15130} The [sqlite3_value_text16le(V)] interface converts the | 
|         |   4111 **          [protected sqlite3_value] object V into a zero-terminated 2-byte | 
|         |   4112 **          aligned UTF-16 little-endian | 
|         |   4113 **          string and returns a pointer to that string. | 
|         |   4114 ** | 
|         |   4115 ** {H15133} The [sqlite3_value_type(V)] interface returns | 
|         |   4116 **          one of [SQLITE_NULL], [SQLITE_INTEGER], [SQLITE_FLOAT], | 
|         |   4117 **          [SQLITE_TEXT], or [SQLITE_BLOB] as appropriate for | 
|         |   4118 **          the [sqlite3_value] object V. | 
|         |   4119 ** | 
|         |   4120 ** {H15136} The [sqlite3_value_numeric_type(V)] interface converts | 
|         |   4121 **          the [protected sqlite3_value] object V into either an integer or | 
|         |   4122 **          a floating point value if it can do so without loss of | 
|         |   4123 **          information, and returns one of [SQLITE_NULL], | 
|         |   4124 **          [SQLITE_INTEGER], [SQLITE_FLOAT], [SQLITE_TEXT], or | 
|         |   4125 **          [SQLITE_BLOB] as appropriate for the | 
|         |   4126 **          [protected sqlite3_value] object V after the conversion attempt. | 
|         |   4127 */ | 
|         |   4128 IMPORT_C const void *sqlite3_value_blob(sqlite3_value*); | 
|         |   4129 IMPORT_C int sqlite3_value_bytes(sqlite3_value*); | 
|         |   4130 IMPORT_C int sqlite3_value_bytes16(sqlite3_value*); | 
|         |   4131 IMPORT_C double sqlite3_value_double(sqlite3_value*); | 
|         |   4132 IMPORT_C int sqlite3_value_int(sqlite3_value*); | 
|         |   4133 IMPORT_C sqlite3_int64 sqlite3_value_int64(sqlite3_value*); | 
|         |   4134 IMPORT_C const unsigned char *sqlite3_value_text(sqlite3_value*); | 
|         |   4135 IMPORT_C const void *sqlite3_value_text16(sqlite3_value*); | 
|         |   4136 IMPORT_C const void *sqlite3_value_text16le(sqlite3_value*); | 
|         |   4137 IMPORT_C const void *sqlite3_value_text16be(sqlite3_value*); | 
|         |   4138 IMPORT_C int sqlite3_value_type(sqlite3_value*); | 
|         |   4139 IMPORT_C int sqlite3_value_numeric_type(sqlite3_value*); | 
|         |   4140  | 
|         |   4141 /* | 
|         |   4142 ** CAPI3REF: Obtain Aggregate Function Context {H16210} <S20200> | 
|         |   4143 ** | 
|         |   4144 ** The implementation of aggregate SQL functions use this routine to allocate | 
|         |   4145 ** a structure for storing their state. | 
|         |   4146 ** | 
|         |   4147 ** The first time the sqlite3_aggregate_context() routine is called for a | 
|         |   4148 ** particular aggregate, SQLite allocates nBytes of memory, zeroes out that | 
|         |   4149 ** memory, and returns a pointer to it. On second and subsequent calls to | 
|         |   4150 ** sqlite3_aggregate_context() for the same aggregate function index, | 
|         |   4151 ** the same buffer is returned. The implementation of the aggregate can use | 
|         |   4152 ** the returned buffer to accumulate data. | 
|         |   4153 ** | 
|         |   4154 ** SQLite automatically frees the allocated buffer when the aggregate | 
|         |   4155 ** query concludes. | 
|         |   4156 ** | 
|         |   4157 ** The first parameter should be a copy of the | 
|         |   4158 ** [sqlite3_context | SQL function context] that is the first parameter | 
|         |   4159 ** to the callback routine that implements the aggregate function. | 
|         |   4160 ** | 
|         |   4161 ** This routine must be called from the same thread in which | 
|         |   4162 ** the aggregate SQL function is running. | 
|         |   4163 ** | 
|         |   4164 ** INVARIANTS: | 
|         |   4165 ** | 
|         |   4166 ** {H16211} The first invocation of [sqlite3_aggregate_context(C,N)] for | 
|         |   4167 **          a particular instance of an aggregate function (for a particular | 
|         |   4168 **          context C) causes SQLite to allocate N bytes of memory, | 
|         |   4169 **          zero that memory, and return a pointer to the allocated memory. | 
|         |   4170 ** | 
|         |   4171 ** {H16213} If a memory allocation error occurs during | 
|         |   4172 **          [sqlite3_aggregate_context(C,N)] then the function returns 0. | 
|         |   4173 ** | 
|         |   4174 ** {H16215} Second and subsequent invocations of | 
|         |   4175 **          [sqlite3_aggregate_context(C,N)] for the same context pointer C | 
|         |   4176 **          ignore the N parameter and return a pointer to the same | 
|         |   4177 **          block of memory returned by the first invocation. | 
|         |   4178 ** | 
|         |   4179 ** {H16217} The memory allocated by [sqlite3_aggregate_context(C,N)] is | 
|         |   4180 **          automatically freed on the next call to [sqlite3_reset()] | 
|         |   4181 **          or [sqlite3_finalize()] for the [prepared statement] containing | 
|         |   4182 **          the aggregate function associated with context C. | 
|         |   4183 */ | 
|         |   4184 IMPORT_C void *sqlite3_aggregate_context(sqlite3_context*, int nBytes); | 
|         |   4185  | 
|         |   4186 /* | 
|         |   4187 ** CAPI3REF: User Data For Functions {H16240} <S20200> | 
|         |   4188 ** | 
|         |   4189 ** The sqlite3_user_data() interface returns a copy of | 
|         |   4190 ** the pointer that was the pUserData parameter (the 5th parameter) | 
|         |   4191 ** of the [sqlite3_create_function()] | 
|         |   4192 ** and [sqlite3_create_function16()] routines that originally | 
|         |   4193 ** registered the application defined function. {END} | 
|         |   4194 ** | 
|         |   4195 ** This routine must be called from the same thread in which | 
|         |   4196 ** the application-defined function is running. | 
|         |   4197 ** | 
|         |   4198 ** INVARIANTS: | 
|         |   4199 ** | 
|         |   4200 ** {H16243} The [sqlite3_user_data(C)] interface returns a copy of the | 
|         |   4201 **          P pointer from the [sqlite3_create_function(D,X,N,E,P,F,S,L)] | 
|         |   4202 **          or [sqlite3_create_function16(D,X,N,E,P,F,S,L)] call that | 
|         |   4203 **          registered the SQL function associated with [sqlite3_context] C. | 
|         |   4204 */ | 
|         |   4205 IMPORT_C void *sqlite3_user_data(sqlite3_context*); | 
|         |   4206  | 
|         |   4207 /* | 
|         |   4208 ** CAPI3REF: Database Connection For Functions {H16250} <S60600><S20200> | 
|         |   4209 ** | 
|         |   4210 ** The sqlite3_context_db_handle() interface returns a copy of | 
|         |   4211 ** the pointer to the [database connection] (the 1st parameter) | 
|         |   4212 ** of the [sqlite3_create_function()] | 
|         |   4213 ** and [sqlite3_create_function16()] routines that originally | 
|         |   4214 ** registered the application defined function. | 
|         |   4215 ** | 
|         |   4216 ** INVARIANTS: | 
|         |   4217 ** | 
|         |   4218 ** {H16253} The [sqlite3_context_db_handle(C)] interface returns a copy of the | 
|         |   4219 **          D pointer from the [sqlite3_create_function(D,X,N,E,P,F,S,L)] | 
|         |   4220 **          or [sqlite3_create_function16(D,X,N,E,P,F,S,L)] call that | 
|         |   4221 **          registered the SQL function associated with [sqlite3_context] C. | 
|         |   4222 */ | 
|         |   4223 IMPORT_C sqlite3 *sqlite3_context_db_handle(sqlite3_context*); | 
|         |   4224  | 
|         |   4225 /* | 
|         |   4226 ** CAPI3REF: Function Auxiliary Data {H16270} <S20200> | 
|         |   4227 ** | 
|         |   4228 ** The following two functions may be used by scalar SQL functions to | 
|         |   4229 ** associate metadata with argument values. If the same value is passed to | 
|         |   4230 ** multiple invocations of the same SQL function during query execution, under | 
|         |   4231 ** some circumstances the associated metadata may be preserved. This may | 
|         |   4232 ** be used, for example, to add a regular-expression matching scalar | 
|         |   4233 ** function. The compiled version of the regular expression is stored as | 
|         |   4234 ** metadata associated with the SQL value passed as the regular expression | 
|         |   4235 ** pattern.  The compiled regular expression can be reused on multiple | 
|         |   4236 ** invocations of the same function so that the original pattern string | 
|         |   4237 ** does not need to be recompiled on each invocation. | 
|         |   4238 ** | 
|         |   4239 ** The sqlite3_get_auxdata() interface returns a pointer to the metadata | 
|         |   4240 ** associated by the sqlite3_set_auxdata() function with the Nth argument | 
|         |   4241 ** value to the application-defined function. If no metadata has been ever | 
|         |   4242 ** been set for the Nth argument of the function, or if the corresponding | 
|         |   4243 ** function parameter has changed since the meta-data was set, | 
|         |   4244 ** then sqlite3_get_auxdata() returns a NULL pointer. | 
|         |   4245 ** | 
|         |   4246 ** The sqlite3_set_auxdata() interface saves the metadata | 
|         |   4247 ** pointed to by its 3rd parameter as the metadata for the N-th | 
|         |   4248 ** argument of the application-defined function.  Subsequent | 
|         |   4249 ** calls to sqlite3_get_auxdata() might return this data, if it has | 
|         |   4250 ** not been destroyed. | 
|         |   4251 ** If it is not NULL, SQLite will invoke the destructor | 
|         |   4252 ** function given by the 4th parameter to sqlite3_set_auxdata() on | 
|         |   4253 ** the metadata when the corresponding function parameter changes | 
|         |   4254 ** or when the SQL statement completes, whichever comes first. | 
|         |   4255 ** | 
|         |   4256 ** SQLite is free to call the destructor and drop metadata on any | 
|         |   4257 ** parameter of any function at any time.  The only guarantee is that | 
|         |   4258 ** the destructor will be called before the metadata is dropped. | 
|         |   4259 ** | 
|         |   4260 ** In practice, metadata is preserved between function calls for | 
|         |   4261 ** expressions that are constant at compile time. This includes literal | 
|         |   4262 ** values and SQL variables. | 
|         |   4263 ** | 
|         |   4264 ** These routines must be called from the same thread in which | 
|         |   4265 ** the SQL function is running. | 
|         |   4266 ** | 
|         |   4267 ** INVARIANTS: | 
|         |   4268 ** | 
|         |   4269 ** {H16272} The [sqlite3_get_auxdata(C,N)] interface returns a pointer | 
|         |   4270 **          to metadata associated with the Nth parameter of the SQL function | 
|         |   4271 **          whose context is C, or NULL if there is no metadata associated | 
|         |   4272 **          with that parameter. | 
|         |   4273 ** | 
|         |   4274 ** {H16274} The [sqlite3_set_auxdata(C,N,P,D)] interface assigns a metadata | 
|         |   4275 **          pointer P to the Nth parameter of the SQL function with context C. | 
|         |   4276 ** | 
|         |   4277 ** {H16276} SQLite will invoke the destructor D with a single argument | 
|         |   4278 **          which is the metadata pointer P following a call to | 
|         |   4279 **          [sqlite3_set_auxdata(C,N,P,D)] when SQLite ceases to hold | 
|         |   4280 **          the metadata. | 
|         |   4281 ** | 
|         |   4282 ** {H16277} SQLite ceases to hold metadata for an SQL function parameter | 
|         |   4283 **          when the value of that parameter changes. | 
|         |   4284 ** | 
|         |   4285 ** {H16278} When [sqlite3_set_auxdata(C,N,P,D)] is invoked, the destructor | 
|         |   4286 **          is called for any prior metadata associated with the same function | 
|         |   4287 **          context C and parameter N. | 
|         |   4288 ** | 
|         |   4289 ** {H16279} SQLite will call destructors for any metadata it is holding | 
|         |   4290 **          in a particular [prepared statement] S when either | 
|         |   4291 **          [sqlite3_reset(S)] or [sqlite3_finalize(S)] is called. | 
|         |   4292 */ | 
|         |   4293 IMPORT_C void *sqlite3_get_auxdata(sqlite3_context*, int N); | 
|         |   4294 IMPORT_C void sqlite3_set_auxdata(sqlite3_context*, int N, void*, void (*)(void*)); | 
|         |   4295  | 
|         |   4296  | 
|         |   4297 /* | 
|         |   4298 ** CAPI3REF: Constants Defining Special Destructor Behavior {H10280} <S30100> | 
|         |   4299 ** | 
|         |   4300 ** These are special values for the destructor that is passed in as the | 
|         |   4301 ** final argument to routines like [sqlite3_result_blob()].  If the destructor | 
|         |   4302 ** argument is SQLITE_STATIC, it means that the content pointer is constant | 
|         |   4303 ** and will never change.  It does not need to be destroyed.  The | 
|         |   4304 ** SQLITE_TRANSIENT value means that the content will likely change in | 
|         |   4305 ** the near future and that SQLite should make its own private copy of | 
|         |   4306 ** the content before returning. | 
|         |   4307 ** | 
|         |   4308 ** The typedef is necessary to work around problems in certain | 
|         |   4309 ** C++ compilers.  See ticket #2191. | 
|         |   4310 */ | 
|         |   4311 typedef void (*sqlite3_destructor_type)(void*); | 
|         |   4312 #define SQLITE_STATIC      ((sqlite3_destructor_type)0) | 
|         |   4313 #define SQLITE_TRANSIENT   ((sqlite3_destructor_type)-1) | 
|         |   4314  | 
|         |   4315 /* | 
|         |   4316 ** CAPI3REF: Setting The Result Of An SQL Function {H16400} <S20200> | 
|         |   4317 ** | 
|         |   4318 ** These routines are used by the xFunc or xFinal callbacks that | 
|         |   4319 ** implement SQL functions and aggregates.  See | 
|         |   4320 ** [sqlite3_create_function()] and [sqlite3_create_function16()] | 
|         |   4321 ** for additional information. | 
|         |   4322 ** | 
|         |   4323 ** These functions work very much like the [parameter binding] family of | 
|         |   4324 ** functions used to bind values to host parameters in prepared statements. | 
|         |   4325 ** Refer to the [SQL parameter] documentation for additional information. | 
|         |   4326 ** | 
|         |   4327 ** The sqlite3_result_blob() interface sets the result from | 
|         |   4328 ** an application-defined function to be the BLOB whose content is pointed | 
|         |   4329 ** to by the second parameter and which is N bytes long where N is the | 
|         |   4330 ** third parameter. | 
|         |   4331 ** | 
|         |   4332 ** The sqlite3_result_zeroblob() interfaces set the result of | 
|         |   4333 ** the application-defined function to be a BLOB containing all zero | 
|         |   4334 ** bytes and N bytes in size, where N is the value of the 2nd parameter. | 
|         |   4335 ** | 
|         |   4336 ** The sqlite3_result_double() interface sets the result from | 
|         |   4337 ** an application-defined function to be a floating point value specified | 
|         |   4338 ** by its 2nd argument. | 
|         |   4339 ** | 
|         |   4340 ** The sqlite3_result_error() and sqlite3_result_error16() functions | 
|         |   4341 ** cause the implemented SQL function to throw an exception. | 
|         |   4342 ** SQLite uses the string pointed to by the | 
|         |   4343 ** 2nd parameter of sqlite3_result_error() or sqlite3_result_error16() | 
|         |   4344 ** as the text of an error message.  SQLite interprets the error | 
|         |   4345 ** message string from sqlite3_result_error() as UTF-8. SQLite | 
|         |   4346 ** interprets the string from sqlite3_result_error16() as UTF-16 in native | 
|         |   4347 ** byte order.  If the third parameter to sqlite3_result_error() | 
|         |   4348 ** or sqlite3_result_error16() is negative then SQLite takes as the error | 
|         |   4349 ** message all text up through the first zero character. | 
|         |   4350 ** If the third parameter to sqlite3_result_error() or | 
|         |   4351 ** sqlite3_result_error16() is non-negative then SQLite takes that many | 
|         |   4352 ** bytes (not characters) from the 2nd parameter as the error message. | 
|         |   4353 ** The sqlite3_result_error() and sqlite3_result_error16() | 
|         |   4354 ** routines make a private copy of the error message text before | 
|         |   4355 ** they return.  Hence, the calling function can deallocate or | 
|         |   4356 ** modify the text after they return without harm. | 
|         |   4357 ** The sqlite3_result_error_code() function changes the error code | 
|         |   4358 ** returned by SQLite as a result of an error in a function.  By default, | 
|         |   4359 ** the error code is SQLITE_ERROR.  A subsequent call to sqlite3_result_error() | 
|         |   4360 ** or sqlite3_result_error16() resets the error code to SQLITE_ERROR. | 
|         |   4361 ** | 
|         |   4362 ** The sqlite3_result_toobig() interface causes SQLite to throw an error | 
|         |   4363 ** indicating that a string or BLOB is to long to represent. | 
|         |   4364 ** | 
|         |   4365 ** The sqlite3_result_nomem() interface causes SQLite to throw an error | 
|         |   4366 ** indicating that a memory allocation failed. | 
|         |   4367 ** | 
|         |   4368 ** The sqlite3_result_int() interface sets the return value | 
|         |   4369 ** of the application-defined function to be the 32-bit signed integer | 
|         |   4370 ** value given in the 2nd argument. | 
|         |   4371 ** The sqlite3_result_int64() interface sets the return value | 
|         |   4372 ** of the application-defined function to be the 64-bit signed integer | 
|         |   4373 ** value given in the 2nd argument. | 
|         |   4374 ** | 
|         |   4375 ** The sqlite3_result_null() interface sets the return value | 
|         |   4376 ** of the application-defined function to be NULL. | 
|         |   4377 ** | 
|         |   4378 ** The sqlite3_result_text(), sqlite3_result_text16(), | 
|         |   4379 ** sqlite3_result_text16le(), and sqlite3_result_text16be() interfaces | 
|         |   4380 ** set the return value of the application-defined function to be | 
|         |   4381 ** a text string which is represented as UTF-8, UTF-16 native byte order, | 
|         |   4382 ** UTF-16 little endian, or UTF-16 big endian, respectively. | 
|         |   4383 ** SQLite takes the text result from the application from | 
|         |   4384 ** the 2nd parameter of the sqlite3_result_text* interfaces. | 
|         |   4385 ** If the 3rd parameter to the sqlite3_result_text* interfaces | 
|         |   4386 ** is negative, then SQLite takes result text from the 2nd parameter | 
|         |   4387 ** through the first zero character. | 
|         |   4388 ** If the 3rd parameter to the sqlite3_result_text* interfaces | 
|         |   4389 ** is non-negative, then as many bytes (not characters) of the text | 
|         |   4390 ** pointed to by the 2nd parameter are taken as the application-defined | 
|         |   4391 ** function result. | 
|         |   4392 ** If the 4th parameter to the sqlite3_result_text* interfaces | 
|         |   4393 ** or sqlite3_result_blob is a non-NULL pointer, then SQLite calls that | 
|         |   4394 ** function as the destructor on the text or BLOB result when it has | 
|         |   4395 ** finished using that result. | 
|         |   4396 ** If the 4th parameter to the sqlite3_result_text* interfaces or | 
|         |   4397 ** sqlite3_result_blob is the special constant SQLITE_STATIC, then SQLite | 
|         |   4398 ** assumes that the text or BLOB result is in constant space and does not | 
|         |   4399 ** copy the it or call a destructor when it has finished using that result. | 
|         |   4400 ** If the 4th parameter to the sqlite3_result_text* interfaces | 
|         |   4401 ** or sqlite3_result_blob is the special constant SQLITE_TRANSIENT | 
|         |   4402 ** then SQLite makes a copy of the result into space obtained from | 
|         |   4403 ** from [sqlite3_malloc()] before it returns. | 
|         |   4404 ** | 
|         |   4405 ** The sqlite3_result_value() interface sets the result of | 
|         |   4406 ** the application-defined function to be a copy the | 
|         |   4407 ** [unprotected sqlite3_value] object specified by the 2nd parameter.  The | 
|         |   4408 ** sqlite3_result_value() interface makes a copy of the [sqlite3_value] | 
|         |   4409 ** so that the [sqlite3_value] specified in the parameter may change or | 
|         |   4410 ** be deallocated after sqlite3_result_value() returns without harm. | 
|         |   4411 ** A [protected sqlite3_value] object may always be used where an | 
|         |   4412 ** [unprotected sqlite3_value] object is required, so either | 
|         |   4413 ** kind of [sqlite3_value] object can be used with this interface. | 
|         |   4414 ** | 
|         |   4415 ** If these routines are called from within the different thread | 
|         |   4416 ** than the one containing the application-defined function that received | 
|         |   4417 ** the [sqlite3_context] pointer, the results are undefined. | 
|         |   4418 ** | 
|         |   4419 ** INVARIANTS: | 
|         |   4420 ** | 
|         |   4421 ** {H16403} The default return value from any SQL function is NULL. | 
|         |   4422 ** | 
|         |   4423 ** {H16406} The [sqlite3_result_blob(C,V,N,D)] interface changes the | 
|         |   4424 **          return value of function C to be a BLOB that is N bytes | 
|         |   4425 **          in length and with content pointed to by V. | 
|         |   4426 ** | 
|         |   4427 ** {H16409} The [sqlite3_result_double(C,V)] interface changes the | 
|         |   4428 **          return value of function C to be the floating point value V. | 
|         |   4429 ** | 
|         |   4430 ** {H16412} The [sqlite3_result_error(C,V,N)] interface changes the return | 
|         |   4431 **          value of function C to be an exception with error code | 
|         |   4432 **          [SQLITE_ERROR] and a UTF-8 error message copied from V up to the | 
|         |   4433 **          first zero byte or until N bytes are read if N is positive. | 
|         |   4434 ** | 
|         |   4435 ** {H16415} The [sqlite3_result_error16(C,V,N)] interface changes the return | 
|         |   4436 **          value of function C to be an exception with error code | 
|         |   4437 **          [SQLITE_ERROR] and a UTF-16 native byte order error message | 
|         |   4438 **          copied from V up to the first zero terminator or until N bytes | 
|         |   4439 **          are read if N is positive. | 
|         |   4440 ** | 
|         |   4441 ** {H16418} The [sqlite3_result_error_toobig(C)] interface changes the return | 
|         |   4442 **          value of the function C to be an exception with error code | 
|         |   4443 **          [SQLITE_TOOBIG] and an appropriate error message. | 
|         |   4444 ** | 
|         |   4445 ** {H16421} The [sqlite3_result_error_nomem(C)] interface changes the return | 
|         |   4446 **          value of the function C to be an exception with error code | 
|         |   4447 **          [SQLITE_NOMEM] and an appropriate error message. | 
|         |   4448 ** | 
|         |   4449 ** {H16424} The [sqlite3_result_error_code(C,E)] interface changes the return | 
|         |   4450 **          value of the function C to be an exception with error code E. | 
|         |   4451 **          The error message text is unchanged. | 
|         |   4452 ** | 
|         |   4453 ** {H16427} The [sqlite3_result_int(C,V)] interface changes the | 
|         |   4454 **          return value of function C to be the 32-bit integer value V. | 
|         |   4455 ** | 
|         |   4456 ** {H16430} The [sqlite3_result_int64(C,V)] interface changes the | 
|         |   4457 **          return value of function C to be the 64-bit integer value V. | 
|         |   4458 ** | 
|         |   4459 ** {H16433} The [sqlite3_result_null(C)] interface changes the | 
|         |   4460 **          return value of function C to be NULL. | 
|         |   4461 ** | 
|         |   4462 ** {H16436} The [sqlite3_result_text(C,V,N,D)] interface changes the | 
|         |   4463 **          return value of function C to be the UTF-8 string | 
|         |   4464 **          V up to the first zero if N is negative | 
|         |   4465 **          or the first N bytes of V if N is non-negative. | 
|         |   4466 ** | 
|         |   4467 ** {H16439} The [sqlite3_result_text16(C,V,N,D)] interface changes the | 
|         |   4468 **          return value of function C to be the UTF-16 native byte order | 
|         |   4469 **          string V up to the first zero if N is negative | 
|         |   4470 **          or the first N bytes of V if N is non-negative. | 
|         |   4471 ** | 
|         |   4472 ** {H16442} The [sqlite3_result_text16be(C,V,N,D)] interface changes the | 
|         |   4473 **          return value of function C to be the UTF-16 big-endian | 
|         |   4474 **          string V up to the first zero if N is negative | 
|         |   4475 **          or the first N bytes or V if N is non-negative. | 
|         |   4476 ** | 
|         |   4477 ** {H16445} The [sqlite3_result_text16le(C,V,N,D)] interface changes the | 
|         |   4478 **          return value of function C to be the UTF-16 little-endian | 
|         |   4479 **          string V up to the first zero if N is negative | 
|         |   4480 **          or the first N bytes of V if N is non-negative. | 
|         |   4481 ** | 
|         |   4482 ** {H16448} The [sqlite3_result_value(C,V)] interface changes the | 
|         |   4483 **          return value of function C to be the [unprotected sqlite3_value] | 
|         |   4484 **          object V. | 
|         |   4485 ** | 
|         |   4486 ** {H16451} The [sqlite3_result_zeroblob(C,N)] interface changes the | 
|         |   4487 **          return value of function C to be an N-byte BLOB of all zeros. | 
|         |   4488 ** | 
|         |   4489 ** {H16454} The [sqlite3_result_error()] and [sqlite3_result_error16()] | 
|         |   4490 **          interfaces make a copy of their error message strings before | 
|         |   4491 **          returning. | 
|         |   4492 ** | 
|         |   4493 ** {H16457} If the D destructor parameter to [sqlite3_result_blob(C,V,N,D)], | 
|         |   4494 **          [sqlite3_result_text(C,V,N,D)], [sqlite3_result_text16(C,V,N,D)], | 
|         |   4495 **          [sqlite3_result_text16be(C,V,N,D)], or | 
|         |   4496 **          [sqlite3_result_text16le(C,V,N,D)] is the constant [SQLITE_STATIC] | 
|         |   4497 **          then no destructor is ever called on the pointer V and SQLite | 
|         |   4498 **          assumes that V is immutable. | 
|         |   4499 ** | 
|         |   4500 ** {H16460} If the D destructor parameter to [sqlite3_result_blob(C,V,N,D)], | 
|         |   4501 **          [sqlite3_result_text(C,V,N,D)], [sqlite3_result_text16(C,V,N,D)], | 
|         |   4502 **          [sqlite3_result_text16be(C,V,N,D)], or | 
|         |   4503 **          [sqlite3_result_text16le(C,V,N,D)] is the constant | 
|         |   4504 **          [SQLITE_TRANSIENT] then the interfaces makes a copy of the | 
|         |   4505 **          content of V and retains the copy. | 
|         |   4506 ** | 
|         |   4507 ** {H16463} If the D destructor parameter to [sqlite3_result_blob(C,V,N,D)], | 
|         |   4508 **          [sqlite3_result_text(C,V,N,D)], [sqlite3_result_text16(C,V,N,D)], | 
|         |   4509 **          [sqlite3_result_text16be(C,V,N,D)], or | 
|         |   4510 **          [sqlite3_result_text16le(C,V,N,D)] is some value other than | 
|         |   4511 **          the constants [SQLITE_STATIC] and [SQLITE_TRANSIENT] then | 
|         |   4512 **          SQLite will invoke the destructor D with V as its only argument | 
|         |   4513 **          when it has finished with the V value. | 
|         |   4514 */ | 
|         |   4515 IMPORT_C void sqlite3_result_blob(sqlite3_context*, const void*, int, void(*)(void*)); | 
|         |   4516 IMPORT_C void sqlite3_result_double(sqlite3_context*, double); | 
|         |   4517 IMPORT_C void sqlite3_result_error(sqlite3_context*, const char*, int); | 
|         |   4518 IMPORT_C void sqlite3_result_error16(sqlite3_context*, const void*, int); | 
|         |   4519 IMPORT_C void sqlite3_result_error_toobig(sqlite3_context*); | 
|         |   4520 IMPORT_C void sqlite3_result_error_nomem(sqlite3_context*); | 
|         |   4521 IMPORT_C void sqlite3_result_error_code(sqlite3_context*, int); | 
|         |   4522 IMPORT_C void sqlite3_result_int(sqlite3_context*, int); | 
|         |   4523 IMPORT_C void sqlite3_result_int64(sqlite3_context*, sqlite3_int64); | 
|         |   4524 IMPORT_C void sqlite3_result_null(sqlite3_context*); | 
|         |   4525 IMPORT_C void sqlite3_result_text(sqlite3_context*, const char*, int, void(*)(void*)); | 
|         |   4526 IMPORT_C void sqlite3_result_text16(sqlite3_context*, const void*, int, void(*)(void*)); | 
|         |   4527 IMPORT_C void sqlite3_result_text16le(sqlite3_context*, const void*, int,void(*)(void*)); | 
|         |   4528 IMPORT_C void sqlite3_result_text16be(sqlite3_context*, const void*, int,void(*)(void*)); | 
|         |   4529 IMPORT_C void sqlite3_result_value(sqlite3_context*, sqlite3_value*); | 
|         |   4530 IMPORT_C void sqlite3_result_zeroblob(sqlite3_context*, int n); | 
|         |   4531  | 
|         |   4532 /* | 
|         |   4533 ** CAPI3REF: Define New Collating Sequences {H16600} <S20300> | 
|         |   4534 ** | 
|         |   4535 ** These functions are used to add new collation sequences to the | 
|         |   4536 ** [database connection] specified as the first argument. | 
|         |   4537 ** | 
|         |   4538 ** The name of the new collation sequence is specified as a UTF-8 string | 
|         |   4539 ** for sqlite3_create_collation() and sqlite3_create_collation_v2() | 
|         |   4540 ** and a UTF-16 string for sqlite3_create_collation16(). In all cases | 
|         |   4541 ** the name is passed as the second function argument. | 
|         |   4542 ** | 
|         |   4543 ** The third argument may be one of the constants [SQLITE_UTF8], | 
|         |   4544 ** [SQLITE_UTF16LE] or [SQLITE_UTF16BE], indicating that the user-supplied | 
|         |   4545 ** routine expects to be passed pointers to strings encoded using UTF-8, | 
|         |   4546 ** UTF-16 little-endian, or UTF-16 big-endian, respectively. The | 
|         |   4547 ** third argument might also be [SQLITE_UTF16_ALIGNED] to indicate that | 
|         |   4548 ** the routine expects pointers to 16-bit word aligned strings | 
|         |   4549 ** of UTF-16 in the native byte order of the host computer. | 
|         |   4550 ** | 
|         |   4551 ** A pointer to the user supplied routine must be passed as the fifth | 
|         |   4552 ** argument.  If it is NULL, this is the same as deleting the collation | 
|         |   4553 ** sequence (so that SQLite cannot call it anymore). | 
|         |   4554 ** Each time the application supplied function is invoked, it is passed | 
|         |   4555 ** as its first parameter a copy of the void* passed as the fourth argument | 
|         |   4556 ** to sqlite3_create_collation() or sqlite3_create_collation16(). | 
|         |   4557 ** | 
|         |   4558 ** The remaining arguments to the application-supplied routine are two strings, | 
|         |   4559 ** each represented by a (length, data) pair and encoded in the encoding | 
|         |   4560 ** that was passed as the third argument when the collation sequence was | 
|         |   4561 ** registered. {END}  The application defined collation routine should | 
|         |   4562 ** return negative, zero or positive if the first string is less than, | 
|         |   4563 ** equal to, or greater than the second string. i.e. (STRING1 - STRING2). | 
|         |   4564 ** | 
|         |   4565 ** The sqlite3_create_collation_v2() works like sqlite3_create_collation() | 
|         |   4566 ** except that it takes an extra argument which is a destructor for | 
|         |   4567 ** the collation.  The destructor is called when the collation is | 
|         |   4568 ** destroyed and is passed a copy of the fourth parameter void* pointer | 
|         |   4569 ** of the sqlite3_create_collation_v2(). | 
|         |   4570 ** Collations are destroyed when they are overridden by later calls to the | 
|         |   4571 ** collation creation functions or when the [database connection] is closed | 
|         |   4572 ** using [sqlite3_close()]. | 
|         |   4573 ** | 
|         |   4574 ** INVARIANTS: | 
|         |   4575 ** | 
|         |   4576 ** {H16603} A successful call to the | 
|         |   4577 **          [sqlite3_create_collation_v2(B,X,E,P,F,D)] interface | 
|         |   4578 **          registers function F as the comparison function used to | 
|         |   4579 **          implement collation X on the [database connection] B for | 
|         |   4580 **          databases having encoding E. | 
|         |   4581 ** | 
|         |   4582 ** {H16604} SQLite understands the X parameter to | 
|         |   4583 **          [sqlite3_create_collation_v2(B,X,E,P,F,D)] as a zero-terminated | 
|         |   4584 **          UTF-8 string in which case is ignored for ASCII characters and | 
|         |   4585 **          is significant for non-ASCII characters. | 
|         |   4586 ** | 
|         |   4587 ** {H16606} Successive calls to [sqlite3_create_collation_v2(B,X,E,P,F,D)] | 
|         |   4588 **          with the same values for B, X, and E, override prior values | 
|         |   4589 **          of P, F, and D. | 
|         |   4590 ** | 
|         |   4591 ** {H16609} If the destructor D in [sqlite3_create_collation_v2(B,X,E,P,F,D)] | 
|         |   4592 **          is not NULL then it is called with argument P when the | 
|         |   4593 **          collating function is dropped by SQLite. | 
|         |   4594 ** | 
|         |   4595 ** {H16612} A collating function is dropped when it is overloaded. | 
|         |   4596 ** | 
|         |   4597 ** {H16615} A collating function is dropped when the database connection | 
|         |   4598 **          is closed using [sqlite3_close()]. | 
|         |   4599 ** | 
|         |   4600 ** {H16618} The pointer P in [sqlite3_create_collation_v2(B,X,E,P,F,D)] | 
|         |   4601 **          is passed through as the first parameter to the comparison | 
|         |   4602 **          function F for all subsequent invocations of F. | 
|         |   4603 ** | 
|         |   4604 ** {H16621} A call to [sqlite3_create_collation(B,X,E,P,F)] is exactly | 
|         |   4605 **          the same as a call to [sqlite3_create_collation_v2()] with | 
|         |   4606 **          the same parameters and a NULL destructor. | 
|         |   4607 ** | 
|         |   4608 ** {H16624} Following a [sqlite3_create_collation_v2(B,X,E,P,F,D)], | 
|         |   4609 **          SQLite uses the comparison function F for all text comparison | 
|         |   4610 **          operations on the [database connection] B on text values that | 
|         |   4611 **          use the collating sequence named X. | 
|         |   4612 ** | 
|         |   4613 ** {H16627} The [sqlite3_create_collation16(B,X,E,P,F)] works the same | 
|         |   4614 **          as [sqlite3_create_collation(B,X,E,P,F)] except that the | 
|         |   4615 **          collation name X is understood as UTF-16 in native byte order | 
|         |   4616 **          instead of UTF-8. | 
|         |   4617 ** | 
|         |   4618 ** {H16630} When multiple comparison functions are available for the same | 
|         |   4619 **          collating sequence, SQLite chooses the one whose text encoding | 
|         |   4620 **          requires the least amount of conversion from the default | 
|         |   4621 **          text encoding of the database. | 
|         |   4622 */ | 
|         |   4623 IMPORT_C int sqlite3_create_collation( | 
|         |   4624   sqlite3*,  | 
|         |   4625   const char *zName,  | 
|         |   4626   int eTextRep,  | 
|         |   4627   void*, | 
|         |   4628   int(*xCompare)(void*,int,const void*,int,const void*) | 
|         |   4629 ); | 
|         |   4630 IMPORT_C int sqlite3_create_collation_v2( | 
|         |   4631   sqlite3*,  | 
|         |   4632   const char *zName,  | 
|         |   4633   int eTextRep,  | 
|         |   4634   void*, | 
|         |   4635   int(*xCompare)(void*,int,const void*,int,const void*), | 
|         |   4636   void(*xDestroy)(void*) | 
|         |   4637 ); | 
|         |   4638 IMPORT_C int sqlite3_create_collation16( | 
|         |   4639   sqlite3*,  | 
|         |   4640   const void *zName, | 
|         |   4641   int eTextRep,  | 
|         |   4642   void*, | 
|         |   4643   int(*xCompare)(void*,int,const void*,int,const void*) | 
|         |   4644 ); | 
|         |   4645  | 
|         |   4646 /* | 
|         |   4647 ** CAPI3REF: Collation Needed Callbacks {H16700} <S20300> | 
|         |   4648 ** | 
|         |   4649 ** To avoid having to register all collation sequences before a database | 
|         |   4650 ** can be used, a single callback function may be registered with the | 
|         |   4651 ** [database connection] to be called whenever an undefined collation | 
|         |   4652 ** sequence is required. | 
|         |   4653 ** | 
|         |   4654 ** If the function is registered using the sqlite3_collation_needed() API, | 
|         |   4655 ** then it is passed the names of undefined collation sequences as strings | 
|         |   4656 ** encoded in UTF-8. {H16703} If sqlite3_collation_needed16() is used, | 
|         |   4657 ** the names are passed as UTF-16 in machine native byte order. | 
|         |   4658 ** A call to either function replaces any existing callback. | 
|         |   4659 ** | 
|         |   4660 ** When the callback is invoked, the first argument passed is a copy | 
|         |   4661 ** of the second argument to sqlite3_collation_needed() or | 
|         |   4662 ** sqlite3_collation_needed16().  The second argument is the database | 
|         |   4663 ** connection.  The third argument is one of [SQLITE_UTF8], [SQLITE_UTF16BE], | 
|         |   4664 ** or [SQLITE_UTF16LE], indicating the most desirable form of the collation | 
|         |   4665 ** sequence function required.  The fourth parameter is the name of the | 
|         |   4666 ** required collation sequence. | 
|         |   4667 ** | 
|         |   4668 ** The callback function should register the desired collation using | 
|         |   4669 ** [sqlite3_create_collation()], [sqlite3_create_collation16()], or | 
|         |   4670 ** [sqlite3_create_collation_v2()]. | 
|         |   4671 ** | 
|         |   4672 ** INVARIANTS: | 
|         |   4673 ** | 
|         |   4674 ** {H16702} A successful call to [sqlite3_collation_needed(D,P,F)] | 
|         |   4675 **          or [sqlite3_collation_needed16(D,P,F)] causes | 
|         |   4676 **          the [database connection] D to invoke callback F with first | 
|         |   4677 **          parameter P whenever it needs a comparison function for a | 
|         |   4678 **          collating sequence that it does not know about. | 
|         |   4679 ** | 
|         |   4680 ** {H16704} Each successful call to [sqlite3_collation_needed()] or | 
|         |   4681 **          [sqlite3_collation_needed16()] overrides the callback registered | 
|         |   4682 **          on the same [database connection] by prior calls to either | 
|         |   4683 **          interface. | 
|         |   4684 ** | 
|         |   4685 ** {H16706} The name of the requested collating function passed in the | 
|         |   4686 **          4th parameter to the callback is in UTF-8 if the callback | 
|         |   4687 **          was registered using [sqlite3_collation_needed()] and | 
|         |   4688 **          is in UTF-16 native byte order if the callback was | 
|         |   4689 **          registered using [sqlite3_collation_needed16()]. | 
|         |   4690 */ | 
|         |   4691 IMPORT_C int sqlite3_collation_needed( | 
|         |   4692   sqlite3*,  | 
|         |   4693   void*,  | 
|         |   4694   void(*)(void*,sqlite3*,int eTextRep,const char*) | 
|         |   4695 ); | 
|         |   4696 IMPORT_C int sqlite3_collation_needed16( | 
|         |   4697   sqlite3*,  | 
|         |   4698   void*, | 
|         |   4699   void(*)(void*,sqlite3*,int eTextRep,const void*) | 
|         |   4700 ); | 
|         |   4701  | 
|         |   4702 /* | 
|         |   4703 ** Specify the key for an encrypted database.  This routine should be | 
|         |   4704 ** called right after sqlite3_open(). | 
|         |   4705 ** | 
|         |   4706 ** The code to implement this API is not available in the public release | 
|         |   4707 ** of SQLite. | 
|         |   4708 */ | 
|         |   4709 IMPORT_C int sqlite3_key( | 
|         |   4710   sqlite3 *db,                   /* Database to be rekeyed */ | 
|         |   4711   const void *pKey, int nKey     /* The key */ | 
|         |   4712 ); | 
|         |   4713  | 
|         |   4714 /* | 
|         |   4715 ** Change the key on an open database.  If the current database is not | 
|         |   4716 ** encrypted, this routine will encrypt it.  If pNew==0 or nNew==0, the | 
|         |   4717 ** database is decrypted. | 
|         |   4718 ** | 
|         |   4719 ** The code to implement this API is not available in the public release | 
|         |   4720 ** of SQLite. | 
|         |   4721 */ | 
|         |   4722 IMPORT_C int sqlite3_rekey( | 
|         |   4723   sqlite3 *db,                   /* Database to be rekeyed */ | 
|         |   4724   const void *pKey, int nKey     /* The new key */ | 
|         |   4725 ); | 
|         |   4726  | 
|         |   4727 /* | 
|         |   4728 ** CAPI3REF: Suspend Execution For A Short Time {H10530} <S40410> | 
|         |   4729 ** | 
|         |   4730 ** The sqlite3_sleep() function causes the current thread to suspend execution | 
|         |   4731 ** for at least a number of milliseconds specified in its parameter. | 
|         |   4732 ** | 
|         |   4733 ** If the operating system does not support sleep requests with | 
|         |   4734 ** millisecond time resolution, then the time will be rounded up to | 
|         |   4735 ** the nearest second. The number of milliseconds of sleep actually | 
|         |   4736 ** requested from the operating system is returned. | 
|         |   4737 ** | 
|         |   4738 ** SQLite implements this interface by calling the xSleep() | 
|         |   4739 ** method of the default [sqlite3_vfs] object. | 
|         |   4740 ** | 
|         |   4741 ** INVARIANTS: | 
|         |   4742 ** | 
|         |   4743 ** {H10533} The [sqlite3_sleep(M)] interface invokes the xSleep | 
|         |   4744 **          method of the default [sqlite3_vfs|VFS] in order to | 
|         |   4745 **          suspend execution of the current thread for at least | 
|         |   4746 **          M milliseconds. | 
|         |   4747 ** | 
|         |   4748 ** {H10536} The [sqlite3_sleep(M)] interface returns the number of | 
|         |   4749 **          milliseconds of sleep actually requested of the operating | 
|         |   4750 **          system, which might be larger than the parameter M. | 
|         |   4751 */ | 
|         |   4752 IMPORT_C int sqlite3_sleep(int); | 
|         |   4753  | 
|         |   4754 /* | 
|         |   4755 ** CAPI3REF: Name Of The Folder Holding Temporary Files {H10310} <S20000> | 
|         |   4756 ** | 
|         |   4757 ** If this global variable is made to point to a string which is | 
|         |   4758 ** the name of a folder (a.k.a. directory), then all temporary files | 
|         |   4759 ** created by SQLite will be placed in that directory.  If this variable | 
|         |   4760 ** is a NULL pointer, then SQLite performs a search for an appropriate | 
|         |   4761 ** temporary file directory. | 
|         |   4762 ** | 
|         |   4763 ** It is not safe to modify this variable once a [database connection] | 
|         |   4764 ** has been opened.  It is intended that this variable be set once | 
|         |   4765 ** as part of process initialization and before any SQLite interface | 
|         |   4766 ** routines have been call and remain unchanged thereafter. | 
|         |   4767 */ | 
|         |   4768 SQLITE_EXTERN char *sqlite3_temp_directory; | 
|         |   4769  | 
|         |   4770 /* | 
|         |   4771 ** CAPI3REF: Test For Auto-Commit Mode {H12930} <S60200> | 
|         |   4772 ** KEYWORDS: {autocommit mode} | 
|         |   4773 ** | 
|         |   4774 ** The sqlite3_get_autocommit() interface returns non-zero or | 
|         |   4775 ** zero if the given database connection is or is not in autocommit mode, | 
|         |   4776 ** respectively.  Autocommit mode is on by default. | 
|         |   4777 ** Autocommit mode is disabled by a [BEGIN] statement. | 
|         |   4778 ** Autocommit mode is re-enabled by a [COMMIT] or [ROLLBACK]. | 
|         |   4779 ** | 
|         |   4780 ** If certain kinds of errors occur on a statement within a multi-statement | 
|         |   4781 ** transaction (errors including [SQLITE_FULL], [SQLITE_IOERR], | 
|         |   4782 ** [SQLITE_NOMEM], [SQLITE_BUSY], and [SQLITE_INTERRUPT]) then the | 
|         |   4783 ** transaction might be rolled back automatically.  The only way to | 
|         |   4784 ** find out whether SQLite automatically rolled back the transaction after | 
|         |   4785 ** an error is to use this function. | 
|         |   4786 ** | 
|         |   4787 ** INVARIANTS: | 
|         |   4788 ** | 
|         |   4789 ** {H12931} The [sqlite3_get_autocommit(D)] interface returns non-zero or | 
|         |   4790 **          zero if the [database connection] D is or is not in autocommit | 
|         |   4791 **          mode, respectively. | 
|         |   4792 ** | 
|         |   4793 ** {H12932} Autocommit mode is on by default. | 
|         |   4794 ** | 
|         |   4795 ** {H12933} Autocommit mode is disabled by a successful [BEGIN] statement. | 
|         |   4796 ** | 
|         |   4797 ** {H12934} Autocommit mode is enabled by a successful [COMMIT] or [ROLLBACK] | 
|         |   4798 **          statement. | 
|         |   4799 ** | 
|         |   4800 ** ASSUMPTIONS: | 
|         |   4801 ** | 
|         |   4802 ** {A12936} If another thread changes the autocommit status of the database | 
|         |   4803 **          connection while this routine is running, then the return value | 
|         |   4804 **          is undefined. | 
|         |   4805 */ | 
|         |   4806 IMPORT_C int sqlite3_get_autocommit(sqlite3*); | 
|         |   4807  | 
|         |   4808 /* | 
|         |   4809 ** CAPI3REF: Find The Database Handle Of A Prepared Statement {H13120} <S60600> | 
|         |   4810 ** | 
|         |   4811 ** The sqlite3_db_handle interface returns the [database connection] handle | 
|         |   4812 ** to which a [prepared statement] belongs.  The database handle returned by | 
|         |   4813 ** sqlite3_db_handle is the same database handle that was the first argument | 
|         |   4814 ** to the [sqlite3_prepare_v2()] call (or its variants) that was used to | 
|         |   4815 ** create the statement in the first place. | 
|         |   4816 ** | 
|         |   4817 ** INVARIANTS: | 
|         |   4818 ** | 
|         |   4819 ** {H13123} The [sqlite3_db_handle(S)] interface returns a pointer | 
|         |   4820 **          to the [database connection] associated with the | 
|         |   4821 **          [prepared statement] S. | 
|         |   4822 */ | 
|         |   4823 IMPORT_C sqlite3 *sqlite3_db_handle(sqlite3_stmt*); | 
|         |   4824  | 
|         |   4825 /* | 
|         |   4826 ** CAPI3REF: Find the next prepared statement {H13140} <S60600> | 
|         |   4827 ** | 
|         |   4828 ** This interface returns a pointer to the next [prepared statement] after | 
|         |   4829 ** pStmt associated with the [database connection] pDb.  If pStmt is NULL | 
|         |   4830 ** then this interface returns a pointer to the first prepared statement | 
|         |   4831 ** associated with the database connection pDb.  If no prepared statement | 
|         |   4832 ** satisfies the conditions of this routine, it returns NULL. | 
|         |   4833 ** | 
|         |   4834 ** INVARIANTS: | 
|         |   4835 ** | 
|         |   4836 ** {H13143} If D is a [database connection] that holds one or more | 
|         |   4837 **          unfinalized [prepared statements] and S is a NULL pointer, | 
|         |   4838 **          then [sqlite3_next_stmt(D, S)] routine shall return a pointer | 
|         |   4839 **          to one of the prepared statements associated with D. | 
|         |   4840 ** | 
|         |   4841 ** {H13146} If D is a [database connection] that holds no unfinalized | 
|         |   4842 **          [prepared statements] and S is a NULL pointer, then | 
|         |   4843 **          [sqlite3_next_stmt(D, S)] routine shall return a NULL pointer. | 
|         |   4844 ** | 
|         |   4845 ** {H13149} If S is a [prepared statement] in the [database connection] D | 
|         |   4846 **          and S is not the last prepared statement in D, then | 
|         |   4847 **          [sqlite3_next_stmt(D, S)] routine shall return a pointer | 
|         |   4848 **          to the next prepared statement in D after S. | 
|         |   4849 ** | 
|         |   4850 ** {H13152} If S is the last [prepared statement] in the | 
|         |   4851 **          [database connection] D then the [sqlite3_next_stmt(D, S)] | 
|         |   4852 **          routine shall return a NULL pointer. | 
|         |   4853 ** | 
|         |   4854 ** ASSUMPTIONS: | 
|         |   4855 ** | 
|         |   4856 ** {A13154} The [database connection] pointer D in a call to | 
|         |   4857 **          [sqlite3_next_stmt(D,S)] must refer to an open database | 
|         |   4858 **          connection and in particular must not be a NULL pointer. | 
|         |   4859 */ | 
|         |   4860 IMPORT_C sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt); | 
|         |   4861  | 
|         |   4862 /* | 
|         |   4863 ** CAPI3REF: Commit And Rollback Notification Callbacks {H12950} <S60400> | 
|         |   4864 ** | 
|         |   4865 ** The sqlite3_commit_hook() interface registers a callback | 
|         |   4866 ** function to be invoked whenever a transaction is committed. | 
|         |   4867 ** Any callback set by a previous call to sqlite3_commit_hook() | 
|         |   4868 ** for the same database connection is overridden. | 
|         |   4869 ** The sqlite3_rollback_hook() interface registers a callback | 
|         |   4870 ** function to be invoked whenever a transaction is committed. | 
|         |   4871 ** Any callback set by a previous call to sqlite3_commit_hook() | 
|         |   4872 ** for the same database connection is overridden. | 
|         |   4873 ** The pArg argument is passed through to the callback. | 
|         |   4874 ** If the callback on a commit hook function returns non-zero, | 
|         |   4875 ** then the commit is converted into a rollback. | 
|         |   4876 ** | 
|         |   4877 ** If another function was previously registered, its | 
|         |   4878 ** pArg value is returned.  Otherwise NULL is returned. | 
|         |   4879 ** | 
|         |   4880 ** The callback implementation must not do anything that will modify | 
|         |   4881 ** the database connection that invoked the callback.  Any actions | 
|         |   4882 ** to modify the database connection must be deferred until after the | 
|         |   4883 ** completion of the [sqlite3_step()] call that triggered the commit | 
|         |   4884 ** or rollback hook in the first place. | 
|         |   4885 ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their | 
|         |   4886 ** database connections for the meaning of "modify" in this paragraph. | 
|         |   4887 ** | 
|         |   4888 ** Registering a NULL function disables the callback. | 
|         |   4889 ** | 
|         |   4890 ** For the purposes of this API, a transaction is said to have been | 
|         |   4891 ** rolled back if an explicit "ROLLBACK" statement is executed, or | 
|         |   4892 ** an error or constraint causes an implicit rollback to occur. | 
|         |   4893 ** The rollback callback is not invoked if a transaction is | 
|         |   4894 ** automatically rolled back because the database connection is closed. | 
|         |   4895 ** The rollback callback is not invoked if a transaction is | 
|         |   4896 ** rolled back because a commit callback returned non-zero. | 
|         |   4897 ** <todo> Check on this </todo> | 
|         |   4898 ** | 
|         |   4899 ** INVARIANTS: | 
|         |   4900 ** | 
|         |   4901 ** {H12951} The [sqlite3_commit_hook(D,F,P)] interface registers the | 
|         |   4902 **          callback function F to be invoked with argument P whenever | 
|         |   4903 **          a transaction commits on the [database connection] D. | 
|         |   4904 ** | 
|         |   4905 ** {H12952} The [sqlite3_commit_hook(D,F,P)] interface returns the P argument | 
|         |   4906 **          from the previous call with the same [database connection] D, | 
|         |   4907 **          or NULL on the first call for a particular database connection D. | 
|         |   4908 ** | 
|         |   4909 ** {H12953} Each call to [sqlite3_commit_hook()] overwrites the callback | 
|         |   4910 **          registered by prior calls. | 
|         |   4911 ** | 
|         |   4912 ** {H12954} If the F argument to [sqlite3_commit_hook(D,F,P)] is NULL | 
|         |   4913 **          then the commit hook callback is canceled and no callback | 
|         |   4914 **          is invoked when a transaction commits. | 
|         |   4915 ** | 
|         |   4916 ** {H12955} If the commit callback returns non-zero then the commit is | 
|         |   4917 **          converted into a rollback. | 
|         |   4918 ** | 
|         |   4919 ** {H12961} The [sqlite3_rollback_hook(D,F,P)] interface registers the | 
|         |   4920 **          callback function F to be invoked with argument P whenever | 
|         |   4921 **          a transaction rolls back on the [database connection] D. | 
|         |   4922 ** | 
|         |   4923 ** {H12962} The [sqlite3_rollback_hook(D,F,P)] interface returns the P | 
|         |   4924 **          argument from the previous call with the same | 
|         |   4925 **          [database connection] D, or NULL on the first call | 
|         |   4926 **          for a particular database connection D. | 
|         |   4927 ** | 
|         |   4928 ** {H12963} Each call to [sqlite3_rollback_hook()] overwrites the callback | 
|         |   4929 **          registered by prior calls. | 
|         |   4930 ** | 
|         |   4931 ** {H12964} If the F argument to [sqlite3_rollback_hook(D,F,P)] is NULL | 
|         |   4932 **          then the rollback hook callback is canceled and no callback | 
|         |   4933 **          is invoked when a transaction rolls back. | 
|         |   4934 */ | 
|         |   4935 IMPORT_C void *sqlite3_commit_hook(sqlite3*, int(*)(void*), void*); | 
|         |   4936 IMPORT_C void *sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*); | 
|         |   4937  | 
|         |   4938 /* | 
|         |   4939 ** CAPI3REF: Data Change Notification Callbacks {H12970} <S60400> | 
|         |   4940 ** | 
|         |   4941 ** The sqlite3_update_hook() interface registers a callback function | 
|         |   4942 ** with the [database connection] identified by the first argument | 
|         |   4943 ** to be invoked whenever a row is updated, inserted or deleted. | 
|         |   4944 ** Any callback set by a previous call to this function | 
|         |   4945 ** for the same database connection is overridden. | 
|         |   4946 ** | 
|         |   4947 ** The second argument is a pointer to the function to invoke when a | 
|         |   4948 ** row is updated, inserted or deleted. | 
|         |   4949 ** The first argument to the callback is a copy of the third argument | 
|         |   4950 ** to sqlite3_update_hook(). | 
|         |   4951 ** The second callback argument is one of [SQLITE_INSERT], [SQLITE_DELETE], | 
|         |   4952 ** or [SQLITE_UPDATE], depending on the operation that caused the callback | 
|         |   4953 ** to be invoked. | 
|         |   4954 ** The third and fourth arguments to the callback contain pointers to the | 
|         |   4955 ** database and table name containing the affected row. | 
|         |   4956 ** The final callback parameter is the rowid of the row. In the case of | 
|         |   4957 ** an update, this is the rowid after the update takes place. | 
|         |   4958 ** | 
|         |   4959 ** The update hook is not invoked when internal system tables are | 
|         |   4960 ** modified (i.e. sqlite_master and sqlite_sequence). | 
|         |   4961 ** | 
|         |   4962 ** The update hook implementation must not do anything that will modify | 
|         |   4963 ** the database connection that invoked the update hook.  Any actions | 
|         |   4964 ** to modify the database connection must be deferred until after the | 
|         |   4965 ** completion of the [sqlite3_step()] call that triggered the update hook. | 
|         |   4966 ** Note that [sqlite3_prepare_v2()] and [sqlite3_step()] both modify their | 
|         |   4967 ** database connections for the meaning of "modify" in this paragraph. | 
|         |   4968 ** | 
|         |   4969 ** If another function was previously registered, its pArg value | 
|         |   4970 ** is returned.  Otherwise NULL is returned. | 
|         |   4971 ** | 
|         |   4972 ** INVARIANTS: | 
|         |   4973 ** | 
|         |   4974 ** {H12971} The [sqlite3_update_hook(D,F,P)] interface causes the callback | 
|         |   4975 **          function F to be invoked with first parameter P whenever | 
|         |   4976 **          a table row is modified, inserted, or deleted on | 
|         |   4977 **          the [database connection] D. | 
|         |   4978 ** | 
|         |   4979 ** {H12973} The [sqlite3_update_hook(D,F,P)] interface returns the value | 
|         |   4980 **          of P for the previous call on the same [database connection] D, | 
|         |   4981 **          or NULL for the first call. | 
|         |   4982 ** | 
|         |   4983 ** {H12975} If the update hook callback F in [sqlite3_update_hook(D,F,P)] | 
|         |   4984 **          is NULL then the no update callbacks are made. | 
|         |   4985 ** | 
|         |   4986 ** {H12977} Each call to [sqlite3_update_hook(D,F,P)] overrides prior calls | 
|         |   4987 **          to the same interface on the same [database connection] D. | 
|         |   4988 ** | 
|         |   4989 ** {H12979} The update hook callback is not invoked when internal system | 
|         |   4990 **          tables such as sqlite_master and sqlite_sequence are modified. | 
|         |   4991 ** | 
|         |   4992 ** {H12981} The second parameter to the update callback | 
|         |   4993 **          is one of [SQLITE_INSERT], [SQLITE_DELETE] or [SQLITE_UPDATE], | 
|         |   4994 **          depending on the operation that caused the callback to be invoked. | 
|         |   4995 ** | 
|         |   4996 ** {H12983} The third and fourth arguments to the callback contain pointers | 
|         |   4997 **          to zero-terminated UTF-8 strings which are the names of the | 
|         |   4998 **          database and table that is being updated. | 
|         |   4999  | 
|         |   5000 ** {H12985} The final callback parameter is the rowid of the row after | 
|         |   5001 **          the change occurs. | 
|         |   5002 */ | 
|         |   5003 IMPORT_C void *sqlite3_update_hook( | 
|         |   5004   sqlite3*,  | 
|         |   5005   void(*)(void *,int ,char const *,char const *,sqlite3_int64), | 
|         |   5006   void* | 
|         |   5007 ); | 
|         |   5008  | 
|         |   5009 /* | 
|         |   5010 ** CAPI3REF: Enable Or Disable Shared Pager Cache {H10330} <S30900> | 
|         |   5011 ** KEYWORDS: {shared cache} {shared cache mode} | 
|         |   5012 ** | 
|         |   5013 ** This routine enables or disables the sharing of the database cache | 
|         |   5014 ** and schema data structures between [database connection | connections] | 
|         |   5015 ** to the same database. Sharing is enabled if the argument is true | 
|         |   5016 ** and disabled if the argument is false. | 
|         |   5017 ** | 
|         |   5018 ** Cache sharing is enabled and disabled for an entire process. {END} | 
|         |   5019 ** This is a change as of SQLite version 3.5.0. In prior versions of SQLite, | 
|         |   5020 ** sharing was enabled or disabled for each thread separately. | 
|         |   5021 ** | 
|         |   5022 ** The cache sharing mode set by this interface effects all subsequent | 
|         |   5023 ** calls to [sqlite3_open()], [sqlite3_open_v2()], and [sqlite3_open16()]. | 
|         |   5024 ** Existing database connections continue use the sharing mode | 
|         |   5025 ** that was in effect at the time they were opened. | 
|         |   5026 ** | 
|         |   5027 ** Virtual tables cannot be used with a shared cache.  When shared | 
|         |   5028 ** cache is enabled, the [sqlite3_create_module()] API used to register | 
|         |   5029 ** virtual tables will always return an error. | 
|         |   5030 ** | 
|         |   5031 ** This routine returns [SQLITE_OK] if shared cache was enabled or disabled | 
|         |   5032 ** successfully.  An [error code] is returned otherwise. | 
|         |   5033 ** | 
|         |   5034 ** Shared cache is disabled by default. But this might change in | 
|         |   5035 ** future releases of SQLite.  Applications that care about shared | 
|         |   5036 ** cache setting should set it explicitly. | 
|         |   5037 ** | 
|         |   5038 ** INVARIANTS: | 
|         |   5039 ** | 
|         |   5040 ** {H10331} A successful invocation of [sqlite3_enable_shared_cache(B)] | 
|         |   5041 **          will enable or disable shared cache mode for any subsequently | 
|         |   5042 **          created [database connection] in the same process. | 
|         |   5043 ** | 
|         |   5044 ** {H10336} When shared cache is enabled, the [sqlite3_create_module()] | 
|         |   5045 **          interface will always return an error. | 
|         |   5046 ** | 
|         |   5047 ** {H10337} The [sqlite3_enable_shared_cache(B)] interface returns | 
|         |   5048 **          [SQLITE_OK] if shared cache was enabled or disabled successfully. | 
|         |   5049 ** | 
|         |   5050 ** {H10339} Shared cache is disabled by default. | 
|         |   5051 */ | 
|         |   5052 IMPORT_C int sqlite3_enable_shared_cache(int); | 
|         |   5053  | 
|         |   5054 /* | 
|         |   5055 ** CAPI3REF: Attempt To Free Heap Memory {H17340} <S30220> | 
|         |   5056 ** | 
|         |   5057 ** The sqlite3_release_memory() interface attempts to free N bytes | 
|         |   5058 ** of heap memory by deallocating non-essential memory allocations | 
|         |   5059 ** held by the database library. {END}  Memory used to cache database | 
|         |   5060 ** pages to improve performance is an example of non-essential memory. | 
|         |   5061 ** sqlite3_release_memory() returns the number of bytes actually freed, | 
|         |   5062 ** which might be more or less than the amount requested. | 
|         |   5063 ** | 
|         |   5064 ** INVARIANTS: | 
|         |   5065 ** | 
|         |   5066 ** {H17341} The [sqlite3_release_memory(N)] interface attempts to | 
|         |   5067 **          free N bytes of heap memory by deallocating non-essential | 
|         |   5068 **          memory allocations held by the database library. | 
|         |   5069 ** | 
|         |   5070 ** {H16342} The [sqlite3_release_memory(N)] returns the number | 
|         |   5071 **          of bytes actually freed, which might be more or less | 
|         |   5072 **          than the amount requested. | 
|         |   5073 */ | 
|         |   5074 IMPORT_C int sqlite3_release_memory(int); | 
|         |   5075  | 
|         |   5076 /* | 
|         |   5077 ** CAPI3REF: Impose A Limit On Heap Size {H17350} <S30220> | 
|         |   5078 ** | 
|         |   5079 ** The sqlite3_soft_heap_limit() interface places a "soft" limit | 
|         |   5080 ** on the amount of heap memory that may be allocated by SQLite. | 
|         |   5081 ** If an internal allocation is requested that would exceed the | 
|         |   5082 ** soft heap limit, [sqlite3_release_memory()] is invoked one or | 
|         |   5083 ** more times to free up some space before the allocation is performed. | 
|         |   5084 ** | 
|         |   5085 ** The limit is called "soft", because if [sqlite3_release_memory()] | 
|         |   5086 ** cannot free sufficient memory to prevent the limit from being exceeded, | 
|         |   5087 ** the memory is allocated anyway and the current operation proceeds. | 
|         |   5088 ** | 
|         |   5089 ** A negative or zero value for N means that there is no soft heap limit and | 
|         |   5090 ** [sqlite3_release_memory()] will only be called when memory is exhausted. | 
|         |   5091 ** The default value for the soft heap limit is zero. | 
|         |   5092 ** | 
|         |   5093 ** SQLite makes a best effort to honor the soft heap limit. | 
|         |   5094 ** But if the soft heap limit cannot be honored, execution will | 
|         |   5095 ** continue without error or notification.  This is why the limit is | 
|         |   5096 ** called a "soft" limit.  It is advisory only. | 
|         |   5097 ** | 
|         |   5098 ** Prior to SQLite version 3.5.0, this routine only constrained the memory | 
|         |   5099 ** allocated by a single thread - the same thread in which this routine | 
|         |   5100 ** runs.  Beginning with SQLite version 3.5.0, the soft heap limit is | 
|         |   5101 ** applied to all threads. The value specified for the soft heap limit | 
|         |   5102 ** is an upper bound on the total memory allocation for all threads. In | 
|         |   5103 ** version 3.5.0 there is no mechanism for limiting the heap usage for | 
|         |   5104 ** individual threads. | 
|         |   5105 ** | 
|         |   5106 ** INVARIANTS: | 
|         |   5107 ** | 
|         |   5108 ** {H16351} The [sqlite3_soft_heap_limit(N)] interface places a soft limit | 
|         |   5109 **          of N bytes on the amount of heap memory that may be allocated | 
|         |   5110 **          using [sqlite3_malloc()] or [sqlite3_realloc()] at any point | 
|         |   5111 **          in time. | 
|         |   5112 ** | 
|         |   5113 ** {H16352} If a call to [sqlite3_malloc()] or [sqlite3_realloc()] would | 
|         |   5114 **          cause the total amount of allocated memory to exceed the | 
|         |   5115 **          soft heap limit, then [sqlite3_release_memory()] is invoked | 
|         |   5116 **          in an attempt to reduce the memory usage prior to proceeding | 
|         |   5117 **          with the memory allocation attempt. | 
|         |   5118 ** | 
|         |   5119 ** {H16353} Calls to [sqlite3_malloc()] or [sqlite3_realloc()] that trigger | 
|         |   5120 **          attempts to reduce memory usage through the soft heap limit | 
|         |   5121 **          mechanism continue even if the attempt to reduce memory | 
|         |   5122 **          usage is unsuccessful. | 
|         |   5123 ** | 
|         |   5124 ** {H16354} A negative or zero value for N in a call to | 
|         |   5125 **          [sqlite3_soft_heap_limit(N)] means that there is no soft | 
|         |   5126 **          heap limit and [sqlite3_release_memory()] will only be | 
|         |   5127 **          called when memory is completely exhausted. | 
|         |   5128 ** | 
|         |   5129 ** {H16355} The default value for the soft heap limit is zero. | 
|         |   5130 ** | 
|         |   5131 ** {H16358} Each call to [sqlite3_soft_heap_limit(N)] overrides the | 
|         |   5132 **          values set by all prior calls. | 
|         |   5133 */ | 
|         |   5134 IMPORT_C void sqlite3_soft_heap_limit(int); | 
|         |   5135  | 
|         |   5136 /* | 
|         |   5137 ** CAPI3REF: Extract Metadata About A Column Of A Table {H12850} <S60300> | 
|         |   5138 ** | 
|         |   5139 ** This routine returns metadata about a specific column of a specific | 
|         |   5140 ** database table accessible using the [database connection] handle | 
|         |   5141 ** passed as the first function argument. | 
|         |   5142 ** | 
|         |   5143 ** The column is identified by the second, third and fourth parameters to | 
|         |   5144 ** this function. The second parameter is either the name of the database | 
|         |   5145 ** (i.e. "main", "temp" or an attached database) containing the specified | 
|         |   5146 ** table or NULL. If it is NULL, then all attached databases are searched | 
|         |   5147 ** for the table using the same algorithm used by the database engine to | 
|         |   5148 ** resolve unqualified table references. | 
|         |   5149 ** | 
|         |   5150 ** The third and fourth parameters to this function are the table and column | 
|         |   5151 ** name of the desired column, respectively. Neither of these parameters | 
|         |   5152 ** may be NULL. | 
|         |   5153 ** | 
|         |   5154 ** Metadata is returned by writing to the memory locations passed as the 5th | 
|         |   5155 ** and subsequent parameters to this function. Any of these arguments may be | 
|         |   5156 ** NULL, in which case the corresponding element of metadata is omitted. | 
|         |   5157 ** | 
|         |   5158 ** <blockquote> | 
|         |   5159 ** <table border="1"> | 
|         |   5160 ** <tr><th> Parameter <th> Output<br>Type <th>  Description | 
|         |   5161 ** | 
|         |   5162 ** <tr><td> 5th <td> const char* <td> Data type | 
|         |   5163 ** <tr><td> 6th <td> const char* <td> Name of default collation sequence | 
|         |   5164 ** <tr><td> 7th <td> int         <td> True if column has a NOT NULL constraint | 
|         |   5165 ** <tr><td> 8th <td> int         <td> True if column is part of the PRIMARY KEY | 
|         |   5166 ** <tr><td> 9th <td> int         <td> True if column is AUTOINCREMENT | 
|         |   5167 ** </table> | 
|         |   5168 ** </blockquote> | 
|         |   5169 ** | 
|         |   5170 ** The memory pointed to by the character pointers returned for the | 
|         |   5171 ** declaration type and collation sequence is valid only until the next | 
|         |   5172 ** call to any SQLite API function. | 
|         |   5173 ** | 
|         |   5174 ** If the specified table is actually a view, an [error code] is returned. | 
|         |   5175 ** | 
|         |   5176 ** If the specified column is "rowid", "oid" or "_rowid_" and an | 
|         |   5177 ** INTEGER PRIMARY KEY column has been explicitly declared, then the output | 
|         |   5178 ** parameters are set for the explicitly declared column. If there is no | 
|         |   5179 ** explicitly declared INTEGER PRIMARY KEY column, then the output | 
|         |   5180 ** parameters are set as follows: | 
|         |   5181 ** | 
|         |   5182 ** <pre> | 
|         |   5183 **     data type: "INTEGER" | 
|         |   5184 **     collation sequence: "BINARY" | 
|         |   5185 **     not null: 0 | 
|         |   5186 **     primary key: 1 | 
|         |   5187 **     auto increment: 0 | 
|         |   5188 ** </pre> | 
|         |   5189 ** | 
|         |   5190 ** This function may load one or more schemas from database files. If an | 
|         |   5191 ** error occurs during this process, or if the requested table or column | 
|         |   5192 ** cannot be found, an [error code] is returned and an error message left | 
|         |   5193 ** in the [database connection] (to be retrieved using sqlite3_errmsg()). | 
|         |   5194 ** | 
|         |   5195 ** This API is only available if the library was compiled with the | 
|         |   5196 ** [SQLITE_ENABLE_COLUMN_METADATA] C-preprocessor symbol defined. | 
|         |   5197 */ | 
|         |   5198 IMPORT_C int sqlite3_table_column_metadata( | 
|         |   5199   sqlite3 *db,                /* Connection handle */ | 
|         |   5200   const char *zDbName,        /* Database name or NULL */ | 
|         |   5201   const char *zTableName,     /* Table name */ | 
|         |   5202   const char *zColumnName,    /* Column name */ | 
|         |   5203   char const **pzDataType,    /* OUTPUT: Declared data type */ | 
|         |   5204   char const **pzCollSeq,     /* OUTPUT: Collation sequence name */ | 
|         |   5205   int *pNotNull,              /* OUTPUT: True if NOT NULL constraint exists */ | 
|         |   5206   int *pPrimaryKey,           /* OUTPUT: True if column part of PK */ | 
|         |   5207   int *pAutoinc               /* OUTPUT: True if column is auto-increment */ | 
|         |   5208 ); | 
|         |   5209  | 
|         |   5210 /* | 
|         |   5211 ** CAPI3REF: Load An Extension {H12600} <S20500> | 
|         |   5212 ** | 
|         |   5213 ** This interface loads an SQLite extension library from the named file. | 
|         |   5214 ** | 
|         |   5215 ** {H12601} The sqlite3_load_extension() interface attempts to load an | 
|         |   5216 **          SQLite extension library contained in the file zFile. | 
|         |   5217 ** | 
|         |   5218 ** {H12602} The entry point is zProc. | 
|         |   5219 ** | 
|         |   5220 ** {H12603} zProc may be 0, in which case the name of the entry point | 
|         |   5221 **          defaults to "sqlite3_extension_init". | 
|         |   5222 ** | 
|         |   5223 ** {H12604} The sqlite3_load_extension() interface shall return | 
|         |   5224 **          [SQLITE_OK] on success and [SQLITE_ERROR] if something goes wrong. | 
|         |   5225 ** | 
|         |   5226 ** {H12605} If an error occurs and pzErrMsg is not 0, then the | 
|         |   5227 **          [sqlite3_load_extension()] interface shall attempt to | 
|         |   5228 **          fill *pzErrMsg with error message text stored in memory | 
|         |   5229 **          obtained from [sqlite3_malloc()]. {END}  The calling function | 
|         |   5230 **          should free this memory by calling [sqlite3_free()]. | 
|         |   5231 ** | 
|         |   5232 ** {H12606} Extension loading must be enabled using | 
|         |   5233 **          [sqlite3_enable_load_extension()] prior to calling this API, | 
|         |   5234 **          otherwise an error will be returned. | 
|         |   5235 */ | 
|         |   5236 IMPORT_C int sqlite3_load_extension( | 
|         |   5237   sqlite3 *db,          /* Load the extension into this database connection */ | 
|         |   5238   const char *zFile,    /* Name of the shared library containing extension */ | 
|         |   5239   const char *zProc,    /* Entry point.  Derived from zFile if 0 */ | 
|         |   5240   char **pzErrMsg       /* Put error message here if not 0 */ | 
|         |   5241 ); | 
|         |   5242  | 
|         |   5243 /* | 
|         |   5244 ** CAPI3REF: Enable Or Disable Extension Loading {H12620} <S20500> | 
|         |   5245 ** | 
|         |   5246 ** So as not to open security holes in older applications that are | 
|         |   5247 ** unprepared to deal with extension loading, and as a means of disabling | 
|         |   5248 ** extension loading while evaluating user-entered SQL, the following API | 
|         |   5249 ** is provided to turn the [sqlite3_load_extension()] mechanism on and off. | 
|         |   5250 ** | 
|         |   5251 ** Extension loading is off by default. See ticket #1863. | 
|         |   5252 ** | 
|         |   5253 ** {H12621} Call the sqlite3_enable_load_extension() routine with onoff==1 | 
|         |   5254 **          to turn extension loading on and call it with onoff==0 to turn | 
|         |   5255 **          it back off again. | 
|         |   5256 ** | 
|         |   5257 ** {H12622} Extension loading is off by default. | 
|         |   5258 */ | 
|         |   5259 IMPORT_C int sqlite3_enable_load_extension(sqlite3 *db, int onoff); | 
|         |   5260  | 
|         |   5261 /* | 
|         |   5262 ** CAPI3REF: Automatically Load An Extensions {H12640} <S20500> | 
|         |   5263 ** | 
|         |   5264 ** This API can be invoked at program startup in order to register | 
|         |   5265 ** one or more statically linked extensions that will be available | 
|         |   5266 ** to all new [database connections]. {END} | 
|         |   5267 ** | 
|         |   5268 ** This routine stores a pointer to the extension in an array that is | 
|         |   5269 ** obtained from [sqlite3_malloc()].  If you run a memory leak checker | 
|         |   5270 ** on your program and it reports a leak because of this array, invoke | 
|         |   5271 ** [sqlite3_reset_auto_extension()] prior to shutdown to free the memory. | 
|         |   5272 ** | 
|         |   5273 ** {H12641} This function registers an extension entry point that is | 
|         |   5274 **          automatically invoked whenever a new [database connection] | 
|         |   5275 **          is opened using [sqlite3_open()], [sqlite3_open16()], | 
|         |   5276 **          or [sqlite3_open_v2()]. | 
|         |   5277 ** | 
|         |   5278 ** {H12642} Duplicate extensions are detected so calling this routine | 
|         |   5279 **          multiple times with the same extension is harmless. | 
|         |   5280 ** | 
|         |   5281 ** {H12643} This routine stores a pointer to the extension in an array | 
|         |   5282 **          that is obtained from [sqlite3_malloc()]. | 
|         |   5283 ** | 
|         |   5284 ** {H12644} Automatic extensions apply across all threads. | 
|         |   5285 */ | 
|         |   5286 IMPORT_C int sqlite3_auto_extension(void *xEntryPoint); | 
|         |   5287  | 
|         |   5288 /* | 
|         |   5289 ** CAPI3REF: Reset Automatic Extension Loading {H12660} <S20500> | 
|         |   5290 ** | 
|         |   5291 ** This function disables all previously registered automatic | 
|         |   5292 ** extensions. {END}  It undoes the effect of all prior | 
|         |   5293 ** [sqlite3_auto_extension()] calls. | 
|         |   5294 ** | 
|         |   5295 ** {H12661} This function disables all previously registered | 
|         |   5296 **          automatic extensions. | 
|         |   5297 ** | 
|         |   5298 ** {H12662} This function disables automatic extensions in all threads. | 
|         |   5299 */ | 
|         |   5300 IMPORT_C void sqlite3_reset_auto_extension(void); | 
|         |   5301  | 
|         |   5302 /* | 
|         |   5303 ****** EXPERIMENTAL - subject to change without notice ************** | 
|         |   5304 ** | 
|         |   5305 ** The interface to the virtual-table mechanism is currently considered | 
|         |   5306 ** to be experimental.  The interface might change in incompatible ways. | 
|         |   5307 ** If this is a problem for you, do not use the interface at this time. | 
|         |   5308 ** | 
|         |   5309 ** When the virtual-table mechanism stabilizes, we will declare the | 
|         |   5310 ** interface fixed, support it indefinitely, and remove this comment. | 
|         |   5311 */ | 
|         |   5312  | 
|         |   5313 /* | 
|         |   5314 ** Structures used by the virtual table interface | 
|         |   5315 */ | 
|         |   5316 typedef struct sqlite3_vtab sqlite3_vtab; | 
|         |   5317 typedef struct sqlite3_index_info sqlite3_index_info; | 
|         |   5318 typedef struct sqlite3_vtab_cursor sqlite3_vtab_cursor; | 
|         |   5319 typedef struct sqlite3_module sqlite3_module; | 
|         |   5320  | 
|         |   5321 /* | 
|         |   5322 ** CAPI3REF: Virtual Table Object {H18000} <S20400> | 
|         |   5323 ** KEYWORDS: sqlite3_module | 
|         |   5324 ** EXPERIMENTAL | 
|         |   5325 ** | 
|         |   5326 ** A module is a class of virtual tables.  Each module is defined | 
|         |   5327 ** by an instance of the following structure.  This structure consists | 
|         |   5328 ** mostly of methods for the module. | 
|         |   5329 ** | 
|         |   5330 ** This interface is experimental and is subject to change or | 
|         |   5331 ** removal in future releases of SQLite. | 
|         |   5332 */ | 
|         |   5333 struct sqlite3_module { | 
|         |   5334   int iVersion; | 
|         |   5335   int (*xCreate)(sqlite3*, void *pAux, | 
|         |   5336                int argc, const char *const*argv, | 
|         |   5337                sqlite3_vtab **ppVTab, char**); | 
|         |   5338   int (*xConnect)(sqlite3*, void *pAux, | 
|         |   5339                int argc, const char *const*argv, | 
|         |   5340                sqlite3_vtab **ppVTab, char**); | 
|         |   5341   int (*xBestIndex)(sqlite3_vtab *pVTab, sqlite3_index_info*); | 
|         |   5342   int (*xDisconnect)(sqlite3_vtab *pVTab); | 
|         |   5343   int (*xDestroy)(sqlite3_vtab *pVTab); | 
|         |   5344   int (*xOpen)(sqlite3_vtab *pVTab, sqlite3_vtab_cursor **ppCursor); | 
|         |   5345   int (*xClose)(sqlite3_vtab_cursor*); | 
|         |   5346   int (*xFilter)(sqlite3_vtab_cursor*, int idxNum, const char *idxStr, | 
|         |   5347                 int argc, sqlite3_value **argv); | 
|         |   5348   int (*xNext)(sqlite3_vtab_cursor*); | 
|         |   5349   int (*xEof)(sqlite3_vtab_cursor*); | 
|         |   5350   int (*xColumn)(sqlite3_vtab_cursor*, sqlite3_context*, int); | 
|         |   5351   int (*xRowid)(sqlite3_vtab_cursor*, sqlite3_int64 *pRowid); | 
|         |   5352   int (*xUpdate)(sqlite3_vtab *, int, sqlite3_value **, sqlite3_int64 *); | 
|         |   5353   int (*xBegin)(sqlite3_vtab *pVTab); | 
|         |   5354   int (*xSync)(sqlite3_vtab *pVTab); | 
|         |   5355   int (*xCommit)(sqlite3_vtab *pVTab); | 
|         |   5356   int (*xRollback)(sqlite3_vtab *pVTab); | 
|         |   5357   int (*xFindFunction)(sqlite3_vtab *pVtab, int nArg, const char *zName, | 
|         |   5358                        void (**pxFunc)(sqlite3_context*,int,sqlite3_value**), | 
|         |   5359                        void **ppArg); | 
|         |   5360   int (*xRename)(sqlite3_vtab *pVtab, const char *zNew); | 
|         |   5361 }; | 
|         |   5362  | 
|         |   5363 /* | 
|         |   5364 ** CAPI3REF: Virtual Table Indexing Information {H18100} <S20400> | 
|         |   5365 ** KEYWORDS: sqlite3_index_info | 
|         |   5366 ** EXPERIMENTAL | 
|         |   5367 ** | 
|         |   5368 ** The sqlite3_index_info structure and its substructures is used to | 
|         |   5369 ** pass information into and receive the reply from the xBestIndex | 
|         |   5370 ** method of an sqlite3_module.  The fields under **Inputs** are the | 
|         |   5371 ** inputs to xBestIndex and are read-only.  xBestIndex inserts its | 
|         |   5372 ** results into the **Outputs** fields. | 
|         |   5373 ** | 
|         |   5374 ** The aConstraint[] array records WHERE clause constraints of the form: | 
|         |   5375 ** | 
|         |   5376 ** <pre>column OP expr</pre> | 
|         |   5377 ** | 
|         |   5378 ** where OP is =, <, <=, >, or >=.  The particular operator is | 
|         |   5379 ** stored in aConstraint[].op.  The index of the column is stored in | 
|         |   5380 ** aConstraint[].iColumn.  aConstraint[].usable is TRUE if the | 
|         |   5381 ** expr on the right-hand side can be evaluated (and thus the constraint | 
|         |   5382 ** is usable) and false if it cannot. | 
|         |   5383 ** | 
|         |   5384 ** The optimizer automatically inverts terms of the form "expr OP column" | 
|         |   5385 ** and makes other simplifications to the WHERE clause in an attempt to | 
|         |   5386 ** get as many WHERE clause terms into the form shown above as possible. | 
|         |   5387 ** The aConstraint[] array only reports WHERE clause terms in the correct | 
|         |   5388 ** form that refer to the particular virtual table being queried. | 
|         |   5389 ** | 
|         |   5390 ** Information about the ORDER BY clause is stored in aOrderBy[]. | 
|         |   5391 ** Each term of aOrderBy records a column of the ORDER BY clause. | 
|         |   5392 ** | 
|         |   5393 ** The xBestIndex method must fill aConstraintUsage[] with information | 
|         |   5394 ** about what parameters to pass to xFilter.  If argvIndex>0 then | 
|         |   5395 ** the right-hand side of the corresponding aConstraint[] is evaluated | 
|         |   5396 ** and becomes the argvIndex-th entry in argv.  If aConstraintUsage[].omit | 
|         |   5397 ** is true, then the constraint is assumed to be fully handled by the | 
|         |   5398 ** virtual table and is not checked again by SQLite. | 
|         |   5399 ** | 
|         |   5400 ** The idxNum and idxPtr values are recorded and passed into xFilter. | 
|         |   5401 ** sqlite3_free() is used to free idxPtr if needToFreeIdxPtr is true. | 
|         |   5402 ** | 
|         |   5403 ** The orderByConsumed means that output from xFilter will occur in | 
|         |   5404 ** the correct order to satisfy the ORDER BY clause so that no separate | 
|         |   5405 ** sorting step is required. | 
|         |   5406 ** | 
|         |   5407 ** The estimatedCost value is an estimate of the cost of doing the | 
|         |   5408 ** particular lookup.  A full scan of a table with N entries should have | 
|         |   5409 ** a cost of N.  A binary search of a table of N entries should have a | 
|         |   5410 ** cost of approximately log(N). | 
|         |   5411 ** | 
|         |   5412 ** This interface is experimental and is subject to change or | 
|         |   5413 ** removal in future releases of SQLite. | 
|         |   5414 */ | 
|         |   5415 struct sqlite3_index_info { | 
|         |   5416   /* Inputs */ | 
|         |   5417   int nConstraint;           /* Number of entries in aConstraint */ | 
|         |   5418   struct sqlite3_index_constraint { | 
|         |   5419      int iColumn;              /* Column on left-hand side of constraint */ | 
|         |   5420      unsigned char op;         /* Constraint operator */ | 
|         |   5421      unsigned char usable;     /* True if this constraint is usable */ | 
|         |   5422      int iTermOffset;          /* Used internally - xBestIndex should ignore */ | 
|         |   5423   } *aConstraint;            /* Table of WHERE clause constraints */ | 
|         |   5424   int nOrderBy;              /* Number of terms in the ORDER BY clause */ | 
|         |   5425   struct sqlite3_index_orderby { | 
|         |   5426      int iColumn;              /* Column number */ | 
|         |   5427      unsigned char desc;       /* True for DESC.  False for ASC. */ | 
|         |   5428   } *aOrderBy;               /* The ORDER BY clause */ | 
|         |   5429   /* Outputs */ | 
|         |   5430   struct sqlite3_index_constraint_usage { | 
|         |   5431     int argvIndex;           /* if >0, constraint is part of argv to xFilter */ | 
|         |   5432     unsigned char omit;      /* Do not code a test for this constraint */ | 
|         |   5433   } *aConstraintUsage; | 
|         |   5434   int idxNum;                /* Number used to identify the index */ | 
|         |   5435   char *idxStr;              /* String, possibly obtained from sqlite3_malloc */ | 
|         |   5436   int needToFreeIdxStr;      /* Free idxStr using sqlite3_free() if true */ | 
|         |   5437   int orderByConsumed;       /* True if output is already ordered */ | 
|         |   5438   double estimatedCost;      /* Estimated cost of using this index */ | 
|         |   5439 }; | 
|         |   5440 #define SQLITE_INDEX_CONSTRAINT_EQ    2 | 
|         |   5441 #define SQLITE_INDEX_CONSTRAINT_GT    4 | 
|         |   5442 #define SQLITE_INDEX_CONSTRAINT_LE    8 | 
|         |   5443 #define SQLITE_INDEX_CONSTRAINT_LT    16 | 
|         |   5444 #define SQLITE_INDEX_CONSTRAINT_GE    32 | 
|         |   5445 #define SQLITE_INDEX_CONSTRAINT_MATCH 64 | 
|         |   5446  | 
|         |   5447 /* | 
|         |   5448 ** CAPI3REF: Register A Virtual Table Implementation {H18200} <S20400> | 
|         |   5449 ** EXPERIMENTAL | 
|         |   5450 ** | 
|         |   5451 ** This routine is used to register a new module name with a | 
|         |   5452 ** [database connection].  Module names must be registered before | 
|         |   5453 ** creating new virtual tables on the module, or before using | 
|         |   5454 ** preexisting virtual tables of the module. | 
|         |   5455 ** | 
|         |   5456 ** This interface is experimental and is subject to change or | 
|         |   5457 ** removal in future releases of SQLite. | 
|         |   5458 */ | 
|         |   5459 IMPORT_C int sqlite3_create_module( | 
|         |   5460   sqlite3 *db,               /* SQLite connection to register module with */ | 
|         |   5461   const char *zName,         /* Name of the module */ | 
|         |   5462   const sqlite3_module *,    /* Methods for the module */ | 
|         |   5463   void *                     /* Client data for xCreate/xConnect */ | 
|         |   5464 ); | 
|         |   5465  | 
|         |   5466 /* | 
|         |   5467 ** CAPI3REF: Register A Virtual Table Implementation {H18210} <S20400> | 
|         |   5468 ** EXPERIMENTAL | 
|         |   5469 ** | 
|         |   5470 ** This routine is identical to the [sqlite3_create_module()] method above, | 
|         |   5471 ** except that it allows a destructor function to be specified. It is | 
|         |   5472 ** even more experimental than the rest of the virtual tables API. | 
|         |   5473 */ | 
|         |   5474 IMPORT_C int sqlite3_create_module_v2( | 
|         |   5475   sqlite3 *db,               /* SQLite connection to register module with */ | 
|         |   5476   const char *zName,         /* Name of the module */ | 
|         |   5477   const sqlite3_module *,    /* Methods for the module */ | 
|         |   5478   void *,                    /* Client data for xCreate/xConnect */ | 
|         |   5479   void(*xDestroy)(void*)     /* Module destructor function */ | 
|         |   5480 ); | 
|         |   5481  | 
|         |   5482 /* | 
|         |   5483 ** CAPI3REF: Virtual Table Instance Object {H18010} <S20400> | 
|         |   5484 ** KEYWORDS: sqlite3_vtab | 
|         |   5485 ** EXPERIMENTAL | 
|         |   5486 ** | 
|         |   5487 ** Every module implementation uses a subclass of the following structure | 
|         |   5488 ** to describe a particular instance of the module.  Each subclass will | 
|         |   5489 ** be tailored to the specific needs of the module implementation. | 
|         |   5490 ** The purpose of this superclass is to define certain fields that are | 
|         |   5491 ** common to all module implementations. | 
|         |   5492 ** | 
|         |   5493 ** Virtual tables methods can set an error message by assigning a | 
|         |   5494 ** string obtained from [sqlite3_mprintf()] to zErrMsg.  The method should | 
|         |   5495 ** take care that any prior string is freed by a call to [sqlite3_free()] | 
|         |   5496 ** prior to assigning a new string to zErrMsg.  After the error message | 
|         |   5497 ** is delivered up to the client application, the string will be automatically | 
|         |   5498 ** freed by sqlite3_free() and the zErrMsg field will be zeroed.  Note | 
|         |   5499 ** that sqlite3_mprintf() and sqlite3_free() are used on the zErrMsg field | 
|         |   5500 ** since virtual tables are commonly implemented in loadable extensions which | 
|         |   5501 ** do not have access to sqlite3MPrintf() or sqlite3Free(). | 
|         |   5502 ** | 
|         |   5503 ** This interface is experimental and is subject to change or | 
|         |   5504 ** removal in future releases of SQLite. | 
|         |   5505 */ | 
|         |   5506 struct sqlite3_vtab { | 
|         |   5507   const sqlite3_module *pModule;  /* The module for this virtual table */ | 
|         |   5508   int nRef;                       /* Used internally */ | 
|         |   5509   char *zErrMsg;                  /* Error message from sqlite3_mprintf() */ | 
|         |   5510   /* Virtual table implementations will typically add additional fields */ | 
|         |   5511 }; | 
|         |   5512  | 
|         |   5513 /* | 
|         |   5514 ** CAPI3REF: Virtual Table Cursor Object  {H18020} <S20400> | 
|         |   5515 ** KEYWORDS: sqlite3_vtab_cursor | 
|         |   5516 ** EXPERIMENTAL | 
|         |   5517 ** | 
|         |   5518 ** Every module implementation uses a subclass of the following structure | 
|         |   5519 ** to describe cursors that point into the virtual table and are used | 
|         |   5520 ** to loop through the virtual table.  Cursors are created using the | 
|         |   5521 ** xOpen method of the module.  Each module implementation will define | 
|         |   5522 ** the content of a cursor structure to suit its own needs. | 
|         |   5523 ** | 
|         |   5524 ** This superclass exists in order to define fields of the cursor that | 
|         |   5525 ** are common to all implementations. | 
|         |   5526 ** | 
|         |   5527 ** This interface is experimental and is subject to change or | 
|         |   5528 ** removal in future releases of SQLite. | 
|         |   5529 */ | 
|         |   5530 struct sqlite3_vtab_cursor { | 
|         |   5531   sqlite3_vtab *pVtab;      /* Virtual table of this cursor */ | 
|         |   5532   /* Virtual table implementations will typically add additional fields */ | 
|         |   5533 }; | 
|         |   5534  | 
|         |   5535 /* | 
|         |   5536 ** CAPI3REF: Declare The Schema Of A Virtual Table {H18280} <S20400> | 
|         |   5537 ** EXPERIMENTAL | 
|         |   5538 ** | 
|         |   5539 ** The xCreate and xConnect methods of a module use the following API | 
|         |   5540 ** to declare the format (the names and datatypes of the columns) of | 
|         |   5541 ** the virtual tables they implement. | 
|         |   5542 ** | 
|         |   5543 ** This interface is experimental and is subject to change or | 
|         |   5544 ** removal in future releases of SQLite. | 
|         |   5545 */ | 
|         |   5546 IMPORT_C int sqlite3_declare_vtab(sqlite3*, const char *zCreateTable); | 
|         |   5547  | 
|         |   5548 /* | 
|         |   5549 ** CAPI3REF: Overload A Function For A Virtual Table {H18300} <S20400> | 
|         |   5550 ** EXPERIMENTAL | 
|         |   5551 ** | 
|         |   5552 ** Virtual tables can provide alternative implementations of functions | 
|         |   5553 ** using the xFindFunction method.  But global versions of those functions | 
|         |   5554 ** must exist in order to be overloaded. | 
|         |   5555 ** | 
|         |   5556 ** This API makes sure a global version of a function with a particular | 
|         |   5557 ** name and number of parameters exists.  If no such function exists | 
|         |   5558 ** before this API is called, a new function is created.  The implementation | 
|         |   5559 ** of the new function always causes an exception to be thrown.  So | 
|         |   5560 ** the new function is not good for anything by itself.  Its only | 
|         |   5561 ** purpose is to be a placeholder function that can be overloaded | 
|         |   5562 ** by virtual tables. | 
|         |   5563 ** | 
|         |   5564 ** This API should be considered part of the virtual table interface, | 
|         |   5565 ** which is experimental and subject to change. | 
|         |   5566 */ | 
|         |   5567 IMPORT_C int sqlite3_overload_function(sqlite3*, const char *zFuncName, int nArg); | 
|         |   5568  | 
|         |   5569 /* | 
|         |   5570 ** The interface to the virtual-table mechanism defined above (back up | 
|         |   5571 ** to a comment remarkably similar to this one) is currently considered | 
|         |   5572 ** to be experimental.  The interface might change in incompatible ways. | 
|         |   5573 ** If this is a problem for you, do not use the interface at this time. | 
|         |   5574 ** | 
|         |   5575 ** When the virtual-table mechanism stabilizes, we will declare the | 
|         |   5576 ** interface fixed, support it indefinitely, and remove this comment. | 
|         |   5577 ** | 
|         |   5578 ****** EXPERIMENTAL - subject to change without notice ************** | 
|         |   5579 */ | 
|         |   5580  | 
|         |   5581 /* | 
|         |   5582 ** CAPI3REF: A Handle To An Open BLOB {H17800} <S30230> | 
|         |   5583 ** KEYWORDS: {BLOB handle} {BLOB handles} | 
|         |   5584 ** | 
|         |   5585 ** An instance of this object represents an open BLOB on which | 
|         |   5586 ** [sqlite3_blob_open | incremental BLOB I/O] can be performed. | 
|         |   5587 ** Objects of this type are created by [sqlite3_blob_open()] | 
|         |   5588 ** and destroyed by [sqlite3_blob_close()]. | 
|         |   5589 ** The [sqlite3_blob_read()] and [sqlite3_blob_write()] interfaces | 
|         |   5590 ** can be used to read or write small subsections of the BLOB. | 
|         |   5591 ** The [sqlite3_blob_bytes()] interface returns the size of the BLOB in bytes. | 
|         |   5592 */ | 
|         |   5593 typedef struct sqlite3_blob sqlite3_blob; | 
|         |   5594  | 
|         |   5595 /* | 
|         |   5596 ** CAPI3REF: Open A BLOB For Incremental I/O {H17810} <S30230> | 
|         |   5597 ** | 
|         |   5598 ** This interfaces opens a [BLOB handle | handle] to the BLOB located | 
|         |   5599 ** in row iRow, column zColumn, table zTable in database zDb; | 
|         |   5600 ** in other words, the same BLOB that would be selected by: | 
|         |   5601 ** | 
|         |   5602 ** <pre> | 
|         |   5603 **     SELECT zColumn FROM zDb.zTable WHERE rowid = iRow; | 
|         |   5604 ** </pre> {END} | 
|         |   5605 ** | 
|         |   5606 ** If the flags parameter is non-zero, the the BLOB is opened for read | 
|         |   5607 ** and write access. If it is zero, the BLOB is opened for read access. | 
|         |   5608 ** | 
|         |   5609 ** Note that the database name is not the filename that contains | 
|         |   5610 ** the database but rather the symbolic name of the database that | 
|         |   5611 ** is assigned when the database is connected using [ATTACH]. | 
|         |   5612 ** For the main database file, the database name is "main". | 
|         |   5613 ** For TEMP tables, the database name is "temp". | 
|         |   5614 ** | 
|         |   5615 ** On success, [SQLITE_OK] is returned and the new [BLOB handle] is written | 
|         |   5616 ** to *ppBlob. Otherwise an [error code] is returned and any value written | 
|         |   5617 ** to *ppBlob should not be used by the caller. | 
|         |   5618 ** This function sets the [database connection] error code and message | 
|         |   5619 ** accessible via [sqlite3_errcode()] and [sqlite3_errmsg()]. | 
|         |   5620 ** | 
|         |   5621 ** If the row that a BLOB handle points to is modified by an | 
|         |   5622 ** [UPDATE], [DELETE], or by [ON CONFLICT] side-effects | 
|         |   5623 ** then the BLOB handle is marked as "expired". | 
|         |   5624 ** This is true if any column of the row is changed, even a column | 
|         |   5625 ** other than the one the BLOB handle is open on. | 
|         |   5626 ** Calls to [sqlite3_blob_read()] and [sqlite3_blob_write()] for | 
|         |   5627 ** a expired BLOB handle fail with an return code of [SQLITE_ABORT]. | 
|         |   5628 ** Changes written into a BLOB prior to the BLOB expiring are not | 
|         |   5629 ** rollback by the expiration of the BLOB.  Such changes will eventually | 
|         |   5630 ** commit if the transaction continues to completion. | 
|         |   5631 ** | 
|         |   5632 ** INVARIANTS: | 
|         |   5633 ** | 
|         |   5634 ** {H17813} A successful invocation of the [sqlite3_blob_open(D,B,T,C,R,F,P)] | 
|         |   5635 **          interface shall open an [sqlite3_blob] object P on the BLOB | 
|         |   5636 **          in column C of the table T in the database B on | 
|         |   5637 **          the [database connection] D. | 
|         |   5638 ** | 
|         |   5639 ** {H17814} A successful invocation of [sqlite3_blob_open(D,...)] shall start | 
|         |   5640 **          a new transaction on the [database connection] D if that | 
|         |   5641 **          connection is not already in a transaction. | 
|         |   5642 ** | 
|         |   5643 ** {H17816} The [sqlite3_blob_open(D,B,T,C,R,F,P)] interface shall open | 
|         |   5644 **          the BLOB for read and write access if and only if the F | 
|         |   5645 **          parameter is non-zero. | 
|         |   5646 ** | 
|         |   5647 ** {H17819} The [sqlite3_blob_open()] interface shall return [SQLITE_OK] on | 
|         |   5648 **          success and an appropriate [error code] on failure. | 
|         |   5649 ** | 
|         |   5650 ** {H17821} If an error occurs during evaluation of [sqlite3_blob_open(D,...)] | 
|         |   5651 **          then subsequent calls to [sqlite3_errcode(D)], | 
|         |   5652 **          [sqlite3_errmsg(D)], and [sqlite3_errmsg16(D)] shall return | 
|         |   5653 **          information appropriate for that error. | 
|         |   5654 ** | 
|         |   5655 ** {H17824} If any column in the row that a [sqlite3_blob] has open is | 
|         |   5656 **          changed by a separate [UPDATE] or [DELETE] statement or by | 
|         |   5657 **          an [ON CONFLICT] side effect, then the [sqlite3_blob] shall | 
|         |   5658 **          be marked as invalid. | 
|         |   5659 */ | 
|         |   5660 IMPORT_C int sqlite3_blob_open( | 
|         |   5661   sqlite3*, | 
|         |   5662   const char *zDb, | 
|         |   5663   const char *zTable, | 
|         |   5664   const char *zColumn, | 
|         |   5665   sqlite3_int64 iRow, | 
|         |   5666   int flags, | 
|         |   5667   sqlite3_blob **ppBlob | 
|         |   5668 ); | 
|         |   5669  | 
|         |   5670 /* | 
|         |   5671 ** CAPI3REF: Close A BLOB Handle {H17830} <S30230> | 
|         |   5672 ** | 
|         |   5673 ** Closes an open [BLOB handle]. | 
|         |   5674 ** | 
|         |   5675 ** Closing a BLOB shall cause the current transaction to commit | 
|         |   5676 ** if there are no other BLOBs, no pending prepared statements, and the | 
|         |   5677 ** database connection is in [autocommit mode]. | 
|         |   5678 ** If any writes were made to the BLOB, they might be held in cache | 
|         |   5679 ** until the close operation if they will fit. {END} | 
|         |   5680 ** | 
|         |   5681 ** Closing the BLOB often forces the changes | 
|         |   5682 ** out to disk and so if any I/O errors occur, they will likely occur | 
|         |   5683 ** at the time when the BLOB is closed.  {H17833} Any errors that occur during | 
|         |   5684 ** closing are reported as a non-zero return value. | 
|         |   5685 ** | 
|         |   5686 ** The BLOB is closed unconditionally.  Even if this routine returns | 
|         |   5687 ** an error code, the BLOB is still closed. | 
|         |   5688 ** | 
|         |   5689 ** INVARIANTS: | 
|         |   5690 ** | 
|         |   5691 ** {H17833} The [sqlite3_blob_close(P)] interface closes an [sqlite3_blob] | 
|         |   5692 **          object P previously opened using [sqlite3_blob_open()]. | 
|         |   5693 ** | 
|         |   5694 ** {H17836} Closing an [sqlite3_blob] object using | 
|         |   5695 **          [sqlite3_blob_close()] shall cause the current transaction to | 
|         |   5696 **          commit if there are no other open [sqlite3_blob] objects | 
|         |   5697 **          or [prepared statements] on the same [database connection] and | 
|         |   5698 **          the database connection is in [autocommit mode]. | 
|         |   5699 ** | 
|         |   5700 ** {H17839} The [sqlite3_blob_close(P)] interfaces shall close the | 
|         |   5701 **          [sqlite3_blob] object P unconditionally, even if | 
|         |   5702 **          [sqlite3_blob_close(P)] returns something other than [SQLITE_OK]. | 
|         |   5703 */ | 
|         |   5704 IMPORT_C int sqlite3_blob_close(sqlite3_blob *); | 
|         |   5705  | 
|         |   5706 /* | 
|         |   5707 ** CAPI3REF: Return The Size Of An Open BLOB {H17840} <S30230> | 
|         |   5708 ** | 
|         |   5709 ** Returns the size in bytes of the BLOB accessible via the open | 
|         |   5710 ** []BLOB handle] in its only argument. | 
|         |   5711 ** | 
|         |   5712 ** INVARIANTS: | 
|         |   5713 ** | 
|         |   5714 ** {H17843} The [sqlite3_blob_bytes(P)] interface returns the size | 
|         |   5715 **          in bytes of the BLOB that the [sqlite3_blob] object P | 
|         |   5716 **          refers to. | 
|         |   5717 */ | 
|         |   5718 IMPORT_C int sqlite3_blob_bytes(sqlite3_blob *); | 
|         |   5719  | 
|         |   5720 /* | 
|         |   5721 ** CAPI3REF: Read Data From A BLOB Incrementally {H17850} <S30230> | 
|         |   5722 ** | 
|         |   5723 ** This function is used to read data from an open [BLOB handle] into a | 
|         |   5724 ** caller-supplied buffer. N bytes of data are copied into buffer Z | 
|         |   5725 ** from the open BLOB, starting at offset iOffset. | 
|         |   5726 ** | 
|         |   5727 ** If offset iOffset is less than N bytes from the end of the BLOB, | 
|         |   5728 ** [SQLITE_ERROR] is returned and no data is read.  If N or iOffset is | 
|         |   5729 ** less than zero, [SQLITE_ERROR] is returned and no data is read. | 
|         |   5730 ** | 
|         |   5731 ** An attempt to read from an expired [BLOB handle] fails with an | 
|         |   5732 ** error code of [SQLITE_ABORT]. | 
|         |   5733 ** | 
|         |   5734 ** On success, SQLITE_OK is returned. | 
|         |   5735 ** Otherwise, an [error code] or an [extended error code] is returned. | 
|         |   5736 ** | 
|         |   5737 ** INVARIANTS: | 
|         |   5738 ** | 
|         |   5739 ** {H17853} A successful invocation of [sqlite3_blob_read(P,Z,N,X)]  | 
|         |   5740 **          shall reads N bytes of data out of the BLOB referenced by | 
|         |   5741 **          [BLOB handle] P beginning at offset X and store those bytes | 
|         |   5742 **          into buffer Z. | 
|         |   5743 ** | 
|         |   5744 ** {H17856} In [sqlite3_blob_read(P,Z,N,X)] if the size of the BLOB | 
|         |   5745 **          is less than N+X bytes, then the function shall leave the | 
|         |   5746 **          Z buffer unchanged and return [SQLITE_ERROR]. | 
|         |   5747 ** | 
|         |   5748 ** {H17859} In [sqlite3_blob_read(P,Z,N,X)] if X or N is less than zero | 
|         |   5749 **          then the function shall leave the Z buffer unchanged | 
|         |   5750 **          and return [SQLITE_ERROR]. | 
|         |   5751 ** | 
|         |   5752 ** {H17862} The [sqlite3_blob_read(P,Z,N,X)] interface shall return [SQLITE_OK] | 
|         |   5753 **          if N bytes are successfully read into buffer Z. | 
|         |   5754 ** | 
|         |   5755 ** {H17863} If the [BLOB handle] P is expired and X and N are within bounds | 
|         |   5756 **          then [sqlite3_blob_read(P,Z,N,X)] shall leave the Z buffer | 
|         |   5757 **          unchanged and return [SQLITE_ABORT]. | 
|         |   5758 ** | 
|         |   5759 ** {H17865} If the requested read could not be completed, | 
|         |   5760 **          the [sqlite3_blob_read(P,Z,N,X)] interface shall return an | 
|         |   5761 **          appropriate [error code] or [extended error code]. | 
|         |   5762 ** | 
|         |   5763 ** {H17868} If an error occurs during evaluation of [sqlite3_blob_read(P,...)] | 
|         |   5764 **          then subsequent calls to [sqlite3_errcode(D)], | 
|         |   5765 **          [sqlite3_errmsg(D)], and [sqlite3_errmsg16(D)] shall return | 
|         |   5766 **          information appropriate for that error, where D is the | 
|         |   5767 **          [database connection] that was used to open the [BLOB handle] P. | 
|         |   5768 */ | 
|         |   5769 IMPORT_C int sqlite3_blob_read(sqlite3_blob *, void *Z, int N, int iOffset); | 
|         |   5770  | 
|         |   5771 /* | 
|         |   5772 ** CAPI3REF: Write Data Into A BLOB Incrementally {H17870} <S30230> | 
|         |   5773 ** | 
|         |   5774 ** This function is used to write data into an open [BLOB handle] from a | 
|         |   5775 ** caller-supplied buffer. N bytes of data are copied from the buffer Z | 
|         |   5776 ** into the open BLOB, starting at offset iOffset. | 
|         |   5777 ** | 
|         |   5778 ** If the [BLOB handle] passed as the first argument was not opened for | 
|         |   5779 ** writing (the flags parameter to [sqlite3_blob_open()] was zero), | 
|         |   5780 ** this function returns [SQLITE_READONLY]. | 
|         |   5781 ** | 
|         |   5782 ** This function may only modify the contents of the BLOB; it is | 
|         |   5783 ** not possible to increase the size of a BLOB using this API. | 
|         |   5784 ** If offset iOffset is less than N bytes from the end of the BLOB, | 
|         |   5785 ** [SQLITE_ERROR] is returned and no data is written.  If N is | 
|         |   5786 ** less than zero [SQLITE_ERROR] is returned and no data is written. | 
|         |   5787 ** | 
|         |   5788 ** An attempt to write to an expired [BLOB handle] fails with an | 
|         |   5789 ** error code of [SQLITE_ABORT].  Writes to the BLOB that occurred | 
|         |   5790 ** before the [BLOB handle] expired are not rolled back by the | 
|         |   5791 ** expiration of the handle, though of course those changes might | 
|         |   5792 ** have been overwritten by the statement that expired the BLOB handle | 
|         |   5793 ** or by other independent statements. | 
|         |   5794 ** | 
|         |   5795 ** On success, SQLITE_OK is returned. | 
|         |   5796 ** Otherwise, an  [error code] or an [extended error code] is returned. | 
|         |   5797 ** | 
|         |   5798 ** INVARIANTS: | 
|         |   5799 ** | 
|         |   5800 ** {H17873} A successful invocation of [sqlite3_blob_write(P,Z,N,X)] | 
|         |   5801 **          shall write N bytes of data from buffer Z into the BLOB  | 
|         |   5802 **          referenced by [BLOB handle] P beginning at offset X into | 
|         |   5803 **          the BLOB. | 
|         |   5804 ** | 
|         |   5805 ** {H17874} In the absence of other overridding changes, the changes | 
|         |   5806 **          written to a BLOB by [sqlite3_blob_write()] shall | 
|         |   5807 **          remain in effect after the associated [BLOB handle] expires. | 
|         |   5808 ** | 
|         |   5809 ** {H17875} If the [BLOB handle] P was opened for reading only then | 
|         |   5810 **          an invocation of [sqlite3_blob_write(P,Z,N,X)] shall leave | 
|         |   5811 **          the referenced BLOB unchanged and return [SQLITE_READONLY]. | 
|         |   5812 ** | 
|         |   5813 ** {H17876} If the size of the BLOB referenced by [BLOB handle] P is | 
|         |   5814 **          less than N+X bytes then [sqlite3_blob_write(P,Z,N,X)] shall | 
|         |   5815 **          leave the BLOB unchanged and return [SQLITE_ERROR]. | 
|         |   5816 ** | 
|         |   5817 ** {H17877} If the [BLOB handle] P is expired and X and N are within bounds | 
|         |   5818 **          then [sqlite3_blob_read(P,Z,N,X)] shall leave the BLOB | 
|         |   5819 **          unchanged and return [SQLITE_ABORT]. | 
|         |   5820 ** | 
|         |   5821 ** {H17879} If X or N are less than zero then [sqlite3_blob_write(P,Z,N,X)] | 
|         |   5822 **          shall leave the BLOB referenced by [BLOB handle] P unchanged | 
|         |   5823 **          and return [SQLITE_ERROR]. | 
|         |   5824 ** | 
|         |   5825 ** {H17882} The [sqlite3_blob_write(P,Z,N,X)] interface shall return | 
|         |   5826 **          [SQLITE_OK] if N bytes where successfully written into the BLOB. | 
|         |   5827 ** | 
|         |   5828 ** {H17885} If the requested write could not be completed, | 
|         |   5829 **          the [sqlite3_blob_write(P,Z,N,X)] interface shall return an | 
|         |   5830 **          appropriate [error code] or [extended error code]. | 
|         |   5831 ** | 
|         |   5832 ** {H17888} If an error occurs during evaluation of [sqlite3_blob_write(D,...)] | 
|         |   5833 **          then subsequent calls to [sqlite3_errcode(D)], | 
|         |   5834 **          [sqlite3_errmsg(D)], and [sqlite3_errmsg16(D)] shall return | 
|         |   5835 **          information appropriate for that error. | 
|         |   5836 */ | 
|         |   5837 IMPORT_C int sqlite3_blob_write(sqlite3_blob *, const void *z, int n, int iOffset); | 
|         |   5838  | 
|         |   5839 /* | 
|         |   5840 ** CAPI3REF: Virtual File System Objects {H11200} <S20100> | 
|         |   5841 ** | 
|         |   5842 ** A virtual filesystem (VFS) is an [sqlite3_vfs] object | 
|         |   5843 ** that SQLite uses to interact | 
|         |   5844 ** with the underlying operating system.  Most SQLite builds come with a | 
|         |   5845 ** single default VFS that is appropriate for the host computer. | 
|         |   5846 ** New VFSes can be registered and existing VFSes can be unregistered. | 
|         |   5847 ** The following interfaces are provided. | 
|         |   5848 ** | 
|         |   5849 ** The sqlite3_vfs_find() interface returns a pointer to a VFS given its name. | 
|         |   5850 ** Names are case sensitive. | 
|         |   5851 ** Names are zero-terminated UTF-8 strings. | 
|         |   5852 ** If there is no match, a NULL pointer is returned. | 
|         |   5853 ** If zVfsName is NULL then the default VFS is returned. | 
|         |   5854 ** | 
|         |   5855 ** New VFSes are registered with sqlite3_vfs_register(). | 
|         |   5856 ** Each new VFS becomes the default VFS if the makeDflt flag is set. | 
|         |   5857 ** The same VFS can be registered multiple times without injury. | 
|         |   5858 ** To make an existing VFS into the default VFS, register it again | 
|         |   5859 ** with the makeDflt flag set.  If two different VFSes with the | 
|         |   5860 ** same name are registered, the behavior is undefined.  If a | 
|         |   5861 ** VFS is registered with a name that is NULL or an empty string, | 
|         |   5862 ** then the behavior is undefined. | 
|         |   5863 ** | 
|         |   5864 ** Unregister a VFS with the sqlite3_vfs_unregister() interface. | 
|         |   5865 ** If the default VFS is unregistered, another VFS is chosen as | 
|         |   5866 ** the default.  The choice for the new VFS is arbitrary. | 
|         |   5867 ** | 
|         |   5868 ** INVARIANTS: | 
|         |   5869 ** | 
|         |   5870 ** {H11203} The [sqlite3_vfs_find(N)] interface returns a pointer to the | 
|         |   5871 **          registered [sqlite3_vfs] object whose name exactly matches | 
|         |   5872 **          the zero-terminated UTF-8 string N, or it returns NULL if | 
|         |   5873 **          there is no match. | 
|         |   5874 ** | 
|         |   5875 ** {H11206} If the N parameter to [sqlite3_vfs_find(N)] is NULL then | 
|         |   5876 **          the function returns a pointer to the default [sqlite3_vfs] | 
|         |   5877 **          object if there is one, or NULL if there is no default | 
|         |   5878 **          [sqlite3_vfs] object. | 
|         |   5879 ** | 
|         |   5880 ** {H11209} The [sqlite3_vfs_register(P,F)] interface registers the | 
|         |   5881 **          well-formed [sqlite3_vfs] object P using the name given | 
|         |   5882 **          by the zName field of the object. | 
|         |   5883 ** | 
|         |   5884 ** {H11212} Using the [sqlite3_vfs_register(P,F)] interface to register | 
|         |   5885 **          the same [sqlite3_vfs] object multiple times is a harmless no-op. | 
|         |   5886 ** | 
|         |   5887 ** {H11215} The [sqlite3_vfs_register(P,F)] interface makes the [sqlite3_vfs] | 
|         |   5888 **          object P the default [sqlite3_vfs] object if F is non-zero. | 
|         |   5889 ** | 
|         |   5890 ** {H11218} The [sqlite3_vfs_unregister(P)] interface unregisters the | 
|         |   5891 **          [sqlite3_vfs] object P so that it is no longer returned by | 
|         |   5892 **          subsequent calls to [sqlite3_vfs_find()]. | 
|         |   5893 */ | 
|         |   5894 IMPORT_C sqlite3_vfs *sqlite3_vfs_find(const char *zVfsName); | 
|         |   5895 IMPORT_C int sqlite3_vfs_register(sqlite3_vfs*, int makeDflt); | 
|         |   5896 IMPORT_C int sqlite3_vfs_unregister(sqlite3_vfs*); | 
|         |   5897  | 
|         |   5898 /* | 
|         |   5899 ** CAPI3REF: Mutexes {H17000} <S20000> | 
|         |   5900 ** | 
|         |   5901 ** The SQLite core uses these routines for thread | 
|         |   5902 ** synchronization. Though they are intended for internal | 
|         |   5903 ** use by SQLite, code that links against SQLite is | 
|         |   5904 ** permitted to use any of these routines. | 
|         |   5905 ** | 
|         |   5906 ** The SQLite source code contains multiple implementations | 
|         |   5907 ** of these mutex routines.  An appropriate implementation | 
|         |   5908 ** is selected automatically at compile-time.  The following | 
|         |   5909 ** implementations are available in the SQLite core: | 
|         |   5910 ** | 
|         |   5911 ** <ul> | 
|         |   5912 ** <li>   SQLITE_MUTEX_OS2 | 
|         |   5913 ** <li>   SQLITE_MUTEX_PTHREAD | 
|         |   5914 ** <li>   SQLITE_MUTEX_W32 | 
|         |   5915 ** <li>   SQLITE_MUTEX_NOOP | 
|         |   5916 ** </ul> | 
|         |   5917 ** | 
|         |   5918 ** The SQLITE_MUTEX_NOOP implementation is a set of routines | 
|         |   5919 ** that does no real locking and is appropriate for use in | 
|         |   5920 ** a single-threaded application.  The SQLITE_MUTEX_OS2, | 
|         |   5921 ** SQLITE_MUTEX_PTHREAD, and SQLITE_MUTEX_W32 implementations | 
|         |   5922 ** are appropriate for use on OS/2, Unix, and Windows. | 
|         |   5923 ** | 
|         |   5924 ** If SQLite is compiled with the SQLITE_MUTEX_APPDEF preprocessor | 
|         |   5925 ** macro defined (with "-DSQLITE_MUTEX_APPDEF=1"), then no mutex | 
|         |   5926 ** implementation is included with the library. In this case the | 
|         |   5927 ** application must supply a custom mutex implementation using the | 
|         |   5928 ** [SQLITE_CONFIG_MUTEX] option of the sqlite3_config() function | 
|         |   5929 ** before calling sqlite3_initialize() or any other public sqlite3_ | 
|         |   5930 ** function that calls sqlite3_initialize(). | 
|         |   5931 ** | 
|         |   5932 ** {H17011} The sqlite3_mutex_alloc() routine allocates a new | 
|         |   5933 ** mutex and returns a pointer to it. {H17012} If it returns NULL | 
|         |   5934 ** that means that a mutex could not be allocated. {H17013} SQLite | 
|         |   5935 ** will unwind its stack and return an error. {H17014} The argument | 
|         |   5936 ** to sqlite3_mutex_alloc() is one of these integer constants: | 
|         |   5937 ** | 
|         |   5938 ** <ul> | 
|         |   5939 ** <li>  SQLITE_MUTEX_FAST | 
|         |   5940 ** <li>  SQLITE_MUTEX_RECURSIVE | 
|         |   5941 ** <li>  SQLITE_MUTEX_STATIC_MASTER | 
|         |   5942 ** <li>  SQLITE_MUTEX_STATIC_MEM | 
|         |   5943 ** <li>  SQLITE_MUTEX_STATIC_MEM2 | 
|         |   5944 ** <li>  SQLITE_MUTEX_STATIC_PRNG | 
|         |   5945 ** <li>  SQLITE_MUTEX_STATIC_LRU | 
|         |   5946 ** <li>  SQLITE_MUTEX_STATIC_LRU2 | 
|         |   5947 ** </ul> | 
|         |   5948 ** | 
|         |   5949 ** {H17015} The first two constants cause sqlite3_mutex_alloc() to create | 
|         |   5950 ** a new mutex.  The new mutex is recursive when SQLITE_MUTEX_RECURSIVE | 
|         |   5951 ** is used but not necessarily so when SQLITE_MUTEX_FAST is used. {END} | 
|         |   5952 ** The mutex implementation does not need to make a distinction | 
|         |   5953 ** between SQLITE_MUTEX_RECURSIVE and SQLITE_MUTEX_FAST if it does | 
|         |   5954 ** not want to.  {H17016} But SQLite will only request a recursive mutex in | 
|         |   5955 ** cases where it really needs one.  {END} If a faster non-recursive mutex | 
|         |   5956 ** implementation is available on the host platform, the mutex subsystem | 
|         |   5957 ** might return such a mutex in response to SQLITE_MUTEX_FAST. | 
|         |   5958 ** | 
|         |   5959 ** {H17017} The other allowed parameters to sqlite3_mutex_alloc() each return | 
|         |   5960 ** a pointer to a static preexisting mutex. {END}  Four static mutexes are | 
|         |   5961 ** used by the current version of SQLite.  Future versions of SQLite | 
|         |   5962 ** may add additional static mutexes.  Static mutexes are for internal | 
|         |   5963 ** use by SQLite only.  Applications that use SQLite mutexes should | 
|         |   5964 ** use only the dynamic mutexes returned by SQLITE_MUTEX_FAST or | 
|         |   5965 ** SQLITE_MUTEX_RECURSIVE. | 
|         |   5966 ** | 
|         |   5967 ** {H17018} Note that if one of the dynamic mutex parameters (SQLITE_MUTEX_FAST | 
|         |   5968 ** or SQLITE_MUTEX_RECURSIVE) is used then sqlite3_mutex_alloc() | 
|         |   5969 ** returns a different mutex on every call.  {H17034} But for the static | 
|         |   5970 ** mutex types, the same mutex is returned on every call that has | 
|         |   5971 ** the same type number. | 
|         |   5972 ** | 
|         |   5973 ** {H17019} The sqlite3_mutex_free() routine deallocates a previously | 
|         |   5974 ** allocated dynamic mutex. {H17020} SQLite is careful to deallocate every | 
|         |   5975 ** dynamic mutex that it allocates. {A17021} The dynamic mutexes must not be in | 
|         |   5976 ** use when they are deallocated. {A17022} Attempting to deallocate a static | 
|         |   5977 ** mutex results in undefined behavior. {H17023} SQLite never deallocates | 
|         |   5978 ** a static mutex. {END} | 
|         |   5979 ** | 
|         |   5980 ** The sqlite3_mutex_enter() and sqlite3_mutex_try() routines attempt | 
|         |   5981 ** to enter a mutex. {H17024} If another thread is already within the mutex, | 
|         |   5982 ** sqlite3_mutex_enter() will block and sqlite3_mutex_try() will return | 
|         |   5983 ** SQLITE_BUSY. {H17025}  The sqlite3_mutex_try() interface returns [SQLITE_OK] | 
|         |   5984 ** upon successful entry.  {H17026} Mutexes created using | 
|         |   5985 ** SQLITE_MUTEX_RECURSIVE can be entered multiple times by the same thread. | 
|         |   5986 ** {H17027} In such cases the, | 
|         |   5987 ** mutex must be exited an equal number of times before another thread | 
|         |   5988 ** can enter.  {A17028} If the same thread tries to enter any other | 
|         |   5989 ** kind of mutex more than once, the behavior is undefined. | 
|         |   5990 ** {H17029} SQLite will never exhibit | 
|         |   5991 ** such behavior in its own use of mutexes. | 
|         |   5992 ** | 
|         |   5993 ** Some systems (for example, Windows 95) do not support the operation | 
|         |   5994 ** implemented by sqlite3_mutex_try().  On those systems, sqlite3_mutex_try() | 
|         |   5995 ** will always return SQLITE_BUSY.  {H17030} The SQLite core only ever uses | 
|         |   5996 ** sqlite3_mutex_try() as an optimization so this is acceptable behavior. | 
|         |   5997 ** | 
|         |   5998 ** {H17031} The sqlite3_mutex_leave() routine exits a mutex that was | 
|         |   5999 ** previously entered by the same thread.  {A17032} The behavior | 
|         |   6000 ** is undefined if the mutex is not currently entered by the | 
|         |   6001 ** calling thread or is not currently allocated.  {H17033} SQLite will | 
|         |   6002 ** never do either. {END} | 
|         |   6003 ** | 
|         |   6004 ** If the argument to sqlite3_mutex_enter(), sqlite3_mutex_try(), or | 
|         |   6005 ** sqlite3_mutex_leave() is a NULL pointer, then all three routines | 
|         |   6006 ** behave as no-ops. | 
|         |   6007 ** | 
|         |   6008 ** See also: [sqlite3_mutex_held()] and [sqlite3_mutex_notheld()]. | 
|         |   6009 */ | 
|         |   6010 IMPORT_C sqlite3_mutex *sqlite3_mutex_alloc(int); | 
|         |   6011 IMPORT_C void sqlite3_mutex_free(sqlite3_mutex*); | 
|         |   6012 IMPORT_C void sqlite3_mutex_enter(sqlite3_mutex*); | 
|         |   6013 IMPORT_C int sqlite3_mutex_try(sqlite3_mutex*); | 
|         |   6014 IMPORT_C void sqlite3_mutex_leave(sqlite3_mutex*); | 
|         |   6015  | 
|         |   6016 /* | 
|         |   6017 ** CAPI3REF: Mutex Methods Object {H17120} <S20130> | 
|         |   6018 ** EXPERIMENTAL | 
|         |   6019 ** | 
|         |   6020 ** An instance of this structure defines the low-level routines | 
|         |   6021 ** used to allocate and use mutexes. | 
|         |   6022 ** | 
|         |   6023 ** Usually, the default mutex implementations provided by SQLite are | 
|         |   6024 ** sufficient, however the user has the option of substituting a custom | 
|         |   6025 ** implementation for specialized deployments or systems for which SQLite | 
|         |   6026 ** does not provide a suitable implementation. In this case, the user | 
|         |   6027 ** creates and populates an instance of this structure to pass | 
|         |   6028 ** to sqlite3_config() along with the [SQLITE_CONFIG_MUTEX] option. | 
|         |   6029 ** Additionally, an instance of this structure can be used as an | 
|         |   6030 ** output variable when querying the system for the current mutex | 
|         |   6031 ** implementation, using the [SQLITE_CONFIG_GETMUTEX] option. | 
|         |   6032 ** | 
|         |   6033 ** The xMutexInit method defined by this structure is invoked as | 
|         |   6034 ** part of system initialization by the sqlite3_initialize() function. | 
|         |   6035 ** {H17001} The xMutexInit routine shall be called by SQLite once for each | 
|         |   6036 ** effective call to [sqlite3_initialize()]. | 
|         |   6037 ** | 
|         |   6038 ** The xMutexEnd method defined by this structure is invoked as | 
|         |   6039 ** part of system shutdown by the sqlite3_shutdown() function. The | 
|         |   6040 ** implementation of this method is expected to release all outstanding | 
|         |   6041 ** resources obtained by the mutex methods implementation, especially | 
|         |   6042 ** those obtained by the xMutexInit method. {H17003} The xMutexEnd() | 
|         |   6043 ** interface shall be invoked once for each call to [sqlite3_shutdown()]. | 
|         |   6044 ** | 
|         |   6045 ** The remaining seven methods defined by this structure (xMutexAlloc, | 
|         |   6046 ** xMutexFree, xMutexEnter, xMutexTry, xMutexLeave, xMutexHeld and | 
|         |   6047 ** xMutexNotheld) implement the following interfaces (respectively): | 
|         |   6048 ** | 
|         |   6049 ** <ul> | 
|         |   6050 **   <li>  [sqlite3_mutex_alloc()] </li> | 
|         |   6051 **   <li>  [sqlite3_mutex_free()] </li> | 
|         |   6052 **   <li>  [sqlite3_mutex_enter()] </li> | 
|         |   6053 **   <li>  [sqlite3_mutex_try()] </li> | 
|         |   6054 **   <li>  [sqlite3_mutex_leave()] </li> | 
|         |   6055 **   <li>  [sqlite3_mutex_held()] </li> | 
|         |   6056 **   <li>  [sqlite3_mutex_notheld()] </li> | 
|         |   6057 ** </ul> | 
|         |   6058 ** | 
|         |   6059 ** The only difference is that the public sqlite3_XXX functions enumerated | 
|         |   6060 ** above silently ignore any invocations that pass a NULL pointer instead | 
|         |   6061 ** of a valid mutex handle. The implementations of the methods defined | 
|         |   6062 ** by this structure are not required to handle this case, the results | 
|         |   6063 ** of passing a NULL pointer instead of a valid mutex handle are undefined | 
|         |   6064 ** (i.e. it is acceptable to provide an implementation that segfaults if | 
|         |   6065 ** it is passed a NULL pointer). | 
|         |   6066 */ | 
|         |   6067 typedef struct sqlite3_mutex_methods sqlite3_mutex_methods; | 
|         |   6068 struct sqlite3_mutex_methods { | 
|         |   6069   int (*xMutexInit)(void); | 
|         |   6070   int (*xMutexEnd)(void); | 
|         |   6071   sqlite3_mutex *(*xMutexAlloc)(int); | 
|         |   6072   void (*xMutexFree)(sqlite3_mutex *); | 
|         |   6073   void (*xMutexEnter)(sqlite3_mutex *); | 
|         |   6074   int (*xMutexTry)(sqlite3_mutex *); | 
|         |   6075   void (*xMutexLeave)(sqlite3_mutex *); | 
|         |   6076   int (*xMutexHeld)(sqlite3_mutex *); | 
|         |   6077   int (*xMutexNotheld)(sqlite3_mutex *); | 
|         |   6078 }; | 
|         |   6079  | 
|         |   6080 /* | 
|         |   6081 ** CAPI3REF: Mutex Verification Routines {H17080} <S20130> <S30800> | 
|         |   6082 ** | 
|         |   6083 ** The sqlite3_mutex_held() and sqlite3_mutex_notheld() routines | 
|         |   6084 ** are intended for use inside assert() statements. {H17081} The SQLite core | 
|         |   6085 ** never uses these routines except inside an assert() and applications | 
|         |   6086 ** are advised to follow the lead of the core.  {H17082} The core only | 
|         |   6087 ** provides implementations for these routines when it is compiled | 
|         |   6088 ** with the SQLITE_DEBUG flag.  {A17087} External mutex implementations | 
|         |   6089 ** are only required to provide these routines if SQLITE_DEBUG is | 
|         |   6090 ** defined and if NDEBUG is not defined. | 
|         |   6091 ** | 
|         |   6092 ** {H17083} These routines should return true if the mutex in their argument | 
|         |   6093 ** is held or not held, respectively, by the calling thread. | 
|         |   6094 ** | 
|         |   6095 ** {X17084} The implementation is not required to provided versions of these | 
|         |   6096 ** routines that actually work. If the implementation does not provide working | 
|         |   6097 ** versions of these routines, it should at least provide stubs that always | 
|         |   6098 ** return true so that one does not get spurious assertion failures. | 
|         |   6099 ** | 
|         |   6100 ** {H17085} If the argument to sqlite3_mutex_held() is a NULL pointer then | 
|         |   6101 ** the routine should return 1.  {END} This seems counter-intuitive since | 
|         |   6102 ** clearly the mutex cannot be held if it does not exist.  But the | 
|         |   6103 ** the reason the mutex does not exist is because the build is not | 
|         |   6104 ** using mutexes.  And we do not want the assert() containing the | 
|         |   6105 ** call to sqlite3_mutex_held() to fail, so a non-zero return is | 
|         |   6106 ** the appropriate thing to do.  {H17086} The sqlite3_mutex_notheld() | 
|         |   6107 ** interface should also return 1 when given a NULL pointer. | 
|         |   6108 */ | 
|         |   6109 IMPORT_C int sqlite3_mutex_held(sqlite3_mutex*); | 
|         |   6110 IMPORT_C int sqlite3_mutex_notheld(sqlite3_mutex*); | 
|         |   6111  | 
|         |   6112 /* | 
|         |   6113 ** CAPI3REF: Mutex Types {H17001} <H17000> | 
|         |   6114 ** | 
|         |   6115 ** The [sqlite3_mutex_alloc()] interface takes a single argument | 
|         |   6116 ** which is one of these integer constants. | 
|         |   6117 ** | 
|         |   6118 ** The set of static mutexes may change from one SQLite release to the | 
|         |   6119 ** next.  Applications that override the built-in mutex logic must be | 
|         |   6120 ** prepared to accommodate additional static mutexes. | 
|         |   6121 */ | 
|         |   6122 #define SQLITE_MUTEX_FAST             0 | 
|         |   6123 #define SQLITE_MUTEX_RECURSIVE        1 | 
|         |   6124 #define SQLITE_MUTEX_STATIC_MASTER    2 | 
|         |   6125 #define SQLITE_MUTEX_STATIC_MEM       3  /* sqlite3_malloc() */ | 
|         |   6126 #define SQLITE_MUTEX_STATIC_MEM2      4  /* sqlite3_release_memory() */ | 
|         |   6127 #define SQLITE_MUTEX_STATIC_PRNG      5  /* sqlite3_random() */ | 
|         |   6128 #define SQLITE_MUTEX_STATIC_LRU       6  /* lru page list */ | 
|         |   6129 #define SQLITE_MUTEX_STATIC_LRU2      7  /* lru page list */ | 
|         |   6130  | 
|         |   6131 /* | 
|         |   6132 ** CAPI3REF: Low-Level Control Of Database Files {H11300} <S30800> | 
|         |   6133 ** | 
|         |   6134 ** {H11301} The [sqlite3_file_control()] interface makes a direct call to the | 
|         |   6135 ** xFileControl method for the [sqlite3_io_methods] object associated | 
|         |   6136 ** with a particular database identified by the second argument. {H11302} The | 
|         |   6137 ** name of the database is the name assigned to the database by the | 
|         |   6138 ** <a href="lang_attach.html">ATTACH</a> SQL command that opened the | 
|         |   6139 ** database. {H11303} To control the main database file, use the name "main" | 
|         |   6140 ** or a NULL pointer. {H11304} The third and fourth parameters to this routine | 
|         |   6141 ** are passed directly through to the second and third parameters of | 
|         |   6142 ** the xFileControl method.  {H11305} The return value of the xFileControl | 
|         |   6143 ** method becomes the return value of this routine. | 
|         |   6144 ** | 
|         |   6145 ** {H11306} If the second parameter (zDbName) does not match the name of any | 
|         |   6146 ** open database file, then SQLITE_ERROR is returned. {H11307} This error | 
|         |   6147 ** code is not remembered and will not be recalled by [sqlite3_errcode()] | 
|         |   6148 ** or [sqlite3_errmsg()]. {A11308} The underlying xFileControl method might | 
|         |   6149 ** also return SQLITE_ERROR.  {A11309} There is no way to distinguish between | 
|         |   6150 ** an incorrect zDbName and an SQLITE_ERROR return from the underlying | 
|         |   6151 ** xFileControl method. {END} | 
|         |   6152 ** | 
|         |   6153 ** See also: [SQLITE_FCNTL_LOCKSTATE] | 
|         |   6154 */ | 
|         |   6155 IMPORT_C int sqlite3_file_control(sqlite3*, const char *zDbName, int op, void*); | 
|         |   6156  | 
|         |   6157 /* | 
|         |   6158 ** CAPI3REF: Testing Interface {H11400} <S30800> | 
|         |   6159 ** | 
|         |   6160 ** The sqlite3_test_control() interface is used to read out internal | 
|         |   6161 ** state of SQLite and to inject faults into SQLite for testing | 
|         |   6162 ** purposes.  The first parameter is an operation code that determines | 
|         |   6163 ** the number, meaning, and operation of all subsequent parameters. | 
|         |   6164 ** | 
|         |   6165 ** This interface is not for use by applications.  It exists solely | 
|         |   6166 ** for verifying the correct operation of the SQLite library.  Depending | 
|         |   6167 ** on how the SQLite library is compiled, this interface might not exist. | 
|         |   6168 ** | 
|         |   6169 ** The details of the operation codes, their meanings, the parameters | 
|         |   6170 ** they take, and what they do are all subject to change without notice. | 
|         |   6171 ** Unlike most of the SQLite API, this function is not guaranteed to | 
|         |   6172 ** operate consistently from one release to the next. | 
|         |   6173 */ | 
|         |   6174 IMPORT_C int sqlite3_test_control(int op, ...); | 
|         |   6175  | 
|         |   6176 /* | 
|         |   6177 ** CAPI3REF: Testing Interface Operation Codes {H11410} <H11400> | 
|         |   6178 ** | 
|         |   6179 ** These constants are the valid operation code parameters used | 
|         |   6180 ** as the first argument to [sqlite3_test_control()]. | 
|         |   6181 ** | 
|         |   6182 ** These parameters and their meanings are subject to change | 
|         |   6183 ** without notice.  These values are for testing purposes only. | 
|         |   6184 ** Applications should not use any of these parameters or the | 
|         |   6185 ** [sqlite3_test_control()] interface. | 
|         |   6186 */ | 
|         |   6187 #define SQLITE_TESTCTRL_PRNG_SAVE                5 | 
|         |   6188 #define SQLITE_TESTCTRL_PRNG_RESTORE             6 | 
|         |   6189 #define SQLITE_TESTCTRL_PRNG_RESET               7 | 
|         |   6190 #define SQLITE_TESTCTRL_BITVEC_TEST              8 | 
|         |   6191 #define SQLITE_TESTCTRL_FAULT_INSTALL            9 | 
|         |   6192 #define SQLITE_TESTCTRL_BENIGN_MALLOC_HOOKS     10 | 
|         |   6193  | 
|         |   6194 /* | 
|         |   6195 ** CAPI3REF: SQLite Runtime Status {H17200} <S60200> | 
|         |   6196 ** EXPERIMENTAL | 
|         |   6197 ** | 
|         |   6198 ** This interface is used to retrieve runtime status information | 
|         |   6199 ** about the preformance of SQLite, and optionally to reset various | 
|         |   6200 ** highwater marks.  The first argument is an integer code for | 
|         |   6201 ** the specific parameter to measure.  Recognized integer codes | 
|         |   6202 ** are of the form [SQLITE_STATUS_MEMORY_USED | SQLITE_STATUS_...]. | 
|         |   6203 ** The current value of the parameter is returned into *pCurrent. | 
|         |   6204 ** The highest recorded value is returned in *pHighwater.  If the | 
|         |   6205 ** resetFlag is true, then the highest record value is reset after | 
|         |   6206 ** *pHighwater is written. Some parameters do not record the highest | 
|         |   6207 ** value.  For those parameters | 
|         |   6208 ** nothing is written into *pHighwater and the resetFlag is ignored. | 
|         |   6209 ** Other parameters record only the highwater mark and not the current | 
|         |   6210 ** value.  For these latter parameters nothing is written into *pCurrent. | 
|         |   6211 ** | 
|         |   6212 ** This routine returns SQLITE_OK on success and a non-zero | 
|         |   6213 ** [error code] on failure. | 
|         |   6214 ** | 
|         |   6215 ** This routine is threadsafe but is not atomic.  This routine can | 
|         |   6216 ** called while other threads are running the same or different SQLite | 
|         |   6217 ** interfaces.  However the values returned in *pCurrent and | 
|         |   6218 ** *pHighwater reflect the status of SQLite at different points in time | 
|         |   6219 ** and it is possible that another thread might change the parameter | 
|         |   6220 ** in between the times when *pCurrent and *pHighwater are written. | 
|         |   6221 ** | 
|         |   6222 ** See also: [sqlite3_db_status()] | 
|         |   6223 */ | 
|         |   6224 IMPORT_C int sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetFlag); | 
|         |   6225  | 
|         |   6226 /* | 
|         |   6227 ** CAPI3REF: Database Connection Status {H17201} <S60200> | 
|         |   6228 ** EXPERIMENTAL | 
|         |   6229 ** | 
|         |   6230 ** This interface is used to retrieve runtime status information  | 
|         |   6231 ** about a single [database connection].  The first argument is the | 
|         |   6232 ** database connection object to be interrogated.  The second argument | 
|         |   6233 ** is the parameter to interrogate.  Currently, the only allowed value | 
|         |   6234 ** for the second parameter is [SQLITE_DBSTATUS_LOOKASIDE_USED]. | 
|         |   6235 ** Additional options will likely appear in future releases of SQLite. | 
|         |   6236 ** | 
|         |   6237 ** The current value of the request parameter is written into *pCur | 
|         |   6238 ** and the highest instantaneous value is written into *pHiwtr.  If | 
|         |   6239 ** the resetFlg is true, then the highest instantaneous value is | 
|         |   6240 ** reset back down to the current value. | 
|         |   6241 ** | 
|         |   6242 ** See also: [sqlite3_status()]. | 
|         |   6243 */ | 
|         |   6244 IMPORT_C int sqlite3_db_status(sqlite3*, int op, int *pCur, int *pHiwtr, int resetFlg); | 
|         |   6245  | 
|         |   6246  | 
|         |   6247 int sqlite3_wsd_init(int N, int J); | 
|         |   6248 void *sqlite3_wsd_find(void *K, int L); | 
|         |   6249  | 
|         |   6250 /* | 
|         |   6251 ** CAPI3REF: Status Parameters {H17250} <H17200> | 
|         |   6252 ** EXPERIMENTAL | 
|         |   6253 ** | 
|         |   6254 ** These integer constants designate various run-time status parameters | 
|         |   6255 ** that can be returned by [sqlite3_status()]. | 
|         |   6256 ** | 
|         |   6257 ** <dl> | 
|         |   6258 ** <dt>SQLITE_STATUS_MEMORY_USED</dt> | 
|         |   6259 ** <dd>This parameter is the current amount of memory checked out | 
|         |   6260 ** using [sqlite3_malloc()], either directly or indirectly.  The | 
|         |   6261 ** figure includes calls made to [sqlite3_malloc()] by the application | 
|         |   6262 ** and internal memory usage by the SQLite library.  Scratch memory | 
|         |   6263 ** controlled by [SQLITE_CONFIG_SCRATCH] and auxiliary page-cache | 
|         |   6264 ** memory controlled by [SQLITE_CONFIG_PAGECACHE] is not included in | 
|         |   6265 ** this parameter.  The amount returned is the sum of the allocation | 
|         |   6266 ** sizes as reported by the xSize method in [sqlite3_mem_methods].</dd> | 
|         |   6267 ** | 
|         |   6268 ** <dt>SQLITE_STATUS_MALLOC_SIZE</dt> | 
|         |   6269 ** <dd>This parameter records the largest memory allocation request | 
|         |   6270 ** handed to [sqlite3_malloc()] or [sqlite3_realloc()] (or their | 
|         |   6271 ** internal equivalents).  Only the value returned in the | 
|         |   6272 ** *pHighwater parameter to [sqlite3_status()] is of interest.   | 
|         |   6273 ** The value written into the *pCurrent parameter is undefined.</dd> | 
|         |   6274 ** | 
|         |   6275 ** <dt>SQLITE_STATUS_PAGECACHE_USED</dt> | 
|         |   6276 ** <dd>This parameter returns the number of pages used out of the | 
|         |   6277 ** [pagecache memory allocator] that was configured using  | 
|         |   6278 ** [SQLITE_CONFIG_PAGECACHE].  The | 
|         |   6279 ** value returned is in pages, not in bytes.</dd> | 
|         |   6280 ** | 
|         |   6281 ** <dt>SQLITE_STATUS_PAGECACHE_OVERFLOW</dt> | 
|         |   6282 ** <dd>This parameter returns the number of bytes of page cache | 
|         |   6283 ** allocation which could not be statisfied by the [SQLITE_CONFIG_PAGECACHE] | 
|         |   6284 ** buffer and where forced to overflow to [sqlite3_malloc()].  The | 
|         |   6285 ** returned value includes allocations that overflowed because they | 
|         |   6286 ** where too large (they were larger than the "sz" parameter to | 
|         |   6287 ** [SQLITE_CONFIG_PAGECACHE]) and allocations that overflowed because | 
|         |   6288 ** no space was left in the page cache.</dd> | 
|         |   6289 ** | 
|         |   6290 ** <dt>SQLITE_STATUS_PAGECACHE_SIZE</dt> | 
|         |   6291 ** <dd>This parameter records the largest memory allocation request | 
|         |   6292 ** handed to [pagecache memory allocator].  Only the value returned in the | 
|         |   6293 ** *pHighwater parameter to [sqlite3_status()] is of interest.   | 
|         |   6294 ** The value written into the *pCurrent parameter is undefined.</dd> | 
|         |   6295 ** | 
|         |   6296 ** <dt>SQLITE_STATUS_SCRATCH_USED</dt> | 
|         |   6297 ** <dd>This parameter returns the number of allocations used out of the | 
|         |   6298 ** [scratch memory allocator] configured using | 
|         |   6299 ** [SQLITE_CONFIG_SCRATCH].  The value returned is in allocations, not | 
|         |   6300 ** in bytes.  Since a single thread may only have one scratch allocation | 
|         |   6301 ** outstanding at time, this parameter also reports the number of threads | 
|         |   6302 ** using scratch memory at the same time.</dd> | 
|         |   6303 ** | 
|         |   6304 ** <dt>SQLITE_STATUS_SCRATCH_OVERFLOW</dt> | 
|         |   6305 ** <dd>This parameter returns the number of bytes of scratch memory | 
|         |   6306 ** allocation which could not be statisfied by the [SQLITE_CONFIG_SCRATCH] | 
|         |   6307 ** buffer and where forced to overflow to [sqlite3_malloc()].  The values | 
|         |   6308 ** returned include overflows because the requested allocation was too | 
|         |   6309 ** larger (that is, because the requested allocation was larger than the | 
|         |   6310 ** "sz" parameter to [SQLITE_CONFIG_SCRATCH]) and because no scratch buffer | 
|         |   6311 ** slots were available. | 
|         |   6312 ** </dd> | 
|         |   6313 ** | 
|         |   6314 ** <dt>SQLITE_STATUS_SCRATCH_SIZE</dt> | 
|         |   6315 ** <dd>This parameter records the largest memory allocation request | 
|         |   6316 ** handed to [scratch memory allocator].  Only the value returned in the | 
|         |   6317 ** *pHighwater parameter to [sqlite3_status()] is of interest.   | 
|         |   6318 ** The value written into the *pCurrent parameter is undefined.</dd> | 
|         |   6319 ** | 
|         |   6320 ** <dt>SQLITE_STATUS_PARSER_STACK</dt> | 
|         |   6321 ** <dd>This parameter records the deepest parser stack.  It is only | 
|         |   6322 ** meaningful if SQLite is compiled with [YYTRACKMAXSTACKDEPTH].</dd> | 
|         |   6323 ** </dl> | 
|         |   6324 ** | 
|         |   6325 ** New status parameters may be added from time to time. | 
|         |   6326 */ | 
|         |   6327 #define SQLITE_STATUS_MEMORY_USED          0 | 
|         |   6328 #define SQLITE_STATUS_PAGECACHE_USED       1 | 
|         |   6329 #define SQLITE_STATUS_PAGECACHE_OVERFLOW   2 | 
|         |   6330 #define SQLITE_STATUS_SCRATCH_USED         3 | 
|         |   6331 #define SQLITE_STATUS_SCRATCH_OVERFLOW     4 | 
|         |   6332 #define SQLITE_STATUS_MALLOC_SIZE          5 | 
|         |   6333 #define SQLITE_STATUS_PARSER_STACK         6 | 
|         |   6334 #define SQLITE_STATUS_PAGECACHE_SIZE       7 | 
|         |   6335 #define SQLITE_STATUS_SCRATCH_SIZE         8 | 
|         |   6336  | 
|         |   6337 /* | 
|         |   6338 ** CAPI3REF: Status Parameters for database connections {H17275} <H17200> | 
|         |   6339 ** EXPERIMENTAL | 
|         |   6340 ** | 
|         |   6341 ** Status verbs for [sqlite3_db_status()]. | 
|         |   6342 ** | 
|         |   6343 ** <dl> | 
|         |   6344 ** <dt>SQLITE_DBSTATUS_LOOKASIDE_USED</dt> | 
|         |   6345 ** <dd>This parameter returns the number of lookaside memory slots currently | 
|         |   6346 ** checked out.</dd> | 
|         |   6347 ** </dl> | 
|         |   6348 */ | 
|         |   6349 #define SQLITE_DBSTATUS_LOOKASIDE_USED     0 | 
|         |   6350  | 
|         |   6351 /* | 
|         |   6352 ** Undo the hack that converts floating point types to integer for | 
|         |   6353 ** builds on processors without floating point support. | 
|         |   6354 */ | 
|         |   6355 #ifdef SQLITE_OMIT_FLOATING_POINT | 
|         |   6356 # undef double | 
|         |   6357 #endif | 
|         |   6358  | 
|         |   6359 #ifdef __cplusplus | 
|         |   6360 }  /* End of the 'extern "C"' block */ | 
|         |   6361 #endif | 
|         |   6362 #endif |