descriptionUnofficial git mirror of the SQLite sources
last changeSat, 24 Jun 2017 19:21:48 +0000 (24 19:21 +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

2 days ago D. Richard... Disable shell tests for the .schema command if virtual... master
2 days ago D. Richard... Make sure the config.h header is included by ctime...
2 days ago D. Richard... Query planner tuning: When deciding between two plans...
2 days ago D. Richard... Make sure enough memory is allocated for pathological...
3 days ago Dan KennedyWhen generating individual loops for each ORed term...
4 days ago Dan KennedyWhen generating individual loops for each ORed term... or-optimization
6 days ago D. Richard... Enable pragma virtual tables for the integrity_check...
6 days ago D. Richard... Rename the azCompileOpt global constant to avoid a...
6 days ago Dan KennedyEnsure that the query planner knows that any column...
9 days ago D. Richard... Fix a missing comma in the previous check-in.
9 days ago Dan KennedyRework the code in ctime.c a bit to report on more...
9 days ago Dan KennedyEnsure that the value of the THREADSAFE symbol is alway... ctime-refactor
9 days ago Dan KennedyAdd extra test cases for sqlite3changeset_apply() and...
10 days ago Dan KennedyRework the code in ctime.c a bit to report on more...
10 days ago D. Richard... Minor refactoring change to clarify how ATTACH works...
10 days ago D. Richard... Prevent pagesize changes on VACUUM in encrypted databas...
9 days ago version-3.18.2
9 days ago release
10 days ago version-3.18.1
2 weeks ago version-3.19.3
4 weeks ago version-3.19.2
4 weeks ago version-3.19.1
5 weeks ago version-3.19.0
2 months ago version-3.18.0
4 months ago version-3.17.0
5 months ago version-3.16.2
5 months ago version-3.16.1
5 months ago version-3.16.0
6 months ago version-3.15.2
7 months ago version-3.15.1
8 months ago version-3.15.0
9 months ago version-3.14.2
24 hours ago lsm-vtab
2 days ago master
2 days ago partial-index-variables
3 days ago apple-osx
4 days ago or-optimization
6 days ago server-edition
7 days ago fast-secure-delete
9 days ago subquery-limit-opt
9 days ago ctime-refactor
9 days ago branch-3.18
10 days ago mistake
2 weeks ago 3.18
2 weeks ago begin-concurrent
2 weeks ago prepare_v3
2 weeks ago branch-3.19
2 weeks ago analyze-empty-tables