amalgalite 1.9.1-x64-mingw-ucrt → 1.9.4-x64-mingw-ucrt

Sign up to get free protection for your applications and to get access to all the features.
@@ -146,9 +146,9 @@ extern "C" {
146
146
  ** [sqlite3_libversion_number()], [sqlite3_sourceid()],
147
147
  ** [sqlite_version()] and [sqlite_source_id()].
148
148
  */
149
- #define SQLITE_VERSION "3.41.2"
150
- #define SQLITE_VERSION_NUMBER 3041002
151
- #define SQLITE_SOURCE_ID "2023-03-22 11:56:21 0d1fc92f94cb6b76bffe3ec34d69cffde2924203304e8ffc4155597af0c191da"
149
+ #define SQLITE_VERSION "3.45.1"
150
+ #define SQLITE_VERSION_NUMBER 3045001
151
+ #define SQLITE_SOURCE_ID "2024-01-30 16:01:20 e876e51a0ed5c5b3126f52e532044363a014bc594cfefa87ffb5b82257cc467a"
152
152
 
153
153
  /*
154
154
  ** CAPI3REF: Run-Time Library Version Numbers
@@ -528,6 +528,7 @@ SQLITE_API int sqlite3_exec(
528
528
  #define SQLITE_IOERR_ROLLBACK_ATOMIC (SQLITE_IOERR | (31<<8))
529
529
  #define SQLITE_IOERR_DATA (SQLITE_IOERR | (32<<8))
530
530
  #define SQLITE_IOERR_CORRUPTFS (SQLITE_IOERR | (33<<8))
531
+ #define SQLITE_IOERR_IN_PAGE (SQLITE_IOERR | (34<<8))
531
532
  #define SQLITE_LOCKED_SHAREDCACHE (SQLITE_LOCKED | (1<<8))
532
533
  #define SQLITE_LOCKED_VTAB (SQLITE_LOCKED | (2<<8))
533
534
  #define SQLITE_BUSY_RECOVERY (SQLITE_BUSY | (1<<8))
@@ -1190,7 +1191,7 @@ struct sqlite3_io_methods {
1190
1191
  ** by clients within the current process, only within other processes.
1191
1192
  **
1192
1193
  ** <li>[[SQLITE_FCNTL_CKSM_FILE]]
1193
- ** The [SQLITE_FCNTL_CKSM_FILE] opcode is for use interally by the
1194
+ ** The [SQLITE_FCNTL_CKSM_FILE] opcode is for use internally by the
1194
1195
  ** [checksum VFS shim] only.
1195
1196
  **
1196
1197
  ** <li>[[SQLITE_FCNTL_RESET_CACHE]]
@@ -1655,20 +1656,23 @@ SQLITE_API int sqlite3_os_end(void);
1655
1656
  ** must ensure that no other SQLite interfaces are invoked by other
1656
1657
  ** threads while sqlite3_config() is running.</b>
1657
1658
  **
1658
- ** The sqlite3_config() interface
1659
- ** may only be invoked prior to library initialization using
1660
- ** [sqlite3_initialize()] or after shutdown by [sqlite3_shutdown()].
1661
- ** ^If sqlite3_config() is called after [sqlite3_initialize()] and before
1662
- ** [sqlite3_shutdown()] then it will return SQLITE_MISUSE.
1663
- ** Note, however, that ^sqlite3_config() can be called as part of the
1664
- ** implementation of an application-defined [sqlite3_os_init()].
1665
- **
1666
1659
  ** The first argument to sqlite3_config() is an integer
1667
1660
  ** [configuration option] that determines
1668
1661
  ** what property of SQLite is to be configured. Subsequent arguments
1669
1662
  ** vary depending on the [configuration option]
1670
1663
  ** in the first argument.
1671
1664
  **
1665
+ ** For most configuration options, the sqlite3_config() interface
1666
+ ** may only be invoked prior to library initialization using
1667
+ ** [sqlite3_initialize()] or after shutdown by [sqlite3_shutdown()].
1668
+ ** The exceptional configuration options that may be invoked at any time
1669
+ ** are called "anytime configuration options".
1670
+ ** ^If sqlite3_config() is called after [sqlite3_initialize()] and before
1671
+ ** [sqlite3_shutdown()] with a first argument that is not an anytime
1672
+ ** configuration option, then the sqlite3_config() call will return SQLITE_MISUSE.
1673
+ ** Note, however, that ^sqlite3_config() can be called as part of the
1674
+ ** implementation of an application-defined [sqlite3_os_init()].
1675
+ **
1672
1676
  ** ^When a configuration option is set, sqlite3_config() returns [SQLITE_OK].
1673
1677
  ** ^If the option is unknown or SQLite is unable to set the option
1674
1678
  ** then this routine returns a non-zero [error code].
@@ -1776,6 +1780,23 @@ struct sqlite3_mem_methods {
1776
1780
  ** These constants are the available integer configuration options that
1777
1781
  ** can be passed as the first argument to the [sqlite3_config()] interface.
1778
1782
  **
1783
+ ** Most of the configuration options for sqlite3_config()
1784
+ ** will only work if invoked prior to [sqlite3_initialize()] or after
1785
+ ** [sqlite3_shutdown()]. The few exceptions to this rule are called
1786
+ ** "anytime configuration options".
1787
+ ** ^Calling [sqlite3_config()] with a first argument that is not an
1788
+ ** anytime configuration option in between calls to [sqlite3_initialize()] and
1789
+ ** [sqlite3_shutdown()] is a no-op that returns SQLITE_MISUSE.
1790
+ **
1791
+ ** The set of anytime configuration options can change (by insertions
1792
+ ** and/or deletions) from one release of SQLite to the next.
1793
+ ** As of SQLite version 3.42.0, the complete set of anytime configuration
1794
+ ** options is:
1795
+ ** <ul>
1796
+ ** <li> SQLITE_CONFIG_LOG
1797
+ ** <li> SQLITE_CONFIG_PCACHE_HDRSZ
1798
+ ** </ul>
1799
+ **
1779
1800
  ** New configuration options may be added in future releases of SQLite.
1780
1801
  ** Existing configuration options might be discontinued. Applications
1781
1802
  ** should check the return code from [sqlite3_config()] to make sure that
@@ -2106,7 +2127,7 @@ struct sqlite3_mem_methods {
2106
2127
  ** is stored in each sorted record and the required column values loaded
2107
2128
  ** from the database as records are returned in sorted order. The default
2108
2129
  ** value for this option is to never use this optimization. Specifying a
2109
- ** negative value for this option restores the default behaviour.
2130
+ ** negative value for this option restores the default behavior.
2110
2131
  ** This option is only available if SQLite is compiled with the
2111
2132
  ** [SQLITE_ENABLE_SORTER_REFERENCES] compile-time option.
2112
2133
  **
@@ -2122,28 +2143,28 @@ struct sqlite3_mem_methods {
2122
2143
  ** compile-time option is not set, then the default maximum is 1073741824.
2123
2144
  ** </dl>
2124
2145
  */
2125
- #define SQLITE_CONFIG_SINGLETHREAD 1 /* nil */
2126
- #define SQLITE_CONFIG_MULTITHREAD 2 /* nil */
2127
- #define SQLITE_CONFIG_SERIALIZED 3 /* nil */
2128
- #define SQLITE_CONFIG_MALLOC 4 /* sqlite3_mem_methods* */
2129
- #define SQLITE_CONFIG_GETMALLOC 5 /* sqlite3_mem_methods* */
2130
- #define SQLITE_CONFIG_SCRATCH 6 /* No longer used */
2131
- #define SQLITE_CONFIG_PAGECACHE 7 /* void*, int sz, int N */
2132
- #define SQLITE_CONFIG_HEAP 8 /* void*, int nByte, int min */
2133
- #define SQLITE_CONFIG_MEMSTATUS 9 /* boolean */
2134
- #define SQLITE_CONFIG_MUTEX 10 /* sqlite3_mutex_methods* */
2135
- #define SQLITE_CONFIG_GETMUTEX 11 /* sqlite3_mutex_methods* */
2136
- /* previously SQLITE_CONFIG_CHUNKALLOC 12 which is now unused. */
2137
- #define SQLITE_CONFIG_LOOKASIDE 13 /* int int */
2138
- #define SQLITE_CONFIG_PCACHE 14 /* no-op */
2139
- #define SQLITE_CONFIG_GETPCACHE 15 /* no-op */
2140
- #define SQLITE_CONFIG_LOG 16 /* xFunc, void* */
2141
- #define SQLITE_CONFIG_URI 17 /* int */
2142
- #define SQLITE_CONFIG_PCACHE2 18 /* sqlite3_pcache_methods2* */
2143
- #define SQLITE_CONFIG_GETPCACHE2 19 /* sqlite3_pcache_methods2* */
2146
+ #define SQLITE_CONFIG_SINGLETHREAD 1 /* nil */
2147
+ #define SQLITE_CONFIG_MULTITHREAD 2 /* nil */
2148
+ #define SQLITE_CONFIG_SERIALIZED 3 /* nil */
2149
+ #define SQLITE_CONFIG_MALLOC 4 /* sqlite3_mem_methods* */
2150
+ #define SQLITE_CONFIG_GETMALLOC 5 /* sqlite3_mem_methods* */
2151
+ #define SQLITE_CONFIG_SCRATCH 6 /* No longer used */
2152
+ #define SQLITE_CONFIG_PAGECACHE 7 /* void*, int sz, int N */
2153
+ #define SQLITE_CONFIG_HEAP 8 /* void*, int nByte, int min */
2154
+ #define SQLITE_CONFIG_MEMSTATUS 9 /* boolean */
2155
+ #define SQLITE_CONFIG_MUTEX 10 /* sqlite3_mutex_methods* */
2156
+ #define SQLITE_CONFIG_GETMUTEX 11 /* sqlite3_mutex_methods* */
2157
+ /* previously SQLITE_CONFIG_CHUNKALLOC 12 which is now unused. */
2158
+ #define SQLITE_CONFIG_LOOKASIDE 13 /* int int */
2159
+ #define SQLITE_CONFIG_PCACHE 14 /* no-op */
2160
+ #define SQLITE_CONFIG_GETPCACHE 15 /* no-op */
2161
+ #define SQLITE_CONFIG_LOG 16 /* xFunc, void* */
2162
+ #define SQLITE_CONFIG_URI 17 /* int */
2163
+ #define SQLITE_CONFIG_PCACHE2 18 /* sqlite3_pcache_methods2* */
2164
+ #define SQLITE_CONFIG_GETPCACHE2 19 /* sqlite3_pcache_methods2* */
2144
2165
  #define SQLITE_CONFIG_COVERING_INDEX_SCAN 20 /* int */
2145
- #define SQLITE_CONFIG_SQLLOG 21 /* xSqllog, void* */
2146
- #define SQLITE_CONFIG_MMAP_SIZE 22 /* sqlite3_int64, sqlite3_int64 */
2166
+ #define SQLITE_CONFIG_SQLLOG 21 /* xSqllog, void* */
2167
+ #define SQLITE_CONFIG_MMAP_SIZE 22 /* sqlite3_int64, sqlite3_int64 */
2147
2168
  #define SQLITE_CONFIG_WIN32_HEAPSIZE 23 /* int nByte */
2148
2169
  #define SQLITE_CONFIG_PCACHE_HDRSZ 24 /* int *psz */
2149
2170
  #define SQLITE_CONFIG_PMASZ 25 /* unsigned int szPma */
@@ -2281,7 +2302,7 @@ struct sqlite3_mem_methods {
2281
2302
  ** database handle, SQLite checks if this will mean that there are now no
2282
2303
  ** connections at all to the database. If so, it performs a checkpoint
2283
2304
  ** operation before closing the connection. This option may be used to
2284
- ** override this behaviour. The first parameter passed to this operation
2305
+ ** override this behavior. The first parameter passed to this operation
2285
2306
  ** is an integer - positive to disable checkpoints-on-close, or zero (the
2286
2307
  ** default) to enable them, and negative to leave the setting unchanged.
2287
2308
  ** The second parameter is a pointer to an integer
@@ -2378,7 +2399,7 @@ struct sqlite3_mem_methods {
2378
2399
  ** </dd>
2379
2400
  **
2380
2401
  ** [[SQLITE_DBCONFIG_DQS_DML]]
2381
- ** <dt>SQLITE_DBCONFIG_DQS_DML</td>
2402
+ ** <dt>SQLITE_DBCONFIG_DQS_DML</dt>
2382
2403
  ** <dd>The SQLITE_DBCONFIG_DQS_DML option activates or deactivates
2383
2404
  ** the legacy [double-quoted string literal] misfeature for DML statements
2384
2405
  ** only, that is DELETE, INSERT, SELECT, and UPDATE statements. The
@@ -2387,7 +2408,7 @@ struct sqlite3_mem_methods {
2387
2408
  ** </dd>
2388
2409
  **
2389
2410
  ** [[SQLITE_DBCONFIG_DQS_DDL]]
2390
- ** <dt>SQLITE_DBCONFIG_DQS_DDL</td>
2411
+ ** <dt>SQLITE_DBCONFIG_DQS_DDL</dt>
2391
2412
  ** <dd>The SQLITE_DBCONFIG_DQS option activates or deactivates
2392
2413
  ** the legacy [double-quoted string literal] misfeature for DDL statements,
2393
2414
  ** such as CREATE TABLE and CREATE INDEX. The
@@ -2396,7 +2417,7 @@ struct sqlite3_mem_methods {
2396
2417
  ** </dd>
2397
2418
  **
2398
2419
  ** [[SQLITE_DBCONFIG_TRUSTED_SCHEMA]]
2399
- ** <dt>SQLITE_DBCONFIG_TRUSTED_SCHEMA</td>
2420
+ ** <dt>SQLITE_DBCONFIG_TRUSTED_SCHEMA</dt>
2400
2421
  ** <dd>The SQLITE_DBCONFIG_TRUSTED_SCHEMA option tells SQLite to
2401
2422
  ** assume that database schemas are untainted by malicious content.
2402
2423
  ** When the SQLITE_DBCONFIG_TRUSTED_SCHEMA option is disabled, SQLite
@@ -2416,7 +2437,7 @@ struct sqlite3_mem_methods {
2416
2437
  ** </dd>
2417
2438
  **
2418
2439
  ** [[SQLITE_DBCONFIG_LEGACY_FILE_FORMAT]]
2419
- ** <dt>SQLITE_DBCONFIG_LEGACY_FILE_FORMAT</td>
2440
+ ** <dt>SQLITE_DBCONFIG_LEGACY_FILE_FORMAT</dt>
2420
2441
  ** <dd>The SQLITE_DBCONFIG_LEGACY_FILE_FORMAT option activates or deactivates
2421
2442
  ** the legacy file format flag. When activated, this flag causes all newly
2422
2443
  ** created database file to have a schema format version number (the 4-byte
@@ -2425,7 +2446,7 @@ struct sqlite3_mem_methods {
2425
2446
  ** any SQLite version back to 3.0.0 ([dateof:3.0.0]). Without this setting,
2426
2447
  ** newly created databases are generally not understandable by SQLite versions
2427
2448
  ** prior to 3.3.0 ([dateof:3.3.0]). As these words are written, there
2428
- ** is now scarcely any need to generated database files that are compatible
2449
+ ** is now scarcely any need to generate database files that are compatible
2429
2450
  ** all the way back to version 3.0.0, and so this setting is of little
2430
2451
  ** practical use, but is provided so that SQLite can continue to claim the
2431
2452
  ** ability to generate new database files that are compatible with version
@@ -2434,8 +2455,40 @@ struct sqlite3_mem_methods {
2434
2455
  ** the [VACUUM] command will fail with an obscure error when attempting to
2435
2456
  ** process a table with generated columns and a descending index. This is
2436
2457
  ** not considered a bug since SQLite versions 3.3.0 and earlier do not support
2437
- ** either generated columns or decending indexes.
2458
+ ** either generated columns or descending indexes.
2459
+ ** </dd>
2460
+ **
2461
+ ** [[SQLITE_DBCONFIG_STMT_SCANSTATUS]]
2462
+ ** <dt>SQLITE_DBCONFIG_STMT_SCANSTATUS</dt>
2463
+ ** <dd>The SQLITE_DBCONFIG_STMT_SCANSTATUS option is only useful in
2464
+ ** SQLITE_ENABLE_STMT_SCANSTATUS builds. In this case, it sets or clears
2465
+ ** a flag that enables collection of the sqlite3_stmt_scanstatus_v2()
2466
+ ** statistics. For statistics to be collected, the flag must be set on
2467
+ ** the database handle both when the SQL statement is prepared and when it
2468
+ ** is stepped. The flag is set (collection of statistics is enabled)
2469
+ ** by default. This option takes two arguments: an integer and a pointer to
2470
+ ** an integer.. The first argument is 1, 0, or -1 to enable, disable, or
2471
+ ** leave unchanged the statement scanstatus option. If the second argument
2472
+ ** is not NULL, then the value of the statement scanstatus setting after
2473
+ ** processing the first argument is written into the integer that the second
2474
+ ** argument points to.
2475
+ ** </dd>
2476
+ **
2477
+ ** [[SQLITE_DBCONFIG_REVERSE_SCANORDER]]
2478
+ ** <dt>SQLITE_DBCONFIG_REVERSE_SCANORDER</dt>
2479
+ ** <dd>The SQLITE_DBCONFIG_REVERSE_SCANORDER option changes the default order
2480
+ ** in which tables and indexes are scanned so that the scans start at the end
2481
+ ** and work toward the beginning rather than starting at the beginning and
2482
+ ** working toward the end. Setting SQLITE_DBCONFIG_REVERSE_SCANORDER is the
2483
+ ** same as setting [PRAGMA reverse_unordered_selects]. This option takes
2484
+ ** two arguments which are an integer and a pointer to an integer. The first
2485
+ ** argument is 1, 0, or -1 to enable, disable, or leave unchanged the
2486
+ ** reverse scan order flag, respectively. If the second argument is not NULL,
2487
+ ** then 0 or 1 is written into the integer that the second argument points to
2488
+ ** depending on if the reverse scan order flag is set after processing the
2489
+ ** first argument.
2438
2490
  ** </dd>
2491
+ **
2439
2492
  ** </dl>
2440
2493
  */
2441
2494
  #define SQLITE_DBCONFIG_MAINDBNAME 1000 /* const char* */
@@ -2456,7 +2509,9 @@ struct sqlite3_mem_methods {
2456
2509
  #define SQLITE_DBCONFIG_ENABLE_VIEW 1015 /* int int* */
2457
2510
  #define SQLITE_DBCONFIG_LEGACY_FILE_FORMAT 1016 /* int int* */
2458
2511
  #define SQLITE_DBCONFIG_TRUSTED_SCHEMA 1017 /* int int* */
2459
- #define SQLITE_DBCONFIG_MAX 1017 /* Largest DBCONFIG */
2512
+ #define SQLITE_DBCONFIG_STMT_SCANSTATUS 1018 /* int int* */
2513
+ #define SQLITE_DBCONFIG_REVERSE_SCANORDER 1019 /* int int* */
2514
+ #define SQLITE_DBCONFIG_MAX 1019 /* Largest DBCONFIG */
2460
2515
 
2461
2516
  /*
2462
2517
  ** CAPI3REF: Enable Or Disable Extended Result Codes
@@ -2681,6 +2736,7 @@ SQLITE_API sqlite3_int64 sqlite3_total_changes64(sqlite3*);
2681
2736
  **
2682
2737
  ** ^The [sqlite3_is_interrupted(D)] interface can be used to determine whether
2683
2738
  ** or not an interrupt is currently in effect for [database connection] D.
2739
+ ** It returns 1 if an interrupt is currently in effect, or 0 otherwise.
2684
2740
  */
2685
2741
  SQLITE_API void sqlite3_interrupt(sqlite3*);
2686
2742
  SQLITE_API int sqlite3_is_interrupted(sqlite3*);
@@ -3334,8 +3390,10 @@ SQLITE_API SQLITE_DEPRECATED void *sqlite3_profile(sqlite3*,
3334
3390
  ** M argument should be the bitwise OR-ed combination of
3335
3391
  ** zero or more [SQLITE_TRACE] constants.
3336
3392
  **
3337
- ** ^Each call to either sqlite3_trace() or sqlite3_trace_v2() overrides
3338
- ** (cancels) any prior calls to sqlite3_trace() or sqlite3_trace_v2().
3393
+ ** ^Each call to either sqlite3_trace(D,X,P) or sqlite3_trace_v2(D,M,X,P)
3394
+ ** overrides (cancels) all prior calls to sqlite3_trace(D,X,P) or
3395
+ ** sqlite3_trace_v2(D,M,X,P) for the [database connection] D. Each
3396
+ ** database connection may have at most one trace callback.
3339
3397
  **
3340
3398
  ** ^The X callback is invoked whenever any of the events identified by
3341
3399
  ** mask M occur. ^The integer return value from the callback is currently
@@ -3704,7 +3762,7 @@ SQLITE_API int sqlite3_open_v2(
3704
3762
  ** as F) must be one of:
3705
3763
  ** <ul>
3706
3764
  ** <li> A database filename pointer created by the SQLite core and
3707
- ** passed into the xOpen() method of a VFS implemention, or
3765
+ ** passed into the xOpen() method of a VFS implementation, or
3708
3766
  ** <li> A filename obtained from [sqlite3_db_filename()], or
3709
3767
  ** <li> A new filename constructed using [sqlite3_create_filename()].
3710
3768
  ** </ul>
@@ -3817,7 +3875,7 @@ SQLITE_API sqlite3_file *sqlite3_database_file_object(const char*);
3817
3875
  /*
3818
3876
  ** CAPI3REF: Create and Destroy VFS Filenames
3819
3877
  **
3820
- ** These interfces are provided for use by [VFS shim] implementations and
3878
+ ** These interfaces are provided for use by [VFS shim] implementations and
3821
3879
  ** are not useful outside of that context.
3822
3880
  **
3823
3881
  ** The sqlite3_create_filename(D,J,W,N,P) allocates memory to hold a version of
@@ -3896,14 +3954,17 @@ SQLITE_API void sqlite3_free_filename(sqlite3_filename);
3896
3954
  ** </ul>
3897
3955
  **
3898
3956
  ** ^The sqlite3_errmsg() and sqlite3_errmsg16() return English-language
3899
- ** text that describes the error, as either UTF-8 or UTF-16 respectively.
3957
+ ** text that describes the error, as either UTF-8 or UTF-16 respectively,
3958
+ ** or NULL if no error message is available.
3959
+ ** (See how SQLite handles [invalid UTF] for exceptions to this rule.)
3900
3960
  ** ^(Memory to hold the error message string is managed internally.
3901
3961
  ** The application does not need to worry about freeing the result.
3902
3962
  ** However, the error string might be overwritten or deallocated by
3903
3963
  ** subsequent calls to other SQLite interface functions.)^
3904
3964
  **
3905
- ** ^The sqlite3_errstr() interface returns the English-language text
3906
- ** that describes the [result code], as UTF-8.
3965
+ ** ^The sqlite3_errstr(E) interface returns the English-language text
3966
+ ** that describes the [result code] E, as UTF-8, or NULL if E is not an
3967
+ ** result code for which a text error message is available.
3907
3968
  ** ^(Memory to hold the error message string is managed internally
3908
3969
  ** and must not be freed by the application)^.
3909
3970
  **
@@ -4364,6 +4425,41 @@ SQLITE_API int sqlite3_stmt_readonly(sqlite3_stmt *pStmt);
4364
4425
  */
4365
4426
  SQLITE_API int sqlite3_stmt_isexplain(sqlite3_stmt *pStmt);
4366
4427
 
4428
+ /*
4429
+ ** CAPI3REF: Change The EXPLAIN Setting For A Prepared Statement
4430
+ ** METHOD: sqlite3_stmt
4431
+ **
4432
+ ** The sqlite3_stmt_explain(S,E) interface changes the EXPLAIN
4433
+ ** setting for [prepared statement] S. If E is zero, then S becomes
4434
+ ** a normal prepared statement. If E is 1, then S behaves as if
4435
+ ** its SQL text began with "[EXPLAIN]". If E is 2, then S behaves as if
4436
+ ** its SQL text began with "[EXPLAIN QUERY PLAN]".
4437
+ **
4438
+ ** Calling sqlite3_stmt_explain(S,E) might cause S to be reprepared.
4439
+ ** SQLite tries to avoid a reprepare, but a reprepare might be necessary
4440
+ ** on the first transition into EXPLAIN or EXPLAIN QUERY PLAN mode.
4441
+ **
4442
+ ** Because of the potential need to reprepare, a call to
4443
+ ** sqlite3_stmt_explain(S,E) will fail with SQLITE_ERROR if S cannot be
4444
+ ** reprepared because it was created using [sqlite3_prepare()] instead of
4445
+ ** the newer [sqlite3_prepare_v2()] or [sqlite3_prepare_v3()] interfaces and
4446
+ ** hence has no saved SQL text with which to reprepare.
4447
+ **
4448
+ ** Changing the explain setting for a prepared statement does not change
4449
+ ** the original SQL text for the statement. Hence, if the SQL text originally
4450
+ ** began with EXPLAIN or EXPLAIN QUERY PLAN, but sqlite3_stmt_explain(S,0)
4451
+ ** is called to convert the statement into an ordinary statement, the EXPLAIN
4452
+ ** or EXPLAIN QUERY PLAN keywords will still appear in the sqlite3_sql(S)
4453
+ ** output, even though the statement now acts like a normal SQL statement.
4454
+ **
4455
+ ** This routine returns SQLITE_OK if the explain mode is successfully
4456
+ ** changed, or an error code if the explain mode could not be changed.
4457
+ ** The explain mode cannot be changed while a statement is active.
4458
+ ** Hence, it is good practice to call [sqlite3_reset(S)]
4459
+ ** immediately prior to calling sqlite3_stmt_explain(S,E).
4460
+ */
4461
+ SQLITE_API int sqlite3_stmt_explain(sqlite3_stmt *pStmt, int eMode);
4462
+
4367
4463
  /*
4368
4464
  ** CAPI3REF: Determine If A Prepared Statement Has Been Reset
4369
4465
  ** METHOD: sqlite3_stmt
@@ -4527,7 +4623,7 @@ typedef struct sqlite3_context sqlite3_context;
4527
4623
  ** with it may be passed. ^It is called to dispose of the BLOB or string even
4528
4624
  ** if the call to the bind API fails, except the destructor is not called if
4529
4625
  ** the third parameter is a NULL pointer or the fourth parameter is negative.
4530
- ** ^ (2) The special constant, [SQLITE_STATIC], may be passsed to indicate that
4626
+ ** ^ (2) The special constant, [SQLITE_STATIC], may be passed to indicate that
4531
4627
  ** the application remains responsible for disposing of the object. ^In this
4532
4628
  ** case, the object and the provided pointer to it must remain valid until
4533
4629
  ** either the prepared statement is finalized or the same SQL parameter is
@@ -5206,20 +5302,33 @@ SQLITE_API int sqlite3_finalize(sqlite3_stmt *pStmt);
5206
5302
  ** ^The [sqlite3_reset(S)] interface resets the [prepared statement] S
5207
5303
  ** back to the beginning of its program.
5208
5304
  **
5209
- ** ^If the most recent call to [sqlite3_step(S)] for the
5210
- ** [prepared statement] S returned [SQLITE_ROW] or [SQLITE_DONE],
5211
- ** or if [sqlite3_step(S)] has never before been called on S,
5212
- ** then [sqlite3_reset(S)] returns [SQLITE_OK].
5305
+ ** ^The return code from [sqlite3_reset(S)] indicates whether or not
5306
+ ** the previous evaluation of prepared statement S completed successfully.
5307
+ ** ^If [sqlite3_step(S)] has never before been called on S or if
5308
+ ** [sqlite3_step(S)] has not been called since the previous call
5309
+ ** to [sqlite3_reset(S)], then [sqlite3_reset(S)] will return
5310
+ ** [SQLITE_OK].
5213
5311
  **
5214
5312
  ** ^If the most recent call to [sqlite3_step(S)] for the
5215
5313
  ** [prepared statement] S indicated an error, then
5216
5314
  ** [sqlite3_reset(S)] returns an appropriate [error code].
5315
+ ** ^The [sqlite3_reset(S)] interface might also return an [error code]
5316
+ ** if there were no prior errors but the process of resetting
5317
+ ** the prepared statement caused a new error. ^For example, if an
5318
+ ** [INSERT] statement with a [RETURNING] clause is only stepped one time,
5319
+ ** that one call to [sqlite3_step(S)] might return SQLITE_ROW but
5320
+ ** the overall statement might still fail and the [sqlite3_reset(S)] call
5321
+ ** might return SQLITE_BUSY if locking constraints prevent the
5322
+ ** database change from committing. Therefore, it is important that
5323
+ ** applications check the return code from [sqlite3_reset(S)] even if
5324
+ ** no prior call to [sqlite3_step(S)] indicated a problem.
5217
5325
  **
5218
5326
  ** ^The [sqlite3_reset(S)] interface does not change the values
5219
5327
  ** of any [sqlite3_bind_blob|bindings] on the [prepared statement] S.
5220
5328
  */
5221
5329
  SQLITE_API int sqlite3_reset(sqlite3_stmt *pStmt);
5222
5330
 
5331
+
5223
5332
  /*
5224
5333
  ** CAPI3REF: Create Or Redefine SQL Functions
5225
5334
  ** KEYWORDS: {function creation routines}
@@ -5430,7 +5539,7 @@ SQLITE_API int sqlite3_create_window_function(
5430
5539
  ** [application-defined SQL function]
5431
5540
  ** that has side-effects or that could potentially leak sensitive information.
5432
5541
  ** This will prevent attacks in which an application is tricked
5433
- ** into using a database file that has had its schema surreptiously
5542
+ ** into using a database file that has had its schema surreptitiously
5434
5543
  ** modified to invoke the application-defined function in ways that are
5435
5544
  ** harmful.
5436
5545
  ** <p>
@@ -5466,13 +5575,27 @@ SQLITE_API int sqlite3_create_window_function(
5466
5575
  ** </dd>
5467
5576
  **
5468
5577
  ** [[SQLITE_SUBTYPE]] <dt>SQLITE_SUBTYPE</dt><dd>
5469
- ** The SQLITE_SUBTYPE flag indicates to SQLite that a function may call
5578
+ ** The SQLITE_SUBTYPE flag indicates to SQLite that a function might call
5470
5579
  ** [sqlite3_value_subtype()] to inspect the sub-types of its arguments.
5471
- ** Specifying this flag makes no difference for scalar or aggregate user
5472
- ** functions. However, if it is not specified for a user-defined window
5473
- ** function, then any sub-types belonging to arguments passed to the window
5474
- ** function may be discarded before the window function is called (i.e.
5475
- ** sqlite3_value_subtype() will always return 0).
5580
+ ** This flag instructs SQLite to omit some corner-case optimizations that
5581
+ ** might disrupt the operation of the [sqlite3_value_subtype()] function,
5582
+ ** causing it to return zero rather than the correct subtype().
5583
+ ** SQL functions that invokes [sqlite3_value_subtype()] should have this
5584
+ ** property. If the SQLITE_SUBTYPE property is omitted, then the return
5585
+ ** value from [sqlite3_value_subtype()] might sometimes be zero even though
5586
+ ** a non-zero subtype was specified by the function argument expression.
5587
+ **
5588
+ ** [[SQLITE_RESULT_SUBTYPE]] <dt>SQLITE_RESULT_SUBTYPE</dt><dd>
5589
+ ** The SQLITE_RESULT_SUBTYPE flag indicates to SQLite that a function might call
5590
+ ** [sqlite3_result_subtype()] to cause a sub-type to be associated with its
5591
+ ** result.
5592
+ ** Every function that invokes [sqlite3_result_subtype()] should have this
5593
+ ** property. If it does not, then the call to [sqlite3_result_subtype()]
5594
+ ** might become a no-op if the function is used as term in an
5595
+ ** [expression index]. On the other hand, SQL functions that never invoke
5596
+ ** [sqlite3_result_subtype()] should avoid setting this property, as the
5597
+ ** purpose of this property is to disable certain optimizations that are
5598
+ ** incompatible with subtypes.
5476
5599
  ** </dd>
5477
5600
  ** </dl>
5478
5601
  */
@@ -5480,6 +5603,7 @@ SQLITE_API int sqlite3_create_window_function(
5480
5603
  #define SQLITE_DIRECTONLY 0x000080000
5481
5604
  #define SQLITE_SUBTYPE 0x000100000
5482
5605
  #define SQLITE_INNOCUOUS 0x000200000
5606
+ #define SQLITE_RESULT_SUBTYPE 0x001000000
5483
5607
 
5484
5608
  /*
5485
5609
  ** CAPI3REF: Deprecated Functions
@@ -5676,6 +5800,12 @@ SQLITE_API int sqlite3_value_encoding(sqlite3_value*);
5676
5800
  ** information can be used to pass a limited amount of context from
5677
5801
  ** one SQL function to another. Use the [sqlite3_result_subtype()]
5678
5802
  ** routine to set the subtype for the return value of an SQL function.
5803
+ **
5804
+ ** Every [application-defined SQL function] that invoke this interface
5805
+ ** should include the [SQLITE_SUBTYPE] property in the text
5806
+ ** encoding argument when the function is [sqlite3_create_function|registered].
5807
+ ** If the [SQLITE_SUBTYPE] property is omitted, then sqlite3_value_subtype()
5808
+ ** might return zero instead of the upstream subtype in some corner cases.
5679
5809
  */
5680
5810
  SQLITE_API unsigned int sqlite3_value_subtype(sqlite3_value*);
5681
5811
 
@@ -5774,48 +5904,56 @@ SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*);
5774
5904
  ** METHOD: sqlite3_context
5775
5905
  **
5776
5906
  ** These functions may be used by (non-aggregate) SQL functions to
5777
- ** associate metadata with argument values. If the same value is passed to
5778
- ** multiple invocations of the same SQL function during query execution, under
5779
- ** some circumstances the associated metadata may be preserved. An example
5780
- ** of where this might be useful is in a regular-expression matching
5781
- ** function. The compiled version of the regular expression can be stored as
5782
- ** metadata associated with the pattern string.
5907
+ ** associate auxiliary data with argument values. If the same argument
5908
+ ** value is passed to multiple invocations of the same SQL function during
5909
+ ** query execution, under some circumstances the associated auxiliary data
5910
+ ** might be preserved. An example of where this might be useful is in a
5911
+ ** regular-expression matching function. The compiled version of the regular
5912
+ ** expression can be stored as auxiliary data associated with the pattern string.
5783
5913
  ** Then as long as the pattern string remains the same,
5784
5914
  ** the compiled regular expression can be reused on multiple
5785
5915
  ** invocations of the same function.
5786
5916
  **
5787
- ** ^The sqlite3_get_auxdata(C,N) interface returns a pointer to the metadata
5917
+ ** ^The sqlite3_get_auxdata(C,N) interface returns a pointer to the auxiliary data
5788
5918
  ** associated by the sqlite3_set_auxdata(C,N,P,X) function with the Nth argument
5789
5919
  ** value to the application-defined function. ^N is zero for the left-most
5790
- ** function argument. ^If there is no metadata
5920
+ ** function argument. ^If there is no auxiliary data
5791
5921
  ** associated with the function argument, the sqlite3_get_auxdata(C,N) interface
5792
5922
  ** returns a NULL pointer.
5793
5923
  **
5794
- ** ^The sqlite3_set_auxdata(C,N,P,X) interface saves P as metadata for the N-th
5795
- ** argument of the application-defined function. ^Subsequent
5924
+ ** ^The sqlite3_set_auxdata(C,N,P,X) interface saves P as auxiliary data for the
5925
+ ** N-th argument of the application-defined function. ^Subsequent
5796
5926
  ** calls to sqlite3_get_auxdata(C,N) return P from the most recent
5797
- ** sqlite3_set_auxdata(C,N,P,X) call if the metadata is still valid or
5798
- ** NULL if the metadata has been discarded.
5927
+ ** sqlite3_set_auxdata(C,N,P,X) call if the auxiliary data is still valid or
5928
+ ** NULL if the auxiliary data has been discarded.
5799
5929
  ** ^After each call to sqlite3_set_auxdata(C,N,P,X) where X is not NULL,
5800
5930
  ** SQLite will invoke the destructor function X with parameter P exactly
5801
- ** once, when the metadata is discarded.
5802
- ** SQLite is free to discard the metadata at any time, including: <ul>
5931
+ ** once, when the auxiliary data is discarded.
5932
+ ** SQLite is free to discard the auxiliary data at any time, including: <ul>
5803
5933
  ** <li> ^(when the corresponding function parameter changes)^, or
5804
5934
  ** <li> ^(when [sqlite3_reset()] or [sqlite3_finalize()] is called for the
5805
5935
  ** SQL statement)^, or
5806
5936
  ** <li> ^(when sqlite3_set_auxdata() is invoked again on the same
5807
5937
  ** parameter)^, or
5808
5938
  ** <li> ^(during the original sqlite3_set_auxdata() call when a memory
5809
- ** allocation error occurs.)^ </ul>
5939
+ ** allocation error occurs.)^
5940
+ ** <li> ^(during the original sqlite3_set_auxdata() call if the function
5941
+ ** is evaluated during query planning instead of during query execution,
5942
+ ** as sometimes happens with [SQLITE_ENABLE_STAT4].)^ </ul>
5810
5943
  **
5811
- ** Note the last bullet in particular. The destructor X in
5944
+ ** Note the last two bullets in particular. The destructor X in
5812
5945
  ** sqlite3_set_auxdata(C,N,P,X) might be called immediately, before the
5813
5946
  ** sqlite3_set_auxdata() interface even returns. Hence sqlite3_set_auxdata()
5814
5947
  ** should be called near the end of the function implementation and the
5815
5948
  ** function implementation should not make any use of P after
5816
- ** sqlite3_set_auxdata() has been called.
5817
- **
5818
- ** ^(In practice, metadata is preserved between function calls for
5949
+ ** sqlite3_set_auxdata() has been called. Furthermore, a call to
5950
+ ** sqlite3_get_auxdata() that occurs immediately after a corresponding call
5951
+ ** to sqlite3_set_auxdata() might still return NULL if an out-of-memory
5952
+ ** condition occurred during the sqlite3_set_auxdata() call or if the
5953
+ ** function is being evaluated during query planning rather than during
5954
+ ** query execution.
5955
+ **
5956
+ ** ^(In practice, auxiliary data is preserved between function calls for
5819
5957
  ** function parameters that are compile-time constants, including literal
5820
5958
  ** values and [parameters] and expressions composed from the same.)^
5821
5959
  **
@@ -5825,10 +5963,67 @@ SQLITE_API sqlite3 *sqlite3_context_db_handle(sqlite3_context*);
5825
5963
  **
5826
5964
  ** These routines must be called from the same thread in which
5827
5965
  ** the SQL function is running.
5966
+ **
5967
+ ** See also: [sqlite3_get_clientdata()] and [sqlite3_set_clientdata()].
5828
5968
  */
5829
5969
  SQLITE_API void *sqlite3_get_auxdata(sqlite3_context*, int N);
5830
5970
  SQLITE_API void sqlite3_set_auxdata(sqlite3_context*, int N, void*, void (*)(void*));
5831
5971
 
5972
+ /*
5973
+ ** CAPI3REF: Database Connection Client Data
5974
+ ** METHOD: sqlite3
5975
+ **
5976
+ ** These functions are used to associate one or more named pointers
5977
+ ** with a [database connection].
5978
+ ** A call to sqlite3_set_clientdata(D,N,P,X) causes the pointer P
5979
+ ** to be attached to [database connection] D using name N. Subsequent
5980
+ ** calls to sqlite3_get_clientdata(D,N) will return a copy of pointer P
5981
+ ** or a NULL pointer if there were no prior calls to
5982
+ ** sqlite3_set_clientdata() with the same values of D and N.
5983
+ ** Names are compared using strcmp() and are thus case sensitive.
5984
+ **
5985
+ ** If P and X are both non-NULL, then the destructor X is invoked with
5986
+ ** argument P on the first of the following occurrences:
5987
+ ** <ul>
5988
+ ** <li> An out-of-memory error occurs during the call to
5989
+ ** sqlite3_set_clientdata() which attempts to register pointer P.
5990
+ ** <li> A subsequent call to sqlite3_set_clientdata(D,N,P,X) is made
5991
+ ** with the same D and N parameters.
5992
+ ** <li> The database connection closes. SQLite does not make any guarantees
5993
+ ** about the order in which destructors are called, only that all
5994
+ ** destructors will be called exactly once at some point during the
5995
+ ** database connection closing process.
5996
+ ** </ul>
5997
+ **
5998
+ ** SQLite does not do anything with client data other than invoke
5999
+ ** destructors on the client data at the appropriate time. The intended
6000
+ ** use for client data is to provide a mechanism for wrapper libraries
6001
+ ** to store additional information about an SQLite database connection.
6002
+ **
6003
+ ** There is no limit (other than available memory) on the number of different
6004
+ ** client data pointers (with different names) that can be attached to a
6005
+ ** single database connection. However, the implementation is optimized
6006
+ ** for the case of having only one or two different client data names.
6007
+ ** Applications and wrapper libraries are discouraged from using more than
6008
+ ** one client data name each.
6009
+ **
6010
+ ** There is no way to enumerate the client data pointers
6011
+ ** associated with a database connection. The N parameter can be thought
6012
+ ** of as a secret key such that only code that knows the secret key is able
6013
+ ** to access the associated data.
6014
+ **
6015
+ ** Security Warning: These interfaces should not be exposed in scripting
6016
+ ** languages or in other circumstances where it might be possible for an
6017
+ ** an attacker to invoke them. Any agent that can invoke these interfaces
6018
+ ** can probably also take control of the process.
6019
+ **
6020
+ ** Database connection client data is only available for SQLite
6021
+ ** version 3.44.0 ([dateof:3.44.0]) and later.
6022
+ **
6023
+ ** See also: [sqlite3_set_auxdata()] and [sqlite3_get_auxdata()].
6024
+ */
6025
+ SQLITE_API void *sqlite3_get_clientdata(sqlite3*,const char*);
6026
+ SQLITE_API int sqlite3_set_clientdata(sqlite3*, const char*, void*, void(*)(void*));
5832
6027
 
5833
6028
  /*
5834
6029
  ** CAPI3REF: Constants Defining Special Destructor Behavior
@@ -6030,6 +6225,20 @@ SQLITE_API int sqlite3_result_zeroblob64(sqlite3_context*, sqlite3_uint64 n);
6030
6225
  ** higher order bits are discarded.
6031
6226
  ** The number of subtype bytes preserved by SQLite might increase
6032
6227
  ** in future releases of SQLite.
6228
+ **
6229
+ ** Every [application-defined SQL function] that invokes this interface
6230
+ ** should include the [SQLITE_RESULT_SUBTYPE] property in its
6231
+ ** text encoding argument when the SQL function is
6232
+ ** [sqlite3_create_function|registered]. If the [SQLITE_RESULT_SUBTYPE]
6233
+ ** property is omitted from the function that invokes sqlite3_result_subtype(),
6234
+ ** then in some cases the sqlite3_result_subtype() might fail to set
6235
+ ** the result subtype.
6236
+ **
6237
+ ** If SQLite is compiled with -DSQLITE_STRICT_SUBTYPE=1, then any
6238
+ ** SQL function that invokes the sqlite3_result_subtype() interface
6239
+ ** and that does not have the SQLITE_RESULT_SUBTYPE property will raise
6240
+ ** an error. Future versions of SQLite might enable -DSQLITE_STRICT_SUBTYPE=1
6241
+ ** by default.
6033
6242
  */
6034
6243
  SQLITE_API void sqlite3_result_subtype(sqlite3_context*,unsigned int);
6035
6244
 
@@ -6201,6 +6410,13 @@ SQLITE_API void sqlite3_activate_cerod(
6201
6410
  ** of the default VFS is not implemented correctly, or not implemented at
6202
6411
  ** all, then the behavior of sqlite3_sleep() may deviate from the description
6203
6412
  ** in the previous paragraphs.
6413
+ **
6414
+ ** If a negative argument is passed to sqlite3_sleep() the results vary by
6415
+ ** VFS and operating system. Some system treat a negative argument as an
6416
+ ** instruction to sleep forever. Others understand it to mean do not sleep
6417
+ ** at all. ^In SQLite version 3.42.0 and later, a negative
6418
+ ** argument passed into sqlite3_sleep() is changed to zero before it is relayed
6419
+ ** down into the xSleep method of the VFS.
6204
6420
  */
6205
6421
  SQLITE_API int sqlite3_sleep(int);
6206
6422
 
@@ -6454,7 +6670,7 @@ SQLITE_API int sqlite3_db_readonly(sqlite3 *db, const char *zDbName);
6454
6670
  SQLITE_API int sqlite3_txn_state(sqlite3*,const char *zSchema);
6455
6671
 
6456
6672
  /*
6457
- ** CAPI3REF: Allowed return values from [sqlite3_txn_state()]
6673
+ ** CAPI3REF: Allowed return values from sqlite3_txn_state()
6458
6674
  ** KEYWORDS: {transaction state}
6459
6675
  **
6460
6676
  ** These constants define the current transaction state of a database file.
@@ -6586,7 +6802,7 @@ SQLITE_API void *sqlite3_rollback_hook(sqlite3*, void(*)(void *), void*);
6586
6802
  ** ^Each call to the sqlite3_autovacuum_pages() interface overrides all
6587
6803
  ** previous invocations for that database connection. ^If the callback
6588
6804
  ** argument (C) to sqlite3_autovacuum_pages(D,C,P,X) is a NULL pointer,
6589
- ** then the autovacuum steps callback is cancelled. The return value
6805
+ ** then the autovacuum steps callback is canceled. The return value
6590
6806
  ** from sqlite3_autovacuum_pages() is normally SQLITE_OK, but might
6591
6807
  ** be some other error code if something goes wrong. The current
6592
6808
  ** implementation will only return SQLITE_OK or SQLITE_MISUSE, but other
@@ -7105,6 +7321,10 @@ struct sqlite3_module {
7105
7321
  /* The methods above are in versions 1 and 2 of the sqlite_module object.
7106
7322
  ** Those below are for version 3 and greater. */
7107
7323
  int (*xShadowName)(const char*);
7324
+ /* The methods above are in versions 1 through 3 of the sqlite_module object.
7325
+ ** Those below are for version 4 and greater. */
7326
+ int (*xIntegrity)(sqlite3_vtab *pVTab, const char *zSchema,
7327
+ const char *zTabName, int mFlags, char **pzErr);
7108
7328
  };
7109
7329
 
7110
7330
  /*
@@ -7592,7 +7812,7 @@ SQLITE_API int sqlite3_blob_reopen(sqlite3_blob *, sqlite3_int64);
7592
7812
  ** code is returned and the transaction rolled back.
7593
7813
  **
7594
7814
  ** Calling this function with an argument that is not a NULL pointer or an
7595
- ** open blob handle results in undefined behaviour. ^Calling this routine
7815
+ ** open blob handle results in undefined behavior. ^Calling this routine
7596
7816
  ** with a null pointer (such as would be returned by a failed call to
7597
7817
  ** [sqlite3_blob_open()]) is a harmless no-op. ^Otherwise, if this function
7598
7818
  ** is passed a valid open blob handle, the values returned by the
@@ -7819,18 +8039,20 @@ SQLITE_API int sqlite3_vfs_unregister(sqlite3_vfs*);
7819
8039
  **
7820
8040
  ** ^(Some systems (for example, Windows 95) do not support the operation
7821
8041
  ** implemented by sqlite3_mutex_try(). On those systems, sqlite3_mutex_try()
7822
- ** will always return SQLITE_BUSY. The SQLite core only ever uses
7823
- ** sqlite3_mutex_try() as an optimization so this is acceptable
7824
- ** behavior.)^
8042
+ ** will always return SQLITE_BUSY. In most cases the SQLite core only uses
8043
+ ** sqlite3_mutex_try() as an optimization, so this is acceptable
8044
+ ** behavior. The exceptions are unix builds that set the
8045
+ ** SQLITE_ENABLE_SETLK_TIMEOUT build option. In that case a working
8046
+ ** sqlite3_mutex_try() is required.)^
7825
8047
  **
7826
8048
  ** ^The sqlite3_mutex_leave() routine exits a mutex that was
7827
8049
  ** previously entered by the same thread. The behavior
7828
8050
  ** is undefined if the mutex is not currently entered by the
7829
8051
  ** calling thread or is not currently allocated.
7830
8052
  **
7831
- ** ^If the argument to sqlite3_mutex_enter(), sqlite3_mutex_try(), or
7832
- ** sqlite3_mutex_leave() is a NULL pointer, then all three routines
7833
- ** behave as no-ops.
8053
+ ** ^If the argument to sqlite3_mutex_enter(), sqlite3_mutex_try(),
8054
+ ** sqlite3_mutex_leave(), or sqlite3_mutex_free() is a NULL pointer,
8055
+ ** then any of the four routines behaves as a no-op.
7834
8056
  **
7835
8057
  ** See also: [sqlite3_mutex_held()] and [sqlite3_mutex_notheld()].
7836
8058
  */
@@ -8072,6 +8294,7 @@ SQLITE_API int sqlite3_test_control(int op, ...);
8072
8294
  #define SQLITE_TESTCTRL_PRNG_SAVE 5
8073
8295
  #define SQLITE_TESTCTRL_PRNG_RESTORE 6
8074
8296
  #define SQLITE_TESTCTRL_PRNG_RESET 7 /* NOT USED */
8297
+ #define SQLITE_TESTCTRL_FK_NO_ACTION 7
8075
8298
  #define SQLITE_TESTCTRL_BITVEC_TEST 8
8076
8299
  #define SQLITE_TESTCTRL_FAULT_INSTALL 9
8077
8300
  #define SQLITE_TESTCTRL_BENIGN_MALLOC_HOOKS 10
@@ -8079,6 +8302,7 @@ SQLITE_API int sqlite3_test_control(int op, ...);
8079
8302
  #define SQLITE_TESTCTRL_ASSERT 12
8080
8303
  #define SQLITE_TESTCTRL_ALWAYS 13
8081
8304
  #define SQLITE_TESTCTRL_RESERVE 14 /* NOT USED */
8305
+ #define SQLITE_TESTCTRL_JSON_SELFCHECK 14
8082
8306
  #define SQLITE_TESTCTRL_OPTIMIZATIONS 15
8083
8307
  #define SQLITE_TESTCTRL_ISKEYWORD 16 /* NOT USED */
8084
8308
  #define SQLITE_TESTCTRL_SCRATCHMALLOC 17 /* NOT USED */
@@ -8100,7 +8324,8 @@ SQLITE_API int sqlite3_test_control(int op, ...);
8100
8324
  #define SQLITE_TESTCTRL_TRACEFLAGS 31
8101
8325
  #define SQLITE_TESTCTRL_TUNE 32
8102
8326
  #define SQLITE_TESTCTRL_LOGEST 33
8103
- #define SQLITE_TESTCTRL_LAST 33 /* Largest TESTCTRL */
8327
+ #define SQLITE_TESTCTRL_USELONGDOUBLE 34
8328
+ #define SQLITE_TESTCTRL_LAST 34 /* Largest TESTCTRL */
8104
8329
 
8105
8330
  /*
8106
8331
  ** CAPI3REF: SQL Keyword Checking
@@ -9556,7 +9781,7 @@ SQLITE_API int sqlite3_vtab_config(sqlite3*, int op, ...);
9556
9781
  ** [[SQLITE_VTAB_DIRECTONLY]]<dt>SQLITE_VTAB_DIRECTONLY</dt>
9557
9782
  ** <dd>Calls of the form
9558
9783
  ** [sqlite3_vtab_config](db,SQLITE_VTAB_DIRECTONLY) from within the
9559
- ** the [xConnect] or [xCreate] methods of a [virtual table] implmentation
9784
+ ** the [xConnect] or [xCreate] methods of a [virtual table] implementation
9560
9785
  ** prohibits that virtual table from being used from within triggers and
9561
9786
  ** views.
9562
9787
  ** </dd>
@@ -9564,18 +9789,28 @@ SQLITE_API int sqlite3_vtab_config(sqlite3*, int op, ...);
9564
9789
  ** [[SQLITE_VTAB_INNOCUOUS]]<dt>SQLITE_VTAB_INNOCUOUS</dt>
9565
9790
  ** <dd>Calls of the form
9566
9791
  ** [sqlite3_vtab_config](db,SQLITE_VTAB_INNOCUOUS) from within the
9567
- ** the [xConnect] or [xCreate] methods of a [virtual table] implmentation
9792
+ ** the [xConnect] or [xCreate] methods of a [virtual table] implementation
9568
9793
  ** identify that virtual table as being safe to use from within triggers
9569
9794
  ** and views. Conceptually, the SQLITE_VTAB_INNOCUOUS tag means that the
9570
9795
  ** virtual table can do no serious harm even if it is controlled by a
9571
9796
  ** malicious hacker. Developers should avoid setting the SQLITE_VTAB_INNOCUOUS
9572
9797
  ** flag unless absolutely necessary.
9573
9798
  ** </dd>
9799
+ **
9800
+ ** [[SQLITE_VTAB_USES_ALL_SCHEMAS]]<dt>SQLITE_VTAB_USES_ALL_SCHEMAS</dt>
9801
+ ** <dd>Calls of the form
9802
+ ** [sqlite3_vtab_config](db,SQLITE_VTAB_USES_ALL_SCHEMA) from within the
9803
+ ** the [xConnect] or [xCreate] methods of a [virtual table] implementation
9804
+ ** instruct the query planner to begin at least a read transaction on
9805
+ ** all schemas ("main", "temp", and any ATTACH-ed databases) whenever the
9806
+ ** virtual table is used.
9807
+ ** </dd>
9574
9808
  ** </dl>
9575
9809
  */
9576
9810
  #define SQLITE_VTAB_CONSTRAINT_SUPPORT 1
9577
9811
  #define SQLITE_VTAB_INNOCUOUS 2
9578
9812
  #define SQLITE_VTAB_DIRECTONLY 3
9813
+ #define SQLITE_VTAB_USES_ALL_SCHEMAS 4
9579
9814
 
9580
9815
  /*
9581
9816
  ** CAPI3REF: Determine The Virtual Table Conflict Policy
@@ -9736,7 +9971,7 @@ SQLITE_API int sqlite3_vtab_distinct(sqlite3_index_info*);
9736
9971
  ** communicated to the xBestIndex method as a
9737
9972
  ** [SQLITE_INDEX_CONSTRAINT_EQ] constraint.)^ If xBestIndex wants to use
9738
9973
  ** this constraint, it must set the corresponding
9739
- ** aConstraintUsage[].argvIndex to a postive integer. ^(Then, under
9974
+ ** aConstraintUsage[].argvIndex to a positive integer. ^(Then, under
9740
9975
  ** the usual mode of handling IN operators, SQLite generates [bytecode]
9741
9976
  ** that invokes the [xFilter|xFilter() method] once for each value
9742
9977
  ** on the right-hand side of the IN operator.)^ Thus the virtual table
@@ -10165,7 +10400,7 @@ SQLITE_API int sqlite3_db_cacheflush(sqlite3*);
10165
10400
  ** When the [sqlite3_blob_write()] API is used to update a blob column,
10166
10401
  ** the pre-update hook is invoked with SQLITE_DELETE. This is because the
10167
10402
  ** in this case the new values are not available. In this case, when a
10168
- ** callback made with op==SQLITE_DELETE is actuall a write using the
10403
+ ** callback made with op==SQLITE_DELETE is actually a write using the
10169
10404
  ** sqlite3_blob_write() API, the [sqlite3_preupdate_blobwrite()] returns
10170
10405
  ** the index of the column being written. In other cases, where the
10171
10406
  ** pre-update hook is being invoked for some other reason, including a
@@ -10426,6 +10661,13 @@ SQLITE_API SQLITE_EXPERIMENTAL int sqlite3_snapshot_recover(sqlite3 *db, const c
10426
10661
  ** SQLITE_SERIALIZE_NOCOPY bit is set but no contiguous copy
10427
10662
  ** of the database exists.
10428
10663
  **
10664
+ ** After the call, if the SQLITE_SERIALIZE_NOCOPY bit had been set,
10665
+ ** the returned buffer content will remain accessible and unchanged
10666
+ ** until either the next write operation on the connection or when
10667
+ ** the connection is closed, and applications must not modify the
10668
+ ** buffer. If the bit had been clear, the returned buffer will not
10669
+ ** be accessed by SQLite after the call.
10670
+ **
10429
10671
  ** A call to sqlite3_serialize(D,S,P,F) might return NULL even if the
10430
10672
  ** SQLITE_SERIALIZE_NOCOPY bit is omitted from argument F if a memory
10431
10673
  ** allocation error occurs.
@@ -10474,6 +10716,9 @@ SQLITE_API unsigned char *sqlite3_serialize(
10474
10716
  ** SQLite will try to increase the buffer size using sqlite3_realloc64()
10475
10717
  ** if writes on the database cause it to grow larger than M bytes.
10476
10718
  **
10719
+ ** Applications must not modify the buffer P or invalidate it before
10720
+ ** the database connection D is closed.
10721
+ **
10477
10722
  ** The sqlite3_deserialize() interface will fail with SQLITE_BUSY if the
10478
10723
  ** database is currently in a read transaction or is involved in a backup
10479
10724
  ** operation.
@@ -10482,6 +10727,13 @@ SQLITE_API unsigned char *sqlite3_serialize(
10482
10727
  ** S argument to sqlite3_deserialize(D,S,P,N,M,F) is "temp" then the
10483
10728
  ** function returns SQLITE_ERROR.
10484
10729
  **
10730
+ ** The deserialized database should not be in [WAL mode]. If the database
10731
+ ** is in WAL mode, then any attempt to use the database file will result
10732
+ ** in an [SQLITE_CANTOPEN] error. The application can set the
10733
+ ** [file format version numbers] (bytes 18 and 19) of the input database P
10734
+ ** to 0x01 prior to invoking sqlite3_deserialize(D,S,P,N,M,F) to force the
10735
+ ** database file into rollback mode and work around this limitation.
10736
+ **
10485
10737
  ** If sqlite3_deserialize(D,S,P,N,M,F) fails for any reason and if the
10486
10738
  ** SQLITE_DESERIALIZE_FREEONCLOSE bit is set in argument F, then
10487
10739
  ** [sqlite3_free()] is invoked on argument P prior to returning.
@@ -10750,16 +11002,20 @@ SQLITE_API int sqlite3session_create(
10750
11002
  SQLITE_API void sqlite3session_delete(sqlite3_session *pSession);
10751
11003
 
10752
11004
  /*
10753
- ** CAPIREF: Conigure a Session Object
11005
+ ** CAPI3REF: Configure a Session Object
10754
11006
  ** METHOD: sqlite3_session
10755
11007
  **
10756
11008
  ** This method is used to configure a session object after it has been
10757
- ** created. At present the only valid value for the second parameter is
10758
- ** [SQLITE_SESSION_OBJCONFIG_SIZE].
11009
+ ** created. At present the only valid values for the second parameter are
11010
+ ** [SQLITE_SESSION_OBJCONFIG_SIZE] and [SQLITE_SESSION_OBJCONFIG_ROWID].
10759
11011
  **
10760
- ** Arguments for sqlite3session_object_config()
11012
+ */
11013
+ SQLITE_API int sqlite3session_object_config(sqlite3_session*, int op, void *pArg);
11014
+
11015
+ /*
11016
+ ** CAPI3REF: Options for sqlite3session_object_config
10761
11017
  **
10762
- ** The following values may passed as the the 4th parameter to
11018
+ ** The following values may passed as the the 2nd parameter to
10763
11019
  ** sqlite3session_object_config().
10764
11020
  **
10765
11021
  ** <dt>SQLITE_SESSION_OBJCONFIG_SIZE <dd>
@@ -10775,12 +11031,21 @@ SQLITE_API void sqlite3session_delete(sqlite3_session *pSession);
10775
11031
  **
10776
11032
  ** It is an error (SQLITE_MISUSE) to attempt to modify this setting after
10777
11033
  ** the first table has been attached to the session object.
11034
+ **
11035
+ ** <dt>SQLITE_SESSION_OBJCONFIG_ROWID <dd>
11036
+ ** This option is used to set, clear or query the flag that enables
11037
+ ** collection of data for tables with no explicit PRIMARY KEY.
11038
+ **
11039
+ ** Normally, tables with no explicit PRIMARY KEY are simply ignored
11040
+ ** by the sessions module. However, if this flag is set, it behaves
11041
+ ** as if such tables have a column "_rowid_ INTEGER PRIMARY KEY" inserted
11042
+ ** as their leftmost columns.
11043
+ **
11044
+ ** It is an error (SQLITE_MISUSE) to attempt to modify this setting after
11045
+ ** the first table has been attached to the session object.
10778
11046
  */
10779
- SQLITE_API int sqlite3session_object_config(sqlite3_session*, int op, void *pArg);
10780
-
10781
- /*
10782
- */
10783
- #define SQLITE_SESSION_OBJCONFIG_SIZE 1
11047
+ #define SQLITE_SESSION_OBJCONFIG_SIZE 1
11048
+ #define SQLITE_SESSION_OBJCONFIG_ROWID 2
10784
11049
 
10785
11050
  /*
10786
11051
  ** CAPI3REF: Enable Or Disable A Session Object
@@ -11541,6 +11806,18 @@ SQLITE_API int sqlite3changeset_concat(
11541
11806
  );
11542
11807
 
11543
11808
 
11809
+ /*
11810
+ ** CAPI3REF: Upgrade the Schema of a Changeset/Patchset
11811
+ */
11812
+ SQLITE_API int sqlite3changeset_upgrade(
11813
+ sqlite3 *db,
11814
+ const char *zDb,
11815
+ int nIn, const void *pIn, /* Input changeset */
11816
+ int *pnOut, void **ppOut /* OUT: Inverse of input */
11817
+ );
11818
+
11819
+
11820
+
11544
11821
  /*
11545
11822
  ** CAPI3REF: Changegroup Handle
11546
11823
  **
@@ -11587,6 +11864,38 @@ typedef struct sqlite3_changegroup sqlite3_changegroup;
11587
11864
  */
11588
11865
  SQLITE_API int sqlite3changegroup_new(sqlite3_changegroup **pp);
11589
11866
 
11867
+ /*
11868
+ ** CAPI3REF: Add a Schema to a Changegroup
11869
+ ** METHOD: sqlite3_changegroup_schema
11870
+ **
11871
+ ** This method may be used to optionally enforce the rule that the changesets
11872
+ ** added to the changegroup handle must match the schema of database zDb
11873
+ ** ("main", "temp", or the name of an attached database). If
11874
+ ** sqlite3changegroup_add() is called to add a changeset that is not compatible
11875
+ ** with the configured schema, SQLITE_SCHEMA is returned and the changegroup
11876
+ ** object is left in an undefined state.
11877
+ **
11878
+ ** A changeset schema is considered compatible with the database schema in
11879
+ ** the same way as for sqlite3changeset_apply(). Specifically, for each
11880
+ ** table in the changeset, there exists a database table with:
11881
+ **
11882
+ ** <ul>
11883
+ ** <li> The name identified by the changeset, and
11884
+ ** <li> at least as many columns as recorded in the changeset, and
11885
+ ** <li> the primary key columns in the same position as recorded in
11886
+ ** the changeset.
11887
+ ** </ul>
11888
+ **
11889
+ ** The output of the changegroup object always has the same schema as the
11890
+ ** database nominated using this function. In cases where changesets passed
11891
+ ** to sqlite3changegroup_add() have fewer columns than the corresponding table
11892
+ ** in the database schema, these are filled in using the default column
11893
+ ** values from the database schema. This makes it possible to combined
11894
+ ** changesets that have different numbers of columns for a single table
11895
+ ** within a changegroup, provided that they are otherwise compatible.
11896
+ */
11897
+ SQLITE_API int sqlite3changegroup_schema(sqlite3_changegroup*, sqlite3*, const char *zDb);
11898
+
11590
11899
  /*
11591
11900
  ** CAPI3REF: Add A Changeset To A Changegroup
11592
11901
  ** METHOD: sqlite3_changegroup
@@ -11655,13 +11964,18 @@ SQLITE_API int sqlite3changegroup_new(sqlite3_changegroup **pp);
11655
11964
  ** If the new changeset contains changes to a table that is already present
11656
11965
  ** in the changegroup, then the number of columns and the position of the
11657
11966
  ** primary key columns for the table must be consistent. If this is not the
11658
- ** case, this function fails with SQLITE_SCHEMA. If the input changeset
11659
- ** appears to be corrupt and the corruption is detected, SQLITE_CORRUPT is
11660
- ** returned. Or, if an out-of-memory condition occurs during processing, this
11661
- ** function returns SQLITE_NOMEM. In all cases, if an error occurs the state
11662
- ** of the final contents of the changegroup is undefined.
11967
+ ** case, this function fails with SQLITE_SCHEMA. Except, if the changegroup
11968
+ ** object has been configured with a database schema using the
11969
+ ** sqlite3changegroup_schema() API, then it is possible to combine changesets
11970
+ ** with different numbers of columns for a single table, provided that
11971
+ ** they are otherwise compatible.
11972
+ **
11973
+ ** If the input changeset appears to be corrupt and the corruption is
11974
+ ** detected, SQLITE_CORRUPT is returned. Or, if an out-of-memory condition
11975
+ ** occurs during processing, this function returns SQLITE_NOMEM.
11663
11976
  **
11664
- ** If no error occurs, SQLITE_OK is returned.
11977
+ ** In all cases, if an error occurs the state of the final contents of the
11978
+ ** changegroup is undefined. If no error occurs, SQLITE_OK is returned.
11665
11979
  */
11666
11980
  SQLITE_API int sqlite3changegroup_add(sqlite3_changegroup*, int nData, void *pData);
11667
11981
 
@@ -11913,9 +12227,30 @@ SQLITE_API int sqlite3changeset_apply_v2(
11913
12227
  ** Invert the changeset before applying it. This is equivalent to inverting
11914
12228
  ** a changeset using sqlite3changeset_invert() before applying it. It is
11915
12229
  ** an error to specify this flag with a patchset.
12230
+ **
12231
+ ** <dt>SQLITE_CHANGESETAPPLY_IGNORENOOP <dd>
12232
+ ** Do not invoke the conflict handler callback for any changes that
12233
+ ** would not actually modify the database even if they were applied.
12234
+ ** Specifically, this means that the conflict handler is not invoked
12235
+ ** for:
12236
+ ** <ul>
12237
+ ** <li>a delete change if the row being deleted cannot be found,
12238
+ ** <li>an update change if the modified fields are already set to
12239
+ ** their new values in the conflicting row, or
12240
+ ** <li>an insert change if all fields of the conflicting row match
12241
+ ** the row being inserted.
12242
+ ** </ul>
12243
+ **
12244
+ ** <dt>SQLITE_CHANGESETAPPLY_FKNOACTION <dd>
12245
+ ** If this flag it set, then all foreign key constraints in the target
12246
+ ** database behave as if they were declared with "ON UPDATE NO ACTION ON
12247
+ ** DELETE NO ACTION", even if they are actually CASCADE, RESTRICT, SET NULL
12248
+ ** or SET DEFAULT.
11916
12249
  */
11917
12250
  #define SQLITE_CHANGESETAPPLY_NOSAVEPOINT 0x0001
11918
12251
  #define SQLITE_CHANGESETAPPLY_INVERT 0x0002
12252
+ #define SQLITE_CHANGESETAPPLY_IGNORENOOP 0x0004
12253
+ #define SQLITE_CHANGESETAPPLY_FKNOACTION 0x0008
11919
12254
 
11920
12255
  /*
11921
12256
  ** CAPI3REF: Constants Passed To The Conflict Handler
@@ -12481,8 +12816,11 @@ struct Fts5PhraseIter {
12481
12816
  ** created with the "columnsize=0" option.
12482
12817
  **
12483
12818
  ** xColumnText:
12484
- ** This function attempts to retrieve the text of column iCol of the
12485
- ** current document. If successful, (*pz) is set to point to a buffer
12819
+ ** If parameter iCol is less than zero, or greater than or equal to the
12820
+ ** number of columns in the table, SQLITE_RANGE is returned.
12821
+ **
12822
+ ** Otherwise, this function attempts to retrieve the text of column iCol of
12823
+ ** the current document. If successful, (*pz) is set to point to a buffer
12486
12824
  ** containing the text in utf-8 encoding, (*pn) is set to the size in bytes
12487
12825
  ** (not characters) of the buffer and SQLITE_OK is returned. Otherwise,
12488
12826
  ** if an error occurs, an SQLite error code is returned and the final values
@@ -12492,8 +12830,10 @@ struct Fts5PhraseIter {
12492
12830
  ** Returns the number of phrases in the current query expression.
12493
12831
  **
12494
12832
  ** xPhraseSize:
12495
- ** Returns the number of tokens in phrase iPhrase of the query. Phrases
12496
- ** are numbered starting from zero.
12833
+ ** If parameter iCol is less than zero, or greater than or equal to the
12834
+ ** number of phrases in the current query, as returned by xPhraseCount,
12835
+ ** 0 is returned. Otherwise, this function returns the number of tokens in
12836
+ ** phrase iPhrase of the query. Phrases are numbered starting from zero.
12497
12837
  **
12498
12838
  ** xInstCount:
12499
12839
  ** Set *pnInst to the total number of occurrences of all phrases within
@@ -12509,12 +12849,13 @@ struct Fts5PhraseIter {
12509
12849
  ** Query for the details of phrase match iIdx within the current row.
12510
12850
  ** Phrase matches are numbered starting from zero, so the iIdx argument
12511
12851
  ** should be greater than or equal to zero and smaller than the value
12512
- ** output by xInstCount().
12852
+ ** output by xInstCount(). If iIdx is less than zero or greater than
12853
+ ** or equal to the value returned by xInstCount(), SQLITE_RANGE is returned.
12513
12854
  **
12514
- ** Usually, output parameter *piPhrase is set to the phrase number, *piCol
12855
+ ** Otherwise, output parameter *piPhrase is set to the phrase number, *piCol
12515
12856
  ** to the column in which it occurs and *piOff the token offset of the
12516
- ** first token of the phrase. Returns SQLITE_OK if successful, or an error
12517
- ** code (i.e. SQLITE_NOMEM) if an error occurs.
12857
+ ** first token of the phrase. SQLITE_OK is returned if successful, or an
12858
+ ** error code (i.e. SQLITE_NOMEM) if an error occurs.
12518
12859
  **
12519
12860
  ** This API can be quite slow if used with an FTS5 table created with the
12520
12861
  ** "detail=none" or "detail=column" option.
@@ -12540,6 +12881,10 @@ struct Fts5PhraseIter {
12540
12881
  ** Invoking Api.xUserData() returns a copy of the pointer passed as
12541
12882
  ** the third argument to pUserData.
12542
12883
  **
12884
+ ** If parameter iPhrase is less than zero, or greater than or equal to
12885
+ ** the number of phrases in the query, as returned by xPhraseCount(),
12886
+ ** this function returns SQLITE_RANGE.
12887
+ **
12543
12888
  ** If the callback function returns any value other than SQLITE_OK, the
12544
12889
  ** query is abandoned and the xQueryPhrase function returns immediately.
12545
12890
  ** If the returned value is SQLITE_DONE, xQueryPhrase returns SQLITE_OK.
@@ -12654,6 +12999,39 @@ struct Fts5PhraseIter {
12654
12999
  **
12655
13000
  ** xPhraseNextColumn()
12656
13001
  ** See xPhraseFirstColumn above.
13002
+ **
13003
+ ** xQueryToken(pFts5, iPhrase, iToken, ppToken, pnToken)
13004
+ ** This is used to access token iToken of phrase iPhrase of the current
13005
+ ** query. Before returning, output parameter *ppToken is set to point
13006
+ ** to a buffer containing the requested token, and *pnToken to the
13007
+ ** size of this buffer in bytes.
13008
+ **
13009
+ ** If iPhrase or iToken are less than zero, or if iPhrase is greater than
13010
+ ** or equal to the number of phrases in the query as reported by
13011
+ ** xPhraseCount(), or if iToken is equal to or greater than the number of
13012
+ ** tokens in the phrase, SQLITE_RANGE is returned and *ppToken and *pnToken
13013
+ are both zeroed.
13014
+ **
13015
+ ** The output text is not a copy of the query text that specified the
13016
+ ** token. It is the output of the tokenizer module. For tokendata=1
13017
+ ** tables, this includes any embedded 0x00 and trailing data.
13018
+ **
13019
+ ** xInstToken(pFts5, iIdx, iToken, ppToken, pnToken)
13020
+ ** This is used to access token iToken of phrase hit iIdx within the
13021
+ ** current row. If iIdx is less than zero or greater than or equal to the
13022
+ ** value returned by xInstCount(), SQLITE_RANGE is returned. Otherwise,
13023
+ ** output variable (*ppToken) is set to point to a buffer containing the
13024
+ ** matching document token, and (*pnToken) to the size of that buffer in
13025
+ ** bytes. This API is not available if the specified token matches a
13026
+ ** prefix query term. In that case both output variables are always set
13027
+ ** to 0.
13028
+ **
13029
+ ** The output text is not a copy of the document text that was tokenized.
13030
+ ** It is the output of the tokenizer module. For tokendata=1 tables, this
13031
+ ** includes any embedded 0x00 and trailing data.
13032
+ **
13033
+ ** This API can be quite slow if used with an FTS5 table created with the
13034
+ ** "detail=none" or "detail=column" option.
12657
13035
  */
12658
13036
  struct Fts5ExtensionApi {
12659
13037
  int iVersion; /* Currently always set to 3 */
@@ -12691,6 +13069,13 @@ struct Fts5ExtensionApi {
12691
13069
 
12692
13070
  int (*xPhraseFirstColumn)(Fts5Context*, int iPhrase, Fts5PhraseIter*, int*);
12693
13071
  void (*xPhraseNextColumn)(Fts5Context*, Fts5PhraseIter*, int *piCol);
13072
+
13073
+ /* Below this point are iVersion>=3 only */
13074
+ int (*xQueryToken)(Fts5Context*,
13075
+ int iPhrase, int iToken,
13076
+ const char **ppToken, int *pnToken
13077
+ );
13078
+ int (*xInstToken)(Fts5Context*, int iIdx, int iToken, const char**, int*);
12694
13079
  };
12695
13080
 
12696
13081
  /*
@@ -12885,8 +13270,8 @@ struct Fts5ExtensionApi {
12885
13270
  ** as separate queries of the FTS index are required for each synonym.
12886
13271
  **
12887
13272
  ** When using methods (2) or (3), it is important that the tokenizer only
12888
- ** provide synonyms when tokenizing document text (method (2)) or query
12889
- ** text (method (3)), not both. Doing so will not cause any errors, but is
13273
+ ** provide synonyms when tokenizing document text (method (3)) or query
13274
+ ** text (method (2)), not both. Doing so will not cause any errors, but is
12890
13275
  ** inefficient.
12891
13276
  */
12892
13277
  typedef struct Fts5Tokenizer Fts5Tokenizer;
@@ -12934,7 +13319,7 @@ struct fts5_api {
12934
13319
  int (*xCreateTokenizer)(
12935
13320
  fts5_api *pApi,
12936
13321
  const char *zName,
12937
- void *pContext,
13322
+ void *pUserData,
12938
13323
  fts5_tokenizer *pTokenizer,
12939
13324
  void (*xDestroy)(void*)
12940
13325
  );
@@ -12943,7 +13328,7 @@ struct fts5_api {
12943
13328
  int (*xFindTokenizer)(
12944
13329
  fts5_api *pApi,
12945
13330
  const char *zName,
12946
- void **ppContext,
13331
+ void **ppUserData,
12947
13332
  fts5_tokenizer *pTokenizer
12948
13333
  );
12949
13334
 
@@ -12951,7 +13336,7 @@ struct fts5_api {
12951
13336
  int (*xCreateFunction)(
12952
13337
  fts5_api *pApi,
12953
13338
  const char *zName,
12954
- void *pContext,
13339
+ void *pUserData,
12955
13340
  fts5_extension_function xFunction,
12956
13341
  void (*xDestroy)(void*)
12957
13342
  );