summaryrefslogtreecommitdiffstats
path: root/third_party/sqlite/README.chromium
blob: 45d0a8d0c95eb4175327cb6434759b0607870072 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
Name: SQLite
License File: src/LICENSE
URL: http://sqlite.org/

Instructions for importing a new release of SQLite from sqlite.org.

Note: our current base version is 3.6.18.

First, you need to be on Linux.

# Determine the versions of the release you want and the release we currently
# have. (See the VERSION file to determine which release we currently have.)
# You may wish to consult http://www.sqlite.org/changes.html to find out what
# changes have been made in each release.
# Note - this is just an example. Always refer to the version above for our
# real current version.
# Set some variables to remember the versions, e.g.:
BASE=3.6.18
LATEST=3.6.22

# Get to the src/third_party directory in your Chromium client:
cd src/third_party

# Download the .tar.gz files for the releases:
# (If the URL changes you might need to find the new one.)
wget http://www.sqlite.org/sqlite-$BASE.tar.gz
wget http://www.sqlite.org/sqlite-$LATEST.tar.gz

# Extract the vanilla current and desired versions:
tar xzf sqlite-$BASE.tar.gz
tar xzf sqlite-$LATEST.tar.gz

# Use kdiff3 to merge the changes:
kdiff3 -m sqlite-$BASE sqlite-$LATEST sqlite

# Resolve any conflicts.  Figure out if we've got everything we should
# have (see below), or if we can omit any changes we no longer need.

# Change to the sqlite directory:
cd sqlite

# Run the google_generate_preprocessed.sh script:
./google_generate_preprocessed.sh

# Find a sucker.  Send review.
# TODO(shess) Describe an appropriate comment style.  Seems like it
# should at least include the SQLite version number.

--------------------------------------------

For reference, all of our local patches are also kept as .patch files in the
sqlite directory. Here is a list of the patches, in the order they should be
applied to a vanilla SQLite (of the version we currently have) to get, in
principle, exactly what is checked in:

misc.patch
preload-cache.patch
safe-tolower.patch
sqlite-poison.patch
fts2.patch
fts3.patch
icu-regexp.patch
attach-integer.patch

So, e.g. you could do this to apply all our patches to vanilla SQLite:

cd sqlite-$LATEST
patch -p0 < ../sqlite/misc.patch
patch -p0 < ../sqlite/preload-cache.patch
patch -p0 < ../sqlite/safe-tolower.patch
patch -p0 < ../sqlite/sqlite-poison.patch
patch -p0 < ../sqlite/fts2.patch
patch -p0 < ../sqlite/fts3.patch
patch -p0 < ../sqlite/icu-regexp.patch
patch -p0 < ../sqlite/attach-integer.patch

This will only be the case if all changes we make also update the corresponding
patch files. Therefore please remember to do that whenever you make a change!

Descriptions of the changes we've made can be found at the bottom of this file.

--------------------------------------------

How to run the SQLite tests for the Chromium version of SQLite on Linux.

Prerequisties: On my corp Ubuntu 8.04 workstation, I needed to install the
following packages:
sudo apt-get install tcl8.4-dev libicu-dev

cd src/third_party/sqlite
mkdir build
cd build
make -f ../Makefile.linux-gcc testfixture
make -f ../Makefile.linux-gcc test > /tmp/test.log
egrep -v 'Ok$' /tmp/test.log
# For an ideal test run, you would see:
# 0 errors out of 57887 tests
# However, the current situation on my corp Linux Ubuntu 8.04 machine, with
# test run on a locally mounted directory, is the failure of:
# "rollback-2.3", "tkt3457-1.4"
# I do not know why, but it is not related to our fts2.c changes -- I backed
# them out to check.

Chris Evans <cevans@google.com>, Oct 1, 2009

--------------------------------------------

As of May 07, 2010, these are our changes from sqlite_vendor:

 - A fix for a crash passing an integer expression to ATTACH / DETACH. See
 attach-integer.patch
 - A fix for a crash mis-calling the REGEXP() function of the ICU extension.
 See icu-regexp.patch
 - A large number of fts2 robustness fixes against corrupt data in its metadata
   tables.
 - fts2.c disables fts2_tokenizer().
 - fts3.c disables fts3_tokenizer().
 - sqlite3Poison() in src/btree.c.
 - Tweak to SQLITE_EXTENSION_INIT* in sqlite3ext.h.
   - That implied a change in src/test_autoext.c for testing.
 - Added fts.test and fts1.test in tests, modified quick.test.
 - src/os_symbian.cc.
 - Modifications to Makefile.linux-gcc and main.mk for compiling
   SQLite tests.
 - Compile warning (cast to void* for sqlite3_free) fixed in func.c.
 - Avoid using tolower() in fts code which causes problem in some locales, see:
   safe-tolower.patch
   http://crbug.com/15261
   http://www.sqlite.org/src/tktview/991789d9f3136a0460dc83a33e815c1aa9757c26
 - Check that the third argument to memset() is nonzero in expr.c to avoid
   a linker warning when the compiler can optimize it to a constant zero
   (e.g. see http://www.sqlite.org/cvstrac/tktview?tn=3765,39)

Changes from Chrome:
 - I marked all changes I made with "evanm", so you can find them with
   "grep evanm *".
 - Most files include sqlite3ext.h with SQLITE_CORE #defined, but two don't:
   fts2_tokenizer.c and icu.c.  Without this #define, the calls in
   fts2_tokenizer.c try to go through some pointer to the sqlite API instead
   of calling the functions directly (to work as a loadable module), but then
   crash (because the other files never initialize that loadable module
   support).  As a hack I #defined it in these files, but it'd be nice to
   figure out what really ought to happen here (perhaps this file is new and
   hasn't been tested to verify it works right).  Update: Seems this is an
   issue we get because we're using fts2 instead of fts3.
 - shell_icu_win.c and shell_icu_linux.c are Chrome-specific files used to load
   our ICU data.  shell.c has been modifed to call into these files.
 - fts2_icu.c and fts3_icu.c have a critical bug. U8_NEXT is used over
   a UTF-16 string. It's rep$ by U16_NEXT (jungshik)
 - Added a new function sqlite3Preload we use to prime the database cache. It
   allows much faster performance by reading the file in one contiguous
   operation rather than bringing it in organically, which involves a lot of
   seeking. This change also required sqlite3PcacheGetCachesize to be compiled
   even outside SQLITE_TEST.
 - Added a new function chromium_sqlite3_initialize_win_sqlite3_file()
   at the end of os_win.c. It allows the Windows-specific Chromium VFS
   to reuse most of the win32 SQLite VFS.
 - Added a new function
   chromium_sqlite3_initialize_unix_sqlite3_file() and made
   fillInUnixFile() non-static in os_unix.c. It allows the
   Linux-specific Chromium VFS to reuse most of the unix SQLite VFS.
 - Exposed three functions that deal with unused file descriptors in
   os_unix.c, to allow Chromium's Posix VFS implementation in
   WebKit/WebCore/platform/sql/chromium/SQLiteFileSystemChromiumPosix.cpp
   to correctly implement the "unused file descriptors" logic in the
   xDlOpen() method. The new functions are
   chromium_sqlite3_get_reusable_file_handle(),
   chromium_sqlite3_update_reusable_file_handle() and
   chromium_sqlite3_destroy_reusable_file_handle(). Also, added the
   chromium_sqlite3_fill_in_unix_sqlite3_file() function that calls
   fillInUnixFile(), which will be made static again as soon as a
   WebKit patch using the new function lands.