descriptionUnofficial git mirror of the SQLite sources
last changeFri, 23 Feb 2018 13:38:54 +0000 (23 13:38 +0000)
content tags
sqlite git mirror @

SQLite Git Mirror

Self-contained implementation of most of the SQL-92 specification

An unofficial git mirror of only the source code from the main SQLite repository at which is part of the SQLite project.

Building SQLite

In order to clone and build SQLite from this git repository, a substitute manifest and manifest.uuid file (these are fossil vcs specific files) must be created or the build will fail.

The following script may be executed with the current directory set to the working directory of the git clone in order to create or update these files:

# See for license details
# Creates a minimal manifest and manifest.uuid file so sqlite (and fossil) can build
git rev-parse --git-dir >/dev/null || exit 1
echo $(git log -1 --format=format:%H) > manifest.uuid
echo C $(cat manifest.uuid) > manifest
git log -1 --format=format:%ci%n | sed 's/ [-+].*$//;s/ /T/;s/^/D /' >> manifest

The above script simply records the hash of the current HEAD commit in manifest.uuid (and as the manifest’s "C"omment) and the UTC time of the commit in ISO format (preceded by "D ") in the manifest file.

The above script must be run at least once from the top-level of the working directory of the git clone for make to succeed and should be run before make whenever HEAD has changed otherwise the sqlite_source_id() information will be incorrect.

The above script is also available from the project in the create-fossil-manifest file.

After having created the substitute manifest and manifest.uuid files, simply build as normal (i.e. run ./configure with any desired options and then run make).

About This Mirror

This git mirror has been created using the information found in the project. Please see that project’s README.txt file for more information.

The fossil check-in hash of the fossil SQLite repository check-in corresponding to a commit can be found in the "fossil" notes (i.e. refs/notes/fossil). (Use git log --show-notes=fossil to see them.) Once you have the fossil check-in hash (e.g. git log --show-notes=fossil -1 version-3.8.5) you can then view the original commit in the SQLite fossil repository at (e.g.

Please note that this mirror is updated only once a day so it may take up to 24 hours for commits to the main SQLite fossil repository at to appear here.

IMPORTANT: Since this is strictly a mirror, if the upstream fossil repository should rewrite history in any way, the refs in this repository will be force updated without notice!

The Great 2017 Rebuild

In March of 2017, the official SQLite repository started using a new hash algorithm. As a result, the older version of fossil being used was no longer capable of keeping this mirror up-to-date.

Switching to a newer fossil version produced some minor differences in the commit objects (the exported tree objects the commits refer to are identical between the two versions). This caused all the refs to be force-updated. Unfortunately it was unavoidable in order for this mirror to remain current.

Since the tree objects themselves are identical, rebasing any work built on the old ref values to the new ref values should be relatively painless.


Since this is strictly a mirror of the code from the native SQLite fossil repository, the standard SQLite license applies.


Downloads are available from the main SQLite download area or from links found at

Visit the project page (source code etc.) at


Visit the SQLite project’s home site at

42 hours ago Joe MistachkinFix harmless compiler warnings in the zipfile extension... master
42 hours ago Joe MistachkinEnable the JSON1 extension when compiling the test...
2 days ago D. Richard... For the "SQLite archive" link in the file...
2 days ago D. Richard... Updates to the file. Mention the ability...
4 days ago D. Richard... Remove an unreachable branch in the walIndexPage()...
4 days ago D. Richard... Small performance improvement in sqltie3WalFindFrame().
4 days ago D. Richard... Remove an unnecessary memset().
4 days ago D. Richard... Make the walIndexPage() routine about 3x faster by...
4 days ago D. Richard... In the script, make WAL mode the default...
4 days ago D. Richard... Remove a superfluous "#if 1". No logic changes.
4 days ago D. Richard... Optimize calls to sqlite3_mprintf("%z...") so that...
4 days ago D. Richard... Remove a lot of the text describing extended format...
5 days ago D. Richard... Enhance the string formatter (used by printf()) so...
5 days ago D. Richard... Printing a value of 0 using %c terminates the string.printf-enhancement
5 days ago D. Richard... More test cases for unicode handling in printf.
5 days ago D. Richard... Test cases and a bug fix on the new unicode handling...
4 weeks ago version-3.22.0
4 weeks ago release
4 months ago version-3.21.0
6 months ago version-3.20.1
6 months ago version-3.19.4
6 months ago version-3.20.0
8 months ago version-3.18.2
8 months ago version-3.18.1
8 months ago version-3.19.3
9 months ago version-3.19.2
9 months ago version-3.19.1
9 months ago version-3.19.0
10 months ago version-3.18.0
12 months ago version-3.17.0
13 months ago version-3.16.2
13 months ago version-3.16.1
23 hours ago zonefile
42 hours ago master
4 days ago begin-concurrent-pnu
5 days ago printf-enhancement
9 days ago write-queue-flush-hack
3 weeks ago branch-3.9.2
3 weeks ago branch-3.19
3 weeks ago zipfile-timestamp-fix
3 weeks ago omit-left-join-fix
4 weeks ago memdb
4 weeks ago noop-update-reprepare
4 weeks ago apple-osx
5 weeks ago sessions-stat1
6 weeks ago f2fs-test-fixes
6 weeks ago sqlite3_value_nochange
6 weeks ago rtree-one-pass