aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordan <dan@noemail.net>2010-08-17 19:34:13 +0000
committerdan <dan@noemail.net>2010-08-17 19:34:13 +0000
commitc8d735aed30be0d41689a08dd273330a3cd63ec8 (patch)
tree668dfb92d98175abab4a0c02d744a203db68ab6e
parent0028486b7346479504b43a5bd5cd0b4e3d4bd907 (diff)
downloadsqlite-c8d735aed30be0d41689a08dd273330a3cd63ec8.tar.gz
sqlite-c8d735aed30be0d41689a08dd273330a3cd63ec8.zip
Return an error when parsing "?NNN" if NNN is so large it cannot be stored as a 32-bit int.
FossilOrigin-Name: fc9014be0f00d046e7ba830a644f9ce93eca5db8
-rw-r--r--manifest24
-rw-r--r--manifest.uuid2
-rw-r--r--src/expr.c5
3 files changed, 11 insertions, 20 deletions
diff --git a/manifest b/manifest
index 64b4b2491..8c4c88c70 100644
--- a/manifest
+++ b/manifest
@@ -1,8 +1,5 @@
------BEGIN PGP SIGNED MESSAGE-----
-Hash: SHA1
-
-C It\sis\sno\slonger\spossible\sto\sreach\spagerStress()\swhile\sin\sthe\serror\sstate,\nso\sput\sa\sNEVER()\saround\sthe\serror\sstate\stest\sof\sthat\sroutine.
-D 2010-08-17T18:37:13
+C Return\san\serror\swhen\sparsing\s"?NNN"\sif\sNNN\sis\sso\slarge\sit\scannot\sbe\sstored\sas\sa\s32-bit\sint.
+D 2010-08-17T19:34:14
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
F Makefile.in ec08dc838fd8110fe24c92e5130bcd91cbb1ff2e
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
@@ -125,7 +122,7 @@ F src/complete.c dc1d136c0feee03c2f7550bafc0d29075e36deac
F src/ctime.c 4f3aadad62c6c9f0d4e5a96718516ac4e3c598df
F src/date.c 5dd8448a0bfea8d31fb14cff487d0c06ff8c8b20
F src/delete.c 7ed8a8c8b5f748ece92df173d7e0f7810c899ebd
-F src/expr.c a0fd9c5e248229851077de92f2e9346f2c43ed46
+F src/expr.c 9532d71de52ad7a5523b0a4b9d7d64874560e328
F src/fault.c 160a0c015b6c2629d3899ed2daf63d75754a32bb
F src/fkey.c 58bbf52c6ddd3f64ca40a3230f9e548a83a5cb16
F src/func.c 464b0dc70618b896c402c574eb04bc5eacf35341
@@ -846,14 +843,7 @@ F tool/speedtest2.tcl ee2149167303ba8e95af97873c575c3e0fab58ff
F tool/speedtest8.c 2902c46588c40b55661e471d7a86e4dd71a18224
F tool/speedtest8inst1.c 293327bc76823f473684d589a8160bde1f52c14e
F tool/vdbe-compress.tcl d70ea6d8a19e3571d7ab8c9b75cba86d1173ff0f
-P 8ac185236e766becdac7248c1ba3dfa42a9464b1
-R 15788ebc670118d1933aed30ce393c67
-U drh
-Z 4d416488630bf985a539466ff7ee6ddb
------BEGIN PGP SIGNATURE-----
-Version: GnuPG v1.4.6 (GNU/Linux)
-
-iD8DBQFMatbcoxKgR168RlERAiVJAKCLNKPoYvUl5GoHta8oDcjdGJE8mACfZs+E
-8kxI6koAtXdn/nw0mMZtkgg=
-=Gyit
------END PGP SIGNATURE-----
+P d7ed463496c4474cc435d032874a4e55d780e74a
+R 3be15ad5597167776a39a56056816d30
+U dan
+Z 8343604ee459a9523d2a5de8f96f92a2
diff --git a/manifest.uuid b/manifest.uuid
index f57abe519..5ba01f171 100644
--- a/manifest.uuid
+++ b/manifest.uuid
@@ -1 +1 @@
-d7ed463496c4474cc435d032874a4e55d780e74a \ No newline at end of file
+fc9014be0f00d046e7ba830a644f9ce93eca5db8 \ No newline at end of file
diff --git a/src/expr.c b/src/expr.c
index 153751f7c..fd21eb558 100644
--- a/src/expr.c
+++ b/src/expr.c
@@ -554,13 +554,14 @@ void sqlite3ExprAssignVarNumber(Parse *pParse, Expr *pExpr){
}else if( z[0]=='?' ){
/* Wildcard of the form "?nnn". Convert "nnn" to an integer and
** use it as the variable number */
- int i = atoi((char*)&z[1]);
+ i64 i;
+ int bOk = sqlite3Atoi64(&z[1], &i);
pExpr->iColumn = (ynVar)i;
testcase( i==0 );
testcase( i==1 );
testcase( i==db->aLimit[SQLITE_LIMIT_VARIABLE_NUMBER]-1 );
testcase( i==db->aLimit[SQLITE_LIMIT_VARIABLE_NUMBER] );
- if( i<1 || i>db->aLimit[SQLITE_LIMIT_VARIABLE_NUMBER] ){
+ if( bOk==0 || i<1 || i>db->aLimit[SQLITE_LIMIT_VARIABLE_NUMBER] ){
sqlite3ErrorMsg(pParse, "variable number must be between ?1 and ?%d",
db->aLimit[SQLITE_LIMIT_VARIABLE_NUMBER]);
}