]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Move most of the makefile code into the static main.mk.
authorstephan <stephan@noemail.net>
Sat, 19 Oct 2024 20:26:17 +0000 (20:26 +0000)
committerstephan <stephan@noemail.net>
Sat, 19 Oct 2024 20:26:17 +0000 (20:26 +0000)
FossilOrigin-Name: 09905ed094f7102dbb4fc81b059452c50b48b0f3a2bd9736bed364b0639d89d7

Makefile.in
main.mk
manifest
manifest.uuid

index fb9df642e3d128a37f532615aa0b294f142724f0..d414ca3d9bb8e6ad0407c6bd7263d5e74ad3488b 100644 (file)
@@ -24,6 +24,7 @@ LDFLAGS_MATH ?= @LDFLAGS_MATH@
 LDFLAGS_RPATH ?= @LDFLAGS_RPATH@
 LDFLAGS_READLINE ?= @LDFLAGS_READLINE@
 LDFLAGS_PTHREAD ?= @LDFLAGS_PTHREAD@
+LDFLAGS_SHOBJ ?= @SHOBJ_LDFLAGS@
 ENABLE_SHARED ?= @ENABLE_SHARED@
 HAVE_WASI_SDK ?= @HAVE_WASI_SDK@
 AR ?= @AR@
@@ -33,6 +34,7 @@ CC ?= @CC@
 # will run on the platform that is doing the build.
 #
 BCC = @BUILD_CC@ @BUILD_CFLAGS@
+
 #
 # TCC is the C Compile and options for use in building executables that
 # will run on the target platform.  (BCC and TCC are usually the
@@ -43,22 +45,21 @@ BCC = @BUILD_CC@ @BUILD_CFLAGS@
 CFLAGS ?= @CFLAGS@ @SH_CFLAGS@
 CPPFLAGS ?= @CPPFLAGS@
 # CFLAGS_stdio3 ==> for sqlite3_stdio.h
-CFLAGS_stdio3 := -I${TOP}/ext/misc
-TCC = ${CC} ${CFLAGS}
-TCC += -I. -I${TOP}/src -I${TOP}/ext/rtree -I${TOP}/ext/icu
-TCC += -I${TOP}/ext/fts3 -I${TOP}/ext/async -I${TOP}/ext/session
-TCC += -I${TOP}/ext/userauth
-
-# Define this for the autoconf-based build, so that the code knows it can
-# include the generated sqlite_cfg.h
-#
-TCC += -D_HAVE_SQLITE_CONFIG_H -DBUILD_sqlite
+CFLAGS_stdio3 := -I$(TOP)/ext/misc
+TCC = $(CC) $(CFLAGS)
 
 # Define -DNDEBUG to compile without debugging (i.e., for production usage)
 # Omitting the define will cause extra debugging code to be inserted and
 # includes extra comments when "EXPLAIN stmt" is used.
 #
-TCC += @TARGET_DEBUG@
+TCCX ?= $(TCC) @TARGET_DEBUG@
+# Define this for the autoconf-based build, so that the code knows it can
+# include the generated sqlite_cfg.h
+#
+TCCX += -D_HAVE_SQLITE_CONFIG_H -DBUILD_sqlite
+#
+# main.mk will fill out TCCX with some flags common to all builds.
+
 #XX#
 #XX## Compiler options needed for programs that use the TCL library.
 #XX##
@@ -67,7 +68,8 @@ TCC += @TARGET_DEBUG@
 #XX## The library that programs using TCL must link against.
 #XX##
 LIBTCL = @TCL_LIB_SPEC@
-#XX#
+
+#
 # Compiler options needed for programs that use the readline() library.
 #
 CFLAGS_readline = -DHAVE_READLINE=@HAVE_READLINE@ @CFLAGS_READLINE@
@@ -119,7 +121,7 @@ $(BTCLSH):
 # default to file, 2 to default to memory, and 3 to force temporary
 # tables to always be in memory.
 #
-TEMP_STORE = -DSQLITE_TEMP_STORE=@TEMP_STORE@
+TEMP_STORE ?= -DSQLITE_TEMP_STORE=@TEMP_STORE@
 
 # Enable/disable loadable extensions, and other optional features
 # based on configuration. (-DSQLITE_OMIT*, -DSQLITE_ENABLE*).
@@ -222,25 +224,6 @@ pkgconfigdir ?= $(libdir)/pkgconfig
 bindir ?= @bindir@
 includedir ?= @includedir@
 INSTALL = @BIN_INSTALL@
-INSTALL_noexec = $(INSTALL) -m 0644
-# ^^^ do not use GNU-specific flags to $(INSTALL), e.g. --mode=...
-
-# install.XYZ = dirs for installation. They're in quotes to
-# accommodate installations where paths have spaces in them.
-#
-install.bindir = "$(DESTDIR)$(bindir)"
-install.libdir = "$(DESTDIR)$(libdir)"
-install.includedir = "$(DESTDIR)$(prefix)/include"
-install.pkgconfigdir = "$(DESTDIR)$(pkgconfigdir)"
-$(install.bindir) $(install.libdir) $(install.includedir) $(install.pkgconfigdir):
-       $(INSTALL) -d $@
-
-# TCOMPILE = generic target platform compiler invocation
-TCOMPILE = $(TCC) $(TCOMPILE_EXTRAS)
-# TLINK = compiler invocation for when the target will be an executable
-TLINK = $(TCC) $(TLINK_EXTRAS)
-# TLINK_shared = $(TLINK) invocation specifically for shared libraries
-TLINK_shared = $(TLINK) @SHOBJ_LDFLAGS@
 
 #
 # You should not have to change anything below this line
@@ -253,495 +236,13 @@ TLINK_shared = $(TLINK) @SHOBJ_LDFLAGS@
 #
 AS_AUTO_DEF = $(TOP)/auto.def
 
-USE_AMALGAMATION = @USE_AMALGAMATION@
-AMALGAMATION_LINE_MACROS = --linemacros=@AMALGAMATION_LINE_MACROS@
+USE_AMALGAMATION ?= @USE_AMALGAMATION@
+AMALGAMATION_LINE_MACROS ?= --linemacros=@AMALGAMATION_LINE_MACROS@
 
-#
-# Object files for the SQLite library (non-amalgamation).
-#
-LIBOBJS0 = alter.o analyze.o attach.o auth.o \
-         backup.o bitvec.o btmutex.o btree.o build.o \
-         callback.o complete.o ctime.o \
-         date.o dbpage.o dbstat.o delete.o \
-         expr.o fault.o fkey.o \
-         fts3.o fts3_aux.o fts3_expr.o fts3_hash.o fts3_icu.o \
-         fts3_porter.o fts3_snippet.o fts3_tokenizer.o fts3_tokenizer1.o \
-         fts3_tokenize_vtab.o \
-         fts3_unicode.o fts3_unicode2.o fts3_write.o \
-         fts5.o \
-         func.o global.o hash.o \
-         icu.o insert.o json.o legacy.o loadext.o \
-         main.o malloc.o mem0.o mem1.o mem2.o mem3.o mem5.o \
-         memdb.o memjournal.o \
-         mutex.o mutex_noop.o mutex_unix.o mutex_w32.o \
-         notify.o opcodes.o os.o os_kv.o os_unix.o os_win.o \
-         pager.o parse.o pcache.o pcache1.o pragma.o prepare.o printf.o \
-         random.o resolve.o rowset.o rtree.o \
-         sqlite3session.o select.o sqlite3rbu.o status.o stmt.o \
-         table.o threads.o tokenize.o treeview.o trigger.o \
-         update.o upsert.o userauth.o utf.o util.o vacuum.o \
-         vdbe.o vdbeapi.o vdbeaux.o vdbeblob.o vdbemem.o vdbesort.o \
-         vdbetrace.o vdbevtab.o vtab.o \
-         wal.o walker.o where.o wherecode.o whereexpr.o \
-         window.o
-
-# Object files for the amalgamation.
-#
-LIBOBJS1 = sqlite3.o
-
-# Determine the real value of LIBOBJ based on the 'configure' script
-#
-LIBOBJ = $(LIBOBJS$(USE_AMALGAMATION))
-
-# All of the source code files.
-#
-SRC = \
-  $(TOP)/src/alter.c \
-  $(TOP)/src/analyze.c \
-  $(TOP)/src/attach.c \
-  $(TOP)/src/auth.c \
-  $(TOP)/src/backup.c \
-  $(TOP)/src/bitvec.c \
-  $(TOP)/src/btmutex.c \
-  $(TOP)/src/btree.c \
-  $(TOP)/src/btree.h \
-  $(TOP)/src/btreeInt.h \
-  $(TOP)/src/build.c \
-  $(TOP)/src/callback.c \
-  $(TOP)/src/complete.c \
-  $(TOP)/src/ctime.c \
-  $(TOP)/src/date.c \
-  $(TOP)/src/dbpage.c \
-  $(TOP)/src/dbstat.c \
-  $(TOP)/src/delete.c \
-  $(TOP)/src/expr.c \
-  $(TOP)/src/fault.c \
-  $(TOP)/src/fkey.c \
-  $(TOP)/src/func.c \
-  $(TOP)/src/global.c \
-  $(TOP)/src/hash.c \
-  $(TOP)/src/hash.h \
-  $(TOP)/src/hwtime.h \
-  $(TOP)/src/insert.c \
-  $(TOP)/src/json.c \
-  $(TOP)/src/legacy.c \
-  $(TOP)/src/loadext.c \
-  $(TOP)/src/main.c \
-  $(TOP)/src/malloc.c \
-  $(TOP)/src/mem0.c \
-  $(TOP)/src/mem1.c \
-  $(TOP)/src/mem2.c \
-  $(TOP)/src/mem3.c \
-  $(TOP)/src/mem5.c \
-  $(TOP)/src/memdb.c \
-  $(TOP)/src/memjournal.c \
-  $(TOP)/src/msvc.h \
-  $(TOP)/src/mutex.c \
-  $(TOP)/src/mutex.h \
-  $(TOP)/src/mutex_noop.c \
-  $(TOP)/src/mutex_unix.c \
-  $(TOP)/src/mutex_w32.c \
-  $(TOP)/src/notify.c \
-  $(TOP)/src/os.c \
-  $(TOP)/src/os.h \
-  $(TOP)/src/os_common.h \
-  $(TOP)/src/os_setup.h \
-  $(TOP)/src/os_kv.c \
-  $(TOP)/src/os_unix.c \
-  $(TOP)/src/os_win.c \
-  $(TOP)/src/os_win.h \
-  $(TOP)/src/pager.c \
-  $(TOP)/src/pager.h \
-  $(TOP)/src/parse.y \
-  $(TOP)/src/pcache.c \
-  $(TOP)/src/pcache.h \
-  $(TOP)/src/pcache1.c \
-  $(TOP)/src/pragma.c \
-  $(TOP)/src/pragma.h \
-  $(TOP)/src/prepare.c \
-  $(TOP)/src/printf.c \
-  $(TOP)/src/random.c \
-  $(TOP)/src/resolve.c \
-  $(TOP)/src/rowset.c \
-  $(TOP)/src/select.c \
-  $(TOP)/src/status.c \
-  $(TOP)/src/shell.c.in \
-  $(TOP)/src/sqlite.h.in \
-  $(TOP)/src/sqlite3ext.h \
-  $(TOP)/src/sqliteInt.h \
-  $(TOP)/src/sqliteLimit.h \
-  $(TOP)/src/table.c \
-  $(TOP)/src/tclsqlite.c \
-  $(TOP)/src/threads.c \
-  $(TOP)/src/tokenize.c \
-  $(TOP)/src/treeview.c \
-  $(TOP)/src/trigger.c \
-  $(TOP)/src/utf.c \
-  $(TOP)/src/update.c \
-  $(TOP)/src/upsert.c \
-  $(TOP)/src/util.c \
-  $(TOP)/src/vacuum.c \
-  $(TOP)/src/vdbe.c \
-  $(TOP)/src/vdbe.h \
-  $(TOP)/src/vdbeapi.c \
-  $(TOP)/src/vdbeaux.c \
-  $(TOP)/src/vdbeblob.c \
-  $(TOP)/src/vdbemem.c \
-  $(TOP)/src/vdbesort.c \
-  $(TOP)/src/vdbetrace.c \
-  $(TOP)/src/vdbevtab.c \
-  $(TOP)/src/vdbeInt.h \
-  $(TOP)/src/vtab.c \
-  $(TOP)/src/vxworks.h \
-  $(TOP)/src/wal.c \
-  $(TOP)/src/wal.h \
-  $(TOP)/src/walker.c \
-  $(TOP)/src/where.c \
-  $(TOP)/src/wherecode.c \
-  $(TOP)/src/whereexpr.c \
-  $(TOP)/src/whereInt.h \
-  $(TOP)/src/window.c
-
-# Source code for extensions
-#
-SRC += \
-  $(TOP)/ext/fts3/fts3.c \
-  $(TOP)/ext/fts3/fts3.h \
-  $(TOP)/ext/fts3/fts3Int.h \
-  $(TOP)/ext/fts3/fts3_aux.c \
-  $(TOP)/ext/fts3/fts3_expr.c \
-  $(TOP)/ext/fts3/fts3_hash.c \
-  $(TOP)/ext/fts3/fts3_hash.h \
-  $(TOP)/ext/fts3/fts3_icu.c \
-  $(TOP)/ext/fts3/fts3_porter.c \
-  $(TOP)/ext/fts3/fts3_snippet.c \
-  $(TOP)/ext/fts3/fts3_tokenizer.h \
-  $(TOP)/ext/fts3/fts3_tokenizer.c \
-  $(TOP)/ext/fts3/fts3_tokenizer1.c \
-  $(TOP)/ext/fts3/fts3_tokenize_vtab.c \
-  $(TOP)/ext/fts3/fts3_unicode.c \
-  $(TOP)/ext/fts3/fts3_unicode2.c \
-  $(TOP)/ext/fts3/fts3_write.c
-SRC += \
-  $(TOP)/ext/icu/sqliteicu.h \
-  $(TOP)/ext/icu/icu.c
-SRC += \
-  $(TOP)/ext/rtree/rtree.h \
-  $(TOP)/ext/rtree/rtree.c \
-  $(TOP)/ext/rtree/geopoly.c
-SRC += \
-  $(TOP)/ext/session/sqlite3session.c \
-  $(TOP)/ext/session/sqlite3session.h
-SRC += \
-  $(TOP)/ext/userauth/userauth.c \
-  $(TOP)/ext/userauth/sqlite3userauth.h
-SRC += \
-  $(TOP)/ext/rbu/sqlite3rbu.h \
-  $(TOP)/ext/rbu/sqlite3rbu.c
-SRC += \
-  $(TOP)/ext/misc/stmt.c
-
-# Generated source code files
-#
-SRC += \
-  keywordhash.h \
-  opcodes.c \
-  opcodes.h \
-  parse.c \
-  parse.h \
-  sqlite_cfg.h \
-  shell.c \
-  sqlite3.h
-
-# Source code to the test files.
-#
-TESTSRC = \
-  $(TOP)/src/test1.c \
-  $(TOP)/src/test2.c \
-  $(TOP)/src/test3.c \
-  $(TOP)/src/test4.c \
-  $(TOP)/src/test5.c \
-  $(TOP)/src/test6.c \
-  $(TOP)/src/test8.c \
-  $(TOP)/src/test9.c \
-  $(TOP)/src/test_autoext.c \
-  $(TOP)/src/test_async.c \
-  $(TOP)/src/test_backup.c \
-  $(TOP)/src/test_bestindex.c \
-  $(TOP)/src/test_blob.c \
-  $(TOP)/src/test_btree.c \
-  $(TOP)/src/test_config.c \
-  $(TOP)/src/test_delete.c \
-  $(TOP)/src/test_demovfs.c \
-  $(TOP)/src/test_devsym.c \
-  $(TOP)/src/test_fs.c \
-  $(TOP)/src/test_func.c \
-  $(TOP)/src/test_hexio.c \
-  $(TOP)/src/test_init.c \
-  $(TOP)/src/test_intarray.c \
-  $(TOP)/src/test_journal.c \
-  $(TOP)/src/test_malloc.c \
-  $(TOP)/src/test_md5.c \
-  $(TOP)/src/test_multiplex.c \
-  $(TOP)/src/test_mutex.c \
-  $(TOP)/src/test_onefile.c \
-  $(TOP)/src/test_osinst.c \
-  $(TOP)/src/test_pcache.c \
-  $(TOP)/src/test_quota.c \
-  $(TOP)/src/test_rtree.c \
-  $(TOP)/src/test_schema.c \
-  $(TOP)/src/test_superlock.c \
-  $(TOP)/src/test_syscall.c \
-  $(TOP)/src/test_tclsh.c \
-  $(TOP)/src/test_tclvar.c \
-  $(TOP)/src/test_thread.c \
-  $(TOP)/src/test_vdbecov.c \
-  $(TOP)/src/test_vfs.c \
-  $(TOP)/src/test_windirent.c \
-  $(TOP)/src/test_window.c \
-  $(TOP)/src/test_wsd.c       \
-  $(TOP)/ext/fts3/fts3_term.c \
-  $(TOP)/ext/fts3/fts3_test.c  \
-  $(TOP)/ext/session/test_session.c \
-  $(TOP)/ext/recover/sqlite3recover.c \
-  $(TOP)/ext/recover/dbdata.c \
-  $(TOP)/ext/recover/test_recover.c \
-  $(TOP)/ext/intck/test_intck.c  \
-  $(TOP)/ext/intck/sqlite3intck.c \
-  $(TOP)/ext/rbu/test_rbu.c
-
-# Statically linked extensions
-#
-TESTSRC += \
-  $(TOP)/ext/expert/sqlite3expert.c \
-  $(TOP)/ext/expert/test_expert.c \
-  $(TOP)/ext/misc/amatch.c \
-  $(TOP)/ext/misc/appendvfs.c \
-  $(TOP)/ext/misc/basexx.c \
-  $(TOP)/ext/misc/carray.c \
-  $(TOP)/ext/misc/cksumvfs.c \
-  $(TOP)/ext/misc/closure.c \
-  $(TOP)/ext/misc/csv.c \
-  $(TOP)/ext/misc/decimal.c \
-  $(TOP)/ext/misc/eval.c \
-  $(TOP)/ext/misc/explain.c \
-  $(TOP)/ext/misc/fileio.c \
-  $(TOP)/ext/misc/fuzzer.c \
-  $(TOP)/ext/fts5/fts5_tcl.c \
-  $(TOP)/ext/fts5/fts5_test_mi.c \
-  $(TOP)/ext/fts5/fts5_test_tok.c \
-  $(TOP)/ext/misc/ieee754.c \
-  $(TOP)/ext/misc/mmapwarm.c \
-  $(TOP)/ext/misc/nextchar.c \
-  $(TOP)/ext/misc/normalize.c \
-  $(TOP)/ext/misc/percentile.c \
-  $(TOP)/ext/misc/prefixes.c \
-  $(TOP)/ext/misc/qpvtab.c \
-  $(TOP)/ext/misc/randomjson.c \
-  $(TOP)/ext/misc/regexp.c \
-  $(TOP)/ext/misc/remember.c \
-  $(TOP)/ext/misc/series.c \
-  $(TOP)/ext/misc/spellfix.c \
-  $(TOP)/ext/misc/stmtrand.c \
-  $(TOP)/ext/misc/totype.c \
-  $(TOP)/ext/misc/unionvtab.c \
-  $(TOP)/ext/misc/wholenumber.c \
-  $(TOP)/ext/misc/zipfile.c \
-  $(TOP)/ext/userauth/userauth.c \
-  $(TOP)/ext/rtree/test_rtreedoc.c
-
-# Source code to the library files needed by the test fixture
-#
-TESTSRC2 = \
-  $(TOP)/src/attach.c \
-  $(TOP)/src/backup.c \
-  $(TOP)/src/bitvec.c \
-  $(TOP)/src/btree.c \
-  $(TOP)/src/build.c \
-  $(TOP)/src/ctime.c \
-  $(TOP)/src/date.c \
-  $(TOP)/src/dbpage.c \
-  $(TOP)/src/dbstat.c \
-  $(TOP)/src/expr.c \
-  $(TOP)/src/func.c \
-  $(TOP)/src/global.c \
-  $(TOP)/src/insert.c \
-  $(TOP)/src/wal.c \
-  $(TOP)/src/main.c \
-  $(TOP)/src/mem5.c \
-  $(TOP)/src/os.c \
-  $(TOP)/src/os_kv.c \
-  $(TOP)/src/os_unix.c \
-  $(TOP)/src/os_win.c \
-  $(TOP)/src/pager.c \
-  $(TOP)/src/pragma.c \
-  $(TOP)/src/prepare.c \
-  $(TOP)/src/printf.c \
-  $(TOP)/src/random.c \
-  $(TOP)/src/pcache.c \
-  $(TOP)/src/pcache1.c \
-  $(TOP)/src/select.c \
-  $(TOP)/src/tokenize.c \
-  $(TOP)/src/treeview.c \
-  $(TOP)/src/utf.c \
-  $(TOP)/src/util.c \
-  $(TOP)/src/vdbeapi.c \
-  $(TOP)/src/vdbeaux.c \
-  $(TOP)/src/vdbe.c \
-  $(TOP)/src/vdbemem.c \
-  $(TOP)/src/vdbetrace.c \
-  $(TOP)/src/vdbevtab.c \
-  $(TOP)/src/where.c \
-  $(TOP)/src/wherecode.c \
-  $(TOP)/src/whereexpr.c \
-  $(TOP)/src/window.c \
-  parse.c \
-  $(TOP)/ext/fts3/fts3.c \
-  $(TOP)/ext/fts3/fts3_aux.c \
-  $(TOP)/ext/fts3/fts3_expr.c \
-  $(TOP)/ext/fts3/fts3_term.c \
-  $(TOP)/ext/fts3/fts3_tokenizer.c \
-  $(TOP)/ext/fts3/fts3_write.c \
-  $(TOP)/ext/async/sqlite3async.c \
-  $(TOP)/ext/session/sqlite3session.c \
-  $(TOP)/ext/misc/stmt.c \
-  fts5.c
-
-# Header files used by all library source files.
-#
-HDR = \
-   $(TOP)/src/btree.h \
-   $(TOP)/src/btreeInt.h \
-   $(TOP)/src/hash.h \
-   $(TOP)/src/hwtime.h \
-   keywordhash.h \
-   $(TOP)/src/msvc.h \
-   $(TOP)/src/mutex.h \
-   opcodes.h \
-   $(TOP)/src/os.h \
-   $(TOP)/src/os_common.h \
-   $(TOP)/src/os_setup.h \
-   $(TOP)/src/os_win.h \
-   $(TOP)/src/pager.h \
-   $(TOP)/src/pcache.h \
-   parse.h  \
-   $(TOP)/src/pragma.h \
-   sqlite3.h  \
-   $(TOP)/src/sqlite3ext.h \
-   $(TOP)/src/sqliteInt.h  \
-   $(TOP)/src/sqliteLimit.h \
-   $(TOP)/src/vdbe.h \
-   $(TOP)/src/vdbeInt.h \
-   $(TOP)/src/vxworks.h \
-   $(TOP)/src/whereInt.h \
-   sqlite_cfg.h
-
-# Header files used by extensions
-#
-EXTHDR += \
-  $(TOP)/ext/fts3/fts3.h \
-  $(TOP)/ext/fts3/fts3Int.h \
-  $(TOP)/ext/fts3/fts3_hash.h \
-  $(TOP)/ext/fts3/fts3_tokenizer.h
-EXTHDR += \
-  $(TOP)/ext/rtree/rtree.h \
-  $(TOP)/ext/rtree/geopoly.c
-EXTHDR += \
-  $(TOP)/ext/icu/sqliteicu.h
-EXTHDR += \
-  $(TOP)/ext/rtree/sqlite3rtree.h
-EXTHDR += \
-  $(TOP)/ext/userauth/sqlite3userauth.h
-
-# executables needed for testing
-#
-TESTPROGS = \
-  testfixture$(TEXE) \
-  sqlite3$(TEXE) \
-  sqlite3_analyzer$(TEXE) \
-  sqldiff$(TEXE) \
-  dbhash$(TEXE) \
-  sqltclsh$(TEXE)
-
-# Databases containing fuzzer test cases
-#
-FUZZDATA = \
-  $(TOP)/test/fuzzdata1.db \
-  $(TOP)/test/fuzzdata2.db \
-  $(TOP)/test/fuzzdata3.db \
-  $(TOP)/test/fuzzdata4.db \
-  $(TOP)/test/fuzzdata5.db \
-  $(TOP)/test/fuzzdata6.db \
-  $(TOP)/test/fuzzdata7.db \
-  $(TOP)/test/fuzzdata8.db
-
-# Standard options to testfixture
-#
-TESTOPTS = --verbose=file --output=test-out.txt
-
-# Extra compiler options for various shell tools
-#
-SHELL_OPT = @OPT_SHELL@
-SHELL_OPT += -DSQLITE_DQS=0
-SHELL_OPT += -DSQLITE_ENABLE_FTS4
-#SHELL_OPT += -DSQLITE_ENABLE_FTS5
-SHELL_OPT += -DSQLITE_ENABLE_RTREE
-SHELL_OPT += -DSQLITE_ENABLE_EXPLAIN_COMMENTS
-SHELL_OPT += -DSQLITE_ENABLE_UNKNOWN_SQL_FUNCTION
-SHELL_OPT += -DSQLITE_ENABLE_STMTVTAB
-SHELL_OPT += -DSQLITE_ENABLE_DBPAGE_VTAB
-SHELL_OPT += -DSQLITE_ENABLE_DBSTAT_VTAB
-SHELL_OPT += -DSQLITE_ENABLE_BYTECODE_VTAB
-SHELL_OPT += -DSQLITE_ENABLE_OFFSET_SQL_FUNC
-SHELL_OPT += -DSQLITE_STRICT_SUBTYPE=1
-FUZZERSHELL_OPT =
-FUZZCHECK_OPT += -I$(TOP)/test
-FUZZCHECK_OPT += -I$(TOP)/ext/recover
-FUZZCHECK_OPT += \
-  -DSQLITE_OSS_FUZZ \
-  -DSQLITE_ENABLE_BYTECODE_VTAB \
-  -DSQLITE_ENABLE_DBPAGE_VTAB \
-  -DSQLITE_ENABLE_DBSTAT_VTAB \
-  -DSQLITE_ENABLE_BYTECODE_VTAB \
-  -DSQLITE_ENABLE_DESERIALIZE \
-  -DSQLITE_ENABLE_EXPLAIN_COMMENTS \
-  -DSQLITE_ENABLE_FTS3_PARENTHESIS \
-  -DSQLITE_ENABLE_FTS4 \
-  -DSQLITE_ENABLE_FTS5 \
-  -DSQLITE_ENABLE_GEOPOLY \
-  -DSQLITE_ENABLE_MATH_FUNCTIONS \
-  -DSQLITE_ENABLE_MEMSYS5 \
-  -DSQLITE_ENABLE_NORMALIZE \
-  -DSQLITE_ENABLE_OFFSET_SQL_FUNC \
-  -DSQLITE_ENABLE_PREUPDATE_HOOK \
-  -DSQLITE_ENABLE_RTREE \
-  -DSQLITE_ENABLE_SESSION \
-  -DSQLITE_ENABLE_STMTVTAB \
-  -DSQLITE_ENABLE_UNKNOWN_SQL_FUNCTION \
-  -DSQLITE_ENABLE_STAT4 \
-  -DSQLITE_ENABLE_STMT_SCANSTATUS \
-  -DSQLITE_MAX_MEMORY=50000000 \
-  -DSQLITE_MAX_MMAP_SIZE=0 \
-  -DSQLITE_OMIT_LOAD_EXTENSION \
-  -DSQLITE_PRINTF_PRECISION_LIMIT=1000 \
-  -DSQLITE_PRIVATE="" \
-  -DSQLITE_STRICT_SUBTYPE=1 \
-  -DSQLITE_STATIC_RANDOMJSON
-
-FUZZCHECK_SRC += $(TOP)/test/fuzzcheck.c
-FUZZCHECK_SRC += $(TOP)/test/ossfuzz.c
-FUZZCHECK_SRC += $(TOP)/test/fuzzinvariants.c
-FUZZCHECK_SRC += $(TOP)/ext/recover/dbdata.c
-FUZZCHECK_SRC += $(TOP)/ext/recover/sqlite3recover.c
-FUZZCHECK_SRC += $(TOP)/test/vt02.c
-FUZZCHECK_SRC += $(TOP)/ext/misc/percentile.c
-FUZZCHECK_SRC += $(TOP)/ext/misc/randomjson.c
-DBFUZZ_OPT =
-ST_OPT = -DSQLITE_OS_KV_OPTIONAL
+SHELL_OPT ?= @OPT_SHELL@
 
 
 # In wasi-sdk builds, remove the CLI shell build from 'all'.
-target_sqlite3_shell_1 =
 target_sqlite3_shell_0 = sqlite3$(TEXE)
 target_sqlite3_shell = $(target_sqlite3_shell_$(HAVE_WASI_SDK))
 
@@ -772,1040 +273,6 @@ sqlite_cfg.h: $(TOP)/sqlite_cfg.h.in $(AS_AUTO_DEF)
        $(AS_AUTOREMAKE)
        @touch $@
 
-libsqlite3.LIB = libsqlite3$(TLIB)
-
-$(libsqlite3.LIB): $(LIBOBJ)
-       $(AR) crs $@ $(LIBOBJ)
-lib: $(libsqlite3.LIB)
-all: lib
-
-# LDFLAGS_libsqlite3 should be used with any target which either
-# results in building libsqlite3.so, compiles sqlite3.c directly, or
-# links in either of $(LIBOBJSO) or $(LIBOBJS1).  Note that these
-# flags are for the target build platform, not necessarily localhost.
-# i.e. it should be used with $(TCC) or $(TLINK) but not $(BCC).
-LDFLAGS_libsqlite3 = \
-  $(LDFLAGS_RPATH) $(TLIBS) $(LDFLAGS_PTHREAD) \
-  $(LDFLAGS_MATH) $(LDFLAGS_ZLIB)
-
-libsqlite3.SO = libsqlite3$(TDLL)
-target_libsqlite3_so_0 =
-target_libsqlite3_so_1 = $(libsqlite3.SO)
-target_libsqlite3_so = $(target_libsqlite3_so_$(ENABLE_SHARED))
-
-$(libsqlite3.SO):      $(LIBOBJ)
-       @if [ "x1" != "x$(ENABLE_SHARED)" ]; then echo "Shared lib build is disabled." 1>&2; exit 1; fi
-       $(TLINK_shared) -o $@ \
-               $(LIBOBJ) $(TLIBS) $(LDFLAGS_libsqlite3)
-so: $(target_libsqlite3_so)
-all: so
-
-# Install the $(libsqlite3.SO) as $(libsqlite3.SO).$(RELEASE) and
-# create symlinks which point to it. Do we really need all of this
-# hoop-jumping? Can we not simply install the .so as-is to
-# libsqlite3.so (without the versioned bits)?
-#
-# The historical SQLite build always used a version number of 0.8.6
-# for reasons lost to history but having something to do with libtool
-# (which is not longer used in this tree).
-#
-install-so-1: $(install.libdir) $(libsqlite3.SO)
-       $(INSTALL) $(libsqlite3.SO) $(install.libdir); \
-       cd $(install.libdir); \
-               rm -f $(libsqlite3.SO).3 $(libsqlite3.SO).$(RELEASE); \
-               mv $(libsqlite3.SO) $(libsqlite3.SO).$(RELEASE); \
-               ln -s $(libsqlite3.SO).$(RELEASE) $(libsqlite3.SO).3; \
-               ln -s $(libsqlite3.SO).3 $(libsqlite3.SO)
-install-so-0:
-install: install-so-$(ENABLE_SHARED)
-
-# Install $(libsqlite3.LIB)
-#
-install-lib: $(install.libdir) $(libsqlite3.LIB)
-       $(INSTALL_noexec) $(libsqlite3.LIB) $(install.libdir)
-install: install-lib
-
-# Install C header files
-#
-install-includes: sqlite3.h $(install.includedir)
-       $(INSTALL_noexec) sqlite3.h "$(TOP)/src/sqlite3ext.h" $(install.includedir)
-install: install-includes
-
-# libtclsqlite3...
-#
-libtclsqlite3.SO = libtclsqlite3$(TDLL)
-target_libtclsqlite3_1 = $(libtclsqlite3.SO)
-target_libtclsqlite3_0 =
-target_libtclsqlite3 = $(target_libtclsqlite3_$(HAVE_TCL))
-$(libtclsqlite3.SO): tclsqlite.o $(libsqlite3.LIB)
-       $(TLINK_shared) -o $@ tclsqlite.o \
-               $(TCL_INCLUDE_SPEC) $(TCL_STUB_LIB_SPEC) $(LDFLAGS_libsqlite3) \
-               $(libsqlite3.LIB) $(TCLLIB_RPATH)
-
-libtcl:        $(target_libtclsqlite3)
-
-all:   $(target_libtclsqlite3)
-
-pkgIndex.tcl:
-       echo 'package ifneeded sqlite3 $(RELEASE) [list load [file join $$dir libtclsqlite3[info sharedlibextension]] sqlite3]' > $@
-
-install.tcldir = "$(DESTDIR)$(TCLLIBDIR)"
-install-tcl: install-lib $(target_libtclsqlite3) pkgIndex.tcl
-       @if [ "x$(DESTDIR)" = "x$(install.tcldir)" ]; then echo "TCLLIBDIR is not set." 1>&2; exit 1; fi
-       $(INSTALL) -d $(install.tcldir)
-       $(INSTALL) $(libtclsqlite3.SO) $(install.tcldir)
-       $(INSTALL_noexec) pkgIndex.tcl $(install.tcldir)
-install: install-tcl
-
-tclsqlite3.c:  sqlite3.c
-       echo '#ifndef USE_SYSTEM_SQLITE' >tclsqlite3.c
-       cat sqlite3.c >>tclsqlite3.c
-       echo '#endif /* USE_SYSTEM_SQLITE */' >>tclsqlite3.c
-       cat $(TOP)/src/tclsqlite.c >>tclsqlite3.c
-
-sqlite3-all.c: sqlite3.c $(TOP)/tool/split-sqlite3c.tcl $(BTCLSH) # has_tclsh84
-       $(BTCLSH) $(TOP)/tool/split-sqlite3c.tcl
-
-# Build the SQLite TCL extension in a way that make it compatible
-# with whatever version of TCL is running as $TCLSH_CMD, possibly defined
-# by --with-tclsh=
-#
-tclextension: tclsqlite3.c
-       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --build-only --cc "$(CC)" $(CFLAGS) $(OPT_FEATURE_FLAGS) $(OPTS)
-
-# Install the SQLite TCL extension in a way that is appropriate for $TCLSH_CMD
-# to find it.
-#
-tclextension-install: tclsqlite3.c
-       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --cc "$(CC)" $(CFLAGS) $(OPT_FEATURE_FLAGS) $(OPTS)
-
-# Install the SQLite TCL extension that is used by $TCLSH_CMD
-#
-tclextension-uninstall:
-       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --uninstall
-
-# List all installed the SQLite TCL extension that is are accessible
-# by $TCLSH_CMD, included prior versions.
-#
-tclextension-list:
-       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --info
-
-sqlite3$(TEXE):        shell.c sqlite3.c
-       $(TCC) $(CFLAGS_readline) $(SHELL_OPT) -o $@ \
-               shell.c sqlite3.c \
-               $(LDFLAGS_libsqlite3) $(LDFLAGS_READLINE)
-
-install-cli-0: sqlite3$(TEXT) $(install.bindir)
-       $(INSTALL) -s sqlite3$(TEXT) $(install.bindir)
-install-cli-1:
-install: install-cli-$(HAVE_WASI_SDK)
-
-sqldiff$(TEXE):        $(TOP)/tool/sqldiff.c $(TOP)/ext/misc/sqlite3_stdio.h sqlite3.o sqlite3.h
-       $(TLINK) $(CFLAGS_stdio3) -o $@ $(TOP)/tool/sqldiff.c sqlite3.o $(LDFLAGS_libsqlite3)
-
-install-diff: sqldiff$(TEXE) $(install.bindir)
-       $(INSTALL) -s sqldiff$(TEXT) $(install.bindir)
-#install: install-diff
-
-dbhash$(TEXE): $(TOP)/tool/dbhash.c sqlite3.o sqlite3.h
-       $(TLINK) -o $@ $(TOP)/tool/dbhash.c sqlite3.o $(LDFLAGS_libsqlite3)
-
-RSYNC_SRC = \
-  $(TOP)/tool/sqlite3_rsync.c \
-  sqlite3.c
-
-RSYNC_OPT = \
-  -DSQLITE_ENABLE_DBPAGE_VTAB \
-  -USQLITE_THREADSAFE \
-  -DSQLITE_THREADSAFE=0 \
-  -DSQLITE_OMIT_LOAD_EXTENSION \
-  -DSQLITE_OMIT_DEPRECATED
-
-sqlite3_rsync$(TEXE):  $(RSYNC_SRC)
-       $(TCC) -o $@ $(RSYNC_OPT) $(RSYNC_SRC) $(LDFLAGS_libsqlite3)
-
-install-rsync: sqlite3_rsync$(TEXE) $(install.bindir)
-       $(INSTALL) sqlite3_rsync$(TEXT) $(install.bindir)
-#install: install-rsync
-
-scrub$(TEXE):  $(TOP)/ext/misc/scrub.c sqlite3.o
-       $(TLINK) -o $@ -I. -DSCRUB_STANDALONE \
-               $(TOP)/ext/misc/scrub.c sqlite3.o $(LDFLAGS_libsqlite3)
-
-srcck1$(BEXE): $(TOP)/tool/srcck1.c
-       $(BCC) -o srcck1$(BEXE) $(TOP)/tool/srcck1.c
-
-sourcetest:    srcck1$(BEXE) sqlite3.c
-       ./srcck1$(BEXE) sqlite3.c
-
-src-verify$(BEXE):     $(TOP)/tool/src-verify.c
-       $(BCC) -o src-verify$(BEXE) $(TOP)/tool/src-verify.c
-
-verify-source: ./src-verify$(BEXE)
-       ./src-verify$(BEXE) $(TOP)
-
-fuzzershell$(TEXE):    $(TOP)/tool/fuzzershell.c sqlite3.c sqlite3.h
-       $(TLINK) -o $@ $(FUZZERSHELL_OPT) \
-         $(TOP)/tool/fuzzershell.c sqlite3.c $(LDFLAGS_libsqlite3)
-fuzzy: fuzzershell$(TEXE)
-
-fuzzcheck$(TEXE):      $(FUZZCHECK_SRC) sqlite3.c sqlite3.h $(FUZZCHECK_DEP)
-       $(TLINK) -o $@ $(FUZZCHECK_OPT) $(FUZZCHECK_SRC) sqlite3.c $(LDFLAGS_libsqlite3)
-fuzzy: fuzzcheck$(TEXE)
-
-fuzzcheck-asan$(TEXE): $(FUZZCHECK_SRC) sqlite3.c sqlite3.h $(FUZZCHECK_DEP)
-       $(TLINK) -o $@ -fsanitize=address $(FUZZCHECK_OPT) $(FUZZCHECK_SRC) \
-               sqlite3.c $(LDFLAGS_libsqlite3)
-fuzzy: fuzzcheck-asan$(TEXE)
-
-
-fuzzcheck-ubsan$(TEXE):        $(FUZZCHECK_SRC) sqlite3.c sqlite3.h $(FUZZCHECK_DEP)
-       $(TLINK) -o $@ -fsanitize=undefined $(FUZZCHECK_OPT) $(FUZZCHECK_SRC) \
-               sqlite3.c $(LDFLAGS_libsqlite3)
-fuzzy: fuzzcheck-ubsan$(TEXE)
-
-# Usage:    FUZZDB=filename make run-fuzzcheck
-#
-# Where filename is a fuzzcheck database, this target builds and runs
-# fuzzcheck, fuzzcheck-asan, and fuzzcheck-ubsan on that database.
-#
-# FUZZDB can be a glob pattern of two or more databases. Example:
-#
-#     FUZZDB=test/fuzzdata*.db make run-fuzzcheck
-#
-run-fuzzcheck: fuzzcheck$(TEXE) fuzzcheck-asan$(TEXE) fuzzcheck-ubsan$(TEXE)
-       @if test "$(FUZZDB)" = ""; then echo 'ERROR: No FUZZDB specified. Rerun with FUZZDB=filename'; exit 1; fi
-       ./fuzzcheck$(TEXE) --spinner $(FUZZDB)
-       ./fuzzcheck-asan$(TEXE) --spinner $(FUZZDB)
-       ./fuzzcheck-ubsan$(TEXE) --spinner $(FUZZDB)
-
-ossshell$(TEXE):       $(TOP)/test/ossfuzz.c $(TOP)/test/ossshell.c sqlite3.c sqlite3.h
-       $(TLINK) -o $@ $(FUZZCHECK_OPT) $(TOP)/test/ossshell.c \
-             $(TOP)/test/ossfuzz.c sqlite3.c $(LDFLAGS_libsqlite3)
-fuzzy: ossshell$(TEXE)
-
-sessionfuzz$(TEXE):    $(TOP)/test/sessionfuzz.c sqlite3.c sqlite3.h
-       $(TLINK) -o $@ $(TOP)/test/sessionfuzz.c $(LDFLAGS_libsqlite3)
-fuzzy: sessionfuzz$(TEXE)
-
-dbfuzz$(TEXE): $(TOP)/test/dbfuzz.c sqlite3.c sqlite3.h
-       $(TLINK) -o $@ $(DBFUZZ_OPT) $(TOP)/test/dbfuzz.c sqlite3.c $(LDFLAGS_libsqlite3)
-fuzzy: dbfuzz$(TEXE)
-
-DBFUZZ2_OPTS = \
-  -USQLITE_THREADSAFE \
-  -DSQLITE_THREADSAFE=0 \
-  -DSQLITE_OMIT_LOAD_EXTENSION \
-  -DSQLITE_DEBUG \
-  -DSQLITE_ENABLE_DBSTAT_VTAB \
-  -DSQLITE_ENABLE_BYTECODE_VTAB \
-  -DSQLITE_ENABLE_RTREE \
-  -DSQLITE_ENABLE_FTS4 \
-  -DSQLITE_ENABLE_FTS5
-
-dbfuzz2$(TEXE):        $(TOP)/test/dbfuzz2.c sqlite3.c sqlite3.h
-       $(CC) $(OPT_FEATURE_FLAGS) $(OPTS) -I. -g -O0 \
-               -DSTANDALONE -o dbfuzz2 \
-               $(DBFUZZ2_OPTS) $(TOP)/test/dbfuzz2.c sqlite3.c $(LDFLAGS_libsqlite3)
-       mkdir -p dbfuzz2-dir
-       cp $(TOP)/test/dbfuzz2-seed* dbfuzz2-dir
-fuzzy: dbfuzz2$(TEXE)
-
-mptester$(TEXE):       $(libsqlite3.LIB) $(TOP)/mptest/mptest.c
-       $(TLINK) -o $@ -I. $(TOP)/mptest/mptest.c $(libsqlite3.LIB) \
-               $(LDFLAGS_libsqlite3)
-
-MPTEST1=./mptester$(TEXE) mptest.db $(TOP)/mptest/crash01.test --repeat 20
-MPTEST2=./mptester$(TEXE) mptest.db $(TOP)/mptest/multiwrite01.test --repeat 20
-mptest:        mptester$(TEXE)
-       rm -f mptest.db
-       $(MPTEST1) --journalmode DELETE
-       $(MPTEST2) --journalmode WAL
-       $(MPTEST1) --journalmode WAL
-       $(MPTEST2) --journalmode PERSIST
-       $(MPTEST1) --journalmode PERSIST
-       $(MPTEST2) --journalmode TRUNCATE
-       $(MPTEST1) --journalmode TRUNCATE
-       $(MPTEST2) --journalmode DELETE
-
-has_tclsh84:
-       sh $(TOP)/tool/cktclsh.sh 8.4 $(TCLSH_CMD)
-       touch has_tclsh84
-
-has_tclsh85:
-       sh $(TOP)/tool/cktclsh.sh 8.5 $(TCLSH_CMD)
-       touch has_tclsh85
-
-has_tclconfig:
-       @if [ x = "x$(TCL_CONFIG_SH)" ]; then
-               echo 'TCL_CONFIG_SH must be set to point to a "tclConfig.sh"' 1>&2; exit 1; \
-       fi
-       touch has_tclconfig
-
-#
-# This target creates a directory named "tsrc" and fills it with
-# copies of all of the C source code and header files needed to
-# build on the target system.  Some of the C source code and header
-# files are automatically generated.  This target takes care of
-# all that automatic generation.
-#
-.target_source:        $(SRC) $(TOP)/tool/vdbe-compress.tcl fts5.c $(BTCLSH) # has_tclsh84
-       rm -rf tsrc
-       mkdir tsrc
-       cp -f $(SRC) tsrc
-       rm tsrc/sqlite.h.in tsrc/parse.y
-       $(BTCLSH) $(TOP)/tool/vdbe-compress.tcl $(OPTS) <tsrc/vdbe.c >vdbe.new
-       mv vdbe.new tsrc/vdbe.c
-       cp fts5.c fts5.h tsrc
-       touch .target_source
-
-sqlite3.h:     $(TOP)/src/sqlite.h.in $(TOP)/manifest mksourceid$(BEXE) \
-               $(TOP)/VERSION $(BTCLSH) # has_tclsh84
-       $(BTCLSH) $(TOP)/tool/mksqlite3h.tcl $(TOP) >sqlite3.h
-
-sqlite3.c:     .target_source sqlite3.h $(TOP)/tool/mksqlite3c.tcl src-verify \
-               $(BTCLSH) # has_tclsh84
-       $(BTCLSH) $(TOP)/tool/mksqlite3c.tcl $(AMALGAMATION_LINE_MACROS) $(EXTRA_SRC)
-       cp tsrc/sqlite3ext.h .
-       cp $(TOP)/ext/session/sqlite3session.h .
-
-sqlite3r.h: sqlite3.h $(BTCLSH) # has_tclsh84
-       $(BTCLSH) $(TOP)/tool/mksqlite3h.tcl $(TOP) --enable-recover >sqlite3r.h
-
-sqlite3r.c: sqlite3.c sqlite3r.h $(BTCLSH) # has_tclsh84
-       cp $(TOP)/ext/recover/sqlite3recover.c tsrc/
-       cp $(TOP)/ext/recover/sqlite3recover.h tsrc/
-       cp $(TOP)/ext/recover/dbdata.c tsrc/
-       $(BTCLSH) $(TOP)/tool/mksqlite3c.tcl --enable-recover $(AMALGAMATION_LINE_MACROS) $(EXTRA_SRC)
-
-sqlite3ext.h:  .target_source
-       cp tsrc/sqlite3ext.h .
-
-# Rules to build the LEMON compiler generator
-#
-lemon$(BEXE):  $(TOP)/tool/lemon.c $(TOP)/tool/lempar.c
-       $(BCC) -o $@ $(TOP)/tool/lemon.c
-       cp $(TOP)/tool/lempar.c .
-
-# Rules to build the program that generates the source-id
-#
-mksourceid$(BEXE):     $(TOP)/tool/mksourceid.c
-       $(BCC) -o $@ $(TOP)/tool/mksourceid.c
-
-# Rules to build individual *.o files from generated *.c files. This
-# applies to:
-#
-#     parse.o
-#     opcodes.o
-#
-parse.o:       parse.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c parse.c
-
-opcodes.o:     opcodes.c
-       $(TCOMPILE) $(TEMP_STORE) -c opcodes.c
-
-# Rules to build individual *.o files from files in the src directory.
-#
-alter.o:       $(TOP)/src/alter.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/alter.c
-
-analyze.o:     $(TOP)/src/analyze.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/analyze.c
-
-attach.o:      $(TOP)/src/attach.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/attach.c
-
-auth.o:        $(TOP)/src/auth.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/auth.c
-
-backup.o:      $(TOP)/src/backup.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/backup.c
-
-bitvec.o:      $(TOP)/src/bitvec.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/bitvec.c
-
-btmutex.o:     $(TOP)/src/btmutex.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/btmutex.c
-
-btree.o:       $(TOP)/src/btree.c $(HDR) $(TOP)/src/pager.h
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/btree.c
-
-build.o:       $(TOP)/src/build.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/build.c
-
-callback.o:    $(TOP)/src/callback.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/callback.c
-
-complete.o:    $(TOP)/src/complete.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/complete.c
-
-ctime.o:       $(TOP)/src/ctime.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/ctime.c
-
-date.o:        $(TOP)/src/date.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/date.c
-
-dbpage.o:      $(TOP)/src/dbpage.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/dbpage.c
-
-dbstat.o:      $(TOP)/src/dbstat.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/dbstat.c
-
-delete.o:      $(TOP)/src/delete.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/delete.c
-
-expr.o:        $(TOP)/src/expr.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/expr.c
-
-fault.o:       $(TOP)/src/fault.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/fault.c
-
-fkey.o:        $(TOP)/src/fkey.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/fkey.c
-
-func.o:        $(TOP)/src/func.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/func.c
-
-global.o:      $(TOP)/src/global.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/global.c
-
-hash.o:        $(TOP)/src/hash.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/hash.c
-
-insert.o:      $(TOP)/src/insert.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/insert.c
-
-json.o:        $(TOP)/src/json.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/json.c
-
-legacy.o:      $(TOP)/src/legacy.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/legacy.c
-
-loadext.o:     $(TOP)/src/loadext.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/loadext.c
-
-main.o:        $(TOP)/src/main.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/main.c
-
-malloc.o:      $(TOP)/src/malloc.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/malloc.c
-
-mem0.o:        $(TOP)/src/mem0.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem0.c
-
-mem1.o:        $(TOP)/src/mem1.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem1.c
-
-mem2.o:        $(TOP)/src/mem2.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem2.c
-
-mem3.o:        $(TOP)/src/mem3.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem3.c
-
-mem5.o:        $(TOP)/src/mem5.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem5.c
-
-memdb.o:       $(TOP)/src/memdb.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/memdb.c
-
-memjournal.o:  $(TOP)/src/memjournal.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/memjournal.c
-
-mutex.o:       $(TOP)/src/mutex.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex.c
-
-mutex_noop.o:  $(TOP)/src/mutex_noop.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex_noop.c
-
-mutex_unix.o:  $(TOP)/src/mutex_unix.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex_unix.c
-
-mutex_w32.o:   $(TOP)/src/mutex_w32.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex_w32.c
-
-notify.o:      $(TOP)/src/notify.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/notify.c
-
-pager.o:       $(TOP)/src/pager.c $(HDR) $(TOP)/src/pager.h
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pager.c
-
-pcache.o:      $(TOP)/src/pcache.c $(HDR) $(TOP)/src/pcache.h
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pcache.c
-
-pcache1.o:     $(TOP)/src/pcache1.c $(HDR) $(TOP)/src/pcache.h
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pcache1.c
-
-os.o:  $(TOP)/src/os.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os.c
-
-os_kv.o:       $(TOP)/src/os_kv.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os_kv.c
-
-os_unix.o:     $(TOP)/src/os_unix.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os_unix.c
-
-os_win.o:      $(TOP)/src/os_win.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os_win.c
-
-pragma.o:      $(TOP)/src/pragma.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pragma.c
-
-prepare.o:     $(TOP)/src/prepare.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/prepare.c
-
-printf.o:      $(TOP)/src/printf.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/printf.c
-
-random.o:      $(TOP)/src/random.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/random.c
-
-resolve.o:     $(TOP)/src/resolve.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/resolve.c
-
-rowset.o:      $(TOP)/src/rowset.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/rowset.c
-
-select.o:      $(TOP)/src/select.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/select.c
-
-status.o:      $(TOP)/src/status.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/status.c
-
-table.o:       $(TOP)/src/table.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/table.c
-
-threads.o:     $(TOP)/src/threads.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/threads.c
-
-tokenize.o:    $(TOP)/src/tokenize.c keywordhash.h $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/tokenize.c
-
-treeview.o:    $(TOP)/src/treeview.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/treeview.c
-
-trigger.o:     $(TOP)/src/trigger.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/trigger.c
-
-update.o:      $(TOP)/src/update.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/update.c
-
-upsert.o:      $(TOP)/src/upsert.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/upsert.c
-
-utf.o: $(TOP)/src/utf.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/utf.c
-
-util.o:        $(TOP)/src/util.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/util.c
-
-vacuum.o:      $(TOP)/src/vacuum.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vacuum.c
-
-vdbe.o:        $(TOP)/src/vdbe.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbe.c
-
-vdbeapi.o:     $(TOP)/src/vdbeapi.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbeapi.c
-
-vdbeaux.o:     $(TOP)/src/vdbeaux.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbeaux.c
-
-vdbeblob.o:    $(TOP)/src/vdbeblob.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbeblob.c
-
-vdbemem.o:     $(TOP)/src/vdbemem.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbemem.c
-
-vdbesort.o:    $(TOP)/src/vdbesort.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbesort.c
-
-vdbetrace.o:   $(TOP)/src/vdbetrace.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbetrace.c
-
-vdbevtab.o:    $(TOP)/src/vdbevtab.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbevtab.c
-
-vtab.o:        $(TOP)/src/vtab.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vtab.c
-
-wal.o: $(TOP)/src/wal.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/wal.c
-
-walker.o:      $(TOP)/src/walker.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/walker.c
-
-where.o:       $(TOP)/src/where.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/where.c
-
-wherecode.o:   $(TOP)/src/wherecode.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/wherecode.c
-
-whereexpr.o:   $(TOP)/src/whereexpr.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/whereexpr.c
-
-window.o:      $(TOP)/src/window.c $(HDR)
-       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/window.c
-
-tclsqlite.o:   $(TOP)/src/tclsqlite.c $(HDR)
-       $(TCOMPILE) -DUSE_TCL_STUBS=1 $(TCL_INCLUDE_SPEC) \
-               -c $(TOP)/src/tclsqlite.c
-
-tclsqlite-shell.o:     $(TOP)/src/tclsqlite.c $(HDR)
-       $(TCOMPILE) -DTCLSH -o $@ -c $(TOP)/src/tclsqlite.c
-
-tclsqlite-stubs.o:     $(TOP)/src/tclsqlite.c $(HDR)
-       $(TCOMPILE) -DUSE_TCL_STUBS=1 -o $@ -c $(TOP)/src/tclsqlite.c
-
-tclsqlite3$(TEXE):     has_tclconfig tclsqlite-shell.o $(libsqlite3.LIB)
-       $(TLINK) -o $@ tclsqlite-shell.o \
-                $(libsqlite3.LIB) $(LIBTCL)
-
-# Rules to build opcodes.c and opcodes.h
-#
-opcodes.c:     opcodes.h $(TOP)/tool/mkopcodec.tcl $(BTCLSH) # has_tclsh84
-       $(BTCLSH) $(TOP)/tool/mkopcodec.tcl opcodes.h >opcodes.c
-
-opcodes.h:     parse.h $(TOP)/src/vdbe.c \
-               $(TOP)/tool/mkopcodeh.tcl $(BTCLSH) # has_tclsh84
-       cat parse.h $(TOP)/src/vdbe.c | $(BTCLSH) $(TOP)/tool/mkopcodeh.tcl >opcodes.h
-
-# Rules to build parse.c and parse.h - the outputs of lemon.
-#
-parse.h:       parse.c
-
-parse.c:       $(TOP)/src/parse.y lemon$(BEXE)
-       cp $(TOP)/src/parse.y .
-       ./lemon$(BEXE) $(OPT_FEATURE_FLAGS) $(OPTS) -S parse.y
-
-sqlite3rc.h:   $(TOP)/src/sqlite3.rc $(TOP)/VERSION $(BTCLSH) # has_tclsh84
-       echo '#ifndef SQLITE_RESOURCE_VERSION' >$@
-       echo -n '#define SQLITE_RESOURCE_VERSION ' >>$@
-       cat $(TOP)/VERSION | $(BTCLSH) $(TOP)/tool/replace.tcl exact . , >>$@
-       echo '#endif' >>sqlite3rc.h
-
-keywordhash.h: $(TOP)/tool/mkkeywordhash.c
-       $(BCC) -o mkkeywordhash$(BEXE) $(OPT_FEATURE_FLAGS) $(OPTS) $(TOP)/tool/mkkeywordhash.c
-       ./mkkeywordhash$(BEXE) >keywordhash.h
-
-# Source and header files that shell.c depends on
-SHELL_DEP = \
-    $(TOP)/src/shell.c.in \
-    $(TOP)/ext/consio/console_io.c \
-    $(TOP)/ext/consio/console_io.h \
-    $(TOP)/ext/expert/sqlite3expert.c \
-    $(TOP)/ext/expert/sqlite3expert.h \
-    $(TOP)/ext/intck/sqlite3intck.c \
-    $(TOP)/ext/intck/sqlite3intck.h \
-    $(TOP)/ext/misc/appendvfs.c \
-    $(TOP)/ext/misc/base64.c \
-    $(TOP)/ext/misc/base85.c \
-    $(TOP)/ext/misc/completion.c \
-    $(TOP)/ext/misc/decimal.c \
-    $(TOP)/ext/misc/fileio.c \
-    $(TOP)/ext/misc/ieee754.c \
-    $(TOP)/ext/misc/memtrace.c \
-    $(TOP)/ext/misc/pcachetrace.c \
-    $(TOP)/ext/misc/percentile.c \
-    $(TOP)/ext/misc/regexp.c \
-    $(TOP)/ext/misc/series.c \
-    $(TOP)/ext/misc/sha1.c \
-    $(TOP)/ext/misc/shathree.c \
-    $(TOP)/ext/misc/sqlar.c \
-    $(TOP)/ext/misc/uint.c \
-    $(TOP)/ext/misc/vfstrace.c \
-    $(TOP)/ext/misc/zipfile.c \
-    $(TOP)/ext/recover/dbdata.c \
-    $(TOP)/ext/recover/sqlite3recover.c \
-    $(TOP)/ext/recover/sqlite3recover.h \
-    $(TOP)/src/test_windirent.c \
-    $(TOP)/src/test_windirent.h
-
-shell.c:       $(SHELL_DEP) $(TOP)/tool/mkshellc.tcl $(BTCLSH) # has_tclsh84
-       $(BTCLSH) $(TOP)/tool/mkshellc.tcl >shell.c
-
-
-# Rules to build the extension objects.
-#
-icu.o: $(TOP)/ext/icu/icu.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/icu/icu.c
-
-fts3.o:        $(TOP)/ext/fts3/fts3.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3.c
-
-fts3_aux.o:    $(TOP)/ext/fts3/fts3_aux.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_aux.c
-
-fts3_expr.o:   $(TOP)/ext/fts3/fts3_expr.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_expr.c
-
-fts3_hash.o:   $(TOP)/ext/fts3/fts3_hash.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_hash.c
-
-fts3_icu.o:    $(TOP)/ext/fts3/fts3_icu.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_icu.c
-
-fts3_porter.o: $(TOP)/ext/fts3/fts3_porter.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_porter.c
-
-fts3_snippet.o:        $(TOP)/ext/fts3/fts3_snippet.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_snippet.c
-
-fts3_tokenizer.o:      $(TOP)/ext/fts3/fts3_tokenizer.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_tokenizer.c
-
-fts3_tokenizer1.o:     $(TOP)/ext/fts3/fts3_tokenizer1.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_tokenizer1.c
-
-fts3_tokenize_vtab.o:  $(TOP)/ext/fts3/fts3_tokenize_vtab.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_tokenize_vtab.c
-
-fts3_unicode.o:        $(TOP)/ext/fts3/fts3_unicode.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_unicode.c
-
-fts3_unicode2.o:       $(TOP)/ext/fts3/fts3_unicode2.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_unicode2.c
-
-fts3_write.o:  $(TOP)/ext/fts3/fts3_write.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_write.c
-
-rtree.o:       $(TOP)/ext/rtree/rtree.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/rtree/rtree.c
-
-userauth.o:    $(TOP)/ext/userauth/userauth.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/userauth/userauth.c
-
-sqlite3session.o:      $(TOP)/ext/session/sqlite3session.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/session/sqlite3session.c
-
-stmt.o:        $(TOP)/ext/misc/stmt.c
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/misc/stmt.c
-
-# FTS5 things
-#
-FTS5_SRC = \
-   $(TOP)/ext/fts5/fts5.h \
-   $(TOP)/ext/fts5/fts5Int.h \
-   $(TOP)/ext/fts5/fts5_aux.c \
-   $(TOP)/ext/fts5/fts5_buffer.c \
-   $(TOP)/ext/fts5/fts5_main.c \
-   $(TOP)/ext/fts5/fts5_config.c \
-   $(TOP)/ext/fts5/fts5_expr.c \
-   $(TOP)/ext/fts5/fts5_hash.c \
-   $(TOP)/ext/fts5/fts5_index.c \
-   fts5parse.c fts5parse.h \
-   $(TOP)/ext/fts5/fts5_storage.c \
-   $(TOP)/ext/fts5/fts5_tokenize.c \
-   $(TOP)/ext/fts5/fts5_unicode2.c \
-   $(TOP)/ext/fts5/fts5_varint.c \
-   $(TOP)/ext/fts5/fts5_vocab.c  \
-
-fts5parse.c:   $(TOP)/ext/fts5/fts5parse.y lemon$(BEXE)
-       cp $(TOP)/ext/fts5/fts5parse.y .
-       rm -f fts5parse.h
-       ./lemon$(BEXE) $(OPTS) -S fts5parse.y
-
-fts5parse.h: fts5parse.c
-
-fts5.c: $(FTS5_SRC) $(BTCLSH) # has_tclsh84
-       $(BTCLSH) $(TOP)/ext/fts5/tool/mkfts5c.tcl
-       cp $(TOP)/ext/fts5/fts5.h .
-
-fts5.o:        fts5.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c fts5.c
-
-sqlite3rbu.o:  $(TOP)/ext/rbu/sqlite3rbu.c $(HDR) $(EXTHDR)
-       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/rbu/sqlite3rbu.c
-
-
-# Rules to build the 'testfixture' application.
-#
-# If using the amalgamation, use sqlite3.c directly to build the test
-# fixture.  Otherwise link against libsqlite3.a.  (This distinction is
-# necessary because the test fixture requires non-API symbols which are
-# hidden when the library is built via the amalgamation).
-#
-TESTFIXTURE_FLAGS  = -DSQLITE_TEST=1 -DSQLITE_CRASH_TEST=1
-TESTFIXTURE_FLAGS += -DTCLSH_INIT_PROC=sqlite3TestInit
-TESTFIXTURE_FLAGS += -DSQLITE_SERVER=1 -DSQLITE_PRIVATE="" -DSQLITE_CORE
-TESTFIXTURE_FLAGS += -DBUILD_sqlite
-TESTFIXTURE_FLAGS += -DSQLITE_SERIES_CONSTRAINT_VERIFY=1
-TESTFIXTURE_FLAGS += -DSQLITE_DEFAULT_PAGE_SIZE=1024
-TESTFIXTURE_FLAGS += -DSQLITE_ENABLE_STMTVTAB
-TESTFIXTURE_FLAGS += -DSQLITE_ENABLE_DBPAGE_VTAB
-TESTFIXTURE_FLAGS += -DSQLITE_ENABLE_BYTECODE_VTAB
-TESTFIXTURE_FLAGS += -DSQLITE_CKSUMVFS_STATIC
-TESTFIXTURE_FLAGS += -DSQLITE_STATIC_RANDOMJSON
-TESTFIXTURE_FLAGS += -DSQLITE_STRICT_SUBTYPE=1
-
-TESTFIXTURE_SRC0 = $(TESTSRC2) $(libsqlite3.LIB)
-TESTFIXTURE_SRC1 = sqlite3.c
-TESTFIXTURE_SRC = $(TESTSRC) $(TOP)/src/tclsqlite.c
-TESTFIXTURE_SRC += $(TESTFIXTURE_SRC$(USE_AMALGAMATION))
-
-testfixture$(TEXE):    has_tclconfig has_tclsh85 $(TESTFIXTURE_SRC)
-       $(TLINK) -DSQLITE_NO_SYNC=1 $(TEMP_STORE) $(TESTFIXTURE_FLAGS) \
-               -o $@ $(TESTFIXTURE_SRC) $(LIBTCL) $(LDFLAGS_libsqlite3) $(TCL_INCLUDE_SPEC)
-
-coretestprogs: testfixture$(BEXE) sqlite3$(BEXE)
-
-testprogs:     $(TESTPROGS) srcck1$(BEXE) fuzzcheck$(TEXE) sessionfuzz$(TEXE)
-
-# A very detailed test running most or all test cases
-fulltest:      alltest fuzztest
-
-# Run most or all tcl test cases
-alltest:       $(TESTPROGS)
-       ./testfixture$(TEXE) $(TOP)/test/all.test $(TESTOPTS)
-
-# Really really long testing
-soaktest:      $(TESTPROGS)
-       ./testfixture$(TEXE) $(TOP)/test/all.test -soak=1 $(TESTOPTS)
-
-# Do extra testing but not everything.
-fulltestonly:  $(TESTPROGS) fuzztest
-       ./testfixture$(TEXE) $(TOP)/test/full.test
-
-# Fuzz testing
-#
-# WARNING: When the "fuzztest" target is run by the testrunner.tcl script,
-# it does not actually run this code. Instead, it schedules equivalent
-# commands. Therefore, if this target is updated, then code in
-# testrunner_data.tcl (search for "trd_fuzztest_data") must also be updated.
-#
-fuzztest:      fuzzcheck$(TEXE) $(FUZZDATA) sessionfuzz$(TEXE)
-       ./fuzzcheck$(TEXE) $(FUZZDATA)
-       ./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
-
-valgrindfuzz:  fuzzcheck$(TEXT) $(FUZZDATA) sessionfuzz$(TEXE)
-       valgrind ./fuzzcheck$(TEXE) --cell-size-check --limit-mem 10M $(FUZZDATA)
-       valgrind ./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
-
-# The veryquick.test TCL tests.
-#
-tcltest:       ./testfixture$(TEXE)
-       ./testfixture$(TEXE) $(TOP)/test/veryquick.test $(TESTOPTS)
-
-# Runs all the same tests cases as the "tcltest" target but uses
-# the testrunner.tcl script to run them in multiple cores
-# concurrently.
-testrunner:    testfixture$(TEXE)
-       ./testfixture$(TEXE) $(TOP)/test/testrunner.tcl
-
-# This is the testing target preferred by the core SQLite developers.
-# It runs tests under a standard configuration, regardless of how
-# ./configure was run.  The devs run "make devtest" prior to each
-# check-in, at a minimum.  Probably other tests too, but at least this
-# one.
-#
-devtest:       srctree-check sourcetest
-       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl mdevtest $(TSTRNNR_OPTS)
-
-mdevtest: srctree-check has_tclsh85
-       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl mdevtest $(TSTRNNR_OPTS)
-
-sdevtest: has_tclsh85
-       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl sdevtest $(TSTRNNR_OPTS)
-
-# Validate that various generated files in the source tree
-# are up-to-date.
-#
-srctree-check: $(TOP)/tool/srctree-check.tcl
-       $(TCLSH_CMD) $(TOP)/tool/srctree-check.tcl
-
-# Testing for a release
-#
-releasetest: srctree-check has_tclsh85 verify-source
-       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl release $(TSTRNNR_OPTS)
-
-# Minimal testing that runs in less than 3 minutes
-#
-quicktest:     ./testfixture$(TEXE)
-       ./testfixture$(TEXE) $(TOP)/test/extraquick.test $(TESTOPTS)
-
-# Try to run tests on whatever options are specified by the
-# ./configure.  The developers seldom use this target.  Instead
-# they use "make devtest" which runs tests on a standard set of
-# options regardless of how SQLite is configured.  This "test"
-# target is provided for legacy only.
-#
-test:  srctree-check fuzztest sourcetest $(TESTPROGS) tcltest
-
-# Run a test using valgrind.  This can take a really long time
-# because valgrind is so much slower than a native machine.
-#
-valgrindtest:  $(TESTPROGS) valgrindfuzz
-       OMIT_MISUSE=1 valgrind -v ./testfixture$(TEXE) $(TOP)/test/permutations.test valgrind $(TESTOPTS)
-
-# A very fast test that checks basic sanity.  The name comes from
-# the 60s-era electronics testing:  "Turn it on and see if smoke
-# comes out."
-#
-smoketest:     $(TESTPROGS) fuzzcheck$(TEXE)
-       ./testfixture$(TEXE) $(TOP)/test/main.test $(TESTOPTS)
-
-shelltest:
-       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl release shell
-
-sqlite3_analyzer.c: sqlite3.c $(TOP)/src/tclsqlite.c $(TOP)/tool/spaceanal.tcl \
-                    $(TOP)/tool/mkccode.tcl $(TOP)/tool/sqlite3_analyzer.c.in has_tclsh85
-       $(BTCLSH) $(TOP)/tool/mkccode.tcl $(TOP)/tool/sqlite3_analyzer.c.in >sqlite3_analyzer.c
-
-sqlite3_analyzer$(TEXE): has_tclconfig sqlite3_analyzer.c
-       $(TLINK) sqlite3_analyzer.c -o $@ $(LIBTCL) $(TCL_INCLUDE_SPEC) $(LDFLAGS_libsqlite3)
-
-sqltclsh.c: sqlite3.c $(TOP)/src/tclsqlite.c $(TOP)/tool/sqltclsh.tcl \
-            $(TOP)/ext/misc/appendvfs.c $(TOP)/tool/mkccode.tcl \
-            $(TOP)/tool/sqltclsh.c.in has_tclsh85
-       $(BTCLSH) $(TOP)/tool/mkccode.tcl $(TOP)/tool/sqltclsh.c.in >sqltclsh.c
-
-sqltclsh$(TEXE): has_tclconfig sqltclsh.c
-       $(TLINK) sqltclsh.c -o $@ $(LIBTCL) $(LDFLAGS_libsqlite3)
-
-sqlite3_expert$(TEXE): $(TOP)/ext/expert/sqlite3expert.h $(TOP)/ext/expert/sqlite3expert.c \
-                       $(TOP)/ext/expert/expert.c sqlite3.c
-       $(TLINK)        $(TOP)/ext/expert/sqlite3expert.h $(TOP)/ext/expert/sqlite3expert.c \
-               $(TOP)/ext/expert/expert.c sqlite3.c -o sqlite3_expert $(LDFLAGS_libsqlite3)
-
-CHECKER_DEPS =\
-  $(TOP)/tool/mkccode.tcl \
-  sqlite3.c \
-  $(TOP)/src/tclsqlite.c \
-  $(TOP)/ext/repair/sqlite3_checker.tcl \
-  $(TOP)/ext/repair/checkindex.c \
-  $(TOP)/ext/repair/checkfreelist.c \
-  $(TOP)/ext/misc/btreeinfo.c \
-  $(TOP)/ext/repair/sqlite3_checker.c.in
-
-sqlite3_checker.c:     $(CHECKER_DEPS) has_tclsh85
-       $(BTCLSH) $(TOP)/tool/mkccode.tcl $(TOP)/ext/repair/sqlite3_checker.c.in >$@
-
-sqlite3_checker$(TEXE):        has_tclconfig sqlite3_checker.c
-       $(TLINK) sqlite3_checker.c -o $@ $(LIBTCL) $(LDFLAGS_libsqlite3)
-
-dbdump$(TEXE): $(TOP)/ext/misc/dbdump.c sqlite3.lo
-       $(TLINK) -DDBDUMP_STANDALONE -o $@ \
-           $(TOP)/ext/misc/dbdump.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-dbtotxt$(TEXE): $(TOP)/tool/dbtotxt.c
-       $(TLINK)-o $@ $(TOP)/tool/dbtotxt.c
-
-showdb$(TEXE): $(TOP)/tool/showdb.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/tool/showdb.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-showstat4$(TEXE):      $(TOP)/tool/showstat4.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/tool/showstat4.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-showjournal$(TEXE):    $(TOP)/tool/showjournal.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/tool/showjournal.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-showwal$(TEXE):        $(TOP)/tool/showwal.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/tool/showwal.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-showshm$(TEXE):        $(TOP)/tool/showshm.c
-       $(TLINK) -o $@ $(TOP)/tool/showshm.c
-
-index_usage$(TEXE): $(TOP)/tool/index_usage.c sqlite3.lo
-       $(TLINK) $(SHELL_OPT) -o $@ $(TOP)/tool/index_usage.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-changeset$(TEXE):      $(TOP)/ext/session/changeset.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/ext/session/changeset.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-changesetfuzz$(TEXE):  $(TOP)/ext/session/changesetfuzz.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/ext/session/changesetfuzz.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-rollback-test$(TEXE):  $(TOP)/tool/rollback-test.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/tool/rollback-test.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-atrc$(TEXX): $(TOP)/test/atrc.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/test/atrc.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-LogEst$(TEXE): $(TOP)/tool/logest.c sqlite3.h
-       $(TLINK) -I. -o $@ $(TOP)/tool/logest.c
-
-wordcount$(TEXE):      $(TOP)/test/wordcount.c sqlite3.lo
-       $(TLINK) -o $@ $(TOP)/test/wordcount.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-speedtest1$(TEXE):     $(TOP)/test/speedtest1.c sqlite3.c Makefile
-       $(TLINK) $(ST_OPT) -o $@ $(TOP)/test/speedtest1.c sqlite3.c $(LDFLAGS_libsqlite3)
-
-#XX#startup$(TEXE):    $(TOP)/test/startup.c sqlite3.c
-#XX#   $(CC) -Os -g -DSQLITE_THREADSAFE=0 -o $@ $(TOP)/test/startup.c sqlite3.c $(TLIBS)
-# ^^^ note that it wants $(TLIBS) (a.k.a. $(LDFLAGS_libsqlite3) but is using $(CC)
-# instead of $(BCC).
-
-KV_OPT += -DSQLITE_DIRECT_OVERFLOW_READ
-
-kvtest$(TEXE): $(TOP)/test/kvtest.c sqlite3.c
-       $(TLINK) $(KV_OPT) -o $@ $(TOP)/test/kvtest.c sqlite3.c $(LDFLAGS_libsqlite3)
-
-rbu$(EXE): $(TOP)/ext/rbu/rbu.c $(TOP)/ext/rbu/sqlite3rbu.c sqlite3.lo
-       $(TLINK) -I. -o $@ $(TOP)/ext/rbu/rbu.c sqlite3.lo $(LDFLAGS_libsqlite3)
-
-loadfts$(EXE): $(TOP)/tool/loadfts.c libsqlite3.la
-       $(TLINK) $(TOP)/tool/loadfts.c libsqlite3.la -o $@ $(LDFLAGS_libsqlite3)
-
-# This target will fail if the SQLite amalgamation contains any exported
-# symbols that do not begin with "sqlite3_". It is run as part of the
-# releasetest.tcl script.
-#
-VALIDIDS=' sqlite3(changeset|changegroup|session)?_'
-checksymbols: sqlite3.o
-       nm -g --defined-only sqlite3.o
-       nm -g --defined-only sqlite3.o | egrep -v $(VALIDIDS); test $$? -ne 0
-       echo '0 errors out of 1 tests'
-
-# Build a ZIP archive containing various command-line tools.
-#
-tool-zip:      testfixture$(TEXE) sqlite3$(TEXE) sqldiff$(TEXE) \
-            sqlite3_analyzer$(TEXE) sqlite3_rsync$(TEXE) $(TOP)/tool/mktoolzip.tcl
-       strip sqlite3$(TEXE) sqldiff$(TEXE) sqlite3_analyzer$(TEXE) sqlite3_rsync$(TEXE)
-       ./testfixture$(TEXE) $(TOP)/tool/mktoolzip.tcl
-
-#XX# TODO: adapt the autoconf amalgamation for autosetup
-#XX#
-#XX## Build the amalgamation-autoconf package.  The amalamgation-tarball target builds
-#XX## a tarball named for the version number.  Ex:  sqlite-autoconf-3110000.tar.gz.
-#XX## The snapshot-tarball target builds a tarball named by the SHA1 hash
-#XX##
-#XX#amalgamation-tarball: sqlite3.c sqlite3rc.h
-#XX#   TOP=$(TOP) sh $(TOP)/tool/mkautoconfamal.sh --normal
-#XX#
-#XX#snapshot-tarball: sqlite3.c sqlite3rc.h
-#XX#   TOP=$(TOP) sh $(TOP)/tool/mkautoconfamal.sh --snapshot
-#XX#
-
-# The next two rules are used to support the "threadtest" target. Building
-# threadtest runs a few thread-safety tests that are implemented in C. This
-# target is invoked by the releasetest.tcl script.
-#
-THREADTEST3_SRC = $(TOP)/test/threadtest3.c    \
-                  $(TOP)/test/tt3_checkpoint.c \
-                  $(TOP)/test/tt3_index.c      \
-                  $(TOP)/test/tt3_vacuum.c      \
-                  $(TOP)/test/tt3_stress.c      \
-                  $(TOP)/test/tt3_lookaside1.c
-
-threadtest3$(TEXE): sqlite3.lo $(THREADTEST3_SRC)
-       $(TLINK) $(TOP)/test/threadtest3.c $(TOP)/src/test_multiplex.c sqlite3.lo -o $@ $(LDFLAGS_libsqlite3)
-
-threadtest: threadtest3$(TEXE)
-       ./threadtest3$(TEXE)
-
-threadtest5: sqlite3.c $(TOP)/test/threadtest5.c
-       $(TLINK) $(TOP)/test/threadtest5.c sqlite3.c -o $@ $(LDFLAGS_libsqlite3)
-
-#
-# Windows section
-#
-dll: sqlite3.dll
-sqlite3.def: $(LIBOBJ)
-       echo 'EXPORTS' >sqlite3.def
-       nm $(LIBOBJ) | grep ' T ' | grep ' _sqlite3_' \
-               | sed 's/^.* _//' >>sqlite3.def
-
-sqlite3.dll: $(LIBOBJ) sqlite3.def
-       $(TCC) @SHOBJ_LDFLAGS@ -o $@ sqlite3.def \
-               -Wl,"--strip-all" $(LIBOBJ)
 
 #
 # Fiddle app
@@ -1836,53 +303,4 @@ fiddle: sqlite3.c shell.c
 misspell: ./custom.rws has_tclsh84
        $(TCLSH_CMD) ./tool/spellsift.tcl ./src/*.c ./src/*.h ./src/*.in
 
-#
-# tool/version-info: a utility for emitting sqlite3 version info
-# in various forms.
-#
-version-info$(TEXE):   $(TOP)/tool/version-info.c Makefile sqlite3.h
-       $(TLINK) $(ST_OPT) -o $@ $(TOP)/tool/version-info.c
-
-
-# Remove build products sufficient so that subsequent makes will recompile
-# everything from scratch.  Do not remove:
-#
-#   *   test results and test logs
-#   *   output from ./configure
-#
-tidy:
-       rm -f *.o *.c *.da *.bb *.bbg gmon.* *.rws sqlite3$(TEXE)
-       rm -f fts5.h keywordhash.h opcodes.h sqlite3.h sqlite3ext.h sqlite3session.h
-       rm -rf .libs .deps tsrc .target_source
-       rm -f lemon$(BEXE) sqlite*.tar.gz
-       rm -f mkkeywordhash$(BEXE) mksourceid$(BEXE)
-       rm -f parse.* fts5parse.*
-       rm -f $(libsqlite3.SO) $(libsqlite3.LIB)
-       rm -f tclsqlite3$(TEXE) $(TESTPROGS)
-       rm -f LogEst$(TEXE) fts3view$(TEXE) rollback-test$(TEXE) showdb$(TEXE)
-       rm -f showjournal$(TEXE) showstat4$(TEXE) showwal$(TEXE) speedtest1$(TEXE)
-       rm -f wordcount$(TEXE) changeset$(TEXE) version-info$(TEXE)
-       rm -f *.dll *.lib *.exp *.pc *.vsix *.so *.dylib pkgIndex.tcl
-       rm -f sqlite3_analyzer$(TEXE) sqlite3_rsync$(TEXE) sqlite3_expert$(TEXE)
-       rm -f mptester$(TEXE) rbu$(TEXE)        srcck1$(TEXE)
-       rm -f fuzzershell$(TEXE) fuzzcheck$(TEXE) sqldiff$(TEXE) dbhash$(TEXE)
-       rm -f dbfuzz$(TEXE) dbfuzz2$(TEXE) dbfuzz2-asan$(TEXE) dbfuzz2-msan$(TEXE)
-       rm -f fuzzcheck-asan$(TEXE) fuzzcheck-ubsan$(TEXE) ossshell$(TEXE)
-       rm -f sessionfuzz$(TEXE)
-       rm -f threadtest5$(TEXE)
-       rm -f src-verify$(BEXE) has_tclsh* has_tclconfig
-       rm -f tclsqlite3.c
-       rm -f sqlite3rc.h sqlite3.def
-
-#
-# Removes build products and test logs.  Retains ./configure outputs.
-#
-clean: tidy
-       rm -rf omittest* testrunner* testdir*
-       -gmake -C ext/wasm distclean 2>/dev/null; true
-
-# Clean up everything.  No exceptions.
-distclean:     clean
-       rm -f sqlite_cfg.h config.log config.status $(JIMSH) Makefile
-       rm -f $(TOP)/tool/emcc.sh
-       -gmake -C ext/wasm distclean 2>/dev/null; true
+include $(TOP)/main.mk
diff --git a/main.mk b/main.mk
index fa9f7cce1ad69491acea3ec125f73aaa7bf6b94a..848b859a220f81c5a4bfa40ab0060ff46cfed9eb 100644 (file)
--- a/main.mk
+++ b/main.mk
 # Once the variables above are defined, the rest of this make script
 # will build the SQLite library and testing tools.
 ################################################################################
+
+#
+# Ideally these all come from the calling makefile, but we can provide some
+# sane defaults for many of them...
+#
+prefix ?= /usr/local
+exec_prefix ?= $(prefix)
+libdir ?= $(prefix)/lib
+pkgconfigdir ?= $(libdir)/pkgconfig
+bindir ?= $(prefix)/bin
+includedir ?= $(prefix)/include
+USE_AMALGAMATION ?= 2
+AMALGAMATION_LINE_MACROS ?= --linemacros=0
+INSTALL ?= install
+
+LDFLAGS_ZLIB ?= -lz
+LDFLAGS_MATH ?= -lm
+LDFLAGS_RPATH ?= -Wl,-rpath -Wl,$(prefix)/lib
+LDFLAGS_READLINE ?= -lreadline
+LDFLAGS_PTHREAD ?= -lpthread
+LDFLAGS_SHOBJ ?= -shared
+ENABLE_SHARED ?= 1
+HAVE_WASI_SDK ?= 0
+
+INSTALL_noexec = $(INSTALL) -m 0644
+# ^^^ do not use GNU-specific flags to $(INSTALL), e.g. --mode=...
+
+# TCOMPILE = generic target platform compiler invocation
+TCOMPILE = $(TCC) $(TCOMPILE_EXTRAS)
+# TLINK = compiler invocation for when the target will be an executable
+TLINK = $(TCC) $(TLINK_EXTRAS)
+# TLINK_shared = $(TLINK) invocation specifically for shared libraries
+LDFLAGS_SHOBJ ?= -shared
+TLINK_shared = $(TLINK) $(LDFLAGS_SHOBJ)
+
+# TCCX is $(TCC) plus any CFLAGS which are common to most compilations
+# for the target platform. In auto-configured builds it is typically
+# defined by the main makefile to include configure-time-dependent
+# options.
+TCCX ?= $(TCC)
+TCCX += -I. -I$(TOP)/src -I$(TOP)/ext/rtree -I$(TOP)/ext/icu
+TCCX += -I$(TOP)/ext/fts3 -I$(TOP)/ext/async -I$(TOP)/ext/session
+TCCX += -I$(TOP)/ext/userauth
+
+TEMP_STORE ?= -DSQLITE_TEMP_STORE=1
+
+#
+# LDFLAGS_libsqlite3 should be used with any target which either
+# results in building libsqlite3.so, compiles sqlite3.c directly, or
+# links in either of $(LIBOBJSO) or $(LIBOBJS1).  Note that these
+# flags are for the target build platform, not necessarily localhost.
+# i.e. it should be used with $(TCCX) or $(TLINK) but not $(BCC).
+#
+LDFLAGS_libsqlite3 = \
+  $(LDFLAGS_RPATH) $(TLIBS) $(LDFLAGS_PTHREAD) \
+  $(LDFLAGS_MATH) $(LDFLAGS_ZLIB)
+
+#
+# install.XYZ = dirs for installation. They're in quotes to
+# accommodate installations where paths have spaces in them.
+#
+install.bindir = "$(DESTDIR)$(bindir)"
+install.libdir = "$(DESTDIR)$(libdir)"
+install.includedir = "$(DESTDIR)$(prefix)/include"
+install.pkgconfigdir = "$(DESTDIR)$(pkgconfigdir)"
+$(install.bindir) $(install.libdir) $(install.includedir) $(install.pkgconfigdir):
+       $(INSTALL) -d $@
+
+
+#
+# Object files for the SQLite library (non-amalgamation).
+#
+LIBOBJS0 = alter.o analyze.o attach.o auth.o \
+         backup.o bitvec.o btmutex.o btree.o build.o \
+         callback.o complete.o ctime.o \
+         date.o dbpage.o dbstat.o delete.o \
+         expr.o fault.o fkey.o \
+         fts3.o fts3_aux.o fts3_expr.o fts3_hash.o fts3_icu.o \
+         fts3_porter.o fts3_snippet.o fts3_tokenizer.o fts3_tokenizer1.o \
+         fts3_tokenize_vtab.o \
+         fts3_unicode.o fts3_unicode2.o fts3_write.o \
+         fts5.o \
+         func.o global.o hash.o \
+         icu.o insert.o json.o legacy.o loadext.o \
+         main.o malloc.o mem0.o mem1.o mem2.o mem3.o mem5.o \
+         memdb.o memjournal.o \
+         mutex.o mutex_noop.o mutex_unix.o mutex_w32.o \
+         notify.o opcodes.o os.o os_kv.o os_unix.o os_win.o \
+         pager.o parse.o pcache.o pcache1.o pragma.o prepare.o printf.o \
+         random.o resolve.o rowset.o rtree.o \
+         sqlite3session.o select.o sqlite3rbu.o status.o stmt.o \
+         table.o threads.o tokenize.o treeview.o trigger.o \
+         update.o upsert.o userauth.o utf.o util.o vacuum.o \
+         vdbe.o vdbeapi.o vdbeaux.o vdbeblob.o vdbemem.o vdbesort.o \
+         vdbetrace.o vdbevtab.o vtab.o \
+         wal.o walker.o where.o wherecode.o whereexpr.o \
+         window.o
+LIBOBJS = $(LIBOBJS0)
+
+# Object files for the amalgamation.
+#
+LIBOBJS1 = sqlite3.o
+
+# Determine the real value of LIBOBJ based on the 'configure' script
+#
+LIBOBJ = $(LIBOBJS$(USE_AMALGAMATION))
+
+# All of the source code files.
+#
+SRC = \
+  $(TOP)/src/alter.c \
+  $(TOP)/src/analyze.c \
+  $(TOP)/src/attach.c \
+  $(TOP)/src/auth.c \
+  $(TOP)/src/backup.c \
+  $(TOP)/src/bitvec.c \
+  $(TOP)/src/btmutex.c \
+  $(TOP)/src/btree.c \
+  $(TOP)/src/btree.h \
+  $(TOP)/src/btreeInt.h \
+  $(TOP)/src/build.c \
+  $(TOP)/src/callback.c \
+  $(TOP)/src/complete.c \
+  $(TOP)/src/ctime.c \
+  $(TOP)/src/date.c \
+  $(TOP)/src/dbpage.c \
+  $(TOP)/src/dbstat.c \
+  $(TOP)/src/delete.c \
+  $(TOP)/src/expr.c \
+  $(TOP)/src/fault.c \
+  $(TOP)/src/fkey.c \
+  $(TOP)/src/func.c \
+  $(TOP)/src/global.c \
+  $(TOP)/src/hash.c \
+  $(TOP)/src/hash.h \
+  $(TOP)/src/hwtime.h \
+  $(TOP)/src/insert.c \
+  $(TOP)/src/json.c \
+  $(TOP)/src/legacy.c \
+  $(TOP)/src/loadext.c \
+  $(TOP)/src/main.c \
+  $(TOP)/src/malloc.c \
+  $(TOP)/src/mem0.c \
+  $(TOP)/src/mem1.c \
+  $(TOP)/src/mem2.c \
+  $(TOP)/src/mem3.c \
+  $(TOP)/src/mem5.c \
+  $(TOP)/src/memdb.c \
+  $(TOP)/src/memjournal.c \
+  $(TOP)/src/msvc.h \
+  $(TOP)/src/mutex.c \
+  $(TOP)/src/mutex.h \
+  $(TOP)/src/mutex_noop.c \
+  $(TOP)/src/mutex_unix.c \
+  $(TOP)/src/mutex_w32.c \
+  $(TOP)/src/notify.c \
+  $(TOP)/src/os.c \
+  $(TOP)/src/os.h \
+  $(TOP)/src/os_common.h \
+  $(TOP)/src/os_setup.h \
+  $(TOP)/src/os_kv.c \
+  $(TOP)/src/os_unix.c \
+  $(TOP)/src/os_win.c \
+  $(TOP)/src/os_win.h \
+  $(TOP)/src/pager.c \
+  $(TOP)/src/pager.h \
+  $(TOP)/src/parse.y \
+  $(TOP)/src/pcache.c \
+  $(TOP)/src/pcache.h \
+  $(TOP)/src/pcache1.c \
+  $(TOP)/src/pragma.c \
+  $(TOP)/src/pragma.h \
+  $(TOP)/src/prepare.c \
+  $(TOP)/src/printf.c \
+  $(TOP)/src/random.c \
+  $(TOP)/src/resolve.c \
+  $(TOP)/src/rowset.c \
+  $(TOP)/src/select.c \
+  $(TOP)/src/status.c \
+  $(TOP)/src/shell.c.in \
+  $(TOP)/src/sqlite.h.in \
+  $(TOP)/src/sqlite3ext.h \
+  $(TOP)/src/sqliteInt.h \
+  $(TOP)/src/sqliteLimit.h \
+  $(TOP)/src/table.c \
+  $(TOP)/src/tclsqlite.c \
+  $(TOP)/src/threads.c \
+  $(TOP)/src/tokenize.c \
+  $(TOP)/src/treeview.c \
+  $(TOP)/src/trigger.c \
+  $(TOP)/src/utf.c \
+  $(TOP)/src/update.c \
+  $(TOP)/src/upsert.c \
+  $(TOP)/src/util.c \
+  $(TOP)/src/vacuum.c \
+  $(TOP)/src/vdbe.c \
+  $(TOP)/src/vdbe.h \
+  $(TOP)/src/vdbeapi.c \
+  $(TOP)/src/vdbeaux.c \
+  $(TOP)/src/vdbeblob.c \
+  $(TOP)/src/vdbemem.c \
+  $(TOP)/src/vdbesort.c \
+  $(TOP)/src/vdbetrace.c \
+  $(TOP)/src/vdbevtab.c \
+  $(TOP)/src/vdbeInt.h \
+  $(TOP)/src/vtab.c \
+  $(TOP)/src/vxworks.h \
+  $(TOP)/src/wal.c \
+  $(TOP)/src/wal.h \
+  $(TOP)/src/walker.c \
+  $(TOP)/src/where.c \
+  $(TOP)/src/wherecode.c \
+  $(TOP)/src/whereexpr.c \
+  $(TOP)/src/whereInt.h \
+  $(TOP)/src/window.c
+
+# Source code for extensions
+#
+SRC += \
+  $(TOP)/ext/fts3/fts3.c \
+  $(TOP)/ext/fts3/fts3.h \
+  $(TOP)/ext/fts3/fts3Int.h \
+  $(TOP)/ext/fts3/fts3_aux.c \
+  $(TOP)/ext/fts3/fts3_expr.c \
+  $(TOP)/ext/fts3/fts3_hash.c \
+  $(TOP)/ext/fts3/fts3_hash.h \
+  $(TOP)/ext/fts3/fts3_icu.c \
+  $(TOP)/ext/fts3/fts3_porter.c \
+  $(TOP)/ext/fts3/fts3_snippet.c \
+  $(TOP)/ext/fts3/fts3_tokenizer.h \
+  $(TOP)/ext/fts3/fts3_tokenizer.c \
+  $(TOP)/ext/fts3/fts3_tokenizer1.c \
+  $(TOP)/ext/fts3/fts3_tokenize_vtab.c \
+  $(TOP)/ext/fts3/fts3_unicode.c \
+  $(TOP)/ext/fts3/fts3_unicode2.c \
+  $(TOP)/ext/fts3/fts3_write.c
+SRC += \
+  $(TOP)/ext/icu/sqliteicu.h \
+  $(TOP)/ext/icu/icu.c
+SRC += \
+  $(TOP)/ext/rtree/rtree.h \
+  $(TOP)/ext/rtree/rtree.c \
+  $(TOP)/ext/rtree/geopoly.c
+SRC += \
+  $(TOP)/ext/session/sqlite3session.c \
+  $(TOP)/ext/session/sqlite3session.h
+SRC += \
+  $(TOP)/ext/userauth/userauth.c \
+  $(TOP)/ext/userauth/sqlite3userauth.h
+SRC += \
+  $(TOP)/ext/rbu/sqlite3rbu.h \
+  $(TOP)/ext/rbu/sqlite3rbu.c
+SRC += \
+  $(TOP)/ext/misc/stmt.c
+
+# Generated source code files
+#
+SRC += \
+  keywordhash.h \
+  opcodes.c \
+  opcodes.h \
+  parse.c \
+  parse.h \
+  sqlite_cfg.h \
+  shell.c \
+  sqlite3.h
+
+# Source code to the test files.
+#
+TESTSRC = \
+  $(TOP)/src/test1.c \
+  $(TOP)/src/test2.c \
+  $(TOP)/src/test3.c \
+  $(TOP)/src/test4.c \
+  $(TOP)/src/test5.c \
+  $(TOP)/src/test6.c \
+  $(TOP)/src/test8.c \
+  $(TOP)/src/test9.c \
+  $(TOP)/src/test_autoext.c \
+  $(TOP)/src/test_async.c \
+  $(TOP)/src/test_backup.c \
+  $(TOP)/src/test_bestindex.c \
+  $(TOP)/src/test_blob.c \
+  $(TOP)/src/test_btree.c \
+  $(TOP)/src/test_config.c \
+  $(TOP)/src/test_delete.c \
+  $(TOP)/src/test_demovfs.c \
+  $(TOP)/src/test_devsym.c \
+  $(TOP)/src/test_fs.c \
+  $(TOP)/src/test_func.c \
+  $(TOP)/src/test_hexio.c \
+  $(TOP)/src/test_init.c \
+  $(TOP)/src/test_intarray.c \
+  $(TOP)/src/test_journal.c \
+  $(TOP)/src/test_malloc.c \
+  $(TOP)/src/test_md5.c \
+  $(TOP)/src/test_multiplex.c \
+  $(TOP)/src/test_mutex.c \
+  $(TOP)/src/test_onefile.c \
+  $(TOP)/src/test_osinst.c \
+  $(TOP)/src/test_pcache.c \
+  $(TOP)/src/test_quota.c \
+  $(TOP)/src/test_rtree.c \
+  $(TOP)/src/test_schema.c \
+  $(TOP)/src/test_superlock.c \
+  $(TOP)/src/test_syscall.c \
+  $(TOP)/src/test_tclsh.c \
+  $(TOP)/src/test_tclvar.c \
+  $(TOP)/src/test_thread.c \
+  $(TOP)/src/test_vdbecov.c \
+  $(TOP)/src/test_vfs.c \
+  $(TOP)/src/test_windirent.c \
+  $(TOP)/src/test_window.c \
+  $(TOP)/src/test_wsd.c       \
+  $(TOP)/ext/fts3/fts3_term.c \
+  $(TOP)/ext/fts3/fts3_test.c  \
+  $(TOP)/ext/session/test_session.c \
+  $(TOP)/ext/recover/sqlite3recover.c \
+  $(TOP)/ext/recover/dbdata.c \
+  $(TOP)/ext/recover/test_recover.c \
+  $(TOP)/ext/intck/test_intck.c  \
+  $(TOP)/ext/intck/sqlite3intck.c \
+  $(TOP)/ext/rbu/test_rbu.c
+
+# Statically linked extensions
+#
+TESTSRC += \
+  $(TOP)/ext/expert/sqlite3expert.c \
+  $(TOP)/ext/expert/test_expert.c \
+  $(TOP)/ext/misc/amatch.c \
+  $(TOP)/ext/misc/appendvfs.c \
+  $(TOP)/ext/misc/basexx.c \
+  $(TOP)/ext/misc/carray.c \
+  $(TOP)/ext/misc/cksumvfs.c \
+  $(TOP)/ext/misc/closure.c \
+  $(TOP)/ext/misc/csv.c \
+  $(TOP)/ext/misc/decimal.c \
+  $(TOP)/ext/misc/eval.c \
+  $(TOP)/ext/misc/explain.c \
+  $(TOP)/ext/misc/fileio.c \
+  $(TOP)/ext/misc/fuzzer.c \
+  $(TOP)/ext/fts5/fts5_tcl.c \
+  $(TOP)/ext/fts5/fts5_test_mi.c \
+  $(TOP)/ext/fts5/fts5_test_tok.c \
+  $(TOP)/ext/misc/ieee754.c \
+  $(TOP)/ext/misc/mmapwarm.c \
+  $(TOP)/ext/misc/nextchar.c \
+  $(TOP)/ext/misc/normalize.c \
+  $(TOP)/ext/misc/percentile.c \
+  $(TOP)/ext/misc/prefixes.c \
+  $(TOP)/ext/misc/qpvtab.c \
+  $(TOP)/ext/misc/randomjson.c \
+  $(TOP)/ext/misc/regexp.c \
+  $(TOP)/ext/misc/remember.c \
+  $(TOP)/ext/misc/series.c \
+  $(TOP)/ext/misc/spellfix.c \
+  $(TOP)/ext/misc/stmtrand.c \
+  $(TOP)/ext/misc/totype.c \
+  $(TOP)/ext/misc/unionvtab.c \
+  $(TOP)/ext/misc/wholenumber.c \
+  $(TOP)/ext/misc/zipfile.c \
+  $(TOP)/ext/userauth/userauth.c \
+  $(TOP)/ext/rtree/test_rtreedoc.c
+
+# Source code to the library files needed by the test fixture
+#
+TESTSRC2 = \
+  $(TOP)/src/attach.c \
+  $(TOP)/src/backup.c \
+  $(TOP)/src/bitvec.c \
+  $(TOP)/src/btree.c \
+  $(TOP)/src/build.c \
+  $(TOP)/src/ctime.c \
+  $(TOP)/src/date.c \
+  $(TOP)/src/dbpage.c \
+  $(TOP)/src/dbstat.c \
+  $(TOP)/src/expr.c \
+  $(TOP)/src/func.c \
+  $(TOP)/src/global.c \
+  $(TOP)/src/insert.c \
+  $(TOP)/src/wal.c \
+  $(TOP)/src/main.c \
+  $(TOP)/src/mem5.c \
+  $(TOP)/src/os.c \
+  $(TOP)/src/os_kv.c \
+  $(TOP)/src/os_unix.c \
+  $(TOP)/src/os_win.c \
+  $(TOP)/src/pager.c \
+  $(TOP)/src/pragma.c \
+  $(TOP)/src/prepare.c \
+  $(TOP)/src/printf.c \
+  $(TOP)/src/random.c \
+  $(TOP)/src/pcache.c \
+  $(TOP)/src/pcache1.c \
+  $(TOP)/src/select.c \
+  $(TOP)/src/tokenize.c \
+  $(TOP)/src/treeview.c \
+  $(TOP)/src/utf.c \
+  $(TOP)/src/util.c \
+  $(TOP)/src/vdbeapi.c \
+  $(TOP)/src/vdbeaux.c \
+  $(TOP)/src/vdbe.c \
+  $(TOP)/src/vdbemem.c \
+  $(TOP)/src/vdbetrace.c \
+  $(TOP)/src/vdbevtab.c \
+  $(TOP)/src/where.c \
+  $(TOP)/src/wherecode.c \
+  $(TOP)/src/whereexpr.c \
+  $(TOP)/src/window.c \
+  parse.c \
+  $(TOP)/ext/fts3/fts3.c \
+  $(TOP)/ext/fts3/fts3_aux.c \
+  $(TOP)/ext/fts3/fts3_expr.c \
+  $(TOP)/ext/fts3/fts3_term.c \
+  $(TOP)/ext/fts3/fts3_tokenizer.c \
+  $(TOP)/ext/fts3/fts3_write.c \
+  $(TOP)/ext/async/sqlite3async.c \
+  $(TOP)/ext/session/sqlite3session.c \
+  $(TOP)/ext/misc/stmt.c \
+  fts5.c
+
+# Header files used by all library source files.
+#
+HDR = \
+   $(TOP)/src/btree.h \
+   $(TOP)/src/btreeInt.h \
+   $(TOP)/src/hash.h \
+   $(TOP)/src/hwtime.h \
+   keywordhash.h \
+   $(TOP)/src/msvc.h \
+   $(TOP)/src/mutex.h \
+   opcodes.h \
+   $(TOP)/src/os.h \
+   $(TOP)/src/os_common.h \
+   $(TOP)/src/os_setup.h \
+   $(TOP)/src/os_win.h \
+   $(TOP)/src/pager.h \
+   $(TOP)/src/pcache.h \
+   parse.h  \
+   $(TOP)/src/pragma.h \
+   sqlite3.h  \
+   $(TOP)/src/sqlite3ext.h \
+   $(TOP)/src/sqliteInt.h  \
+   $(TOP)/src/sqliteLimit.h \
+   $(TOP)/src/vdbe.h \
+   $(TOP)/src/vdbeInt.h \
+   $(TOP)/src/vxworks.h \
+   $(TOP)/src/whereInt.h \
+   sqlite_cfg.h
+
+# Header files used by extensions
+#
+EXTHDR += \
+  $(TOP)/ext/fts3/fts3.h \
+  $(TOP)/ext/fts3/fts3Int.h \
+  $(TOP)/ext/fts3/fts3_hash.h \
+  $(TOP)/ext/fts3/fts3_tokenizer.h
+EXTHDR += \
+  $(TOP)/ext/rtree/rtree.h \
+  $(TOP)/ext/rtree/geopoly.c
+EXTHDR += \
+  $(TOP)/ext/icu/sqliteicu.h
+EXTHDR += \
+  $(TOP)/ext/rtree/sqlite3rtree.h
+EXTHDR += \
+  $(TOP)/ext/userauth/sqlite3userauth.h
+
+# executables needed for testing
+#
+TESTPROGS = \
+  testfixture$(TEXE) \
+  sqlite3$(TEXE) \
+  sqlite3_analyzer$(TEXE) \
+  sqldiff$(TEXE) \
+  dbhash$(TEXE) \
+  sqltclsh$(TEXE)
+
+# Databases containing fuzzer test cases
+#
+FUZZDATA = \
+  $(TOP)/test/fuzzdata1.db \
+  $(TOP)/test/fuzzdata2.db \
+  $(TOP)/test/fuzzdata3.db \
+  $(TOP)/test/fuzzdata4.db \
+  $(TOP)/test/fuzzdata5.db \
+  $(TOP)/test/fuzzdata6.db \
+  $(TOP)/test/fuzzdata7.db \
+  $(TOP)/test/fuzzdata8.db
+
+# Standard options to testfixture
+#
+TESTOPTS = --verbose=file --output=test-out.txt
+
+# Extra compiler options for various shell tools
+#
+SHELL_OPT += -DSQLITE_DQS=0
+SHELL_OPT += -DSQLITE_ENABLE_FTS4
+#SHELL_OPT += -DSQLITE_ENABLE_FTS5
+SHELL_OPT += -DSQLITE_ENABLE_RTREE
+SHELL_OPT += -DSQLITE_ENABLE_EXPLAIN_COMMENTS
+SHELL_OPT += -DSQLITE_ENABLE_UNKNOWN_SQL_FUNCTION
+SHELL_OPT += -DSQLITE_ENABLE_STMTVTAB
+SHELL_OPT += -DSQLITE_ENABLE_DBPAGE_VTAB
+SHELL_OPT += -DSQLITE_ENABLE_DBSTAT_VTAB
+SHELL_OPT += -DSQLITE_ENABLE_BYTECODE_VTAB
+SHELL_OPT += -DSQLITE_ENABLE_OFFSET_SQL_FUNC
+SHELL_OPT += -DSQLITE_STRICT_SUBTYPE=1
+FUZZERSHELL_OPT =
+FUZZCHECK_OPT += -I$(TOP)/test
+FUZZCHECK_OPT += -I$(TOP)/ext/recover
+FUZZCHECK_OPT += \
+  -DSQLITE_OSS_FUZZ \
+  -DSQLITE_ENABLE_BYTECODE_VTAB \
+  -DSQLITE_ENABLE_DBPAGE_VTAB \
+  -DSQLITE_ENABLE_DBSTAT_VTAB \
+  -DSQLITE_ENABLE_BYTECODE_VTAB \
+  -DSQLITE_ENABLE_DESERIALIZE \
+  -DSQLITE_ENABLE_EXPLAIN_COMMENTS \
+  -DSQLITE_ENABLE_FTS3_PARENTHESIS \
+  -DSQLITE_ENABLE_FTS4 \
+  -DSQLITE_ENABLE_FTS5 \
+  -DSQLITE_ENABLE_GEOPOLY \
+  -DSQLITE_ENABLE_MATH_FUNCTIONS \
+  -DSQLITE_ENABLE_MEMSYS5 \
+  -DSQLITE_ENABLE_NORMALIZE \
+  -DSQLITE_ENABLE_OFFSET_SQL_FUNC \
+  -DSQLITE_ENABLE_PREUPDATE_HOOK \
+  -DSQLITE_ENABLE_RTREE \
+  -DSQLITE_ENABLE_SESSION \
+  -DSQLITE_ENABLE_STMTVTAB \
+  -DSQLITE_ENABLE_UNKNOWN_SQL_FUNCTION \
+  -DSQLITE_ENABLE_STAT4 \
+  -DSQLITE_ENABLE_STMT_SCANSTATUS \
+  -DSQLITE_MAX_MEMORY=50000000 \
+  -DSQLITE_MAX_MMAP_SIZE=0 \
+  -DSQLITE_OMIT_LOAD_EXTENSION \
+  -DSQLITE_PRINTF_PRECISION_LIMIT=1000 \
+  -DSQLITE_PRIVATE="" \
+  -DSQLITE_STRICT_SUBTYPE=1 \
+  -DSQLITE_STATIC_RANDOMJSON
+
+FUZZCHECK_SRC += $(TOP)/test/fuzzcheck.c
+FUZZCHECK_SRC += $(TOP)/test/ossfuzz.c
+FUZZCHECK_SRC += $(TOP)/test/fuzzinvariants.c
+FUZZCHECK_SRC += $(TOP)/ext/recover/dbdata.c
+FUZZCHECK_SRC += $(TOP)/ext/recover/sqlite3recover.c
+FUZZCHECK_SRC += $(TOP)/test/vt02.c
+FUZZCHECK_SRC += $(TOP)/ext/misc/percentile.c
+FUZZCHECK_SRC += $(TOP)/ext/misc/randomjson.c
+DBFUZZ_OPT =
+ST_OPT = -DSQLITE_OS_KV_OPTIONAL
+
+
+has_tclsh84:
+       sh $(TOP)/tool/cktclsh.sh 8.4 $(TCLSH_CMD)
+       touch has_tclsh84
+
+has_tclsh85:
+       sh $(TOP)/tool/cktclsh.sh 8.5 $(TCLSH_CMD)
+       touch has_tclsh85
+
+has_tclconfig:
+       @if [ x = "x$(TCL_CONFIG_SH)" ]; then \
+               echo 'TCL_CONFIG_SH must be set to point to a "tclConfig.sh"' 1>&2; exit 1; \
+       fi
+       touch has_tclconfig
+
+#
+# This target creates a directory named "tsrc" and fills it with
+# copies of all of the C source code and header files needed to
+# build on the target system.  Some of the C source code and header
+# files are automatically generated.  This target takes care of
+# all that automatic generation.
+#
+.target_source:        $(SRC) $(TOP)/tool/vdbe-compress.tcl fts5.c $(BTCLSH) # has_tclsh84
+       rm -rf tsrc
+       mkdir tsrc
+       cp -f $(SRC) tsrc
+       rm tsrc/sqlite.h.in tsrc/parse.y
+       $(BTCLSH) $(TOP)/tool/vdbe-compress.tcl $(OPTS) <tsrc/vdbe.c >vdbe.new
+       mv vdbe.new tsrc/vdbe.c
+       cp fts5.c fts5.h tsrc
+       touch .target_source
+
+libsqlite3.LIB = libsqlite3$(TLIB)
+libsqlite3.SO = libsqlite3$(TDLL)
+
+# Rules to build the LEMON compiler generator
+#
+lemon$(BEXE):  $(TOP)/tool/lemon.c $(TOP)/tool/lempar.c
+       $(BCC) -o $@ $(TOP)/tool/lemon.c
+       cp $(TOP)/tool/lempar.c .
+
+# Rules to build the program that generates the source-id
+#
+mksourceid$(BEXE):     $(TOP)/tool/mksourceid.c
+       $(BCC) -o $@ $(TOP)/tool/mksourceid.c
+
+sqlite3.h:     $(TOP)/src/sqlite.h.in $(TOP)/manifest mksourceid$(BEXE) \
+               $(TOP)/VERSION $(BTCLSH) # has_tclsh84
+       $(BTCLSH) $(TOP)/tool/mksqlite3h.tcl $(TOP) >sqlite3.h
+
+sqlite3.c:     .target_source sqlite3.h $(TOP)/tool/mksqlite3c.tcl src-verify \
+               $(BTCLSH) # has_tclsh84
+       $(BTCLSH) $(TOP)/tool/mksqlite3c.tcl $(AMALGAMATION_LINE_MACROS) $(EXTRA_SRC)
+       cp tsrc/sqlite3ext.h .
+       cp $(TOP)/ext/session/sqlite3session.h .
+
+sqlite3r.h: sqlite3.h $(BTCLSH) # has_tclsh84
+       $(BTCLSH) $(TOP)/tool/mksqlite3h.tcl $(TOP) --enable-recover >sqlite3r.h
+
+sqlite3r.c: sqlite3.c sqlite3r.h $(BTCLSH) # has_tclsh84
+       cp $(TOP)/ext/recover/sqlite3recover.c tsrc/
+       cp $(TOP)/ext/recover/sqlite3recover.h tsrc/
+       cp $(TOP)/ext/recover/dbdata.c tsrc/
+       $(BTCLSH) $(TOP)/tool/mksqlite3c.tcl --enable-recover $(AMALGAMATION_LINE_MACROS) $(EXTRA_SRC)
+
+sqlite3ext.h:  .target_source
+       cp tsrc/sqlite3ext.h .
+
+# Rules to build individual *.o files from generated *.c files. This
+# applies to:
+#
+#     parse.o
+#     opcodes.o
+#
+parse.o:       parse.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c parse.c
+
+opcodes.o:     opcodes.c
+       $(TCOMPILE) $(TEMP_STORE) -c opcodes.c
+
+# Rules to build individual *.o files from files in the src directory.
+#
+alter.o:       $(TOP)/src/alter.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/alter.c
+
+analyze.o:     $(TOP)/src/analyze.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/analyze.c
+
+attach.o:      $(TOP)/src/attach.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/attach.c
+
+auth.o:        $(TOP)/src/auth.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/auth.c
+
+backup.o:      $(TOP)/src/backup.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/backup.c
+
+bitvec.o:      $(TOP)/src/bitvec.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/bitvec.c
+
+btmutex.o:     $(TOP)/src/btmutex.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/btmutex.c
+
+btree.o:       $(TOP)/src/btree.c $(HDR) $(TOP)/src/pager.h
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/btree.c
+
+build.o:       $(TOP)/src/build.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/build.c
+
+callback.o:    $(TOP)/src/callback.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/callback.c
+
+complete.o:    $(TOP)/src/complete.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/complete.c
+
+ctime.o:       $(TOP)/src/ctime.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/ctime.c
+
+date.o:        $(TOP)/src/date.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/date.c
+
+dbpage.o:      $(TOP)/src/dbpage.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/dbpage.c
+
+dbstat.o:      $(TOP)/src/dbstat.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/dbstat.c
+
+delete.o:      $(TOP)/src/delete.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/delete.c
+
+expr.o:        $(TOP)/src/expr.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/expr.c
+
+fault.o:       $(TOP)/src/fault.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/fault.c
+
+fkey.o:        $(TOP)/src/fkey.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/fkey.c
+
+func.o:        $(TOP)/src/func.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/func.c
+
+global.o:      $(TOP)/src/global.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/global.c
+
+hash.o:        $(TOP)/src/hash.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/hash.c
+
+insert.o:      $(TOP)/src/insert.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/insert.c
+
+json.o:        $(TOP)/src/json.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/json.c
+
+legacy.o:      $(TOP)/src/legacy.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/legacy.c
+
+loadext.o:     $(TOP)/src/loadext.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/loadext.c
+
+main.o:        $(TOP)/src/main.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/main.c
+
+malloc.o:      $(TOP)/src/malloc.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/malloc.c
+
+mem0.o:        $(TOP)/src/mem0.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem0.c
+
+mem1.o:        $(TOP)/src/mem1.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem1.c
+
+mem2.o:        $(TOP)/src/mem2.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem2.c
+
+mem3.o:        $(TOP)/src/mem3.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem3.c
+
+mem5.o:        $(TOP)/src/mem5.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mem5.c
+
+memdb.o:       $(TOP)/src/memdb.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/memdb.c
+
+memjournal.o:  $(TOP)/src/memjournal.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/memjournal.c
+
+mutex.o:       $(TOP)/src/mutex.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex.c
+
+mutex_noop.o:  $(TOP)/src/mutex_noop.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex_noop.c
+
+mutex_unix.o:  $(TOP)/src/mutex_unix.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex_unix.c
+
+mutex_w32.o:   $(TOP)/src/mutex_w32.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/mutex_w32.c
+
+notify.o:      $(TOP)/src/notify.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/notify.c
+
+pager.o:       $(TOP)/src/pager.c $(HDR) $(TOP)/src/pager.h
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pager.c
+
+pcache.o:      $(TOP)/src/pcache.c $(HDR) $(TOP)/src/pcache.h
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pcache.c
+
+pcache1.o:     $(TOP)/src/pcache1.c $(HDR) $(TOP)/src/pcache.h
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pcache1.c
+
+os.o:  $(TOP)/src/os.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os.c
+
+os_kv.o:       $(TOP)/src/os_kv.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os_kv.c
+
+os_unix.o:     $(TOP)/src/os_unix.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os_unix.c
+
+os_win.o:      $(TOP)/src/os_win.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/os_win.c
+
+pragma.o:      $(TOP)/src/pragma.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/pragma.c
+
+prepare.o:     $(TOP)/src/prepare.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/prepare.c
+
+printf.o:      $(TOP)/src/printf.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/printf.c
+
+random.o:      $(TOP)/src/random.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/random.c
+
+resolve.o:     $(TOP)/src/resolve.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/resolve.c
+
+rowset.o:      $(TOP)/src/rowset.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/rowset.c
+
+select.o:      $(TOP)/src/select.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/select.c
+
+status.o:      $(TOP)/src/status.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/status.c
+
+sqlite3.o:     sqlite3.h sqlite3.c
+       $(TCOMPILE) $(TEMP_STORE) -c sqlite3.c
+
+table.o:       $(TOP)/src/table.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/table.c
+
+threads.o:     $(TOP)/src/threads.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/threads.c
+
+tokenize.o:    $(TOP)/src/tokenize.c keywordhash.h $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/tokenize.c
+
+treeview.o:    $(TOP)/src/treeview.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/treeview.c
+
+trigger.o:     $(TOP)/src/trigger.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/trigger.c
+
+update.o:      $(TOP)/src/update.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/update.c
+
+upsert.o:      $(TOP)/src/upsert.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/upsert.c
+
+utf.o: $(TOP)/src/utf.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/utf.c
+
+util.o:        $(TOP)/src/util.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/util.c
+
+vacuum.o:      $(TOP)/src/vacuum.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vacuum.c
+
+vdbe.o:        $(TOP)/src/vdbe.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbe.c
+
+vdbeapi.o:     $(TOP)/src/vdbeapi.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbeapi.c
+
+vdbeaux.o:     $(TOP)/src/vdbeaux.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbeaux.c
+
+vdbeblob.o:    $(TOP)/src/vdbeblob.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbeblob.c
+
+vdbemem.o:     $(TOP)/src/vdbemem.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbemem.c
+
+vdbesort.o:    $(TOP)/src/vdbesort.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbesort.c
+
+vdbetrace.o:   $(TOP)/src/vdbetrace.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbetrace.c
+
+vdbevtab.o:    $(TOP)/src/vdbevtab.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vdbevtab.c
+
+vtab.o:        $(TOP)/src/vtab.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/vtab.c
+
+wal.o: $(TOP)/src/wal.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/wal.c
+
+walker.o:      $(TOP)/src/walker.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/walker.c
+
+where.o:       $(TOP)/src/where.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/where.c
+
+wherecode.o:   $(TOP)/src/wherecode.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/wherecode.c
+
+whereexpr.o:   $(TOP)/src/whereexpr.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/whereexpr.c
+
+window.o:      $(TOP)/src/window.c $(HDR)
+       $(TCOMPILE) $(TEMP_STORE) -c $(TOP)/src/window.c
+
+tclsqlite.o:   $(TOP)/src/tclsqlite.c $(HDR)
+       $(TCOMPILE) -DUSE_TCL_STUBS=1 $(TCL_INCLUDE_SPEC) \
+               -c $(TOP)/src/tclsqlite.c
+
+tclsqlite-shell.o:     $(TOP)/src/tclsqlite.c $(HDR)
+       $(TCOMPILE) -DTCLSH -o $@ -c $(TOP)/src/tclsqlite.c $(TCL_INCLUDE_SPEC)
+
+tclsqlite-stubs.o:     $(TOP)/src/tclsqlite.c $(HDR)
+       $(TCOMPILE) -DUSE_TCL_STUBS=1 -o $@ -c $(TOP)/src/tclsqlite.c $(TCL_INCLUDE_SPEC)
+
+tclsqlite3$(TEXE):     has_tclconfig tclsqlite-shell.o $(libsqlite3.LIB)
+       $(TLINK) -o $@ tclsqlite-shell.o \
+                $(libsqlite3.LIB) $(TCL_INCLUDE_SPEC) $(TCL_LIB_SPEC) $(LDFLAGS_libsqlite3)
+
+# Rules to build opcodes.c and opcodes.h
+#
+opcodes.c:     opcodes.h $(TOP)/tool/mkopcodec.tcl $(BTCLSH) # has_tclsh84
+       $(BTCLSH) $(TOP)/tool/mkopcodec.tcl opcodes.h >opcodes.c
+
+opcodes.h:     parse.h $(TOP)/src/vdbe.c \
+               $(TOP)/tool/mkopcodeh.tcl $(BTCLSH) # has_tclsh84
+       cat parse.h $(TOP)/src/vdbe.c | $(BTCLSH) $(TOP)/tool/mkopcodeh.tcl >opcodes.h
+
+# Rules to build parse.c and parse.h - the outputs of lemon.
+#
+parse.h:       parse.c
+
+parse.c:       $(TOP)/src/parse.y lemon$(BEXE)
+       cp $(TOP)/src/parse.y .
+       ./lemon$(BEXE) $(OPT_FEATURE_FLAGS) $(OPTS) -S parse.y
+
+sqlite3rc.h:   $(TOP)/src/sqlite3.rc $(TOP)/VERSION $(BTCLSH) # has_tclsh84
+       echo '#ifndef SQLITE_RESOURCE_VERSION' >$@
+       echo -n '#define SQLITE_RESOURCE_VERSION ' >>$@
+       cat $(TOP)/VERSION | $(BTCLSH) $(TOP)/tool/replace.tcl exact . , >>$@
+       echo '#endif' >>sqlite3rc.h
+
+mkkeywordhash$(BEXE): $(TOP)/tool/mkkeywordhash.c
+       $(BCC) -o $@ $(OPT_FEATURE_FLAGS) $(OPTS) $(TOP)/tool/mkkeywordhash.c
+keywordhash.h: mkkeywordhash$(BEXE)
+       ./mkkeywordhash$(BEXE) > $@
+
+
+$(libsqlite3.LIB): $(LIBOBJ)
+       $(AR) crs $@ $(LIBOBJ)
+lib: $(libsqlite3.LIB)
+all: lib
+
+target_libsqlite3_so_1 = $(libsqlite3.SO)
+target_libsqlite3_so = $(target_libsqlite3_so_$(ENABLE_SHARED))
+$(libsqlite3.SO):      $(LIBOBJ)
+       $(TLINK_shared) -o $@ $(LIBOBJ) $(LDFLAGS_libsqlite3)
+so: $(target_libsqlite3_so)
+all: so
+
+sqlite3-all.c: sqlite3.c $(TOP)/tool/split-sqlite3c.tcl $(BTCLSH) # has_tclsh84
+       $(BTCLSH) $(TOP)/tool/split-sqlite3c.tcl
+
+# Install the $(libsqlite3.SO) as $(libsqlite3.SO).$(RELEASE) and
+# create symlinks which point to it. Do we really need all of this
+# hoop-jumping? Can we not simply install the .so as-is to
+# libsqlite3.so (without the versioned bits)?
+#
+# The historical SQLite build always used a version number of 0.8.6
+# for reasons lost to history but having something to do with libtool
+# (which is not longer used in this tree).
+#
+install-so-1: $(install.libdir) $(libsqlite3.SO)
+       $(INSTALL) $(libsqlite3.SO) $(install.libdir); \
+       cd $(install.libdir); \
+               rm -f $(libsqlite3.SO).3 $(libsqlite3.SO).$(RELEASE); \
+               mv $(libsqlite3.SO) $(libsqlite3.SO).$(RELEASE); \
+               ln -s $(libsqlite3.SO).$(RELEASE) $(libsqlite3.SO).3; \
+               ln -s $(libsqlite3.SO).3 $(libsqlite3.SO)
+install-so-0:
+install: install-so-$(ENABLE_SHARED)
+
+# Install $(libsqlite3.LIB)
+#
+install-lib: $(install.libdir) $(libsqlite3.LIB)
+       $(INSTALL_noexec) $(libsqlite3.LIB) $(install.libdir)
+install: install-lib
+
+# Install C header files
+#
+install-includes: sqlite3.h $(install.includedir)
+       $(INSTALL_noexec) sqlite3.h "$(TOP)/src/sqlite3ext.h" $(install.includedir)
+install: install-includes
+
+# libtclsqlite3...
+#
+pkgIndex.tcl:
+       echo 'package ifneeded sqlite3 $(RELEASE) [list load [file join $$dir libtclsqlite3[info sharedlibextension]] sqlite3]' > $@
+libtclsqlite3.SO = libtclsqlite3$(TDLL)
+target_libtclsqlite3_1 = $(libtclsqlite3.SO)
+target_libtclsqlite3 = $(target_libtclsqlite3_$(HAVE_TCL))
+$(libtclsqlite3.SO): tclsqlite.o $(libsqlite3.LIB)
+       $(TLINK_shared) -o $@ tclsqlite.o \
+               $(TCL_INCLUDE_SPEC) $(TCL_STUB_LIB_SPEC) $(LDFLAGS_libsqlite3) \
+               $(libsqlite3.LIB) $(TCLLIB_RPATH)
+libtcl:        $(target_libtclsqlite3)
+all:   libtcl
+
+install.tcldir = "$(DESTDIR)$(TCLLIBDIR)"
+install-tcl-1: install-lib $(target_libtclsqlite3) pkgIndex.tcl
+       @if [ "x$(DESTDIR)" = "x$(install.tcldir)" ]; then echo "TCLLIBDIR is not set." 1>&2; exit 1; fi
+       $(INSTALL) -d $(install.tcldir)
+       $(INSTALL) $(libtclsqlite3.SO) $(install.tcldir)
+       $(INSTALL_noexec) pkgIndex.tcl $(install.tcldir)
+install-tcl-0 install-tcl-:
+install: install-tcl-$(HAVE_TCL)
+
+tclsqlite3.c:  sqlite3.c
+       echo '#ifndef USE_SYSTEM_SQLITE' >tclsqlite3.c
+       cat sqlite3.c >>tclsqlite3.c
+       echo '#endif /* USE_SYSTEM_SQLITE */' >>tclsqlite3.c
+       cat $(TOP)/src/tclsqlite.c >>tclsqlite3.c
+
+# Build the SQLite TCL extension in a way that make it compatible
+# with whatever version of TCL is running as $TCLSH_CMD, possibly defined
+# by --with-tclsh=
+#
+tclextension: tclsqlite3.c
+       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --build-only --cc "$(CC)" $(CFLAGS) $(OPT_FEATURE_FLAGS) $(OPTS)
+
+# Install the SQLite TCL extension in a way that is appropriate for $TCLSH_CMD
+# to find it.
+#
+tclextension-install: tclsqlite3.c
+       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --cc "$(CC)" $(CFLAGS) $(OPT_FEATURE_FLAGS) $(OPTS)
+
+# Install the SQLite TCL extension that is used by $TCLSH_CMD
+#
+tclextension-uninstall:
+       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --uninstall
+
+# List all installed the SQLite TCL extension that is are accessible
+# by $TCLSH_CMD, included prior versions.
+#
+tclextension-list:
+       $(TCLSH_CMD) $(TOP)/tool/buildtclext.tcl --info
+
+# FTS5 things
+#
+FTS5_SRC = \
+   $(TOP)/ext/fts5/fts5.h \
+   $(TOP)/ext/fts5/fts5Int.h \
+   $(TOP)/ext/fts5/fts5_aux.c \
+   $(TOP)/ext/fts5/fts5_buffer.c \
+   $(TOP)/ext/fts5/fts5_main.c \
+   $(TOP)/ext/fts5/fts5_config.c \
+   $(TOP)/ext/fts5/fts5_expr.c \
+   $(TOP)/ext/fts5/fts5_hash.c \
+   $(TOP)/ext/fts5/fts5_index.c \
+   fts5parse.c fts5parse.h \
+   $(TOP)/ext/fts5/fts5_storage.c \
+   $(TOP)/ext/fts5/fts5_tokenize.c \
+   $(TOP)/ext/fts5/fts5_unicode2.c \
+   $(TOP)/ext/fts5/fts5_varint.c \
+   $(TOP)/ext/fts5/fts5_vocab.c  \
+
+fts5parse.c:   $(TOP)/ext/fts5/fts5parse.y lemon$(BEXE)
+       cp $(TOP)/ext/fts5/fts5parse.y .
+       rm -f fts5parse.h
+       ./lemon$(BEXE) $(OPTS) -S fts5parse.y
+
+fts5parse.h: fts5parse.c
+
+fts5.c: $(FTS5_SRC) $(BTCLSH) # has_tclsh84
+       $(BTCLSH) $(TOP)/ext/fts5/tool/mkfts5c.tcl
+       cp $(TOP)/ext/fts5/fts5.h .
+
+fts5.o:        fts5.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c fts5.c
+
+sqlite3rbu.o:  $(TOP)/ext/rbu/sqlite3rbu.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/rbu/sqlite3rbu.c
+
+
+# Rules to build the 'testfixture' application.
+#
+# If using the amalgamation, use sqlite3.c directly to build the test
+# fixture.  Otherwise link against libsqlite3.a.  (This distinction is
+# necessary because the test fixture requires non-API symbols which are
+# hidden when the library is built via the amalgamation).
+#
+TESTFIXTURE_FLAGS  = -DSQLITE_TEST=1 -DSQLITE_CRASH_TEST=1
+TESTFIXTURE_FLAGS += -DTCLSH_INIT_PROC=sqlite3TestInit
+TESTFIXTURE_FLAGS += -DSQLITE_SERVER=1 -DSQLITE_PRIVATE="" -DSQLITE_CORE
+TESTFIXTURE_FLAGS += -DBUILD_sqlite
+TESTFIXTURE_FLAGS += -DSQLITE_SERIES_CONSTRAINT_VERIFY=1
+TESTFIXTURE_FLAGS += -DSQLITE_DEFAULT_PAGE_SIZE=1024
+TESTFIXTURE_FLAGS += -DSQLITE_ENABLE_STMTVTAB
+TESTFIXTURE_FLAGS += -DSQLITE_ENABLE_DBPAGE_VTAB
+TESTFIXTURE_FLAGS += -DSQLITE_ENABLE_BYTECODE_VTAB
+TESTFIXTURE_FLAGS += -DSQLITE_CKSUMVFS_STATIC
+TESTFIXTURE_FLAGS += -DSQLITE_STATIC_RANDOMJSON
+TESTFIXTURE_FLAGS += -DSQLITE_STRICT_SUBTYPE=1
+
+TESTFIXTURE_SRC0 = $(TESTSRC2) $(libsqlite3.LIB)
+TESTFIXTURE_SRC1 = sqlite3.c
+TESTFIXTURE_SRC = $(TESTSRC) $(TOP)/src/tclsqlite.c
+TESTFIXTURE_SRC += $(TESTFIXTURE_SRC$(USE_AMALGAMATION))
+
+testfixture$(TEXE):    has_tclconfig has_tclsh85 $(TESTFIXTURE_SRC)
+       $(TLINK) -DSQLITE_NO_SYNC=1 $(TEMP_STORE) $(TESTFIXTURE_FLAGS) \
+               -o $@ $(TESTFIXTURE_SRC) $(LIBTCL) $(LDFLAGS_libsqlite3) $(TCL_INCLUDE_SPEC)
+
+coretestprogs: testfixture$(BEXE) sqlite3$(BEXE)
+
+testprogs:     $(TESTPROGS) srcck1$(BEXE) fuzzcheck$(TEXE) sessionfuzz$(TEXE)
+
+# A very detailed test running most or all test cases
+fulltest:      alltest fuzztest
+
+# Run most or all tcl test cases
+alltest:       $(TESTPROGS)
+       ./testfixture$(TEXE) $(TOP)/test/all.test $(TESTOPTS)
+
+# Really really long testing
+soaktest:      $(TESTPROGS)
+       ./testfixture$(TEXE) $(TOP)/test/all.test -soak=1 $(TESTOPTS)
+
+# Do extra testing but not everything.
+fulltestonly:  $(TESTPROGS) fuzztest
+       ./testfixture$(TEXE) $(TOP)/test/full.test
+
+# Fuzz testing
+#
+# WARNING: When the "fuzztest" target is run by the testrunner.tcl script,
+# it does not actually run this code. Instead, it schedules equivalent
+# commands. Therefore, if this target is updated, then code in
+# testrunner_data.tcl (search for "trd_fuzztest_data") must also be updated.
+#
+fuzztest:      fuzzcheck$(TEXE) $(FUZZDATA) sessionfuzz$(TEXE)
+       ./fuzzcheck$(TEXE) $(FUZZDATA)
+       ./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
+
+valgrindfuzz:  fuzzcheck$(TEXT) $(FUZZDATA) sessionfuzz$(TEXE)
+       valgrind ./fuzzcheck$(TEXE) --cell-size-check --limit-mem 10M $(FUZZDATA)
+       valgrind ./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
+
+# The veryquick.test TCL tests.
+#
+tcltest:       ./testfixture$(TEXE)
+       ./testfixture$(TEXE) $(TOP)/test/veryquick.test $(TESTOPTS)
+
+# Runs all the same tests cases as the "tcltest" target but uses
+# the testrunner.tcl script to run them in multiple cores
+# concurrently.
+testrunner:    testfixture$(TEXE)
+       ./testfixture$(TEXE) $(TOP)/test/testrunner.tcl
+
+# This is the testing target preferred by the core SQLite developers.
+# It runs tests under a standard configuration, regardless of how
+# ./configure was run.  The devs run "make devtest" prior to each
+# check-in, at a minimum.  Probably other tests too, but at least this
+# one.
+#
+devtest:       srctree-check sourcetest
+       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl mdevtest $(TSTRNNR_OPTS)
+
+mdevtest: srctree-check has_tclsh85
+       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl mdevtest $(TSTRNNR_OPTS)
+
+sdevtest: has_tclsh85
+       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl sdevtest $(TSTRNNR_OPTS)
+
+# Validate that various generated files in the source tree
+# are up-to-date.
+#
+srctree-check: $(TOP)/tool/srctree-check.tcl
+       $(TCLSH_CMD) $(TOP)/tool/srctree-check.tcl
+
+# Testing for a release
+#
+releasetest: srctree-check has_tclsh85 verify-source
+       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl release $(TSTRNNR_OPTS)
+
+# Minimal testing that runs in less than 3 minutes
+#
+quicktest:     ./testfixture$(TEXE)
+       ./testfixture$(TEXE) $(TOP)/test/extraquick.test $(TESTOPTS)
+
+# Try to run tests on whatever options are specified by the
+# ./configure.  The developers seldom use this target.  Instead
+# they use "make devtest" which runs tests on a standard set of
+# options regardless of how SQLite is configured.  This "test"
+# target is provided for legacy only.
+#
+test:  srctree-check fuzztest sourcetest $(TESTPROGS) tcltest
+
+# Run a test using valgrind.  This can take a really long time
+# because valgrind is so much slower than a native machine.
+#
+valgrindtest:  $(TESTPROGS) valgrindfuzz
+       OMIT_MISUSE=1 valgrind -v ./testfixture$(TEXE) $(TOP)/test/permutations.test valgrind $(TESTOPTS)
+
+# A very fast test that checks basic sanity.  The name comes from
+# the 60s-era electronics testing:  "Turn it on and see if smoke
+# comes out."
+#
+smoketest:     $(TESTPROGS) fuzzcheck$(TEXE)
+       ./testfixture$(TEXE) $(TOP)/test/main.test $(TESTOPTS)
+
+shelltest:
+       $(TCLSH_CMD) $(TOP)/test/testrunner.tcl release shell
+
+sqlite3_analyzer.c: sqlite3.c $(TOP)/src/tclsqlite.c $(TOP)/tool/spaceanal.tcl \
+                    $(TOP)/tool/mkccode.tcl $(TOP)/tool/sqlite3_analyzer.c.in has_tclsh85
+       $(BTCLSH) $(TOP)/tool/mkccode.tcl $(TOP)/tool/sqlite3_analyzer.c.in >sqlite3_analyzer.c
+
+sqlite3_analyzer$(TEXE): has_tclconfig sqlite3_analyzer.c
+       $(TLINK) sqlite3_analyzer.c -o $@ $(LIBTCL) $(TCL_INCLUDE_SPEC) $(LDFLAGS_libsqlite3)
+
+sqltclsh.c: sqlite3.c $(TOP)/src/tclsqlite.c $(TOP)/tool/sqltclsh.tcl \
+            $(TOP)/ext/misc/appendvfs.c $(TOP)/tool/mkccode.tcl \
+            $(TOP)/tool/sqltclsh.c.in has_tclsh85
+       $(BTCLSH) $(TOP)/tool/mkccode.tcl $(TOP)/tool/sqltclsh.c.in >sqltclsh.c
+
+sqltclsh$(TEXE): has_tclconfig sqltclsh.c
+       $(TLINK) sqltclsh.c -o $@ $(LIBTCL) $(LDFLAGS_libsqlite3)
+
+sqlite3_expert$(TEXE): $(TOP)/ext/expert/sqlite3expert.h $(TOP)/ext/expert/sqlite3expert.c \
+                       $(TOP)/ext/expert/expert.c sqlite3.c
+       $(TLINK)        $(TOP)/ext/expert/sqlite3expert.h $(TOP)/ext/expert/sqlite3expert.c \
+               $(TOP)/ext/expert/expert.c sqlite3.c -o sqlite3_expert $(LDFLAGS_libsqlite3)
+
+CHECKER_DEPS =\
+  $(TOP)/tool/mkccode.tcl \
+  sqlite3.c \
+  $(TOP)/src/tclsqlite.c \
+  $(TOP)/ext/repair/sqlite3_checker.tcl \
+  $(TOP)/ext/repair/checkindex.c \
+  $(TOP)/ext/repair/checkfreelist.c \
+  $(TOP)/ext/misc/btreeinfo.c \
+  $(TOP)/ext/repair/sqlite3_checker.c.in
+
+sqlite3_checker.c:     $(CHECKER_DEPS) has_tclsh85
+       $(BTCLSH) $(TOP)/tool/mkccode.tcl $(TOP)/ext/repair/sqlite3_checker.c.in >$@
+
+sqlite3_checker$(TEXE):        has_tclconfig sqlite3_checker.c
+       $(TLINK) sqlite3_checker.c -o $@ $(LIBTCL) $(LDFLAGS_libsqlite3)
+
+dbdump$(TEXE): $(TOP)/ext/misc/dbdump.c sqlite3.lo
+       $(TLINK) -DDBDUMP_STANDALONE -o $@ \
+           $(TOP)/ext/misc/dbdump.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+dbtotxt$(TEXE): $(TOP)/tool/dbtotxt.c
+       $(TLINK)-o $@ $(TOP)/tool/dbtotxt.c
+
+showdb$(TEXE): $(TOP)/tool/showdb.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/tool/showdb.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+showstat4$(TEXE):      $(TOP)/tool/showstat4.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/tool/showstat4.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+showjournal$(TEXE):    $(TOP)/tool/showjournal.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/tool/showjournal.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+showwal$(TEXE):        $(TOP)/tool/showwal.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/tool/showwal.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+showshm$(TEXE):        $(TOP)/tool/showshm.c
+       $(TLINK) -o $@ $(TOP)/tool/showshm.c
+
+index_usage$(TEXE): $(TOP)/tool/index_usage.c sqlite3.lo
+       $(TLINK) $(SHELL_OPT) -o $@ $(TOP)/tool/index_usage.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+changeset$(TEXE):      $(TOP)/ext/session/changeset.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/ext/session/changeset.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+changesetfuzz$(TEXE):  $(TOP)/ext/session/changesetfuzz.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/ext/session/changesetfuzz.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+rollback-test$(TEXE):  $(TOP)/tool/rollback-test.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/tool/rollback-test.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+atrc$(TEXX): $(TOP)/test/atrc.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/test/atrc.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+LogEst$(TEXE): $(TOP)/tool/logest.c sqlite3.h
+       $(TLINK) -I. -o $@ $(TOP)/tool/logest.c
+
+wordcount$(TEXE):      $(TOP)/test/wordcount.c sqlite3.lo
+       $(TLINK) -o $@ $(TOP)/test/wordcount.c sqlite3.lo $(LDFLAGS_libsqlite3)
+
+speedtest1$(TEXE):     $(TOP)/test/speedtest1.c sqlite3.c Makefile
+       $(TLINK) $(ST_OPT) -o $@ $(TOP)/test/speedtest1.c sqlite3.c $(LDFLAGS_libsqlite3)
+
+#XX#startup$(TEXE):    $(TOP)/test/startup.c sqlite3.c
+#XX#   $(CC) -Os -g -DSQLITE_THREADSAFE=0 -o $@ $(TOP)/test/startup.c sqlite3.c $(TLIBS)
+# ^^^ note that it wants $(TLIBS) (a.k.a. $(LDFLAGS_libsqlite3) but is using $(CC)
+# instead of $(BCC).
+
+KV_OPT += -DSQLITE_DIRECT_OVERFLOW_READ
+
+kvtest$(TEXE): $(TOP)/test/kvtest.c sqlite3.c
+       $(TLINK) $(KV_OPT) -o $@ $(TOP)/test/kvtest.c sqlite3.c $(LDFLAGS_libsqlite3)
+
+rbu$(EXE): $(TOP)/ext/rbu/rbu.c $(TOP)/ext/rbu/sqlite3rbu.c sqlite3.o
+       $(TLINK) -I. -o $@ $(TOP)/ext/rbu/rbu.c sqlite3.o $(LDFLAGS_libsqlite3)
+
+loadfts$(EXE): $(TOP)/tool/loadfts.c $(libsqlite3.LIB)
+       $(TLINK) $(TOP)/tool/loadfts.c $(libsqlite3.LIB) -o $@ $(LDFLAGS_libsqlite3)
+
+# This target will fail if the SQLite amalgamation contains any exported
+# symbols that do not begin with "sqlite3_". It is run as part of the
+# releasetest.tcl script.
+#
+VALIDIDS=' sqlite3(changeset|changegroup|session)?_'
+checksymbols: sqlite3.o
+       nm -g --defined-only sqlite3.o
+       nm -g --defined-only sqlite3.o | egrep -v $(VALIDIDS); test $$? -ne 0
+       echo '0 errors out of 1 tests'
+
+# Build a ZIP archive containing various command-line tools.
+#
+tool-zip:      testfixture$(TEXE) sqlite3$(TEXE) sqldiff$(TEXE) \
+            sqlite3_analyzer$(TEXE) sqlite3_rsync$(TEXE) $(TOP)/tool/mktoolzip.tcl
+       strip sqlite3$(TEXE) sqldiff$(TEXE) sqlite3_analyzer$(TEXE) sqlite3_rsync$(TEXE)
+       ./testfixture$(TEXE) $(TOP)/tool/mktoolzip.tcl
+
+#XX# TODO: adapt the autoconf amalgamation for autosetup
+#XX#
+#XX## Build the amalgamation-autoconf package.  The amalamgation-tarball target builds
+#XX## a tarball named for the version number.  Ex:  sqlite-autoconf-3110000.tar.gz.
+#XX## The snapshot-tarball target builds a tarball named by the SHA1 hash
+#XX##
+#XX#amalgamation-tarball: sqlite3.c sqlite3rc.h
+#XX#   TOP=$(TOP) sh $(TOP)/tool/mkautoconfamal.sh --normal
+#XX#
+#XX#snapshot-tarball: sqlite3.c sqlite3rc.h
+#XX#   TOP=$(TOP) sh $(TOP)/tool/mkautoconfamal.sh --snapshot
+#XX#
+
+# The next two rules are used to support the "threadtest" target. Building
+# threadtest runs a few thread-safety tests that are implemented in C. This
+# target is invoked by the releasetest.tcl script.
+#
+THREADTEST3_SRC = $(TOP)/test/threadtest3.c    \
+                  $(TOP)/test/tt3_checkpoint.c \
+                  $(TOP)/test/tt3_index.c      \
+                  $(TOP)/test/tt3_vacuum.c      \
+                  $(TOP)/test/tt3_stress.c      \
+                  $(TOP)/test/tt3_lookaside1.c
+
+threadtest3$(TEXE): sqlite3.lo $(THREADTEST3_SRC)
+       $(TLINK) $(TOP)/test/threadtest3.c $(TOP)/src/test_multiplex.c sqlite3.lo -o $@ $(LDFLAGS_libsqlite3)
+
+threadtest: threadtest3$(TEXE)
+       ./threadtest3$(TEXE)
+
+threadtest5: sqlite3.c $(TOP)/test/threadtest5.c
+       $(TLINK) $(TOP)/test/threadtest5.c sqlite3.c -o $@ $(LDFLAGS_libsqlite3)
+
+sqlite3$(TEXE):        shell.c sqlite3.c
+       $(TCCX) $(CFLAGS_readline) $(SHELL_OPT) -o $@ \
+               shell.c sqlite3.c \
+               $(LDFLAGS_libsqlite3) $(LDFLAGS_READLINE)
+
+install-cli-0: sqlite3$(TEXT) $(install.bindir)
+       $(INSTALL) -s sqlite3$(TEXT) $(install.bindir)
+install-cli-1:
+install: install-cli-$(HAVE_WASI_SDK)
+
+sqldiff$(TEXE):        $(TOP)/tool/sqldiff.c $(TOP)/ext/misc/sqlite3_stdio.h sqlite3.o sqlite3.h
+       $(TLINK) $(CFLAGS_stdio3) -o $@ $(TOP)/tool/sqldiff.c sqlite3.o $(LDFLAGS_libsqlite3)
+
+install-diff: sqldiff$(TEXE) $(install.bindir)
+       $(INSTALL) -s sqldiff$(TEXT) $(install.bindir)
+#install: install-diff
+
+dbhash$(TEXE): $(TOP)/tool/dbhash.c sqlite3.o sqlite3.h
+       $(TLINK) -o $@ $(TOP)/tool/dbhash.c sqlite3.o $(LDFLAGS_libsqlite3)
+
+RSYNC_SRC = \
+  $(TOP)/tool/sqlite3_rsync.c \
+  sqlite3.c
+
+RSYNC_OPT = \
+  -DSQLITE_ENABLE_DBPAGE_VTAB \
+  -USQLITE_THREADSAFE \
+  -DSQLITE_THREADSAFE=0 \
+  -DSQLITE_OMIT_LOAD_EXTENSION \
+  -DSQLITE_OMIT_DEPRECATED
+
+sqlite3_rsync$(TEXE):  $(RSYNC_SRC)
+       $(TCCX) -o $@ $(RSYNC_OPT) $(RSYNC_SRC) $(LDFLAGS_libsqlite3)
+
+install-rsync: sqlite3_rsync$(TEXE) $(install.bindir)
+       $(INSTALL) sqlite3_rsync$(TEXT) $(install.bindir)
+#install: install-rsync
+
+scrub$(TEXE):  $(TOP)/ext/misc/scrub.c sqlite3.o
+       $(TLINK) -o $@ -I. -DSCRUB_STANDALONE \
+               $(TOP)/ext/misc/scrub.c sqlite3.o $(LDFLAGS_libsqlite3)
+
+srcck1$(BEXE): $(TOP)/tool/srcck1.c
+       $(BCC) -o srcck1$(BEXE) $(TOP)/tool/srcck1.c
+
+sourcetest:    srcck1$(BEXE) sqlite3.c
+       ./srcck1$(BEXE) sqlite3.c
+
+src-verify$(BEXE):     $(TOP)/tool/src-verify.c
+       $(BCC) -o src-verify$(BEXE) $(TOP)/tool/src-verify.c
+
+verify-source: ./src-verify$(BEXE)
+       ./src-verify$(BEXE) $(TOP)
+
+fuzzershell$(TEXE):    $(TOP)/tool/fuzzershell.c sqlite3.c sqlite3.h
+       $(TLINK) -o $@ $(FUZZERSHELL_OPT) \
+         $(TOP)/tool/fuzzershell.c sqlite3.c $(LDFLAGS_libsqlite3)
+fuzzy: fuzzershell$(TEXE)
+
+fuzzcheck$(TEXE):      $(FUZZCHECK_SRC) sqlite3.c sqlite3.h $(FUZZCHECK_DEP)
+       $(TLINK) -o $@ $(FUZZCHECK_OPT) $(FUZZCHECK_SRC) sqlite3.c $(LDFLAGS_libsqlite3)
+fuzzy: fuzzcheck$(TEXE)
+
+fuzzcheck-asan$(TEXE): $(FUZZCHECK_SRC) sqlite3.c sqlite3.h $(FUZZCHECK_DEP)
+       $(TLINK) -o $@ -fsanitize=address $(FUZZCHECK_OPT) $(FUZZCHECK_SRC) \
+               sqlite3.c $(LDFLAGS_libsqlite3)
+fuzzy: fuzzcheck-asan$(TEXE)
+
+
+fuzzcheck-ubsan$(TEXE):        $(FUZZCHECK_SRC) sqlite3.c sqlite3.h $(FUZZCHECK_DEP)
+       $(TLINK) -o $@ -fsanitize=undefined $(FUZZCHECK_OPT) $(FUZZCHECK_SRC) \
+               sqlite3.c $(LDFLAGS_libsqlite3)
+fuzzy: fuzzcheck-ubsan$(TEXE)
+
+# Usage:    FUZZDB=filename make run-fuzzcheck
+#
+# Where filename is a fuzzcheck database, this target builds and runs
+# fuzzcheck, fuzzcheck-asan, and fuzzcheck-ubsan on that database.
+#
+# FUZZDB can be a glob pattern of two or more databases. Example:
+#
+#     FUZZDB=test/fuzzdata*.db make run-fuzzcheck
+#
+run-fuzzcheck: fuzzcheck$(TEXE) fuzzcheck-asan$(TEXE) fuzzcheck-ubsan$(TEXE)
+       @if test "$(FUZZDB)" = ""; then echo 'ERROR: No FUZZDB specified. Rerun with FUZZDB=filename'; exit 1; fi
+       ./fuzzcheck$(TEXE) --spinner $(FUZZDB)
+       ./fuzzcheck-asan$(TEXE) --spinner $(FUZZDB)
+       ./fuzzcheck-ubsan$(TEXE) --spinner $(FUZZDB)
+
+ossshell$(TEXE):       $(TOP)/test/ossfuzz.c $(TOP)/test/ossshell.c sqlite3.c sqlite3.h
+       $(TLINK) -o $@ $(FUZZCHECK_OPT) $(TOP)/test/ossshell.c \
+             $(TOP)/test/ossfuzz.c sqlite3.c $(LDFLAGS_libsqlite3)
+fuzzy: ossshell$(TEXE)
+
+sessionfuzz$(TEXE):    $(TOP)/test/sessionfuzz.c sqlite3.c sqlite3.h
+       $(TLINK) -o $@ $(TOP)/test/sessionfuzz.c $(LDFLAGS_libsqlite3)
+fuzzy: sessionfuzz$(TEXE)
+
+dbfuzz$(TEXE): $(TOP)/test/dbfuzz.c sqlite3.c sqlite3.h
+       $(TLINK) -o $@ $(DBFUZZ_OPT) $(TOP)/test/dbfuzz.c sqlite3.c $(LDFLAGS_libsqlite3)
+fuzzy: dbfuzz$(TEXE)
+
+DBFUZZ2_OPTS = \
+  -USQLITE_THREADSAFE \
+  -DSQLITE_THREADSAFE=0 \
+  -DSQLITE_OMIT_LOAD_EXTENSION \
+  -DSQLITE_DEBUG \
+  -DSQLITE_ENABLE_DBSTAT_VTAB \
+  -DSQLITE_ENABLE_BYTECODE_VTAB \
+  -DSQLITE_ENABLE_RTREE \
+  -DSQLITE_ENABLE_FTS4 \
+  -DSQLITE_ENABLE_FTS5
+
+dbfuzz2$(TEXE):        $(TOP)/test/dbfuzz2.c sqlite3.c sqlite3.h
+       $(CC) $(OPT_FEATURE_FLAGS) $(OPTS) -I. -g -O0 \
+               -DSTANDALONE -o dbfuzz2 \
+               $(DBFUZZ2_OPTS) $(TOP)/test/dbfuzz2.c sqlite3.c $(LDFLAGS_libsqlite3)
+       mkdir -p dbfuzz2-dir
+       cp $(TOP)/test/dbfuzz2-seed* dbfuzz2-dir
+fuzzy: dbfuzz2$(TEXE)
+
+mptester$(TEXE):       $(libsqlite3.LIB) $(TOP)/mptest/mptest.c
+       $(TLINK) -o $@ -I. $(TOP)/mptest/mptest.c $(libsqlite3.LIB) \
+               $(LDFLAGS_libsqlite3)
+
+MPTEST1=./mptester$(TEXE) mptest.db $(TOP)/mptest/crash01.test --repeat 20
+MPTEST2=./mptester$(TEXE) mptest.db $(TOP)/mptest/multiwrite01.test --repeat 20
+mptest:        mptester$(TEXE)
+       rm -f mptest.db
+       $(MPTEST1) --journalmode DELETE
+       $(MPTEST2) --journalmode WAL
+       $(MPTEST1) --journalmode WAL
+       $(MPTEST2) --journalmode PERSIST
+       $(MPTEST1) --journalmode PERSIST
+       $(MPTEST2) --journalmode TRUNCATE
+       $(MPTEST1) --journalmode TRUNCATE
+       $(MPTEST2) --journalmode DELETE
+
+# Source and header files that shell.c depends on
+SHELL_DEP = \
+    $(TOP)/src/shell.c.in \
+    $(TOP)/ext/consio/console_io.c \
+    $(TOP)/ext/consio/console_io.h \
+    $(TOP)/ext/expert/sqlite3expert.c \
+    $(TOP)/ext/expert/sqlite3expert.h \
+    $(TOP)/ext/intck/sqlite3intck.c \
+    $(TOP)/ext/intck/sqlite3intck.h \
+    $(TOP)/ext/misc/appendvfs.c \
+    $(TOP)/ext/misc/base64.c \
+    $(TOP)/ext/misc/base85.c \
+    $(TOP)/ext/misc/completion.c \
+    $(TOP)/ext/misc/decimal.c \
+    $(TOP)/ext/misc/fileio.c \
+    $(TOP)/ext/misc/ieee754.c \
+    $(TOP)/ext/misc/memtrace.c \
+    $(TOP)/ext/misc/pcachetrace.c \
+    $(TOP)/ext/misc/percentile.c \
+    $(TOP)/ext/misc/regexp.c \
+    $(TOP)/ext/misc/series.c \
+    $(TOP)/ext/misc/sha1.c \
+    $(TOP)/ext/misc/shathree.c \
+    $(TOP)/ext/misc/sqlar.c \
+    $(TOP)/ext/misc/uint.c \
+    $(TOP)/ext/misc/vfstrace.c \
+    $(TOP)/ext/misc/zipfile.c \
+    $(TOP)/ext/recover/dbdata.c \
+    $(TOP)/ext/recover/sqlite3recover.c \
+    $(TOP)/ext/recover/sqlite3recover.h \
+    $(TOP)/src/test_windirent.c \
+    $(TOP)/src/test_windirent.h
+
+shell.c:       $(SHELL_DEP) $(TOP)/tool/mkshellc.tcl $(BTCLSH) # has_tclsh84
+       $(BTCLSH) $(TOP)/tool/mkshellc.tcl >shell.c
+
+
+# Rules to build the extension objects.
+#
+icu.o: $(TOP)/ext/icu/icu.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/icu/icu.c
+
+fts3.o:        $(TOP)/ext/fts3/fts3.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3.c
+
+fts3_aux.o:    $(TOP)/ext/fts3/fts3_aux.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_aux.c
+
+fts3_expr.o:   $(TOP)/ext/fts3/fts3_expr.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_expr.c
+
+fts3_hash.o:   $(TOP)/ext/fts3/fts3_hash.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_hash.c
+
+fts3_icu.o:    $(TOP)/ext/fts3/fts3_icu.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_icu.c
+
+fts3_porter.o: $(TOP)/ext/fts3/fts3_porter.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_porter.c
+
+fts3_snippet.o:        $(TOP)/ext/fts3/fts3_snippet.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_snippet.c
+
+fts3_tokenizer.o:      $(TOP)/ext/fts3/fts3_tokenizer.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_tokenizer.c
+
+fts3_tokenizer1.o:     $(TOP)/ext/fts3/fts3_tokenizer1.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_tokenizer1.c
+
+fts3_tokenize_vtab.o:  $(TOP)/ext/fts3/fts3_tokenize_vtab.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_tokenize_vtab.c
+
+fts3_unicode.o:        $(TOP)/ext/fts3/fts3_unicode.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_unicode.c
+
+fts3_unicode2.o:       $(TOP)/ext/fts3/fts3_unicode2.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_unicode2.c
+
+fts3_write.o:  $(TOP)/ext/fts3/fts3_write.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/fts3/fts3_write.c
+
+rtree.o:       $(TOP)/ext/rtree/rtree.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/rtree/rtree.c
+
+userauth.o:    $(TOP)/ext/userauth/userauth.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/userauth/userauth.c
+
+sqlite3session.o:      $(TOP)/ext/session/sqlite3session.c $(HDR) $(EXTHDR)
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/session/sqlite3session.c
+
+stmt.o:        $(TOP)/ext/misc/stmt.c
+       $(TCOMPILE) -DSQLITE_CORE -c $(TOP)/ext/misc/stmt.c
+
+#
+# tool/version-info: a utility for emitting sqlite3 version info
+# in various forms.
+#
+version-info$(TEXE):   $(TOP)/tool/version-info.c Makefile sqlite3.h
+       $(TLINK) $(ST_OPT) -o $@ $(TOP)/tool/version-info.c
+
+#
+# Windows section
+#
+dll: sqlite3.dll
+sqlite3.def: $(LIBOBJ)
+       echo 'EXPORTS' >sqlite3.def
+       nm $(LIBOBJ) | grep ' T ' | grep ' _sqlite3_' \
+               | sed 's/^.* _//' >>sqlite3.def
+
+sqlite3.dll: $(LIBOBJ) sqlite3.def
+       $(TCCX) $(LDFLAGS_SHOBJ) -o $@ sqlite3.def \
+               -Wl,"--strip-all" $(LIBOBJ)
+
+
+# Remove build products sufficient so that subsequent makes will recompile
+# everything from scratch.  Do not remove:
+#
+#   *   test results and test logs
+#   *   output from ./configure
+#
+tidy:
+       rm -f *.o *.c *.da *.bb *.bbg gmon.* *.rws sqlite3$(TEXE)
+       rm -f fts5.h keywordhash.h opcodes.h sqlite3.h sqlite3ext.h sqlite3session.h
+       rm -rf .libs .deps tsrc .target_source
+       rm -f lemon$(BEXE) sqlite*.tar.gz
+       rm -f mkkeywordhash$(BEXE) mksourceid$(BEXE)
+       rm -f parse.* fts5parse.*
+       rm -f $(libsqlite3.SO) $(libsqlite3.LIB)
+       rm -f tclsqlite3$(TEXE) $(TESTPROGS)
+       rm -f LogEst$(TEXE) fts3view$(TEXE) rollback-test$(TEXE) showdb$(TEXE)
+       rm -f showjournal$(TEXE) showstat4$(TEXE) showwal$(TEXE) speedtest1$(TEXE)
+       rm -f wordcount$(TEXE) changeset$(TEXE) version-info$(TEXE)
+       rm -f *.dll *.lib *.exp *.pc *.vsix *.so *.dylib pkgIndex.tcl
+       rm -f sqlite3_analyzer$(TEXE) sqlite3_rsync$(TEXE) sqlite3_expert$(TEXE)
+       rm -f mptester$(TEXE) rbu$(TEXE)        srcck1$(TEXE)
+       rm -f fuzzershell$(TEXE) fuzzcheck$(TEXE) sqldiff$(TEXE) dbhash$(TEXE)
+       rm -f dbfuzz$(TEXE) dbfuzz2$(TEXE) dbfuzz2-asan$(TEXE) dbfuzz2-msan$(TEXE)
+       rm -f fuzzcheck-asan$(TEXE) fuzzcheck-ubsan$(TEXE) ossshell$(TEXE)
+       rm -f sessionfuzz$(TEXE)
+       rm -f threadtest5$(TEXE)
+       rm -f src-verify$(BEXE) has_tclsh* has_tclconfig
+       rm -f tclsqlite3.c
+       rm -f sqlite3rc.h sqlite3.def
+
+#
+# Removes build products and test logs.  Retains ./configure outputs.
+#
+clean: tidy
+       rm -rf omittest* testrunner* testdir*
+       -gmake -C ext/wasm distclean 2>/dev/null; true
+
+# Clean up everything.  No exceptions.
+distclean:     clean
+       rm -f sqlite_cfg.h config.log config.status $(JIMSH) Makefile
+       rm -f $(TOP)/tool/emcc.sh
+       -gmake -C ext/wasm distclean 2>/dev/null; true
index 2eb7bebd49fed77ea917293cd52cb1b15c9adf0a..d31f53fa5b4ce9a6e92a7fdc62252814a1359967 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,9 +1,9 @@
-C Factor\sout\sall\sautosetup-processed\s@if/@else\sblocks\sfrom\sMakefile.in\sin\sprep\sfor\smoving\smost\sof\sthe\smakefile\scode\sinto\smain.mk\s(which\shas,\sso\sfar,\sbeen\scompletely\soverlooked\sin\sthis\sport\sbut\swill\snow\sbecome\sthe\smain\sbasis\sfor\sthe\sstatic\sparts\sof\sthe\sbuild).\sThe\sidea\sis\sthat\sall\sbuild\sconfiguration\sgoes\sinto\sa\splatform-dependent\smakefile\swhich\sthen\sincludes\smain.mk.
-D 2024-10-19T18:31:47.423
+C Move\smost\sof\sthe\smakefile\scode\sinto\sthe\sstatic\smain.mk.
+D 2024-10-19T20:26:17.451
 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
 F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
-F Makefile.in 799e30c5ea3622e4909e2befa455bfa4e90ec214cb06a714c469897da3166b9e
+F Makefile.in 1167ba2d57c63bbcbf96e919b6783665f751cc04e4b75985ed67f2a59b8074e6
 F Makefile.linux-gcc f3842a0b1efbfbb74ac0ef60e56b301836d05b4d867d014f714fa750048f1ab6
 F Makefile.msc 58b69eda1faad5d475092b8aeffab9156ee4901a82db089b166607f2ec907ee4
 F README.md c3c0f19532ce28f6297a71870f3c7b424729f0e6d9ab889616d3587dd2332159
@@ -711,7 +711,7 @@ F ext/wasm/wasmfs.make bc8bb227f35d5bd3863a7bd2233437c37472a0d81585979f058f9b9b5
 F install-sh 9d4de14ab9fb0facae2f48780b874848cbf2f895 x
 F ltmain.sh 3ff0879076df340d2e23ae905484d8c15d5fdea8
 F magic.txt 5ade0bc977aa135e79e3faaea894d5671b26107cc91e70783aa7dc83f22f3ba0
-F main.mk ea3f49474ea443c294ca75820839fb43db4a9f72cd4b14b895ddc9fa73a4e9b0
+F main.mk 10bec40eca5f1e371130e12d0eef005d630b7f0885d3a0137ad489c54a78f9b7
 F mptest/config01.test 3c6adcbc50b991866855f1977ff172eb6d901271
 F mptest/config02.test 4415dfe36c48785f751e16e32c20b077c28ae504
 F mptest/crash01.test 61e61469e257df0850df4293d7d4d6c2af301421
@@ -2240,8 +2240,8 @@ F vsixtest/vsixtest.tcl 6195aba1f12a5e10efc2b8c0009532167be5e301abe5b31385638080
 F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
 F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
 F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P 510afccf02dc9c3e3b928c64c34d10bee66a2343ecec6e24c4770cb0f139cd65
-R 7a8eadbb3ae7a887d98a01ebf4e8c64c
+P 707e0f5857d58ec8b457270f988126b1dd0f01b5a3445a43ff7b5429324b1b3d
+R 7e557d1ad5ee2c5b2e44bb3a9becbb6a
 U stephan
-Z 7236fe64030e3971014f63694120dff4
+Z 03e1de4c6fd20e15dd82a14719fd967a
 # Remove this line to create a well-formed Fossil manifest.
index 5d2c7d818bbc08b443d34cda68650c872cb7299e..72e5783713639502b93ce0e889a54a6eb39cfe3e 100644 (file)
@@ -1 +1 @@
-707e0f5857d58ec8b457270f988126b1dd0f01b5a3445a43ff7b5429324b1b3d
+09905ed094f7102dbb4fc81b059452c50b48b0f3a2bd9736bed364b0639d89d7