4 ** The author disclaims copyright to this source code. In place of
5 ** a legal notice, here is a blessing:
7 ** May you do good and not evil.
8 ** May you find forgiveness for yourself and forgive others.
9 ** May you share freely, never taking more than you give.
11 *************************************************************************
13 ** This file contains code used for testing the SQLite system.
14 ** None of the code in this file goes into a deliverable build.
16 ** The focus of this file is providing the TCL testing layer
17 ** access to compile-time constants.
20 #include "sqliteLimit.h"
22 #include "sqliteInt.h"
27 #if defined(INCLUDE_SQLITE_TCL_H)
28 # include "sqlite_tcl.h"
36 ** Macro to stringify the results of the evaluation a pre-processor
37 ** macro. i.e. so that STRINGVALUE(SQLITE_NOMEM) -> "7".
39 #define STRINGVALUE2(x) #x
40 #define STRINGVALUE(x) STRINGVALUE2(x)
43 ** This routine sets entries in the global ::sqlite_options() array variable
44 ** according to the compile-time configuration of the database. Test
45 ** procedures use this to determine when tests should be omitted.
47 static void set_options(Tcl_Interp
*interp
){
48 #if HAVE_MALLOC_USABLE_SIZE
49 Tcl_SetVar2(interp
, "sqlite_options", "malloc_usable_size", "1",
52 Tcl_SetVar2(interp
, "sqlite_options", "malloc_usable_size", "0",
56 #ifdef SQLITE_32BIT_ROWID
57 Tcl_SetVar2(interp
, "sqlite_options", "rowid32", "1", TCL_GLOBAL_ONLY
);
59 Tcl_SetVar2(interp
, "sqlite_options", "rowid32", "0", TCL_GLOBAL_ONLY
);
62 #ifdef SQLITE_ALLOW_ROWID_IN_VIEW
64 interp
, "sqlite_options", "allow_rowid_in_view", "1", TCL_GLOBAL_ONLY
);
67 interp
, "sqlite_options", "allow_rowid_in_view", "0", TCL_GLOBAL_ONLY
);
70 #ifdef SQLITE_CASE_SENSITIVE_LIKE
71 Tcl_SetVar2(interp
, "sqlite_options","casesensitivelike","1",TCL_GLOBAL_ONLY
);
73 Tcl_SetVar2(interp
, "sqlite_options","casesensitivelike","0",TCL_GLOBAL_ONLY
);
76 #ifdef CONFIG_SLOWDOWN_FACTOR
77 Tcl_SetVar2(interp
, "sqlite_options","configslower",
78 STRINGVALUE(CONFIG_SLOWDOWN_FACTOR
),TCL_GLOBAL_ONLY
);
80 Tcl_SetVar2(interp
, "sqlite_options","configslower","1.0",TCL_GLOBAL_ONLY
);
83 #if !SQLITE_OS_WINCE && !SQLITE_OS_WINRT
84 Tcl_SetVar2(interp
, "sqlite_options", "curdir", "1", TCL_GLOBAL_ONLY
);
86 Tcl_SetVar2(interp
, "sqlite_options", "curdir", "0", TCL_GLOBAL_ONLY
);
89 #ifdef SQLITE_WIN32_MALLOC
90 Tcl_SetVar2(interp
, "sqlite_options", "win32malloc", "1", TCL_GLOBAL_ONLY
);
92 Tcl_SetVar2(interp
, "sqlite_options", "win32malloc", "0", TCL_GLOBAL_ONLY
);
96 Tcl_SetVar2(interp
, "sqlite_options", "debug", "1", TCL_GLOBAL_ONLY
);
98 Tcl_SetVar2(interp
, "sqlite_options", "debug", "0", TCL_GLOBAL_ONLY
);
101 #ifdef SQLITE_DEFAULT_CKPTFULLFSYNC
102 Tcl_SetVar2(interp
, "sqlite_options", "default_ckptfullfsync",
103 SQLITE_DEFAULT_CKPTFULLFSYNC
? "1" : "0", TCL_GLOBAL_ONLY
);
105 Tcl_SetVar2(interp
, "sqlite_options", "default_ckptfullfsync", "0", TCL_GLOBAL_ONLY
);
108 #ifdef SQLITE_DIRECT_OVERFLOW_READ
109 Tcl_SetVar2(interp
, "sqlite_options", "direct_read", "1", TCL_GLOBAL_ONLY
);
111 Tcl_SetVar2(interp
, "sqlite_options", "direct_read", "0", TCL_GLOBAL_ONLY
);
114 #ifdef SQLITE_DISABLE_DIRSYNC
115 Tcl_SetVar2(interp
, "sqlite_options", "dirsync", "0", TCL_GLOBAL_ONLY
);
117 Tcl_SetVar2(interp
, "sqlite_options", "dirsync", "1", TCL_GLOBAL_ONLY
);
120 #ifdef SQLITE_DISABLE_LFS
121 Tcl_SetVar2(interp
, "sqlite_options", "lfs", "0", TCL_GLOBAL_ONLY
);
123 Tcl_SetVar2(interp
, "sqlite_options", "lfs", "1", TCL_GLOBAL_ONLY
);
126 #ifdef SQLITE_DISABLE_PAGECACHE_OVERFLOW_STATS
127 Tcl_SetVar2(interp
, "sqlite_options", "pagecache_overflow_stats","0",TCL_GLOBAL_ONLY
);
129 Tcl_SetVar2(interp
, "sqlite_options", "pagecache_overflow_stats","1",TCL_GLOBAL_ONLY
);
132 #if SQLITE_MAX_MMAP_SIZE>0
133 Tcl_SetVar2(interp
, "sqlite_options", "mmap", "1", TCL_GLOBAL_ONLY
);
135 Tcl_SetVar2(interp
, "sqlite_options", "mmap", "0", TCL_GLOBAL_ONLY
);
138 Tcl_SetVar2(interp
, "sqlite_options", "worker_threads",
139 STRINGVALUE(SQLITE_MAX_WORKER_THREADS
), TCL_GLOBAL_ONLY
142 #ifdef SQLITE_MEMDEBUG
143 Tcl_SetVar2(interp
, "sqlite_options", "memdebug", "1", TCL_GLOBAL_ONLY
);
145 Tcl_SetVar2(interp
, "sqlite_options", "memdebug", "0", TCL_GLOBAL_ONLY
);
148 #ifdef SQLITE_ENABLE_8_3_NAMES
149 Tcl_SetVar2(interp
, "sqlite_options", "8_3_names", "1", TCL_GLOBAL_ONLY
);
151 Tcl_SetVar2(interp
, "sqlite_options", "8_3_names", "0", TCL_GLOBAL_ONLY
);
154 #ifdef SQLITE_ENABLE_CURSOR_HINTS
155 Tcl_SetVar2(interp
, "sqlite_options", "cursorhints", "1", TCL_GLOBAL_ONLY
);
157 Tcl_SetVar2(interp
, "sqlite_options", "cursorhints", "0", TCL_GLOBAL_ONLY
);
160 #ifdef SQLITE_ENABLE_HIDDEN_COLUMNS
161 Tcl_SetVar2(interp
, "sqlite_options", "hiddencolumns", "1", TCL_GLOBAL_ONLY
);
163 Tcl_SetVar2(interp
, "sqlite_options", "hiddencolumns", "0", TCL_GLOBAL_ONLY
);
166 #ifndef SQLITE_OMIT_DESERIALIZE
167 Tcl_SetVar2(interp
, "sqlite_options", "deserialize", "1", TCL_GLOBAL_ONLY
);
169 Tcl_SetVar2(interp
, "sqlite_options", "deserialize", "0", TCL_GLOBAL_ONLY
);
172 #ifdef SQLITE_ENABLE_MATH_FUNCTIONS
173 Tcl_SetVar2(interp
, "sqlite_options", "mathlib", "1", TCL_GLOBAL_ONLY
);
175 Tcl_SetVar2(interp
, "sqlite_options", "mathlib", "0", TCL_GLOBAL_ONLY
);
178 #ifdef SQLITE_ENABLE_MEMSYS3
179 Tcl_SetVar2(interp
, "sqlite_options", "mem3", "1", TCL_GLOBAL_ONLY
);
181 Tcl_SetVar2(interp
, "sqlite_options", "mem3", "0", TCL_GLOBAL_ONLY
);
184 #ifdef SQLITE_ENABLE_MEMSYS5
185 Tcl_SetVar2(interp
, "sqlite_options", "mem5", "1", TCL_GLOBAL_ONLY
);
187 Tcl_SetVar2(interp
, "sqlite_options", "mem5", "0", TCL_GLOBAL_ONLY
);
190 #ifdef SQLITE_ENABLE_OFFSET_SQL_FUNC
191 Tcl_SetVar2(interp
, "sqlite_options", "offset_sql_func","1",TCL_GLOBAL_ONLY
);
193 Tcl_SetVar2(interp
, "sqlite_options", "offset_sql_func","0",TCL_GLOBAL_ONLY
);
196 #ifdef SQLITE_ENABLE_PREUPDATE_HOOK
197 Tcl_SetVar2(interp
, "sqlite_options", "preupdate", "1", TCL_GLOBAL_ONLY
);
199 Tcl_SetVar2(interp
, "sqlite_options", "preupdate", "0", TCL_GLOBAL_ONLY
);
202 #ifdef SQLITE_ENABLE_SNAPSHOT
203 Tcl_SetVar2(interp
, "sqlite_options", "snapshot", "1", TCL_GLOBAL_ONLY
);
205 Tcl_SetVar2(interp
, "sqlite_options", "snapshot", "0", TCL_GLOBAL_ONLY
);
208 #ifdef SQLITE_MUTEX_OMIT
209 Tcl_SetVar2(interp
, "sqlite_options", "mutex", "0", TCL_GLOBAL_ONLY
);
211 Tcl_SetVar2(interp
, "sqlite_options", "mutex", "1", TCL_GLOBAL_ONLY
);
214 #ifdef SQLITE_MUTEX_NOOP
215 Tcl_SetVar2(interp
, "sqlite_options", "mutex_noop", "1", TCL_GLOBAL_ONLY
);
217 Tcl_SetVar2(interp
, "sqlite_options", "mutex_noop", "0", TCL_GLOBAL_ONLY
);
220 #ifdef SQLITE_OMIT_ALTERTABLE
221 Tcl_SetVar2(interp
, "sqlite_options", "altertable", "0", TCL_GLOBAL_ONLY
);
223 Tcl_SetVar2(interp
, "sqlite_options", "altertable", "1", TCL_GLOBAL_ONLY
);
226 #ifdef SQLITE_OMIT_ANALYZE
227 Tcl_SetVar2(interp
, "sqlite_options", "analyze", "0", TCL_GLOBAL_ONLY
);
229 Tcl_SetVar2(interp
, "sqlite_options", "analyze", "1", TCL_GLOBAL_ONLY
);
232 #ifdef SQLITE_ENABLE_API_ARMOR
233 Tcl_SetVar2(interp
, "sqlite_options", "api_armor", "1", TCL_GLOBAL_ONLY
);
235 Tcl_SetVar2(interp
, "sqlite_options", "api_armor", "0", TCL_GLOBAL_ONLY
);
238 #ifdef SQLITE_ENABLE_ATOMIC_WRITE
239 Tcl_SetVar2(interp
, "sqlite_options", "atomicwrite", "1", TCL_GLOBAL_ONLY
);
241 Tcl_SetVar2(interp
, "sqlite_options", "atomicwrite", "0", TCL_GLOBAL_ONLY
);
244 #ifdef SQLITE_ENABLE_GEOPOLY
245 Tcl_SetVar2(interp
, "sqlite_options", "geopoly", "1", TCL_GLOBAL_ONLY
);
247 Tcl_SetVar2(interp
, "sqlite_options", "geopoly", "0", TCL_GLOBAL_ONLY
);
250 #ifndef SQLITE_OMIT_JSON
251 Tcl_SetVar2(interp
, "sqlite_options", "json1", "1", TCL_GLOBAL_ONLY
);
253 Tcl_SetVar2(interp
, "sqlite_options", "json1", "0", TCL_GLOBAL_ONLY
);
256 /* BEGIN SQLCIPHER */
257 #ifdef SQLITE_HAS_CODEC
258 Tcl_SetVar2(interp
, "sqlite_options", "has_codec", "1", TCL_GLOBAL_ONLY
);
260 Tcl_SetVar2(interp
, "sqlite_options", "has_codec", "0", TCL_GLOBAL_ONLY
);
264 #ifdef SQLITE_LIKE_DOESNT_MATCH_BLOBS
265 Tcl_SetVar2(interp
, "sqlite_options", "like_match_blobs", "0", TCL_GLOBAL_ONLY
);
267 Tcl_SetVar2(interp
, "sqlite_options", "like_match_blobs", "1", TCL_GLOBAL_ONLY
);
270 #ifdef SQLITE_OMIT_ATTACH
271 Tcl_SetVar2(interp
, "sqlite_options", "attach", "0", TCL_GLOBAL_ONLY
);
273 Tcl_SetVar2(interp
, "sqlite_options", "attach", "1", TCL_GLOBAL_ONLY
);
276 #ifdef SQLITE_OMIT_AUTHORIZATION
277 Tcl_SetVar2(interp
, "sqlite_options", "auth", "0", TCL_GLOBAL_ONLY
);
279 Tcl_SetVar2(interp
, "sqlite_options", "auth", "1", TCL_GLOBAL_ONLY
);
282 #ifdef SQLITE_OMIT_AUTOINCREMENT
283 Tcl_SetVar2(interp
, "sqlite_options", "autoinc", "0", TCL_GLOBAL_ONLY
);
285 Tcl_SetVar2(interp
, "sqlite_options", "autoinc", "1", TCL_GLOBAL_ONLY
);
288 #ifdef SQLITE_OMIT_AUTOMATIC_INDEX
289 Tcl_SetVar2(interp
, "sqlite_options", "autoindex", "0", TCL_GLOBAL_ONLY
);
291 Tcl_SetVar2(interp
, "sqlite_options", "autoindex", "1", TCL_GLOBAL_ONLY
);
294 #ifdef SQLITE_OMIT_AUTORESET
295 Tcl_SetVar2(interp
, "sqlite_options", "autoreset", "0", TCL_GLOBAL_ONLY
);
297 Tcl_SetVar2(interp
, "sqlite_options", "autoreset", "1", TCL_GLOBAL_ONLY
);
300 #ifdef SQLITE_OMIT_AUTOVACUUM
301 Tcl_SetVar2(interp
, "sqlite_options", "autovacuum", "0", TCL_GLOBAL_ONLY
);
303 Tcl_SetVar2(interp
, "sqlite_options", "autovacuum", "1", TCL_GLOBAL_ONLY
);
304 #endif /* SQLITE_OMIT_AUTOVACUUM */
305 #if !defined(SQLITE_DEFAULT_AUTOVACUUM)
306 Tcl_SetVar2(interp
,"sqlite_options","default_autovacuum","0",TCL_GLOBAL_ONLY
);
308 Tcl_SetVar2(interp
, "sqlite_options", "default_autovacuum",
309 STRINGVALUE(SQLITE_DEFAULT_AUTOVACUUM
), TCL_GLOBAL_ONLY
);
312 #ifdef SQLITE_OMIT_BETWEEN_OPTIMIZATION
313 Tcl_SetVar2(interp
, "sqlite_options", "between_opt", "0", TCL_GLOBAL_ONLY
);
315 Tcl_SetVar2(interp
, "sqlite_options", "between_opt", "1", TCL_GLOBAL_ONLY
);
318 #ifdef SQLITE_UNTESTABLE
319 Tcl_SetVar2(interp
, "sqlite_options", "builtin_test", "0", TCL_GLOBAL_ONLY
);
321 Tcl_SetVar2(interp
, "sqlite_options", "builtin_test", "1", TCL_GLOBAL_ONLY
);
324 #ifdef SQLITE_OMIT_BLOB_LITERAL
325 Tcl_SetVar2(interp
, "sqlite_options", "bloblit", "0", TCL_GLOBAL_ONLY
);
327 Tcl_SetVar2(interp
, "sqlite_options", "bloblit", "1", TCL_GLOBAL_ONLY
);
330 #ifdef SQLITE_OMIT_CAST
331 Tcl_SetVar2(interp
, "sqlite_options", "cast", "0", TCL_GLOBAL_ONLY
);
333 Tcl_SetVar2(interp
, "sqlite_options", "cast", "1", TCL_GLOBAL_ONLY
);
336 #ifdef SQLITE_OMIT_CHECK
337 Tcl_SetVar2(interp
, "sqlite_options", "check", "0", TCL_GLOBAL_ONLY
);
339 Tcl_SetVar2(interp
, "sqlite_options", "check", "1", TCL_GLOBAL_ONLY
);
342 #ifdef SQLITE_OMIT_CTE
343 Tcl_SetVar2(interp
, "sqlite_options", "cte", "0", TCL_GLOBAL_ONLY
);
345 Tcl_SetVar2(interp
, "sqlite_options", "cte", "1", TCL_GLOBAL_ONLY
);
348 #ifdef SQLITE_ENABLE_COLUMN_METADATA
349 Tcl_SetVar2(interp
, "sqlite_options", "columnmetadata", "1", TCL_GLOBAL_ONLY
);
351 Tcl_SetVar2(interp
, "sqlite_options", "columnmetadata", "0", TCL_GLOBAL_ONLY
);
354 #ifdef SQLITE_ENABLE_OVERSIZE_CELL_CHECK
355 Tcl_SetVar2(interp
, "sqlite_options", "oversize_cell_check", "1",
358 Tcl_SetVar2(interp
, "sqlite_options", "oversize_cell_check", "0",
362 #ifdef SQLITE_OMIT_COMPILEOPTION_DIAGS
363 Tcl_SetVar2(interp
, "sqlite_options", "compileoption_diags", "0", TCL_GLOBAL_ONLY
);
365 Tcl_SetVar2(interp
, "sqlite_options", "compileoption_diags", "1", TCL_GLOBAL_ONLY
);
368 #ifdef SQLITE_OMIT_COMPLETE
369 Tcl_SetVar2(interp
, "sqlite_options", "complete", "0", TCL_GLOBAL_ONLY
);
371 Tcl_SetVar2(interp
, "sqlite_options", "complete", "1", TCL_GLOBAL_ONLY
);
374 #ifdef SQLITE_OMIT_COMPOUND_SELECT
375 Tcl_SetVar2(interp
, "sqlite_options", "compound", "0", TCL_GLOBAL_ONLY
);
377 Tcl_SetVar2(interp
, "sqlite_options", "compound", "1", TCL_GLOBAL_ONLY
);
380 Tcl_SetVar2(interp
, "sqlite_options", "conflict", "1", TCL_GLOBAL_ONLY
);
381 Tcl_SetVar2(interp
, "sqlite_options", "crashtest", "1", TCL_GLOBAL_ONLY
);
383 #ifdef SQLITE_OMIT_DATETIME_FUNCS
384 Tcl_SetVar2(interp
, "sqlite_options", "datetime", "0", TCL_GLOBAL_ONLY
);
386 Tcl_SetVar2(interp
, "sqlite_options", "datetime", "1", TCL_GLOBAL_ONLY
);
389 #ifdef SQLITE_OMIT_DECLTYPE
390 Tcl_SetVar2(interp
, "sqlite_options", "decltype", "0", TCL_GLOBAL_ONLY
);
392 Tcl_SetVar2(interp
, "sqlite_options", "decltype", "1", TCL_GLOBAL_ONLY
);
395 #ifdef SQLITE_OMIT_DEPRECATED
396 Tcl_SetVar2(interp
, "sqlite_options", "deprecated", "0", TCL_GLOBAL_ONLY
);
398 Tcl_SetVar2(interp
, "sqlite_options", "deprecated", "1", TCL_GLOBAL_ONLY
);
401 #ifdef SQLITE_OMIT_DISKIO
402 Tcl_SetVar2(interp
, "sqlite_options", "diskio", "0", TCL_GLOBAL_ONLY
);
404 Tcl_SetVar2(interp
, "sqlite_options", "diskio", "1", TCL_GLOBAL_ONLY
);
407 #ifdef SQLITE_OMIT_EXPLAIN
408 Tcl_SetVar2(interp
, "sqlite_options", "explain", "0", TCL_GLOBAL_ONLY
);
410 Tcl_SetVar2(interp
, "sqlite_options", "explain", "1", TCL_GLOBAL_ONLY
);
413 #ifdef SQLITE_OMIT_FLOATING_POINT
414 Tcl_SetVar2(interp
, "sqlite_options", "floatingpoint", "0", TCL_GLOBAL_ONLY
);
416 Tcl_SetVar2(interp
, "sqlite_options", "floatingpoint", "1", TCL_GLOBAL_ONLY
);
419 #ifdef SQLITE_OMIT_FOREIGN_KEY
420 Tcl_SetVar2(interp
, "sqlite_options", "foreignkey", "0", TCL_GLOBAL_ONLY
);
422 Tcl_SetVar2(interp
, "sqlite_options", "foreignkey", "1", TCL_GLOBAL_ONLY
);
425 #ifdef SQLITE_ENABLE_FTS3
426 Tcl_SetVar2(interp
, "sqlite_options", "fts3", "1", TCL_GLOBAL_ONLY
);
428 Tcl_SetVar2(interp
, "sqlite_options", "fts3", "0", TCL_GLOBAL_ONLY
);
431 #ifdef SQLITE_ENABLE_FTS5
432 Tcl_SetVar2(interp
, "sqlite_options", "fts5", "1", TCL_GLOBAL_ONLY
);
434 Tcl_SetVar2(interp
, "sqlite_options", "fts5", "0", TCL_GLOBAL_ONLY
);
437 #if defined(SQLITE_ENABLE_FTS3) && !defined(SQLITE_DISABLE_FTS3_UNICODE)
438 Tcl_SetVar2(interp
, "sqlite_options", "fts3_unicode", "1", TCL_GLOBAL_ONLY
);
440 Tcl_SetVar2(interp
, "sqlite_options", "fts3_unicode", "0", TCL_GLOBAL_ONLY
);
443 #ifdef SQLITE_DISABLE_FTS4_DEFERRED
444 Tcl_SetVar2(interp
, "sqlite_options", "fts4_deferred", "0", TCL_GLOBAL_ONLY
);
446 Tcl_SetVar2(interp
, "sqlite_options", "fts4_deferred", "1", TCL_GLOBAL_ONLY
);
449 #ifdef SQLITE_OMIT_GET_TABLE
450 Tcl_SetVar2(interp
, "sqlite_options", "gettable", "0", TCL_GLOBAL_ONLY
);
452 Tcl_SetVar2(interp
, "sqlite_options", "gettable", "1", TCL_GLOBAL_ONLY
);
455 #ifdef SQLITE_ENABLE_ICU
456 Tcl_SetVar2(interp
, "sqlite_options", "icu", "1", TCL_GLOBAL_ONLY
);
458 Tcl_SetVar2(interp
, "sqlite_options", "icu", "0", TCL_GLOBAL_ONLY
);
461 #ifdef SQLITE_ENABLE_ICU_COLLATIONS
462 Tcl_SetVar2(interp
, "sqlite_options", "icu_collations", "1", TCL_GLOBAL_ONLY
);
464 Tcl_SetVar2(interp
, "sqlite_options", "icu_collations", "0", TCL_GLOBAL_ONLY
);
467 #ifdef SQLITE_OMIT_INCRBLOB
468 Tcl_SetVar2(interp
, "sqlite_options", "incrblob", "0", TCL_GLOBAL_ONLY
);
470 Tcl_SetVar2(interp
, "sqlite_options", "incrblob", "1", TCL_GLOBAL_ONLY
);
471 #endif /* SQLITE_OMIT_AUTOVACUUM */
473 #ifdef SQLITE_OMIT_INTEGRITY_CHECK
474 Tcl_SetVar2(interp
, "sqlite_options", "integrityck", "0", TCL_GLOBAL_ONLY
);
476 Tcl_SetVar2(interp
, "sqlite_options", "integrityck", "1", TCL_GLOBAL_ONLY
);
479 #if defined(SQLITE_DEFAULT_FILE_FORMAT) && SQLITE_DEFAULT_FILE_FORMAT==1
480 Tcl_SetVar2(interp
, "sqlite_options", "legacyformat", "1", TCL_GLOBAL_ONLY
);
482 Tcl_SetVar2(interp
, "sqlite_options", "legacyformat", "0", TCL_GLOBAL_ONLY
);
485 #ifdef SQLITE_OMIT_LIKE_OPTIMIZATION
486 Tcl_SetVar2(interp
, "sqlite_options", "like_opt", "0", TCL_GLOBAL_ONLY
);
488 Tcl_SetVar2(interp
, "sqlite_options", "like_opt", "1", TCL_GLOBAL_ONLY
);
491 #ifdef SQLITE_OMIT_LOAD_EXTENSION
492 Tcl_SetVar2(interp
, "sqlite_options", "load_ext", "0", TCL_GLOBAL_ONLY
);
494 Tcl_SetVar2(interp
, "sqlite_options", "load_ext", "1", TCL_GLOBAL_ONLY
);
497 #ifdef SQLITE_OMIT_LOCALTIME
498 Tcl_SetVar2(interp
, "sqlite_options", "localtime", "0", TCL_GLOBAL_ONLY
);
500 Tcl_SetVar2(interp
, "sqlite_options", "localtime", "1", TCL_GLOBAL_ONLY
);
503 #ifdef SQLITE_OMIT_LOOKASIDE
504 Tcl_SetVar2(interp
, "sqlite_options", "lookaside", "0", TCL_GLOBAL_ONLY
);
506 Tcl_SetVar2(interp
, "sqlite_options", "lookaside", "1", TCL_GLOBAL_ONLY
);
509 Tcl_SetVar2(interp
, "sqlite_options", "long_double",
510 sizeof(LONGDOUBLE_TYPE
)>sizeof(double) ? "1" : "0",
513 #ifdef SQLITE_OMIT_MEMORYDB
514 Tcl_SetVar2(interp
, "sqlite_options", "memorydb", "0", TCL_GLOBAL_ONLY
);
516 Tcl_SetVar2(interp
, "sqlite_options", "memorydb", "1", TCL_GLOBAL_ONLY
);
519 #ifdef SQLITE_ENABLE_MEMORY_MANAGEMENT
520 Tcl_SetVar2(interp
, "sqlite_options", "memorymanage", "1", TCL_GLOBAL_ONLY
);
522 Tcl_SetVar2(interp
, "sqlite_options", "memorymanage", "0", TCL_GLOBAL_ONLY
);
525 Tcl_SetVar2(interp
, "sqlite_options", "mergesort", "1", TCL_GLOBAL_ONLY
);
527 #ifdef SQLITE_ENABLE_NULL_TRIM
528 Tcl_SetVar2(interp
, "sqlite_options", "null_trim", "1", TCL_GLOBAL_ONLY
);
530 Tcl_SetVar2(interp
, "sqlite_options", "null_trim", "0", TCL_GLOBAL_ONLY
);
533 #ifdef SQLITE_OMIT_OR_OPTIMIZATION
534 Tcl_SetVar2(interp
, "sqlite_options", "or_opt", "0", TCL_GLOBAL_ONLY
);
536 Tcl_SetVar2(interp
, "sqlite_options", "or_opt", "1", TCL_GLOBAL_ONLY
);
539 #ifdef SQLITE_ENABLE_RBU
540 Tcl_SetVar2(interp
, "sqlite_options", "rbu", "1", TCL_GLOBAL_ONLY
);
542 Tcl_SetVar2(interp
, "sqlite_options", "rbu", "0", TCL_GLOBAL_ONLY
);
545 #ifdef SQLITE_OMIT_PAGER_PRAGMAS
546 Tcl_SetVar2(interp
, "sqlite_options", "pager_pragmas", "0", TCL_GLOBAL_ONLY
);
548 Tcl_SetVar2(interp
, "sqlite_options", "pager_pragmas", "1", TCL_GLOBAL_ONLY
);
551 #if defined(SQLITE_OMIT_PRAGMA) || defined(SQLITE_OMIT_FLAG_PRAGMAS)
552 Tcl_SetVar2(interp
, "sqlite_options", "pragma", "0", TCL_GLOBAL_ONLY
);
553 Tcl_SetVar2(interp
, "sqlite_options", "integrityck", "0", TCL_GLOBAL_ONLY
);
555 Tcl_SetVar2(interp
, "sqlite_options", "pragma", "1", TCL_GLOBAL_ONLY
);
558 #ifdef SQLITE_OMIT_PROGRESS_CALLBACK
559 Tcl_SetVar2(interp
, "sqlite_options", "progress", "0", TCL_GLOBAL_ONLY
);
561 Tcl_SetVar2(interp
, "sqlite_options", "progress", "1", TCL_GLOBAL_ONLY
);
564 #ifdef SQLITE_OMIT_REINDEX
565 Tcl_SetVar2(interp
, "sqlite_options", "reindex", "0", TCL_GLOBAL_ONLY
);
567 Tcl_SetVar2(interp
, "sqlite_options", "reindex", "1", TCL_GLOBAL_ONLY
);
570 #ifdef SQLITE_ENABLE_RTREE
571 Tcl_SetVar2(interp
, "sqlite_options", "rtree", "1", TCL_GLOBAL_ONLY
);
573 Tcl_SetVar2(interp
, "sqlite_options", "rtree", "0", TCL_GLOBAL_ONLY
);
576 #ifdef SQLITE_RTREE_INT_ONLY
577 Tcl_SetVar2(interp
, "sqlite_options", "rtree_int_only", "1", TCL_GLOBAL_ONLY
);
579 Tcl_SetVar2(interp
, "sqlite_options", "rtree_int_only", "0", TCL_GLOBAL_ONLY
);
582 #ifdef SQLITE_OMIT_SCHEMA_PRAGMAS
583 Tcl_SetVar2(interp
, "sqlite_options", "schema_pragmas", "0", TCL_GLOBAL_ONLY
);
585 Tcl_SetVar2(interp
, "sqlite_options", "schema_pragmas", "1", TCL_GLOBAL_ONLY
);
588 #ifdef SQLITE_OMIT_SCHEMA_VERSION_PRAGMAS
589 Tcl_SetVar2(interp
, "sqlite_options", "schema_version", "0", TCL_GLOBAL_ONLY
);
591 Tcl_SetVar2(interp
, "sqlite_options", "schema_version", "1", TCL_GLOBAL_ONLY
);
594 #if defined(SQLITE_ENABLE_SESSION) && defined(SQLITE_ENABLE_PREUPDATE_HOOK)
595 Tcl_SetVar2(interp
, "sqlite_options", "session", "1", TCL_GLOBAL_ONLY
);
597 Tcl_SetVar2(interp
, "sqlite_options", "session", "0", TCL_GLOBAL_ONLY
);
600 #ifdef SQLITE_ENABLE_STAT4
601 Tcl_SetVar2(interp
, "sqlite_options", "stat4", "1", TCL_GLOBAL_ONLY
);
603 Tcl_SetVar2(interp
, "sqlite_options", "stat4", "0", TCL_GLOBAL_ONLY
);
605 #if defined(SQLITE_ENABLE_STMTVTAB) && !defined(SQLITE_OMIT_VIRTUALTABLE)
606 Tcl_SetVar2(interp
, "sqlite_options", "stmtvtab", "1", TCL_GLOBAL_ONLY
);
608 Tcl_SetVar2(interp
, "sqlite_options", "stmtvtab", "0", TCL_GLOBAL_ONLY
);
611 #ifdef SQLITE_ENABLE_STMT_SCANSTATUS
612 Tcl_SetVar2(interp
, "sqlite_options", "scanstatus", "1", TCL_GLOBAL_ONLY
);
614 Tcl_SetVar2(interp
, "sqlite_options", "scanstatus", "0", TCL_GLOBAL_ONLY
);
617 #if !defined(SQLITE_ENABLE_LOCKING_STYLE)
618 # if defined(__APPLE__)
619 # define SQLITE_ENABLE_LOCKING_STYLE 1
621 # define SQLITE_ENABLE_LOCKING_STYLE 0
624 #if SQLITE_ENABLE_LOCKING_STYLE && defined(__APPLE__)
625 Tcl_SetVar2(interp
,"sqlite_options","lock_proxy_pragmas","1",TCL_GLOBAL_ONLY
);
627 Tcl_SetVar2(interp
,"sqlite_options","lock_proxy_pragmas","0",TCL_GLOBAL_ONLY
);
629 #if defined(SQLITE_PREFER_PROXY_LOCKING) && defined(__APPLE__)
630 Tcl_SetVar2(interp
,"sqlite_options","prefer_proxy_locking","1",TCL_GLOBAL_ONLY
);
632 Tcl_SetVar2(interp
,"sqlite_options","prefer_proxy_locking","0",TCL_GLOBAL_ONLY
);
636 #ifdef SQLITE_OMIT_SHARED_CACHE
637 Tcl_SetVar2(interp
, "sqlite_options", "shared_cache", "0", TCL_GLOBAL_ONLY
);
639 Tcl_SetVar2(interp
, "sqlite_options", "shared_cache", "1", TCL_GLOBAL_ONLY
);
642 #ifdef SQLITE_OMIT_SUBQUERY
643 Tcl_SetVar2(interp
, "sqlite_options", "subquery", "0", TCL_GLOBAL_ONLY
);
645 Tcl_SetVar2(interp
, "sqlite_options", "subquery", "1", TCL_GLOBAL_ONLY
);
648 #ifdef SQLITE_OMIT_TCL_VARIABLE
649 Tcl_SetVar2(interp
, "sqlite_options", "tclvar", "0", TCL_GLOBAL_ONLY
);
651 Tcl_SetVar2(interp
, "sqlite_options", "tclvar", "1", TCL_GLOBAL_ONLY
);
654 Tcl_SetVar2(interp
, "sqlite_options", "threadsafe",
655 SQLITE_THREADSAFE
? "1" : "0", TCL_GLOBAL_ONLY
);
656 Tcl_SetVar2(interp
, "sqlite_options", "threadsafe1",
657 SQLITE_THREADSAFE
==1 ? "1" : "0", TCL_GLOBAL_ONLY
);
658 Tcl_SetVar2(interp
, "sqlite_options", "threadsafe2",
659 SQLITE_THREADSAFE
==2 ? "1" : "0", TCL_GLOBAL_ONLY
);
660 assert( sqlite3_threadsafe()==SQLITE_THREADSAFE
);
662 #ifdef SQLITE_OMIT_TEMPDB
663 Tcl_SetVar2(interp
, "sqlite_options", "tempdb", "0", TCL_GLOBAL_ONLY
);
665 Tcl_SetVar2(interp
, "sqlite_options", "tempdb", "1", TCL_GLOBAL_ONLY
);
668 #ifdef SQLITE_OMIT_TRACE
669 Tcl_SetVar2(interp
, "sqlite_options", "trace", "0", TCL_GLOBAL_ONLY
);
671 Tcl_SetVar2(interp
, "sqlite_options", "trace", "1", TCL_GLOBAL_ONLY
);
674 #ifdef SQLITE_OMIT_TRIGGER
675 Tcl_SetVar2(interp
, "sqlite_options", "trigger", "0", TCL_GLOBAL_ONLY
);
677 Tcl_SetVar2(interp
, "sqlite_options", "trigger", "1", TCL_GLOBAL_ONLY
);
680 #ifdef SQLITE_OMIT_TRUNCATE_OPTIMIZATION
681 Tcl_SetVar2(interp
, "sqlite_options", "truncate_opt", "0", TCL_GLOBAL_ONLY
);
683 Tcl_SetVar2(interp
, "sqlite_options", "truncate_opt", "1", TCL_GLOBAL_ONLY
);
686 #ifdef SQLITE_OMIT_UTF16
687 Tcl_SetVar2(interp
, "sqlite_options", "utf16", "0", TCL_GLOBAL_ONLY
);
689 Tcl_SetVar2(interp
, "sqlite_options", "utf16", "1", TCL_GLOBAL_ONLY
);
692 #if defined(SQLITE_OMIT_VACUUM) || defined(SQLITE_OMIT_ATTACH)
693 Tcl_SetVar2(interp
, "sqlite_options", "vacuum", "0", TCL_GLOBAL_ONLY
);
695 Tcl_SetVar2(interp
, "sqlite_options", "vacuum", "1", TCL_GLOBAL_ONLY
);
698 #ifdef SQLITE_OMIT_VIEW
699 Tcl_SetVar2(interp
, "sqlite_options", "view", "0", TCL_GLOBAL_ONLY
);
701 Tcl_SetVar2(interp
, "sqlite_options", "view", "1", TCL_GLOBAL_ONLY
);
704 #ifdef SQLITE_OMIT_VIRTUALTABLE
705 Tcl_SetVar2(interp
, "sqlite_options", "vtab", "0", TCL_GLOBAL_ONLY
);
707 Tcl_SetVar2(interp
, "sqlite_options", "vtab", "1", TCL_GLOBAL_ONLY
);
710 #ifdef SQLITE_OMIT_WAL
711 Tcl_SetVar2(interp
, "sqlite_options", "wal", "0", TCL_GLOBAL_ONLY
);
713 Tcl_SetVar2(interp
, "sqlite_options", "wal", "1", TCL_GLOBAL_ONLY
);
716 #ifdef SQLITE_OMIT_WSD
717 Tcl_SetVar2(interp
, "sqlite_options", "wsd", "0", TCL_GLOBAL_ONLY
);
719 Tcl_SetVar2(interp
, "sqlite_options", "wsd", "1", TCL_GLOBAL_ONLY
);
722 #if defined(SQLITE_ENABLE_UPDATE_DELETE_LIMIT) && !defined(SQLITE_OMIT_SUBQUERY)
723 Tcl_SetVar2(interp
, "sqlite_options", "update_delete_limit", "1", TCL_GLOBAL_ONLY
);
725 Tcl_SetVar2(interp
, "sqlite_options", "update_delete_limit", "0", TCL_GLOBAL_ONLY
);
728 #if defined(SQLITE_ENABLE_UNLOCK_NOTIFY)
729 Tcl_SetVar2(interp
, "sqlite_options", "unlock_notify", "1", TCL_GLOBAL_ONLY
);
731 Tcl_SetVar2(interp
, "sqlite_options", "unlock_notify", "0", TCL_GLOBAL_ONLY
);
734 #ifdef SQLITE_FAST_SECURE_DELETE
735 Tcl_SetVar2(interp
, "sqlite_options", "fast_secure_delete", "1", TCL_GLOBAL_ONLY
);
737 Tcl_SetVar2(interp
, "sqlite_options", "fast_secure_delete", "0", TCL_GLOBAL_ONLY
);
740 #ifdef SQLITE_SECURE_DELETE
741 Tcl_SetVar2(interp
, "sqlite_options", "secure_delete", "1", TCL_GLOBAL_ONLY
);
743 Tcl_SetVar2(interp
, "sqlite_options", "secure_delete", "0", TCL_GLOBAL_ONLY
);
746 #ifdef SQLITE_USER_AUTHENTICATION
747 Tcl_SetVar2(interp
, "sqlite_options", "userauth", "1", TCL_GLOBAL_ONLY
);
749 Tcl_SetVar2(interp
, "sqlite_options", "userauth", "0", TCL_GLOBAL_ONLY
);
752 #ifdef SQLITE_MULTIPLEX_EXT_OVWR
753 Tcl_SetVar2(interp
, "sqlite_options", "multiplex_ext_overwrite", "1", TCL_GLOBAL_ONLY
);
755 Tcl_SetVar2(interp
, "sqlite_options", "multiplex_ext_overwrite", "0", TCL_GLOBAL_ONLY
);
758 #ifdef YYTRACKMAXSTACKDEPTH
759 Tcl_SetVar2(interp
, "sqlite_options", "yytrackmaxstackdepth", "1", TCL_GLOBAL_ONLY
);
761 Tcl_SetVar2(interp
, "sqlite_options", "yytrackmaxstackdepth", "0", TCL_GLOBAL_ONLY
);
764 #ifdef SQLITE_ENABLE_SQLLOG
765 Tcl_SetVar2(interp
, "sqlite_options", "sqllog", "1", TCL_GLOBAL_ONLY
);
767 Tcl_SetVar2(interp
, "sqlite_options", "sqllog", "0", TCL_GLOBAL_ONLY
);
770 #ifdef SQLITE_ENABLE_URI_00_ERROR
771 Tcl_SetVar2(interp
, "sqlite_options", "uri_00_error", "1", TCL_GLOBAL_ONLY
);
773 Tcl_SetVar2(interp
, "sqlite_options", "uri_00_error", "0", TCL_GLOBAL_ONLY
);
776 #if defined(SQLITE_ENABLE_NORMALIZE)
777 Tcl_SetVar2(interp
, "sqlite_options", "normalize", "1", TCL_GLOBAL_ONLY
);
779 Tcl_SetVar2(interp
, "sqlite_options", "normalize", "0", TCL_GLOBAL_ONLY
);
782 #ifdef SQLITE_OMIT_WINDOWFUNC
783 Tcl_SetVar2(interp
, "sqlite_options", "windowfunc", "0", TCL_GLOBAL_ONLY
);
785 Tcl_SetVar2(interp
, "sqlite_options", "windowfunc", "1", TCL_GLOBAL_ONLY
);
788 #define LINKVAR(x) { \
789 static const int cv_ ## x = SQLITE_ ## x; \
790 Tcl_LinkVar(interp, "SQLITE_" #x, (char *)&(cv_ ## x), \
791 TCL_LINK_INT | TCL_LINK_READ_ONLY); }
793 LINKVAR( MAX_LENGTH
);
794 LINKVAR( MAX_COLUMN
);
795 LINKVAR( MAX_SQL_LENGTH
);
796 LINKVAR( MAX_EXPR_DEPTH
);
797 LINKVAR( MAX_COMPOUND_SELECT
);
798 LINKVAR( MAX_VDBE_OP
);
799 LINKVAR( MAX_FUNCTION_ARG
);
800 LINKVAR( MAX_VARIABLE_NUMBER
);
801 LINKVAR( MAX_PAGE_SIZE
);
802 LINKVAR( MAX_PAGE_COUNT
);
803 LINKVAR( MAX_LIKE_PATTERN_LENGTH
);
804 LINKVAR( MAX_TRIGGER_DEPTH
);
805 LINKVAR( DEFAULT_CACHE_SIZE
);
806 LINKVAR( DEFAULT_PAGE_SIZE
);
807 LINKVAR( DEFAULT_FILE_FORMAT
);
808 LINKVAR( DEFAULT_SYNCHRONOUS
);
809 LINKVAR( DEFAULT_WAL_SYNCHRONOUS
);
810 LINKVAR( MAX_ATTACHED
);
811 LINKVAR( MAX_DEFAULT_PAGE_SIZE
);
812 LINKVAR( MAX_WORKER_THREADS
);
815 static const int cv_TEMP_STORE
= SQLITE_TEMP_STORE
;
816 Tcl_LinkVar(interp
, "TEMP_STORE", (char *)&(cv_TEMP_STORE
),
817 TCL_LINK_INT
| TCL_LINK_READ_ONLY
);
822 static const int cv__MSC_VER
= 1;
823 Tcl_LinkVar(interp
, "_MSC_VER", (char *)&(cv__MSC_VER
),
824 TCL_LINK_INT
| TCL_LINK_READ_ONLY
);
829 static const int cv___GNUC__
= 1;
830 Tcl_LinkVar(interp
, "__GNUC__", (char *)&(cv___GNUC__
),
831 TCL_LINK_INT
| TCL_LINK_READ_ONLY
);
838 ** Register commands with the TCL interpreter.
840 int Sqliteconfig_Init(Tcl_Interp
*interp
){