mirror of
https://github.com/sqlite/sqlite.git
synced 2025-08-05 15:55:57 +03:00
Allow the sqlite3_config() interface to be invoked at any time for a few
choosen options: SQLITE_CONFIG_LOG, SQLITE_CONFIG_URI, and SQLITE_CONFIG_PCACHE_HDRSZ. This list will likely change before release. FossilOrigin-Name: e1702eb48d13c7c9b7605f1e77242672222c53059edcdc4e9cea59510715822a
This commit is contained in:
19
manifest
19
manifest
@@ -1,5 +1,5 @@
|
|||||||
C Provide\s-DHAVE_LOG2=0\sand\s-DHAVE_LOG10=0\scompile-time\soptions\sfor\suse\son\ssystems\nthat\slack\sthe\slog2()\sand\slog10()\sstandard\smath\slibrary\sroutines,\sto\scause\nSQLite\sto\ssubstitute\sits\sown\salternatives.
|
C Allow\sthe\ssqlite3_config()\sinterface\sto\sbe\sinvoked\sat\sany\stime\sfor\sa\sfew\nchoosen\soptions:\s\sSQLITE_CONFIG_LOG,\sSQLITE_CONFIG_URI,\sand\nSQLITE_CONFIG_PCACHE_HDRSZ.\s\sThis\slist\swill\slikely\schange\sbefore\srelease.
|
||||||
D 2023-02-23T01:52:54.076
|
D 2023-02-23T14:22:29.829
|
||||||
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
|
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
|
||||||
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
|
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
|
||||||
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
|
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
|
||||||
@@ -584,7 +584,7 @@ F src/insert.c 1b11a2e33ee52db93c02fddac67e39d00161d61b69fac2675b82f2aa68c1b61c
|
|||||||
F src/json.c c85ed6fce06f43d414b0d7fff64749d43a0dbd1067123ee407bd3a0752454161
|
F src/json.c c85ed6fce06f43d414b0d7fff64749d43a0dbd1067123ee407bd3a0752454161
|
||||||
F src/legacy.c d7874bc885906868cd51e6c2156698f2754f02d9eee1bae2d687323c3ca8e5aa
|
F src/legacy.c d7874bc885906868cd51e6c2156698f2754f02d9eee1bae2d687323c3ca8e5aa
|
||||||
F src/loadext.c b04eb648cedc45efe4298e1ef439ac4f0096ae27b5f01accb0a1f49d57789128
|
F src/loadext.c b04eb648cedc45efe4298e1ef439ac4f0096ae27b5f01accb0a1f49d57789128
|
||||||
F src/main.c f5ed7b748d7e54b96ac577a9d87af9461f13f092bbe684d473448010333402dc
|
F src/main.c 437e97a14936763b42e013f02495ef9c0bca6654073321c2bdd844cb4ec441f5
|
||||||
F src/malloc.c 47b82c5daad557d9b963e3873e99c22570fb470719082c6658bf64e3012f7d23
|
F src/malloc.c 47b82c5daad557d9b963e3873e99c22570fb470719082c6658bf64e3012f7d23
|
||||||
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
||||||
F src/mem1.c c12a42539b1ba105e3707d0e628ad70e611040d8f5e38cf942cee30c867083de
|
F src/mem1.c c12a42539b1ba105e3707d0e628ad70e611040d8f5e38cf942cee30c867083de
|
||||||
@@ -623,10 +623,10 @@ F src/resolve.c d62c5665279cc7485f9d45b5e20911cc7b19c203f268321a90d05d74f4725750
|
|||||||
F src/rowset.c ba9515a922af32abe1f7d39406b9d35730ed65efab9443dc5702693b60854c92
|
F src/rowset.c ba9515a922af32abe1f7d39406b9d35730ed65efab9443dc5702693b60854c92
|
||||||
F src/select.c 39ec68e3e88064c1ce76eb8d3fc7dbf97a95a54ff0c37e22d94df2e33550da6a
|
F src/select.c 39ec68e3e88064c1ce76eb8d3fc7dbf97a95a54ff0c37e22d94df2e33550da6a
|
||||||
F src/shell.c.in 6f36f5ca05f1bebf74935a7fcf2dce983016e807a09cbd752a673583ad7da087
|
F src/shell.c.in 6f36f5ca05f1bebf74935a7fcf2dce983016e807a09cbd752a673583ad7da087
|
||||||
F src/sqlite.h.in 662a2fa083d093896b92560c871dea6d86792b49dc4bf7b4e8dbeca8e7171488
|
F src/sqlite.h.in 3bdc92831511442cad4de5243b619ba8b887bb102bb464bbc5436df7e2e6568a
|
||||||
F src/sqlite3.rc 5121c9e10c3964d5755191c80dd1180c122fc3a8
|
F src/sqlite3.rc 5121c9e10c3964d5755191c80dd1180c122fc3a8
|
||||||
F src/sqlite3ext.h da473ce2b3d0ae407a6300c4a164589b9a6bfdbec9462688a8593ff16f3bb6e4
|
F src/sqlite3ext.h da473ce2b3d0ae407a6300c4a164589b9a6bfdbec9462688a8593ff16f3bb6e4
|
||||||
F src/sqliteInt.h 25f38ade2d93828231d6cd8614f635c0b084bee004360d970542861ad2e3e3d8
|
F src/sqliteInt.h cb7182dcdc9910d5f1352c90762545cc5ffb79c4a47f4ae7c5ee044fdb80423b
|
||||||
F src/sqliteLimit.h d7323ffea5208c6af2734574bae933ca8ed2ab728083caa117c9738581a31657
|
F src/sqliteLimit.h d7323ffea5208c6af2734574bae933ca8ed2ab728083caa117c9738581a31657
|
||||||
F src/status.c 160c445d7d28c984a0eae38c144f6419311ed3eace59b44ac6dafc20db4af749
|
F src/status.c 160c445d7d28c984a0eae38c144f6419311ed3eace59b44ac6dafc20db4af749
|
||||||
F src/table.c 0f141b58a16de7e2fbe81c308379e7279f4c6b50eb08efeec5892794a0ba30d1
|
F src/table.c 0f141b58a16de7e2fbe81c308379e7279f4c6b50eb08efeec5892794a0ba30d1
|
||||||
@@ -2046,8 +2046,11 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
|
|||||||
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
|
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
|
||||||
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
|
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
|
||||||
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
|
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
|
||||||
P a4aacdd323a854d771c8cb1e2e4cfc4fb66b0020cfed23525733603605f5c63b
|
P 7ee22f95e7a7d8650f961f20e304e56c7813e624f05655d7392ca9347748270f
|
||||||
R d9f0889f326fe560e4856fa0dae980c0
|
R dd36b4ed22c075361723563dc0d19a92
|
||||||
|
T *branch * anytime-config
|
||||||
|
T *sym-anytime-config *
|
||||||
|
T -sym-trunk *
|
||||||
U drh
|
U drh
|
||||||
Z c988455137d4c4b07349732581414345
|
Z be923bc0bbf1d0d6df34f343f10e1fcc
|
||||||
# Remove this line to create a well-formed Fossil manifest.
|
# Remove this line to create a well-formed Fossil manifest.
|
||||||
|
@@ -1 +1 @@
|
|||||||
7ee22f95e7a7d8650f961f20e304e56c7813e624f05655d7392ca9347748270f
|
e1702eb48d13c7c9b7605f1e77242672222c53059edcdc4e9cea59510715822a
|
36
src/main.c
36
src/main.c
@@ -430,9 +430,23 @@ int sqlite3_config(int op, ...){
|
|||||||
va_list ap;
|
va_list ap;
|
||||||
int rc = SQLITE_OK;
|
int rc = SQLITE_OK;
|
||||||
|
|
||||||
/* sqlite3_config() shall return SQLITE_MISUSE if it is invoked while
|
/* sqlite3_config() normally returns SQLITE_MISUSE if it is invoked while
|
||||||
** the SQLite library is in use. */
|
** the SQLite library is in use. Except, a few selected opcodes
|
||||||
if( sqlite3GlobalConfig.isInit ) return SQLITE_MISUSE_BKPT;
|
** are allowed.
|
||||||
|
*/
|
||||||
|
if( sqlite3GlobalConfig.isInit ){
|
||||||
|
static const u64 mAnytimeConfigOption = 0
|
||||||
|
| MASKBIT64( SQLITE_CONFIG_LOG )
|
||||||
|
| MASKBIT64( SQLITE_CONFIG_URI )
|
||||||
|
| MASKBIT64( SQLITE_CONFIG_PCACHE_HDRSZ )
|
||||||
|
;
|
||||||
|
if( op<0 || op>63 || (MASKBIT64(op) & mAnytimeConfigOption)==0 ){
|
||||||
|
return SQLITE_MISUSE_BKPT;
|
||||||
|
}
|
||||||
|
testcase( op==SQLITE_CONFIG_LOG );
|
||||||
|
testcase( op==SQLITE_CONFIG_URI );
|
||||||
|
testcase( op==SQLITE_CONFIG_PCACHE_HDRSZ );
|
||||||
|
}
|
||||||
|
|
||||||
va_start(ap, op);
|
va_start(ap, op);
|
||||||
switch( op ){
|
switch( op ){
|
||||||
@@ -501,6 +515,7 @@ int sqlite3_config(int op, ...){
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SQLITE_CONFIG_MEMSTATUS: {
|
case SQLITE_CONFIG_MEMSTATUS: {
|
||||||
|
assert( !sqlite3GlobalConfig.isInit ); /* Cannot change at runtime */
|
||||||
/* EVIDENCE-OF: R-61275-35157 The SQLITE_CONFIG_MEMSTATUS option takes
|
/* EVIDENCE-OF: R-61275-35157 The SQLITE_CONFIG_MEMSTATUS option takes
|
||||||
** single argument of type int, interpreted as a boolean, which enables
|
** single argument of type int, interpreted as a boolean, which enables
|
||||||
** or disables the collection of memory allocation statistics. */
|
** or disables the collection of memory allocation statistics. */
|
||||||
@@ -624,8 +639,10 @@ int sqlite3_config(int op, ...){
|
|||||||
** sqlite3GlobalConfig.xLog = va_arg(ap, void(*)(void*,int,const char*));
|
** sqlite3GlobalConfig.xLog = va_arg(ap, void(*)(void*,int,const char*));
|
||||||
*/
|
*/
|
||||||
typedef void(*LOGFUNC_t)(void*,int,const char*);
|
typedef void(*LOGFUNC_t)(void*,int,const char*);
|
||||||
sqlite3GlobalConfig.xLog = va_arg(ap, LOGFUNC_t);
|
LOGFUNC_t xLog = va_arg(ap, LOGFUNC_t);
|
||||||
sqlite3GlobalConfig.pLogArg = va_arg(ap, void*);
|
void *pLogArg = va_arg(ap, void*);
|
||||||
|
AtomicStore(&sqlite3GlobalConfig.xLog, xLog);
|
||||||
|
AtomicStore(&sqlite3GlobalConfig.pLogArg, pLogArg);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -639,7 +656,8 @@ int sqlite3_config(int op, ...){
|
|||||||
** argument of type int. If non-zero, then URI handling is globally
|
** argument of type int. If non-zero, then URI handling is globally
|
||||||
** enabled. If the parameter is zero, then URI handling is globally
|
** enabled. If the parameter is zero, then URI handling is globally
|
||||||
** disabled. */
|
** disabled. */
|
||||||
sqlite3GlobalConfig.bOpenUri = va_arg(ap, int);
|
int bOpenUri = va_arg(ap, int);
|
||||||
|
AtomicStore(&sqlite3GlobalConfig.bOpenUri, bOpenUri);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2939,9 +2957,9 @@ int sqlite3ParseUri(
|
|||||||
|
|
||||||
assert( *pzErrMsg==0 );
|
assert( *pzErrMsg==0 );
|
||||||
|
|
||||||
if( ((flags & SQLITE_OPEN_URI) /* IMP: R-48725-32206 */
|
if( ((flags & SQLITE_OPEN_URI) /* IMP: R-48725-32206 */
|
||||||
|| sqlite3GlobalConfig.bOpenUri) /* IMP: R-51689-46548 */
|
|| AtomicLoad(&sqlite3GlobalConfig.bOpenUri)) /* IMP: R-51689-46548 */
|
||||||
&& nUri>=5 && memcmp(zUri, "file:", 5)==0 /* IMP: R-57884-37496 */
|
&& nUri>=5 && memcmp(zUri, "file:", 5)==0 /* IMP: R-57884-37496 */
|
||||||
){
|
){
|
||||||
char *zOpt;
|
char *zOpt;
|
||||||
int eState; /* Parser state when parsing URI */
|
int eState; /* Parser state when parsing URI */
|
||||||
|
@@ -1655,20 +1655,23 @@ int sqlite3_os_end(void);
|
|||||||
** must ensure that no other SQLite interfaces are invoked by other
|
** must ensure that no other SQLite interfaces are invoked by other
|
||||||
** threads while sqlite3_config() is running.</b>
|
** threads while sqlite3_config() is running.</b>
|
||||||
**
|
**
|
||||||
** The sqlite3_config() interface
|
|
||||||
** may only be invoked prior to library initialization using
|
|
||||||
** [sqlite3_initialize()] or after shutdown by [sqlite3_shutdown()].
|
|
||||||
** ^If sqlite3_config() is called after [sqlite3_initialize()] and before
|
|
||||||
** [sqlite3_shutdown()] then it will return SQLITE_MISUSE.
|
|
||||||
** Note, however, that ^sqlite3_config() can be called as part of the
|
|
||||||
** implementation of an application-defined [sqlite3_os_init()].
|
|
||||||
**
|
|
||||||
** The first argument to sqlite3_config() is an integer
|
** The first argument to sqlite3_config() is an integer
|
||||||
** [configuration option] that determines
|
** [configuration option] that determines
|
||||||
** what property of SQLite is to be configured. Subsequent arguments
|
** what property of SQLite is to be configured. Subsequent arguments
|
||||||
** vary depending on the [configuration option]
|
** vary depending on the [configuration option]
|
||||||
** in the first argument.
|
** in the first argument.
|
||||||
**
|
**
|
||||||
|
** For most configuration options, the sqlite3_config() interface
|
||||||
|
** may only be invoked prior to library initialization using
|
||||||
|
** [sqlite3_initialize()] or after shutdown by [sqlite3_shutdown()].
|
||||||
|
** The exceptional configuration options that may be invoked at any time
|
||||||
|
** are called "anytime configuration options".
|
||||||
|
** ^If sqlite3_config() is called after [sqlite3_initialize()] and before
|
||||||
|
** [sqlite3_shutdown()] with a first argument that is not an anytime
|
||||||
|
** configuration option, then the sqlite3_config() call will return SQLITE_MISUSE.
|
||||||
|
** Note, however, that ^sqlite3_config() can be called as part of the
|
||||||
|
** implementation of an application-defined [sqlite3_os_init()].
|
||||||
|
**
|
||||||
** ^When a configuration option is set, sqlite3_config() returns [SQLITE_OK].
|
** ^When a configuration option is set, sqlite3_config() returns [SQLITE_OK].
|
||||||
** ^If the option is unknown or SQLite is unable to set the option
|
** ^If the option is unknown or SQLite is unable to set the option
|
||||||
** then this routine returns a non-zero [error code].
|
** then this routine returns a non-zero [error code].
|
||||||
@@ -1776,6 +1779,24 @@ struct sqlite3_mem_methods {
|
|||||||
** These constants are the available integer configuration options that
|
** These constants are the available integer configuration options that
|
||||||
** can be passed as the first argument to the [sqlite3_config()] interface.
|
** can be passed as the first argument to the [sqlite3_config()] interface.
|
||||||
**
|
**
|
||||||
|
** Most of the configuration options for sqlite3_config()
|
||||||
|
** will only work if invoked prior to [sqlite3_initialize()] or after
|
||||||
|
** [sqlite3_shutdown()]. The few exceptions to this rule are called
|
||||||
|
** "anytime configuration options".
|
||||||
|
** ^Calling [sqlite3_config()] with a first argument that is not an
|
||||||
|
** anytime configuration option in between calls to [sqlite3_initialize()] and
|
||||||
|
** [sqlite3_shutdown()] is a no-op that returns SQLITE_MISUSE.
|
||||||
|
**
|
||||||
|
** The set of anytime configuration options can change (by insertions
|
||||||
|
** and/or deletions) from one release of SQLite to the next.
|
||||||
|
** As of SQLite version 3.42.0, the complete set of anytime configuration
|
||||||
|
** options is:
|
||||||
|
** <ul>
|
||||||
|
** <li> SQLITE_CONFIG_LOG
|
||||||
|
** <li> SQLITE_CONFIG_URI
|
||||||
|
** <li> SQLITE_CONFIG_PCACHE_HDRSZ
|
||||||
|
** </ul>
|
||||||
|
**
|
||||||
** New configuration options may be added in future releases of SQLite.
|
** New configuration options may be added in future releases of SQLite.
|
||||||
** Existing configuration options might be discontinued. Applications
|
** Existing configuration options might be discontinued. Applications
|
||||||
** should check the return code from [sqlite3_config()] to make sure that
|
** should check the return code from [sqlite3_config()] to make sure that
|
||||||
|
@@ -224,8 +224,8 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** WAL mode depends on atomic aligned 32-bit loads and stores in a few
|
** A few places in the code require atomic load/store of aligned
|
||||||
** places. The following macros try to make this explicit.
|
** integer values.
|
||||||
*/
|
*/
|
||||||
#ifndef __has_extension
|
#ifndef __has_extension
|
||||||
# define __has_extension(x) 0 /* compatibility with non-clang compilers */
|
# define __has_extension(x) 0 /* compatibility with non-clang compilers */
|
||||||
|
Reference in New Issue
Block a user