mirror of
https://github.com/sqlite/sqlite.git
synced 2025-08-05 15:55:57 +03:00
Add the SQLITE_ENABLE_API_ARMOR compile-time option. This is a work in
progress and is not yet completely functional. FossilOrigin-Name: c297a84bc678f81ffc0aa9139ab73f0ca87c1971
This commit is contained in:
49
manifest
49
manifest
@@ -1,5 +1,5 @@
|
|||||||
C Implement\ssqlite3_create_collation()\sby\sinvoking\s\nsqlite3_create_collation_v2()\swith\sa\sNULL\sdestructor\sargument.\s\sThis\ssaves\na\slittle\sspace.
|
C Add\sthe\sSQLITE_ENABLE_API_ARMOR\scompile-time\soption.\s\sThis\sis\sa\swork\sin\nprogress\sand\sis\snot\syet\scompletely\sfunctional.
|
||||||
D 2014-10-23T01:01:26.636
|
D 2014-10-24T00:35:58.052
|
||||||
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
||||||
F Makefile.in cf57f673d77606ab0f2d9627ca52a9ba1464146a
|
F Makefile.in cf57f673d77606ab0f2d9627ca52a9ba1464146a
|
||||||
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
||||||
@@ -168,17 +168,17 @@ F sqlite3.pc.in 48fed132e7cb71ab676105d2a4dc77127d8c1f3a
|
|||||||
F src/alter.c ba266a779bc7ce10e52e59e7d3dc79fa342e8fdb
|
F src/alter.c ba266a779bc7ce10e52e59e7d3dc79fa342e8fdb
|
||||||
F src/analyze.c afbcca663c3f3625340b8e30d440cd7a97ded6bc
|
F src/analyze.c afbcca663c3f3625340b8e30d440cd7a97ded6bc
|
||||||
F src/attach.c f4e94df2d1826feda65eb0939f7f6f5f923a0ad9
|
F src/attach.c f4e94df2d1826feda65eb0939f7f6f5f923a0ad9
|
||||||
F src/auth.c d8abcde53426275dab6243b441256fcd8ccbebb2
|
F src/auth.c b56c78ebe40a2110fd361379f7e8162d23f92240
|
||||||
F src/backup.c a31809c65623cc41849b94d368917f8bb66e6a7e
|
F src/backup.c 7f841396adfd47507ff670a471162d2bfcda3136
|
||||||
F src/bitvec.c 19a4ba637bd85f8f63fc8c9bae5ade9fb05ec1cb
|
F src/bitvec.c 19a4ba637bd85f8f63fc8c9bae5ade9fb05ec1cb
|
||||||
F src/btmutex.c 49ca66250c7dfa844a4d4cb8272b87420d27d3a5
|
F src/btmutex.c 49ca66250c7dfa844a4d4cb8272b87420d27d3a5
|
||||||
F src/btree.c 1b1123cba0c65caa0baa51e71b8c089e3167c3ed
|
F src/btree.c 1b1123cba0c65caa0baa51e71b8c089e3167c3ed
|
||||||
F src/btree.h a79aa6a71e7f1055f01052b7f821bd1c2dce95c8
|
F src/btree.h a79aa6a71e7f1055f01052b7f821bd1c2dce95c8
|
||||||
F src/btreeInt.h 026d0129724e8f265fdc60d44ec240cf5a4e6179
|
F src/btreeInt.h 026d0129724e8f265fdc60d44ec240cf5a4e6179
|
||||||
F src/build.c 9dc2bd94347b878c89627000c92b0c8d97ec2919
|
F src/build.c 67bb05b1077e0cdaccb2e36bfcbe7a5df9ed31e8
|
||||||
F src/callback.c 7b44ce59674338ad48b0e84e7b72f935ea4f68b0
|
F src/callback.c 7b44ce59674338ad48b0e84e7b72f935ea4f68b0
|
||||||
F src/complete.c 535183afb3c75628b78ce82612931ac7cdf26f14
|
F src/complete.c c4ba6e0626bb94bc77a0861735f3382fcf7cc818
|
||||||
F src/ctime.c bb434068b5308a857b181c2d204a320ff0d6c638
|
F src/ctime.c dfa83bfebb4201d07b16534acb8a0149592c3a25
|
||||||
F src/date.c 57a7f9ba9f6b4d5268f5e411739066a611f99036
|
F src/date.c 57a7f9ba9f6b4d5268f5e411739066a611f99036
|
||||||
F src/delete.c fae81cc2eb14b75267d4f47d3cfc9ae02aae726f
|
F src/delete.c fae81cc2eb14b75267d4f47d3cfc9ae02aae726f
|
||||||
F src/expr.c fc204d08af06437ddaffe5a1b1f1f6f9e1a55d6d
|
F src/expr.c fc204d08af06437ddaffe5a1b1f1f6f9e1a55d6d
|
||||||
@@ -194,8 +194,8 @@ F src/journal.c b4124532212b6952f42eb2c12fa3c25701d8ba8d
|
|||||||
F src/legacy.c ba1863ea58c4c840335a84ec276fc2b25e22bc4e
|
F src/legacy.c ba1863ea58c4c840335a84ec276fc2b25e22bc4e
|
||||||
F src/lempar.c 7274c97d24bb46631e504332ccd3bd1b37841770
|
F src/lempar.c 7274c97d24bb46631e504332ccd3bd1b37841770
|
||||||
F src/loadext.c de741e66e5ddc1598d904d7289239696e40ed994
|
F src/loadext.c de741e66e5ddc1598d904d7289239696e40ed994
|
||||||
F src/main.c 8207ece1b4005b1efab55d1505d8ffb45bfced05
|
F src/main.c 2b882f64580ea72e2d972a5296f9eaa75a353161
|
||||||
F src/malloc.c 3c3ac67969612493d435e14b6832793209afd2ec
|
F src/malloc.c 5e02eab3e70cfcc265817f4de008f55e768dca51
|
||||||
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
||||||
F src/mem1.c faf615aafd8be74a71494dfa027c113ea5c6615f
|
F src/mem1.c faf615aafd8be74a71494dfa027c113ea5c6615f
|
||||||
F src/mem2.c f1940d9e91948dd6a908fbb9ce3835c36b5d83c3
|
F src/mem2.c f1940d9e91948dd6a908fbb9ce3835c36b5d83c3
|
||||||
@@ -205,10 +205,10 @@ F src/memjournal.c 3eb2c0b51adbd869cb6a44780323f05fa904dc85
|
|||||||
F src/mutex.c 84a073c9a23a8d7bdd2ea832522d1730df18812c
|
F src/mutex.c 84a073c9a23a8d7bdd2ea832522d1730df18812c
|
||||||
F src/mutex.h 779d588e3b7756ec3ecf7d78cde1d84aba414f85
|
F src/mutex.h 779d588e3b7756ec3ecf7d78cde1d84aba414f85
|
||||||
F src/mutex_noop.c f3f09fd7a2eb4287cfc799753ffc30380e7b71a1
|
F src/mutex_noop.c f3f09fd7a2eb4287cfc799753ffc30380e7b71a1
|
||||||
F src/mutex_unix.c 1b10d5413dfc794364a8adf3eb3a192926b43fa3
|
F src/mutex_unix.c 551e2f25f0fa0ee8fd7a43f50fc3d8be00e95dde
|
||||||
F src/mutex_w32.c 06bfff9a3a83b53389a51a967643db3967032e1e
|
F src/mutex_w32.c 06bfff9a3a83b53389a51a967643db3967032e1e
|
||||||
F src/notify.c 9711a7575036f0d3040ba61bc6e217f13a9888e7
|
F src/notify.c 9711a7575036f0d3040ba61bc6e217f13a9888e7
|
||||||
F src/os.c 1b147e4cf7cc39e618115c14a086aed44bc91ace
|
F src/os.c 8fd25588eeba74068d41102d26810e216999b6c8
|
||||||
F src/os.h 3e57a24e2794a94d3cf2342c6d9a884888cd96bf
|
F src/os.h 3e57a24e2794a94d3cf2342c6d9a884888cd96bf
|
||||||
F src/os_common.h 92815ed65f805560b66166e3583470ff94478f04
|
F src/os_common.h 92815ed65f805560b66166e3583470ff94478f04
|
||||||
F src/os_setup.h c9d4553b5aaa6f73391448b265b89bed0b890faa
|
F src/os_setup.h c9d4553b5aaa6f73391448b265b89bed0b890faa
|
||||||
@@ -222,9 +222,9 @@ F src/pcache.c 4121a0571c18581ee9f82f086d5e2030051ebd6a
|
|||||||
F src/pcache.h 9b559127b83f84ff76d735c8262f04853be0c59a
|
F src/pcache.h 9b559127b83f84ff76d735c8262f04853be0c59a
|
||||||
F src/pcache1.c e412cb585f777c840ddce0500eddc5c6043c2bb5
|
F src/pcache1.c e412cb585f777c840ddce0500eddc5c6043c2bb5
|
||||||
F src/pragma.c 3f3e959390a10c0131676f0e307acce372777e0f
|
F src/pragma.c 3f3e959390a10c0131676f0e307acce372777e0f
|
||||||
F src/prepare.c 6ef0cf2f9274982988ed6b7cab1be23147e94196
|
F src/prepare.c b7b7bf020bd4c962f7c8aed5a3c542c7dfe9f9c7
|
||||||
F src/printf.c 090fac0f779c93c8a95089a125339686648835e4
|
F src/printf.c c31012ac23e458081df4a32634b60424e0cdfaf3
|
||||||
F src/random.c d10c1f85b6709ca97278428fd5db5bbb9c74eece
|
F src/random.c 689c95a50b90e7a8b3e6088e33d1d2d4212e6e88
|
||||||
F src/resolve.c a3466128b52a86c466e47ac1a19e2174f7b5cf89
|
F src/resolve.c a3466128b52a86c466e47ac1a19e2174f7b5cf89
|
||||||
F src/rowset.c eccf6af6d620aaa4579bd3b72c1b6395d9e9fa1e
|
F src/rowset.c eccf6af6d620aaa4579bd3b72c1b6395d9e9fa1e
|
||||||
F src/select.c 428165951748151e87a15295b7357221433e311b
|
F src/select.c 428165951748151e87a15295b7357221433e311b
|
||||||
@@ -234,8 +234,8 @@ F src/sqlite3.rc 992c9f5fb8285ae285d6be28240a7e8d3a7f2bad
|
|||||||
F src/sqlite3ext.h 17d487c3c91b0b8c584a32fbeb393f6f795eea7d
|
F src/sqlite3ext.h 17d487c3c91b0b8c584a32fbeb393f6f795eea7d
|
||||||
F src/sqliteInt.h 6e9e125698c1e5c78a51050ea61f179a281c766d
|
F src/sqliteInt.h 6e9e125698c1e5c78a51050ea61f179a281c766d
|
||||||
F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d
|
F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d
|
||||||
F src/status.c 961d5926e5a8fda611d385ec22c226b8635cd1cb
|
F src/status.c 81712116e826b0089bb221b018929536b2b5406f
|
||||||
F src/table.c 2e99ef7ef16187e17033d9398dc962ce22dab5cb
|
F src/table.c f142bba7903e93ca8d113a5b8877a108ad1a27dc
|
||||||
F src/tclsqlite.c c67d310c833046cccc192125d64ad422ab882684
|
F src/tclsqlite.c c67d310c833046cccc192125d64ad422ab882684
|
||||||
F src/test1.c 63d4b1707c4052cf9c05c1cbb4a62666d70a0b48
|
F src/test1.c 63d4b1707c4052cf9c05c1cbb4a62666d70a0b48
|
||||||
F src/test2.c 98049e51a17dc62606a99a9eb95ee477f9996712
|
F src/test2.c 98049e51a17dc62606a99a9eb95ee477f9996712
|
||||||
@@ -287,18 +287,18 @@ F src/tokenize.c cc9016e5007fc5e76789079616d2f26741bcc689
|
|||||||
F src/trigger.c 25571661fdeae8c7f975ff40ffec205520a3f92f
|
F src/trigger.c 25571661fdeae8c7f975ff40ffec205520a3f92f
|
||||||
F src/update.c 729f6f18fc27740591d085e1172cebe311144bf0
|
F src/update.c 729f6f18fc27740591d085e1172cebe311144bf0
|
||||||
F src/utf.c fc6b889ba0779b7722634cdeaa25f1930d93820c
|
F src/utf.c fc6b889ba0779b7722634cdeaa25f1930d93820c
|
||||||
F src/util.c 4006c01772bd8d8ac4306d523bbcee41d3e392d8
|
F src/util.c 3b627daa45c7308c1e36e3dbaa3f9ce7e5c7fa73
|
||||||
F src/vacuum.c 59f03f92bcff57faa6a8ca256eb29ccddfb0614a
|
F src/vacuum.c 59f03f92bcff57faa6a8ca256eb29ccddfb0614a
|
||||||
F src/vdbe.c 5ee15a66ce07e0482b92aa29e4dd0c5827a22d79
|
F src/vdbe.c 5ee15a66ce07e0482b92aa29e4dd0c5827a22d79
|
||||||
F src/vdbe.h 09f5b4e3719fa454f252322b1cdab5cf1f361327
|
F src/vdbe.h 09f5b4e3719fa454f252322b1cdab5cf1f361327
|
||||||
F src/vdbeInt.h e2a060a55ee18a6ab973353a5e2ec7ee569bf787
|
F src/vdbeInt.h e2a060a55ee18a6ab973353a5e2ec7ee569bf787
|
||||||
F src/vdbeapi.c 37a6c6ae284a97bcace365f2f0a225680c0499d9
|
F src/vdbeapi.c 02d8afcff710eb35e3d9e49cb677308296b00009
|
||||||
F src/vdbeaux.c edbb7a9c8b2a8f7a68ac75c2475edd4040266b76
|
F src/vdbeaux.c edbb7a9c8b2a8f7a68ac75c2475edd4040266b76
|
||||||
F src/vdbeblob.c 848238dc73e93e48432991bb5651bf87d865eca4
|
F src/vdbeblob.c 8b5442ff0954c44b45cbabbe2e94091a2e16fdef
|
||||||
F src/vdbemem.c 31d8eabb0cd78bfeab4e5124c7363c3e9e54db9f
|
F src/vdbemem.c 31d8eabb0cd78bfeab4e5124c7363c3e9e54db9f
|
||||||
F src/vdbesort.c 975aeffa99acb0991b2f288d30294756bff41438
|
F src/vdbesort.c 975aeffa99acb0991b2f288d30294756bff41438
|
||||||
F src/vdbetrace.c 7e4222955e07dd707a2f360c0eb73452be1cb010
|
F src/vdbetrace.c 7e4222955e07dd707a2f360c0eb73452be1cb010
|
||||||
F src/vtab.c cb0c194303fea276b48d7d4b6d970b5a96bde8de
|
F src/vtab.c 2a30791bbd7926b589401bd09c3abb33de563793
|
||||||
F src/wal.c 10e7de7ce90865a68153f001a61f1d985cd17983
|
F src/wal.c 10e7de7ce90865a68153f001a61f1d985cd17983
|
||||||
F src/wal.h df01efe09c5cb8c8e391ff1715cca294f89668a4
|
F src/wal.h df01efe09c5cb8c8e391ff1715cca294f89668a4
|
||||||
F src/walker.c c253b95b4ee44b21c406e2a1052636c31ea27804
|
F src/walker.c c253b95b4ee44b21c406e2a1052636c31ea27804
|
||||||
@@ -1205,7 +1205,10 @@ F tool/vdbe_profile.tcl 67746953071a9f8f2f668b73fe899074e2c6d8c1
|
|||||||
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
|
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
|
||||||
F tool/warnings.sh 0abfd78ceb09b7f7c27c688c8e3fe93268a13b32
|
F tool/warnings.sh 0abfd78ceb09b7f7c27c688c8e3fe93268a13b32
|
||||||
F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f
|
F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f
|
||||||
P e580470db77d6da970c755102790e603fb26b3c6
|
P 9762ad0639cca2fc1ef0573113fb613ce9e7e83e
|
||||||
R f159389d59e4350424d5f438676d787b
|
R 98ebc598759882f163c17892cc0d9e3e
|
||||||
|
T *branch * api-armor
|
||||||
|
T *sym-api-armor *
|
||||||
|
T -sym-trunk *
|
||||||
U drh
|
U drh
|
||||||
Z 177632e852e703fce9e831bfbe27f418
|
Z 48418cab28475295c0204ad2ebe00aca
|
||||||
|
@@ -1 +1 @@
|
|||||||
9762ad0639cca2fc1ef0573113fb613ce9e7e83e
|
c297a84bc678f81ffc0aa9139ab73f0ca87c1971
|
@@ -72,6 +72,9 @@ int sqlite3_set_authorizer(
|
|||||||
int (*xAuth)(void*,int,const char*,const char*,const char*,const char*),
|
int (*xAuth)(void*,int,const char*,const char*,const char*,const char*),
|
||||||
void *pArg
|
void *pArg
|
||||||
){
|
){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
db->xAuth = (sqlite3_xauth)xAuth;
|
db->xAuth = (sqlite3_xauth)xAuth;
|
||||||
db->pAuthArg = pArg;
|
db->pAuthArg = pArg;
|
||||||
|
22
src/backup.c
22
src/backup.c
@@ -138,6 +138,13 @@ sqlite3_backup *sqlite3_backup_init(
|
|||||||
){
|
){
|
||||||
sqlite3_backup *p; /* Value to return */
|
sqlite3_backup *p; /* Value to return */
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(pSrcDb)||!sqlite3SafetyCheckOk(pDestDb) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Lock the source database handle. The destination database
|
/* Lock the source database handle. The destination database
|
||||||
** handle is not locked in this routine, but it is locked in
|
** handle is not locked in this routine, but it is locked in
|
||||||
** sqlite3_backup_step(). The user is required to ensure that no
|
** sqlite3_backup_step(). The user is required to ensure that no
|
||||||
@@ -334,6 +341,9 @@ int sqlite3_backup_step(sqlite3_backup *p, int nPage){
|
|||||||
int pgszSrc = 0; /* Source page size */
|
int pgszSrc = 0; /* Source page size */
|
||||||
int pgszDest = 0; /* Destination page size */
|
int pgszDest = 0; /* Destination page size */
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( p==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(p->pSrcDb->mutex);
|
sqlite3_mutex_enter(p->pSrcDb->mutex);
|
||||||
sqlite3BtreeEnter(p->pSrc);
|
sqlite3BtreeEnter(p->pSrc);
|
||||||
if( p->pDestDb ){
|
if( p->pDestDb ){
|
||||||
@@ -623,6 +633,12 @@ int sqlite3_backup_finish(sqlite3_backup *p){
|
|||||||
** call to sqlite3_backup_step().
|
** call to sqlite3_backup_step().
|
||||||
*/
|
*/
|
||||||
int sqlite3_backup_remaining(sqlite3_backup *p){
|
int sqlite3_backup_remaining(sqlite3_backup *p){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( p==0 ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return p->nRemaining;
|
return p->nRemaining;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -631,6 +647,12 @@ int sqlite3_backup_remaining(sqlite3_backup *p){
|
|||||||
** recent call to sqlite3_backup_step().
|
** recent call to sqlite3_backup_step().
|
||||||
*/
|
*/
|
||||||
int sqlite3_backup_pagecount(sqlite3_backup *p){
|
int sqlite3_backup_pagecount(sqlite3_backup *p){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( p==0 ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return p->nPagecount;
|
return p->nPagecount;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -307,7 +307,11 @@ int sqlite3UserAuthTable(const char *zTable){
|
|||||||
Table *sqlite3FindTable(sqlite3 *db, const char *zName, const char *zDatabase){
|
Table *sqlite3FindTable(sqlite3 *db, const char *zName, const char *zDatabase){
|
||||||
Table *p = 0;
|
Table *p = 0;
|
||||||
int i;
|
int i;
|
||||||
assert( zName!=0 );
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || zName==0 ) return 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* All mutexes are required for schema access. Make sure we hold them. */
|
/* All mutexes are required for schema access. Make sure we hold them. */
|
||||||
assert( zDatabase!=0 || sqlite3BtreeHoldsAllMutexes(db) );
|
assert( zDatabase!=0 || sqlite3BtreeHoldsAllMutexes(db) );
|
||||||
#if SQLITE_USER_AUTHENTICATION
|
#if SQLITE_USER_AUTHENTICATION
|
||||||
|
@@ -105,6 +105,13 @@ int sqlite3_complete(const char *zSql){
|
|||||||
u8 state = 0; /* Current state, using numbers defined in header comment */
|
u8 state = 0; /* Current state, using numbers defined in header comment */
|
||||||
u8 token; /* Value of the next token */
|
u8 token; /* Value of the next token */
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( zSql==0 ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef SQLITE_OMIT_TRIGGER
|
#ifndef SQLITE_OMIT_TRIGGER
|
||||||
/* A complex statement machine used to detect the end of a CREATE TRIGGER
|
/* A complex statement machine used to detect the end of a CREATE TRIGGER
|
||||||
** statement. This is the normal case.
|
** statement. This is the normal case.
|
||||||
|
10
src/ctime.c
10
src/ctime.c
@@ -63,6 +63,9 @@ static const char * const azCompileOpt[] = {
|
|||||||
#ifdef SQLITE_DISABLE_LFS
|
#ifdef SQLITE_DISABLE_LFS
|
||||||
"DISABLE_LFS",
|
"DISABLE_LFS",
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
"ENABLE_API_ARMOR",
|
||||||
|
#endif
|
||||||
#ifdef SQLITE_ENABLE_ATOMIC_WRITE
|
#ifdef SQLITE_ENABLE_ATOMIC_WRITE
|
||||||
"ENABLE_ATOMIC_WRITE",
|
"ENABLE_ATOMIC_WRITE",
|
||||||
#endif
|
#endif
|
||||||
@@ -388,6 +391,13 @@ static const char * const azCompileOpt[] = {
|
|||||||
*/
|
*/
|
||||||
int sqlite3_compileoption_used(const char *zOptName){
|
int sqlite3_compileoption_used(const char *zOptName){
|
||||||
int i, n;
|
int i, n;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMORE
|
||||||
|
if( zOptName==0 ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
if( sqlite3StrNICmp(zOptName, "SQLITE_", 7)==0 ) zOptName += 7;
|
if( sqlite3StrNICmp(zOptName, "SQLITE_", 7)==0 ) zOptName += 7;
|
||||||
n = sqlite3Strlen30(zOptName);
|
n = sqlite3Strlen30(zOptName);
|
||||||
|
|
||||||
|
165
src/main.c
165
src/main.c
@@ -598,6 +598,12 @@ static int setupLookaside(sqlite3 *db, void *pBuf, int sz, int cnt){
|
|||||||
** Return the mutex associated with a database connection.
|
** Return the mutex associated with a database connection.
|
||||||
*/
|
*/
|
||||||
sqlite3_mutex *sqlite3_db_mutex(sqlite3 *db){
|
sqlite3_mutex *sqlite3_db_mutex(sqlite3 *db){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return db->mutex;
|
return db->mutex;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -607,6 +613,10 @@ sqlite3_mutex *sqlite3_db_mutex(sqlite3 *db){
|
|||||||
*/
|
*/
|
||||||
int sqlite3_db_release_memory(sqlite3 *db){
|
int sqlite3_db_release_memory(sqlite3 *db){
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
sqlite3BtreeEnterAll(db);
|
sqlite3BtreeEnterAll(db);
|
||||||
for(i=0; i<db->nDb; i++){
|
for(i=0; i<db->nDb; i++){
|
||||||
@@ -737,6 +747,12 @@ static int nocaseCollatingFunc(
|
|||||||
** Return the ROWID of the most recent insert
|
** Return the ROWID of the most recent insert
|
||||||
*/
|
*/
|
||||||
sqlite_int64 sqlite3_last_insert_rowid(sqlite3 *db){
|
sqlite_int64 sqlite3_last_insert_rowid(sqlite3 *db){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return db->lastRowid;
|
return db->lastRowid;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -744,6 +760,12 @@ sqlite_int64 sqlite3_last_insert_rowid(sqlite3 *db){
|
|||||||
** Return the number of changes in the most recent call to sqlite3_exec().
|
** Return the number of changes in the most recent call to sqlite3_exec().
|
||||||
*/
|
*/
|
||||||
int sqlite3_changes(sqlite3 *db){
|
int sqlite3_changes(sqlite3 *db){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return db->nChange;
|
return db->nChange;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -751,6 +773,12 @@ int sqlite3_changes(sqlite3 *db){
|
|||||||
** Return the number of changes since the database handle was opened.
|
** Return the number of changes since the database handle was opened.
|
||||||
*/
|
*/
|
||||||
int sqlite3_total_changes(sqlite3 *db){
|
int sqlite3_total_changes(sqlite3 *db){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return db->nTotalChange;
|
return db->nTotalChange;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1296,6 +1324,9 @@ int sqlite3_busy_handler(
|
|||||||
int (*xBusy)(void*,int),
|
int (*xBusy)(void*,int),
|
||||||
void *pArg
|
void *pArg
|
||||||
){
|
){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
db->busyHandler.xFunc = xBusy;
|
db->busyHandler.xFunc = xBusy;
|
||||||
db->busyHandler.pArg = pArg;
|
db->busyHandler.pArg = pArg;
|
||||||
@@ -1317,6 +1348,12 @@ void sqlite3_progress_handler(
|
|||||||
int (*xProgress)(void*),
|
int (*xProgress)(void*),
|
||||||
void *pArg
|
void *pArg
|
||||||
){
|
){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
if( nOps>0 ){
|
if( nOps>0 ){
|
||||||
db->xProgress = xProgress;
|
db->xProgress = xProgress;
|
||||||
@@ -1337,6 +1374,9 @@ void sqlite3_progress_handler(
|
|||||||
** specified number of milliseconds before returning 0.
|
** specified number of milliseconds before returning 0.
|
||||||
*/
|
*/
|
||||||
int sqlite3_busy_timeout(sqlite3 *db, int ms){
|
int sqlite3_busy_timeout(sqlite3 *db, int ms){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
if( ms>0 ){
|
if( ms>0 ){
|
||||||
sqlite3_busy_handler(db, sqliteDefaultBusyCallback, (void*)db);
|
sqlite3_busy_handler(db, sqliteDefaultBusyCallback, (void*)db);
|
||||||
db->busyTimeout = ms;
|
db->busyTimeout = ms;
|
||||||
@@ -1350,6 +1390,12 @@ int sqlite3_busy_timeout(sqlite3 *db, int ms){
|
|||||||
** Cause any pending operation to stop at its earliest opportunity.
|
** Cause any pending operation to stop at its earliest opportunity.
|
||||||
*/
|
*/
|
||||||
void sqlite3_interrupt(sqlite3 *db){
|
void sqlite3_interrupt(sqlite3 *db){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
db->u1.isInterrupted = 1;
|
db->u1.isInterrupted = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1487,6 +1533,12 @@ int sqlite3_create_function_v2(
|
|||||||
){
|
){
|
||||||
int rc = SQLITE_ERROR;
|
int rc = SQLITE_ERROR;
|
||||||
FuncDestructor *pArg = 0;
|
FuncDestructor *pArg = 0;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
return SQLITE_MISUSE_BKPT;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
if( xDestroy ){
|
if( xDestroy ){
|
||||||
pArg = (FuncDestructor *)sqlite3DbMallocZero(db, sizeof(FuncDestructor));
|
pArg = (FuncDestructor *)sqlite3DbMallocZero(db, sizeof(FuncDestructor));
|
||||||
@@ -1523,6 +1575,10 @@ int sqlite3_create_function16(
|
|||||||
){
|
){
|
||||||
int rc;
|
int rc;
|
||||||
char *zFunc8;
|
char *zFunc8;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || zFunctionName==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
assert( !db->mallocFailed );
|
assert( !db->mallocFailed );
|
||||||
zFunc8 = sqlite3Utf16to8(db, zFunctionName, -1, SQLITE_UTF16NATIVE);
|
zFunc8 = sqlite3Utf16to8(db, zFunctionName, -1, SQLITE_UTF16NATIVE);
|
||||||
@@ -1554,6 +1610,12 @@ int sqlite3_overload_function(
|
|||||||
){
|
){
|
||||||
int nName = sqlite3Strlen30(zName);
|
int nName = sqlite3Strlen30(zName);
|
||||||
int rc = SQLITE_OK;
|
int rc = SQLITE_OK;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || zName==0 || nArg<-2 ){
|
||||||
|
return SQLITE_MISUSE_BKPT;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
if( sqlite3FindFunction(db, zName, nName, nArg, SQLITE_UTF8, 0)==0 ){
|
if( sqlite3FindFunction(db, zName, nName, nArg, SQLITE_UTF8, 0)==0 ){
|
||||||
rc = sqlite3CreateFunc(db, zName, nArg, SQLITE_UTF8,
|
rc = sqlite3CreateFunc(db, zName, nArg, SQLITE_UTF8,
|
||||||
@@ -1575,6 +1637,13 @@ int sqlite3_overload_function(
|
|||||||
*/
|
*/
|
||||||
void *sqlite3_trace(sqlite3 *db, void (*xTrace)(void*,const char*), void *pArg){
|
void *sqlite3_trace(sqlite3 *db, void (*xTrace)(void*,const char*), void *pArg){
|
||||||
void *pOld;
|
void *pOld;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
pOld = db->pTraceArg;
|
pOld = db->pTraceArg;
|
||||||
db->xTrace = xTrace;
|
db->xTrace = xTrace;
|
||||||
@@ -1596,6 +1665,13 @@ void *sqlite3_profile(
|
|||||||
void *pArg
|
void *pArg
|
||||||
){
|
){
|
||||||
void *pOld;
|
void *pOld;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
pOld = db->pProfileArg;
|
pOld = db->pProfileArg;
|
||||||
db->xProfile = xProfile;
|
db->xProfile = xProfile;
|
||||||
@@ -1616,6 +1692,13 @@ void *sqlite3_commit_hook(
|
|||||||
void *pArg /* Argument to the function */
|
void *pArg /* Argument to the function */
|
||||||
){
|
){
|
||||||
void *pOld;
|
void *pOld;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
pOld = db->pCommitArg;
|
pOld = db->pCommitArg;
|
||||||
db->xCommitCallback = xCallback;
|
db->xCommitCallback = xCallback;
|
||||||
@@ -1634,6 +1717,13 @@ void *sqlite3_update_hook(
|
|||||||
void *pArg /* Argument to the function */
|
void *pArg /* Argument to the function */
|
||||||
){
|
){
|
||||||
void *pRet;
|
void *pRet;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
pRet = db->pUpdateArg;
|
pRet = db->pUpdateArg;
|
||||||
db->xUpdateCallback = xCallback;
|
db->xUpdateCallback = xCallback;
|
||||||
@@ -1652,6 +1742,13 @@ void *sqlite3_rollback_hook(
|
|||||||
void *pArg /* Argument to the function */
|
void *pArg /* Argument to the function */
|
||||||
){
|
){
|
||||||
void *pRet;
|
void *pRet;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
pRet = db->pRollbackArg;
|
pRet = db->pRollbackArg;
|
||||||
db->xRollbackCallback = xCallback;
|
db->xRollbackCallback = xCallback;
|
||||||
@@ -1698,6 +1795,9 @@ int sqlite3_wal_autocheckpoint(sqlite3 *db, int nFrame){
|
|||||||
UNUSED_PARAMETER(db);
|
UNUSED_PARAMETER(db);
|
||||||
UNUSED_PARAMETER(nFrame);
|
UNUSED_PARAMETER(nFrame);
|
||||||
#else
|
#else
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
if( nFrame>0 ){
|
if( nFrame>0 ){
|
||||||
sqlite3_wal_hook(db, sqlite3WalDefaultHook, SQLITE_INT_TO_PTR(nFrame));
|
sqlite3_wal_hook(db, sqlite3WalDefaultHook, SQLITE_INT_TO_PTR(nFrame));
|
||||||
}else{
|
}else{
|
||||||
@@ -1718,6 +1818,12 @@ void *sqlite3_wal_hook(
|
|||||||
){
|
){
|
||||||
#ifndef SQLITE_OMIT_WAL
|
#ifndef SQLITE_OMIT_WAL
|
||||||
void *pRet;
|
void *pRet;
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
pRet = db->pWalArg;
|
pRet = db->pWalArg;
|
||||||
db->xWalCallback = xCallback;
|
db->xWalCallback = xCallback;
|
||||||
@@ -1745,6 +1851,10 @@ int sqlite3_wal_checkpoint_v2(
|
|||||||
int rc; /* Return code */
|
int rc; /* Return code */
|
||||||
int iDb = SQLITE_MAX_ATTACHED; /* sqlite3.aDb[] index of db to checkpoint */
|
int iDb = SQLITE_MAX_ATTACHED; /* sqlite3.aDb[] index of db to checkpoint */
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Initialize the output variables to -1 in case an error occurs. */
|
/* Initialize the output variables to -1 in case an error occurs. */
|
||||||
if( pnLog ) *pnLog = -1;
|
if( pnLog ) *pnLog = -1;
|
||||||
if( pnCkpt ) *pnCkpt = -1;
|
if( pnCkpt ) *pnCkpt = -1;
|
||||||
@@ -2141,6 +2251,12 @@ static const int aHardLimit[] = {
|
|||||||
int sqlite3_limit(sqlite3 *db, int limitId, int newLimit){
|
int sqlite3_limit(sqlite3 *db, int limitId, int newLimit){
|
||||||
int oldLimit;
|
int oldLimit;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* EVIDENCE-OF: R-30189-54097 For each limit category SQLITE_LIMIT_NAME
|
/* EVIDENCE-OF: R-30189-54097 For each limit category SQLITE_LIMIT_NAME
|
||||||
** there is a hard upper bound set at compile-time by a C preprocessor
|
** there is a hard upper bound set at compile-time by a C preprocessor
|
||||||
@@ -2426,6 +2542,9 @@ static int openDatabase(
|
|||||||
char *zOpen = 0; /* Filename argument to pass to BtreeOpen() */
|
char *zOpen = 0; /* Filename argument to pass to BtreeOpen() */
|
||||||
char *zErrMsg = 0; /* Error message from sqlite3ParseUri() */
|
char *zErrMsg = 0; /* Error message from sqlite3ParseUri() */
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( ppDb==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
*ppDb = 0;
|
*ppDb = 0;
|
||||||
#ifndef SQLITE_OMIT_AUTOINIT
|
#ifndef SQLITE_OMIT_AUTOINIT
|
||||||
rc = sqlite3_initialize();
|
rc = sqlite3_initialize();
|
||||||
@@ -2715,13 +2834,15 @@ int sqlite3_open16(
|
|||||||
sqlite3_value *pVal;
|
sqlite3_value *pVal;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
assert( zFilename );
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
assert( ppDb );
|
if( ppDb==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
*ppDb = 0;
|
*ppDb = 0;
|
||||||
#ifndef SQLITE_OMIT_AUTOINIT
|
#ifndef SQLITE_OMIT_AUTOINIT
|
||||||
rc = sqlite3_initialize();
|
rc = sqlite3_initialize();
|
||||||
if( rc ) return rc;
|
if( rc ) return rc;
|
||||||
#endif
|
#endif
|
||||||
|
if( zFilename==0 ) zFilename = "\000\000";
|
||||||
pVal = sqlite3ValueNew(0);
|
pVal = sqlite3ValueNew(0);
|
||||||
sqlite3ValueSetStr(pVal, -1, zFilename, SQLITE_UTF16NATIVE, SQLITE_STATIC);
|
sqlite3ValueSetStr(pVal, -1, zFilename, SQLITE_UTF16NATIVE, SQLITE_STATIC);
|
||||||
zFilename8 = sqlite3ValueText(pVal, SQLITE_UTF8);
|
zFilename8 = sqlite3ValueText(pVal, SQLITE_UTF8);
|
||||||
@@ -2766,6 +2887,10 @@ int sqlite3_create_collation_v2(
|
|||||||
void(*xDel)(void*)
|
void(*xDel)(void*)
|
||||||
){
|
){
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || zName==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
assert( !db->mallocFailed );
|
assert( !db->mallocFailed );
|
||||||
rc = createCollation(db, zName, (u8)enc, pCtx, xCompare, xDel);
|
rc = createCollation(db, zName, (u8)enc, pCtx, xCompare, xDel);
|
||||||
@@ -2787,6 +2912,10 @@ int sqlite3_create_collation16(
|
|||||||
){
|
){
|
||||||
int rc = SQLITE_OK;
|
int rc = SQLITE_OK;
|
||||||
char *zName8;
|
char *zName8;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || zName==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
assert( !db->mallocFailed );
|
assert( !db->mallocFailed );
|
||||||
zName8 = sqlite3Utf16to8(db, zName, -1, SQLITE_UTF16NATIVE);
|
zName8 = sqlite3Utf16to8(db, zName, -1, SQLITE_UTF16NATIVE);
|
||||||
@@ -2809,6 +2938,9 @@ int sqlite3_collation_needed(
|
|||||||
void *pCollNeededArg,
|
void *pCollNeededArg,
|
||||||
void(*xCollNeeded)(void*,sqlite3*,int eTextRep,const char*)
|
void(*xCollNeeded)(void*,sqlite3*,int eTextRep,const char*)
|
||||||
){
|
){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
db->xCollNeeded = xCollNeeded;
|
db->xCollNeeded = xCollNeeded;
|
||||||
db->xCollNeeded16 = 0;
|
db->xCollNeeded16 = 0;
|
||||||
@@ -2827,6 +2959,9 @@ int sqlite3_collation_needed16(
|
|||||||
void *pCollNeededArg,
|
void *pCollNeededArg,
|
||||||
void(*xCollNeeded16)(void*,sqlite3*,int eTextRep,const void*)
|
void(*xCollNeeded16)(void*,sqlite3*,int eTextRep,const void*)
|
||||||
){
|
){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
db->xCollNeeded = 0;
|
db->xCollNeeded = 0;
|
||||||
db->xCollNeeded16 = xCollNeeded16;
|
db->xCollNeeded16 = xCollNeeded16;
|
||||||
@@ -2853,6 +2988,12 @@ int sqlite3_global_recover(void){
|
|||||||
** by the next COMMIT or ROLLBACK.
|
** by the next COMMIT or ROLLBACK.
|
||||||
*/
|
*/
|
||||||
int sqlite3_get_autocommit(sqlite3 *db){
|
int sqlite3_get_autocommit(sqlite3 *db){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return db->autoCommit;
|
return db->autoCommit;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3035,6 +3176,9 @@ int sqlite3_sleep(int ms){
|
|||||||
** Enable or disable the extended result codes.
|
** Enable or disable the extended result codes.
|
||||||
*/
|
*/
|
||||||
int sqlite3_extended_result_codes(sqlite3 *db, int onoff){
|
int sqlite3_extended_result_codes(sqlite3 *db, int onoff){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
db->errMask = onoff ? 0xffffffff : 0xff;
|
db->errMask = onoff ? 0xffffffff : 0xff;
|
||||||
sqlite3_mutex_leave(db->mutex);
|
sqlite3_mutex_leave(db->mutex);
|
||||||
@@ -3048,6 +3192,9 @@ int sqlite3_file_control(sqlite3 *db, const char *zDbName, int op, void *pArg){
|
|||||||
int rc = SQLITE_ERROR;
|
int rc = SQLITE_ERROR;
|
||||||
Btree *pBtree;
|
Btree *pBtree;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
pBtree = sqlite3DbNameToBtree(db, zDbName);
|
pBtree = sqlite3DbNameToBtree(db, zDbName);
|
||||||
if( pBtree ){
|
if( pBtree ){
|
||||||
@@ -3390,7 +3537,7 @@ int sqlite3_test_control(int op, ...){
|
|||||||
** returns a NULL pointer.
|
** returns a NULL pointer.
|
||||||
*/
|
*/
|
||||||
const char *sqlite3_uri_parameter(const char *zFilename, const char *zParam){
|
const char *sqlite3_uri_parameter(const char *zFilename, const char *zParam){
|
||||||
if( zFilename==0 ) return 0;
|
if( zFilename==0 || zParam==0 ) return 0;
|
||||||
zFilename += sqlite3Strlen30(zFilename) + 1;
|
zFilename += sqlite3Strlen30(zFilename) + 1;
|
||||||
while( zFilename[0] ){
|
while( zFilename[0] ){
|
||||||
int x = strcmp(zFilename, zParam);
|
int x = strcmp(zFilename, zParam);
|
||||||
@@ -3446,6 +3593,12 @@ Btree *sqlite3DbNameToBtree(sqlite3 *db, const char *zDbName){
|
|||||||
** connection.
|
** connection.
|
||||||
*/
|
*/
|
||||||
const char *sqlite3_db_filename(sqlite3 *db, const char *zDbName){
|
const char *sqlite3_db_filename(sqlite3 *db, const char *zDbName){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
Btree *pBt = sqlite3DbNameToBtree(db, zDbName);
|
Btree *pBt = sqlite3DbNameToBtree(db, zDbName);
|
||||||
return pBt ? sqlite3BtreeGetFilename(pBt) : 0;
|
return pBt ? sqlite3BtreeGetFilename(pBt) : 0;
|
||||||
}
|
}
|
||||||
@@ -3455,6 +3608,12 @@ const char *sqlite3_db_filename(sqlite3 *db, const char *zDbName){
|
|||||||
** no such database exists.
|
** no such database exists.
|
||||||
*/
|
*/
|
||||||
int sqlite3_db_readonly(sqlite3 *db, const char *zDbName){
|
int sqlite3_db_readonly(sqlite3 *db, const char *zDbName){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
Btree *pBt = sqlite3DbNameToBtree(db, zDbName);
|
Btree *pBt = sqlite3DbNameToBtree(db, zDbName);
|
||||||
return pBt ? sqlite3BtreeIsReadonly(pBt) : -1;
|
return pBt ? sqlite3BtreeIsReadonly(pBt) : -1;
|
||||||
}
|
}
|
||||||
|
@@ -475,6 +475,9 @@ sqlite3_uint64 sqlite3_msize(void *p){
|
|||||||
** Free memory previously obtained from sqlite3Malloc().
|
** Free memory previously obtained from sqlite3Malloc().
|
||||||
*/
|
*/
|
||||||
void sqlite3_free(void *p){
|
void sqlite3_free(void *p){
|
||||||
|
#if defined(SQLITE_ENABLE_API_ARMOR) && !defined(SQLITE_OMIT_AUTOINIT)
|
||||||
|
if( sqlite3_initialize() ) return;
|
||||||
|
#endif
|
||||||
if( p==0 ) return; /* IMP: R-49053-54554 */
|
if( p==0 ) return; /* IMP: R-49053-54554 */
|
||||||
assert( sqlite3MemdebugHasType(p, MEMTYPE_HEAP) );
|
assert( sqlite3MemdebugHasType(p, MEMTYPE_HEAP) );
|
||||||
assert( sqlite3MemdebugNoType(p, ~MEMTYPE_HEAP) );
|
assert( sqlite3MemdebugNoType(p, ~MEMTYPE_HEAP) );
|
||||||
|
@@ -175,8 +175,12 @@ static sqlite3_mutex *pthreadMutexAlloc(int iType){
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
assert( iType-2 >= 0 );
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
assert( iType-2 < ArraySize(staticMutexes) );
|
if( iType-2<0 || iType-2>=ArraySize(staticMutexes) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
p = &staticMutexes[iType-2];
|
p = &staticMutexes[iType-2];
|
||||||
#if SQLITE_MUTEX_NREF
|
#if SQLITE_MUTEX_NREF
|
||||||
p->id = iType;
|
p->id = iType;
|
||||||
|
4
src/os.c
4
src/os.c
@@ -361,6 +361,10 @@ int sqlite3_vfs_register(sqlite3_vfs *pVfs, int makeDflt){
|
|||||||
int rc = sqlite3_initialize();
|
int rc = sqlite3_initialize();
|
||||||
if( rc ) return rc;
|
if( rc ) return rc;
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( pVfs==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
|
|
||||||
MUTEX_LOGIC( mutex = sqlite3MutexAlloc(SQLITE_MUTEX_STATIC_MASTER); )
|
MUTEX_LOGIC( mutex = sqlite3MutexAlloc(SQLITE_MUTEX_STATIC_MASTER); )
|
||||||
sqlite3_mutex_enter(mutex);
|
sqlite3_mutex_enter(mutex);
|
||||||
vfsUnlink(pVfs);
|
vfsUnlink(pVfs);
|
||||||
|
@@ -709,9 +709,12 @@ static int sqlite3LockAndPrepare(
|
|||||||
const char **pzTail /* OUT: End of parsed string */
|
const char **pzTail /* OUT: End of parsed string */
|
||||||
){
|
){
|
||||||
int rc;
|
int rc;
|
||||||
assert( ppStmt!=0 );
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( ppStmt==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
*ppStmt = 0;
|
*ppStmt = 0;
|
||||||
if( !sqlite3SafetyCheckOk(db) ){
|
if( !sqlite3SafetyCheckOk(db)||zSql==0 ){
|
||||||
return SQLITE_MISUSE_BKPT;
|
return SQLITE_MISUSE_BKPT;
|
||||||
}
|
}
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
@@ -818,9 +821,11 @@ static int sqlite3Prepare16(
|
|||||||
const char *zTail8 = 0;
|
const char *zTail8 = 0;
|
||||||
int rc = SQLITE_OK;
|
int rc = SQLITE_OK;
|
||||||
|
|
||||||
assert( ppStmt );
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( ppStmt==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
*ppStmt = 0;
|
*ppStmt = 0;
|
||||||
if( !sqlite3SafetyCheckOk(db) ){
|
if( !sqlite3SafetyCheckOk(db)||zSql==0 ){
|
||||||
return SQLITE_MISUSE_BKPT;
|
return SQLITE_MISUSE_BKPT;
|
||||||
}
|
}
|
||||||
if( nBytes>=0 ){
|
if( nBytes>=0 ){
|
||||||
|
21
src/printf.c
21
src/printf.c
@@ -223,6 +223,13 @@ void sqlite3VXPrintf(
|
|||||||
PrintfArguments *pArgList = 0; /* Arguments for SQLITE_PRINTF_SQLFUNC */
|
PrintfArguments *pArgList = 0; /* Arguments for SQLITE_PRINTF_SQLFUNC */
|
||||||
char buf[etBUFSIZE]; /* Conversion buffer */
|
char buf[etBUFSIZE]; /* Conversion buffer */
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( ap==0 ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
sqlite3StrAccumReset(pAccum);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
bufpt = 0;
|
bufpt = 0;
|
||||||
if( bFlags ){
|
if( bFlags ){
|
||||||
if( (bArgList = (bFlags & SQLITE_PRINTF_SQLFUNC))!=0 ){
|
if( (bArgList = (bFlags & SQLITE_PRINTF_SQLFUNC))!=0 ){
|
||||||
@@ -943,6 +950,13 @@ char *sqlite3_vmprintf(const char *zFormat, va_list ap){
|
|||||||
char *z;
|
char *z;
|
||||||
char zBase[SQLITE_PRINT_BUF_SIZE];
|
char zBase[SQLITE_PRINT_BUF_SIZE];
|
||||||
StrAccum acc;
|
StrAccum acc;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( zFormat==0 ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
#ifndef SQLITE_OMIT_AUTOINIT
|
#ifndef SQLITE_OMIT_AUTOINIT
|
||||||
if( sqlite3_initialize() ) return 0;
|
if( sqlite3_initialize() ) return 0;
|
||||||
#endif
|
#endif
|
||||||
@@ -985,6 +999,13 @@ char *sqlite3_mprintf(const char *zFormat, ...){
|
|||||||
char *sqlite3_vsnprintf(int n, char *zBuf, const char *zFormat, va_list ap){
|
char *sqlite3_vsnprintf(int n, char *zBuf, const char *zFormat, va_list ap){
|
||||||
StrAccum acc;
|
StrAccum acc;
|
||||||
if( n<=0 ) return zBuf;
|
if( n<=0 ) return zBuf;
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( zBuf==0 || zFormat==0 ) {
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
if( zBuf && n>0 ) zBuf[0] = 0;
|
||||||
|
return zBuf;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3StrAccumInit(&acc, zBuf, n, 0);
|
sqlite3StrAccumInit(&acc, zBuf, n, 0);
|
||||||
acc.useMalloc = 0;
|
acc.useMalloc = 0;
|
||||||
sqlite3VXPrintf(&acc, 0, zFormat, ap);
|
sqlite3VXPrintf(&acc, 0, zFormat, ap);
|
||||||
|
11
src/random.c
11
src/random.c
@@ -34,6 +34,11 @@ void sqlite3_randomness(int N, void *pBuf){
|
|||||||
unsigned char t;
|
unsigned char t;
|
||||||
unsigned char *zBuf = pBuf;
|
unsigned char *zBuf = pBuf;
|
||||||
|
|
||||||
|
#ifndef SQLITE_OMIT_AUTOINIT
|
||||||
|
if( sqlite3_initialize() ) return;
|
||||||
|
#endif
|
||||||
|
if( pBuf==0 || N<=0 ) return;
|
||||||
|
|
||||||
/* The "wsdPrng" macro will resolve to the pseudo-random number generator
|
/* The "wsdPrng" macro will resolve to the pseudo-random number generator
|
||||||
** state vector. If writable static data is unsupported on the target,
|
** state vector. If writable static data is unsupported on the target,
|
||||||
** we have to locate the state vector at run-time. In the more common
|
** we have to locate the state vector at run-time. In the more common
|
||||||
@@ -52,12 +57,6 @@ void sqlite3_randomness(int N, void *pBuf){
|
|||||||
sqlite3_mutex_enter(mutex);
|
sqlite3_mutex_enter(mutex);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( N<=0 ){
|
|
||||||
wsdPrng.isInit = 0;
|
|
||||||
sqlite3_mutex_leave(mutex);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Initialize the state of the random number generator once,
|
/* Initialize the state of the random number generator once,
|
||||||
** the first time this routine is called. The seed value does
|
** the first time this routine is called. The seed value does
|
||||||
** not need to contain a lot of randomness since we are not
|
** not need to contain a lot of randomness since we are not
|
||||||
|
@@ -86,6 +86,9 @@ int sqlite3_status(int op, int *pCurrent, int *pHighwater, int resetFlag){
|
|||||||
if( op<0 || op>=ArraySize(wsdStat.nowValue) ){
|
if( op<0 || op>=ArraySize(wsdStat.nowValue) ){
|
||||||
return SQLITE_MISUSE_BKPT;
|
return SQLITE_MISUSE_BKPT;
|
||||||
}
|
}
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( pCurrent==0 || pHighwater==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
*pCurrent = wsdStat.nowValue[op];
|
*pCurrent = wsdStat.nowValue[op];
|
||||||
*pHighwater = wsdStat.mxValue[op];
|
*pHighwater = wsdStat.mxValue[op];
|
||||||
if( resetFlag ){
|
if( resetFlag ){
|
||||||
@@ -105,6 +108,11 @@ int sqlite3_db_status(
|
|||||||
int resetFlag /* Reset high-water mark if true */
|
int resetFlag /* Reset high-water mark if true */
|
||||||
){
|
){
|
||||||
int rc = SQLITE_OK; /* Return code */
|
int rc = SQLITE_OK; /* Return code */
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || pCurrent==0|| pHighwater==0 ){
|
||||||
|
return SQLITE_MISUSE_BKPT;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
switch( op ){
|
switch( op ){
|
||||||
case SQLITE_DBSTATUS_LOOKASIDE_USED: {
|
case SQLITE_DBSTATUS_LOOKASIDE_USED: {
|
||||||
|
@@ -126,6 +126,9 @@ int sqlite3_get_table(
|
|||||||
int rc;
|
int rc;
|
||||||
TabResult res;
|
TabResult res;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( pazResult==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
*pazResult = 0;
|
*pazResult = 0;
|
||||||
if( pnColumn ) *pnColumn = 0;
|
if( pnColumn ) *pnColumn = 0;
|
||||||
if( pnRow ) *pnRow = 0;
|
if( pnRow ) *pnRow = 0;
|
||||||
|
10
src/util.c
10
src/util.c
@@ -251,6 +251,11 @@ int sqlite3Dequote(char *z){
|
|||||||
*/
|
*/
|
||||||
int sqlite3_stricmp(const char *zLeft, const char *zRight){
|
int sqlite3_stricmp(const char *zLeft, const char *zRight){
|
||||||
register unsigned char *a, *b;
|
register unsigned char *a, *b;
|
||||||
|
if( zLeft==0 ){
|
||||||
|
return zRight ? -1 : 0;
|
||||||
|
}else if( zRight==0 ){
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
a = (unsigned char *)zLeft;
|
a = (unsigned char *)zLeft;
|
||||||
b = (unsigned char *)zRight;
|
b = (unsigned char *)zRight;
|
||||||
while( *a!=0 && UpperToLower[*a]==UpperToLower[*b]){ a++; b++; }
|
while( *a!=0 && UpperToLower[*a]==UpperToLower[*b]){ a++; b++; }
|
||||||
@@ -258,6 +263,11 @@ int sqlite3_stricmp(const char *zLeft, const char *zRight){
|
|||||||
}
|
}
|
||||||
int sqlite3_strnicmp(const char *zLeft, const char *zRight, int N){
|
int sqlite3_strnicmp(const char *zLeft, const char *zRight, int N){
|
||||||
register unsigned char *a, *b;
|
register unsigned char *a, *b;
|
||||||
|
if( zLeft==0 ){
|
||||||
|
return zRight ? -1 : 0;
|
||||||
|
}else if( zRight==0 ){
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
a = (unsigned char *)zLeft;
|
a = (unsigned char *)zLeft;
|
||||||
b = (unsigned char *)zRight;
|
b = (unsigned char *)zRight;
|
||||||
while( N-- > 0 && *a!=0 && UpperToLower[*a]==UpperToLower[*b]){ a++; b++; }
|
while( N-- > 0 && *a!=0 && UpperToLower[*a]==UpperToLower[*b]){ a++; b++; }
|
||||||
|
@@ -966,11 +966,19 @@ static const void *columnName(
|
|||||||
const void *(*xFunc)(Mem*),
|
const void *(*xFunc)(Mem*),
|
||||||
int useType
|
int useType
|
||||||
){
|
){
|
||||||
const void *ret = 0;
|
const void *ret;
|
||||||
Vdbe *p = (Vdbe *)pStmt;
|
Vdbe *p;
|
||||||
int n;
|
int n;
|
||||||
sqlite3 *db = p->db;
|
sqlite3 *db;
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( pStmt==0 ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
ret = 0;
|
||||||
|
p = (Vdbe *)pStmt;
|
||||||
|
db = p->db;
|
||||||
assert( db!=0 );
|
assert( db!=0 );
|
||||||
n = sqlite3_column_count(pStmt);
|
n = sqlite3_column_count(pStmt);
|
||||||
if( N<n && N>=0 ){
|
if( N<n && N>=0 ){
|
||||||
@@ -1435,6 +1443,12 @@ int sqlite3_stmt_busy(sqlite3_stmt *pStmt){
|
|||||||
*/
|
*/
|
||||||
sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt){
|
sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt){
|
||||||
sqlite3_stmt *pNext;
|
sqlite3_stmt *pNext;
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(pDb) ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(pDb->mutex);
|
sqlite3_mutex_enter(pDb->mutex);
|
||||||
if( pStmt==0 ){
|
if( pStmt==0 ){
|
||||||
pNext = (sqlite3_stmt*)pDb->pVdbe;
|
pNext = (sqlite3_stmt*)pDb->pVdbe;
|
||||||
@@ -1450,7 +1464,14 @@ sqlite3_stmt *sqlite3_next_stmt(sqlite3 *pDb, sqlite3_stmt *pStmt){
|
|||||||
*/
|
*/
|
||||||
int sqlite3_stmt_status(sqlite3_stmt *pStmt, int op, int resetFlag){
|
int sqlite3_stmt_status(sqlite3_stmt *pStmt, int op, int resetFlag){
|
||||||
Vdbe *pVdbe = (Vdbe*)pStmt;
|
Vdbe *pVdbe = (Vdbe*)pStmt;
|
||||||
u32 v = pVdbe->aCounter[op];
|
u32 v;
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !pStmt ){
|
||||||
|
(void)SQLITE_MISUSE_BKPT;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
v = pVdbe->aCounter[op];
|
||||||
if( resetFlag ) pVdbe->aCounter[op] = 0;
|
if( resetFlag ) pVdbe->aCounter[op] = 0;
|
||||||
return (int)v;
|
return (int)v;
|
||||||
}
|
}
|
||||||
|
@@ -153,6 +153,11 @@ int sqlite3_blob_open(
|
|||||||
Parse *pParse = 0;
|
Parse *pParse = 0;
|
||||||
Incrblob *pBlob = 0;
|
Incrblob *pBlob = 0;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || ppBlob==0 || zTable==0 ){
|
||||||
|
return SQLITE_MISUSE_BKPT;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
flags = !!flags; /* flags = (flags ? 1 : 0); */
|
flags = !!flags; /* flags = (flags ? 1 : 0); */
|
||||||
*ppBlob = 0;
|
*ppBlob = 0;
|
||||||
|
|
||||||
|
16
src/vtab.c
16
src/vtab.c
@@ -81,6 +81,9 @@ int sqlite3_create_module(
|
|||||||
const sqlite3_module *pModule, /* The definition of the module */
|
const sqlite3_module *pModule, /* The definition of the module */
|
||||||
void *pAux /* Context pointer for xCreate/xConnect */
|
void *pAux /* Context pointer for xCreate/xConnect */
|
||||||
){
|
){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || zName==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
return createModule(db, zName, pModule, pAux, 0);
|
return createModule(db, zName, pModule, pAux, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -94,6 +97,9 @@ int sqlite3_create_module_v2(
|
|||||||
void *pAux, /* Context pointer for xCreate/xConnect */
|
void *pAux, /* Context pointer for xCreate/xConnect */
|
||||||
void (*xDestroy)(void *) /* Module destructor function */
|
void (*xDestroy)(void *) /* Module destructor function */
|
||||||
){
|
){
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) || zName==0 ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
return createModule(db, zName, pModule, pAux, xDestroy);
|
return createModule(db, zName, pModule, pAux, xDestroy);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -698,6 +704,9 @@ int sqlite3_declare_vtab(sqlite3 *db, const char *zCreateTable){
|
|||||||
Table *pTab;
|
Table *pTab;
|
||||||
char *zErr = 0;
|
char *zErr = 0;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
if( !db->pVtabCtx || !(pTab = db->pVtabCtx->pTab) ){
|
if( !db->pVtabCtx || !(pTab = db->pVtabCtx->pTab) ){
|
||||||
sqlite3Error(db, SQLITE_MISUSE);
|
sqlite3Error(db, SQLITE_MISUSE);
|
||||||
@@ -1054,6 +1063,9 @@ int sqlite3_vtab_on_conflict(sqlite3 *db){
|
|||||||
static const unsigned char aMap[] = {
|
static const unsigned char aMap[] = {
|
||||||
SQLITE_ROLLBACK, SQLITE_ABORT, SQLITE_FAIL, SQLITE_IGNORE, SQLITE_REPLACE
|
SQLITE_ROLLBACK, SQLITE_ABORT, SQLITE_FAIL, SQLITE_IGNORE, SQLITE_REPLACE
|
||||||
};
|
};
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
assert( OE_Rollback==1 && OE_Abort==2 && OE_Fail==3 );
|
assert( OE_Rollback==1 && OE_Abort==2 && OE_Fail==3 );
|
||||||
assert( OE_Ignore==4 && OE_Replace==5 );
|
assert( OE_Ignore==4 && OE_Replace==5 );
|
||||||
assert( db->vtabOnConflict>=1 && db->vtabOnConflict<=5 );
|
assert( db->vtabOnConflict>=1 && db->vtabOnConflict<=5 );
|
||||||
@@ -1069,8 +1081,10 @@ int sqlite3_vtab_config(sqlite3 *db, int op, ...){
|
|||||||
va_list ap;
|
va_list ap;
|
||||||
int rc = SQLITE_OK;
|
int rc = SQLITE_OK;
|
||||||
|
|
||||||
|
#ifdef SQLITE_ENABLE_API_ARMOR
|
||||||
|
if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT;
|
||||||
|
#endif
|
||||||
sqlite3_mutex_enter(db->mutex);
|
sqlite3_mutex_enter(db->mutex);
|
||||||
|
|
||||||
va_start(ap, op);
|
va_start(ap, op);
|
||||||
switch( op ){
|
switch( op ){
|
||||||
case SQLITE_VTAB_CONSTRAINT_SUPPORT: {
|
case SQLITE_VTAB_CONSTRAINT_SUPPORT: {
|
||||||
|
Reference in New Issue
Block a user