descriptionUnofficial git mirror of the SQLite sources
last changeMon, 21 Aug 2017 02:20:57 +0000 (21 02:20 +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
git log -1 --format=format:%ci%n | sed -e 's/ [-+].*$//;s/ /T/;s/^/D /' > manifest
echo $(git log -1 --format=format:%H) > manifest.uuid

The above script simply records the hash of the current HEAD commit in manifest.uuid and the UTC time of the commit in ISO format (preceded by "D ") in the manifest file. This 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

11 hours ago D. Richard... Remove an unnecessary conditional.master
11 hours ago D. Richard... Minor optimization to sqlite3VdbeMemSetStr().
41 hours ago D. Richard... Space and size optimization to the printf implementation.
2 days ago D. Richard... Another size and performance optimization to readDbPage...
2 days ago D. Richard... Size and performance optimization the readDbPage()...
2 days ago D. Richard... For the unix VFS, avoid an unnecessary stat() system...
2 days ago D. Richard... Combine the OP_CreateTable and OP_CreateIndex opcodes...
3 days ago Dan KennedyOnly use indexes on expressions to optimize ORDER BY...
3 days ago D. Richard... Use the __builtin_clzll() function of gcc to improve...
3 days ago D. Richard... Small optimization in the Expr tree walker.
3 days ago D. Richard... Size optimization in the authorizer error message gener...
3 days ago D. Richard... In sqlite3ViewGetColumnNames(), return the number of...
3 days ago D. Richard... The RTREE extension should return SQLITE_CORRUPT_VTAB...
3 days ago D. Richard... Remove an unnecessary branch from the [be436a7f4587ce51...
3 days ago Dan KennedyAdd test cases for ticket [be436a7f4587ce517] using...
4 days ago D. Richard... Defer schema resets when the query planner is running.
2 days ago version-3.19.4
2 days ago release
2 weeks ago version-3.20.0
2 months ago version-3.18.2
2 months ago version-3.18.1
2 months ago version-3.19.3
2 months ago version-3.19.2
2 months ago version-3.19.1
2 months ago version-3.19.0
4 months ago version-3.18.0
6 months ago version-3.17.0
7 months ago version-3.16.2
7 months ago version-3.16.1
7 months ago version-3.16.0
8 months ago version-3.15.2
9 months ago version-3.15.1
11 hours ago master
45 hours ago server-process-edition
2 days ago branch-3.19
6 days ago begin-concurrent-branch-3.19
8 days ago begin-concurrent
10 days ago writable-vtab-without-rowid
11 days ago reuse-schema
13 days ago mmap-size-limit
2 weeks ago union-vtab
2 weeks ago sqlite3rbu.h-fix
2 weeks ago branch-3.20
3 weeks ago batch-atomic-write-3.19
3 weeks ago early-column-names
3 weeks ago flattener-column-names
3 weeks ago batch-atomic-write
3 weeks ago branch-3.8.9