Add API_ARMOR support to the sqlite3_result_...() family of functions and sqlite3_bind_zeroblob64().

FossilOrigin-Name: afabe3e35a66625527e2881749cdb6e13300888ab57bc0f05889d0e3ee203d73
This commit is contained in:
stephan 2023-10-14 16:29:36 +00:00
parent 7a54b12695
commit c76e450908
3 changed files with 85 additions and 13 deletions

View File

@ -1,5 +1,5 @@
C More\sAPI_ARMOR\sadditions. C Add\sAPI_ARMOR\ssupport\sto\sthe\ssqlite3_result_...()\sfamily\sof\sfunctions\sand\ssqlite3_bind_zeroblob64().
D 2023-10-14T14:53:18.394 D 2023-10-14T16:29:36.931
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724 F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
@ -787,7 +787,7 @@ F src/vacuum.c 604fcdaebe76f3497c855afcbf91b8fa5046b32de3045bab89cc008d68e40104
F src/vdbe.c cd112eb00d20fc5cc44f631d0e713838602637328b0f127c2f3c2aa8cea3cc91 F src/vdbe.c cd112eb00d20fc5cc44f631d0e713838602637328b0f127c2f3c2aa8cea3cc91
F src/vdbe.h 41485521f68e9437fdb7ec4a90f9d86ab294e9bb8281e33b235915e29122cfc0 F src/vdbe.h 41485521f68e9437fdb7ec4a90f9d86ab294e9bb8281e33b235915e29122cfc0
F src/vdbeInt.h 949669dfd8a41550d27dcb905b494f2ccde9a2e6c1b0b04daa1227e2e74c2b2c F src/vdbeInt.h 949669dfd8a41550d27dcb905b494f2ccde9a2e6c1b0b04daa1227e2e74c2b2c
F src/vdbeapi.c dbada91cc9f2e0b76ad4c76aad7b92fbe80c4a439b5dd8d7fa990d4e34b9831c F src/vdbeapi.c 0204e7247582975797a4b45606b39395c8a4f678d7c2b8dc15129044dcbb508f
F src/vdbeaux.c 5b415e09b5b9d5be6c0f4fcbf18ea9d7d16f6a29ced2f14a3b2041020f63e9c1 F src/vdbeaux.c 5b415e09b5b9d5be6c0f4fcbf18ea9d7d16f6a29ced2f14a3b2041020f63e9c1
F src/vdbeblob.c 13f9287b55b6356b4b1845410382d6bede203ceb29ef69388a4a3d007ffacbe5 F src/vdbeblob.c 13f9287b55b6356b4b1845410382d6bede203ceb29ef69388a4a3d007ffacbe5
F src/vdbemem.c 317b9f48708139db6239ade40c7980b4bc8233168383690d588dad6d8437f722 F src/vdbemem.c 317b9f48708139db6239ade40c7980b4bc8233168383690d588dad6d8437f722
@ -2128,8 +2128,8 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0 F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
P 0114a6622afc4588c47e98d804340449417b603dc4831513eab4d8e4ccb15d42 P 78ebf838f645742f87733665cd72af736df345683b27377a2c8310c893b1769d
R 376130abd753bb410df401995b876336 R 71ff5d4a376fdfcdde5b2514a89cbed8
U stephan U stephan
Z fbd9ca46d7a725fcd4bdd4a5ef9f230a Z 2c334c3835eed2b31940cc452708383c
# Remove this line to create a well-formed Fossil manifest. # Remove this line to create a well-formed Fossil manifest.

View File

@ -1 +1 @@
78ebf838f645742f87733665cd72af736df345683b27377a2c8310c893b1769d afabe3e35a66625527e2881749cdb6e13300888ab57bc0f05889d0e3ee203d73

View File

@ -405,7 +405,7 @@ static void setResultStrOrError(
static int invokeValueDestructor( static int invokeValueDestructor(
const void *p, /* Value to destroy */ const void *p, /* Value to destroy */
void (*xDel)(void*), /* The destructor */ void (*xDel)(void*), /* The destructor */
sqlite3_context *pCtx /* Set a SQLITE_TOOBIG error if no NULL */ sqlite3_context *pCtx /* Set a SQLITE_TOOBIG error if not NULL */
){ ){
assert( xDel!=SQLITE_DYNAMIC ); assert( xDel!=SQLITE_DYNAMIC );
if( xDel==0 ){ if( xDel==0 ){
@ -415,7 +415,9 @@ static int invokeValueDestructor(
}else{ }else{
xDel((void*)p); xDel((void*)p);
} }
sqlite3_result_error_toobig(pCtx); if( pCtx!=0 ){
sqlite3_result_error_toobig(pCtx);
}
return SQLITE_TOOBIG; return SQLITE_TOOBIG;
} }
void sqlite3_result_blob( void sqlite3_result_blob(
@ -424,6 +426,12 @@ void sqlite3_result_blob(
int n, int n,
void (*xDel)(void *) void (*xDel)(void *)
){ ){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 || n<0 ){
invokeValueDestructor(z, xDel, pCtx);
return;
}
#endif
assert( n>=0 ); assert( n>=0 );
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
setResultStrOrError(pCtx, z, n, 0, xDel); setResultStrOrError(pCtx, z, n, 0, xDel);
@ -434,8 +442,14 @@ void sqlite3_result_blob64(
sqlite3_uint64 n, sqlite3_uint64 n,
void (*xDel)(void *) void (*xDel)(void *)
){ ){
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
assert( xDel!=SQLITE_DYNAMIC ); assert( xDel!=SQLITE_DYNAMIC );
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ){
invokeValueDestructor(z, xDel, 0);
return;
}
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
if( n>0x7fffffff ){ if( n>0x7fffffff ){
(void)invokeValueDestructor(z, xDel, pCtx); (void)invokeValueDestructor(z, xDel, pCtx);
}else{ }else{
@ -443,30 +457,48 @@ void sqlite3_result_blob64(
} }
} }
void sqlite3_result_double(sqlite3_context *pCtx, double rVal){ void sqlite3_result_double(sqlite3_context *pCtx, double rVal){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
sqlite3VdbeMemSetDouble(pCtx->pOut, rVal); sqlite3VdbeMemSetDouble(pCtx->pOut, rVal);
} }
void sqlite3_result_error(sqlite3_context *pCtx, const char *z, int n){ void sqlite3_result_error(sqlite3_context *pCtx, const char *z, int n){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
pCtx->isError = SQLITE_ERROR; pCtx->isError = SQLITE_ERROR;
sqlite3VdbeMemSetStr(pCtx->pOut, z, n, SQLITE_UTF8, SQLITE_TRANSIENT); sqlite3VdbeMemSetStr(pCtx->pOut, z, n, SQLITE_UTF8, SQLITE_TRANSIENT);
} }
#ifndef SQLITE_OMIT_UTF16 #ifndef SQLITE_OMIT_UTF16
void sqlite3_result_error16(sqlite3_context *pCtx, const void *z, int n){ void sqlite3_result_error16(sqlite3_context *pCtx, const void *z, int n){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
pCtx->isError = SQLITE_ERROR; pCtx->isError = SQLITE_ERROR;
sqlite3VdbeMemSetStr(pCtx->pOut, z, n, SQLITE_UTF16NATIVE, SQLITE_TRANSIENT); sqlite3VdbeMemSetStr(pCtx->pOut, z, n, SQLITE_UTF16NATIVE, SQLITE_TRANSIENT);
} }
#endif #endif
void sqlite3_result_int(sqlite3_context *pCtx, int iVal){ void sqlite3_result_int(sqlite3_context *pCtx, int iVal){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
sqlite3VdbeMemSetInt64(pCtx->pOut, (i64)iVal); sqlite3VdbeMemSetInt64(pCtx->pOut, (i64)iVal);
} }
void sqlite3_result_int64(sqlite3_context *pCtx, i64 iVal){ void sqlite3_result_int64(sqlite3_context *pCtx, i64 iVal){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
sqlite3VdbeMemSetInt64(pCtx->pOut, iVal); sqlite3VdbeMemSetInt64(pCtx->pOut, iVal);
} }
void sqlite3_result_null(sqlite3_context *pCtx){ void sqlite3_result_null(sqlite3_context *pCtx){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
sqlite3VdbeMemSetNull(pCtx->pOut); sqlite3VdbeMemSetNull(pCtx->pOut);
} }
@ -476,14 +508,25 @@ void sqlite3_result_pointer(
const char *zPType, const char *zPType,
void (*xDestructor)(void*) void (*xDestructor)(void*)
){ ){
Mem *pOut = pCtx->pOut; Mem *pOut;
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ){
invokeValueDestructor(pPtr, xDestructor, 0);
return;
}
#endif
pOut = pCtx->pOut;
assert( sqlite3_mutex_held(pOut->db->mutex) ); assert( sqlite3_mutex_held(pOut->db->mutex) );
sqlite3VdbeMemRelease(pOut); sqlite3VdbeMemRelease(pOut);
pOut->flags = MEM_Null; pOut->flags = MEM_Null;
sqlite3VdbeMemSetPointer(pOut, pPtr, zPType, xDestructor); sqlite3VdbeMemSetPointer(pOut, pPtr, zPType, xDestructor);
} }
void sqlite3_result_subtype(sqlite3_context *pCtx, unsigned int eSubtype){ void sqlite3_result_subtype(sqlite3_context *pCtx, unsigned int eSubtype){
Mem *pOut = pCtx->pOut; Mem *pOut;
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
pOut = pCtx->pOut;
assert( sqlite3_mutex_held(pOut->db->mutex) ); assert( sqlite3_mutex_held(pOut->db->mutex) );
pOut->eSubtype = eSubtype & 0xff; pOut->eSubtype = eSubtype & 0xff;
pOut->flags |= MEM_Subtype; pOut->flags |= MEM_Subtype;
@ -494,6 +537,12 @@ void sqlite3_result_text(
int n, int n,
void (*xDel)(void *) void (*xDel)(void *)
){ ){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ){
invokeValueDestructor(z, xDel, 0);
return;
}
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
setResultStrOrError(pCtx, z, n, SQLITE_UTF8, xDel); setResultStrOrError(pCtx, z, n, SQLITE_UTF8, xDel);
} }
@ -504,6 +553,12 @@ void sqlite3_result_text64(
void (*xDel)(void *), void (*xDel)(void *),
unsigned char enc unsigned char enc
){ ){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ){
invokeValueDestructor(z, xDel, 0);
return;
}
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
assert( xDel!=SQLITE_DYNAMIC ); assert( xDel!=SQLITE_DYNAMIC );
if( enc!=SQLITE_UTF8 ){ if( enc!=SQLITE_UTF8 ){
@ -568,7 +623,12 @@ void sqlite3_result_zeroblob(sqlite3_context *pCtx, int n){
sqlite3_result_zeroblob64(pCtx, n>0 ? n : 0); sqlite3_result_zeroblob64(pCtx, n>0 ? n : 0);
} }
int sqlite3_result_zeroblob64(sqlite3_context *pCtx, u64 n){ int sqlite3_result_zeroblob64(sqlite3_context *pCtx, u64 n){
Mem *pOut = pCtx->pOut; Mem *pOut;
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return SQLITE_MISUSE_BKPT;
#endif
pOut = pCtx->pOut;
assert( sqlite3_mutex_held(pOut->db->mutex) ); assert( sqlite3_mutex_held(pOut->db->mutex) );
if( n>(u64)pOut->db->aLimit[SQLITE_LIMIT_LENGTH] ){ if( n>(u64)pOut->db->aLimit[SQLITE_LIMIT_LENGTH] ){
sqlite3_result_error_toobig(pCtx); sqlite3_result_error_toobig(pCtx);
@ -582,6 +642,9 @@ int sqlite3_result_zeroblob64(sqlite3_context *pCtx, u64 n){
#endif #endif
} }
void sqlite3_result_error_code(sqlite3_context *pCtx, int errCode){ void sqlite3_result_error_code(sqlite3_context *pCtx, int errCode){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
pCtx->isError = errCode ? errCode : -1; pCtx->isError = errCode ? errCode : -1;
#ifdef SQLITE_DEBUG #ifdef SQLITE_DEBUG
if( pCtx->pVdbe ) pCtx->pVdbe->rcApp = errCode; if( pCtx->pVdbe ) pCtx->pVdbe->rcApp = errCode;
@ -594,6 +657,9 @@ void sqlite3_result_error_code(sqlite3_context *pCtx, int errCode){
/* Force an SQLITE_TOOBIG error. */ /* Force an SQLITE_TOOBIG error. */
void sqlite3_result_error_toobig(sqlite3_context *pCtx){ void sqlite3_result_error_toobig(sqlite3_context *pCtx){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
pCtx->isError = SQLITE_TOOBIG; pCtx->isError = SQLITE_TOOBIG;
sqlite3VdbeMemSetStr(pCtx->pOut, "string or blob too big", -1, sqlite3VdbeMemSetStr(pCtx->pOut, "string or blob too big", -1,
@ -602,6 +668,9 @@ void sqlite3_result_error_toobig(sqlite3_context *pCtx){
/* An SQLITE_NOMEM error. */ /* An SQLITE_NOMEM error. */
void sqlite3_result_error_nomem(sqlite3_context *pCtx){ void sqlite3_result_error_nomem(sqlite3_context *pCtx){
#ifdef SQLITE_ENABLE_API_ARMOR
if( pCtx==0 ) return;
#endif
assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) ); assert( sqlite3_mutex_held(pCtx->pOut->db->mutex) );
sqlite3VdbeMemSetNull(pCtx->pOut); sqlite3VdbeMemSetNull(pCtx->pOut);
pCtx->isError = SQLITE_NOMEM_BKPT; pCtx->isError = SQLITE_NOMEM_BKPT;
@ -1765,6 +1834,9 @@ int sqlite3_bind_zeroblob(sqlite3_stmt *pStmt, int i, int n){
int sqlite3_bind_zeroblob64(sqlite3_stmt *pStmt, int i, sqlite3_uint64 n){ int sqlite3_bind_zeroblob64(sqlite3_stmt *pStmt, int i, sqlite3_uint64 n){
int rc; int rc;
Vdbe *p = (Vdbe *)pStmt; Vdbe *p = (Vdbe *)pStmt;
#ifdef SQLITE_ENABLE_API_ARMOR
if( p==0 ) return SQLITE_MISUSE_BKPT;
#endif
sqlite3_mutex_enter(p->db->mutex); sqlite3_mutex_enter(p->db->mutex);
if( n>(u64)p->db->aLimit[SQLITE_LIMIT_LENGTH] ){ if( n>(u64)p->db->aLimit[SQLITE_LIMIT_LENGTH] ){
rc = SQLITE_TOOBIG; rc = SQLITE_TOOBIG;