1
0
mirror of https://github.com/sqlite/sqlite.git synced 2025-07-30 19:03:16 +03:00

Allow parameters to be introduced by characters ':', '$' and '#'. This

is an experimental change. (CVS 2523)

FossilOrigin-Name: f3427a139c3bd4faf9134ec6290b3eb829c0a19f
This commit is contained in:
drh
2005-06-22 08:48:06 +00:00
parent edef8fcd73
commit 288d37f1b4
5 changed files with 50 additions and 63 deletions

View File

@ -1,5 +1,5 @@
C Fix\sa\sbug\sin\san\sassert\sfound\swhile\sinvestigating\sticket\s#1287\sbut\sotherwise\nunrelated\sto\sthat\sproblem.\s(CVS\s2522) C Allow\sparameters\sto\sbe\sintroduced\sby\scharacters\s':',\s'$'\sand\s'#'.\s\sThis\nis\san\sexperimental\schange.\s(CVS\s2523)
D 2005-06-22T02:36:37 D 2005-06-22T08:48:06
F Makefile.in 64a6635ef44a98325e0cffe8d67669920a3dad47 F Makefile.in 64a6635ef44a98325e0cffe8d67669920a3dad47
F Makefile.linux-gcc 06be33b2a9ad4f005a5f42b22c4a19dab3cbb5c7 F Makefile.linux-gcc 06be33b2a9ad4f005a5f42b22c4a19dab3cbb5c7
F README 9c4e2d6706bdcc3efdd773ce752a8cdab4f90028 F README 9c4e2d6706bdcc3efdd773ce752a8cdab4f90028
@ -37,7 +37,7 @@ F src/callback.c 0910b611e0c158f107ee3ff86f8a371654971e2b
F src/date.c 2134ef4388256e8247405178df8a61bd60dc180a F src/date.c 2134ef4388256e8247405178df8a61bd60dc180a
F src/delete.c 4b68127f55971c7fb459146e0b6cf3bd70cfffe9 F src/delete.c 4b68127f55971c7fb459146e0b6cf3bd70cfffe9
F src/experimental.c 50c1e3b34f752f4ac10c36f287db095c2b61766d F src/experimental.c 50c1e3b34f752f4ac10c36f287db095c2b61766d
F src/expr.c 6d7058944c5f4b7e4304be3fe63ada91dac221a1 F src/expr.c 4d6e26da200e0d08233df52fd8d07916d24a6926
F src/func.c f208d71f741d47b63277530939f552815af8ce35 F src/func.c f208d71f741d47b63277530939f552815af8ce35
F src/hash.c 2b1b13f7400e179631c83a1be0c664608c8f021f F src/hash.c 2b1b13f7400e179631c83a1be0c664608c8f021f
F src/hash.h 1b0c445e1c89ff2aaad9b4605ba61375af001e84 F src/hash.h 1b0c445e1c89ff2aaad9b4605ba61375af001e84
@ -71,7 +71,7 @@ F src/test2.c 716c1809dba8e5be6093703e9cada99d627542dc
F src/test3.c 683e1e3819152ffd35da2f201e507228921148d0 F src/test3.c 683e1e3819152ffd35da2f201e507228921148d0
F src/test4.c 7c6b9fc33dd1f3f93c7f1ee6e5e6d016afa6c1df F src/test4.c 7c6b9fc33dd1f3f93c7f1ee6e5e6d016afa6c1df
F src/test5.c 64f08b2a50ef371a1bd68ff206829e7b1b9997f5 F src/test5.c 64f08b2a50ef371a1bd68ff206829e7b1b9997f5
F src/tokenize.c d89743f2c0d05d49b5b4d6462432a1f3cc4765f1 F src/tokenize.c 57ec9926612fb9e325b57a141303573bc20c79bf
F src/trigger.c f51dec15921629591cb98bf2e350018e268b109a F src/trigger.c f51dec15921629591cb98bf2e350018e268b109a
F src/update.c e96c7b342cd8903c672162f4cf84d2c737943347 F src/update.c e96c7b342cd8903c672162f4cf84d2c737943347
F src/utf.c bda5eb85039ef16f2d17004c1e18c96e1ab0a80c F src/utf.c bda5eb85039ef16f2d17004c1e18c96e1ab0a80c
@ -100,7 +100,7 @@ F test/autovacuum_ioerr.test 9cf27275ca47b72e188a47c53b61b6d583a01d24
F test/autovacuum_ioerr2.test 2f8a3fb31f833fd0ca86ad4ad98913c73e807572 F test/autovacuum_ioerr2.test 2f8a3fb31f833fd0ca86ad4ad98913c73e807572
F test/bigfile.test d3744a8821ce9abb8697f2826a3e3d22b719e89f F test/bigfile.test d3744a8821ce9abb8697f2826a3e3d22b719e89f
F test/bigrow.test f0aeb7573dcb8caaafea76454be3ade29b7fc747 F test/bigrow.test f0aeb7573dcb8caaafea76454be3ade29b7fc747
F test/bind.test bf1a99cb5471c8ec9958f7af0c8608d824535558 F test/bind.test 3169339a9fb7aaa8244d0ed8651fe6b6796d809c
F test/bindxfer.test 856830e9e5552b9882c9d5c6647f90e25bdae4ac F test/bindxfer.test 856830e9e5552b9882c9d5c6647f90e25bdae4ac
F test/blob.test fc41fe95bdc10da51f0dee73ce86e75ce1d6eb9d F test/blob.test fc41fe95bdc10da51f0dee73ce86e75ce1d6eb9d
F test/btree.test 8aa7424aeec844df990273fe36447e5d7e407261 F test/btree.test 8aa7424aeec844df990273fe36447e5d7e407261
@ -281,7 +281,7 @@ F www/tclsqlite.tcl 425be741b8ae664f55cb1ef2371aab0a75109cf9
F www/vdbe.tcl 87a31ace769f20d3627a64fa1fade7fed47b90d0 F www/vdbe.tcl 87a31ace769f20d3627a64fa1fade7fed47b90d0
F www/version3.tcl a99cf5f6d8bd4d5537584a2b342f0fb9fa601d8b F www/version3.tcl a99cf5f6d8bd4d5537584a2b342f0fb9fa601d8b
F www/whentouse.tcl 528299b8316726dbcc5548e9aa0648c8b1bd055b F www/whentouse.tcl 528299b8316726dbcc5548e9aa0648c8b1bd055b
P 59c95731f70ed9b9e135584f62d0a2b0f1a3bb96 P 60f752ed1817e6710c13c2ce393c3bf51dae76ad
R 446ed8445a101f560ead4db2a96c0b93 R 0728a1fdbaca12bf5f29cdb10e76a914
U drh U drh
Z c13f27ef7404ed30108e450cbb1c3c08 Z 6446212b902f4acbac0e5ce1e2a10f05

View File

@ -1 +1 @@
60f752ed1817e6710c13c2ce393c3bf51dae76ad f3427a139c3bd4faf9134ec6290b3eb829c0a19f

View File

@ -12,7 +12,7 @@
** This file contains routines used for analyzing expressions and ** This file contains routines used for analyzing expressions and
** for generating VDBE code that evaluates expressions in SQLite. ** for generating VDBE code that evaluates expressions in SQLite.
** **
** $Id: expr.c,v 1.206 2005/06/12 21:35:52 drh Exp $ ** $Id: expr.c,v 1.207 2005/06/22 08:48:06 drh Exp $
*/ */
#include "sqliteInt.h" #include "sqliteInt.h"
#include <ctype.h> #include <ctype.h>
@ -207,9 +207,8 @@ Expr *sqlite3Expr(int op, Expr *pLeft, Expr *pRight, const Token *pToken){
/* /*
** When doing a nested parse, you can include terms in an expression ** When doing a nested parse, you can include terms in an expression
** that look like this: #0 #1 #2 ... These terms refer to elements ** that look like this: #0 #1 #2 ... These terms refer to elements
** on the stack. "#0" (or just "#") means the top of the stack. ** on the stack. "#0" means the top of the stack.
** "#1" means the next down on the stack. And so forth. #-1 means ** "#1" means the next down on the stack. And so forth.
** memory location 0. #-2 means memory location 1. And so forth.
** **
** This routine is called by the parser to deal with on of those terms. ** This routine is called by the parser to deal with on of those terms.
** It immediately generates code to store the value in a memory location. ** It immediately generates code to store the value in a memory location.
@ -230,13 +229,9 @@ Expr *sqlite3RegisterExpr(Parse *pParse, Token *pToken){
return 0; /* Malloc failed */ return 0; /* Malloc failed */
} }
depth = atoi(&pToken->z[1]); depth = atoi(&pToken->z[1]);
if( depth>=0 ){ p->iTable = pParse->nMem++;
p->iTable = pParse->nMem++; sqlite3VdbeAddOp(v, OP_Dup, depth, 0);
sqlite3VdbeAddOp(v, OP_Dup, depth, 0); sqlite3VdbeAddOp(v, OP_MemStore, p->iTable, 1);
sqlite3VdbeAddOp(v, OP_MemStore, p->iTable, 1);
}else{
p->iTable = -1-depth;
}
return p; return p;
} }

View File

@ -15,7 +15,7 @@
** individual tokens and sends those tokens one-by-one over to the ** individual tokens and sends those tokens one-by-one over to the
** parser for analysis. ** parser for analysis.
** **
** $Id: tokenize.c,v 1.103 2005/06/06 14:45:43 drh Exp $ ** $Id: tokenize.c,v 1.104 2005/06/22 08:48:06 drh Exp $
*/ */
#include "sqliteInt.h" #include "sqliteInt.h"
#include "os.h" #include "os.h"
@ -183,11 +183,6 @@ static int getToken(const unsigned char *z, int *tokenType){
*tokenType = TK_BITNOT; *tokenType = TK_BITNOT;
return 1; return 1;
} }
case '#': {
for(i=1; isdigit(z[i]) || (i==1 && z[1]=='-'); i++){}
*tokenType = TK_REGISTER;
return i;
}
case '\'': case '"': { case '\'': case '"': {
int delim = z[0]; int delim = z[0];
for(i=1; (c=z[i])!=0; i++){ for(i=1; (c=z[i])!=0; i++){
@ -239,50 +234,47 @@ static int getToken(const unsigned char *z, int *tokenType){
for(i=1; isdigit(z[i]); i++){} for(i=1; isdigit(z[i]); i++){}
return i; return i;
} }
case ':': { case '#': {
for(i=1; IdChar(z[i]); i++){} for(i=1; isdigit(z[i]); i++){}
*tokenType = i>1 ? TK_VARIABLE : TK_ILLEGAL; if( i>1 ){
return i; /* Parameters of the form #NNN (where NNN is a number) are used
** internally by sqlite3NestedParse. */
*tokenType = TK_REGISTER;
return i;
}
/* Fall through into the next case if the '#' is not followed by
** a digit. Try to match #AAAA where AAAA is a parameter name. */
} }
#ifndef SQLITE_OMIT_TCL_VARIABLE #ifndef SQLITE_OMIT_TCL_VARIABLE
case '$': { case '$':
#endif
case ':': {
int n = 0;
*tokenType = TK_VARIABLE; *tokenType = TK_VARIABLE;
if( z[1]=='{' ){ for(i=1; (c=z[i])!=0; i++){
int nBrace = 1; if( IdChar(c) ){
for(i=2; (c=z[i])!=0 && nBrace; i++){ n++;
if( c=='{' ){ #ifndef SQLITE_OMIT_TCL_VARIABLE
nBrace++; }else if( c=='(' && n>0 ){
}else if( c=='}' ){ do{
nBrace--; i++;
} }while( (c=z[i])!=0 && !isspace(c) && c!=')' );
} if( c==')' ){
if( c==0 ) *tokenType = TK_ILLEGAL;
}else{
int n = 0;
for(i=1; (c=z[i])!=0; i++){
if( isalnum(c) || c=='_' ){
n++;
}else if( c=='(' && n>0 ){
do{
i++;
}while( (c=z[i])!=0 && !isspace(c) && c!=')' );
if( c==')' ){
i++;
}else{
*tokenType = TK_ILLEGAL;
}
break;
}else if( c==':' && z[i+1]==':' ){
i++; i++;
}else{ }else{
break; *tokenType = TK_ILLEGAL;
} }
break;
}else if( c==':' && z[i+1]==':' ){
i++;
#endif
}else{
break;
} }
if( n==0 ) *tokenType = TK_ILLEGAL;
} }
if( n==0 ) *tokenType = TK_ILLEGAL;
return i; return i;
} }
#endif
#ifndef SQLITE_OMIT_BLOB_LITERAL #ifndef SQLITE_OMIT_BLOB_LITERAL
case 'x': case 'X': { case 'x': case 'X': {
if( (c=z[1])=='\'' || c=='"' ){ if( (c=z[1])=='\'' || c=='"' ){

View File

@ -11,7 +11,7 @@
# This file implements regression tests for SQLite library. The # This file implements regression tests for SQLite library. The
# focus of this script testing the sqlite_bind API. # focus of this script testing the sqlite_bind API.
# #
# $Id: bind.test,v 1.31 2005/03/20 23:18:58 drh Exp $ # $Id: bind.test,v 1.32 2005/06/22 08:48:07 drh Exp $
# #
set testdir [file dirname $argv0] set testdir [file dirname $argv0]
@ -104,13 +104,13 @@ ifcapable {tclvar} {
execsql { execsql {
DELETE FROM t1; DELETE FROM t1;
} }
set VM [sqlite3_prepare $DB {INSERT INTO t1 VALUES($one,$::two,${x{y}z})}\ set VM [sqlite3_prepare $DB {INSERT INTO t1 VALUES($one,$::two,$x(-z-))}\
-1 TX] -1 TX]
set TX set TX
} {} } {}
set v1 {$one} set v1 {$one}
set v2 {$::two} set v2 {$::two}
set v3 {${x{y}z}} set v3 {$x(-z-)}
} }
ifcapable {!tclvar} { ifcapable {!tclvar} {
do_test bind-2.1 { do_test bind-2.1 {