| Index: third_party/sqlite/src/src/test_config.c
|
| diff --git a/third_party/sqlite/src/src/test_config.c b/third_party/sqlite/src/src/test_config.c
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..03d2f4e976ba666c55c6b0a02772c45310ad82d2
|
| --- /dev/null
|
| +++ b/third_party/sqlite/src/src/test_config.c
|
| @@ -0,0 +1,587 @@
|
| +/*
|
| +** 2007 May 7
|
| +**
|
| +** The author disclaims copyright to this source code. In place of
|
| +** a legal notice, here is a blessing:
|
| +**
|
| +** May you do good and not evil.
|
| +** May you find forgiveness for yourself and forgive others.
|
| +** May you share freely, never taking more than you give.
|
| +**
|
| +*************************************************************************
|
| +**
|
| +** This file contains code used for testing the SQLite system.
|
| +** None of the code in this file goes into a deliverable build.
|
| +**
|
| +** The focus of this file is providing the TCL testing layer
|
| +** access to compile-time constants.
|
| +*/
|
| +
|
| +#include "sqliteLimit.h"
|
| +
|
| +#include "sqliteInt.h"
|
| +#include "tcl.h"
|
| +#include <stdlib.h>
|
| +#include <string.h>
|
| +
|
| +/*
|
| +** Macro to stringify the results of the evaluation a pre-processor
|
| +** macro. i.e. so that STRINGVALUE(SQLITE_NOMEM) -> "7".
|
| +*/
|
| +#define STRINGVALUE2(x) #x
|
| +#define STRINGVALUE(x) STRINGVALUE2(x)
|
| +
|
| +/*
|
| +** This routine sets entries in the global ::sqlite_options() array variable
|
| +** according to the compile-time configuration of the database. Test
|
| +** procedures use this to determine when tests should be omitted.
|
| +*/
|
| +static void set_options(Tcl_Interp *interp){
|
| +#ifdef SQLITE_32BIT_ROWID
|
| + Tcl_SetVar2(interp, "sqlite_options", "rowid32", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "rowid32", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_CASE_SENSITIVE_LIKE
|
| + Tcl_SetVar2(interp, "sqlite_options","casesensitivelike","1",TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options","casesensitivelike","0",TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_DEBUG
|
| + Tcl_SetVar2(interp, "sqlite_options", "debug", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "debug", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_DISABLE_DIRSYNC
|
| + Tcl_SetVar2(interp, "sqlite_options", "dirsync", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "dirsync", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_DISABLE_LFS
|
| + Tcl_SetVar2(interp, "sqlite_options", "lfs", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "lfs", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if 1 /* def SQLITE_MEMDEBUG */
|
| + Tcl_SetVar2(interp, "sqlite_options", "memdebug", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "memdebug", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_MEMSYS3
|
| + Tcl_SetVar2(interp, "sqlite_options", "mem3", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "mem3", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_MEMSYS5
|
| + Tcl_SetVar2(interp, "sqlite_options", "mem5", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "mem5", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_MUTEX_OMIT
|
| + Tcl_SetVar2(interp, "sqlite_options", "mutex", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "mutex", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_MUTEX_NOOP
|
| + Tcl_SetVar2(interp, "sqlite_options", "mutex_noop", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "mutex_noop", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_ALTERTABLE
|
| + Tcl_SetVar2(interp, "sqlite_options", "altertable", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "altertable", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_ANALYZE
|
| + Tcl_SetVar2(interp, "sqlite_options", "analyze", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "analyze", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_ATOMIC_WRITE
|
| + Tcl_SetVar2(interp, "sqlite_options", "atomicwrite", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "atomicwrite", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_ATTACH
|
| + Tcl_SetVar2(interp, "sqlite_options", "attach", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "attach", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_AUTHORIZATION
|
| + Tcl_SetVar2(interp, "sqlite_options", "auth", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "auth", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_AUTOINCREMENT
|
| + Tcl_SetVar2(interp, "sqlite_options", "autoinc", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "autoinc", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_AUTOMATIC_INDEX
|
| + Tcl_SetVar2(interp, "sqlite_options", "autoindex", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "autoindex", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_AUTORESET
|
| + Tcl_SetVar2(interp, "sqlite_options", "autoreset", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "autoreset", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_AUTOVACUUM
|
| + Tcl_SetVar2(interp, "sqlite_options", "autovacuum", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "autovacuum", "1", TCL_GLOBAL_ONLY);
|
| +#endif /* SQLITE_OMIT_AUTOVACUUM */
|
| +#if !defined(SQLITE_DEFAULT_AUTOVACUUM)
|
| + Tcl_SetVar2(interp,"sqlite_options","default_autovacuum","0",TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "default_autovacuum",
|
| + STRINGVALUE(SQLITE_DEFAULT_AUTOVACUUM), TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_BETWEEN_OPTIMIZATION
|
| + Tcl_SetVar2(interp, "sqlite_options", "between_opt", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "between_opt", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_BUILTIN_TEST
|
| + Tcl_SetVar2(interp, "sqlite_options", "builtin_test", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "builtin_test", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_BLOB_LITERAL
|
| + Tcl_SetVar2(interp, "sqlite_options", "bloblit", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "bloblit", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_CAST
|
| + Tcl_SetVar2(interp, "sqlite_options", "cast", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "cast", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_CHECK
|
| + Tcl_SetVar2(interp, "sqlite_options", "check", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "check", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_COLUMN_METADATA
|
| + Tcl_SetVar2(interp, "sqlite_options", "columnmetadata", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "columnmetadata", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_OVERSIZE_CELL_CHECK
|
| + Tcl_SetVar2(interp, "sqlite_options", "oversize_cell_check", "1",
|
| + TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "oversize_cell_check", "0",
|
| + TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_COMPILEOPTION_DIAGS
|
| + Tcl_SetVar2(interp, "sqlite_options", "compileoption_diags", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "compileoption_diags", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_COMPLETE
|
| + Tcl_SetVar2(interp, "sqlite_options", "complete", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "complete", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_COMPOUND_SELECT
|
| + Tcl_SetVar2(interp, "sqlite_options", "compound", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "compound", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_CONFLICT_CLAUSE
|
| + Tcl_SetVar2(interp, "sqlite_options", "conflict", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "conflict", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if SQLITE_OS_UNIX
|
| + Tcl_SetVar2(interp, "sqlite_options", "crashtest", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "crashtest", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_DATETIME_FUNCS
|
| + Tcl_SetVar2(interp, "sqlite_options", "datetime", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "datetime", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_DECLTYPE
|
| + Tcl_SetVar2(interp, "sqlite_options", "decltype", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "decltype", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_DEPRECATED
|
| + Tcl_SetVar2(interp, "sqlite_options", "deprecated", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "deprecated", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_DISKIO
|
| + Tcl_SetVar2(interp, "sqlite_options", "diskio", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "diskio", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_EXPLAIN
|
| + Tcl_SetVar2(interp, "sqlite_options", "explain", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "explain", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_FLOATING_POINT
|
| + Tcl_SetVar2(interp, "sqlite_options", "floatingpoint", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "floatingpoint", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_FOREIGN_KEY
|
| + Tcl_SetVar2(interp, "sqlite_options", "foreignkey", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "foreignkey", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_FTS1
|
| + Tcl_SetVar2(interp, "sqlite_options", "fts1", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "fts1", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_FTS2
|
| + Tcl_SetVar2(interp, "sqlite_options", "fts2", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "fts2", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_FTS3
|
| + Tcl_SetVar2(interp, "sqlite_options", "fts3", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "fts3", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_GET_TABLE
|
| + Tcl_SetVar2(interp, "sqlite_options", "gettable", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "gettable", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_ICU
|
| + Tcl_SetVar2(interp, "sqlite_options", "icu", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "icu", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_INCRBLOB
|
| + Tcl_SetVar2(interp, "sqlite_options", "incrblob", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "incrblob", "1", TCL_GLOBAL_ONLY);
|
| +#endif /* SQLITE_OMIT_AUTOVACUUM */
|
| +
|
| +#ifdef SQLITE_OMIT_INTEGRITY_CHECK
|
| + Tcl_SetVar2(interp, "sqlite_options", "integrityck", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "integrityck", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if defined(SQLITE_DEFAULT_FILE_FORMAT) && SQLITE_DEFAULT_FILE_FORMAT==1
|
| + Tcl_SetVar2(interp, "sqlite_options", "legacyformat", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "legacyformat", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_LIKE_OPTIMIZATION
|
| + Tcl_SetVar2(interp, "sqlite_options", "like_opt", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "like_opt", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_LOAD_EXTENSION
|
| + Tcl_SetVar2(interp, "sqlite_options", "load_ext", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "load_ext", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_LOCALTIME
|
| + Tcl_SetVar2(interp, "sqlite_options", "localtime", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "localtime", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_LOOKASIDE
|
| + Tcl_SetVar2(interp, "sqlite_options", "lookaside", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "lookaside", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +Tcl_SetVar2(interp, "sqlite_options", "long_double",
|
| + sizeof(LONGDOUBLE_TYPE)>sizeof(double) ? "1" : "0",
|
| + TCL_GLOBAL_ONLY);
|
| +
|
| +#ifdef SQLITE_OMIT_MEMORYDB
|
| + Tcl_SetVar2(interp, "sqlite_options", "memorydb", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "memorydb", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_MEMORY_MANAGEMENT
|
| + Tcl_SetVar2(interp, "sqlite_options", "memorymanage", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "memorymanage", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_OR_OPTIMIZATION
|
| + Tcl_SetVar2(interp, "sqlite_options", "or_opt", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "or_opt", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_PAGER_PRAGMAS
|
| + Tcl_SetVar2(interp, "sqlite_options", "pager_pragmas", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "pager_pragmas", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if defined(SQLITE_OMIT_PRAGMA) || defined(SQLITE_OMIT_FLAG_PRAGMAS)
|
| + Tcl_SetVar2(interp, "sqlite_options", "pragma", "0", TCL_GLOBAL_ONLY);
|
| + Tcl_SetVar2(interp, "sqlite_options", "integrityck", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "pragma", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_PROGRESS_CALLBACK
|
| + Tcl_SetVar2(interp, "sqlite_options", "progress", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "progress", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_REINDEX
|
| + Tcl_SetVar2(interp, "sqlite_options", "reindex", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "reindex", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_RTREE
|
| + Tcl_SetVar2(interp, "sqlite_options", "rtree", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "rtree", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_SCHEMA_PRAGMAS
|
| + Tcl_SetVar2(interp, "sqlite_options", "schema_pragmas", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "schema_pragmas", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_SCHEMA_VERSION_PRAGMAS
|
| + Tcl_SetVar2(interp, "sqlite_options", "schema_version", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "schema_version", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_ENABLE_STAT2
|
| + Tcl_SetVar2(interp, "sqlite_options", "stat2", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "stat2", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if !defined(SQLITE_ENABLE_LOCKING_STYLE)
|
| +# if defined(__APPLE__)
|
| +# define SQLITE_ENABLE_LOCKING_STYLE 1
|
| +# else
|
| +# define SQLITE_ENABLE_LOCKING_STYLE 0
|
| +# endif
|
| +#endif
|
| +#if SQLITE_ENABLE_LOCKING_STYLE && defined(__APPLE__)
|
| + Tcl_SetVar2(interp,"sqlite_options","lock_proxy_pragmas","1",TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp,"sqlite_options","lock_proxy_pragmas","0",TCL_GLOBAL_ONLY);
|
| +#endif
|
| +#if defined(SQLITE_PREFER_PROXY_LOCKING) && defined(__APPLE__)
|
| + Tcl_SetVar2(interp,"sqlite_options","prefer_proxy_locking","1",TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp,"sqlite_options","prefer_proxy_locking","0",TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +
|
| +#ifdef SQLITE_OMIT_SHARED_CACHE
|
| + Tcl_SetVar2(interp, "sqlite_options", "shared_cache", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "shared_cache", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_SUBQUERY
|
| + Tcl_SetVar2(interp, "sqlite_options", "subquery", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "subquery", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_TCL_VARIABLE
|
| + Tcl_SetVar2(interp, "sqlite_options", "tclvar", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "tclvar", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| + Tcl_SetVar2(interp, "sqlite_options", "threadsafe",
|
| + STRINGVALUE(SQLITE_THREADSAFE), TCL_GLOBAL_ONLY);
|
| + assert( sqlite3_threadsafe()==SQLITE_THREADSAFE );
|
| +
|
| +#ifdef SQLITE_OMIT_TEMPDB
|
| + Tcl_SetVar2(interp, "sqlite_options", "tempdb", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "tempdb", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_TRACE
|
| + Tcl_SetVar2(interp, "sqlite_options", "trace", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "trace", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_TRIGGER
|
| + Tcl_SetVar2(interp, "sqlite_options", "trigger", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "trigger", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_TRUNCATE_OPTIMIZATION
|
| + Tcl_SetVar2(interp, "sqlite_options", "truncate_opt", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "truncate_opt", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_UTF16
|
| + Tcl_SetVar2(interp, "sqlite_options", "utf16", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "utf16", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if defined(SQLITE_OMIT_VACUUM) || defined(SQLITE_OMIT_ATTACH)
|
| + Tcl_SetVar2(interp, "sqlite_options", "vacuum", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "vacuum", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_VIEW
|
| + Tcl_SetVar2(interp, "sqlite_options", "view", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "view", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_VIRTUALTABLE
|
| + Tcl_SetVar2(interp, "sqlite_options", "vtab", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "vtab", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_WAL
|
| + Tcl_SetVar2(interp, "sqlite_options", "wal", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "wal", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_OMIT_WSD
|
| + Tcl_SetVar2(interp, "sqlite_options", "wsd", "0", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "wsd", "1", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if defined(SQLITE_ENABLE_UPDATE_DELETE_LIMIT) && !defined(SQLITE_OMIT_SUBQUERY)
|
| + Tcl_SetVar2(interp, "sqlite_options", "update_delete_limit", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "update_delete_limit", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#if defined(SQLITE_ENABLE_UNLOCK_NOTIFY)
|
| + Tcl_SetVar2(interp, "sqlite_options", "unlock_notify", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "unlock_notify", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_SECURE_DELETE
|
| + Tcl_SetVar2(interp, "sqlite_options", "secure_delete", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "secure_delete", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef SQLITE_MULTIPLEX_EXT_OVWR
|
| + Tcl_SetVar2(interp, "sqlite_options", "multiplex_ext_overwrite", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "multiplex_ext_overwrite", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#ifdef YYTRACKMAXSTACKDEPTH
|
| + Tcl_SetVar2(interp, "sqlite_options", "yytrackmaxstackdepth", "1", TCL_GLOBAL_ONLY);
|
| +#else
|
| + Tcl_SetVar2(interp, "sqlite_options", "yytrackmaxstackdepth", "0", TCL_GLOBAL_ONLY);
|
| +#endif
|
| +
|
| +#define LINKVAR(x) { \
|
| + static const int cv_ ## x = SQLITE_ ## x; \
|
| + Tcl_LinkVar(interp, "SQLITE_" #x, (char *)&(cv_ ## x), \
|
| + TCL_LINK_INT | TCL_LINK_READ_ONLY); }
|
| +
|
| + LINKVAR( MAX_LENGTH );
|
| + LINKVAR( MAX_COLUMN );
|
| + LINKVAR( MAX_SQL_LENGTH );
|
| + LINKVAR( MAX_EXPR_DEPTH );
|
| + LINKVAR( MAX_COMPOUND_SELECT );
|
| + LINKVAR( MAX_VDBE_OP );
|
| + LINKVAR( MAX_FUNCTION_ARG );
|
| + LINKVAR( MAX_VARIABLE_NUMBER );
|
| + LINKVAR( MAX_PAGE_SIZE );
|
| + LINKVAR( MAX_PAGE_COUNT );
|
| + LINKVAR( MAX_LIKE_PATTERN_LENGTH );
|
| + LINKVAR( MAX_TRIGGER_DEPTH );
|
| + LINKVAR( DEFAULT_TEMP_CACHE_SIZE );
|
| + LINKVAR( DEFAULT_CACHE_SIZE );
|
| + LINKVAR( DEFAULT_PAGE_SIZE );
|
| + LINKVAR( DEFAULT_FILE_FORMAT );
|
| + LINKVAR( MAX_ATTACHED );
|
| +
|
| + {
|
| + static const int cv_TEMP_STORE = SQLITE_TEMP_STORE;
|
| + Tcl_LinkVar(interp, "TEMP_STORE", (char *)&(cv_TEMP_STORE),
|
| + TCL_LINK_INT | TCL_LINK_READ_ONLY);
|
| + }
|
| +}
|
| +
|
| +
|
| +/*
|
| +** Register commands with the TCL interpreter.
|
| +*/
|
| +int Sqliteconfig_Init(Tcl_Interp *interp){
|
| + set_options(interp);
|
| + return TCL_OK;
|
| +}
|
|
|