/ Hex Artifact Content
Login

Artifact c5b8ee4d51df4de4ee51cadfd0123294e3d683d5:


0000: 2f 2a 0a 2a 2a 20 32 30 30 31 20 53 65 70 74 65  /*.** 2001 Septe
0010: 6d 62 65 72 20 31 35 0a 2a 2a 0a 2a 2a 20 54 68  mber 15.**.** Th
0020: 65 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69  e author disclai
0030: 6d 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20  ms copyright to 
0040: 74 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65  this source code
0050: 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a  .  In place of.*
0060: 2a 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65  * a legal notice
0070: 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73  , here is a bles
0080: 73 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d  sing:.**.**    M
0090: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
00a0: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20  nd not evil..** 
00b0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00c0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00d0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00e0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20  give others..** 
00f0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
0100: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0110: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0120: 79 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a  you give..**.***
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 2a 2a 2a 2a 2a 2a 0a 2a 2a 20 54 68 69 73 20 66  ******.** This f
0180: 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 72 6f 75  ile contains rou
0190: 74 69 6e 65 73 20 75 73 65 64 20 66 6f 72 20 61  tines used for a
01a0: 6e 61 6c 79 7a 69 6e 67 20 65 78 70 72 65 73 73  nalyzing express
01b0: 69 6f 6e 73 20 61 6e 64 0a 2a 2a 20 66 6f 72 20  ions and.** for 
01c0: 67 65 6e 65 72 61 74 69 6e 67 20 56 44 42 45 20  generating VDBE 
01d0: 63 6f 64 65 20 74 68 61 74 20 65 76 61 6c 75 61  code that evalua
01e0: 74 65 73 20 65 78 70 72 65 73 73 69 6f 6e 73 20  tes expressions 
01f0: 69 6e 20 53 51 4c 69 74 65 2e 0a 2a 2a 0a 2a 2a  in SQLite..**.**
0200: 20 24 49 64 3a 20 65 78 70 72 2e 63 2c 76 20 31   $Id: expr.c,v 1
0210: 2e 37 35 20 32 30 30 32 2f 30 36 2f 32 38 20 31  .75 2002/06/28 1
0220: 32 3a 31 38 3a 34 37 20 64 72 68 20 45 78 70 20  2:18:47 drh Exp 
0230: 24 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22 73  $.*/.#include "s
0240: 71 6c 69 74 65 49 6e 74 2e 68 22 0a 23 69 6e 63  qliteInt.h".#inc
0250: 6c 75 64 65 20 3c 63 74 79 70 65 2e 68 3e 0a 0a  lude <ctype.h>..
0260: 2f 2a 0a 2a 2a 20 43 6f 6e 73 74 72 75 63 74 20  /*.** Construct 
0270: 61 20 6e 65 77 20 65 78 70 72 65 73 73 69 6f 6e  a new expression
0280: 20 6e 6f 64 65 20 61 6e 64 20 72 65 74 75 72 6e   node and return
0290: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 69 74   a pointer to it
02a0: 2e 20 20 4d 65 6d 6f 72 79 0a 2a 2a 20 66 6f 72  .  Memory.** for
02b0: 20 74 68 69 73 20 6e 6f 64 65 20 69 73 20 6f 62   this node is ob
02c0: 74 61 69 6e 65 64 20 66 72 6f 6d 20 73 71 6c 69  tained from sqli
02d0: 74 65 4d 61 6c 6c 6f 63 28 29 2e 20 20 54 68 65  teMalloc().  The
02e0: 20 63 61 6c 6c 69 6e 67 20 66 75 6e 63 74 69 6f   calling functio
02f0: 6e 0a 2a 2a 20 69 73 20 72 65 73 70 6f 6e 73 69  n.** is responsi
0300: 62 6c 65 20 66 6f 72 20 6d 61 6b 69 6e 67 20 73  ble for making s
0310: 75 72 65 20 74 68 65 20 6e 6f 64 65 20 65 76 65  ure the node eve
0320: 6e 74 75 61 6c 6c 79 20 67 65 74 73 20 66 72 65  ntually gets fre
0330: 65 64 2e 0a 2a 2f 0a 45 78 70 72 20 2a 73 71 6c  ed..*/.Expr *sql
0340: 69 74 65 45 78 70 72 28 69 6e 74 20 6f 70 2c 20  iteExpr(int op, 
0350: 45 78 70 72 20 2a 70 4c 65 66 74 2c 20 45 78 70  Expr *pLeft, Exp
0360: 72 20 2a 70 52 69 67 68 74 2c 20 54 6f 6b 65 6e  r *pRight, Token
0370: 20 2a 70 54 6f 6b 65 6e 29 7b 0a 20 20 45 78 70   *pToken){.  Exp
0380: 72 20 2a 70 4e 65 77 3b 0a 20 20 70 4e 65 77 20  r *pNew;.  pNew 
0390: 3d 20 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 20  = sqliteMalloc( 
03a0: 73 69 7a 65 6f 66 28 45 78 70 72 29 20 29 3b 0a  sizeof(Expr) );.
03b0: 20 20 69 66 28 20 70 4e 65 77 3d 3d 30 20 29 7b    if( pNew==0 ){
03c0: 0a 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 44  .    sqliteExprD
03d0: 65 6c 65 74 65 28 70 4c 65 66 74 29 3b 0a 20 20  elete(pLeft);.  
03e0: 20 20 73 71 6c 69 74 65 45 78 70 72 44 65 6c 65    sqliteExprDele
03f0: 74 65 28 70 52 69 67 68 74 29 3b 0a 20 20 20 20  te(pRight);.    
0400: 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20 20  return 0;.  }.  
0410: 70 4e 65 77 2d 3e 6f 70 20 3d 20 6f 70 3b 0a 20  pNew->op = op;. 
0420: 20 70 4e 65 77 2d 3e 70 4c 65 66 74 20 3d 20 70   pNew->pLeft = p
0430: 4c 65 66 74 3b 0a 20 20 70 4e 65 77 2d 3e 70 52  Left;.  pNew->pR
0440: 69 67 68 74 20 3d 20 70 52 69 67 68 74 3b 0a 20  ight = pRight;. 
0450: 20 69 66 28 20 70 54 6f 6b 65 6e 20 29 7b 0a 20   if( pToken ){. 
0460: 20 20 20 70 4e 65 77 2d 3e 74 6f 6b 65 6e 20 3d     pNew->token =
0470: 20 2a 70 54 6f 6b 65 6e 3b 0a 20 20 7d 65 6c 73   *pToken;.  }els
0480: 65 7b 0a 20 20 20 20 70 4e 65 77 2d 3e 74 6f 6b  e{.    pNew->tok
0490: 65 6e 2e 7a 20 3d 20 30 3b 0a 20 20 20 20 70 4e  en.z = 0;.    pN
04a0: 65 77 2d 3e 74 6f 6b 65 6e 2e 6e 20 3d 20 30 3b  ew->token.n = 0;
04b0: 0a 20 20 7d 0a 20 20 69 66 28 20 70 4c 65 66 74  .  }.  if( pLeft
04c0: 20 26 26 20 70 52 69 67 68 74 20 29 7b 0a 20 20   && pRight ){.  
04d0: 20 20 73 71 6c 69 74 65 45 78 70 72 53 70 61 6e    sqliteExprSpan
04e0: 28 70 4e 65 77 2c 20 26 70 4c 65 66 74 2d 3e 73  (pNew, &pLeft->s
04f0: 70 61 6e 2c 20 26 70 52 69 67 68 74 2d 3e 73 70  pan, &pRight->sp
0500: 61 6e 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  an);.  }else{.  
0510: 20 20 70 4e 65 77 2d 3e 73 70 61 6e 20 3d 20 70    pNew->span = p
0520: 4e 65 77 2d 3e 74 6f 6b 65 6e 3b 0a 20 20 7d 0a  New->token;.  }.
0530: 20 20 72 65 74 75 72 6e 20 70 4e 65 77 3b 0a 7d    return pNew;.}
0540: 0a 0a 2f 2a 0a 2a 2a 20 53 65 74 20 74 68 65 20  ../*.** Set the 
0550: 45 78 70 72 2e 74 6f 6b 65 6e 20 66 69 65 6c 64  Expr.token field
0560: 20 6f 66 20 74 68 65 20 67 69 76 65 6e 20 65 78   of the given ex
0570: 70 72 65 73 73 69 6f 6e 20 74 6f 20 73 70 61 6e  pression to span
0580: 20 61 6c 6c 0a 2a 2a 20 74 65 78 74 20 62 65 74   all.** text bet
0590: 77 65 65 6e 20 74 68 65 20 74 77 6f 20 67 69 76  ween the two giv
05a0: 65 6e 20 74 6f 6b 65 6e 73 2e 0a 2a 2f 0a 76 6f  en tokens..*/.vo
05b0: 69 64 20 73 71 6c 69 74 65 45 78 70 72 53 70 61  id sqliteExprSpa
05c0: 6e 28 45 78 70 72 20 2a 70 45 78 70 72 2c 20 54  n(Expr *pExpr, T
05d0: 6f 6b 65 6e 20 2a 70 4c 65 66 74 2c 20 54 6f 6b  oken *pLeft, Tok
05e0: 65 6e 20 2a 70 52 69 67 68 74 29 7b 0a 20 20 69  en *pRight){.  i
05f0: 66 28 20 70 45 78 70 72 20 29 7b 0a 20 20 20 20  f( pExpr ){.    
0600: 70 45 78 70 72 2d 3e 73 70 61 6e 2e 7a 20 3d 20  pExpr->span.z = 
0610: 70 4c 65 66 74 2d 3e 7a 3b 0a 20 20 20 20 70 45  pLeft->z;.    pE
0620: 78 70 72 2d 3e 73 70 61 6e 2e 6e 20 3d 20 70 52  xpr->span.n = pR
0630: 69 67 68 74 2d 3e 6e 20 2b 20 41 64 64 72 28 70  ight->n + Addr(p
0640: 52 69 67 68 74 2d 3e 7a 29 20 2d 20 41 64 64 72  Right->z) - Addr
0650: 28 70 4c 65 66 74 2d 3e 7a 29 3b 0a 20 20 7d 0a  (pLeft->z);.  }.
0660: 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 73 74 72 75  }../*.** Constru
0670: 63 74 20 61 20 6e 65 77 20 65 78 70 72 65 73 73  ct a new express
0680: 69 6f 6e 20 6e 6f 64 65 20 66 6f 72 20 61 20 66  ion node for a f
0690: 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 6d 75 6c  unction with mul
06a0: 74 69 70 6c 65 0a 2a 2a 20 61 72 67 75 6d 65 6e  tiple.** argumen
06b0: 74 73 2e 0a 2a 2f 0a 45 78 70 72 20 2a 73 71 6c  ts..*/.Expr *sql
06c0: 69 74 65 45 78 70 72 46 75 6e 63 74 69 6f 6e 28  iteExprFunction(
06d0: 45 78 70 72 4c 69 73 74 20 2a 70 4c 69 73 74 2c  ExprList *pList,
06e0: 20 54 6f 6b 65 6e 20 2a 70 54 6f 6b 65 6e 29 7b   Token *pToken){
06f0: 0a 20 20 45 78 70 72 20 2a 70 4e 65 77 3b 0a 20  .  Expr *pNew;. 
0700: 20 70 4e 65 77 20 3d 20 73 71 6c 69 74 65 4d 61   pNew = sqliteMa
0710: 6c 6c 6f 63 28 20 73 69 7a 65 6f 66 28 45 78 70  lloc( sizeof(Exp
0720: 72 29 20 29 3b 0a 20 20 69 66 28 20 70 4e 65 77  r) );.  if( pNew
0730: 3d 3d 30 20 29 7b 0a 20 20 20 20 73 71 6c 69 74  ==0 ){.    sqlit
0740: 65 45 78 70 72 4c 69 73 74 44 65 6c 65 74 65 28  eExprListDelete(
0750: 70 4c 69 73 74 29 3b 0a 20 20 20 20 72 65 74 75  pList);.    retu
0760: 72 6e 20 30 3b 0a 20 20 7d 0a 20 20 70 4e 65 77  rn 0;.  }.  pNew
0770: 2d 3e 6f 70 20 3d 20 54 4b 5f 46 55 4e 43 54 49  ->op = TK_FUNCTI
0780: 4f 4e 3b 0a 20 20 70 4e 65 77 2d 3e 70 4c 69 73  ON;.  pNew->pLis
0790: 74 20 3d 20 70 4c 69 73 74 3b 0a 20 20 69 66 28  t = pList;.  if(
07a0: 20 70 54 6f 6b 65 6e 20 29 7b 0a 20 20 20 20 70   pToken ){.    p
07b0: 4e 65 77 2d 3e 74 6f 6b 65 6e 20 3d 20 2a 70 54  New->token = *pT
07c0: 6f 6b 65 6e 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20  oken;.  }else{. 
07d0: 20 20 20 70 4e 65 77 2d 3e 74 6f 6b 65 6e 2e 7a     pNew->token.z
07e0: 20 3d 20 30 3b 0a 20 20 20 20 70 4e 65 77 2d 3e   = 0;.    pNew->
07f0: 74 6f 6b 65 6e 2e 6e 20 3d 20 30 3b 0a 20 20 7d  token.n = 0;.  }
0800: 0a 20 20 72 65 74 75 72 6e 20 70 4e 65 77 3b 0a  .  return pNew;.
0810: 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 63 75 72 73 69  }../*.** Recursi
0820: 76 65 6c 79 20 64 65 6c 65 74 65 20 61 6e 20 65  vely delete an e
0830: 78 70 72 65 73 73 69 6f 6e 20 74 72 65 65 2e 0a  xpression tree..
0840: 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 45 78  */.void sqliteEx
0850: 70 72 44 65 6c 65 74 65 28 45 78 70 72 20 2a 70  prDelete(Expr *p
0860: 29 7b 0a 20 20 69 66 28 20 70 3d 3d 30 20 29 20  ){.  if( p==0 ) 
0870: 72 65 74 75 72 6e 3b 0a 20 20 69 66 28 20 70 2d  return;.  if( p-
0880: 3e 70 4c 65 66 74 20 29 20 73 71 6c 69 74 65 45  >pLeft ) sqliteE
0890: 78 70 72 44 65 6c 65 74 65 28 70 2d 3e 70 4c 65  xprDelete(p->pLe
08a0: 66 74 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70 52  ft);.  if( p->pR
08b0: 69 67 68 74 20 29 20 73 71 6c 69 74 65 45 78 70  ight ) sqliteExp
08c0: 72 44 65 6c 65 74 65 28 70 2d 3e 70 52 69 67 68  rDelete(p->pRigh
08d0: 74 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70 4c 69  t);.  if( p->pLi
08e0: 73 74 20 29 20 73 71 6c 69 74 65 45 78 70 72 4c  st ) sqliteExprL
08f0: 69 73 74 44 65 6c 65 74 65 28 70 2d 3e 70 4c 69  istDelete(p->pLi
0900: 73 74 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70 53  st);.  if( p->pS
0910: 65 6c 65 63 74 20 29 20 73 71 6c 69 74 65 53 65  elect ) sqliteSe
0920: 6c 65 63 74 44 65 6c 65 74 65 28 70 2d 3e 70 53  lectDelete(p->pS
0930: 65 6c 65 63 74 29 3b 0a 20 20 73 71 6c 69 74 65  elect);.  sqlite
0940: 46 72 65 65 28 70 29 3b 0a 7d 0a 0a 2f 2a 0a 2a  Free(p);.}../*.*
0950: 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20  * The following 
0960: 67 72 6f 75 70 20 6f 66 20 66 75 6e 63 74 69 6f  group of functio
0970: 6e 73 20 61 72 65 20 75 73 65 64 20 74 6f 20 74  ns are used to t
0980: 72 61 6e 73 6c 61 74 65 20 74 68 65 20 73 74 72  ranslate the str
0990: 69 6e 67 0a 2a 2a 20 70 6f 69 6e 74 65 72 73 20  ing.** pointers 
09a0: 6f 66 20 74 6f 6b 65 6e 73 20 69 6e 20 65 78 70  of tokens in exp
09b0: 72 65 73 73 69 6f 6e 20 66 72 6f 6d 20 6f 6e 65  ression from one
09c0: 20 62 75 66 66 65 72 20 74 6f 20 61 6e 6f 74 68   buffer to anoth
09d0: 65 72 2e 0a 2a 2a 0a 2a 2a 20 4e 6f 72 6d 61 6c  er..**.** Normal
09e0: 6c 79 2c 20 74 68 65 20 45 78 70 72 2e 74 6f 6b  ly, the Expr.tok
09f0: 65 6e 2e 7a 20 61 6e 64 20 45 78 70 72 2e 73 70  en.z and Expr.sp
0a00: 61 6e 2e 7a 20 66 69 65 6c 64 73 20 70 6f 69 6e  an.z fields poin
0a10: 74 20 69 6e 74 6f 20 74 68 65 0a 2a 2a 20 6f 72  t into the.** or
0a20: 69 67 69 6e 61 6c 20 69 6e 70 75 74 20 62 75 66  iginal input buf
0a30: 66 65 72 20 6f 66 20 61 6e 20 53 51 4c 20 73 74  fer of an SQL st
0a40: 61 74 65 6d 65 6e 74 2e 20 20 54 68 69 73 20 69  atement.  This i
0a50: 73 20 75 73 75 61 6c 6c 79 20 4f 4b 0a 2a 2a 20  s usually OK.** 
0a60: 73 69 6e 63 65 20 74 68 65 20 53 51 4c 20 73 74  since the SQL st
0a70: 61 74 65 6d 65 6e 74 20 69 73 20 65 78 65 63 75  atement is execu
0a80: 74 65 64 20 61 6e 64 20 74 68 65 20 65 78 70 72  ted and the expr
0a90: 65 73 73 69 6f 6e 20 69 73 20 64 65 6c 65 74 65  ession is delete
0aa0: 64 0a 2a 2a 20 62 65 66 6f 72 65 20 74 68 65 20  d.** before the 
0ab0: 69 6e 70 75 74 20 62 75 66 66 65 72 20 69 73 20  input buffer is 
0ac0: 66 72 65 65 64 2e 20 20 4d 61 6b 69 6e 67 20 74  freed.  Making t
0ad0: 68 65 20 74 6f 6b 65 6e 73 20 70 6f 69 6e 74 20  he tokens point 
0ae0: 74 6f 20 74 68 65 0a 2a 2a 20 6f 72 69 67 69 6e  to the.** origin
0af0: 61 6c 20 69 6e 70 75 74 20 62 75 66 66 65 72 20  al input buffer 
0b00: 73 61 76 65 73 20 6d 61 6e 79 20 63 61 6c 6c 73  saves many calls
0b10: 20 74 6f 20 6d 61 6c 6c 6f 63 28 29 20 61 6e 64   to malloc() and
0b20: 20 74 68 75 73 20 68 65 6c 70 73 0a 2a 2a 20 74   thus helps.** t
0b30: 68 65 20 6c 69 62 72 61 72 79 20 74 6f 20 72 75  he library to ru
0b40: 6e 20 66 61 73 74 65 72 2e 20 0a 2a 2a 0a 2a 2a  n faster. .**.**
0b50: 20 42 75 74 20 73 6f 6d 65 74 69 6d 65 73 20 77   But sometimes w
0b60: 65 20 6e 65 65 64 20 61 6e 20 65 78 70 72 65 73  e need an expres
0b70: 73 69 6f 6e 20 74 6f 20 70 65 72 73 69 73 74 20  sion to persist 
0b80: 70 61 73 74 20 74 68 65 20 74 69 6d 65 20 77 68  past the time wh
0b90: 65 6e 0a 2a 2a 20 74 68 65 20 69 6e 70 75 74 20  en.** the input 
0ba0: 62 75 66 66 65 72 20 69 73 20 66 72 65 65 64 2e  buffer is freed.
0bb0: 20 20 28 45 78 61 6d 70 6c 65 3a 20 54 68 65 20    (Example: The 
0bc0: 53 45 4c 45 43 54 20 63 6c 61 75 73 65 20 6f 66  SELECT clause of
0bd0: 20 61 0a 2a 2a 20 43 52 45 41 54 45 20 56 49 45   a.** CREATE VIE
0be0: 57 20 73 74 61 74 65 6d 65 6e 74 20 63 6f 6e 74  W statement cont
0bf0: 61 69 6e 73 20 65 78 70 72 65 73 73 69 6f 6e 73  ains expressions
0c00: 20 74 68 61 74 20 6d 75 73 74 20 70 65 72 73 69   that must persi
0c10: 73 74 20 66 6f 72 0a 2a 2a 20 74 68 65 20 6c 69  st for.** the li
0c20: 66 65 20 6f 66 20 74 68 65 20 76 69 65 77 2e 29  fe of the view.)
0c30: 20 20 57 68 65 6e 20 74 68 61 74 20 68 61 70 70    When that happ
0c40: 65 6e 73 20 77 65 20 68 61 76 65 20 74 6f 20 6d  ens we have to m
0c50: 61 6b 65 20 61 0a 2a 2a 20 70 65 72 73 69 73 74  ake a.** persist
0c60: 65 6e 74 20 63 6f 70 79 20 6f 66 20 74 68 65 20  ent copy of the 
0c70: 69 6e 70 75 74 20 62 75 66 66 65 72 20 61 6e 64  input buffer and
0c80: 20 74 72 61 6e 73 6c 61 74 65 20 74 68 65 20 45   translate the E
0c90: 78 70 72 2e 74 6f 6b 65 6e 2e 7a 0a 2a 2a 20 61  xpr.token.z.** a
0ca0: 6e 64 20 45 78 70 72 2e 73 70 61 6e 2e 7a 20 66  nd Expr.span.z f
0cb0: 69 65 6c 64 73 20 74 6f 20 70 6f 69 6e 74 20 74  ields to point t
0cc0: 6f 20 74 68 65 20 63 6f 70 79 20 72 61 74 68 65  o the copy rathe
0cd0: 72 20 74 68 61 6e 20 74 68 65 20 0a 2a 2a 20 6f  r than the .** o
0ce0: 72 69 67 69 6e 61 6c 20 69 6e 70 75 74 20 62 75  riginal input bu
0cf0: 66 66 65 72 2e 20 20 54 68 65 20 66 6f 6c 6c 6f  ffer.  The follo
0d00: 77 69 6e 67 20 67 72 6f 75 70 20 6f 66 20 72 6f  wing group of ro
0d10: 75 74 69 6e 65 73 20 68 61 6e 64 6c 65 20 74 68  utines handle th
0d20: 61 74 0a 2a 2a 20 74 72 61 6e 73 6c 61 74 69 6f  at.** translatio
0d30: 6e 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 22 6f 66  n..**.** The "of
0d40: 66 73 65 74 22 20 70 61 72 61 6d 65 74 65 72 20  fset" parameter 
0d50: 69 73 20 74 68 65 20 64 69 73 74 61 6e 63 65 20  is the distance 
0d60: 66 72 6f 6d 20 74 68 65 20 6f 72 69 67 69 6e 61  from the origina
0d70: 6c 20 69 6e 70 75 74 20 62 75 66 66 65 72 0a 2a  l input buffer.*
0d80: 2a 20 74 6f 20 74 68 65 20 70 65 72 73 69 73 74  * to the persist
0d90: 65 6e 74 20 63 6f 70 79 2e 20 20 54 68 65 73 65  ent copy.  These
0da0: 20 72 6f 75 74 69 6e 65 73 20 72 65 63 75 72 73   routines recurs
0db0: 69 76 65 6c 79 20 77 61 6c 6b 20 74 68 65 20 65  ively walk the e
0dc0: 6e 74 69 72 65 0a 2a 2a 20 65 78 70 72 65 73 73  ntire.** express
0dd0: 69 6f 6e 20 74 72 65 65 20 61 6e 64 20 73 68 69  ion tree and shi
0de0: 66 74 20 61 6c 6c 20 74 6f 6b 65 6e 73 20 62 79  ft all tokens by
0df0: 20 22 6f 66 66 73 65 74 22 20 61 6d 6f 75 6e 74   "offset" amount
0e00: 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 77 6f 72 6b  ..**.** The work
0e10: 20 6f 66 20 66 69 67 75 72 69 6e 67 20 6f 75 74   of figuring out
0e20: 20 74 68 65 20 61 70 70 72 6f 70 72 69 61 74 65   the appropriate
0e30: 20 22 6f 66 66 73 65 74 22 20 61 6e 64 20 6d 61   "offset" and ma
0e40: 6b 69 6e 67 20 74 68 65 0a 2a 2a 20 70 72 65 73  king the.** pres
0e50: 69 73 74 65 6e 74 20 63 6f 70 79 20 6f 66 20 74  istent copy of t
0e60: 68 65 20 69 6e 70 75 74 20 62 75 66 66 65 72 20  he input buffer 
0e70: 69 73 20 64 6f 6e 65 20 62 79 20 74 68 65 20 63  is done by the c
0e80: 61 6c 6c 69 6e 67 20 72 6f 75 74 69 6e 65 2e 0a  alling routine..
0e90: 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 45 78  */.void sqliteEx
0ea0: 70 72 4d 6f 76 65 53 74 72 69 6e 67 73 28 45 78  prMoveStrings(Ex
0eb0: 70 72 20 2a 70 2c 20 69 6e 74 20 6f 66 66 73 65  pr *p, int offse
0ec0: 74 29 7b 0a 20 20 69 66 28 20 70 3d 3d 30 20 29  t){.  if( p==0 )
0ed0: 20 72 65 74 75 72 6e 3b 0a 20 20 69 66 28 20 21   return;.  if( !
0ee0: 70 2d 3e 73 74 61 74 69 63 54 6f 6b 65 6e 20 29  p->staticToken )
0ef0: 7b 0a 20 20 20 20 69 66 28 20 70 2d 3e 74 6f 6b  {.    if( p->tok
0f00: 65 6e 2e 7a 20 29 20 70 2d 3e 74 6f 6b 65 6e 2e  en.z ) p->token.
0f10: 7a 20 2b 3d 20 6f 66 66 73 65 74 3b 0a 20 20 20  z += offset;.   
0f20: 20 69 66 28 20 70 2d 3e 73 70 61 6e 2e 7a 20 29   if( p->span.z )
0f30: 20 70 2d 3e 73 70 61 6e 2e 7a 20 2b 3d 20 6f 66   p->span.z += of
0f40: 66 73 65 74 3b 0a 20 20 7d 0a 20 20 69 66 28 20  fset;.  }.  if( 
0f50: 70 2d 3e 70 4c 65 66 74 20 29 20 73 71 6c 69 74  p->pLeft ) sqlit
0f60: 65 45 78 70 72 4d 6f 76 65 53 74 72 69 6e 67 73  eExprMoveStrings
0f70: 28 70 2d 3e 70 4c 65 66 74 2c 20 6f 66 66 73 65  (p->pLeft, offse
0f80: 74 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70 52 69  t);.  if( p->pRi
0f90: 67 68 74 20 29 20 73 71 6c 69 74 65 45 78 70 72  ght ) sqliteExpr
0fa0: 4d 6f 76 65 53 74 72 69 6e 67 73 28 70 2d 3e 70  MoveStrings(p->p
0fb0: 52 69 67 68 74 2c 20 6f 66 66 73 65 74 29 3b 0a  Right, offset);.
0fc0: 20 20 69 66 28 20 70 2d 3e 70 4c 69 73 74 20 29    if( p->pList )
0fd0: 20 73 71 6c 69 74 65 45 78 70 72 4c 69 73 74 4d   sqliteExprListM
0fe0: 6f 76 65 53 74 72 69 6e 67 73 28 70 2d 3e 70 4c  oveStrings(p->pL
0ff0: 69 73 74 2c 20 6f 66 66 73 65 74 29 3b 0a 20 20  ist, offset);.  
1000: 69 66 28 20 70 2d 3e 70 53 65 6c 65 63 74 20 29  if( p->pSelect )
1010: 20 73 71 6c 69 74 65 53 65 6c 65 63 74 4d 6f 76   sqliteSelectMov
1020: 65 53 74 72 69 6e 67 73 28 70 2d 3e 70 53 65 6c  eStrings(p->pSel
1030: 65 63 74 2c 20 6f 66 66 73 65 74 29 3b 0a 7d 0a  ect, offset);.}.
1040: 76 6f 69 64 20 73 71 6c 69 74 65 45 78 70 72 4c  void sqliteExprL
1050: 69 73 74 4d 6f 76 65 53 74 72 69 6e 67 73 28 45  istMoveStrings(E
1060: 78 70 72 4c 69 73 74 20 2a 70 4c 69 73 74 2c 20  xprList *pList, 
1070: 69 6e 74 20 6f 66 66 73 65 74 29 7b 0a 20 20 69  int offset){.  i
1080: 6e 74 20 69 3b 0a 20 20 69 66 28 20 70 4c 69 73  nt i;.  if( pLis
1090: 74 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 20  t==0 ) return;. 
10a0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 4c 69 73   for(i=0; i<pLis
10b0: 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a  t->nExpr; i++){.
10c0: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 4d 6f      sqliteExprMo
10d0: 76 65 53 74 72 69 6e 67 73 28 70 4c 69 73 74 2d  veStrings(pList-
10e0: 3e 61 5b 69 5d 2e 70 45 78 70 72 2c 20 6f 66 66  >a[i].pExpr, off
10f0: 73 65 74 29 3b 0a 20 20 7d 0a 7d 0a 76 6f 69 64  set);.  }.}.void
1100: 20 73 71 6c 69 74 65 53 65 6c 65 63 74 4d 6f 76   sqliteSelectMov
1110: 65 53 74 72 69 6e 67 73 28 53 65 6c 65 63 74 20  eStrings(Select 
1120: 2a 70 53 65 6c 65 63 74 2c 20 69 6e 74 20 6f 66  *pSelect, int of
1130: 66 73 65 74 29 7b 0a 20 20 69 66 28 20 70 53 65  fset){.  if( pSe
1140: 6c 65 63 74 3d 3d 30 20 29 20 72 65 74 75 72 6e  lect==0 ) return
1150: 3b 0a 20 20 73 71 6c 69 74 65 45 78 70 72 4c 69  ;.  sqliteExprLi
1160: 73 74 4d 6f 76 65 53 74 72 69 6e 67 73 28 70 53  stMoveStrings(pS
1170: 65 6c 65 63 74 2d 3e 70 45 4c 69 73 74 2c 20 6f  elect->pEList, o
1180: 66 66 73 65 74 29 3b 0a 20 20 73 71 6c 69 74 65  ffset);.  sqlite
1190: 45 78 70 72 4d 6f 76 65 53 74 72 69 6e 67 73 28  ExprMoveStrings(
11a0: 70 53 65 6c 65 63 74 2d 3e 70 57 68 65 72 65 2c  pSelect->pWhere,
11b0: 20 6f 66 66 73 65 74 29 3b 0a 20 20 73 71 6c 69   offset);.  sqli
11c0: 74 65 45 78 70 72 4c 69 73 74 4d 6f 76 65 53 74  teExprListMoveSt
11d0: 72 69 6e 67 73 28 70 53 65 6c 65 63 74 2d 3e 70  rings(pSelect->p
11e0: 47 72 6f 75 70 42 79 2c 20 6f 66 66 73 65 74 29  GroupBy, offset)
11f0: 3b 0a 20 20 73 71 6c 69 74 65 45 78 70 72 4d 6f  ;.  sqliteExprMo
1200: 76 65 53 74 72 69 6e 67 73 28 70 53 65 6c 65 63  veStrings(pSelec
1210: 74 2d 3e 70 48 61 76 69 6e 67 2c 20 6f 66 66 73  t->pHaving, offs
1220: 65 74 29 3b 0a 20 20 73 71 6c 69 74 65 45 78 70  et);.  sqliteExp
1230: 72 4c 69 73 74 4d 6f 76 65 53 74 72 69 6e 67 73  rListMoveStrings
1240: 28 70 53 65 6c 65 63 74 2d 3e 70 4f 72 64 65 72  (pSelect->pOrder
1250: 42 79 2c 20 6f 66 66 73 65 74 29 3b 0a 20 20 73  By, offset);.  s
1260: 71 6c 69 74 65 53 65 6c 65 63 74 4d 6f 76 65 53  qliteSelectMoveS
1270: 74 72 69 6e 67 73 28 70 53 65 6c 65 63 74 2d 3e  trings(pSelect->
1280: 70 50 72 69 6f 72 2c 20 6f 66 66 73 65 74 29 3b  pPrior, offset);
1290: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 66 6f  .}../*.** The fo
12a0: 6c 6c 6f 77 69 6e 67 20 67 72 6f 75 70 20 6f 66  llowing group of
12b0: 20 72 6f 75 74 69 6e 65 73 20 6d 61 6b 65 20 64   routines make d
12c0: 65 65 70 20 63 6f 70 69 65 73 20 6f 66 20 65 78  eep copies of ex
12d0: 70 72 65 73 73 69 6f 6e 73 2c 0a 2a 2a 20 65 78  pressions,.** ex
12e0: 70 72 65 73 73 69 6f 6e 20 6c 69 73 74 73 2c 20  pression lists, 
12f0: 49 44 20 6c 69 73 74 73 2c 20 61 6e 64 20 73 65  ID lists, and se
1300: 6c 65 63 74 20 73 74 61 74 65 6d 65 6e 74 73 2e  lect statements.
1310: 20 20 54 68 65 20 63 6f 70 69 65 73 20 63 61 6e    The copies can
1320: 0a 2a 2a 20 62 65 20 64 65 6c 65 74 65 64 20 28  .** be deleted (
1330: 62 79 20 62 65 69 6e 67 20 70 61 73 73 65 64 20  by being passed 
1340: 74 6f 20 74 68 65 69 72 20 72 65 73 70 65 63 74  to their respect
1350: 69 76 65 20 2e 2e 2e 44 65 6c 65 74 65 28 29 20  ive ...Delete() 
1360: 72 6f 75 74 69 6e 65 73 29 0a 2a 2a 20 77 69 74  routines).** wit
1370: 68 6f 75 74 20 65 66 66 65 63 74 69 6e 67 20 74  hout effecting t
1380: 68 65 20 6f 72 69 67 69 6e 61 6c 73 2e 0a 2a 2a  he originals..**
1390: 0a 2a 2a 20 4e 6f 74 65 2c 20 68 6f 77 65 76 65  .** Note, howeve
13a0: 72 2c 20 74 68 61 74 20 74 68 65 20 45 78 70 72  r, that the Expr
13b0: 2e 74 6f 6b 65 6e 2e 7a 20 61 6e 64 20 45 78 70  .token.z and Exp
13c0: 72 2e 73 70 61 6e 2e 7a 20 66 69 65 6c 64 73 20  r.span.z fields 
13d0: 70 6f 69 6e 74 20 74 6f 0a 2a 2a 20 73 74 72 69  point to.** stri
13e0: 6e 67 20 73 70 61 63 65 20 74 68 61 74 20 69 73  ng space that is
13f0: 20 61 6c 6c 6f 63 61 74 65 64 20 73 65 70 61 72   allocated separ
1400: 61 74 65 6c 79 20 66 72 6f 6d 20 74 68 65 20 65  ately from the e
1410: 78 70 72 65 73 73 69 6f 6e 20 74 72 65 65 0a 2a  xpression tree.*
1420: 2a 20 69 74 73 65 6c 66 2e 20 20 54 68 65 73 65  * itself.  These
1430: 20 72 6f 75 74 69 6e 65 73 20 64 6f 20 4e 4f 54   routines do NOT
1440: 20 64 75 70 6c 69 63 61 74 65 20 74 68 61 74 20   duplicate that 
1450: 73 74 72 69 6e 67 20 73 70 61 63 65 2e 0a 2a 2a  string space..**
1460: 0a 2a 2a 20 54 68 65 20 65 78 70 72 65 73 73 69  .** The expressi
1470: 6f 6e 20 6c 69 73 74 2c 20 49 44 2c 20 61 6e 64  on list, ID, and
1480: 20 73 6f 75 72 63 65 20 6c 69 73 74 73 20 72 65   source lists re
1490: 74 75 72 6e 20 62 79 20 73 71 6c 69 74 65 45 78  turn by sqliteEx
14a0: 70 72 4c 69 73 74 44 75 70 28 29 2c 0a 2a 2a 20  prListDup(),.** 
14b0: 73 71 6c 69 74 65 49 64 4c 69 73 74 44 75 70 28  sqliteIdListDup(
14c0: 29 2c 20 61 6e 64 20 73 71 6c 69 74 65 53 72 63  ), and sqliteSrc
14d0: 4c 69 73 74 44 75 70 28 29 20 63 61 6e 20 6e 6f  ListDup() can no
14e0: 74 20 62 65 20 66 75 72 74 68 65 72 20 65 78 70  t be further exp
14f0: 61 6e 64 65 64 20 0a 2a 2a 20 62 79 20 73 75 62  anded .** by sub
1500: 73 65 71 75 65 6e 74 20 63 61 6c 6c 73 20 74 6f  sequent calls to
1510: 20 73 71 6c 69 74 65 2a 4c 69 73 74 41 70 70 65   sqlite*ListAppe
1520: 6e 64 28 29 20 72 6f 75 74 69 6e 65 73 2e 0a 2a  nd() routines..*
1530: 2a 0a 2a 2a 20 41 6e 79 20 74 61 62 6c 65 73 20  *.** Any tables 
1540: 74 68 61 74 20 74 68 65 20 53 72 63 4c 69 73 74  that the SrcList
1550: 20 6d 69 67 68 74 20 70 6f 69 6e 74 20 74 6f 20   might point to 
1560: 61 72 65 20 6e 6f 74 20 64 75 70 6c 69 63 61 74  are not duplicat
1570: 65 64 2e 0a 2a 2f 0a 45 78 70 72 20 2a 73 71 6c  ed..*/.Expr *sql
1580: 69 74 65 45 78 70 72 44 75 70 28 45 78 70 72 20  iteExprDup(Expr 
1590: 2a 70 29 7b 0a 20 20 45 78 70 72 20 2a 70 4e 65  *p){.  Expr *pNe
15a0: 77 3b 0a 20 20 69 66 28 20 70 3d 3d 30 20 29 20  w;.  if( p==0 ) 
15b0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 70 4e 65 77  return 0;.  pNew
15c0: 20 3d 20 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28   = sqliteMalloc(
15d0: 20 73 69 7a 65 6f 66 28 2a 70 29 20 29 3b 0a 20   sizeof(*p) );. 
15e0: 20 69 66 28 20 70 4e 65 77 3d 3d 30 20 29 20 72   if( pNew==0 ) r
15f0: 65 74 75 72 6e 20 30 3b 0a 20 20 6d 65 6d 63 70  eturn 0;.  memcp
1600: 79 28 70 4e 65 77 2c 20 70 2c 20 73 69 7a 65 6f  y(pNew, p, sizeo
1610: 66 28 2a 70 4e 65 77 29 29 3b 0a 20 20 70 4e 65  f(*pNew));.  pNe
1620: 77 2d 3e 70 4c 65 66 74 20 3d 20 73 71 6c 69 74  w->pLeft = sqlit
1630: 65 45 78 70 72 44 75 70 28 70 2d 3e 70 4c 65 66  eExprDup(p->pLef
1640: 74 29 3b 0a 20 20 70 4e 65 77 2d 3e 70 52 69 67  t);.  pNew->pRig
1650: 68 74 20 3d 20 73 71 6c 69 74 65 45 78 70 72 44  ht = sqliteExprD
1660: 75 70 28 70 2d 3e 70 52 69 67 68 74 29 3b 0a 20  up(p->pRight);. 
1670: 20 70 4e 65 77 2d 3e 70 4c 69 73 74 20 3d 20 73   pNew->pList = s
1680: 71 6c 69 74 65 45 78 70 72 4c 69 73 74 44 75 70  qliteExprListDup
1690: 28 70 2d 3e 70 4c 69 73 74 29 3b 0a 20 20 70 4e  (p->pList);.  pN
16a0: 65 77 2d 3e 70 53 65 6c 65 63 74 20 3d 20 73 71  ew->pSelect = sq
16b0: 6c 69 74 65 53 65 6c 65 63 74 44 75 70 28 70 2d  liteSelectDup(p-
16c0: 3e 70 53 65 6c 65 63 74 29 3b 0a 20 20 72 65 74  >pSelect);.  ret
16d0: 75 72 6e 20 70 4e 65 77 3b 0a 7d 0a 45 78 70 72  urn pNew;.}.Expr
16e0: 4c 69 73 74 20 2a 73 71 6c 69 74 65 45 78 70 72  List *sqliteExpr
16f0: 4c 69 73 74 44 75 70 28 45 78 70 72 4c 69 73 74  ListDup(ExprList
1700: 20 2a 70 29 7b 0a 20 20 45 78 70 72 4c 69 73 74   *p){.  ExprList
1710: 20 2a 70 4e 65 77 3b 0a 20 20 69 6e 74 20 69 3b   *pNew;.  int i;
1720: 0a 20 20 69 66 28 20 70 3d 3d 30 20 29 20 72 65  .  if( p==0 ) re
1730: 74 75 72 6e 20 30 3b 0a 20 20 70 4e 65 77 20 3d  turn 0;.  pNew =
1740: 20 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 20 73   sqliteMalloc( s
1750: 69 7a 65 6f 66 28 2a 70 4e 65 77 29 20 29 3b 0a  izeof(*pNew) );.
1760: 20 20 69 66 28 20 70 4e 65 77 3d 3d 30 20 29 20    if( pNew==0 ) 
1770: 72 65 74 75 72 6e 20 30 3b 0a 20 20 70 4e 65 77  return 0;.  pNew
1780: 2d 3e 6e 45 78 70 72 20 3d 20 70 2d 3e 6e 45 78  ->nExpr = p->nEx
1790: 70 72 3b 0a 20 20 70 4e 65 77 2d 3e 61 20 3d 20  pr;.  pNew->a = 
17a0: 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 20 70 2d  sqliteMalloc( p-
17b0: 3e 6e 45 78 70 72 2a 73 69 7a 65 6f 66 28 70 2d  >nExpr*sizeof(p-
17c0: 3e 61 5b 30 5d 29 20 29 3b 0a 20 20 69 66 28 20  >a[0]) );.  if( 
17d0: 70 4e 65 77 2d 3e 61 3d 3d 30 20 29 20 72 65 74  pNew->a==0 ) ret
17e0: 75 72 6e 20 30 3b 0a 20 20 66 6f 72 28 69 3d 30  urn 0;.  for(i=0
17f0: 3b 20 69 3c 70 2d 3e 6e 45 78 70 72 3b 20 69 2b  ; i<p->nExpr; i+
1800: 2b 29 7b 0a 20 20 20 20 70 4e 65 77 2d 3e 61 5b  +){.    pNew->a[
1810: 69 5d 2e 70 45 78 70 72 20 3d 20 73 71 6c 69 74  i].pExpr = sqlit
1820: 65 45 78 70 72 44 75 70 28 70 2d 3e 61 5b 69 5d  eExprDup(p->a[i]
1830: 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 70 4e 65  .pExpr);.    pNe
1840: 77 2d 3e 61 5b 69 5d 2e 7a 4e 61 6d 65 20 3d 20  w->a[i].zName = 
1850: 73 71 6c 69 74 65 53 74 72 44 75 70 28 70 2d 3e  sqliteStrDup(p->
1860: 61 5b 69 5d 2e 7a 4e 61 6d 65 29 3b 0a 20 20 20  a[i].zName);.   
1870: 20 70 4e 65 77 2d 3e 61 5b 69 5d 2e 73 6f 72 74   pNew->a[i].sort
1880: 4f 72 64 65 72 20 3d 20 70 2d 3e 61 5b 69 5d 2e  Order = p->a[i].
1890: 73 6f 72 74 4f 72 64 65 72 3b 0a 20 20 20 20 70  sortOrder;.    p
18a0: 4e 65 77 2d 3e 61 5b 69 5d 2e 69 73 41 67 67 20  New->a[i].isAgg 
18b0: 3d 20 70 2d 3e 61 5b 69 5d 2e 69 73 41 67 67 3b  = p->a[i].isAgg;
18c0: 0a 20 20 20 20 70 4e 65 77 2d 3e 61 5b 69 5d 2e  .    pNew->a[i].
18d0: 64 6f 6e 65 20 3d 20 30 3b 0a 20 20 7d 0a 20 20  done = 0;.  }.  
18e0: 72 65 74 75 72 6e 20 70 4e 65 77 3b 0a 7d 0a 53  return pNew;.}.S
18f0: 72 63 4c 69 73 74 20 2a 73 71 6c 69 74 65 53 72  rcList *sqliteSr
1900: 63 4c 69 73 74 44 75 70 28 53 72 63 4c 69 73 74  cListDup(SrcList
1910: 20 2a 70 29 7b 0a 20 20 53 72 63 4c 69 73 74 20   *p){.  SrcList 
1920: 2a 70 4e 65 77 3b 0a 20 20 69 6e 74 20 69 3b 0a  *pNew;.  int i;.
1930: 20 20 69 66 28 20 70 3d 3d 30 20 29 20 72 65 74    if( p==0 ) ret
1940: 75 72 6e 20 30 3b 0a 20 20 70 4e 65 77 20 3d 20  urn 0;.  pNew = 
1950: 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 20 73 69  sqliteMalloc( si
1960: 7a 65 6f 66 28 2a 70 4e 65 77 29 20 29 3b 0a 20  zeof(*pNew) );. 
1970: 20 69 66 28 20 70 4e 65 77 3d 3d 30 20 29 20 72   if( pNew==0 ) r
1980: 65 74 75 72 6e 20 30 3b 0a 20 20 70 4e 65 77 2d  eturn 0;.  pNew-
1990: 3e 6e 53 72 63 20 3d 20 70 2d 3e 6e 53 72 63 3b  >nSrc = p->nSrc;
19a0: 0a 20 20 70 4e 65 77 2d 3e 61 20 3d 20 73 71 6c  .  pNew->a = sql
19b0: 69 74 65 4d 61 6c 6c 6f 63 28 20 70 2d 3e 6e 53  iteMalloc( p->nS
19c0: 72 63 2a 73 69 7a 65 6f 66 28 70 2d 3e 61 5b 30  rc*sizeof(p->a[0
19d0: 5d 29 20 29 3b 0a 20 20 69 66 28 20 70 4e 65 77  ]) );.  if( pNew
19e0: 2d 3e 61 3d 3d 30 20 26 26 20 70 2d 3e 6e 53 72  ->a==0 && p->nSr
19f0: 63 20 21 3d 20 30 20 29 20 72 65 74 75 72 6e 20  c != 0 ) return 
1a00: 30 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c  0;.  for(i=0; i<
1a10: 70 2d 3e 6e 53 72 63 3b 20 69 2b 2b 29 7b 0a 20  p->nSrc; i++){. 
1a20: 20 20 20 70 4e 65 77 2d 3e 61 5b 69 5d 2e 7a 4e     pNew->a[i].zN
1a30: 61 6d 65 20 3d 20 73 71 6c 69 74 65 53 74 72 44  ame = sqliteStrD
1a40: 75 70 28 70 2d 3e 61 5b 69 5d 2e 7a 4e 61 6d 65  up(p->a[i].zName
1a50: 29 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 61 5b 69  );.    pNew->a[i
1a60: 5d 2e 7a 41 6c 69 61 73 20 3d 20 73 71 6c 69 74  ].zAlias = sqlit
1a70: 65 53 74 72 44 75 70 28 70 2d 3e 61 5b 69 5d 2e  eStrDup(p->a[i].
1a80: 7a 41 6c 69 61 73 29 3b 0a 20 20 20 20 70 4e 65  zAlias);.    pNe
1a90: 77 2d 3e 61 5b 69 5d 2e 6a 6f 69 6e 74 79 70 65  w->a[i].jointype
1aa0: 20 3d 20 70 2d 3e 61 5b 69 5d 2e 6a 6f 69 6e 74   = p->a[i].joint
1ab0: 79 70 65 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 61  ype;.    pNew->a
1ac0: 5b 69 5d 2e 70 54 61 62 20 3d 20 30 3b 0a 20 20  [i].pTab = 0;.  
1ad0: 20 20 70 4e 65 77 2d 3e 61 5b 69 5d 2e 70 53 65    pNew->a[i].pSe
1ae0: 6c 65 63 74 20 3d 20 73 71 6c 69 74 65 53 65 6c  lect = sqliteSel
1af0: 65 63 74 44 75 70 28 70 2d 3e 61 5b 69 5d 2e 70  ectDup(p->a[i].p
1b00: 53 65 6c 65 63 74 29 3b 0a 20 20 20 20 70 4e 65  Select);.    pNe
1b10: 77 2d 3e 61 5b 69 5d 2e 70 4f 6e 20 3d 20 73 71  w->a[i].pOn = sq
1b20: 6c 69 74 65 45 78 70 72 44 75 70 28 70 2d 3e 61  liteExprDup(p->a
1b30: 5b 69 5d 2e 70 4f 6e 29 3b 0a 20 20 20 20 70 4e  [i].pOn);.    pN
1b40: 65 77 2d 3e 61 5b 69 5d 2e 70 55 73 69 6e 67 20  ew->a[i].pUsing 
1b50: 3d 20 73 71 6c 69 74 65 49 64 4c 69 73 74 44 75  = sqliteIdListDu
1b60: 70 28 70 2d 3e 61 5b 69 5d 2e 70 55 73 69 6e 67  p(p->a[i].pUsing
1b70: 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20  );.  }.  return 
1b80: 70 4e 65 77 3b 0a 7d 0a 49 64 4c 69 73 74 20 2a  pNew;.}.IdList *
1b90: 73 71 6c 69 74 65 49 64 4c 69 73 74 44 75 70 28  sqliteIdListDup(
1ba0: 49 64 4c 69 73 74 20 2a 70 29 7b 0a 20 20 49 64  IdList *p){.  Id
1bb0: 4c 69 73 74 20 2a 70 4e 65 77 3b 0a 20 20 69 6e  List *pNew;.  in
1bc0: 74 20 69 3b 0a 20 20 69 66 28 20 70 3d 3d 30 20  t i;.  if( p==0 
1bd0: 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 70 4e  ) return 0;.  pN
1be0: 65 77 20 3d 20 73 71 6c 69 74 65 4d 61 6c 6c 6f  ew = sqliteMallo
1bf0: 63 28 20 73 69 7a 65 6f 66 28 2a 70 4e 65 77 29  c( sizeof(*pNew)
1c00: 20 29 3b 0a 20 20 69 66 28 20 70 4e 65 77 3d 3d   );.  if( pNew==
1c10: 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  0 ) return 0;.  
1c20: 70 4e 65 77 2d 3e 6e 49 64 20 3d 20 70 2d 3e 6e  pNew->nId = p->n
1c30: 49 64 3b 0a 20 20 70 4e 65 77 2d 3e 61 20 3d 20  Id;.  pNew->a = 
1c40: 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 20 70 2d  sqliteMalloc( p-
1c50: 3e 6e 49 64 2a 73 69 7a 65 6f 66 28 70 2d 3e 61  >nId*sizeof(p->a
1c60: 5b 30 5d 29 20 29 3b 0a 20 20 69 66 28 20 70 4e  [0]) );.  if( pN
1c70: 65 77 2d 3e 61 3d 3d 30 20 29 20 72 65 74 75 72  ew->a==0 ) retur
1c80: 6e 20 30 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20  n 0;.  for(i=0; 
1c90: 69 3c 70 2d 3e 6e 49 64 3b 20 69 2b 2b 29 7b 0a  i<p->nId; i++){.
1ca0: 20 20 20 20 70 4e 65 77 2d 3e 61 5b 69 5d 2e 7a      pNew->a[i].z
1cb0: 4e 61 6d 65 20 3d 20 73 71 6c 69 74 65 53 74 72  Name = sqliteStr
1cc0: 44 75 70 28 70 2d 3e 61 5b 69 5d 2e 7a 4e 61 6d  Dup(p->a[i].zNam
1cd0: 65 29 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 61 5b  e);.    pNew->a[
1ce0: 69 5d 2e 69 64 78 20 3d 20 70 2d 3e 61 5b 69 5d  i].idx = p->a[i]
1cf0: 2e 69 64 78 3b 0a 20 20 7d 0a 20 20 72 65 74 75  .idx;.  }.  retu
1d00: 72 6e 20 70 4e 65 77 3b 0a 7d 0a 53 65 6c 65 63  rn pNew;.}.Selec
1d10: 74 20 2a 73 71 6c 69 74 65 53 65 6c 65 63 74 44  t *sqliteSelectD
1d20: 75 70 28 53 65 6c 65 63 74 20 2a 70 29 7b 0a 20  up(Select *p){. 
1d30: 20 53 65 6c 65 63 74 20 2a 70 4e 65 77 3b 0a 20   Select *pNew;. 
1d40: 20 69 66 28 20 70 3d 3d 30 20 29 20 72 65 74 75   if( p==0 ) retu
1d50: 72 6e 20 30 3b 0a 20 20 70 4e 65 77 20 3d 20 73  rn 0;.  pNew = s
1d60: 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 20 73 69 7a  qliteMalloc( siz
1d70: 65 6f 66 28 2a 70 29 20 29 3b 0a 20 20 69 66 28  eof(*p) );.  if(
1d80: 20 70 4e 65 77 3d 3d 30 20 29 20 72 65 74 75 72   pNew==0 ) retur
1d90: 6e 20 30 3b 0a 20 20 70 4e 65 77 2d 3e 69 73 44  n 0;.  pNew->isD
1da0: 69 73 74 69 6e 63 74 20 3d 20 70 2d 3e 69 73 44  istinct = p->isD
1db0: 69 73 74 69 6e 63 74 3b 0a 20 20 70 4e 65 77 2d  istinct;.  pNew-
1dc0: 3e 70 45 4c 69 73 74 20 3d 20 73 71 6c 69 74 65  >pEList = sqlite
1dd0: 45 78 70 72 4c 69 73 74 44 75 70 28 70 2d 3e 70  ExprListDup(p->p
1de0: 45 4c 69 73 74 29 3b 0a 20 20 70 4e 65 77 2d 3e  EList);.  pNew->
1df0: 70 53 72 63 20 3d 20 73 71 6c 69 74 65 53 72 63  pSrc = sqliteSrc
1e00: 4c 69 73 74 44 75 70 28 70 2d 3e 70 53 72 63 29  ListDup(p->pSrc)
1e10: 3b 0a 20 20 70 4e 65 77 2d 3e 70 57 68 65 72 65  ;.  pNew->pWhere
1e20: 20 3d 20 73 71 6c 69 74 65 45 78 70 72 44 75 70   = sqliteExprDup
1e30: 28 70 2d 3e 70 57 68 65 72 65 29 3b 0a 20 20 70  (p->pWhere);.  p
1e40: 4e 65 77 2d 3e 70 47 72 6f 75 70 42 79 20 3d 20  New->pGroupBy = 
1e50: 73 71 6c 69 74 65 45 78 70 72 4c 69 73 74 44 75  sqliteExprListDu
1e60: 70 28 70 2d 3e 70 47 72 6f 75 70 42 79 29 3b 0a  p(p->pGroupBy);.
1e70: 20 20 70 4e 65 77 2d 3e 70 48 61 76 69 6e 67 20    pNew->pHaving 
1e80: 3d 20 73 71 6c 69 74 65 45 78 70 72 44 75 70 28  = sqliteExprDup(
1e90: 70 2d 3e 70 48 61 76 69 6e 67 29 3b 0a 20 20 70  p->pHaving);.  p
1ea0: 4e 65 77 2d 3e 70 4f 72 64 65 72 42 79 20 3d 20  New->pOrderBy = 
1eb0: 73 71 6c 69 74 65 45 78 70 72 4c 69 73 74 44 75  sqliteExprListDu
1ec0: 70 28 70 2d 3e 70 4f 72 64 65 72 42 79 29 3b 0a  p(p->pOrderBy);.
1ed0: 20 20 70 4e 65 77 2d 3e 6f 70 20 3d 20 70 2d 3e    pNew->op = p->
1ee0: 6f 70 3b 0a 20 20 70 4e 65 77 2d 3e 70 50 72 69  op;.  pNew->pPri
1ef0: 6f 72 20 3d 20 73 71 6c 69 74 65 53 65 6c 65 63  or = sqliteSelec
1f00: 74 44 75 70 28 70 2d 3e 70 50 72 69 6f 72 29 3b  tDup(p->pPrior);
1f10: 0a 20 20 70 4e 65 77 2d 3e 6e 4c 69 6d 69 74 20  .  pNew->nLimit 
1f20: 3d 20 70 2d 3e 6e 4c 69 6d 69 74 3b 0a 20 20 70  = p->nLimit;.  p
1f30: 4e 65 77 2d 3e 6e 4f 66 66 73 65 74 20 3d 20 70  New->nOffset = p
1f40: 2d 3e 6e 4f 66 66 73 65 74 3b 0a 20 20 70 4e 65  ->nOffset;.  pNe
1f50: 77 2d 3e 7a 53 65 6c 65 63 74 20 3d 20 30 3b 0a  w->zSelect = 0;.
1f60: 20 20 72 65 74 75 72 6e 20 70 4e 65 77 3b 0a 7d    return pNew;.}
1f70: 0a 0a 0a 2f 2a 0a 2a 2a 20 41 64 64 20 61 20 6e  .../*.** Add a n
1f80: 65 77 20 65 6c 65 6d 65 6e 74 20 74 6f 20 74 68  ew element to th
1f90: 65 20 65 6e 64 20 6f 66 20 61 6e 20 65 78 70 72  e end of an expr
1fa0: 65 73 73 69 6f 6e 20 6c 69 73 74 2e 20 20 49 66  ession list.  If
1fb0: 20 70 4c 69 73 74 20 69 73 0a 2a 2a 20 69 6e 69   pList is.** ini
1fc0: 74 69 61 6c 6c 79 20 4e 55 4c 4c 2c 20 74 68 65  tially NULL, the
1fd0: 6e 20 63 72 65 61 74 65 20 61 20 6e 65 77 20 65  n create a new e
1fe0: 78 70 72 65 73 73 69 6f 6e 20 6c 69 73 74 2e 0a  xpression list..
1ff0: 2a 2f 0a 45 78 70 72 4c 69 73 74 20 2a 73 71 6c  */.ExprList *sql
2000: 69 74 65 45 78 70 72 4c 69 73 74 41 70 70 65 6e  iteExprListAppen
2010: 64 28 45 78 70 72 4c 69 73 74 20 2a 70 4c 69 73  d(ExprList *pLis
2020: 74 2c 20 45 78 70 72 20 2a 70 45 78 70 72 2c 20  t, Expr *pExpr, 
2030: 54 6f 6b 65 6e 20 2a 70 4e 61 6d 65 29 7b 0a 20  Token *pName){. 
2040: 20 69 6e 74 20 69 3b 0a 20 20 69 66 28 20 70 4c   int i;.  if( pL
2050: 69 73 74 3d 3d 30 20 29 7b 0a 20 20 20 20 70 4c  ist==0 ){.    pL
2060: 69 73 74 20 3d 20 73 71 6c 69 74 65 4d 61 6c 6c  ist = sqliteMall
2070: 6f 63 28 20 73 69 7a 65 6f 66 28 45 78 70 72 4c  oc( sizeof(ExprL
2080: 69 73 74 29 20 29 3b 0a 20 20 20 20 69 66 28 20  ist) );.    if( 
2090: 70 4c 69 73 74 3d 3d 30 20 29 7b 0a 20 20 20 20  pList==0 ){.    
20a0: 20 20 73 71 6c 69 74 65 45 78 70 72 44 65 6c 65    sqliteExprDele
20b0: 74 65 28 70 45 78 70 72 29 3b 0a 20 20 20 20 20  te(pExpr);.     
20c0: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d   return 0;.    }
20d0: 0a 20 20 7d 0a 20 20 69 66 28 20 28 70 4c 69 73  .  }.  if( (pLis
20e0: 74 2d 3e 6e 45 78 70 72 20 26 20 37 29 3d 3d 30  t->nExpr & 7)==0
20f0: 20 29 7b 0a 20 20 20 20 69 6e 74 20 6e 20 3d 20   ){.    int n = 
2100: 70 4c 69 73 74 2d 3e 6e 45 78 70 72 20 2b 20 38  pList->nExpr + 8
2110: 3b 0a 20 20 20 20 73 74 72 75 63 74 20 45 78 70  ;.    struct Exp
2120: 72 4c 69 73 74 5f 69 74 65 6d 20 2a 61 3b 0a 20  rList_item *a;. 
2130: 20 20 20 61 20 3d 20 73 71 6c 69 74 65 52 65 61     a = sqliteRea
2140: 6c 6c 6f 63 28 70 4c 69 73 74 2d 3e 61 2c 20 6e  lloc(pList->a, n
2150: 2a 73 69 7a 65 6f 66 28 70 4c 69 73 74 2d 3e 61  *sizeof(pList->a
2160: 5b 30 5d 29 29 3b 0a 20 20 20 20 69 66 28 20 61  [0]));.    if( a
2170: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 73 71 6c  ==0 ){.      sql
2180: 69 74 65 45 78 70 72 44 65 6c 65 74 65 28 70 45  iteExprDelete(pE
2190: 78 70 72 29 3b 0a 20 20 20 20 20 20 72 65 74 75  xpr);.      retu
21a0: 72 6e 20 70 4c 69 73 74 3b 0a 20 20 20 20 7d 0a  rn pList;.    }.
21b0: 20 20 20 20 70 4c 69 73 74 2d 3e 61 20 3d 20 61      pList->a = a
21c0: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70 45 78 70  ;.  }.  if( pExp
21d0: 72 20 7c 7c 20 70 4e 61 6d 65 20 29 7b 0a 20 20  r || pName ){.  
21e0: 20 20 69 20 3d 20 70 4c 69 73 74 2d 3e 6e 45 78    i = pList->nEx
21f0: 70 72 2b 2b 3b 0a 20 20 20 20 70 4c 69 73 74 2d  pr++;.    pList-
2200: 3e 61 5b 69 5d 2e 70 45 78 70 72 20 3d 20 70 45  >a[i].pExpr = pE
2210: 78 70 72 3b 0a 20 20 20 20 70 4c 69 73 74 2d 3e  xpr;.    pList->
2220: 61 5b 69 5d 2e 7a 4e 61 6d 65 20 3d 20 30 3b 0a  a[i].zName = 0;.
2230: 20 20 20 20 69 66 28 20 70 4e 61 6d 65 20 29 7b      if( pName ){
2240: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 53 65 74  .      sqliteSet
2250: 4e 53 74 72 69 6e 67 28 26 70 4c 69 73 74 2d 3e  NString(&pList->
2260: 61 5b 69 5d 2e 7a 4e 61 6d 65 2c 20 70 4e 61 6d  a[i].zName, pNam
2270: 65 2d 3e 7a 2c 20 70 4e 61 6d 65 2d 3e 6e 2c 20  e->z, pName->n, 
2280: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
2290: 44 65 71 75 6f 74 65 28 70 4c 69 73 74 2d 3e 61  Dequote(pList->a
22a0: 5b 69 5d 2e 7a 4e 61 6d 65 29 3b 0a 20 20 20 20  [i].zName);.    
22b0: 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 70  }.  }.  return p
22c0: 4c 69 73 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 44  List;.}../*.** D
22d0: 65 6c 65 74 65 20 61 6e 20 65 6e 74 69 72 65 20  elete an entire 
22e0: 65 78 70 72 65 73 73 69 6f 6e 20 6c 69 73 74 2e  expression list.
22f0: 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 45  .*/.void sqliteE
2300: 78 70 72 4c 69 73 74 44 65 6c 65 74 65 28 45 78  xprListDelete(Ex
2310: 70 72 4c 69 73 74 20 2a 70 4c 69 73 74 29 7b 0a  prList *pList){.
2320: 20 20 69 6e 74 20 69 3b 0a 20 20 69 66 28 20 70    int i;.  if( p
2330: 4c 69 73 74 3d 3d 30 20 29 20 72 65 74 75 72 6e  List==0 ) return
2340: 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70  ;.  for(i=0; i<p
2350: 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b  List->nExpr; i++
2360: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 45 78 70  ){.    sqliteExp
2370: 72 44 65 6c 65 74 65 28 70 4c 69 73 74 2d 3e 61  rDelete(pList->a
2380: 5b 69 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20  [i].pExpr);.    
2390: 73 71 6c 69 74 65 46 72 65 65 28 70 4c 69 73 74  sqliteFree(pList
23a0: 2d 3e 61 5b 69 5d 2e 7a 4e 61 6d 65 29 3b 0a 20  ->a[i].zName);. 
23b0: 20 7d 0a 20 20 73 71 6c 69 74 65 46 72 65 65 28   }.  sqliteFree(
23c0: 70 4c 69 73 74 2d 3e 61 29 3b 0a 20 20 73 71 6c  pList->a);.  sql
23d0: 69 74 65 46 72 65 65 28 70 4c 69 73 74 29 3b 0a  iteFree(pList);.
23e0: 7d 0a 0a 2f 2a 0a 2a 2a 20 57 61 6c 6b 20 61 6e  }../*.** Walk an
23f0: 20 65 78 70 72 65 73 73 69 6f 6e 20 74 72 65 65   expression tree
2400: 2e 20 20 52 65 74 75 72 6e 20 31 20 69 66 20 74  .  Return 1 if t
2410: 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20 69 73  he expression is
2420: 20 63 6f 6e 73 74 61 6e 74 0a 2a 2a 20 61 6e 64   constant.** and
2430: 20 30 20 69 66 20 69 74 20 69 6e 76 6f 6c 76 65   0 if it involve
2440: 73 20 76 61 72 69 61 62 6c 65 73 2e 0a 2a 2a 0a  s variables..**.
2450: 2a 2a 20 46 6f 72 20 74 68 65 20 70 75 72 70 6f  ** For the purpo
2460: 73 65 73 20 6f 66 20 74 68 69 73 20 66 75 6e 63  ses of this func
2470: 74 69 6f 6e 2c 20 61 20 64 6f 75 62 6c 65 2d 71  tion, a double-q
2480: 75 6f 74 65 64 20 73 74 72 69 6e 67 20 28 65 78  uoted string (ex
2490: 3a 20 22 61 62 63 22 29 0a 2a 2a 20 69 73 20 63  : "abc").** is c
24a0: 6f 6e 73 69 64 65 72 65 64 20 61 20 76 61 72 69  onsidered a vari
24b0: 61 62 6c 65 20 62 75 74 20 61 20 73 69 6e 67 6c  able but a singl
24c0: 65 2d 71 75 6f 74 65 64 20 73 74 72 69 6e 67 20  e-quoted string 
24d0: 28 65 78 3a 20 27 61 62 63 27 29 20 69 73 0a 2a  (ex: 'abc') is.*
24e0: 2a 20 61 20 63 6f 6e 73 74 61 6e 74 2e 0a 2a 2f  * a constant..*/
24f0: 0a 69 6e 74 20 73 71 6c 69 74 65 45 78 70 72 49  .int sqliteExprI
2500: 73 43 6f 6e 73 74 61 6e 74 28 45 78 70 72 20 2a  sConstant(Expr *
2510: 70 29 7b 0a 20 20 73 77 69 74 63 68 28 20 70 2d  p){.  switch( p-
2520: 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65 20  >op ){.    case 
2530: 54 4b 5f 49 44 3a 0a 20 20 20 20 63 61 73 65 20  TK_ID:.    case 
2540: 54 4b 5f 43 4f 4c 55 4d 4e 3a 0a 20 20 20 20 63  TK_COLUMN:.    c
2550: 61 73 65 20 54 4b 5f 44 4f 54 3a 0a 20 20 20 20  ase TK_DOT:.    
2560: 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20    return 0;.    
2570: 63 61 73 65 20 54 4b 5f 53 54 52 49 4e 47 3a 0a  case TK_STRING:.
2580: 20 20 20 20 20 20 72 65 74 75 72 6e 20 70 2d 3e        return p->
2590: 74 6f 6b 65 6e 2e 7a 5b 30 5d 3d 3d 27 5c 27 27  token.z[0]=='\''
25a0: 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49 4e  ;.    case TK_IN
25b0: 54 45 47 45 52 3a 0a 20 20 20 20 63 61 73 65 20  TEGER:.    case 
25c0: 54 4b 5f 46 4c 4f 41 54 3a 0a 20 20 20 20 20 20  TK_FLOAT:.      
25d0: 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 64 65  return 1;.    de
25e0: 66 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20 69  fault: {.      i
25f0: 66 28 20 70 2d 3e 70 4c 65 66 74 20 26 26 20 21  f( p->pLeft && !
2600: 73 71 6c 69 74 65 45 78 70 72 49 73 43 6f 6e 73  sqliteExprIsCons
2610: 74 61 6e 74 28 70 2d 3e 70 4c 65 66 74 29 20 29  tant(p->pLeft) )
2620: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20   return 0;.     
2630: 20 69 66 28 20 70 2d 3e 70 52 69 67 68 74 20 26   if( p->pRight &
2640: 26 20 21 73 71 6c 69 74 65 45 78 70 72 49 73 43  & !sqliteExprIsC
2650: 6f 6e 73 74 61 6e 74 28 70 2d 3e 70 52 69 67 68  onstant(p->pRigh
2660: 74 29 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20  t) ) return 0;. 
2670: 20 20 20 20 20 69 66 28 20 70 2d 3e 70 4c 69 73       if( p->pLis
2680: 74 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74  t ){.        int
2690: 20 69 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28   i;.        for(
26a0: 69 3d 30 3b 20 69 3c 70 2d 3e 70 4c 69 73 74 2d  i=0; i<p->pList-
26b0: 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a 20 20  >nExpr; i++){.  
26c0: 20 20 20 20 20 20 20 20 69 66 28 20 21 73 71 6c          if( !sql
26d0: 69 74 65 45 78 70 72 49 73 43 6f 6e 73 74 61 6e  iteExprIsConstan
26e0: 74 28 70 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d  t(p->pList->a[i]
26f0: 2e 70 45 78 70 72 29 20 29 20 72 65 74 75 72 6e  .pExpr) ) return
2700: 20 30 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20   0;.        }.  
2710: 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65 74 75      }.      retu
2720: 72 6e 20 70 2d 3e 70 4c 65 66 74 21 3d 30 20 7c  rn p->pLeft!=0 |
2730: 7c 20 70 2d 3e 70 52 69 67 68 74 21 3d 30 20 7c  | p->pRight!=0 |
2740: 7c 20 28 70 2d 3e 70 4c 69 73 74 20 26 26 20 70  | (p->pList && p
2750: 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 3e 30  ->pList->nExpr>0
2760: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72  );.    }.  }.  r
2770: 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a  eturn 0;.}../*.*
2780: 2a 20 49 66 20 74 68 65 20 67 69 76 65 6e 20 65  * If the given e
2790: 78 70 72 65 73 73 69 6f 6e 20 63 6f 64 65 73 20  xpression codes 
27a0: 61 20 63 6f 6e 73 74 61 6e 74 20 69 6e 74 65 67  a constant integ
27b0: 65 72 2c 20 72 65 74 75 72 6e 20 31 20 61 6e 64  er, return 1 and
27c0: 20 70 75 74 0a 2a 2a 20 74 68 65 20 76 61 6c 75   put.** the valu
27d0: 65 20 6f 66 20 74 68 65 20 69 6e 74 65 67 65 72  e of the integer
27e0: 20 69 6e 20 2a 70 56 61 6c 75 65 2e 20 20 49 66   in *pValue.  If
27f0: 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20   the expression 
2800: 69 73 20 6e 6f 74 20 61 6e 0a 2a 2a 20 69 6e 74  is not an.** int
2810: 65 67 65 72 2c 20 72 65 74 75 72 6e 20 30 20 61  eger, return 0 a
2820: 6e 64 20 6c 65 61 76 65 20 2a 70 56 61 6c 75 65  nd leave *pValue
2830: 20 75 6e 63 68 61 6e 67 65 64 2e 0a 2a 2f 0a 69   unchanged..*/.i
2840: 6e 74 20 73 71 6c 69 74 65 45 78 70 72 49 73 49  nt sqliteExprIsI
2850: 6e 74 65 67 65 72 28 45 78 70 72 20 2a 70 2c 20  nteger(Expr *p, 
2860: 69 6e 74 20 2a 70 56 61 6c 75 65 29 7b 0a 20 20  int *pValue){.  
2870: 73 77 69 74 63 68 28 20 70 2d 3e 6f 70 20 29 7b  switch( p->op ){
2880: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49 4e 54  .    case TK_INT
2890: 45 47 45 52 3a 20 7b 0a 20 20 20 20 20 20 2a 70  EGER: {.      *p
28a0: 56 61 6c 75 65 20 3d 20 61 74 6f 69 28 70 2d 3e  Value = atoi(p->
28b0: 74 6f 6b 65 6e 2e 7a 29 3b 0a 20 20 20 20 20 20  token.z);.      
28c0: 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 7d 0a  return 1;.    }.
28d0: 20 20 20 20 63 61 73 65 20 54 4b 5f 53 54 52 49      case TK_STRI
28e0: 4e 47 3a 20 7b 0a 20 20 20 20 20 20 63 6f 6e 73  NG: {.      cons
28f0: 74 20 63 68 61 72 20 2a 7a 20 3d 20 70 2d 3e 74  t char *z = p->t
2900: 6f 6b 65 6e 2e 7a 3b 0a 20 20 20 20 20 20 69 6e  oken.z;.      in
2910: 74 20 6e 20 3d 20 70 2d 3e 74 6f 6b 65 6e 2e 6e  t n = p->token.n
2920: 3b 0a 20 20 20 20 20 20 69 66 28 20 6e 3e 30 20  ;.      if( n>0 
2930: 26 26 20 7a 5b 30 5d 3d 3d 27 2d 27 20 29 7b 20  && z[0]=='-' ){ 
2940: 7a 2b 2b 3b 20 6e 2d 2d 3b 20 7d 0a 20 20 20 20  z++; n--; }.    
2950: 20 20 77 68 69 6c 65 28 20 6e 3e 30 20 26 26 20    while( n>0 && 
2960: 2a 7a 20 26 26 20 69 73 64 69 67 69 74 28 2a 7a  *z && isdigit(*z
2970: 29 20 29 7b 20 7a 2b 2b 3b 20 6e 2d 2d 3b 20 7d  ) ){ z++; n--; }
2980: 0a 20 20 20 20 20 20 69 66 28 20 6e 3d 3d 30 20  .      if( n==0 
2990: 29 7b 0a 20 20 20 20 20 20 20 20 2a 70 56 61 6c  ){.        *pVal
29a0: 75 65 20 3d 20 61 74 6f 69 28 70 2d 3e 74 6f 6b  ue = atoi(p->tok
29b0: 65 6e 2e 7a 29 3b 0a 20 20 20 20 20 20 20 20 72  en.z);.        r
29c0: 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 20 20 7d  eturn 1;.      }
29d0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
29e0: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f    }.    case TK_
29f0: 55 4d 49 4e 55 53 3a 20 7b 0a 20 20 20 20 20 20  UMINUS: {.      
2a00: 69 6e 74 20 76 3b 0a 20 20 20 20 20 20 69 66 28  int v;.      if(
2a10: 20 73 71 6c 69 74 65 45 78 70 72 49 73 49 6e 74   sqliteExprIsInt
2a20: 65 67 65 72 28 70 2d 3e 70 4c 65 66 74 2c 20 26  eger(p->pLeft, &
2a30: 76 29 20 29 7b 0a 20 20 20 20 20 20 20 20 2a 70  v) ){.        *p
2a40: 56 61 6c 75 65 20 3d 20 2d 76 3b 0a 20 20 20 20  Value = -v;.    
2a50: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
2a60: 20 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65 61      }.      brea
2a70: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 64 65 66  k;.    }.    def
2a80: 61 75 6c 74 3a 20 62 72 65 61 6b 3b 0a 20 20 7d  ault: break;.  }
2a90: 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a  .  return 0;.}..
2aa0: 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 54 52 55  /*.** Return TRU
2ab0: 45 20 69 66 20 74 68 65 20 67 69 76 65 6e 20 73  E if the given s
2ac0: 74 72 69 6e 67 20 69 73 20 61 20 72 6f 77 2d 69  tring is a row-i
2ad0: 64 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 2e 0a 2a  d column name..*
2ae0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 73 71 6c  /.static int sql
2af0: 69 74 65 49 73 52 6f 77 69 64 28 63 6f 6e 73 74  iteIsRowid(const
2b00: 20 63 68 61 72 20 2a 7a 29 7b 0a 20 20 69 66 28   char *z){.  if(
2b10: 20 73 71 6c 69 74 65 53 74 72 49 43 6d 70 28 7a   sqliteStrICmp(z
2b20: 2c 20 22 5f 52 4f 57 49 44 5f 22 29 3d 3d 30 20  , "_ROWID_")==0 
2b30: 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 69 66  ) return 1;.  if
2b40: 28 20 73 71 6c 69 74 65 53 74 72 49 43 6d 70 28  ( sqliteStrICmp(
2b50: 7a 2c 20 22 52 4f 57 49 44 22 29 3d 3d 30 20 29  z, "ROWID")==0 )
2b60: 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 69 66 28   return 1;.  if(
2b70: 20 73 71 6c 69 74 65 53 74 72 49 43 6d 70 28 7a   sqliteStrICmp(z
2b80: 2c 20 22 4f 49 44 22 29 3d 3d 30 20 29 20 72 65  , "OID")==0 ) re
2b90: 74 75 72 6e 20 31 3b 0a 20 20 72 65 74 75 72 6e  turn 1;.  return
2ba0: 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69   0;.}../*.** Thi
2bb0: 73 20 72 6f 75 74 69 6e 65 20 77 61 6c 6b 73 20  s routine walks 
2bc0: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 74 72  an expression tr
2bd0: 65 65 20 61 6e 64 20 72 65 73 6f 6c 76 65 73 20  ee and resolves 
2be0: 72 65 66 65 72 65 6e 63 65 73 20 74 6f 0a 2a 2a  references to.**
2bf0: 20 74 61 62 6c 65 20 63 6f 6c 75 6d 6e 73 2e 20   table columns. 
2c00: 20 4e 6f 64 65 73 20 6f 66 20 74 68 65 20 66 6f   Nodes of the fo
2c10: 72 6d 20 49 44 2e 49 44 20 6f 72 20 49 44 20 72  rm ID.ID or ID r
2c20: 65 73 6f 6c 76 65 20 69 6e 74 6f 20 61 6e 0a 2a  esolve into an.*
2c30: 2a 20 69 6e 64 65 78 20 74 6f 20 74 68 65 20 74  * index to the t
2c40: 61 62 6c 65 20 69 6e 20 74 68 65 20 74 61 62 6c  able in the tabl
2c50: 65 20 6c 69 73 74 20 61 6e 64 20 61 20 63 6f 6c  e list and a col
2c60: 75 6d 6e 20 6f 66 66 73 65 74 2e 20 20 54 68 65  umn offset.  The
2c70: 20 0a 2a 2a 20 45 78 70 72 2e 6f 70 63 6f 64 65   .** Expr.opcode
2c80: 20 66 6f 72 20 73 75 63 68 20 6e 6f 64 65 73 20   for such nodes 
2c90: 69 73 20 63 68 61 6e 67 65 64 20 74 6f 20 54 4b  is changed to TK
2ca0: 5f 43 4f 4c 55 4d 4e 2e 20 20 54 68 65 20 45 78  _COLUMN.  The Ex
2cb0: 70 72 2e 69 54 61 62 6c 65 0a 2a 2a 20 76 61 6c  pr.iTable.** val
2cc0: 75 65 20 69 73 20 63 68 61 6e 67 65 64 20 74 6f  ue is changed to
2cd0: 20 74 68 65 20 69 6e 64 65 78 20 6f 66 20 74 68   the index of th
2ce0: 65 20 72 65 66 65 72 65 6e 63 65 64 20 74 61 62  e referenced tab
2cf0: 6c 65 20 69 6e 20 70 54 61 62 4c 69 73 74 0a 2a  le in pTabList.*
2d00: 2a 20 70 6c 75 73 20 74 68 65 20 22 62 61 73 65  * plus the "base
2d10: 22 20 76 61 6c 75 65 2e 20 20 54 68 65 20 62 61  " value.  The ba
2d20: 73 65 20 76 61 6c 75 65 20 77 69 6c 6c 20 75 6c  se value will ul
2d30: 74 69 6d 61 74 65 6c 79 20 62 65 63 6f 6d 65 20  timately become 
2d40: 74 68 65 0a 2a 2a 20 56 44 42 45 20 63 75 72 73  the.** VDBE curs
2d50: 6f 72 20 6e 75 6d 62 65 72 20 66 6f 72 20 61 20  or number for a 
2d60: 63 75 72 73 6f 72 20 74 68 61 74 20 69 73 20 70  cursor that is p
2d70: 6f 69 6e 74 69 6e 67 20 69 6e 74 6f 20 74 68 65  ointing into the
2d80: 20 72 65 66 65 72 65 6e 63 65 64 0a 2a 2a 20 74   referenced.** t
2d90: 61 62 6c 65 2e 20 20 54 68 65 20 45 78 70 72 2e  able.  The Expr.
2da0: 69 43 6f 6c 75 6d 6e 20 76 61 6c 75 65 20 69 73  iColumn value is
2db0: 20 63 68 61 6e 67 65 64 20 74 6f 20 74 68 65 20   changed to the 
2dc0: 69 6e 64 65 78 20 6f 66 20 74 68 65 20 63 6f 6c  index of the col
2dd0: 75 6d 6e 20 0a 2a 2a 20 6f 66 20 74 68 65 20 72  umn .** of the r
2de0: 65 66 65 72 65 6e 63 65 64 20 74 61 62 6c 65 2e  eferenced table.
2df0: 20 20 54 68 65 20 45 78 70 72 2e 69 43 6f 6c 75    The Expr.iColu
2e00: 6d 6e 20 76 61 6c 75 65 20 66 6f 72 20 74 68 65  mn value for the
2e10: 20 73 70 65 63 69 61 6c 0a 2a 2a 20 52 4f 57 49   special.** ROWI
2e20: 44 20 63 6f 6c 75 6d 6e 20 69 73 20 2d 31 2e 20  D column is -1. 
2e30: 20 41 6e 79 20 49 4e 54 45 47 45 52 20 50 52 49   Any INTEGER PRI
2e40: 4d 41 52 59 20 4b 45 59 20 63 6f 6c 75 6d 6e 20  MARY KEY column 
2e50: 69 73 20 74 72 69 65 64 20 61 73 20 61 6e 0a 2a  is tried as an.*
2e60: 2a 20 61 6c 69 61 73 20 66 6f 72 20 52 4f 57 49  * alias for ROWI
2e70: 44 2e 0a 2a 2a 0a 2a 2a 20 57 65 20 61 6c 73 6f  D..**.** We also
2e80: 20 63 68 65 63 6b 20 66 6f 72 20 69 6e 73 74 61   check for insta
2e90: 6e 63 65 73 20 6f 66 20 74 68 65 20 49 4e 20 6f  nces of the IN o
2ea0: 70 65 72 61 74 6f 72 2e 20 20 49 4e 20 63 6f 6d  perator.  IN com
2eb0: 65 73 20 69 6e 20 74 77 6f 0a 2a 2a 20 66 6f 72  es in two.** for
2ec0: 6d 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 20 20  ms:.**.**       
2ed0: 20 20 20 20 65 78 70 72 20 49 4e 20 28 65 78 70      expr IN (exp
2ee0: 72 6c 69 73 74 29 0a 2a 2a 20 61 6e 64 0a 2a 2a  rlist).** and.**
2ef0: 20 20 20 20 20 20 20 20 20 20 20 65 78 70 72 20             expr 
2f00: 49 4e 20 28 53 45 4c 45 43 54 20 2e 2e 2e 29 0a  IN (SELECT ...).
2f10: 2a 2a 0a 2a 2a 20 54 68 65 20 66 69 72 73 74 20  **.** The first 
2f20: 66 6f 72 6d 20 69 73 20 68 61 6e 64 6c 65 64 20  form is handled 
2f30: 62 79 20 63 72 65 61 74 69 6e 67 20 61 20 73 65  by creating a se
2f40: 74 20 68 6f 6c 64 69 6e 67 20 74 68 65 20 6c 69  t holding the li
2f50: 73 74 0a 2a 2a 20 6f 66 20 61 6c 6c 6f 77 65 64  st.** of allowed
2f60: 20 76 61 6c 75 65 73 2e 20 20 54 68 65 20 73 65   values.  The se
2f70: 63 6f 6e 64 20 66 6f 72 6d 20 63 61 75 73 65 73  cond form causes
2f80: 20 74 68 65 20 53 45 4c 45 43 54 20 74 6f 20 67   the SELECT to g
2f90: 65 6e 65 72 61 74 65 20 0a 2a 2a 20 61 20 74 65  enerate .** a te
2fa0: 6d 70 6f 72 61 72 79 20 74 61 62 6c 65 2e 0a 2a  mporary table..*
2fb0: 2a 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69 6e  *.** This routin
2fc0: 65 20 61 6c 73 6f 20 6c 6f 6f 6b 73 20 66 6f 72  e also looks for
2fd0: 20 73 63 61 6c 61 72 20 53 45 4c 45 43 54 73 20   scalar SELECTs 
2fe0: 74 68 61 74 20 61 72 65 20 70 61 72 74 20 6f 66  that are part of
2ff0: 20 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 2e 0a   an expression..
3000: 2a 2a 20 49 66 20 69 74 20 66 69 6e 64 73 20 61  ** If it finds a
3010: 6e 79 2c 20 69 74 20 67 65 6e 65 72 61 74 65 73  ny, it generates
3020: 20 63 6f 64 65 20 74 6f 20 77 72 69 74 65 20 74   code to write t
3030: 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 61 74  he value of that
3040: 20 73 65 6c 65 63 74 0a 2a 2a 20 69 6e 74 6f 20   select.** into 
3050: 61 20 6d 65 6d 6f 72 79 20 63 65 6c 6c 2e 0a 2a  a memory cell..*
3060: 2a 0a 2a 2a 20 55 6e 6b 6e 6f 77 6e 20 63 6f 6c  *.** Unknown col
3070: 75 6d 6e 73 20 6f 72 20 74 61 62 6c 65 73 20 70  umns or tables p
3080: 72 6f 76 6f 6b 65 20 61 6e 20 65 72 72 6f 72 2e  rovoke an error.
3090: 20 20 54 68 65 20 66 75 6e 63 74 69 6f 6e 20 72    The function r
30a0: 65 74 75 72 6e 73 0a 2a 2a 20 74 68 65 20 6e 75  eturns.** the nu
30b0: 6d 62 65 72 20 6f 66 20 65 72 72 6f 72 73 20 73  mber of errors s
30c0: 65 65 6e 20 61 6e 64 20 6c 65 61 76 65 73 20 61  een and leaves a
30d0: 6e 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20  n error message 
30e0: 6f 6e 20 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d  on pParse->zErrM
30f0: 73 67 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  sg..*/.int sqlit
3100: 65 45 78 70 72 52 65 73 6f 6c 76 65 49 64 73 28  eExprResolveIds(
3110: 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65  .  Parse *pParse
3120: 2c 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72  ,     /* The par
3130: 73 65 72 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20  ser context */. 
3140: 20 69 6e 74 20 62 61 73 65 2c 20 20 20 20 20 20   int base,      
3150: 20 20 20 20 2f 2a 20 56 44 42 45 20 63 75 72 73      /* VDBE curs
3160: 6f 72 20 6e 75 6d 62 65 72 20 66 6f 72 20 66 69  or number for fi
3170: 72 73 74 20 65 6e 74 72 79 20 69 6e 20 70 54 61  rst entry in pTa
3180: 62 4c 69 73 74 20 2a 2f 0a 20 20 53 72 63 4c 69  bList */.  SrcLi
3190: 73 74 20 2a 70 54 61 62 4c 69 73 74 2c 20 2f 2a  st *pTabList, /*
31a0: 20 4c 69 73 74 20 6f 66 20 74 61 62 6c 65 73 20   List of tables 
31b0: 75 73 65 64 20 74 6f 20 72 65 73 6f 6c 76 65 20  used to resolve 
31c0: 63 6f 6c 75 6d 6e 20 6e 61 6d 65 73 20 2a 2f 0a  column names */.
31d0: 20 20 45 78 70 72 4c 69 73 74 20 2a 70 45 4c 69    ExprList *pELi
31e0: 73 74 2c 20 20 2f 2a 20 4c 69 73 74 20 6f 66 20  st,  /* List of 
31f0: 65 78 70 72 65 73 73 69 6f 6e 73 20 75 73 65 64  expressions used
3200: 20 74 6f 20 72 65 73 6f 6c 76 65 20 22 41 53 22   to resolve "AS"
3210: 20 2a 2f 0a 20 20 45 78 70 72 20 2a 70 45 78 70   */.  Expr *pExp
3220: 72 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20  r        /* The 
3230: 65 78 70 72 65 73 73 69 6f 6e 20 74 6f 20 62 65  expression to be
3240: 20 61 6e 61 6c 79 7a 65 64 2e 20 2a 2f 0a 29 7b   analyzed. */.){
3250: 0a 20 20 69 66 28 20 70 45 78 70 72 3d 3d 30 20  .  if( pExpr==0 
3260: 7c 7c 20 70 54 61 62 4c 69 73 74 3d 3d 30 20 29  || pTabList==0 )
3270: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 61 73 73   return 0;.  ass
3280: 65 72 74 28 20 62 61 73 65 2b 70 54 61 62 4c 69  ert( base+pTabLi
3290: 73 74 2d 3e 6e 53 72 63 3c 3d 70 50 61 72 73 65  st->nSrc<=pParse
32a0: 2d 3e 6e 54 61 62 20 29 3b 0a 20 20 73 77 69 74  ->nTab );.  swit
32b0: 63 68 28 20 70 45 78 70 72 2d 3e 6f 70 20 29 7b  ch( pExpr->op ){
32c0: 0a 20 20 20 20 2f 2a 20 44 6f 75 62 6c 65 2d 71  .    /* Double-q
32d0: 75 6f 74 65 64 20 73 74 72 69 6e 67 73 20 28 65  uoted strings (e
32e0: 78 3a 20 22 61 62 63 22 29 20 61 72 65 20 75 73  x: "abc") are us
32f0: 65 64 20 61 73 20 69 64 65 6e 74 69 66 69 65 72  ed as identifier
3300: 73 20 69 66 0a 20 20 20 20 2a 2a 20 70 6f 73 73  s if.    ** poss
3310: 69 62 6c 65 2e 20 20 4f 74 68 65 72 77 69 73 65  ible.  Otherwise
3320: 20 74 68 65 79 20 72 65 6d 61 69 6e 20 61 73 20   they remain as 
3330: 73 74 72 69 6e 67 73 2e 20 20 53 69 6e 67 6c 65  strings.  Single
3340: 2d 71 75 6f 74 65 64 0a 20 20 20 20 2a 2a 20 73  -quoted.    ** s
3350: 74 72 69 6e 67 73 20 28 65 78 3a 20 27 61 62 63  trings (ex: 'abc
3360: 27 29 20 61 72 65 20 61 6c 77 61 79 73 20 73 74  ') are always st
3370: 72 69 6e 67 20 6c 69 74 65 72 61 6c 73 2e 0a 20  ring literals.. 
3380: 20 20 20 2a 2f 0a 20 20 20 20 63 61 73 65 20 54     */.    case T
3390: 4b 5f 53 54 52 49 4e 47 3a 20 7b 0a 20 20 20 20  K_STRING: {.    
33a0: 20 20 69 66 28 20 70 45 78 70 72 2d 3e 74 6f 6b    if( pExpr->tok
33b0: 65 6e 2e 7a 5b 30 5d 3d 3d 27 5c 27 27 20 29 20  en.z[0]=='\'' ) 
33c0: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 2f 2a 20  break;.      /* 
33d0: 46 61 6c 6c 20 74 68 72 75 20 69 6e 74 6f 20 74  Fall thru into t
33e0: 68 65 20 54 4b 5f 49 44 20 63 61 73 65 20 69 66  he TK_ID case if
33f0: 20 74 68 69 73 20 69 73 20 61 20 64 6f 75 62 6c   this is a doubl
3400: 65 2d 71 75 6f 74 65 64 20 73 74 72 69 6e 67 20  e-quoted string 
3410: 2a 2f 0a 20 20 20 20 7d 0a 20 20 20 20 2f 2a 20  */.    }.    /* 
3420: 41 20 6c 6f 6e 65 20 69 64 65 6e 74 69 66 69 65  A lone identifie
3430: 72 2e 20 20 54 72 79 20 61 6e 64 20 6d 61 74 63  r.  Try and matc
3440: 68 20 69 74 20 61 73 20 66 6f 6c 6c 6f 77 73 3a  h it as follows:
3450: 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 20  .    **.    **  
3460: 20 20 20 31 2e 20 20 54 6f 20 74 68 65 20 6e 61     1.  To the na
3470: 6d 65 20 6f 66 20 61 20 63 6f 6c 75 6d 6e 20 6f  me of a column o
3480: 66 20 6f 6e 65 20 6f 66 20 74 68 65 20 74 61 62  f one of the tab
3490: 6c 65 73 20 69 6e 20 70 54 61 62 4c 69 73 74 0a  les in pTabList.
34a0: 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 20 20      **.    **   
34b0: 20 20 32 2e 20 20 54 6f 20 74 68 65 20 72 69 67    2.  To the rig
34c0: 68 74 20 73 69 64 65 20 6f 66 20 61 6e 20 41 53  ht side of an AS
34d0: 20 6b 65 79 77 6f 72 64 20 69 6e 20 74 68 65 20   keyword in the 
34e0: 63 6f 6c 75 6d 6e 20 6c 69 73 74 20 6f 66 0a 20  column list of. 
34f0: 20 20 20 2a 2a 20 20 20 20 20 20 20 20 20 61 20     **         a 
3500: 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74  SELECT statement
3510: 2e 20 20 28 46 6f 72 20 65 78 61 6d 70 6c 65 2c  .  (For example,
3520: 20 6d 61 74 63 68 20 61 67 61 69 6e 73 74 20 27   match against '
3530: 78 27 20 69 6e 0a 20 20 20 20 2a 2a 20 20 20 20  x' in.    **    
3540: 20 20 20 20 20 22 53 45 4c 45 43 54 20 61 2b 62       "SELECT a+b
3550: 20 41 53 20 27 78 27 20 46 52 4f 4d 20 74 31 22   AS 'x' FROM t1"
3560: 2e 29 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a  .).    **.    **
3570: 20 20 20 20 20 33 2e 20 20 4f 6e 65 20 6f 66 20       3.  One of 
3580: 74 68 65 20 73 70 65 63 69 61 6c 20 6e 61 6d 65  the special name
3590: 73 20 22 52 4f 57 49 44 22 2c 20 22 4f 49 44 22  s "ROWID", "OID"
35a0: 2c 20 6f 72 20 22 5f 52 4f 57 49 44 5f 22 2e 0a  , or "_ROWID_"..
35b0: 20 20 20 20 2a 2f 0a 20 20 20 20 63 61 73 65 20      */.    case 
35c0: 54 4b 5f 49 44 3a 20 7b 0a 20 20 20 20 20 20 69  TK_ID: {.      i
35d0: 6e 74 20 63 6e 74 20 3d 20 30 3b 20 20 20 20 20  nt cnt = 0;     
35e0: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 6d 61   /* Number of ma
35f0: 74 63 68 65 73 20 2a 2f 0a 20 20 20 20 20 20 69  tches */.      i
3600: 6e 74 20 69 3b 20 20 20 20 20 20 20 20 20 20 20  nt i;           
3610: 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74 65 72   /* Loop counter
3620: 20 2a 2f 0a 20 20 20 20 20 20 63 68 61 72 20 2a   */.      char *
3630: 7a 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28  z;.      assert(
3640: 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 20   pExpr->token.z 
3650: 29 3b 0a 20 20 20 20 20 20 7a 20 3d 20 73 71 6c  );.      z = sql
3660: 69 74 65 53 74 72 4e 44 75 70 28 70 45 78 70 72  iteStrNDup(pExpr
3670: 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72  ->token.z, pExpr
3680: 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20 20  ->token.n);.    
3690: 20 20 73 71 6c 69 74 65 44 65 71 75 6f 74 65 28    sqliteDequote(
36a0: 7a 29 3b 0a 20 20 20 20 20 20 69 66 28 20 7a 3d  z);.      if( z=
36b0: 3d 30 20 29 20 72 65 74 75 72 6e 20 31 3b 0a 20  =0 ) return 1;. 
36c0: 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c       for(i=0; i<
36d0: 70 54 61 62 4c 69 73 74 2d 3e 6e 53 72 63 3b 20  pTabList->nSrc; 
36e0: 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 69 6e  i++){.        in
36f0: 74 20 6a 3b 0a 20 20 20 20 20 20 20 20 54 61 62  t j;.        Tab
3700: 6c 65 20 2a 70 54 61 62 20 3d 20 70 54 61 62 4c  le *pTab = pTabL
3710: 69 73 74 2d 3e 61 5b 69 5d 2e 70 54 61 62 3b 0a  ist->a[i].pTab;.
3720: 20 20 20 20 20 20 20 20 69 66 28 20 70 54 61 62          if( pTab
3730: 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a  ==0 ) continue;.
3740: 20 20 20 20 20 20 20 20 61 73 73 65 72 74 28 20          assert( 
3750: 70 54 61 62 2d 3e 6e 43 6f 6c 3e 30 20 29 3b 0a  pTab->nCol>0 );.
3760: 20 20 20 20 20 20 20 20 66 6f 72 28 6a 3d 30 3b          for(j=0;
3770: 20 6a 3c 70 54 61 62 2d 3e 6e 43 6f 6c 3b 20 6a   j<pTab->nCol; j
3780: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69  ++){.          i
3790: 66 28 20 73 71 6c 69 74 65 53 74 72 49 43 6d 70  f( sqliteStrICmp
37a0: 28 70 54 61 62 2d 3e 61 43 6f 6c 5b 6a 5d 2e 7a  (pTab->aCol[j].z
37b0: 4e 61 6d 65 2c 20 7a 29 3d 3d 30 20 29 7b 0a 20  Name, z)==0 ){. 
37c0: 20 20 20 20 20 20 20 20 20 20 20 63 6e 74 2b 2b             cnt++
37d0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 45  ;.            pE
37e0: 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20 69 20  xpr->iTable = i 
37f0: 2b 20 62 61 73 65 3b 0a 20 20 20 20 20 20 20 20  + base;.        
3800: 20 20 20 20 69 66 28 20 6a 3d 3d 70 54 61 62 2d      if( j==pTab-
3810: 3e 69 50 4b 65 79 20 29 7b 0a 20 20 20 20 20 20  >iPKey ){.      
3820: 20 20 20 20 20 20 20 20 2f 2a 20 53 75 62 73 74          /* Subst
3830: 69 74 75 74 65 20 74 68 65 20 72 65 63 6f 72 64  itute the record
3840: 20 6e 75 6d 62 65 72 20 66 6f 72 20 74 68 65 20   number for the 
3850: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
3860: 4b 45 59 20 2a 2f 0a 20 20 20 20 20 20 20 20 20  KEY */.         
3870: 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c       pExpr->iCol
3880: 75 6d 6e 20 3d 20 2d 31 3b 0a 20 20 20 20 20 20  umn = -1;.      
3890: 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 64          pExpr->d
38a0: 61 74 61 54 79 70 65 20 3d 20 53 51 4c 49 54 45  ataType = SQLITE
38b0: 5f 53 4f 5f 4e 55 4d 3b 0a 20 20 20 20 20 20 20  _SO_NUM;.       
38c0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
38d0: 20 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d            pExpr-
38e0: 3e 69 43 6f 6c 75 6d 6e 20 3d 20 6a 3b 0a 20 20  >iColumn = j;.  
38f0: 20 20 20 20 20 20 20 20 20 20 20 20 70 45 78 70              pExp
3900: 72 2d 3e 64 61 74 61 54 79 70 65 20 3d 20 70 54  r->dataType = pT
3910: 61 62 2d 3e 61 43 6f 6c 5b 6a 5d 2e 73 6f 72 74  ab->aCol[j].sort
3920: 4f 72 64 65 72 20 26 20 53 51 4c 49 54 45 5f 53  Order & SQLITE_S
3930: 4f 5f 54 59 50 45 4d 41 53 4b 3b 0a 20 20 20 20  O_TYPEMASK;.    
3940: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3950: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 6f 70 20        pExpr->op 
3960: 3d 20 54 4b 5f 43 4f 4c 55 4d 4e 3b 0a 20 20 20  = TK_COLUMN;.   
3970: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
3980: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
3990: 20 69 66 28 20 63 6e 74 3d 3d 30 20 26 26 20 70   if( cnt==0 && p
39a0: 45 4c 69 73 74 21 3d 30 20 29 7b 0a 20 20 20 20  EList!=0 ){.    
39b0: 20 20 20 20 69 6e 74 20 6a 3b 0a 20 20 20 20 20      int j;.     
39c0: 20 20 20 66 6f 72 28 6a 3d 30 3b 20 6a 3c 70 45     for(j=0; j<pE
39d0: 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 6a 2b 2b  List->nExpr; j++
39e0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 63 68 61  ){.          cha
39f0: 72 20 2a 7a 41 73 20 3d 20 70 45 4c 69 73 74 2d  r *zAs = pEList-
3a00: 3e 61 5b 6a 5d 2e 7a 4e 61 6d 65 3b 0a 20 20 20  >a[j].zName;.   
3a10: 20 20 20 20 20 20 20 69 66 28 20 7a 41 73 21 3d         if( zAs!=
3a20: 30 20 26 26 20 73 71 6c 69 74 65 53 74 72 49 43  0 && sqliteStrIC
3a30: 6d 70 28 7a 41 73 2c 20 7a 29 3d 3d 30 20 29 7b  mp(zAs, z)==0 ){
3a40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6e 74  .            cnt
3a50: 2b 2b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ++;.            
3a60: 61 73 73 65 72 74 28 20 70 45 78 70 72 2d 3e 70  assert( pExpr->p
3a70: 4c 65 66 74 3d 3d 30 20 26 26 20 70 45 78 70 72  Left==0 && pExpr
3a80: 2d 3e 70 52 69 67 68 74 3d 3d 30 20 29 3b 0a 20  ->pRight==0 );. 
3a90: 20 20 20 20 20 20 20 20 20 20 20 70 45 78 70 72             pExpr
3aa0: 2d 3e 6f 70 20 3d 20 54 4b 5f 41 53 3b 0a 20 20  ->op = TK_AS;.  
3ab0: 20 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d            pExpr-
3ac0: 3e 69 43 6f 6c 75 6d 6e 20 3d 20 6a 3b 0a 20 20  >iColumn = j;.  
3ad0: 20 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d            pExpr-
3ae0: 3e 70 4c 65 66 74 20 3d 20 73 71 6c 69 74 65 45  >pLeft = sqliteE
3af0: 78 70 72 44 75 70 28 70 45 4c 69 73 74 2d 3e 61  xprDup(pEList->a
3b00: 5b 6a 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20  [j].pExpr);.    
3b10: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
3b20: 7d 20 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  } .      }.     
3b30: 20 69 66 28 20 63 6e 74 3d 3d 30 20 26 26 20 73   if( cnt==0 && s
3b40: 71 6c 69 74 65 49 73 52 6f 77 69 64 28 7a 29 20  qliteIsRowid(z) 
3b50: 29 7b 0a 20 20 20 20 20 20 20 20 70 45 78 70 72  ){.        pExpr
3b60: 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20 2d 31 3b 0a  ->iColumn = -1;.
3b70: 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69          pExpr->i
3b80: 54 61 62 6c 65 20 3d 20 62 61 73 65 3b 0a 20 20  Table = base;.  
3b90: 20 20 20 20 20 20 63 6e 74 20 3d 20 31 20 2b 20        cnt = 1 + 
3ba0: 28 70 54 61 62 4c 69 73 74 2d 3e 6e 53 72 63 3e  (pTabList->nSrc>
3bb0: 31 29 3b 0a 20 20 20 20 20 20 20 20 70 45 78 70  1);.        pExp
3bc0: 72 2d 3e 6f 70 20 3d 20 54 4b 5f 43 4f 4c 55 4d  r->op = TK_COLUM
3bd0: 4e 3b 0a 20 20 20 20 20 20 20 20 70 45 78 70 72  N;.        pExpr
3be0: 2d 3e 64 61 74 61 54 79 70 65 20 3d 20 53 51 4c  ->dataType = SQL
3bf0: 49 54 45 5f 53 4f 5f 4e 55 4d 3b 0a 20 20 20 20  ITE_SO_NUM;.    
3c00: 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65    }.      sqlite
3c10: 46 72 65 65 28 7a 29 3b 0a 20 20 20 20 20 20 69  Free(z);.      i
3c20: 66 28 20 63 6e 74 3d 3d 30 20 26 26 20 70 45 78  f( cnt==0 && pEx
3c30: 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 5b 30 5d 21 3d  pr->token.z[0]!=
3c40: 27 22 27 20 29 7b 0a 20 20 20 20 20 20 20 20 73  '"' ){.        s
3c50: 71 6c 69 74 65 53 65 74 4e 53 74 72 69 6e 67 28  qliteSetNString(
3c60: 26 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67  &pParse->zErrMsg
3c70: 2c 20 22 6e 6f 20 73 75 63 68 20 63 6f 6c 75 6d  , "no such colum
3c80: 6e 3a 20 22 2c 20 2d 31 2c 20 20 0a 20 20 20 20  n: ", -1,  .    
3c90: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 74 6f 6b        pExpr->tok
3ca0: 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f 6b  en.z, pExpr->tok
3cb0: 65 6e 2e 6e 2c 20 30 29 3b 0a 20 20 20 20 20 20  en.n, 0);.      
3cc0: 20 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b 2b    pParse->nErr++
3cd0: 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ;.        return
3ce0: 20 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20   1;.      }else 
3cf0: 69 66 28 20 63 6e 74 3e 31 20 29 7b 0a 20 20 20  if( cnt>1 ){.   
3d00: 20 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e 53       sqliteSetNS
3d10: 74 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a  tring(&pParse->z
3d20: 45 72 72 4d 73 67 2c 20 22 61 6d 62 69 67 75 6f  ErrMsg, "ambiguo
3d30: 75 73 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 3a 20  us column name: 
3d40: 22 2c 20 2d 31 2c 20 20 0a 20 20 20 20 20 20 20  ", -1,  .       
3d50: 20 20 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e     pExpr->token.
3d60: 7a 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e  z, pExpr->token.
3d70: 6e 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70  n, 0);.        p
3d80: 50 61 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20  Parse->nErr++;. 
3d90: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b         return 1;
3da0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 62  .      }.      b
3db0: 72 65 61 6b 3b 20 0a 20 20 20 20 7d 0a 20 20 0a  reak; .    }.  .
3dc0: 20 20 20 20 2f 2a 20 41 20 74 61 62 6c 65 20 6e      /* A table n
3dd0: 61 6d 65 20 61 6e 64 20 63 6f 6c 75 6d 6e 20 6e  ame and column n
3de0: 61 6d 65 3a 20 20 49 44 2e 49 44 20 2a 2f 0a 20  ame:  ID.ID */. 
3df0: 20 20 20 63 61 73 65 20 54 4b 5f 44 4f 54 3a 20     case TK_DOT: 
3e00: 7b 0a 20 20 20 20 20 20 69 6e 74 20 63 6e 74 20  {.      int cnt 
3e10: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  = 0;            
3e20: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 6d 61   /* Number of ma
3e30: 74 63 68 65 73 20 2a 2f 0a 20 20 20 20 20 20 69  tches */.      i
3e40: 6e 74 20 63 6e 74 54 61 62 20 3d 20 30 3b 20 20  nt cntTab = 0;  
3e50: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
3e60: 72 20 6f 66 20 6d 61 74 63 68 69 6e 67 20 74 61  r of matching ta
3e70: 62 6c 65 73 20 2a 2f 0a 20 20 20 20 20 20 69 6e  bles */.      in
3e80: 74 20 69 3b 20 20 20 20 20 20 20 20 20 20 20 20  t i;            
3e90: 20 20 20 20 20 20 20 2f 2a 20 4c 6f 6f 70 20 63         /* Loop c
3ea0: 6f 75 6e 74 65 72 20 2a 2f 0a 20 20 20 20 20 20  ounter */.      
3eb0: 45 78 70 72 20 2a 70 4c 65 66 74 2c 20 2a 70 52  Expr *pLeft, *pR
3ec0: 69 67 68 74 3b 20 20 20 20 2f 2a 20 4c 65 66 74  ight;    /* Left
3ed0: 20 61 6e 64 20 72 69 67 68 74 20 73 75 62 62 72   and right subbr
3ee0: 61 6e 63 68 65 73 20 6f 66 20 74 68 65 20 65 78  anches of the ex
3ef0: 70 72 20 2a 2f 0a 20 20 20 20 20 20 63 68 61 72  pr */.      char
3f00: 20 2a 7a 4c 65 66 74 2c 20 2a 7a 52 69 67 68 74   *zLeft, *zRight
3f10: 3b 20 20 20 20 2f 2a 20 54 65 78 74 20 6f 66 20  ;    /* Text of 
3f20: 61 6e 20 69 64 65 6e 74 69 66 69 65 72 20 2a 2f  an identifier */
3f30: 0a 0a 20 20 20 20 20 20 70 4c 65 66 74 20 3d 20  ..      pLeft = 
3f40: 70 45 78 70 72 2d 3e 70 4c 65 66 74 3b 0a 20 20  pExpr->pLeft;.  
3f50: 20 20 20 20 70 52 69 67 68 74 20 3d 20 70 45 78      pRight = pEx
3f60: 70 72 2d 3e 70 52 69 67 68 74 3b 0a 20 20 20 20  pr->pRight;.    
3f70: 20 20 61 73 73 65 72 74 28 20 70 4c 65 66 74 20    assert( pLeft 
3f80: 26 26 20 70 4c 65 66 74 2d 3e 6f 70 3d 3d 54 4b  && pLeft->op==TK
3f90: 5f 49 44 20 26 26 20 70 4c 65 66 74 2d 3e 74 6f  _ID && pLeft->to
3fa0: 6b 65 6e 2e 7a 20 29 3b 0a 20 20 20 20 20 20 61  ken.z );.      a
3fb0: 73 73 65 72 74 28 20 70 52 69 67 68 74 20 26 26  ssert( pRight &&
3fc0: 20 70 52 69 67 68 74 2d 3e 6f 70 3d 3d 54 4b 5f   pRight->op==TK_
3fd0: 49 44 20 26 26 20 70 52 69 67 68 74 2d 3e 74 6f  ID && pRight->to
3fe0: 6b 65 6e 2e 7a 20 29 3b 0a 20 20 20 20 20 20 7a  ken.z );.      z
3ff0: 4c 65 66 74 20 3d 20 73 71 6c 69 74 65 53 74 72  Left = sqliteStr
4000: 4e 44 75 70 28 70 4c 65 66 74 2d 3e 74 6f 6b 65  NDup(pLeft->toke
4010: 6e 2e 7a 2c 20 70 4c 65 66 74 2d 3e 74 6f 6b 65  n.z, pLeft->toke
4020: 6e 2e 6e 29 3b 0a 20 20 20 20 20 20 7a 52 69 67  n.n);.      zRig
4030: 68 74 20 3d 20 73 71 6c 69 74 65 53 74 72 4e 44  ht = sqliteStrND
4040: 75 70 28 70 52 69 67 68 74 2d 3e 74 6f 6b 65 6e  up(pRight->token
4050: 2e 7a 2c 20 70 52 69 67 68 74 2d 3e 74 6f 6b 65  .z, pRight->toke
4060: 6e 2e 6e 29 3b 0a 20 20 20 20 20 20 69 66 28 20  n.n);.      if( 
4070: 7a 4c 65 66 74 3d 3d 30 20 7c 7c 20 7a 52 69 67  zLeft==0 || zRig
4080: 68 74 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ht==0 ){.       
4090: 20 73 71 6c 69 74 65 46 72 65 65 28 7a 4c 65 66   sqliteFree(zLef
40a0: 74 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  t);.        sqli
40b0: 74 65 46 72 65 65 28 7a 52 69 67 68 74 29 3b 0a  teFree(zRight);.
40c0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 31          return 1
40d0: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
40e0: 73 71 6c 69 74 65 44 65 71 75 6f 74 65 28 7a 4c  sqliteDequote(zL
40f0: 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  eft);.      sqli
4100: 74 65 44 65 71 75 6f 74 65 28 7a 52 69 67 68 74  teDequote(zRight
4110: 29 3b 0a 20 20 20 20 20 20 70 45 78 70 72 2d 3e  );.      pExpr->
4120: 69 54 61 62 6c 65 20 3d 20 2d 31 3b 0a 20 20 20  iTable = -1;.   
4130: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 54     for(i=0; i<pT
4140: 61 62 4c 69 73 74 2d 3e 6e 53 72 63 3b 20 69 2b  abList->nSrc; i+
4150: 2b 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20  +){.        int 
4160: 6a 3b 0a 20 20 20 20 20 20 20 20 63 68 61 72 20  j;.        char 
4170: 2a 7a 54 61 62 3b 0a 20 20 20 20 20 20 20 20 54  *zTab;.        T
4180: 61 62 6c 65 20 2a 70 54 61 62 20 3d 20 70 54 61  able *pTab = pTa
4190: 62 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 54 61 62  bList->a[i].pTab
41a0: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 54  ;.        if( pT
41b0: 61 62 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65  ab==0 ) continue
41c0: 3b 0a 20 20 20 20 20 20 20 20 61 73 73 65 72 74  ;.        assert
41d0: 28 20 70 54 61 62 2d 3e 6e 43 6f 6c 3e 30 20 29  ( pTab->nCol>0 )
41e0: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 54  ;.        if( pT
41f0: 61 62 4c 69 73 74 2d 3e 61 5b 69 5d 2e 7a 41 6c  abList->a[i].zAl
4200: 69 61 73 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ias ){.         
4210: 20 7a 54 61 62 20 3d 20 70 54 61 62 4c 69 73 74   zTab = pTabList
4220: 2d 3e 61 5b 69 5d 2e 7a 41 6c 69 61 73 3b 0a 20  ->a[i].zAlias;. 
4230: 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20         }else{.  
4240: 20 20 20 20 20 20 20 20 7a 54 61 62 20 3d 20 70          zTab = p
4250: 54 61 62 2d 3e 7a 4e 61 6d 65 3b 0a 20 20 20 20  Tab->zName;.    
4260: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 69 66      }.        if
4270: 28 20 7a 54 61 62 3d 3d 30 20 7c 7c 20 73 71 6c  ( zTab==0 || sql
4280: 69 74 65 53 74 72 49 43 6d 70 28 7a 54 61 62 2c  iteStrICmp(zTab,
4290: 20 7a 4c 65 66 74 29 21 3d 30 20 29 20 63 6f 6e   zLeft)!=0 ) con
42a0: 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20 69  tinue;.        i
42b0: 66 28 20 30 3d 3d 28 63 6e 74 54 61 62 2b 2b 29  f( 0==(cntTab++)
42c0: 20 29 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65   ) pExpr->iTable
42d0: 20 3d 20 69 20 2b 20 62 61 73 65 3b 0a 20 20 20   = i + base;.   
42e0: 20 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20 6a 3c       for(j=0; j<
42f0: 70 54 61 62 2d 3e 6e 43 6f 6c 3b 20 6a 2b 2b 29  pTab->nCol; j++)
4300: 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  {.          if( 
4310: 73 71 6c 69 74 65 53 74 72 49 43 6d 70 28 70 54  sqliteStrICmp(pT
4320: 61 62 2d 3e 61 43 6f 6c 5b 6a 5d 2e 7a 4e 61 6d  ab->aCol[j].zNam
4330: 65 2c 20 7a 52 69 67 68 74 29 3d 3d 30 20 29 7b  e, zRight)==0 ){
4340: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6e 74  .            cnt
4350: 2b 2b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ++;.            
4360: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20  pExpr->iTable = 
4370: 69 20 2b 20 62 61 73 65 3b 0a 20 20 20 20 20 20  i + base;.      
4380: 20 20 20 20 20 20 69 66 28 20 6a 3d 3d 70 54 61        if( j==pTa
4390: 62 2d 3e 69 50 4b 65 79 20 29 7b 0a 20 20 20 20  b->iPKey ){.    
43a0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 75 62            /* Sub
43b0: 73 74 69 74 75 74 65 20 74 68 65 20 72 65 63 6f  stitute the reco
43c0: 72 64 20 6e 75 6d 62 65 72 20 66 6f 72 20 74 68  rd number for th
43d0: 65 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52  e INTEGER PRIMAR
43e0: 59 20 4b 45 59 20 2a 2f 0a 20 20 20 20 20 20 20  Y KEY */.       
43f0: 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 43         pExpr->iC
4400: 6f 6c 75 6d 6e 20 3d 20 2d 31 3b 0a 20 20 20 20  olumn = -1;.    
4410: 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20          }else{. 
4420: 20 20 20 20 20 20 20 20 20 20 20 20 20 70 45 78               pEx
4430: 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20 6a 3b  pr->iColumn = j;
4440: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20  .            }. 
4450: 20 20 20 20 20 20 20 20 20 20 20 70 45 78 70 72             pExpr
4460: 2d 3e 64 61 74 61 54 79 70 65 20 3d 20 70 54 61  ->dataType = pTa
4470: 62 2d 3e 61 43 6f 6c 5b 6a 5d 2e 73 6f 72 74 4f  b->aCol[j].sortO
4480: 72 64 65 72 20 26 20 53 51 4c 49 54 45 5f 53 4f  rder & SQLITE_SO
4490: 5f 54 59 50 45 4d 41 53 4b 3b 0a 20 20 20 20 20  _TYPEMASK;.     
44a0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d       }.        }
44b0: 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20  .      }..      
44c0: 2f 2a 20 49 66 20 77 65 20 68 61 76 65 20 6e 6f  /* If we have no
44d0: 74 20 61 6c 72 65 61 64 79 20 72 65 73 6f 6c 76  t already resolv
44e0: 65 64 20 74 68 69 73 20 2a 2e 2a 20 65 78 70 72  ed this *.* expr
44f0: 65 73 73 69 6f 6e 2c 20 74 68 65 6e 20 6d 61 79  ession, then may
4500: 62 65 20 0a 20 20 20 20 20 20 20 2a 20 69 74 20  be .       * it 
4510: 69 73 20 61 20 6e 65 77 2e 2a 20 6f 72 20 6f 6c  is a new.* or ol
4520: 64 2e 2a 20 74 72 69 67 67 65 72 20 61 72 67 75  d.* trigger argu
4530: 6d 65 6e 74 20 72 65 66 65 72 65 6e 63 65 20 2a  ment reference *
4540: 2f 0a 20 20 20 20 20 20 69 66 28 20 63 6e 74 20  /.      if( cnt 
4550: 3d 3d 20 30 20 26 26 20 70 50 61 72 73 65 2d 3e  == 0 && pParse->
4560: 74 72 69 67 53 74 61 63 6b 20 21 3d 20 30 20 29  trigStack != 0 )
4570: 7b 0a 20 20 20 20 20 20 20 20 54 72 69 67 67 65  {.        Trigge
4580: 72 53 74 61 63 6b 20 2a 70 54 72 69 67 67 65 72  rStack *pTrigger
4590: 53 74 61 63 6b 20 3d 20 70 50 61 72 73 65 2d 3e  Stack = pParse->
45a0: 74 72 69 67 53 74 61 63 6b 3b 0a 20 20 20 20 20  trigStack;.     
45b0: 20 20 20 69 6e 74 20 74 20 3d 20 30 3b 0a 20 20     int t = 0;.  
45c0: 20 20 20 20 20 20 69 66 28 20 70 54 72 69 67 67        if( pTrigg
45d0: 65 72 53 74 61 63 6b 2d 3e 6e 65 77 49 64 78 20  erStack->newIdx 
45e0: 21 3d 20 2d 31 20 26 26 20 73 71 6c 69 74 65 53  != -1 && sqliteS
45f0: 74 72 49 43 6d 70 28 22 6e 65 77 22 2c 20 7a 4c  trICmp("new", zL
4600: 65 66 74 29 20 3d 3d 20 30 20 29 7b 0a 20 20 20  eft) == 0 ){.   
4610: 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 54         pExpr->iT
4620: 61 62 6c 65 20 3d 20 70 54 72 69 67 67 65 72 53  able = pTriggerS
4630: 74 61 63 6b 2d 3e 6e 65 77 49 64 78 3b 0a 20 20  tack->newIdx;.  
4640: 20 20 20 20 20 20 20 20 63 6e 74 54 61 62 2b 2b          cntTab++
4650: 3b 0a 20 20 20 20 20 20 20 20 20 20 74 20 3d 20  ;.          t = 
4660: 31 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  1;.        }.   
4670: 20 20 20 20 20 69 66 28 20 70 54 72 69 67 67 65       if( pTrigge
4680: 72 53 74 61 63 6b 2d 3e 6f 6c 64 49 64 78 20 21  rStack->oldIdx !
4690: 3d 20 2d 31 20 26 26 20 73 71 6c 69 74 65 53 74  = -1 && sqliteSt
46a0: 72 49 43 6d 70 28 22 6f 6c 64 22 2c 20 7a 4c 65  rICmp("old", zLe
46b0: 66 74 29 20 3d 3d 20 30 20 29 7b 0a 20 20 20 20  ft) == 0 ){.    
46c0: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 54 61        pExpr->iTa
46d0: 62 6c 65 20 3d 20 70 54 72 69 67 67 65 72 53 74  ble = pTriggerSt
46e0: 61 63 6b 2d 3e 6f 6c 64 49 64 78 3b 0a 20 20 20  ack->oldIdx;.   
46f0: 20 20 20 20 20 20 20 63 6e 74 54 61 62 2b 2b 3b         cntTab++;
4700: 0a 20 20 20 20 20 20 20 20 20 20 74 20 3d 20 31  .          t = 1
4710: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20  ;.        }..   
4720: 20 20 20 20 20 69 66 28 20 74 20 29 7b 20 0a 09       if( t ){ ..
4730: 20 20 69 6e 74 20 6a 3b 0a 20 20 20 20 20 20 20    int j;.       
4740: 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62 20 3d     Table *pTab =
4750: 20 70 54 72 69 67 67 65 72 53 74 61 63 6b 2d 3e   pTriggerStack->
4760: 70 54 61 62 3b 0a 20 20 20 20 20 20 20 20 20 20  pTab;.          
4770: 66 6f 72 28 6a 3d 30 3b 20 6a 20 3c 20 70 54 61  for(j=0; j < pTa
4780: 62 2d 3e 6e 43 6f 6c 3b 20 6a 2b 2b 29 20 7b 0a  b->nCol; j++) {.
4790: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 28 20              if( 
47a0: 73 71 6c 69 74 65 53 74 72 49 43 6d 70 28 70 54  sqliteStrICmp(pT
47b0: 61 62 2d 3e 61 43 6f 6c 5b 6a 5d 2e 7a 4e 61 6d  ab->aCol[j].zNam
47c0: 65 2c 20 7a 52 69 67 68 74 29 3d 3d 30 20 29 7b  e, zRight)==0 ){
47d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63  .              c
47e0: 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 20 20 20 20  nt++;.          
47f0: 20 20 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75      pExpr->iColu
4800: 6d 6e 20 3d 20 6a 3b 0a 20 20 20 20 20 20 20 20  mn = j;.        
4810: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 64 61 74        pExpr->dat
4820: 61 54 79 70 65 20 3d 20 70 54 61 62 2d 3e 61 43  aType = pTab->aC
4830: 6f 6c 5b 6a 5d 2e 73 6f 72 74 4f 72 64 65 72 20  ol[j].sortOrder 
4840: 26 20 53 51 4c 49 54 45 5f 53 4f 5f 54 59 50 45  & SQLITE_SO_TYPE
4850: 4d 41 53 4b 3b 0a 20 20 20 20 20 20 20 20 20 20  MASK;.          
4860: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 7d 0a    }.          }.
4870: 09 7d 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20  .}.      }..    
4880: 20 20 69 66 28 20 63 6e 74 3d 3d 30 20 26 26 20    if( cnt==0 && 
4890: 63 6e 74 54 61 62 3d 3d 31 20 26 26 20 73 71 6c  cntTab==1 && sql
48a0: 69 74 65 49 73 52 6f 77 69 64 28 7a 52 69 67 68  iteIsRowid(zRigh
48b0: 74 29 20 29 7b 0a 20 20 20 20 20 20 20 20 63 6e  t) ){.        cn
48c0: 74 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 70  t = 1;.        p
48d0: 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20  Expr->iColumn = 
48e0: 2d 31 3b 0a 20 20 20 20 20 20 20 20 70 45 78 70  -1;.        pExp
48f0: 72 2d 3e 64 61 74 61 54 79 70 65 20 3d 20 53 51  r->dataType = SQ
4900: 4c 49 54 45 5f 53 4f 5f 4e 55 4d 3b 0a 20 20 20  LITE_SO_NUM;.   
4910: 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74     }.      sqlit
4920: 65 46 72 65 65 28 7a 4c 65 66 74 29 3b 0a 20 20  eFree(zLeft);.  
4930: 20 20 20 20 73 71 6c 69 74 65 46 72 65 65 28 7a      sqliteFree(z
4940: 52 69 67 68 74 29 3b 0a 20 20 20 20 20 20 69 66  Right);.      if
4950: 28 20 63 6e 74 3d 3d 30 20 29 7b 0a 20 20 20 20  ( cnt==0 ){.    
4960: 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e 53 74      sqliteSetNSt
4970: 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a 45  ring(&pParse->zE
4980: 72 72 4d 73 67 2c 20 22 6e 6f 20 73 75 63 68 20  rrMsg, "no such 
4990: 63 6f 6c 75 6d 6e 3a 20 22 2c 20 2d 31 2c 20 20  column: ", -1,  
49a0: 0a 20 20 20 20 20 20 20 20 20 20 70 4c 65 66 74  .          pLeft
49b0: 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 4c 65 66 74  ->token.z, pLeft
49c0: 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20 22 2e 22 2c 20  ->token.n, ".", 
49d0: 31 2c 20 0a 20 20 20 20 20 20 20 20 20 20 70 52  1, .          pR
49e0: 69 67 68 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70  ight->token.z, p
49f0: 52 69 67 68 74 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20  Right->token.n, 
4a00: 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50 61 72  0);.        pPar
4a10: 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20 20  se->nErr++;.    
4a20: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
4a30: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 63 6e      }else if( cn
4a40: 74 3e 31 20 29 7b 0a 20 20 20 20 20 20 20 20 73  t>1 ){.        s
4a50: 71 6c 69 74 65 53 65 74 4e 53 74 72 69 6e 67 28  qliteSetNString(
4a60: 26 70 50 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67  &pParse->zErrMsg
4a70: 2c 20 22 61 6d 62 69 67 75 6f 75 73 20 63 6f 6c  , "ambiguous col
4a80: 75 6d 6e 20 6e 61 6d 65 3a 20 22 2c 20 2d 31 2c  umn name: ", -1,
4a90: 20 20 0a 20 20 20 20 20 20 20 20 20 20 70 4c 65    .          pLe
4aa0: 66 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 4c 65  ft->token.z, pLe
4ab0: 66 74 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20 22 2e 22  ft->token.n, "."
4ac0: 2c 20 31 2c 0a 20 20 20 20 20 20 20 20 20 20 70  , 1,.          p
4ad0: 52 69 67 68 74 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20  Right->token.z, 
4ae0: 70 52 69 67 68 74 2d 3e 74 6f 6b 65 6e 2e 6e 2c  pRight->token.n,
4af0: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50 61   0);.        pPa
4b00: 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20  rse->nErr++;.   
4b10: 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20       return 1;. 
4b20: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c       }.      sql
4b30: 69 74 65 45 78 70 72 44 65 6c 65 74 65 28 70 4c  iteExprDelete(pL
4b40: 65 66 74 29 3b 0a 20 20 20 20 20 20 70 45 78 70  eft);.      pExp
4b50: 72 2d 3e 70 4c 65 66 74 20 3d 20 30 3b 0a 20 20  r->pLeft = 0;.  
4b60: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 44 65      sqliteExprDe
4b70: 6c 65 74 65 28 70 52 69 67 68 74 29 3b 0a 20 20  lete(pRight);.  
4b80: 20 20 20 20 70 45 78 70 72 2d 3e 70 52 69 67 68      pExpr->pRigh
4b90: 74 20 3d 20 30 3b 0a 20 20 20 20 20 20 70 45 78  t = 0;.      pEx
4ba0: 70 72 2d 3e 6f 70 20 3d 20 54 4b 5f 43 4f 4c 55  pr->op = TK_COLU
4bb0: 4d 4e 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  MN;.      break;
4bc0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 63 61 73 65  .    }..    case
4bd0: 20 54 4b 5f 49 4e 3a 20 7b 0a 20 20 20 20 20 20   TK_IN: {.      
4be0: 56 64 62 65 20 2a 76 20 3d 20 73 71 6c 69 74 65  Vdbe *v = sqlite
4bf0: 47 65 74 56 64 62 65 28 70 50 61 72 73 65 29 3b  GetVdbe(pParse);
4c00: 0a 20 20 20 20 20 20 69 66 28 20 76 3d 3d 30 20  .      if( v==0 
4c10: 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20  ) return 1;.    
4c20: 20 20 69 66 28 20 73 71 6c 69 74 65 45 78 70 72    if( sqliteExpr
4c30: 52 65 73 6f 6c 76 65 49 64 73 28 70 50 61 72 73  ResolveIds(pPars
4c40: 65 2c 20 62 61 73 65 2c 20 70 54 61 62 4c 69 73  e, base, pTabLis
4c50: 74 2c 20 70 45 4c 69 73 74 2c 20 70 45 78 70 72  t, pEList, pExpr
4c60: 2d 3e 70 4c 65 66 74 29 20 29 7b 0a 20 20 20 20  ->pLeft) ){.    
4c70: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
4c80: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
4c90: 70 45 78 70 72 2d 3e 70 53 65 6c 65 63 74 20 29  pExpr->pSelect )
4ca0: 7b 0a 20 20 20 20 20 20 20 20 2f 2a 20 43 61 73  {.        /* Cas
4cb0: 65 20 31 3a 20 20 20 20 20 65 78 70 72 20 49 4e  e 1:     expr IN
4cc0: 20 28 53 45 4c 45 43 54 20 2e 2e 2e 29 0a 20 20   (SELECT ...).  
4cd0: 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20        **.       
4ce0: 20 2a 2a 20 47 65 6e 65 72 61 74 65 20 63 6f 64   ** Generate cod
4cf0: 65 20 74 6f 20 77 72 69 74 65 20 74 68 65 20 72  e to write the r
4d00: 65 73 75 6c 74 73 20 6f 66 20 74 68 65 20 73 65  esults of the se
4d10: 6c 65 63 74 20 69 6e 74 6f 20 61 20 74 65 6d 70  lect into a temp
4d20: 6f 72 61 72 79 0a 20 20 20 20 20 20 20 20 2a 2a  orary.        **
4d30: 20 74 61 62 6c 65 2e 20 20 54 68 65 20 63 75 72   table.  The cur
4d40: 73 6f 72 20 6e 75 6d 62 65 72 20 6f 66 20 74 68  sor number of th
4d50: 65 20 74 65 6d 70 6f 72 61 72 79 20 74 61 62 6c  e temporary tabl
4d60: 65 20 68 61 73 20 61 6c 72 65 61 64 79 0a 20 20  e has already.  
4d70: 20 20 20 20 20 20 2a 2a 20 62 65 65 6e 20 70 75        ** been pu
4d80: 74 20 69 6e 20 69 54 61 62 6c 65 20 62 79 20 73  t in iTable by s
4d90: 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c 76 65  qliteExprResolve
4da0: 49 6e 53 65 6c 65 63 74 28 29 2e 0a 20 20 20 20  InSelect()..    
4db0: 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 20 20 70      */.        p
4dc0: 45 78 70 72 2d 3e 69 54 61 62 6c 65 20 3d 20 70  Expr->iTable = p
4dd0: 50 61 72 73 65 2d 3e 6e 54 61 62 2b 2b 3b 0a 20  Parse->nTab++;. 
4de0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
4df0: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4f 70 65  eAddOp(v, OP_Ope
4e00: 6e 54 65 6d 70 2c 20 70 45 78 70 72 2d 3e 69 54  nTemp, pExpr->iT
4e10: 61 62 6c 65 2c 20 31 29 3b 0a 20 20 20 20 20 20  able, 1);.      
4e20: 20 20 73 71 6c 69 74 65 53 65 6c 65 63 74 28 70    sqliteSelect(p
4e30: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 53  Parse, pExpr->pS
4e40: 65 6c 65 63 74 2c 20 53 52 54 5f 53 65 74 2c 20  elect, SRT_Set, 
4e50: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 2c 20 30  pExpr->iTable, 0
4e60: 2c 30 2c 30 29 3b 0a 20 20 20 20 20 20 7d 65 6c  ,0,0);.      }el
4e70: 73 65 20 69 66 28 20 70 45 78 70 72 2d 3e 70 4c  se if( pExpr->pL
4e80: 69 73 74 20 29 7b 0a 20 20 20 20 20 20 20 20 2f  ist ){.        /
4e90: 2a 20 43 61 73 65 20 32 3a 20 20 20 20 20 65 78  * Case 2:     ex
4ea0: 70 72 20 49 4e 20 28 65 78 70 72 6c 69 73 74 29  pr IN (exprlist)
4eb0: 0a 20 20 20 20 20 20 20 20 2a 2a 0a 20 20 20 20  .        **.    
4ec0: 20 20 20 20 2a 2a 20 43 72 65 61 74 65 20 61 20      ** Create a 
4ed0: 73 65 74 20 74 6f 20 70 75 74 20 74 68 65 20 65  set to put the e
4ee0: 78 70 72 6c 69 73 74 20 76 61 6c 75 65 73 20 69  xprlist values i
4ef0: 6e 2e 20 20 54 68 65 20 53 65 74 20 69 64 20 69  n.  The Set id i
4f00: 73 20 73 74 6f 72 65 64 0a 20 20 20 20 20 20 20  s stored.       
4f10: 20 2a 2a 20 69 6e 20 69 54 61 62 6c 65 2e 0a 20   ** in iTable.. 
4f20: 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20         */.      
4f30: 20 20 69 6e 74 20 69 2c 20 69 53 65 74 3b 0a 20    int i, iSet;. 
4f40: 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20         for(i=0; 
4f50: 69 3c 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e  i<pExpr->pList->
4f60: 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a 20 20 20  nExpr; i++){.   
4f70: 20 20 20 20 20 20 20 45 78 70 72 20 2a 70 45 32         Expr *pE2
4f80: 20 3d 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d   = pExpr->pList-
4f90: 3e 61 5b 69 5d 2e 70 45 78 70 72 3b 0a 20 20 20  >a[i].pExpr;.   
4fa0: 20 20 20 20 20 20 20 69 66 28 20 21 73 71 6c 69         if( !sqli
4fb0: 74 65 45 78 70 72 49 73 43 6f 6e 73 74 61 6e 74  teExprIsConstant
4fc0: 28 70 45 32 29 20 29 7b 0a 20 20 20 20 20 20 20  (pE2) ){.       
4fd0: 20 20 20 20 20 73 71 6c 69 74 65 53 65 74 53 74       sqliteSetSt
4fe0: 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a 45  ring(&pParse->zE
4ff0: 72 72 4d 73 67 2c 0a 20 20 20 20 20 20 20 20 20  rrMsg,.         
5000: 20 20 20 20 20 22 72 69 67 68 74 2d 68 61 6e 64       "right-hand
5010: 20 73 69 64 65 20 6f 66 20 49 4e 20 6f 70 65 72   side of IN oper
5020: 61 74 6f 72 20 6d 75 73 74 20 62 65 20 63 6f 6e  ator must be con
5030: 73 74 61 6e 74 22 2c 20 30 29 3b 0a 20 20 20 20  stant", 0);.    
5040: 20 20 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e          pParse->
5050: 6e 45 72 72 2b 2b 3b 0a 20 20 20 20 20 20 20 20  nErr++;.        
5060: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
5070: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
5080: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 45 78      if( sqliteEx
5090: 70 72 43 68 65 63 6b 28 70 50 61 72 73 65 2c 20  prCheck(pParse, 
50a0: 70 45 32 2c 20 30 2c 20 30 29 20 29 7b 0a 20 20  pE2, 0, 0) ){.  
50b0: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
50c0: 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a   1;.          }.
50d0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
50e0: 20 20 69 53 65 74 20 3d 20 70 45 78 70 72 2d 3e    iSet = pExpr->
50f0: 69 54 61 62 6c 65 20 3d 20 70 50 61 72 73 65 2d  iTable = pParse-
5100: 3e 6e 53 65 74 2b 2b 3b 0a 20 20 20 20 20 20 20  >nSet++;.       
5110: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 45 78 70   for(i=0; i<pExp
5120: 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 3b  r->pList->nExpr;
5130: 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20   i++){.         
5140: 20 45 78 70 72 20 2a 70 45 32 20 3d 20 70 45 78   Expr *pE2 = pEx
5150: 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e  pr->pList->a[i].
5160: 70 45 78 70 72 3b 0a 20 20 20 20 20 20 20 20 20  pExpr;.         
5170: 20 73 77 69 74 63 68 28 20 70 45 32 2d 3e 6f 70   switch( pE2->op
5180: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
5190: 63 61 73 65 20 54 4b 5f 46 4c 4f 41 54 3a 0a 20  case TK_FLOAT:. 
51a0: 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20             case 
51b0: 54 4b 5f 49 4e 54 45 47 45 52 3a 0a 20 20 20 20  TK_INTEGER:.    
51c0: 20 20 20 20 20 20 20 20 63 61 73 65 20 54 4b 5f          case TK_
51d0: 53 54 52 49 4e 47 3a 20 7b 0a 20 20 20 20 20 20  STRING: {.      
51e0: 20 20 20 20 20 20 20 20 69 6e 74 20 61 64 64 72          int addr
51f0: 20 3d 20 73 71 6c 69 74 65 56 64 62 65 41 64 64   = sqliteVdbeAdd
5200: 4f 70 28 76 2c 20 4f 50 5f 53 65 74 49 6e 73 65  Op(v, OP_SetInse
5210: 72 74 2c 20 69 53 65 74 2c 20 30 29 3b 0a 20 20  rt, iSet, 0);.  
5220: 20 20 20 20 20 20 20 20 20 20 20 20 61 73 73 65              asse
5230: 72 74 28 20 70 45 32 2d 3e 74 6f 6b 65 6e 2e 7a  rt( pE2->token.z
5240: 20 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20   );.            
5250: 20 20 73 71 6c 69 74 65 56 64 62 65 43 68 61 6e    sqliteVdbeChan
5260: 67 65 50 33 28 76 2c 20 61 64 64 72 2c 20 70 45  geP3(v, addr, pE
5270: 32 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 45 32 2d  2->token.z, pE2-
5280: 3e 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20 20 20  >token.n);.     
5290: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 56           sqliteV
52a0: 64 62 65 44 65 71 75 6f 74 65 50 33 28 76 2c 20  dbeDequoteP3(v, 
52b0: 61 64 64 72 29 3b 0a 20 20 20 20 20 20 20 20 20  addr);.         
52c0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
52d0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
52e0: 20 20 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b        default: {
52f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73  .              s
5300: 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50  qliteExprCode(pP
5310: 61 72 73 65 2c 20 70 45 32 29 3b 0a 20 20 20 20  arse, pE2);.    
5320: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
5330: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
5340: 53 65 74 49 6e 73 65 72 74 2c 20 69 53 65 74 2c  SetInsert, iSet,
5350: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20   0);.           
5360: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
5370: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
5380: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
5390: 20 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65 61      }.      brea
53a0: 6b 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 63 61  k;.    }..    ca
53b0: 73 65 20 54 4b 5f 53 45 4c 45 43 54 3a 20 7b 0a  se TK_SELECT: {.
53c0: 20 20 20 20 20 20 2f 2a 20 54 68 69 73 20 68 61        /* This ha
53d0: 73 20 74 6f 20 62 65 20 61 20 73 63 61 6c 61 72  s to be a scalar
53e0: 20 53 45 4c 45 43 54 2e 20 20 47 65 6e 65 72 61   SELECT.  Genera
53f0: 74 65 20 63 6f 64 65 20 74 6f 20 70 75 74 20 74  te code to put t
5400: 68 65 0a 20 20 20 20 20 20 2a 2a 20 76 61 6c 75  he.      ** valu
5410: 65 20 6f 66 20 74 68 69 73 20 73 65 6c 65 63 74  e of this select
5420: 20 69 6e 20 61 20 6d 65 6d 6f 72 79 20 63 65 6c   in a memory cel
5430: 6c 20 61 6e 64 20 72 65 63 6f 72 64 20 74 68 65  l and record the
5440: 20 6e 75 6d 62 65 72 0a 20 20 20 20 20 20 2a 2a   number.      **
5450: 20 6f 66 20 74 68 65 20 6d 65 6d 6f 72 79 20 63   of the memory c
5460: 65 6c 6c 20 69 6e 20 69 43 6f 6c 75 6d 6e 2e 0a  ell in iColumn..
5470: 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 70        */.      p
5480: 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20  Expr->iColumn = 
5490: 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 2b 2b 3b 0a  pParse->nMem++;.
54a0: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
54b0: 53 65 6c 65 63 74 28 70 50 61 72 73 65 2c 20 70  Select(pParse, p
54c0: 45 78 70 72 2d 3e 70 53 65 6c 65 63 74 2c 20 53  Expr->pSelect, S
54d0: 52 54 5f 4d 65 6d 2c 20 70 45 78 70 72 2d 3e 69  RT_Mem, pExpr->i
54e0: 43 6f 6c 75 6d 6e 2c 30 2c 30 2c 30 29 20 29 7b  Column,0,0,0) ){
54f0: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
5500: 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  1;.      }.     
5510: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 0a 20   break;.    }.. 
5520: 20 20 20 2f 2a 20 46 6f 72 20 61 6c 6c 20 65 6c     /* For all el
5530: 73 65 2c 20 6a 75 73 74 20 72 65 63 75 72 73 69  se, just recursi
5540: 76 65 6c 79 20 77 61 6c 6b 20 74 68 65 20 74 72  vely walk the tr
5550: 65 65 20 2a 2f 0a 20 20 20 20 64 65 66 61 75 6c  ee */.    defaul
5560: 74 3a 20 7b 0a 20 20 20 20 20 20 69 66 28 20 70  t: {.      if( p
5570: 45 78 70 72 2d 3e 70 4c 65 66 74 0a 20 20 20 20  Expr->pLeft.    
5580: 20 20 26 26 20 73 71 6c 69 74 65 45 78 70 72 52    && sqliteExprR
5590: 65 73 6f 6c 76 65 49 64 73 28 70 50 61 72 73 65  esolveIds(pParse
55a0: 2c 20 62 61 73 65 2c 20 70 54 61 62 4c 69 73 74  , base, pTabList
55b0: 2c 20 70 45 4c 69 73 74 2c 20 70 45 78 70 72 2d  , pEList, pExpr-
55c0: 3e 70 4c 65 66 74 29 20 29 7b 0a 20 20 20 20 20  >pLeft) ){.     
55d0: 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20     return 1;.   
55e0: 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20 70     }.      if( p
55f0: 45 78 70 72 2d 3e 70 52 69 67 68 74 20 0a 20 20  Expr->pRight .  
5600: 20 20 20 20 26 26 20 73 71 6c 69 74 65 45 78 70      && sqliteExp
5610: 72 52 65 73 6f 6c 76 65 49 64 73 28 70 50 61 72  rResolveIds(pPar
5620: 73 65 2c 20 62 61 73 65 2c 20 70 54 61 62 4c 69  se, base, pTabLi
5630: 73 74 2c 20 70 45 4c 69 73 74 2c 20 70 45 78 70  st, pEList, pExp
5640: 72 2d 3e 70 52 69 67 68 74 29 20 29 7b 0a 20 20  r->pRight) ){.  
5650: 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a        return 1;.
5660: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
5670: 28 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 20 29  ( pExpr->pList )
5680: 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 3b  {.        int i;
5690: 0a 20 20 20 20 20 20 20 20 45 78 70 72 4c 69 73  .        ExprLis
56a0: 74 20 2a 70 4c 69 73 74 20 3d 20 70 45 78 70 72  t *pList = pExpr
56b0: 2d 3e 70 4c 69 73 74 3b 0a 20 20 20 20 20 20 20  ->pList;.       
56c0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 4c 69 73   for(i=0; i<pLis
56d0: 74 2d 3e 6e 45 78 70 72 3b 20 69 2b 2b 29 7b 0a  t->nExpr; i++){.
56e0: 20 20 20 20 20 20 20 20 20 20 45 78 70 72 20 2a            Expr *
56f0: 70 41 72 67 20 3d 20 70 4c 69 73 74 2d 3e 61 5b  pArg = pList->a[
5700: 69 5d 2e 70 45 78 70 72 3b 0a 20 20 20 20 20 20  i].pExpr;.      
5710: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 45 78      if( sqliteEx
5720: 70 72 52 65 73 6f 6c 76 65 49 64 73 28 70 50 61  prResolveIds(pPa
5730: 72 73 65 2c 20 62 61 73 65 2c 20 70 54 61 62 4c  rse, base, pTabL
5740: 69 73 74 2c 20 70 45 4c 69 73 74 2c 20 70 41 72  ist, pEList, pAr
5750: 67 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  g) ){.          
5760: 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20    return 1;.    
5770: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
5780: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  }.      }.    }.
5790: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a    }.  return 0;.
57a0: 7d 0a 0a 2f 2a 0a 2a 2a 20 45 72 72 6f 72 20 63  }../*.** Error c
57b0: 68 65 63 6b 20 74 68 65 20 66 75 6e 63 74 69 6f  heck the functio
57c0: 6e 73 20 69 6e 20 61 6e 20 65 78 70 72 65 73 73  ns in an express
57d0: 69 6f 6e 2e 20 20 4d 61 6b 65 20 73 75 72 65 20  ion.  Make sure 
57e0: 61 6c 6c 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 20  all.** function 
57f0: 6e 61 6d 65 73 20 61 72 65 20 72 65 63 6f 67 6e  names are recogn
5800: 69 7a 65 64 20 61 6e 64 20 61 6c 6c 20 66 75 6e  ized and all fun
5810: 63 74 69 6f 6e 73 20 68 61 76 65 20 74 68 65 20  ctions have the 
5820: 63 6f 72 72 65 63 74 0a 2a 2a 20 6e 75 6d 62 65  correct.** numbe
5830: 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73 2e 20  r of arguments. 
5840: 20 4c 65 61 76 65 20 61 6e 20 65 72 72 6f 72 20   Leave an error 
5850: 6d 65 73 73 61 67 65 20 69 6e 20 70 50 61 72 73  message in pPars
5860: 65 2d 3e 7a 45 72 72 4d 73 67 0a 2a 2a 20 69 66  e->zErrMsg.** if
5870: 20 61 6e 79 74 68 69 6e 67 20 69 73 20 61 6d 69   anything is ami
5880: 73 73 2e 20 20 52 65 74 75 72 6e 20 74 68 65 20  ss.  Return the 
5890: 6e 75 6d 62 65 72 20 6f 66 20 65 72 72 6f 72 73  number of errors
58a0: 2e 0a 2a 2a 0a 2a 2a 20 69 66 20 70 49 73 41 67  ..**.** if pIsAg
58b0: 67 20 69 73 20 6e 6f 74 20 6e 75 6c 6c 20 61 6e  g is not null an
58c0: 64 20 74 68 69 73 20 65 78 70 72 65 73 73 69 6f  d this expressio
58d0: 6e 20 69 73 20 61 6e 20 61 67 67 72 65 67 61 74  n is an aggregat
58e0: 65 20 66 75 6e 63 74 69 6f 6e 0a 2a 2a 20 28 6c  e function.** (l
58f0: 69 6b 65 20 63 6f 75 6e 74 28 2a 29 20 6f 72 20  ike count(*) or 
5900: 6d 61 78 28 76 61 6c 75 65 29 29 20 74 68 65 6e  max(value)) then
5910: 20 77 72 69 74 65 20 61 20 31 20 69 6e 74 6f 20   write a 1 into 
5920: 2a 70 49 73 41 67 67 2e 0a 2a 2f 0a 69 6e 74 20  *pIsAgg..*/.int 
5930: 73 71 6c 69 74 65 45 78 70 72 43 68 65 63 6b 28  sqliteExprCheck(
5940: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 45  Parse *pParse, E
5950: 78 70 72 20 2a 70 45 78 70 72 2c 20 69 6e 74 20  xpr *pExpr, int 
5960: 61 6c 6c 6f 77 41 67 67 2c 20 69 6e 74 20 2a 70  allowAgg, int *p
5970: 49 73 41 67 67 29 7b 0a 20 20 69 6e 74 20 6e 45  IsAgg){.  int nE
5980: 72 72 20 3d 20 30 3b 0a 20 20 69 66 28 20 70 45  rr = 0;.  if( pE
5990: 78 70 72 3d 3d 30 20 29 20 72 65 74 75 72 6e 20  xpr==0 ) return 
59a0: 30 3b 0a 20 20 73 77 69 74 63 68 28 20 70 45 78  0;.  switch( pEx
59b0: 70 72 2d 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61  pr->op ){.    ca
59c0: 73 65 20 54 4b 5f 46 55 4e 43 54 49 4f 4e 3a 20  se TK_FUNCTION: 
59d0: 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  {.      int n = 
59e0: 70 45 78 70 72 2d 3e 70 4c 69 73 74 20 3f 20 70  pExpr->pList ? p
59f0: 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78  Expr->pList->nEx
5a00: 70 72 20 3a 20 30 3b 20 20 2f 2a 20 4e 75 6d 62  pr : 0;  /* Numb
5a10: 65 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73 20  er of arguments 
5a20: 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20 6e 6f 5f  */.      int no_
5a30: 73 75 63 68 5f 66 75 6e 63 20 3d 20 30 3b 20 20  such_func = 0;  
5a40: 20 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20       /* True if 
5a50: 6e 6f 20 73 75 63 68 20 66 75 6e 63 74 69 6f 6e  no such function
5a60: 20 65 78 69 73 74 73 20 2a 2f 0a 20 20 20 20 20   exists */.     
5a70: 20 69 6e 74 20 69 73 5f 74 79 70 65 5f 6f 66 20   int is_type_of 
5a80: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 2f 2a 20  = 0;         /* 
5a90: 54 72 75 65 20 69 66 20 69 73 20 74 68 65 20 73  True if is the s
5aa0: 70 65 63 69 61 6c 20 54 79 70 65 4f 66 28 29 20  pecial TypeOf() 
5ab0: 66 75 6e 63 74 69 6f 6e 20 2a 2f 0a 20 20 20 20  function */.    
5ac0: 20 20 69 6e 74 20 77 72 6f 6e 67 5f 6e 75 6d 5f    int wrong_num_
5ad0: 61 72 67 73 20 3d 20 30 3b 20 20 20 20 20 2f 2a  args = 0;     /*
5ae0: 20 54 72 75 65 20 69 66 20 77 72 6f 6e 67 20 6e   True if wrong n
5af0: 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e  umber of argumen
5b00: 74 73 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74 20  ts */.      int 
5b10: 69 73 5f 61 67 67 20 3d 20 30 3b 20 20 20 20 20  is_agg = 0;     
5b20: 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20          /* True 
5b30: 69 66 20 69 73 20 61 6e 20 61 67 67 72 65 67 61  if is an aggrega
5b40: 74 65 20 66 75 6e 63 74 69 6f 6e 20 2a 2f 0a 20  te function */. 
5b50: 20 20 20 20 20 69 6e 74 20 69 3b 0a 20 20 20 20       int i;.    
5b60: 20 20 46 75 6e 63 44 65 66 20 2a 70 44 65 66 3b    FuncDef *pDef;
5b70: 0a 0a 20 20 20 20 20 20 70 44 65 66 20 3d 20 73  ..      pDef = s
5b80: 71 6c 69 74 65 46 69 6e 64 46 75 6e 63 74 69 6f  qliteFindFunctio
5b90: 6e 28 70 50 61 72 73 65 2d 3e 64 62 2c 0a 20 20  n(pParse->db,.  
5ba0: 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 74 6f         pExpr->to
5bb0: 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f  ken.z, pExpr->to
5bc0: 6b 65 6e 2e 6e 2c 20 6e 2c 20 30 29 3b 0a 20 20  ken.n, n, 0);.  
5bd0: 20 20 20 20 69 66 28 20 70 44 65 66 3d 3d 30 20      if( pDef==0 
5be0: 29 7b 0a 20 20 20 20 20 20 20 20 70 44 65 66 20  ){.        pDef 
5bf0: 3d 20 73 71 6c 69 74 65 46 69 6e 64 46 75 6e 63  = sqliteFindFunc
5c00: 74 69 6f 6e 28 70 50 61 72 73 65 2d 3e 64 62 2c  tion(pParse->db,
5c10: 0a 20 20 20 20 20 20 20 20 20 20 20 70 45 78 70  .           pExp
5c20: 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70  r->token.z, pExp
5c30: 72 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20 2d 31 2c 20  r->token.n, -1, 
5c40: 30 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20  0);.        if( 
5c50: 70 44 65 66 3d 3d 30 20 29 7b 0a 20 20 20 20 20  pDef==0 ){.     
5c60: 20 20 20 20 20 69 66 28 20 6e 3d 3d 31 20 26 26       if( n==1 &&
5c70: 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 3d   pExpr->token.n=
5c80: 3d 36 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  =6.             
5c90: 20 20 26 26 20 73 71 6c 69 74 65 53 74 72 4e 49    && sqliteStrNI
5ca0: 43 6d 70 28 70 45 78 70 72 2d 3e 74 6f 6b 65 6e  Cmp(pExpr->token
5cb0: 2e 7a 2c 20 22 74 79 70 65 6f 66 22 2c 20 36 29  .z, "typeof", 6)
5cc0: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ==0 ){.         
5cd0: 20 20 20 69 73 5f 74 79 70 65 5f 6f 66 20 3d 20     is_type_of = 
5ce0: 31 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 65 6c  1;.          }el
5cf0: 73 65 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20  se {.           
5d00: 20 6e 6f 5f 73 75 63 68 5f 66 75 6e 63 20 3d 20   no_such_func = 
5d10: 31 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  1;.          }. 
5d20: 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20         }else{.  
5d30: 20 20 20 20 20 20 20 20 77 72 6f 6e 67 5f 6e 75          wrong_nu
5d40: 6d 5f 61 72 67 73 20 3d 20 31 3b 0a 20 20 20 20  m_args = 1;.    
5d50: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 65 6c 73      }.      }els
5d60: 65 7b 0a 20 20 20 20 20 20 20 20 69 73 5f 61 67  e{.        is_ag
5d70: 67 20 3d 20 70 44 65 66 2d 3e 78 46 75 6e 63 3d  g = pDef->xFunc=
5d80: 3d 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  =0;.      }.    
5d90: 20 20 69 66 28 20 69 73 5f 61 67 67 20 26 26 20    if( is_agg && 
5da0: 21 61 6c 6c 6f 77 41 67 67 20 29 7b 0a 20 20 20  !allowAgg ){.   
5db0: 20 20 20 20 20 73 71 6c 69 74 65 53 65 74 4e 53       sqliteSetNS
5dc0: 74 72 69 6e 67 28 26 70 50 61 72 73 65 2d 3e 7a  tring(&pParse->z
5dd0: 45 72 72 4d 73 67 2c 20 22 6d 69 73 75 73 65 20  ErrMsg, "misuse 
5de0: 6f 66 20 61 67 67 72 65 67 61 74 65 20 66 75 6e  of aggregate fun
5df0: 63 74 69 6f 6e 20 22 2c 20 2d 31 2c 0a 20 20 20  ction ", -1,.   
5e00: 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 74          pExpr->t
5e10: 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74  oken.z, pExpr->t
5e20: 6f 6b 65 6e 2e 6e 2c 20 22 28 29 22 2c 20 32 2c  oken.n, "()", 2,
5e30: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50 61   0);.        pPa
5e40: 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20  rse->nErr++;.   
5e50: 20 20 20 20 20 6e 45 72 72 2b 2b 3b 0a 20 20 20       nErr++;.   
5e60: 20 20 20 20 20 69 73 5f 61 67 67 20 3d 20 30 3b       is_agg = 0;
5e70: 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28  .      }else if(
5e80: 20 6e 6f 5f 73 75 63 68 5f 66 75 6e 63 20 29 7b   no_such_func ){
5e90: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 53  .        sqliteS
5ea0: 65 74 4e 53 74 72 69 6e 67 28 26 70 50 61 72 73  etNString(&pPars
5eb0: 65 2d 3e 7a 45 72 72 4d 73 67 2c 20 22 6e 6f 20  e->zErrMsg, "no 
5ec0: 73 75 63 68 20 66 75 6e 63 74 69 6f 6e 3a 20 22  such function: "
5ed0: 2c 20 2d 31 2c 0a 20 20 20 20 20 20 20 20 20 20  , -1,.          
5ee0: 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c   pExpr->token.z,
5ef0: 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 2c   pExpr->token.n,
5f00: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 70 50 61   0);.        pPa
5f10: 72 73 65 2d 3e 6e 45 72 72 2b 2b 3b 0a 20 20 20  rse->nErr++;.   
5f20: 20 20 20 20 20 6e 45 72 72 2b 2b 3b 0a 20 20 20       nErr++;.   
5f30: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 77 72 6f     }else if( wro
5f40: 6e 67 5f 6e 75 6d 5f 61 72 67 73 20 29 7b 0a 20  ng_num_args ){. 
5f50: 20 20 20 20 20 20 20 73 71 6c 69 74 65 53 65 74         sqliteSet
5f60: 4e 53 74 72 69 6e 67 28 26 70 50 61 72 73 65 2d  NString(&pParse-
5f70: 3e 7a 45 72 72 4d 73 67 2c 20 0a 20 20 20 20 20  >zErrMsg, .     
5f80: 20 20 20 20 20 20 22 77 72 6f 6e 67 20 6e 75 6d        "wrong num
5f90: 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73  ber of arguments
5fa0: 20 74 6f 20 66 75 6e 63 74 69 6f 6e 20 22 2c 2d   to function ",-
5fb0: 31 2c 0a 20 20 20 20 20 20 20 20 20 20 20 70 45  1,.           pE
5fc0: 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20 70 45  xpr->token.z, pE
5fd0: 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 2c 20 22 28  xpr->token.n, "(
5fe0: 29 22 2c 20 32 2c 20 30 29 3b 0a 20 20 20 20 20  )", 2, 0);.     
5ff0: 20 20 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 2b     pParse->nErr+
6000: 2b 3b 0a 20 20 20 20 20 20 20 20 6e 45 72 72 2b  +;.        nErr+
6010: 2b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  +;.      }.     
6020: 20 69 66 28 20 69 73 5f 61 67 67 20 29 20 70 45   if( is_agg ) pE
6030: 78 70 72 2d 3e 6f 70 20 3d 20 54 4b 5f 41 47 47  xpr->op = TK_AGG
6040: 5f 46 55 4e 43 54 49 4f 4e 3b 0a 20 20 20 20 20  _FUNCTION;.     
6050: 20 69 66 28 20 69 73 5f 61 67 67 20 26 26 20 70   if( is_agg && p
6060: 49 73 41 67 67 20 29 20 2a 70 49 73 41 67 67 20  IsAgg ) *pIsAgg 
6070: 3d 20 31 3b 0a 20 20 20 20 20 20 66 6f 72 28 69  = 1;.      for(i
6080: 3d 30 3b 20 6e 45 72 72 3d 3d 30 20 26 26 20 69  =0; nErr==0 && i
6090: 3c 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  <n; i++){.      
60a0: 20 20 6e 45 72 72 20 3d 20 73 71 6c 69 74 65 45    nErr = sqliteE
60b0: 78 70 72 43 68 65 63 6b 28 70 50 61 72 73 65 2c  xprCheck(pParse,
60c0: 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61   pExpr->pList->a
60d0: 5b 69 5d 2e 70 45 78 70 72 2c 0a 20 20 20 20 20  [i].pExpr,.     
60e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
60f0: 20 20 20 20 20 20 20 20 20 20 61 6c 6c 6f 77 41            allowA
6100: 67 67 20 26 26 20 21 69 73 5f 61 67 67 2c 20 70  gg && !is_agg, p
6110: 49 73 41 67 67 29 3b 0a 20 20 20 20 20 20 7d 0a  IsAgg);.      }.
6120: 20 20 20 20 20 20 69 66 28 20 70 44 65 66 3d 3d        if( pDef==
6130: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28  0 ){.        if(
6140: 20 69 73 5f 74 79 70 65 5f 6f 66 20 29 7b 0a 20   is_type_of ){. 
6150: 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e           pExpr->
6160: 6f 70 20 3d 20 54 4b 5f 53 54 52 49 4e 47 3b 0a  op = TK_STRING;.
6170: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 73 71            if( sq
6180: 6c 69 74 65 45 78 70 72 54 79 70 65 28 70 45 78  liteExprType(pEx
6190: 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 30 5d 2e  pr->pList->a[0].
61a0: 70 45 78 70 72 29 3d 3d 53 51 4c 49 54 45 5f 53  pExpr)==SQLITE_S
61b0: 4f 5f 4e 55 4d 20 29 7b 0a 20 20 20 20 20 20 20  O_NUM ){.       
61c0: 20 20 20 20 20 70 45 78 70 72 2d 3e 74 6f 6b 65       pExpr->toke
61d0: 6e 2e 7a 20 3d 20 22 6e 75 6d 65 72 69 63 22 3b  n.z = "numeric";
61e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 45 78  .            pEx
61f0: 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 20 3d 20 37 3b  pr->token.n = 7;
6200: 0a 20 20 20 20 20 20 20 20 20 20 7d 65 6c 73 65  .          }else
6210: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 45  {.            pE
6220: 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 20 3d 20 22  xpr->token.z = "
6230: 74 65 78 74 22 3b 0a 20 20 20 20 20 20 20 20 20  text";.         
6240: 20 20 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e     pExpr->token.
6250: 6e 20 3d 20 34 3b 0a 20 20 20 20 20 20 20 20 20  n = 4;.         
6260: 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20   }.        }.   
6270: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 70 44 65     }else if( pDe
6280: 66 2d 3e 64 61 74 61 54 79 70 65 3e 3d 30 20 29  f->dataType>=0 )
6290: 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 44  {.        if( pD
62a0: 65 66 2d 3e 64 61 74 61 54 79 70 65 3c 6e 20 29  ef->dataType<n )
62b0: 7b 0a 20 20 20 20 20 20 20 20 20 20 70 45 78 70  {.          pExp
62c0: 72 2d 3e 64 61 74 61 54 79 70 65 20 3d 20 0a 20  r->dataType = . 
62d0: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
62e0: 74 65 45 78 70 72 54 79 70 65 28 70 45 78 70 72  teExprType(pExpr
62f0: 2d 3e 70 4c 69 73 74 2d 3e 61 5b 70 44 65 66 2d  ->pList->a[pDef-
6300: 3e 64 61 74 61 54 79 70 65 5d 2e 70 45 78 70 72  >dataType].pExpr
6310: 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65  );.        }else
6320: 7b 0a 20 20 20 20 20 20 20 20 20 20 70 45 78 70  {.          pExp
6330: 72 2d 3e 64 61 74 61 54 79 70 65 20 3d 20 53 51  r->dataType = SQ
6340: 4c 49 54 45 5f 53 4f 5f 4e 55 4d 3b 0a 20 20 20  LITE_SO_NUM;.   
6350: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 65 6c       }.      }el
6360: 73 65 20 69 66 28 20 70 44 65 66 2d 3e 64 61 74  se if( pDef->dat
6370: 61 54 79 70 65 3d 3d 53 51 4c 49 54 45 5f 41 52  aType==SQLITE_AR
6380: 47 53 20 29 7b 0a 20 20 20 20 20 20 20 20 70 44  GS ){.        pD
6390: 65 66 2d 3e 64 61 74 61 54 79 70 65 20 3d 20 53  ef->dataType = S
63a0: 51 4c 49 54 45 5f 53 4f 5f 54 45 58 54 3b 0a 20  QLITE_SO_TEXT;. 
63b0: 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20         for(i=0; 
63c0: 69 3c 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20  i<n; i++){.     
63d0: 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 45       if( sqliteE
63e0: 78 70 72 54 79 70 65 28 70 45 78 70 72 2d 3e 70  xprType(pExpr->p
63f0: 4c 69 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72  List->a[i].pExpr
6400: 29 3d 3d 53 51 4c 49 54 45 5f 53 4f 5f 4e 55 4d  )==SQLITE_SO_NUM
6410: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
6420: 70 45 78 70 72 2d 3e 64 61 74 61 54 79 70 65 20  pExpr->dataType 
6430: 3d 20 53 51 4c 49 54 45 5f 53 4f 5f 4e 55 4d 3b  = SQLITE_SO_NUM;
6440: 0a 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65  .            bre
6450: 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a  ak;.          }.
6460: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
6470: 7d 65 6c 73 65 20 69 66 28 20 70 44 65 66 2d 3e  }else if( pDef->
6480: 64 61 74 61 54 79 70 65 3d 3d 53 51 4c 49 54 45  dataType==SQLITE
6490: 5f 4e 55 4d 45 52 49 43 20 29 7b 0a 20 20 20 20  _NUMERIC ){.    
64a0: 20 20 20 20 70 45 78 70 72 2d 3e 64 61 74 61 54      pExpr->dataT
64b0: 79 70 65 20 3d 20 53 51 4c 49 54 45 5f 53 4f 5f  ype = SQLITE_SO_
64c0: 4e 55 4d 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  NUM;.      }else
64d0: 7b 0a 20 20 20 20 20 20 20 20 70 45 78 70 72 2d  {.        pExpr-
64e0: 3e 64 61 74 61 54 79 70 65 20 3d 20 53 51 4c 49  >dataType = SQLI
64f0: 54 45 5f 53 4f 5f 54 45 58 54 3b 0a 20 20 20 20  TE_SO_TEXT;.    
6500: 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 64 65    }.    }.    de
6510: 66 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20 69  fault: {.      i
6520: 66 28 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 20  f( pExpr->pLeft 
6530: 29 7b 0a 20 20 20 20 20 20 20 20 6e 45 72 72 20  ){.        nErr 
6540: 3d 20 73 71 6c 69 74 65 45 78 70 72 43 68 65 63  = sqliteExprChec
6550: 6b 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d  k(pParse, pExpr-
6560: 3e 70 4c 65 66 74 2c 20 61 6c 6c 6f 77 41 67 67  >pLeft, allowAgg
6570: 2c 20 70 49 73 41 67 67 29 3b 0a 20 20 20 20 20  , pIsAgg);.     
6580: 20 7d 0a 20 20 20 20 20 20 69 66 28 20 6e 45 72   }.      if( nEr
6590: 72 3d 3d 30 20 26 26 20 70 45 78 70 72 2d 3e 70  r==0 && pExpr->p
65a0: 52 69 67 68 74 20 29 7b 0a 20 20 20 20 20 20 20  Right ){.       
65b0: 20 6e 45 72 72 20 3d 20 73 71 6c 69 74 65 45 78   nErr = sqliteEx
65c0: 70 72 43 68 65 63 6b 28 70 50 61 72 73 65 2c 20  prCheck(pParse, 
65d0: 70 45 78 70 72 2d 3e 70 52 69 67 68 74 2c 20 61  pExpr->pRight, a
65e0: 6c 6c 6f 77 41 67 67 2c 20 70 49 73 41 67 67 29  llowAgg, pIsAgg)
65f0: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
6600: 69 66 28 20 6e 45 72 72 3d 3d 30 20 26 26 20 70  if( nErr==0 && p
6610: 45 78 70 72 2d 3e 70 4c 69 73 74 20 29 7b 0a 20  Expr->pList ){. 
6620: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 70         int n = p
6630: 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78  Expr->pList->nEx
6640: 70 72 3b 0a 20 20 20 20 20 20 20 20 69 6e 74 20  pr;.        int 
6650: 69 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69  i;.        for(i
6660: 3d 30 3b 20 6e 45 72 72 3d 3d 30 20 26 26 20 69  =0; nErr==0 && i
6670: 3c 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  <n; i++){.      
6680: 20 20 20 20 45 78 70 72 20 2a 70 45 32 20 3d 20      Expr *pE2 = 
6690: 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b  pExpr->pList->a[
66a0: 69 5d 2e 70 45 78 70 72 3b 0a 20 20 20 20 20 20  i].pExpr;.      
66b0: 20 20 20 20 6e 45 72 72 20 3d 20 73 71 6c 69 74      nErr = sqlit
66c0: 65 45 78 70 72 43 68 65 63 6b 28 70 50 61 72 73  eExprCheck(pPars
66d0: 65 2c 20 70 45 32 2c 20 61 6c 6c 6f 77 41 67 67  e, pE2, allowAgg
66e0: 2c 20 70 49 73 41 67 67 29 3b 0a 20 20 20 20 20  , pIsAgg);.     
66f0: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
6700: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
6710: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 6e 45 72    }.  return nEr
6720: 72 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  r;.}../*.** Retu
6730: 72 6e 20 65 69 74 68 65 72 20 53 51 4c 49 54 45  rn either SQLITE
6740: 5f 53 4f 5f 4e 55 4d 20 6f 72 20 53 51 4c 49 54  _SO_NUM or SQLIT
6750: 45 5f 53 4f 5f 54 45 58 54 20 74 6f 20 69 6e 64  E_SO_TEXT to ind
6760: 69 63 61 74 65 20 77 68 65 74 68 65 72 20 74 68  icate whether th
6770: 65 0a 2a 2a 20 67 69 76 65 6e 20 65 78 70 72 65  e.** given expre
6780: 73 73 69 6f 6e 20 73 68 6f 75 6c 64 20 73 6f 72  ssion should sor
6790: 74 20 61 73 20 6e 75 6d 65 72 69 63 20 76 61 6c  t as numeric val
67a0: 75 65 73 20 6f 72 20 61 73 20 74 65 78 74 2e 0a  ues or as text..
67b0: 2a 2a 0a 2a 2a 20 54 68 65 20 73 71 6c 69 74 65  **.** The sqlite
67c0: 45 78 70 72 52 65 73 6f 6c 76 65 49 64 73 28 29  ExprResolveIds()
67d0: 20 61 6e 64 20 73 71 6c 69 74 65 45 78 70 72 43   and sqliteExprC
67e0: 68 65 63 6b 28 29 20 72 6f 75 74 69 6e 65 73 20  heck() routines 
67f0: 6d 75 73 74 20 68 61 76 65 0a 2a 2a 20 62 6f 74  must have.** bot
6800: 68 20 62 65 65 6e 20 63 61 6c 6c 65 64 20 6f 6e  h been called on
6810: 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 20   the expression 
6820: 62 65 66 6f 72 65 20 69 74 20 69 73 20 70 61 73  before it is pas
6830: 73 65 64 20 74 6f 20 74 68 69 73 20 72 6f 75 74  sed to this rout
6840: 69 6e 65 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69  ine..*/.int sqli
6850: 74 65 45 78 70 72 54 79 70 65 28 45 78 70 72 20  teExprType(Expr 
6860: 2a 70 29 7b 0a 20 20 69 66 28 20 70 3d 3d 30 20  *p){.  if( p==0 
6870: 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f  ) return SQLITE_
6880: 53 4f 5f 4e 55 4d 3b 0a 20 20 77 68 69 6c 65 28  SO_NUM;.  while(
6890: 20 70 20 29 20 73 77 69 74 63 68 28 20 70 2d 3e   p ) switch( p->
68a0: 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65 20 54  op ){.    case T
68b0: 4b 5f 50 4c 55 53 3a 0a 20 20 20 20 63 61 73 65  K_PLUS:.    case
68c0: 20 54 4b 5f 4d 49 4e 55 53 3a 0a 20 20 20 20 63   TK_MINUS:.    c
68d0: 61 73 65 20 54 4b 5f 53 54 41 52 3a 0a 20 20 20  ase TK_STAR:.   
68e0: 20 63 61 73 65 20 54 4b 5f 53 4c 41 53 48 3a 0a   case TK_SLASH:.
68f0: 20 20 20 20 63 61 73 65 20 54 4b 5f 41 4e 44 3a      case TK_AND:
6900: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4f 52 3a  .    case TK_OR:
6910: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49 53 4e  .    case TK_ISN
6920: 55 4c 4c 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  ULL:.    case TK
6930: 5f 4e 4f 54 4e 55 4c 4c 3a 0a 20 20 20 20 63 61  _NOTNULL:.    ca
6940: 73 65 20 54 4b 5f 4e 4f 54 3a 0a 20 20 20 20 63  se TK_NOT:.    c
6950: 61 73 65 20 54 4b 5f 55 4d 49 4e 55 53 3a 0a 20  ase TK_UMINUS:. 
6960: 20 20 20 63 61 73 65 20 54 4b 5f 42 49 54 41 4e     case TK_BITAN
6970: 44 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 42  D:.    case TK_B
6980: 49 54 4f 52 3a 0a 20 20 20 20 63 61 73 65 20 54  ITOR:.    case T
6990: 4b 5f 42 49 54 4e 4f 54 3a 0a 20 20 20 20 63 61  K_BITNOT:.    ca
69a0: 73 65 20 54 4b 5f 4c 53 48 49 46 54 3a 0a 20 20  se TK_LSHIFT:.  
69b0: 20 20 63 61 73 65 20 54 4b 5f 52 53 48 49 46 54    case TK_RSHIFT
69c0: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 52 45  :.    case TK_RE
69d0: 4d 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49  M:.    case TK_I
69e0: 4e 54 45 47 45 52 3a 0a 20 20 20 20 63 61 73 65  NTEGER:.    case
69f0: 20 54 4b 5f 46 4c 4f 41 54 3a 0a 20 20 20 20 63   TK_FLOAT:.    c
6a00: 61 73 65 20 54 4b 5f 49 4e 3a 0a 20 20 20 20 63  ase TK_IN:.    c
6a10: 61 73 65 20 54 4b 5f 42 45 54 57 45 45 4e 3a 0a  ase TK_BETWEEN:.
6a20: 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c        return SQL
6a30: 49 54 45 5f 53 4f 5f 4e 55 4d 3b 0a 0a 20 20 20  ITE_SO_NUM;..   
6a40: 20 63 61 73 65 20 54 4b 5f 53 54 52 49 4e 47 3a   case TK_STRING:
6a50: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e 55 4c  .    case TK_NUL
6a60: 4c 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 43  L:.    case TK_C
6a70: 4f 4e 43 41 54 3a 0a 20 20 20 20 20 20 72 65 74  ONCAT:.      ret
6a80: 75 72 6e 20 53 51 4c 49 54 45 5f 53 4f 5f 54 45  urn SQLITE_SO_TE
6a90: 58 54 3b 0a 0a 20 20 20 20 63 61 73 65 20 54 4b  XT;..    case TK
6aa0: 5f 4c 54 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _LT:.    case TK
6ab0: 5f 4c 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _LE:.    case TK
6ac0: 5f 47 54 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _GT:.    case TK
6ad0: 5f 47 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _GE:.    case TK
6ae0: 5f 4e 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  _NE:.    case TK
6af0: 5f 45 51 3a 0a 20 20 20 20 20 20 69 66 28 20 73  _EQ:.      if( s
6b00: 71 6c 69 74 65 45 78 70 72 54 79 70 65 28 70 2d  qliteExprType(p-
6b10: 3e 70 4c 65 66 74 29 3d 3d 53 51 4c 49 54 45 5f  >pLeft)==SQLITE_
6b20: 53 4f 5f 4e 55 4d 20 29 7b 0a 20 20 20 20 20 20  SO_NUM ){.      
6b30: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
6b40: 53 4f 5f 4e 55 4d 3b 0a 20 20 20 20 20 20 7d 0a  SO_NUM;.      }.
6b50: 20 20 20 20 20 20 70 20 3d 20 70 2d 3e 70 52 69        p = p->pRi
6b60: 67 68 74 3b 0a 20 20 20 20 20 20 62 72 65 61 6b  ght;.      break
6b70: 3b 0a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 41  ;..    case TK_A
6b80: 53 3a 0a 20 20 20 20 20 20 70 20 3d 20 70 2d 3e  S:.      p = p->
6b90: 70 4c 65 66 74 3b 0a 20 20 20 20 20 20 62 72 65  pLeft;.      bre
6ba0: 61 6b 3b 0a 0a 20 20 20 20 63 61 73 65 20 54 4b  ak;..    case TK
6bb0: 5f 43 4f 4c 55 4d 4e 3a 0a 20 20 20 20 63 61 73  _COLUMN:.    cas
6bc0: 65 20 54 4b 5f 46 55 4e 43 54 49 4f 4e 3a 0a 20  e TK_FUNCTION:. 
6bd0: 20 20 20 63 61 73 65 20 54 4b 5f 41 47 47 5f 46     case TK_AGG_F
6be0: 55 4e 43 54 49 4f 4e 3a 0a 20 20 20 20 20 20 72  UNCTION:.      r
6bf0: 65 74 75 72 6e 20 70 2d 3e 64 61 74 61 54 79 70  eturn p->dataTyp
6c00: 65 3b 0a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  e;..    case TK_
6c10: 53 45 4c 45 43 54 3a 0a 20 20 20 20 20 20 61 73  SELECT:.      as
6c20: 73 65 72 74 28 20 70 2d 3e 70 53 65 6c 65 63 74  sert( p->pSelect
6c30: 20 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74   );.      assert
6c40: 28 20 70 2d 3e 70 53 65 6c 65 63 74 2d 3e 70 45  ( p->pSelect->pE
6c50: 4c 69 73 74 20 29 3b 0a 20 20 20 20 20 20 61 73  List );.      as
6c60: 73 65 72 74 28 20 70 2d 3e 70 53 65 6c 65 63 74  sert( p->pSelect
6c70: 2d 3e 70 45 4c 69 73 74 2d 3e 6e 45 78 70 72 3e  ->pEList->nExpr>
6c80: 30 20 29 3b 0a 20 20 20 20 20 20 70 20 3d 20 70  0 );.      p = p
6c90: 2d 3e 70 53 65 6c 65 63 74 2d 3e 70 45 4c 69 73  ->pSelect->pELis
6ca0: 74 2d 3e 61 5b 30 5d 2e 70 45 78 70 72 3b 0a 20  t->a[0].pExpr;. 
6cb0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 0a 20 20 20       break;..   
6cc0: 20 63 61 73 65 20 54 4b 5f 43 41 53 45 3a 20 7b   case TK_CASE: {
6cd0: 0a 20 20 20 20 20 20 69 66 28 20 70 2d 3e 70 52  .      if( p->pR
6ce0: 69 67 68 74 20 26 26 20 73 71 6c 69 74 65 45 78  ight && sqliteEx
6cf0: 70 72 54 79 70 65 28 70 2d 3e 70 52 69 67 68 74  prType(p->pRight
6d00: 29 3d 3d 53 51 4c 49 54 45 5f 53 4f 5f 4e 55 4d  )==SQLITE_SO_NUM
6d10: 20 29 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75   ){.        retu
6d20: 72 6e 20 53 51 4c 49 54 45 5f 53 4f 5f 4e 55 4d  rn SQLITE_SO_NUM
6d30: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
6d40: 69 66 28 20 70 2d 3e 70 4c 69 73 74 20 29 7b 0a  if( p->pList ){.
6d50: 20 20 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20          int i;. 
6d60: 20 20 20 20 20 20 20 45 78 70 72 4c 69 73 74 20         ExprList 
6d70: 2a 70 4c 69 73 74 20 3d 20 70 2d 3e 70 4c 69 73  *pList = p->pLis
6d80: 74 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69  t;.        for(i
6d90: 3d 31 3b 20 69 3c 70 4c 69 73 74 2d 3e 6e 45 78  =1; i<pList->nEx
6da0: 70 72 3b 20 69 2b 3d 32 29 7b 0a 20 20 20 20 20  pr; i+=2){.     
6db0: 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 45       if( sqliteE
6dc0: 78 70 72 54 79 70 65 28 70 4c 69 73 74 2d 3e 61  xprType(pList->a
6dd0: 5b 69 5d 2e 70 45 78 70 72 29 3d 3d 53 51 4c 49  [i].pExpr)==SQLI
6de0: 54 45 5f 53 4f 5f 4e 55 4d 20 29 7b 0a 20 20 20  TE_SO_NUM ){.   
6df0: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20           return 
6e00: 53 51 4c 49 54 45 5f 53 4f 5f 4e 55 4d 3b 0a 20  SQLITE_SO_NUM;. 
6e10: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20           }.     
6e20: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
6e30: 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45     return SQLITE
6e40: 5f 53 4f 5f 54 45 58 54 3b 0a 20 20 20 20 7d 0a  _SO_TEXT;.    }.
6e50: 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 0a 20 20  .    default:.  
6e60: 20 20 20 20 61 73 73 65 72 74 28 20 70 2d 3e 6f      assert( p->o
6e70: 70 3d 3d 54 4b 5f 41 42 4f 52 54 20 29 3b 20 20  p==TK_ABORT );  
6e80: 2f 2a 20 43 61 6e 27 74 20 48 61 70 70 65 6e 20  /* Can't Happen 
6e90: 2a 2f 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  */.      break;.
6ea0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 53 51 4c    }.  return SQL
6eb0: 49 54 45 5f 53 4f 5f 4e 55 4d 3b 0a 7d 0a 0a 2f  ITE_SO_NUM;.}../
6ec0: 2a 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20 63 6f  *.** Generate co
6ed0: 64 65 20 69 6e 74 6f 20 74 68 65 20 63 75 72 72  de into the curr
6ee0: 65 6e 74 20 56 64 62 65 20 74 6f 20 65 76 61 6c  ent Vdbe to eval
6ef0: 75 61 74 65 20 74 68 65 20 67 69 76 65 6e 0a 2a  uate the given.*
6f00: 2a 20 65 78 70 72 65 73 73 69 6f 6e 20 61 6e 64  * expression and
6f10: 20 6c 65 61 76 65 20 74 68 65 20 72 65 73 75 6c   leave the resul
6f20: 74 20 6f 6e 20 74 68 65 20 74 6f 70 20 6f 66 20  t on the top of 
6f30: 73 74 61 63 6b 2e 0a 2a 2f 0a 76 6f 69 64 20 73  stack..*/.void s
6f40: 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 50 61  qliteExprCode(Pa
6f50: 72 73 65 20 2a 70 50 61 72 73 65 2c 20 45 78 70  rse *pParse, Exp
6f60: 72 20 2a 70 45 78 70 72 29 7b 0a 20 20 56 64 62  r *pExpr){.  Vdb
6f70: 65 20 2a 76 20 3d 20 70 50 61 72 73 65 2d 3e 70  e *v = pParse->p
6f80: 56 64 62 65 3b 0a 20 20 69 6e 74 20 6f 70 3b 0a  Vdbe;.  int op;.
6f90: 20 20 69 66 28 20 76 3d 3d 30 20 7c 7c 20 70 45    if( v==0 || pE
6fa0: 78 70 72 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b  xpr==0 ) return;
6fb0: 0a 20 20 73 77 69 74 63 68 28 20 70 45 78 70 72  .  switch( pExpr
6fc0: 2d 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65  ->op ){.    case
6fd0: 20 54 4b 5f 50 4c 55 53 3a 20 20 20 20 20 6f 70   TK_PLUS:     op
6fe0: 20 3d 20 4f 50 5f 41 64 64 3b 20 20 20 20 20 20   = OP_Add;      
6ff0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
7000: 54 4b 5f 4d 49 4e 55 53 3a 20 20 20 20 6f 70 20  TK_MINUS:    op 
7010: 3d 20 4f 50 5f 53 75 62 74 72 61 63 74 3b 20 62  = OP_Subtract; b
7020: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
7030: 4b 5f 53 54 41 52 3a 20 20 20 20 20 6f 70 20 3d  K_STAR:     op =
7040: 20 4f 50 5f 4d 75 6c 74 69 70 6c 79 3b 20 62 72   OP_Multiply; br
7050: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
7060: 5f 53 4c 41 53 48 3a 20 20 20 20 6f 70 20 3d 20  _SLASH:    op = 
7070: 4f 50 5f 44 69 76 69 64 65 3b 20 20 20 62 72 65  OP_Divide;   bre
7080: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  ak;.    case TK_
7090: 41 4e 44 3a 20 20 20 20 20 20 6f 70 20 3d 20 4f  AND:      op = O
70a0: 50 5f 41 6e 64 3b 20 20 20 20 20 20 62 72 65 61  P_And;      brea
70b0: 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4f  k;.    case TK_O
70c0: 52 3a 20 20 20 20 20 20 20 6f 70 20 3d 20 4f 50  R:       op = OP
70d0: 5f 4f 72 3b 20 20 20 20 20 20 20 62 72 65 61 6b  _Or;       break
70e0: 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 54  ;.    case TK_LT
70f0: 3a 20 20 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f  :       op = OP_
7100: 4c 74 3b 20 20 20 20 20 20 20 62 72 65 61 6b 3b  Lt;       break;
7110: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 45 3a  .    case TK_LE:
7120: 20 20 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 4c         op = OP_L
7130: 65 3b 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  e;       break;.
7140: 20 20 20 20 63 61 73 65 20 54 4b 5f 47 54 3a 20      case TK_GT: 
7150: 20 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 74        op = OP_Gt
7160: 3b 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;       break;. 
7170: 20 20 20 63 61 73 65 20 54 4b 5f 47 45 3a 20 20     case TK_GE:  
7180: 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 65 3b       op = OP_Ge;
7190: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
71a0: 20 20 63 61 73 65 20 54 4b 5f 4e 45 3a 20 20 20    case TK_NE:   
71b0: 20 20 20 20 6f 70 20 3d 20 4f 50 5f 4e 65 3b 20      op = OP_Ne; 
71c0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
71d0: 20 63 61 73 65 20 54 4b 5f 45 51 3a 20 20 20 20   case TK_EQ:    
71e0: 20 20 20 6f 70 20 3d 20 4f 50 5f 45 71 3b 20 20     op = OP_Eq;  
71f0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
7200: 63 61 73 65 20 54 4b 5f 49 53 4e 55 4c 4c 3a 20  case TK_ISNULL: 
7210: 20 20 6f 70 20 3d 20 4f 50 5f 49 73 4e 75 6c 6c    op = OP_IsNull
7220: 3b 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63  ;   break;.    c
7230: 61 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c 4c 3a 20  ase TK_NOTNULL: 
7240: 20 6f 70 20 3d 20 4f 50 5f 4e 6f 74 4e 75 6c 6c   op = OP_NotNull
7250: 3b 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61  ;  break;.    ca
7260: 73 65 20 54 4b 5f 4e 4f 54 3a 20 20 20 20 20 20  se TK_NOT:      
7270: 6f 70 20 3d 20 4f 50 5f 4e 6f 74 3b 20 20 20 20  op = OP_Not;    
7280: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
7290: 65 20 54 4b 5f 55 4d 49 4e 55 53 3a 20 20 20 6f  e TK_UMINUS:   o
72a0: 70 20 3d 20 4f 50 5f 4e 65 67 61 74 69 76 65 3b  p = OP_Negative;
72b0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
72c0: 20 54 4b 5f 42 49 54 41 4e 44 3a 20 20 20 6f 70   TK_BITAND:   op
72d0: 20 3d 20 4f 50 5f 42 69 74 41 6e 64 3b 20 20 20   = OP_BitAnd;   
72e0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
72f0: 54 4b 5f 42 49 54 4f 52 3a 20 20 20 20 6f 70 20  TK_BITOR:    op 
7300: 3d 20 4f 50 5f 42 69 74 4f 72 3b 20 20 20 20 62  = OP_BitOr;    b
7310: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
7320: 4b 5f 42 49 54 4e 4f 54 3a 20 20 20 6f 70 20 3d  K_BITNOT:   op =
7330: 20 4f 50 5f 42 69 74 4e 6f 74 3b 20 20 20 62 72   OP_BitNot;   br
7340: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
7350: 5f 4c 53 48 49 46 54 3a 20 20 20 6f 70 20 3d 20  _LSHIFT:   op = 
7360: 4f 50 5f 53 68 69 66 74 4c 65 66 74 3b 20 20 62  OP_ShiftLeft;  b
7370: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
7380: 4b 5f 52 53 48 49 46 54 3a 20 20 20 6f 70 20 3d  K_RSHIFT:   op =
7390: 20 4f 50 5f 53 68 69 66 74 52 69 67 68 74 3b 20   OP_ShiftRight; 
73a0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
73b0: 54 4b 5f 52 45 4d 3a 20 20 20 20 20 20 6f 70 20  TK_REM:      op 
73c0: 3d 20 4f 50 5f 52 65 6d 61 69 6e 64 65 72 3b 20  = OP_Remainder; 
73d0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 64 65 66 61   break;.    defa
73e0: 75 6c 74 3a 20 62 72 65 61 6b 3b 0a 20 20 7d 0a  ult: break;.  }.
73f0: 20 20 73 77 69 74 63 68 28 20 70 45 78 70 72 2d    switch( pExpr-
7400: 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65 20  >op ){.    case 
7410: 54 4b 5f 43 4f 4c 55 4d 4e 3a 20 7b 0a 20 20 20  TK_COLUMN: {.   
7420: 20 20 20 69 66 28 20 70 50 61 72 73 65 2d 3e 75     if( pParse->u
7430: 73 65 41 67 67 20 29 7b 0a 20 20 20 20 20 20 20  seAgg ){.       
7440: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
7450: 28 76 2c 20 4f 50 5f 41 67 67 47 65 74 2c 20 30  (v, OP_AggGet, 0
7460: 2c 20 70 45 78 70 72 2d 3e 69 41 67 67 29 3b 0a  , pExpr->iAgg);.
7470: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
7480: 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 3e 3d  pExpr->iColumn>=
7490: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  0 ){.        sql
74a0: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
74b0: 4f 50 5f 43 6f 6c 75 6d 6e 2c 20 70 45 78 70 72  OP_Column, pExpr
74c0: 2d 3e 69 54 61 62 6c 65 2c 20 70 45 78 70 72 2d  ->iTable, pExpr-
74d0: 3e 69 43 6f 6c 75 6d 6e 29 3b 0a 20 20 20 20 20  >iColumn);.     
74e0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
74f0: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
7500: 76 2c 20 4f 50 5f 52 65 63 6e 6f 2c 20 70 45 78  v, OP_Recno, pEx
7510: 70 72 2d 3e 69 54 61 62 6c 65 2c 20 30 29 3b 0a  pr->iTable, 0);.
7520: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 62 72        }.      br
7530: 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63  eak;.    }.    c
7540: 61 73 65 20 54 4b 5f 49 4e 54 45 47 45 52 3a 20  ase TK_INTEGER: 
7550: 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 56 61 6c  {.      int iVal
7560: 20 3d 20 61 74 6f 69 28 70 45 78 70 72 2d 3e 74   = atoi(pExpr->t
7570: 6f 6b 65 6e 2e 7a 29 3b 0a 20 20 20 20 20 20 63  oken.z);.      c
7580: 68 61 72 20 7a 42 75 66 5b 33 30 5d 3b 0a 20 20  har zBuf[30];.  
7590: 20 20 20 20 73 70 72 69 6e 74 66 28 7a 42 75 66      sprintf(zBuf
75a0: 2c 22 25 64 22 2c 69 56 61 6c 29 3b 0a 20 20 20  ,"%d",iVal);.   
75b0: 20 20 20 69 66 28 20 73 74 72 6c 65 6e 28 7a 42     if( strlen(zB
75c0: 75 66 29 21 3d 70 45 78 70 72 2d 3e 74 6f 6b 65  uf)!=pExpr->toke
75d0: 6e 2e 6e 20 0a 20 20 20 20 20 20 20 20 20 20 20  n.n .           
75e0: 20 7c 7c 20 73 74 72 6e 63 6d 70 28 70 45 78 70   || strncmp(pExp
75f0: 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 7a 42 75 66 2c  r->token.z,zBuf,
7600: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 29 21  pExpr->token.n)!
7610: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 2f 2a  =0 ){.        /*
7620: 20 49 66 20 74 68 65 20 69 6e 74 65 67 65 72 20   If the integer 
7630: 76 61 6c 75 65 20 63 61 6e 6e 6f 74 20 62 65 20  value cannot be 
7640: 72 65 70 72 65 73 65 6e 74 65 64 20 65 78 61 63  represented exac
7650: 74 6c 79 20 69 6e 20 33 32 20 62 69 74 73 2c 0a  tly in 32 bits,.
7660: 20 20 20 20 20 20 20 20 2a 2a 20 74 68 65 6e 20          ** then 
7670: 63 6f 64 65 20 69 74 20 61 73 20 61 20 73 74 72  code it as a str
7680: 69 6e 67 20 69 6e 73 74 65 61 64 2e 20 2a 2f 0a  ing instead. */.
7690: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64          sqliteVd
76a0: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 74  beAddOp(v, OP_St
76b0: 72 69 6e 67 2c 20 30 2c 20 30 29 3b 0a 20 20 20  ring, 0, 0);.   
76c0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
76d0: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
76e0: 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  p(v, OP_Integer,
76f0: 20 69 56 61 6c 2c 20 30 29 3b 0a 20 20 20 20 20   iVal, 0);.     
7700: 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56   }.      sqliteV
7710: 64 62 65 43 68 61 6e 67 65 50 33 28 76 2c 20 2d  dbeChangeP3(v, -
7720: 31 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e  1, pExpr->token.
7730: 7a 2c 20 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e  z, pExpr->token.
7740: 6e 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  n);.      break;
7750: 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20  .    }.    case 
7760: 54 4b 5f 46 4c 4f 41 54 3a 20 7b 0a 20 20 20 20  TK_FLOAT: {.    
7770: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
7780: 70 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20  p(v, OP_String, 
7790: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 61 73 73  0, 0);.      ass
77a0: 65 72 74 28 20 70 45 78 70 72 2d 3e 74 6f 6b 65  ert( pExpr->toke
77b0: 6e 2e 7a 20 29 3b 0a 20 20 20 20 20 20 73 71 6c  n.z );.      sql
77c0: 69 74 65 56 64 62 65 43 68 61 6e 67 65 50 33 28  iteVdbeChangeP3(
77d0: 76 2c 20 2d 31 2c 20 70 45 78 70 72 2d 3e 74 6f  v, -1, pExpr->to
77e0: 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f  ken.z, pExpr->to
77f0: 6b 65 6e 2e 6e 29 3b 0a 20 20 20 20 20 20 62 72  ken.n);.      br
7800: 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63  eak;.    }.    c
7810: 61 73 65 20 54 4b 5f 53 54 52 49 4e 47 3a 20 7b  ase TK_STRING: {
7820: 0a 20 20 20 20 20 20 69 6e 74 20 61 64 64 72 20  .      int addr 
7830: 3d 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f  = sqliteVdbeAddO
7840: 70 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20  p(v, OP_String, 
7850: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 61 73 73  0, 0);.      ass
7860: 65 72 74 28 20 70 45 78 70 72 2d 3e 74 6f 6b 65  ert( pExpr->toke
7870: 6e 2e 7a 20 29 3b 0a 20 20 20 20 20 20 73 71 6c  n.z );.      sql
7880: 69 74 65 56 64 62 65 43 68 61 6e 67 65 50 33 28  iteVdbeChangeP3(
7890: 76 2c 20 61 64 64 72 2c 20 70 45 78 70 72 2d 3e  v, addr, pExpr->
78a0: 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e  token.z, pExpr->
78b0: 74 6f 6b 65 6e 2e 6e 29 3b 0a 20 20 20 20 20 20  token.n);.      
78c0: 73 71 6c 69 74 65 56 64 62 65 44 65 71 75 6f 74  sqliteVdbeDequot
78d0: 65 50 33 28 76 2c 20 61 64 64 72 29 3b 0a 20 20  eP3(v, addr);.  
78e0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
78f0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e 55 4c  .    case TK_NUL
7900: 4c 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  L: {.      sqlit
7910: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
7920: 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30 29 3b 0a  _String, 0, 0);.
7930: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
7940: 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c   }.    case TK_L
7950: 54 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c  T:.    case TK_L
7960: 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47  E:.    case TK_G
7970: 54 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47  T:.    case TK_G
7980: 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e  E:.    case TK_N
7990: 45 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 45  E:.    case TK_E
79a0: 51 3a 20 7b 0a 20 20 20 20 20 20 69 66 28 20 70  Q: {.      if( p
79b0: 50 61 72 73 65 2d 3e 64 62 2d 3e 66 69 6c 65 5f  Parse->db->file_
79c0: 66 6f 72 6d 61 74 3e 3d 33 20 26 26 20 73 71 6c  format>=3 && sql
79d0: 69 74 65 45 78 70 72 54 79 70 65 28 70 45 78 70  iteExprType(pExp
79e0: 72 29 3d 3d 53 51 4c 49 54 45 5f 53 4f 5f 54 45  r)==SQLITE_SO_TE
79f0: 58 54 20 29 7b 0a 20 20 20 20 20 20 20 20 6f 70  XT ){.        op
7a00: 20 2b 3d 20 36 3b 20 20 2f 2a 20 43 6f 6e 76 65   += 6;  /* Conve
7a10: 72 74 20 6e 75 6d 65 72 69 63 20 6f 70 63 6f 64  rt numeric opcod
7a20: 65 73 20 74 6f 20 74 65 78 74 20 6f 70 63 6f 64  es to text opcod
7a30: 65 73 20 2a 2f 0a 20 20 20 20 20 20 7d 0a 20 20  es */.      }.  
7a40: 20 20 20 20 2f 2a 20 46 61 6c 6c 20 74 68 72 6f      /* Fall thro
7a50: 75 67 68 20 69 6e 74 6f 20 74 68 65 20 6e 65 78  ugh into the nex
7a60: 74 20 63 61 73 65 20 2a 2f 0a 20 20 20 20 7d 0a  t case */.    }.
7a70: 20 20 20 20 63 61 73 65 20 54 4b 5f 41 4e 44 3a      case TK_AND:
7a80: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4f 52 3a  .    case TK_OR:
7a90: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 50 4c 55  .    case TK_PLU
7aa0: 53 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 53  S:.    case TK_S
7ab0: 54 41 52 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  TAR:.    case TK
7ac0: 5f 4d 49 4e 55 53 3a 0a 20 20 20 20 63 61 73 65  _MINUS:.    case
7ad0: 20 54 4b 5f 52 45 4d 3a 0a 20 20 20 20 63 61 73   TK_REM:.    cas
7ae0: 65 20 54 4b 5f 42 49 54 41 4e 44 3a 0a 20 20 20  e TK_BITAND:.   
7af0: 20 63 61 73 65 20 54 4b 5f 42 49 54 4f 52 3a 0a   case TK_BITOR:.
7b00: 20 20 20 20 63 61 73 65 20 54 4b 5f 53 4c 41 53      case TK_SLAS
7b10: 48 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  H: {.      sqlit
7b20: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
7b30: 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b  , pExpr->pLeft);
7b40: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70  .      sqliteExp
7b50: 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45  rCode(pParse, pE
7b60: 78 70 72 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20  xpr->pRight);.  
7b70: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
7b80: 64 4f 70 28 76 2c 20 6f 70 2c 20 30 2c 20 30 29  dOp(v, op, 0, 0)
7b90: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
7ba0: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b     }.    case TK
7bb0: 5f 4c 53 48 49 46 54 3a 0a 20 20 20 20 63 61 73  _LSHIFT:.    cas
7bc0: 65 20 54 4b 5f 52 53 48 49 46 54 3a 20 7b 0a 20  e TK_RSHIFT: {. 
7bd0: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
7be0: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
7bf0: 72 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20 20 20  r->pRight);.    
7c00: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
7c10: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
7c20: 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71  pLeft);.      sq
7c30: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
7c40: 20 6f 70 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20   op, 0, 0);.    
7c50: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20    break;.    }. 
7c60: 20 20 20 63 61 73 65 20 54 4b 5f 43 4f 4e 43 41     case TK_CONCA
7c70: 54 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  T: {.      sqlit
7c80: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
7c90: 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b  , pExpr->pLeft);
7ca0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70  .      sqliteExp
7cb0: 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45  rCode(pParse, pE
7cc0: 78 70 72 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20  xpr->pRight);.  
7cd0: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
7ce0: 64 4f 70 28 76 2c 20 4f 50 5f 43 6f 6e 63 61 74  dOp(v, OP_Concat
7cf0: 2c 20 32 2c 20 30 29 3b 0a 20 20 20 20 20 20 62  , 2, 0);.      b
7d00: 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  reak;.    }.    
7d10: 63 61 73 65 20 54 4b 5f 55 4d 49 4e 55 53 3a 20  case TK_UMINUS: 
7d20: 7b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20  {.      assert( 
7d30: 70 45 78 70 72 2d 3e 70 4c 65 66 74 20 29 3b 0a  pExpr->pLeft );.
7d40: 20 20 20 20 20 20 69 66 28 20 70 45 78 70 72 2d        if( pExpr-
7d50: 3e 70 4c 65 66 74 2d 3e 6f 70 3d 3d 54 4b 5f 46  >pLeft->op==TK_F
7d60: 4c 4f 41 54 20 7c 7c 20 70 45 78 70 72 2d 3e 70  LOAT || pExpr->p
7d70: 4c 65 66 74 2d 3e 6f 70 3d 3d 54 4b 5f 49 4e 54  Left->op==TK_INT
7d80: 45 47 45 52 20 29 7b 0a 20 20 20 20 20 20 20 20  EGER ){.        
7d90: 54 6f 6b 65 6e 20 2a 70 20 3d 20 26 70 45 78 70  Token *p = &pExp
7da0: 72 2d 3e 70 4c 65 66 74 2d 3e 74 6f 6b 65 6e 3b  r->pLeft->token;
7db0: 0a 20 20 20 20 20 20 20 20 63 68 61 72 20 2a 7a  .        char *z
7dc0: 20 3d 20 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28   = sqliteMalloc(
7dd0: 20 70 2d 3e 6e 20 2b 20 32 20 29 3b 0a 20 20 20   p->n + 2 );.   
7de0: 20 20 20 20 20 73 70 72 69 6e 74 66 28 7a 2c 20       sprintf(z, 
7df0: 22 2d 25 2e 2a 73 22 2c 20 70 2d 3e 6e 2c 20 70  "-%.*s", p->n, p
7e00: 2d 3e 7a 29 3b 0a 20 20 20 20 20 20 20 20 69 66  ->z);.        if
7e10: 28 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 2d 3e  ( pExpr->pLeft->
7e20: 6f 70 3d 3d 54 4b 5f 49 4e 54 45 47 45 52 20 29  op==TK_INTEGER )
7e30: 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  {.          sqli
7e40: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
7e50: 50 5f 49 6e 74 65 67 65 72 2c 20 61 74 6f 69 28  P_Integer, atoi(
7e60: 7a 29 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20  z), 0);.        
7e70: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20  }else{.         
7e80: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
7e90: 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30  (v, OP_String, 0
7ea0: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  , 0);.        }.
7eb0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64          sqliteVd
7ec0: 62 65 43 68 61 6e 67 65 50 33 28 76 2c 20 2d 31  beChangeP3(v, -1
7ed0: 2c 20 7a 2c 20 70 2d 3e 6e 2b 31 29 3b 0a 20 20  , z, p->n+1);.  
7ee0: 20 20 20 20 20 20 73 71 6c 69 74 65 46 72 65 65        sqliteFree
7ef0: 28 7a 29 3b 0a 20 20 20 20 20 20 20 20 62 72 65  (z);.        bre
7f00: 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  ak;.      }.    
7f10: 20 20 2f 2a 20 46 61 6c 6c 20 74 68 72 6f 75 67    /* Fall throug
7f20: 68 20 69 6e 74 6f 20 54 4b 5f 4e 4f 54 20 2a 2f  h into TK_NOT */
7f30: 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20  .    }.    case 
7f40: 54 4b 5f 42 49 54 4e 4f 54 3a 0a 20 20 20 20 63  TK_BITNOT:.    c
7f50: 61 73 65 20 54 4b 5f 4e 4f 54 3a 20 7b 0a 20 20  ase TK_NOT: {.  
7f60: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f      sqliteExprCo
7f70: 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72  de(pParse, pExpr
7f80: 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20  ->pLeft);.      
7f90: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
7fa0: 76 2c 20 6f 70 2c 20 30 2c 20 30 29 3b 0a 20 20  v, op, 0, 0);.  
7fb0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
7fc0: 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 49 53 4e  .    case TK_ISN
7fd0: 55 4c 4c 3a 0a 20 20 20 20 63 61 73 65 20 54 4b  ULL:.    case TK
7fe0: 5f 4e 4f 54 4e 55 4c 4c 3a 20 7b 0a 20 20 20 20  _NOTNULL: {.    
7ff0: 20 20 69 6e 74 20 64 65 73 74 3b 0a 20 20 20 20    int dest;.    
8000: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
8010: 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  p(v, OP_Integer,
8020: 20 31 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71   1, 0);.      sq
8030: 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61  liteExprCode(pPa
8040: 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66  rse, pExpr->pLef
8050: 74 29 3b 0a 20 20 20 20 20 20 64 65 73 74 20 3d  t);.      dest =
8060: 20 73 71 6c 69 74 65 56 64 62 65 43 75 72 72 65   sqliteVdbeCurre
8070: 6e 74 41 64 64 72 28 76 29 20 2b 20 32 3b 0a 20  ntAddr(v) + 2;. 
8080: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
8090: 64 64 4f 70 28 76 2c 20 6f 70 2c 20 31 2c 20 64  ddOp(v, op, 1, d
80a0: 65 73 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  est);.      sqli
80b0: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
80c0: 50 5f 41 64 64 49 6d 6d 2c 20 2d 31 2c 20 30 29  P_AddImm, -1, 0)
80d0: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
80e0: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b     }.    case TK
80f0: 5f 41 47 47 5f 46 55 4e 43 54 49 4f 4e 3a 20 7b  _AGG_FUNCTION: {
8100: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
8110: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 41 67 67  eAddOp(v, OP_Agg
8120: 47 65 74 2c 20 30 2c 20 70 45 78 70 72 2d 3e 69  Get, 0, pExpr->i
8130: 41 67 67 29 3b 0a 20 20 20 20 20 20 62 72 65 61  Agg);.      brea
8140: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
8150: 65 20 54 4b 5f 46 55 4e 43 54 49 4f 4e 3a 20 7b  e TK_FUNCTION: {
8160: 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20 20  .      int i;.  
8170: 20 20 20 20 45 78 70 72 4c 69 73 74 20 2a 70 4c      ExprList *pL
8180: 69 73 74 20 3d 20 70 45 78 70 72 2d 3e 70 4c 69  ist = pExpr->pLi
8190: 73 74 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e 45  st;.      int nE
81a0: 78 70 72 20 3d 20 70 4c 69 73 74 20 3f 20 70 4c  xpr = pList ? pL
81b0: 69 73 74 2d 3e 6e 45 78 70 72 20 3a 20 30 3b 0a  ist->nExpr : 0;.
81c0: 20 20 20 20 20 20 46 75 6e 63 44 65 66 20 2a 70        FuncDef *p
81d0: 44 65 66 3b 0a 20 20 20 20 20 20 70 44 65 66 20  Def;.      pDef 
81e0: 3d 20 73 71 6c 69 74 65 46 69 6e 64 46 75 6e 63  = sqliteFindFunc
81f0: 74 69 6f 6e 28 70 50 61 72 73 65 2d 3e 64 62 2c  tion(pParse->db,
8200: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
8210: 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e 74 6f         pExpr->to
8220: 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e 74 6f  ken.z, pExpr->to
8230: 6b 65 6e 2e 6e 2c 20 6e 45 78 70 72 2c 20 30 29  ken.n, nExpr, 0)
8240: 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20  ;.      assert( 
8250: 70 44 65 66 21 3d 30 20 29 3b 0a 20 20 20 20 20  pDef!=0 );.     
8260: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 45 78 70   for(i=0; i<nExp
8270: 72 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20  r; i++){.       
8280: 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28   sqliteExprCode(
8290: 70 50 61 72 73 65 2c 20 70 4c 69 73 74 2d 3e 61  pParse, pList->a
82a0: 5b 69 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20  [i].pExpr);.    
82b0: 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65    }.      sqlite
82c0: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
82d0: 46 75 6e 63 74 69 6f 6e 2c 20 6e 45 78 70 72 2c  Function, nExpr,
82e0: 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   0);.      sqlit
82f0: 65 56 64 62 65 43 68 61 6e 67 65 50 33 28 76 2c  eVdbeChangeP3(v,
8300: 20 2d 31 2c 20 28 63 68 61 72 2a 29 70 44 65 66   -1, (char*)pDef
8310: 2c 20 50 33 5f 50 4f 49 4e 54 45 52 29 3b 0a 20  , P3_POINTER);. 
8320: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
8330: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 53 45  }.    case TK_SE
8340: 4c 45 43 54 3a 20 7b 0a 20 20 20 20 20 20 73 71  LECT: {.      sq
8350: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
8360: 20 4f 50 5f 4d 65 6d 4c 6f 61 64 2c 20 70 45 78   OP_MemLoad, pEx
8370: 70 72 2d 3e 69 43 6f 6c 75 6d 6e 2c 20 30 29 3b  pr->iColumn, 0);
8380: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
8390: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f    }.    case TK_
83a0: 49 4e 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20  IN: {.      int 
83b0: 61 64 64 72 3b 0a 20 20 20 20 20 20 73 71 6c 69  addr;.      sqli
83c0: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
83d0: 50 5f 49 6e 74 65 67 65 72 2c 20 31 2c 20 30 29  P_Integer, 1, 0)
83e0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78  ;.      sqliteEx
83f0: 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70  prCode(pParse, p
8400: 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20  Expr->pLeft);.  
8410: 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74      addr = sqlit
8420: 65 56 64 62 65 43 75 72 72 65 6e 74 41 64 64 72  eVdbeCurrentAddr
8430: 28 76 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  (v);.      sqlit
8440: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
8450: 5f 4e 6f 74 4e 75 6c 6c 2c 20 2d 31 2c 20 61 64  _NotNull, -1, ad
8460: 64 72 2b 34 29 3b 0a 20 20 20 20 20 20 73 71 6c  dr+4);.      sql
8470: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
8480: 4f 50 5f 50 6f 70 2c 20 31 2c 20 30 29 3b 0a 20  OP_Pop, 1, 0);. 
8490: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
84a0: 64 64 4f 70 28 76 2c 20 4f 50 5f 53 74 72 69 6e  ddOp(v, OP_Strin
84b0: 67 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  g, 0, 0);.      
84c0: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
84d0: 76 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20 61  v, OP_Goto, 0, a
84e0: 64 64 72 2b 36 29 3b 0a 20 20 20 20 20 20 69 66  ddr+6);.      if
84f0: 28 20 70 45 78 70 72 2d 3e 70 53 65 6c 65 63 74  ( pExpr->pSelect
8500: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
8510: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
8520: 50 5f 46 6f 75 6e 64 2c 20 70 45 78 70 72 2d 3e  P_Found, pExpr->
8530: 69 54 61 62 6c 65 2c 20 61 64 64 72 2b 36 29 3b  iTable, addr+6);
8540: 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20  .      }else{.  
8550: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
8560: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 65 74 46  AddOp(v, OP_SetF
8570: 6f 75 6e 64 2c 20 70 45 78 70 72 2d 3e 69 54 61  ound, pExpr->iTa
8580: 62 6c 65 2c 20 61 64 64 72 2b 36 29 3b 0a 20 20  ble, addr+6);.  
8590: 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69      }.      sqli
85a0: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
85b0: 50 5f 41 64 64 49 6d 6d 2c 20 2d 31 2c 20 30 29  P_AddImm, -1, 0)
85c0: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
85d0: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b     }.    case TK
85e0: 5f 42 45 54 57 45 45 4e 3a 20 7b 0a 20 20 20 20  _BETWEEN: {.    
85f0: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
8600: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
8610: 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71  pLeft);.      sq
8620: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
8630: 20 4f 50 5f 44 75 70 2c 20 30 2c 20 30 29 3b 0a   OP_Dup, 0, 0);.
8640: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
8650: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78  Code(pParse, pEx
8660: 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 30 5d 2e  pr->pList->a[0].
8670: 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20 73 71  pExpr);.      sq
8680: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
8690: 20 4f 50 5f 47 65 2c 20 30 2c 20 30 29 3b 0a 20   OP_Ge, 0, 0);. 
86a0: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
86b0: 64 64 4f 70 28 76 2c 20 4f 50 5f 50 75 6c 6c 2c  ddOp(v, OP_Pull,
86c0: 20 31 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71   1, 0);.      sq
86d0: 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61  liteExprCode(pPa
86e0: 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69 73  rse, pExpr->pLis
86f0: 74 2d 3e 61 5b 31 5d 2e 70 45 78 70 72 29 3b 0a  t->a[1].pExpr);.
8700: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
8710: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4c 65 2c 20  AddOp(v, OP_Le, 
8720: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
8730: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
8740: 4f 50 5f 41 6e 64 2c 20 30 2c 20 30 29 3b 0a 20  OP_And, 0, 0);. 
8750: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
8760: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 41 53  }.    case TK_AS
8770: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
8780: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
8790: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a   pExpr->pLeft);.
87a0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
87b0: 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 43   }.    case TK_C
87c0: 41 53 45 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74  ASE: {.      int
87d0: 20 65 78 70 72 5f 65 6e 64 5f 6c 61 62 65 6c 3b   expr_end_label;
87e0: 0a 20 20 20 20 20 20 69 6e 74 20 6a 75 6d 70 49  .      int jumpI
87f0: 6e 73 74 3b 0a 20 20 20 20 20 20 69 6e 74 20 61  nst;.      int a
8800: 64 64 72 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e  ddr;.      int n
8810: 45 78 70 72 3b 0a 20 20 20 20 20 20 69 6e 74 20  Expr;.      int 
8820: 69 3b 0a 0a 20 20 20 20 20 20 61 73 73 65 72 74  i;..      assert
8830: 28 70 45 78 70 72 2d 3e 70 4c 69 73 74 29 3b 0a  (pExpr->pList);.
8840: 20 20 20 20 20 20 61 73 73 65 72 74 28 28 70 45        assert((pE
8850: 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70  xpr->pList->nExp
8860: 72 20 25 20 32 29 20 3d 3d 20 30 29 3b 0a 20 20  r % 2) == 0);.  
8870: 20 20 20 20 61 73 73 65 72 74 28 70 45 78 70 72      assert(pExpr
8880: 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 20 3e  ->pList->nExpr >
8890: 20 30 29 3b 0a 20 20 20 20 20 20 6e 45 78 70 72   0);.      nExpr
88a0: 20 3d 20 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d   = pExpr->pList-
88b0: 3e 6e 45 78 70 72 3b 0a 20 20 20 20 20 20 65 78  >nExpr;.      ex
88c0: 70 72 5f 65 6e 64 5f 6c 61 62 65 6c 20 3d 20 73  pr_end_label = s
88d0: 71 6c 69 74 65 56 64 62 65 4d 61 6b 65 4c 61 62  qliteVdbeMakeLab
88e0: 65 6c 28 76 29 3b 0a 20 20 20 20 20 20 69 66 28  el(v);.      if(
88f0: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 20 29 7b   pExpr->pLeft ){
8900: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 45  .        sqliteE
8910: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
8920: 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20  pExpr->pLeft);. 
8930: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 66 6f 72       }.      for
8940: 28 69 3d 30 3b 20 69 3c 6e 45 78 70 72 3b 20 69  (i=0; i<nExpr; i
8950: 3d 69 2b 32 29 7b 0a 20 20 20 20 20 20 20 20 73  =i+2){.        s
8960: 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50  qliteExprCode(pP
8970: 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69  arse, pExpr->pLi
8980: 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 29 3b  st->a[i].pExpr);
8990: 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 45 78  .        if( pEx
89a0: 70 72 2d 3e 70 4c 65 66 74 20 29 7b 0a 20 20 20  pr->pLeft ){.   
89b0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
89c0: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 44 75 70  eAddOp(v, OP_Dup
89d0: 2c 20 31 2c 20 31 29 3b 0a 20 20 20 20 20 20 20  , 1, 1);.       
89e0: 20 20 20 6a 75 6d 70 49 6e 73 74 20 3d 20 73 71     jumpInst = sq
89f0: 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c  liteVdbeAddOp(v,
8a00: 20 4f 50 5f 4e 65 2c 20 31 2c 20 30 29 3b 0a 20   OP_Ne, 1, 0);. 
8a10: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 56           sqliteV
8a20: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 50  dbeAddOp(v, OP_P
8a30: 6f 70 2c 20 31 2c 20 30 29 3b 0a 20 20 20 20 20  op, 1, 0);.     
8a40: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
8a50: 20 20 20 20 6a 75 6d 70 49 6e 73 74 20 3d 20 73      jumpInst = s
8a60: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
8a70: 2c 20 4f 50 5f 49 66 4e 6f 74 2c 20 31 2c 20 30  , OP_IfNot, 1, 0
8a80: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
8a90: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
8aa0: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
8ab0: 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 2b 31 5d  r->pList->a[i+1]
8ac0: 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20 20  .pExpr);.       
8ad0: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
8ae0: 28 76 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20  (v, OP_Goto, 0, 
8af0: 65 78 70 72 5f 65 6e 64 5f 6c 61 62 65 6c 29 3b  expr_end_label);
8b00: 0a 20 20 20 20 20 20 20 20 61 64 64 72 20 3d 20  .        addr = 
8b10: 73 71 6c 69 74 65 56 64 62 65 43 75 72 72 65 6e  sqliteVdbeCurren
8b20: 74 41 64 64 72 28 76 29 3b 0a 20 20 20 20 20 20  tAddr(v);.      
8b30: 20 20 73 71 6c 69 74 65 56 64 62 65 43 68 61 6e    sqliteVdbeChan
8b40: 67 65 50 32 28 76 2c 20 6a 75 6d 70 49 6e 73 74  geP2(v, jumpInst
8b50: 2c 20 61 64 64 72 29 3b 0a 20 20 20 20 20 20 7d  , addr);.      }
8b60: 0a 20 20 20 20 20 20 69 66 28 20 70 45 78 70 72  .      if( pExpr
8b70: 2d 3e 70 4c 65 66 74 20 29 7b 0a 20 20 20 20 20  ->pLeft ){.     
8b80: 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64     sqliteVdbeAdd
8b90: 4f 70 28 76 2c 20 4f 50 5f 50 6f 70 2c 20 31 2c  Op(v, OP_Pop, 1,
8ba0: 20 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20   0);.      }.   
8bb0: 20 20 20 69 66 28 20 70 45 78 70 72 2d 3e 70 52     if( pExpr->pR
8bc0: 69 67 68 74 20 29 7b 0a 20 20 20 20 20 20 20 20  ight ){.        
8bd0: 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70  sqliteExprCode(p
8be0: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 52  Parse, pExpr->pR
8bf0: 69 67 68 74 29 3b 0a 20 20 20 20 20 20 7d 65 6c  ight);.      }el
8c00: 73 65 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  se{.        sqli
8c10: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
8c20: 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30 29 3b  P_String, 0, 0);
8c30: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73  .      }.      s
8c40: 71 6c 69 74 65 56 64 62 65 52 65 73 6f 6c 76 65  qliteVdbeResolve
8c50: 4c 61 62 65 6c 28 76 2c 20 65 78 70 72 5f 65 6e  Label(v, expr_en
8c60: 64 5f 6c 61 62 65 6c 29 3b 0a 20 20 20 20 20 20  d_label);.      
8c70: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20  break;.    }.   
8c80: 20 63 61 73 65 20 54 4b 5f 52 41 49 53 45 3a 20   case TK_RAISE: 
8c90: 7b 0a 20 20 20 20 20 20 69 66 28 20 21 70 50 61  {.      if( !pPa
8ca0: 72 73 65 2d 3e 74 72 69 67 53 74 61 63 6b 20 29  rse->trigStack )
8cb0: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
8cc0: 53 65 74 4e 53 74 72 69 6e 67 28 26 70 50 61 72  SetNString(&pPar
8cd0: 73 65 2d 3e 7a 45 72 72 4d 73 67 2c 20 0a 09 09  se->zErrMsg, ...
8ce0: 22 52 41 49 53 45 28 29 20 6d 61 79 20 6f 6e 6c  "RAISE() may onl
8cf0: 79 20 62 65 20 75 73 65 64 20 77 69 74 68 69 6e  y be used within
8d00: 20 61 20 74 72 69 67 67 65 72 2d 70 72 6f 67 72   a trigger-progr
8d10: 61 6d 22 2c 20 2d 31 2c 20 30 29 3b 0a 20 20 20  am", -1, 0);.   
8d20: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 45 72       pParse->nEr
8d30: 72 2b 2b 3b 0a 09 72 65 74 75 72 6e 3b 0a 20 20  r++;..return;.  
8d40: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
8d50: 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d  pExpr->iColumn =
8d60: 3d 20 4f 45 5f 52 6f 6c 6c 62 61 63 6b 20 7c 7c  = OE_Rollback ||
8d70: 0a 09 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75  ..  pExpr->iColu
8d80: 6d 6e 20 3d 3d 20 4f 45 5f 41 62 6f 72 74 20 7c  mn == OE_Abort |
8d90: 7c 0a 09 20 20 70 45 78 70 72 2d 3e 69 43 6f 6c  |..  pExpr->iCol
8da0: 75 6d 6e 20 3d 3d 20 4f 45 5f 46 61 69 6c 20 29  umn == OE_Fail )
8db0: 7b 0a 09 20 20 63 68 61 72 20 2a 20 6d 73 67 20  {..  char * msg 
8dc0: 3d 20 73 71 6c 69 74 65 53 74 72 4e 44 75 70 28  = sqliteStrNDup(
8dd0: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 7a 2c 20  pExpr->token.z, 
8de0: 70 45 78 70 72 2d 3e 74 6f 6b 65 6e 2e 6e 29 3b  pExpr->token.n);
8df0: 0a 09 20 20 73 71 6c 69 74 65 56 64 62 65 41 64  ..  sqliteVdbeAd
8e00: 64 4f 70 28 76 2c 20 4f 50 5f 48 61 6c 74 2c 20  dOp(v, OP_Halt, 
8e10: 53 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e  SQLITE_CONSTRAIN
8e20: 54 2c 20 70 45 78 70 72 2d 3e 69 43 6f 6c 75 6d  T, pExpr->iColum
8e30: 6e 29 3b 0a 09 20 20 73 71 6c 69 74 65 44 65 71  n);..  sqliteDeq
8e40: 75 6f 74 65 28 6d 73 67 29 3b 0a 09 20 20 73 71  uote(msg);..  sq
8e50: 6c 69 74 65 56 64 62 65 43 68 61 6e 67 65 50 33  liteVdbeChangeP3
8e60: 28 76 2c 20 2d 31 2c 20 6d 73 67 2c 20 30 29 3b  (v, -1, msg, 0);
8e70: 0a 09 20 20 73 71 6c 69 74 65 46 72 65 65 28 6d  ..  sqliteFree(m
8e80: 73 67 29 3b 0a 20 20 20 20 20 20 7d 20 65 6c 73  sg);.      } els
8e90: 65 20 7b 0a 09 20 20 61 73 73 65 72 74 28 20 70  e {..  assert( p
8ea0: 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 3d  Expr->iColumn ==
8eb0: 20 4f 45 5f 49 67 6e 6f 72 65 20 29 3b 0a 09 20   OE_Ignore );.. 
8ec0: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
8ed0: 28 76 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20  (v, OP_Goto, 0, 
8ee0: 70 50 61 72 73 65 2d 3e 74 72 69 67 53 74 61 63  pParse->trigStac
8ef0: 6b 2d 3e 69 67 6e 6f 72 65 4a 75 6d 70 29 3b 0a  k->ignoreJump);.
8f00: 09 20 20 73 71 6c 69 74 65 56 64 62 65 43 68 61  .  sqliteVdbeCha
8f10: 6e 67 65 50 33 28 76 2c 20 2d 31 2c 20 22 28 49  ngeP3(v, -1, "(I
8f20: 47 4e 4f 52 45 20 6a 75 6d 70 29 22 2c 20 2d 31  GNORE jump)", -1
8f30: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
8f40: 0a 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 7d 0a  .    break;.  }.
8f50: 7d 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61 74  }../*.** Generat
8f60: 65 20 63 6f 64 65 20 66 6f 72 20 61 20 62 6f 6f  e code for a boo
8f70: 6c 65 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20  lean expression 
8f80: 73 75 63 68 20 74 68 61 74 20 61 20 6a 75 6d 70  such that a jump
8f90: 20 69 73 20 6d 61 64 65 0a 2a 2a 20 74 6f 20 74   is made.** to t
8fa0: 68 65 20 6c 61 62 65 6c 20 22 64 65 73 74 22 20  he label "dest" 
8fb0: 69 66 20 74 68 65 20 65 78 70 72 65 73 73 69 6f  if the expressio
8fc0: 6e 20 69 73 20 74 72 75 65 20 62 75 74 20 65 78  n is true but ex
8fd0: 65 63 75 74 69 6f 6e 0a 2a 2a 20 63 6f 6e 74 69  ecution.** conti
8fe0: 6e 75 65 73 20 73 74 72 61 69 67 68 74 20 74 68  nues straight th
8ff0: 72 75 20 69 66 20 74 68 65 20 65 78 70 72 65 73  ru if the expres
9000: 73 69 6f 6e 20 69 73 20 66 61 6c 73 65 2e 0a 2a  sion is false..*
9010: 2a 0a 2a 2a 20 49 66 20 74 68 65 20 65 78 70 72  *.** If the expr
9020: 65 73 73 69 6f 6e 20 65 76 61 6c 75 61 74 65 73  ession evaluates
9030: 20 74 6f 20 4e 55 4c 4c 20 28 6e 65 69 74 68 65   to NULL (neithe
9040: 72 20 74 72 75 65 20 6e 6f 72 20 66 61 6c 73 65  r true nor false
9050: 29 2c 20 74 68 65 6e 0a 2a 2a 20 74 61 6b 65 20  ), then.** take 
9060: 74 68 65 20 6a 75 6d 70 20 69 66 20 74 68 65 20  the jump if the 
9070: 6a 75 6d 70 49 66 4e 75 6c 6c 20 66 6c 61 67 20  jumpIfNull flag 
9080: 69 73 20 74 72 75 65 2e 0a 2a 2f 0a 76 6f 69 64  is true..*/.void
9090: 20 73 71 6c 69 74 65 45 78 70 72 49 66 54 72 75   sqliteExprIfTru
90a0: 65 28 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c  e(Parse *pParse,
90b0: 20 45 78 70 72 20 2a 70 45 78 70 72 2c 20 69 6e   Expr *pExpr, in
90c0: 74 20 64 65 73 74 2c 20 69 6e 74 20 6a 75 6d 70  t dest, int jump
90d0: 49 66 4e 75 6c 6c 29 7b 0a 20 20 56 64 62 65 20  IfNull){.  Vdbe 
90e0: 2a 76 20 3d 20 70 50 61 72 73 65 2d 3e 70 56 64  *v = pParse->pVd
90f0: 62 65 3b 0a 20 20 69 6e 74 20 6f 70 20 3d 20 30  be;.  int op = 0
9100: 3b 0a 20 20 69 66 28 20 76 3d 3d 30 20 7c 7c 20  ;.  if( v==0 || 
9110: 70 45 78 70 72 3d 3d 30 20 29 20 72 65 74 75 72  pExpr==0 ) retur
9120: 6e 3b 0a 20 20 73 77 69 74 63 68 28 20 70 45 78  n;.  switch( pEx
9130: 70 72 2d 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61  pr->op ){.    ca
9140: 73 65 20 54 4b 5f 4c 54 3a 20 20 20 20 20 20 20  se TK_LT:       
9150: 6f 70 20 3d 20 4f 50 5f 4c 74 3b 20 20 20 20 20  op = OP_Lt;     
9160: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
9170: 65 20 54 4b 5f 4c 45 3a 20 20 20 20 20 20 20 6f  e TK_LE:       o
9180: 70 20 3d 20 4f 50 5f 4c 65 3b 20 20 20 20 20 20  p = OP_Le;      
9190: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
91a0: 20 54 4b 5f 47 54 3a 20 20 20 20 20 20 20 6f 70   TK_GT:       op
91b0: 20 3d 20 4f 50 5f 47 74 3b 20 20 20 20 20 20 20   = OP_Gt;       
91c0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
91d0: 54 4b 5f 47 45 3a 20 20 20 20 20 20 20 6f 70 20  TK_GE:       op 
91e0: 3d 20 4f 50 5f 47 65 3b 20 20 20 20 20 20 20 62  = OP_Ge;       b
91f0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54  reak;.    case T
9200: 4b 5f 4e 45 3a 20 20 20 20 20 20 20 6f 70 20 3d  K_NE:       op =
9210: 20 4f 50 5f 4e 65 3b 20 20 20 20 20 20 20 62 72   OP_Ne;       br
9220: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b  eak;.    case TK
9230: 5f 45 51 3a 20 20 20 20 20 20 20 6f 70 20 3d 20  _EQ:       op = 
9240: 4f 50 5f 45 71 3b 20 20 20 20 20 20 20 62 72 65  OP_Eq;       bre
9250: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f  ak;.    case TK_
9260: 49 53 4e 55 4c 4c 3a 20 20 20 6f 70 20 3d 20 4f  ISNULL:   op = O
9270: 50 5f 49 73 4e 75 6c 6c 3b 20 20 20 62 72 65 61  P_IsNull;   brea
9280: 6b 3b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e  k;.    case TK_N
9290: 4f 54 4e 55 4c 4c 3a 20 20 6f 70 20 3d 20 4f 50  OTNULL:  op = OP
92a0: 5f 4e 6f 74 4e 75 6c 6c 3b 20 20 62 72 65 61 6b  _NotNull;  break
92b0: 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20 20  ;.    default:  
92c0: 62 72 65 61 6b 3b 0a 20 20 7d 0a 20 20 73 77 69  break;.  }.  swi
92d0: 74 63 68 28 20 70 45 78 70 72 2d 3e 6f 70 20 29  tch( pExpr->op )
92e0: 7b 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 41 4e  {.    case TK_AN
92f0: 44 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 64  D: {.      int d
9300: 32 20 3d 20 73 71 6c 69 74 65 56 64 62 65 4d 61  2 = sqliteVdbeMa
9310: 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 20 20 20 20  keLabel(v);.    
9320: 20 20 73 71 6c 69 74 65 45 78 70 72 49 66 46 61    sqliteExprIfFa
9330: 6c 73 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  lse(pParse, pExp
9340: 72 2d 3e 70 4c 65 66 74 2c 20 64 32 2c 20 21 6a  r->pLeft, d2, !j
9350: 75 6d 70 49 66 4e 75 6c 6c 29 3b 0a 20 20 20 20  umpIfNull);.    
9360: 20 20 73 71 6c 69 74 65 45 78 70 72 49 66 54 72    sqliteExprIfTr
9370: 75 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72  ue(pParse, pExpr
9380: 2d 3e 70 52 69 67 68 74 2c 20 64 65 73 74 2c 20  ->pRight, dest, 
9390: 6a 75 6d 70 49 66 4e 75 6c 6c 29 3b 0a 20 20 20  jumpIfNull);.   
93a0: 20 20 20 73 71 6c 69 74 65 56 64 62 65 52 65 73     sqliteVdbeRes
93b0: 6f 6c 76 65 4c 61 62 65 6c 28 76 2c 20 64 32 29  olveLabel(v, d2)
93c0: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
93d0: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b     }.    case TK
93e0: 5f 4f 52 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c  _OR: {.      sql
93f0: 69 74 65 45 78 70 72 49 66 54 72 75 65 28 70 50  iteExprIfTrue(pP
9400: 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65  arse, pExpr->pLe
9410: 66 74 2c 20 64 65 73 74 2c 20 6a 75 6d 70 49 66  ft, dest, jumpIf
9420: 4e 75 6c 6c 29 3b 0a 20 20 20 20 20 20 73 71 6c  Null);.      sql
9430: 69 74 65 45 78 70 72 49 66 54 72 75 65 28 70 50  iteExprIfTrue(pP
9440: 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 52 69  arse, pExpr->pRi
9450: 67 68 74 2c 20 64 65 73 74 2c 20 6a 75 6d 70 49  ght, dest, jumpI
9460: 66 4e 75 6c 6c 29 3b 0a 20 20 20 20 20 20 62 72  fNull);.      br
9470: 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63  eak;.    }.    c
9480: 61 73 65 20 54 4b 5f 4e 4f 54 3a 20 7b 0a 20 20  ase TK_NOT: {.  
9490: 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 49 66      sqliteExprIf
94a0: 46 61 6c 73 65 28 70 50 61 72 73 65 2c 20 70 45  False(pParse, pE
94b0: 78 70 72 2d 3e 70 4c 65 66 74 2c 20 64 65 73 74  xpr->pLeft, dest
94c0: 2c 20 6a 75 6d 70 49 66 4e 75 6c 6c 29 3b 0a 20  , jumpIfNull);. 
94d0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
94e0: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 54  }.    case TK_LT
94f0: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4c 45  :.    case TK_LE
9500: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47 54  :.    case TK_GT
9510: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 47 45  :.    case TK_GE
9520: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e 45  :.    case TK_NE
9530: 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 45 51  :.    case TK_EQ
9540: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
9550: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
9560: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a   pExpr->pLeft);.
9570: 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72        sqliteExpr
9580: 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78  Code(pParse, pEx
9590: 70 72 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20 20  pr->pRight);.   
95a0: 20 20 20 69 66 28 20 70 50 61 72 73 65 2d 3e 64     if( pParse->d
95b0: 62 2d 3e 66 69 6c 65 5f 66 6f 72 6d 61 74 3e 3d  b->file_format>=
95c0: 33 20 26 26 20 73 71 6c 69 74 65 45 78 70 72 54  3 && sqliteExprT
95d0: 79 70 65 28 70 45 78 70 72 29 3d 3d 53 51 4c 49  ype(pExpr)==SQLI
95e0: 54 45 5f 53 4f 5f 54 45 58 54 20 29 7b 0a 20 20  TE_SO_TEXT ){.  
95f0: 20 20 20 20 20 20 6f 70 20 2b 3d 20 36 3b 20 20        op += 6;  
9600: 2f 2a 20 43 6f 6e 76 65 72 74 20 6e 75 6d 65 72  /* Convert numer
9610: 69 63 20 6f 70 63 6f 64 65 73 20 74 6f 20 74 65  ic opcodes to te
9620: 78 74 20 6f 70 63 6f 64 65 73 20 2a 2f 0a 20 20  xt opcodes */.  
9630: 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69      }.      sqli
9640: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 6f  teVdbeAddOp(v, o
9650: 70 2c 20 6a 75 6d 70 49 66 4e 75 6c 6c 2c 20 64  p, jumpIfNull, d
9660: 65 73 74 29 3b 0a 20 20 20 20 20 20 62 72 65 61  est);.      brea
9670: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
9680: 65 20 54 4b 5f 49 53 4e 55 4c 4c 3a 0a 20 20 20  e TK_ISNULL:.   
9690: 20 63 61 73 65 20 54 4b 5f 4e 4f 54 4e 55 4c 4c   case TK_NOTNULL
96a0: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
96b0: 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c  ExprCode(pParse,
96c0: 20 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a   pExpr->pLeft);.
96d0: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
96e0: 41 64 64 4f 70 28 76 2c 20 6f 70 2c 20 31 2c 20  AddOp(v, op, 1, 
96f0: 64 65 73 74 29 3b 0a 20 20 20 20 20 20 62 72 65  dest);.      bre
9700: 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61  ak;.    }.    ca
9710: 73 65 20 54 4b 5f 49 4e 3a 20 7b 0a 20 20 20 20  se TK_IN: {.    
9720: 20 20 69 6e 74 20 61 64 64 72 3b 0a 20 20 20 20    int addr;.    
9730: 20 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65    sqliteExprCode
9740: 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e  (pParse, pExpr->
9750: 70 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 61 64  pLeft);.      ad
9760: 64 72 20 3d 20 73 71 6c 69 74 65 56 64 62 65 43  dr = sqliteVdbeC
9770: 75 72 72 65 6e 74 41 64 64 72 28 76 29 3b 0a 20  urrentAddr(v);. 
9780: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
9790: 64 64 4f 70 28 76 2c 20 4f 50 5f 4e 6f 74 4e 75  ddOp(v, OP_NotNu
97a0: 6c 6c 2c 20 2d 31 2c 20 61 64 64 72 2b 33 29 3b  ll, -1, addr+3);
97b0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62  .      sqliteVdb
97c0: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 50 6f 70  eAddOp(v, OP_Pop
97d0: 2c 20 31 2c 20 30 29 3b 0a 20 20 20 20 20 20 73  , 1, 0);.      s
97e0: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
97f0: 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20 6a 75  , OP_Goto, 0, ju
9800: 6d 70 49 66 4e 75 6c 6c 20 3f 20 64 65 73 74 20  mpIfNull ? dest 
9810: 3a 20 61 64 64 72 2b 34 29 3b 0a 20 20 20 20 20  : addr+4);.     
9820: 20 69 66 28 20 70 45 78 70 72 2d 3e 70 53 65 6c   if( pExpr->pSel
9830: 65 63 74 20 29 7b 0a 20 20 20 20 20 20 20 20 73  ect ){.        s
9840: 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28 76  qliteVdbeAddOp(v
9850: 2c 20 4f 50 5f 46 6f 75 6e 64 2c 20 70 45 78 70  , OP_Found, pExp
9860: 72 2d 3e 69 54 61 62 6c 65 2c 20 64 65 73 74 29  r->iTable, dest)
9870: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20  ;.      }else{. 
9880: 20 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62         sqliteVdb
9890: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 53 65 74  eAddOp(v, OP_Set
98a0: 46 6f 75 6e 64 2c 20 70 45 78 70 72 2d 3e 69 54  Found, pExpr->iT
98b0: 61 62 6c 65 2c 20 64 65 73 74 29 3b 0a 20 20 20  able, dest);.   
98c0: 20 20 20 7d 0a 20 20 20 20 20 20 62 72 65 61 6b     }.      break
98d0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
98e0: 20 54 4b 5f 42 45 54 57 45 45 4e 3a 20 7b 0a 20   TK_BETWEEN: {. 
98f0: 20 20 20 20 20 69 6e 74 20 61 64 64 72 3b 0a 20       int addr;. 
9900: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
9910: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
9920: 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20 20 20 20  r->pLeft);.     
9930: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
9940: 28 76 2c 20 4f 50 5f 44 75 70 2c 20 30 2c 20 30  (v, OP_Dup, 0, 0
9950: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45  );.      sqliteE
9960: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
9970: 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b  pExpr->pList->a[
9980: 30 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 20  0].pExpr);.     
9990: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 56 64   addr = sqliteVd
99a0: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4c 74  beAddOp(v, OP_Lt
99b0: 2c 20 21 6a 75 6d 70 49 66 4e 75 6c 6c 2c 20 30  , !jumpIfNull, 0
99c0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45  );.      sqliteE
99d0: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
99e0: 70 45 78 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b  pExpr->pList->a[
99f0: 31 5d 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 20  1].pExpr);.     
9a00: 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70   sqliteVdbeAddOp
9a10: 28 76 2c 20 4f 50 5f 4c 65 2c 20 6a 75 6d 70 49  (v, OP_Le, jumpI
9a20: 66 4e 75 6c 6c 2c 20 64 65 73 74 29 3b 0a 20 20  fNull, dest);.  
9a30: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
9a40: 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65  dOp(v, OP_Intege
9a50: 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  r, 0, 0);.      
9a60: 73 71 6c 69 74 65 56 64 62 65 43 68 61 6e 67 65  sqliteVdbeChange
9a70: 50 32 28 76 2c 20 61 64 64 72 2c 20 73 71 6c 69  P2(v, addr, sqli
9a80: 74 65 56 64 62 65 43 75 72 72 65 6e 74 41 64 64  teVdbeCurrentAdd
9a90: 72 28 76 29 29 3b 0a 20 20 20 20 20 20 73 71 6c  r(v));.      sql
9aa0: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
9ab0: 4f 50 5f 50 6f 70 2c 20 31 2c 20 30 29 3b 0a 20  OP_Pop, 1, 0);. 
9ac0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
9ad0: 7d 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b  }.    default: {
9ae0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78 70  .      sqliteExp
9af0: 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45  rCode(pParse, pE
9b00: 78 70 72 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  xpr);.      sqli
9b10: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  teVdbeAddOp(v, O
9b20: 50 5f 49 66 2c 20 6a 75 6d 70 49 66 4e 75 6c 6c  P_If, jumpIfNull
9b30: 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20 20 62  , dest);.      b
9b40: 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  reak;.    }.  }.
9b50: 7d 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61 74  }../*.** Generat
9b60: 65 20 63 6f 64 65 20 66 6f 72 20 61 20 62 6f 6f  e code for a boo
9b70: 6c 65 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20  lean expression 
9b80: 73 75 63 68 20 74 68 61 74 20 61 20 6a 75 6d 70  such that a jump
9b90: 20 69 73 20 6d 61 64 65 0a 2a 2a 20 74 6f 20 74   is made.** to t
9ba0: 68 65 20 6c 61 62 65 6c 20 22 64 65 73 74 22 20  he label "dest" 
9bb0: 69 66 20 74 68 65 20 65 78 70 72 65 73 73 69 6f  if the expressio
9bc0: 6e 20 69 73 20 66 61 6c 73 65 20 62 75 74 20 65  n is false but e
9bd0: 78 65 63 75 74 69 6f 6e 0a 2a 2a 20 63 6f 6e 74  xecution.** cont
9be0: 69 6e 75 65 73 20 73 74 72 61 69 67 68 74 20 74  inues straight t
9bf0: 68 72 75 20 69 66 20 74 68 65 20 65 78 70 72 65  hru if the expre
9c00: 73 73 69 6f 6e 20 69 73 20 74 72 75 65 2e 0a 2a  ssion is true..*
9c10: 2a 0a 2a 2a 20 49 66 20 74 68 65 20 65 78 70 72  *.** If the expr
9c20: 65 73 73 69 6f 6e 20 65 76 61 6c 75 61 74 65 73  ession evaluates
9c30: 20 74 6f 20 4e 55 4c 4c 20 28 6e 65 69 74 68 65   to NULL (neithe
9c40: 72 20 74 72 75 65 20 6e 6f 72 20 66 61 6c 73 65  r true nor false
9c50: 29 20 74 68 65 6e 0a 2a 2a 20 6a 75 6d 70 20 69  ) then.** jump i
9c60: 66 20 6a 75 6d 70 49 66 4e 75 6c 6c 20 69 73 20  f jumpIfNull is 
9c70: 74 72 75 65 20 6f 72 20 66 61 6c 6c 20 74 68 72  true or fall thr
9c80: 6f 75 67 68 20 69 66 20 6a 75 6d 70 49 66 4e 75  ough if jumpIfNu
9c90: 6c 6c 20 69 73 20 66 61 6c 73 65 2e 0a 2a 2f 0a  ll is false..*/.
9ca0: 76 6f 69 64 20 73 71 6c 69 74 65 45 78 70 72 49  void sqliteExprI
9cb0: 66 46 61 6c 73 65 28 50 61 72 73 65 20 2a 70 50  fFalse(Parse *pP
9cc0: 61 72 73 65 2c 20 45 78 70 72 20 2a 70 45 78 70  arse, Expr *pExp
9cd0: 72 2c 20 69 6e 74 20 64 65 73 74 2c 20 69 6e 74  r, int dest, int
9ce0: 20 6a 75 6d 70 49 66 4e 75 6c 6c 29 7b 0a 20 20   jumpIfNull){.  
9cf0: 56 64 62 65 20 2a 76 20 3d 20 70 50 61 72 73 65  Vdbe *v = pParse
9d00: 2d 3e 70 56 64 62 65 3b 0a 20 20 69 6e 74 20 6f  ->pVdbe;.  int o
9d10: 70 20 3d 20 30 3b 0a 20 20 69 66 28 20 76 3d 3d  p = 0;.  if( v==
9d20: 30 20 7c 7c 20 70 45 78 70 72 3d 3d 30 20 29 20  0 || pExpr==0 ) 
9d30: 72 65 74 75 72 6e 3b 0a 20 20 73 77 69 74 63 68  return;.  switch
9d40: 28 20 70 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20  ( pExpr->op ){. 
9d50: 20 20 20 63 61 73 65 20 54 4b 5f 4c 54 3a 20 20     case TK_LT:  
9d60: 20 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 65 3b       op = OP_Ge;
9d70: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
9d80: 20 20 63 61 73 65 20 54 4b 5f 4c 45 3a 20 20 20    case TK_LE:   
9d90: 20 20 20 20 6f 70 20 3d 20 4f 50 5f 47 74 3b 20      op = OP_Gt; 
9da0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
9db0: 20 63 61 73 65 20 54 4b 5f 47 54 3a 20 20 20 20   case TK_GT:    
9dc0: 20 20 20 6f 70 20 3d 20 4f 50 5f 4c 65 3b 20 20     op = OP_Le;  
9dd0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
9de0: 63 61 73 65 20 54 4b 5f 47 45 3a 20 20 20 20 20  case TK_GE:     
9df0: 20 20 6f 70 20 3d 20 4f 50 5f 4c 74 3b 20 20 20    op = OP_Lt;   
9e00: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
9e10: 61 73 65 20 54 4b 5f 4e 45 3a 20 20 20 20 20 20  ase TK_NE:      
9e20: 20 6f 70 20 3d 20 4f 50 5f 45 71 3b 20 20 20 20   op = OP_Eq;    
9e30: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
9e40: 73 65 20 54 4b 5f 45 51 3a 20 20 20 20 20 20 20  se TK_EQ:       
9e50: 6f 70 20 3d 20 4f 50 5f 4e 65 3b 20 20 20 20 20  op = OP_Ne;     
9e60: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
9e70: 65 20 54 4b 5f 49 53 4e 55 4c 4c 3a 20 20 20 6f  e TK_ISNULL:   o
9e80: 70 20 3d 20 4f 50 5f 4e 6f 74 4e 75 6c 6c 3b 20  p = OP_NotNull; 
9e90: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
9ea0: 20 54 4b 5f 4e 4f 54 4e 55 4c 4c 3a 20 20 6f 70   TK_NOTNULL:  op
9eb0: 20 3d 20 4f 50 5f 49 73 4e 75 6c 6c 3b 20 20 20   = OP_IsNull;   
9ec0: 62 72 65 61 6b 3b 0a 20 20 20 20 64 65 66 61 75  break;.    defau
9ed0: 6c 74 3a 20 20 62 72 65 61 6b 3b 0a 20 20 7d 0a  lt:  break;.  }.
9ee0: 20 20 73 77 69 74 63 68 28 20 70 45 78 70 72 2d    switch( pExpr-
9ef0: 3e 6f 70 20 29 7b 0a 20 20 20 20 63 61 73 65 20  >op ){.    case 
9f00: 54 4b 5f 41 4e 44 3a 20 7b 0a 20 20 20 20 20 20  TK_AND: {.      
9f10: 73 71 6c 69 74 65 45 78 70 72 49 66 46 61 6c 73  sqliteExprIfFals
9f20: 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d  e(pParse, pExpr-
9f30: 3e 70 4c 65 66 74 2c 20 64 65 73 74 2c 20 6a 75  >pLeft, dest, ju
9f40: 6d 70 49 66 4e 75 6c 6c 29 3b 0a 20 20 20 20 20  mpIfNull);.     
9f50: 20 73 71 6c 69 74 65 45 78 70 72 49 66 46 61 6c   sqliteExprIfFal
9f60: 73 65 28 70 50 61 72 73 65 2c 20 70 45 78 70 72  se(pParse, pExpr
9f70: 2d 3e 70 52 69 67 68 74 2c 20 64 65 73 74 2c 20  ->pRight, dest, 
9f80: 6a 75 6d 70 49 66 4e 75 6c 6c 29 3b 0a 20 20 20  jumpIfNull);.   
9f90: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
9fa0: 20 20 20 20 63 61 73 65 20 54 4b 5f 4f 52 3a 20      case TK_OR: 
9fb0: 7b 0a 20 20 20 20 20 20 69 6e 74 20 64 32 20 3d  {.      int d2 =
9fc0: 20 73 71 6c 69 74 65 56 64 62 65 4d 61 6b 65 4c   sqliteVdbeMakeL
9fd0: 61 62 65 6c 28 76 29 3b 0a 20 20 20 20 20 20 73  abel(v);.      s
9fe0: 71 6c 69 74 65 45 78 70 72 49 66 54 72 75 65 28  qliteExprIfTrue(
9ff0: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
a000: 4c 65 66 74 2c 20 64 32 2c 20 21 6a 75 6d 70 49  Left, d2, !jumpI
a010: 66 4e 75 6c 6c 29 3b 0a 20 20 20 20 20 20 73 71  fNull);.      sq
a020: 6c 69 74 65 45 78 70 72 49 66 46 61 6c 73 65 28  liteExprIfFalse(
a030: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
a040: 52 69 67 68 74 2c 20 64 65 73 74 2c 20 6a 75 6d  Right, dest, jum
a050: 70 49 66 4e 75 6c 6c 29 3b 0a 20 20 20 20 20 20  pIfNull);.      
a060: 73 71 6c 69 74 65 56 64 62 65 52 65 73 6f 6c 76  sqliteVdbeResolv
a070: 65 4c 61 62 65 6c 28 76 2c 20 64 32 29 3b 0a 20  eLabel(v, d2);. 
a080: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
a090: 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e 4f  }.    case TK_NO
a0a0: 54 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  T: {.      sqlit
a0b0: 65 45 78 70 72 49 66 54 72 75 65 28 70 50 61 72  eExprIfTrue(pPar
a0c0: 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 65 66 74  se, pExpr->pLeft
a0d0: 2c 20 64 65 73 74 2c 20 6a 75 6d 70 49 66 4e 75  , dest, jumpIfNu
a0e0: 6c 6c 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b  ll);.      break
a0f0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65  ;.    }.    case
a100: 20 54 4b 5f 4c 54 3a 0a 20 20 20 20 63 61 73 65   TK_LT:.    case
a110: 20 54 4b 5f 4c 45 3a 0a 20 20 20 20 63 61 73 65   TK_LE:.    case
a120: 20 54 4b 5f 47 54 3a 0a 20 20 20 20 63 61 73 65   TK_GT:.    case
a130: 20 54 4b 5f 47 45 3a 0a 20 20 20 20 63 61 73 65   TK_GE:.    case
a140: 20 54 4b 5f 4e 45 3a 0a 20 20 20 20 63 61 73 65   TK_NE:.    case
a150: 20 54 4b 5f 45 51 3a 20 7b 0a 20 20 20 20 20 20   TK_EQ: {.      
a160: 69 66 28 20 70 50 61 72 73 65 2d 3e 64 62 2d 3e  if( pParse->db->
a170: 66 69 6c 65 5f 66 6f 72 6d 61 74 3e 3d 33 20 26  file_format>=3 &
a180: 26 20 73 71 6c 69 74 65 45 78 70 72 54 79 70 65  & sqliteExprType
a190: 28 70 45 78 70 72 29 3d 3d 53 51 4c 49 54 45 5f  (pExpr)==SQLITE_
a1a0: 53 4f 5f 54 45 58 54 20 29 7b 0a 20 20 20 20 20  SO_TEXT ){.     
a1b0: 20 20 20 6f 70 20 2b 3d 20 36 3b 20 20 2f 2a 20     op += 6;  /* 
a1c0: 43 6f 6e 76 65 72 74 20 6e 75 6d 65 72 69 63 20  Convert numeric 
a1d0: 6f 70 63 6f 64 65 73 20 74 6f 20 74 65 78 74 20  opcodes to text 
a1e0: 6f 70 63 6f 64 65 73 20 2a 2f 0a 20 20 20 20 20  opcodes */.     
a1f0: 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45   }.      sqliteE
a200: 78 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20  xprCode(pParse, 
a210: 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20  pExpr->pLeft);. 
a220: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
a230: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
a240: 72 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20 20 20  r->pRight);.    
a250: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
a260: 70 28 76 2c 20 6f 70 2c 20 6a 75 6d 70 49 66 4e  p(v, op, jumpIfN
a270: 75 6c 6c 2c 20 64 65 73 74 29 3b 0a 20 20 20 20  ull, dest);.    
a280: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20    break;.    }. 
a290: 20 20 20 63 61 73 65 20 54 4b 5f 49 53 4e 55 4c     case TK_ISNUL
a2a0: 4c 3a 0a 20 20 20 20 63 61 73 65 20 54 4b 5f 4e  L:.    case TK_N
a2b0: 4f 54 4e 55 4c 4c 3a 20 7b 0a 20 20 20 20 20 20  OTNULL: {.      
a2c0: 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70  sqliteExprCode(p
a2d0: 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c  Parse, pExpr->pL
a2e0: 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  eft);.      sqli
a2f0: 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 6f  teVdbeAddOp(v, o
a300: 70 2c 20 31 2c 20 64 65 73 74 29 3b 0a 20 20 20  p, 1, dest);.   
a310: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
a320: 20 20 20 20 63 61 73 65 20 54 4b 5f 49 4e 3a 20      case TK_IN: 
a330: 7b 0a 20 20 20 20 20 20 69 6e 74 20 61 64 64 72  {.      int addr
a340: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 45 78  ;.      sqliteEx
a350: 70 72 43 6f 64 65 28 70 50 61 72 73 65 2c 20 70  prCode(pParse, p
a360: 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20 20  Expr->pLeft);.  
a370: 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74      addr = sqlit
a380: 65 56 64 62 65 43 75 72 72 65 6e 74 41 64 64 72  eVdbeCurrentAddr
a390: 28 76 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  (v);.      sqlit
a3a0: 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  eVdbeAddOp(v, OP
a3b0: 5f 4e 6f 74 4e 75 6c 6c 2c 20 2d 31 2c 20 61 64  _NotNull, -1, ad
a3c0: 64 72 2b 33 29 3b 0a 20 20 20 20 20 20 73 71 6c  dr+3);.      sql
a3d0: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
a3e0: 4f 50 5f 50 6f 70 2c 20 31 2c 20 30 29 3b 0a 20  OP_Pop, 1, 0);. 
a3f0: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
a400: 64 64 4f 70 28 76 2c 20 4f 50 5f 47 6f 74 6f 2c  ddOp(v, OP_Goto,
a410: 20 30 2c 20 6a 75 6d 70 49 66 4e 75 6c 6c 20 3f   0, jumpIfNull ?
a420: 20 64 65 73 74 20 3a 20 61 64 64 72 2b 34 29 3b   dest : addr+4);
a430: 0a 20 20 20 20 20 20 69 66 28 20 70 45 78 70 72  .      if( pExpr
a440: 2d 3e 70 53 65 6c 65 63 74 20 29 7b 0a 20 20 20  ->pSelect ){.   
a450: 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41       sqliteVdbeA
a460: 64 64 4f 70 28 76 2c 20 4f 50 5f 4e 6f 74 46 6f  ddOp(v, OP_NotFo
a470: 75 6e 64 2c 20 70 45 78 70 72 2d 3e 69 54 61 62  und, pExpr->iTab
a480: 6c 65 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20  le, dest);.     
a490: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
a4a0: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
a4b0: 76 2c 20 4f 50 5f 53 65 74 4e 6f 74 46 6f 75 6e  v, OP_SetNotFoun
a4c0: 64 2c 20 70 45 78 70 72 2d 3e 69 54 61 62 6c 65  d, pExpr->iTable
a4d0: 2c 20 64 65 73 74 29 3b 0a 20 20 20 20 20 20 7d  , dest);.      }
a4e0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
a4f0: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 54 4b 5f    }.    case TK_
a500: 42 45 54 57 45 45 4e 3a 20 7b 0a 20 20 20 20 20  BETWEEN: {.     
a510: 20 69 6e 74 20 61 64 64 72 3b 0a 20 20 20 20 20   int addr;.     
a520: 20 73 71 6c 69 74 65 45 78 70 72 43 6f 64 65 28   sqliteExprCode(
a530: 70 50 61 72 73 65 2c 20 70 45 78 70 72 2d 3e 70  pParse, pExpr->p
a540: 4c 65 66 74 29 3b 0a 20 20 20 20 20 20 73 71 6c  Left);.      sql
a550: 69 74 65 56 64 62 65 41 64 64 4f 70 28 76 2c 20  iteVdbeAddOp(v, 
a560: 4f 50 5f 44 75 70 2c 20 30 2c 20 30 29 3b 0a 20  OP_Dup, 0, 0);. 
a570: 20 20 20 20 20 73 71 6c 69 74 65 45 78 70 72 43       sqliteExprC
a580: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 45 78 70  ode(pParse, pExp
a590: 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 30 5d 2e 70  r->pList->a[0].p
a5a0: 45 78 70 72 29 3b 0a 20 20 20 20 20 20 61 64 64  Expr);.      add
a5b0: 72 20 3d 20 73 71 6c 69 74 65 56 64 62 65 43 75  r = sqliteVdbeCu
a5c0: 72 72 65 6e 74 41 64 64 72 28 76 29 3b 0a 20 20  rrentAddr(v);.  
a5d0: 20 20 20 20 73 71 6c 69 74 65 56 64 62 65 41 64      sqliteVdbeAd
a5e0: 64 4f 70 28 76 2c 20 4f 50 5f 47 65 2c 20 21 6a  dOp(v, OP_Ge, !j
a5f0: 75 6d 70 49 66 4e 75 6c 6c 2c 20 61 64 64 72 2b  umpIfNull, addr+
a600: 33 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  3);.      sqlite
a610: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
a620: 50 6f 70 2c 20 31 2c 20 30 29 3b 0a 20 20 20 20  Pop, 1, 0);.    
a630: 20 20 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f    sqliteVdbeAddO
a640: 70 28 76 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c  p(v, OP_Goto, 0,
a650: 20 64 65 73 74 29 3b 0a 20 20 20 20 20 20 73 71   dest);.      sq
a660: 6c 69 74 65 45 78 70 72 43 6f 64 65 28 70 50 61  liteExprCode(pPa
a670: 72 73 65 2c 20 70 45 78 70 72 2d 3e 70 4c 69 73  rse, pExpr->pLis
a680: 74 2d 3e 61 5b 31 5d 2e 70 45 78 70 72 29 3b 0a  t->a[1].pExpr);.
a690: 20 20 20 20 20 20 73 71 6c 69 74 65 56 64 62 65        sqliteVdbe
a6a0: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 47 74 2c 20  AddOp(v, OP_Gt, 
a6b0: 6a 75 6d 70 49 66 4e 75 6c 6c 2c 20 64 65 73 74  jumpIfNull, dest
a6c0: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
a6d0: 20 20 20 20 7d 0a 20 20 20 20 64 65 66 61 75 6c      }.    defaul
a6e0: 74 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  t: {.      sqlit
a6f0: 65 45 78 70 72 43 6f 64 65 28 70 50 61 72 73 65  eExprCode(pParse
a700: 2c 20 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20  , pExpr);.      
a710: 73 71 6c 69 74 65 56 64 62 65 41 64 64 4f 70 28  sqliteVdbeAddOp(
a720: 76 2c 20 4f 50 5f 49 66 4e 6f 74 2c 20 6a 75 6d  v, OP_IfNot, jum
a730: 70 49 66 4e 75 6c 6c 2c 20 64 65 73 74 29 3b 0a  pIfNull, dest);.
a740: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
a750: 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20   }.  }.}../*.** 
a760: 44 6f 20 61 20 64 65 65 70 20 63 6f 6d 70 61 72  Do a deep compar
a770: 69 73 6f 6e 20 6f 66 20 74 77 6f 20 65 78 70 72  ison of two expr
a780: 65 73 73 69 6f 6e 20 74 72 65 65 73 2e 20 20 52  ession trees.  R
a790: 65 74 75 72 6e 20 54 52 55 45 20 28 6e 6f 6e 2d  eturn TRUE (non-
a7a0: 7a 65 72 6f 29 0a 2a 2a 20 69 66 20 74 68 65 79  zero).** if they
a7b0: 20 61 72 65 20 69 64 65 6e 74 69 63 61 6c 20 61   are identical a
a7c0: 6e 64 20 72 65 74 75 72 6e 20 46 41 4c 53 45 20  nd return FALSE 
a7d0: 69 66 20 74 68 65 79 20 64 69 66 66 65 72 20 69  if they differ i
a7e0: 6e 20 61 6e 79 20 77 61 79 2e 0a 2a 2f 0a 69 6e  n any way..*/.in
a7f0: 74 20 73 71 6c 69 74 65 45 78 70 72 43 6f 6d 70  t sqliteExprComp
a800: 61 72 65 28 45 78 70 72 20 2a 70 41 2c 20 45 78  are(Expr *pA, Ex
a810: 70 72 20 2a 70 42 29 7b 0a 20 20 69 6e 74 20 69  pr *pB){.  int i
a820: 3b 0a 20 20 69 66 28 20 70 41 3d 3d 30 20 29 7b  ;.  if( pA==0 ){
a830: 0a 20 20 20 20 72 65 74 75 72 6e 20 70 42 3d 3d  .    return pB==
a840: 30 3b 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 70  0;.  }else if( p
a850: 42 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65 74 75  B==0 ){.    retu
a860: 72 6e 20 30 3b 0a 20 20 7d 0a 20 20 69 66 28 20  rn 0;.  }.  if( 
a870: 70 41 2d 3e 6f 70 21 3d 70 42 2d 3e 6f 70 20 29  pA->op!=pB->op )
a880: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 69 66 28   return 0;.  if(
a890: 20 21 73 71 6c 69 74 65 45 78 70 72 43 6f 6d 70   !sqliteExprComp
a8a0: 61 72 65 28 70 41 2d 3e 70 4c 65 66 74 2c 20 70  are(pA->pLeft, p
a8b0: 42 2d 3e 70 4c 65 66 74 29 20 29 20 72 65 74 75  B->pLeft) ) retu
a8c0: 72 6e 20 30 3b 0a 20 20 69 66 28 20 21 73 71 6c  rn 0;.  if( !sql
a8d0: 69 74 65 45 78 70 72 43 6f 6d 70 61 72 65 28 70  iteExprCompare(p
a8e0: 41 2d 3e 70 52 69 67 68 74 2c 20 70 42 2d 3e 70  A->pRight, pB->p
a8f0: 52 69 67 68 74 29 20 29 20 72 65 74 75 72 6e 20  Right) ) return 
a900: 30 3b 0a 20 20 69 66 28 20 70 41 2d 3e 70 4c 69  0;.  if( pA->pLi
a910: 73 74 20 29 7b 0a 20 20 20 20 69 66 28 20 70 42  st ){.    if( pB
a920: 2d 3e 70 4c 69 73 74 3d 3d 30 20 29 20 72 65 74  ->pList==0 ) ret
a930: 75 72 6e 20 30 3b 0a 20 20 20 20 69 66 28 20 70  urn 0;.    if( p
a940: 41 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 21  A->pList->nExpr!
a950: 3d 70 42 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70  =pB->pList->nExp
a960: 72 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  r ) return 0;.  
a970: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 41 2d    for(i=0; i<pA-
a980: 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20 69  >pList->nExpr; i
a990: 2b 2b 29 7b 0a 20 20 20 20 20 20 69 66 28 20 21  ++){.      if( !
a9a0: 73 71 6c 69 74 65 45 78 70 72 43 6f 6d 70 61 72  sqliteExprCompar
a9b0: 65 28 70 41 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69  e(pA->pList->a[i
a9c0: 5d 2e 70 45 78 70 72 2c 20 70 42 2d 3e 70 4c 69  ].pExpr, pB->pLi
a9d0: 73 74 2d 3e 61 5b 69 5d 2e 70 45 78 70 72 29 20  st->a[i].pExpr) 
a9e0: 29 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  ){.        retur
a9f0: 6e 20 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  n 0;.      }.   
aa00: 20 7d 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 70   }.  }else if( p
aa10: 42 2d 3e 70 4c 69 73 74 20 29 7b 0a 20 20 20 20  B->pList ){.    
aa20: 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20 20  return 0;.  }.  
aa30: 69 66 28 20 70 41 2d 3e 70 53 65 6c 65 63 74 20  if( pA->pSelect 
aa40: 7c 7c 20 70 42 2d 3e 70 53 65 6c 65 63 74 20 29  || pB->pSelect )
aa50: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 69 66 28   return 0;.  if(
aa60: 20 70 41 2d 3e 74 6f 6b 65 6e 2e 7a 20 29 7b 0a   pA->token.z ){.
aa70: 20 20 20 20 69 66 28 20 70 42 2d 3e 74 6f 6b 65      if( pB->toke
aa80: 6e 2e 7a 3d 3d 30 20 29 20 72 65 74 75 72 6e 20  n.z==0 ) return 
aa90: 30 3b 0a 20 20 20 20 69 66 28 20 70 42 2d 3e 74  0;.    if( pB->t
aaa0: 6f 6b 65 6e 2e 6e 21 3d 70 41 2d 3e 74 6f 6b 65  oken.n!=pA->toke
aab0: 6e 2e 6e 20 29 20 72 65 74 75 72 6e 20 30 3b 0a  n.n ) return 0;.
aac0: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 53 74      if( sqliteSt
aad0: 72 4e 49 43 6d 70 28 70 41 2d 3e 74 6f 6b 65 6e  rNICmp(pA->token
aae0: 2e 7a 2c 20 70 42 2d 3e 74 6f 6b 65 6e 2e 7a 2c  .z, pB->token.z,
aaf0: 20 70 41 2d 3e 74 6f 6b 65 6e 2e 6e 29 21 3d 30   pA->token.n)!=0
ab00: 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d   ) return 0;.  }
ab10: 0a 20 20 72 65 74 75 72 6e 20 31 3b 0a 7d 0a 0a  .  return 1;.}..
ab20: 2f 2a 0a 2a 2a 20 41 64 64 20 61 20 6e 65 77 20  /*.** Add a new 
ab30: 65 6c 65 6d 65 6e 74 20 74 6f 20 74 68 65 20 70  element to the p
ab40: 50 61 72 73 65 2d 3e 61 41 67 67 5b 5d 20 61 72  Parse->aAgg[] ar
ab50: 72 61 79 20 61 6e 64 20 72 65 74 75 72 6e 20 69  ray and return i
ab60: 74 73 20 69 6e 64 65 78 2e 0a 2a 2f 0a 73 74 61  ts index..*/.sta
ab70: 74 69 63 20 69 6e 74 20 61 70 70 65 6e 64 41 67  tic int appendAg
ab80: 67 49 6e 66 6f 28 50 61 72 73 65 20 2a 70 50 61  gInfo(Parse *pPa
ab90: 72 73 65 29 7b 0a 20 20 69 66 28 20 28 70 50 61  rse){.  if( (pPa
aba0: 72 73 65 2d 3e 6e 41 67 67 20 26 20 30 78 37 29  rse->nAgg & 0x7)
abb0: 3d 3d 30 20 29 7b 0a 20 20 20 20 69 6e 74 20 61  ==0 ){.    int a
abc0: 6d 74 20 3d 20 70 50 61 72 73 65 2d 3e 6e 41 67  mt = pParse->nAg
abd0: 67 20 2b 20 38 3b 0a 20 20 20 20 41 67 67 45 78  g + 8;.    AggEx
abe0: 70 72 20 2a 61 41 67 67 20 3d 20 73 71 6c 69 74  pr *aAgg = sqlit
abf0: 65 52 65 61 6c 6c 6f 63 28 70 50 61 72 73 65 2d  eRealloc(pParse-
ac00: 3e 61 41 67 67 2c 20 61 6d 74 2a 73 69 7a 65 6f  >aAgg, amt*sizeo
ac10: 66 28 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 30  f(pParse->aAgg[0
ac20: 5d 29 29 3b 0a 20 20 20 20 69 66 28 20 61 41 67  ]));.    if( aAg
ac30: 67 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 72 65  g==0 ){.      re
ac40: 74 75 72 6e 20 2d 31 3b 0a 20 20 20 20 7d 0a 20  turn -1;.    }. 
ac50: 20 20 20 70 50 61 72 73 65 2d 3e 61 41 67 67 20     pParse->aAgg 
ac60: 3d 20 61 41 67 67 3b 0a 20 20 7d 0a 20 20 6d 65  = aAgg;.  }.  me
ac70: 6d 73 65 74 28 26 70 50 61 72 73 65 2d 3e 61 41  mset(&pParse->aA
ac80: 67 67 5b 70 50 61 72 73 65 2d 3e 6e 41 67 67 5d  gg[pParse->nAgg]
ac90: 2c 20 30 2c 20 73 69 7a 65 6f 66 28 70 50 61 72  , 0, sizeof(pPar
aca0: 73 65 2d 3e 61 41 67 67 5b 30 5d 29 29 3b 0a 20  se->aAgg[0]));. 
acb0: 20 72 65 74 75 72 6e 20 70 50 61 72 73 65 2d 3e   return pParse->
acc0: 6e 41 67 67 2b 2b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  nAgg++;.}../*.**
acd0: 20 41 6e 61 6c 79 7a 65 20 74 68 65 20 67 69 76   Analyze the giv
ace0: 65 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 6c 6f  en expression lo
acf0: 6f 6b 69 6e 67 20 66 6f 72 20 61 67 67 72 65 67  oking for aggreg
ad00: 61 74 65 20 66 75 6e 63 74 69 6f 6e 73 20 61 6e  ate functions an
ad10: 64 0a 2a 2a 20 66 6f 72 20 76 61 72 69 61 62 6c  d.** for variabl
ad20: 65 73 20 74 68 61 74 20 6e 65 65 64 20 74 6f 20  es that need to 
ad30: 62 65 20 61 64 64 65 64 20 74 6f 20 74 68 65 20  be added to the 
ad40: 70 50 61 72 73 65 2d 3e 61 41 67 67 5b 5d 20 61  pParse->aAgg[] a
ad50: 72 72 61 79 2e 0a 2a 2a 20 4d 61 6b 65 20 61 64  rray..** Make ad
ad60: 64 69 74 69 6f 6e 61 6c 20 65 6e 74 72 69 65 73  ditional entries
ad70: 20 74 6f 20 74 68 65 20 70 50 61 72 73 65 2d 3e   to the pParse->
ad80: 61 41 67 67 5b 5d 20 61 72 72 61 79 20 61 73 20  aAgg[] array as 
ad90: 6e 65 63 65 73 73 61 72 79 2e 0a 2a 2a 0a 2a 2a  necessary..**.**
ada0: 20 54 68 69 73 20 72 6f 75 74 69 6e 65 20 73 68   This routine sh
adb0: 6f 75 6c 64 20 6f 6e 6c 79 20 62 65 20 63 61 6c  ould only be cal
adc0: 6c 65 64 20 61 66 74 65 72 20 74 68 65 20 65 78  led after the ex
add0: 70 72 65 73 73 69 6f 6e 20 68 61 73 20 62 65 65  pression has bee
ade0: 6e 0a 2a 2a 20 61 6e 61 6c 79 7a 65 64 20 62 79  n.** analyzed by
adf0: 20 73 71 6c 69 74 65 45 78 70 72 52 65 73 6f 6c   sqliteExprResol
ae00: 76 65 49 64 73 28 29 20 61 6e 64 20 73 71 6c 69  veIds() and sqli
ae10: 74 65 45 78 70 72 43 68 65 63 6b 28 29 2e 0a 2a  teExprCheck()..*
ae20: 2a 0a 2a 2a 20 49 66 20 65 72 72 6f 72 73 20 61  *.** If errors a
ae30: 72 65 20 73 65 65 6e 2c 20 6c 65 61 76 65 20 61  re seen, leave a
ae40: 6e 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20  n error message 
ae50: 69 6e 20 7a 45 72 72 4d 73 67 20 61 6e 64 20 72  in zErrMsg and r
ae60: 65 74 75 72 6e 0a 2a 2a 20 74 68 65 20 6e 75 6d  eturn.** the num
ae70: 62 65 72 20 6f 66 20 65 72 72 6f 72 73 2e 0a 2a  ber of errors..*
ae80: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 45 78 70 72  /.int sqliteExpr
ae90: 41 6e 61 6c 79 7a 65 41 67 67 72 65 67 61 74 65  AnalyzeAggregate
aea0: 73 28 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c  s(Parse *pParse,
aeb0: 20 45 78 70 72 20 2a 70 45 78 70 72 29 7b 0a 20   Expr *pExpr){. 
aec0: 20 69 6e 74 20 69 3b 0a 20 20 41 67 67 45 78 70   int i;.  AggExp
aed0: 72 20 2a 61 41 67 67 3b 0a 20 20 69 6e 74 20 6e  r *aAgg;.  int n
aee0: 45 72 72 20 3d 20 30 3b 0a 0a 20 20 69 66 28 20  Err = 0;..  if( 
aef0: 70 45 78 70 72 3d 3d 30 20 29 20 72 65 74 75 72  pExpr==0 ) retur
af00: 6e 20 30 3b 0a 20 20 73 77 69 74 63 68 28 20 70  n 0;.  switch( p
af10: 45 78 70 72 2d 3e 6f 70 20 29 7b 0a 20 20 20 20  Expr->op ){.    
af20: 63 61 73 65 20 54 4b 5f 43 4f 4c 55 4d 4e 3a 20  case TK_COLUMN: 
af30: 7b 0a 20 20 20 20 20 20 61 41 67 67 20 3d 20 70  {.      aAgg = p
af40: 50 61 72 73 65 2d 3e 61 41 67 67 3b 0a 20 20 20  Parse->aAgg;.   
af50: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 50     for(i=0; i<pP
af60: 61 72 73 65 2d 3e 6e 41 67 67 3b 20 69 2b 2b 29  arse->nAgg; i++)
af70: 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 61 41  {.        if( aA
af80: 67 67 5b 69 5d 2e 69 73 41 67 67 20 29 20 63 6f  gg[i].isAgg ) co
af90: 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20  ntinue;.        
afa0: 69 66 28 20 61 41 67 67 5b 69 5d 2e 70 45 78 70  if( aAgg[i].pExp
afb0: 72 2d 3e 69 54 61 62 6c 65 3d 3d 70 45 78 70 72  r->iTable==pExpr
afc0: 2d 3e 69 54 61 62 6c 65 0a 20 20 20 20 20 20 20  ->iTable.       
afd0: 20 20 26 26 20 61 41 67 67 5b 69 5d 2e 70 45 78    && aAgg[i].pEx
afe0: 70 72 2d 3e 69 43 6f 6c 75 6d 6e 3d 3d 70 45 78  pr->iColumn==pEx
aff0: 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 29 7b 0a 20  pr->iColumn ){. 
b000: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a           break;.
b010: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
b020: 7d 0a 20 20 20 20 20 20 69 66 28 20 69 3e 3d 70  }.      if( i>=p
b030: 50 61 72 73 65 2d 3e 6e 41 67 67 20 29 7b 0a 20  Parse->nAgg ){. 
b040: 20 20 20 20 20 20 20 69 20 3d 20 61 70 70 65 6e         i = appen
b050: 64 41 67 67 49 6e 66 6f 28 70 50 61 72 73 65 29  dAggInfo(pParse)
b060: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 69 3c  ;.        if( i<
b070: 30 20 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20  0 ) return 1;.  
b080: 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 61 41        pParse->aA
b090: 67 67 5b 69 5d 2e 69 73 41 67 67 20 3d 20 30 3b  gg[i].isAgg = 0;
b0a0: 0a 20 20 20 20 20 20 20 20 70 50 61 72 73 65 2d  .        pParse-
b0b0: 3e 61 41 67 67 5b 69 5d 2e 70 45 78 70 72 20 3d  >aAgg[i].pExpr =
b0c0: 20 70 45 78 70 72 3b 0a 20 20 20 20 20 20 7d 0a   pExpr;.      }.
b0d0: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 69 41 67        pExpr->iAg
b0e0: 67 20 3d 20 69 3b 0a 20 20 20 20 20 20 62 72 65  g = i;.      bre
b0f0: 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61  ak;.    }.    ca
b100: 73 65 20 54 4b 5f 41 47 47 5f 46 55 4e 43 54 49  se TK_AGG_FUNCTI
b110: 4f 4e 3a 20 7b 0a 20 20 20 20 20 20 61 41 67 67  ON: {.      aAgg
b120: 20 3d 20 70 50 61 72 73 65 2d 3e 61 41 67 67 3b   = pParse->aAgg;
b130: 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20  .      for(i=0; 
b140: 69 3c 70 50 61 72 73 65 2d 3e 6e 41 67 67 3b 20  i<pParse->nAgg; 
b150: 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 69 66  i++){.        if
b160: 28 20 21 61 41 67 67 5b 69 5d 2e 69 73 41 67 67  ( !aAgg[i].isAgg
b170: 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20   ) continue;.   
b180: 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 45       if( sqliteE
b190: 78 70 72 43 6f 6d 70 61 72 65 28 61 41 67 67 5b  xprCompare(aAgg[
b1a0: 69 5d 2e 70 45 78 70 72 2c 20 70 45 78 70 72 29  i].pExpr, pExpr)
b1b0: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 62 72   ){.          br
b1c0: 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  eak;.        }. 
b1d0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28       }.      if(
b1e0: 20 69 3e 3d 70 50 61 72 73 65 2d 3e 6e 41 67 67   i>=pParse->nAgg
b1f0: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 20 3d 20   ){.        i = 
b200: 61 70 70 65 6e 64 41 67 67 49 6e 66 6f 28 70 50  appendAggInfo(pP
b210: 61 72 73 65 29 3b 0a 20 20 20 20 20 20 20 20 69  arse);.        i
b220: 66 28 20 69 3c 30 20 29 20 72 65 74 75 72 6e 20  f( i<0 ) return 
b230: 31 3b 0a 20 20 20 20 20 20 20 20 70 50 61 72 73  1;.        pPars
b240: 65 2d 3e 61 41 67 67 5b 69 5d 2e 69 73 41 67 67  e->aAgg[i].isAgg
b250: 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 70 50   = 1;.        pP
b260: 61 72 73 65 2d 3e 61 41 67 67 5b 69 5d 2e 70 45  arse->aAgg[i].pE
b270: 78 70 72 20 3d 20 70 45 78 70 72 3b 0a 20 20 20  xpr = pExpr;.   
b280: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 61 41 67       pParse->aAg
b290: 67 5b 69 5d 2e 70 46 75 6e 63 20 3d 20 73 71 6c  g[i].pFunc = sql
b2a0: 69 74 65 46 69 6e 64 46 75 6e 63 74 69 6f 6e 28  iteFindFunction(
b2b0: 70 50 61 72 73 65 2d 3e 64 62 2c 0a 20 20 20 20  pParse->db,.    
b2c0: 20 20 20 20 20 20 20 20 20 70 45 78 70 72 2d 3e           pExpr->
b2d0: 74 6f 6b 65 6e 2e 7a 2c 20 70 45 78 70 72 2d 3e  token.z, pExpr->
b2e0: 74 6f 6b 65 6e 2e 6e 2c 0a 20 20 20 20 20 20 20  token.n,.       
b2f0: 20 20 20 20 20 20 70 45 78 70 72 2d 3e 70 4c 69        pExpr->pLi
b300: 73 74 20 3f 20 70 45 78 70 72 2d 3e 70 4c 69 73  st ? pExpr->pLis
b310: 74 2d 3e 6e 45 78 70 72 20 3a 20 30 2c 20 30 29  t->nExpr : 0, 0)
b320: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
b330: 70 45 78 70 72 2d 3e 69 41 67 67 20 3d 20 69 3b  pExpr->iAgg = i;
b340: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
b350: 20 20 7d 0a 20 20 20 20 64 65 66 61 75 6c 74 3a    }.    default:
b360: 20 7b 0a 20 20 20 20 20 20 69 66 28 20 70 45 78   {.      if( pEx
b370: 70 72 2d 3e 70 4c 65 66 74 20 29 7b 0a 20 20 20  pr->pLeft ){.   
b380: 20 20 20 20 20 6e 45 72 72 20 3d 20 73 71 6c 69       nErr = sqli
b390: 74 65 45 78 70 72 41 6e 61 6c 79 7a 65 41 67 67  teExprAnalyzeAgg
b3a0: 72 65 67 61 74 65 73 28 70 50 61 72 73 65 2c 20  regates(pParse, 
b3b0: 70 45 78 70 72 2d 3e 70 4c 65 66 74 29 3b 0a 20  pExpr->pLeft);. 
b3c0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28       }.      if(
b3d0: 20 6e 45 72 72 3d 3d 30 20 26 26 20 70 45 78 70   nErr==0 && pExp
b3e0: 72 2d 3e 70 52 69 67 68 74 20 29 7b 0a 20 20 20  r->pRight ){.   
b3f0: 20 20 20 20 20 6e 45 72 72 20 3d 20 73 71 6c 69       nErr = sqli
b400: 74 65 45 78 70 72 41 6e 61 6c 79 7a 65 41 67 67  teExprAnalyzeAgg
b410: 72 65 67 61 74 65 73 28 70 50 61 72 73 65 2c 20  regates(pParse, 
b420: 70 45 78 70 72 2d 3e 70 52 69 67 68 74 29 3b 0a  pExpr->pRight);.
b430: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
b440: 28 20 6e 45 72 72 3d 3d 30 20 26 26 20 70 45 78  ( nErr==0 && pEx
b450: 70 72 2d 3e 70 4c 69 73 74 20 29 7b 0a 20 20 20  pr->pList ){.   
b460: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 70 45 78       int n = pEx
b470: 70 72 2d 3e 70 4c 69 73 74 2d 3e 6e 45 78 70 72  pr->pList->nExpr
b480: 3b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 3b  ;.        int i;
b490: 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30  .        for(i=0
b4a0: 3b 20 6e 45 72 72 3d 3d 30 20 26 26 20 69 3c 6e  ; nErr==0 && i<n
b4b0: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  ; i++){.        
b4c0: 20 20 6e 45 72 72 20 3d 20 73 71 6c 69 74 65 45    nErr = sqliteE
b4d0: 78 70 72 41 6e 61 6c 79 7a 65 41 67 67 72 65 67  xprAnalyzeAggreg
b4e0: 61 74 65 73 28 70 50 61 72 73 65 2c 20 70 45 78  ates(pParse, pEx
b4f0: 70 72 2d 3e 70 4c 69 73 74 2d 3e 61 5b 69 5d 2e  pr->pList->a[i].
b500: 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20 20 20  pExpr);.        
b510: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  }.      }.      
b520: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 7d  break;.    }.  }
b530: 0a 20 20 72 65 74 75 72 6e 20 6e 45 72 72 3b 0a  .  return nErr;.
b540: 7d 0a 0a 2f 2a 0a 2a 2a 20 4c 6f 63 61 74 65 20  }../*.** Locate 
b550: 61 20 75 73 65 72 20 66 75 6e 63 74 69 6f 6e 20  a user function 
b560: 67 69 76 65 6e 20 61 20 6e 61 6d 65 20 61 6e 64  given a name and
b570: 20 61 20 6e 75 6d 62 65 72 20 6f 66 20 61 72 67   a number of arg
b580: 75 6d 65 6e 74 73 2e 0a 2a 2a 20 52 65 74 75 72  uments..** Retur
b590: 6e 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 74  n a pointer to t
b5a0: 68 65 20 46 75 6e 63 44 65 66 20 73 74 72 75 63  he FuncDef struc
b5b0: 74 75 72 65 20 74 68 61 74 20 64 65 66 69 6e 65  ture that define
b5c0: 73 20 74 68 61 74 0a 2a 2a 20 66 75 6e 63 74 69  s that.** functi
b5d0: 6f 6e 2c 20 6f 72 20 72 65 74 75 72 6e 20 4e 55  on, or return NU
b5e0: 4c 4c 20 69 66 20 74 68 65 20 66 75 6e 63 74 69  LL if the functi
b5f0: 6f 6e 20 64 6f 65 73 20 6e 6f 74 20 65 78 69 73  on does not exis
b600: 74 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 65 20  t..**.** If the 
b610: 63 72 65 61 74 65 46 6c 61 67 20 61 72 67 75 6d  createFlag argum
b620: 65 6e 74 20 69 73 20 74 72 75 65 2c 20 74 68 65  ent is true, the
b630: 6e 20 61 20 6e 65 77 20 28 62 6c 61 6e 6b 29 20  n a new (blank) 
b640: 46 75 6e 63 44 65 66 0a 2a 2a 20 73 74 72 75 63  FuncDef.** struc
b650: 74 75 72 65 20 69 73 20 63 72 65 61 74 65 64 20  ture is created 
b660: 61 6e 64 20 6c 69 6b 65 64 20 69 6e 74 6f 20 74  and liked into t
b670: 68 65 20 22 64 62 22 20 73 74 72 75 63 74 75 72  he "db" structur
b680: 65 20 69 66 20 61 0a 2a 2a 20 6e 6f 20 6d 61 74  e if a.** no mat
b690: 63 68 69 6e 67 20 66 75 6e 63 74 69 6f 6e 20 70  ching function p
b6a0: 72 65 76 69 6f 75 73 6c 79 20 65 78 69 73 74 65  reviously existe
b6b0: 64 2e 20 20 57 68 65 6e 20 63 72 65 61 74 65 46  d.  When createF
b6c0: 6c 61 67 20 69 73 20 74 72 75 65 0a 2a 2a 20 61  lag is true.** a
b6d0: 6e 64 20 74 68 65 20 6e 41 72 67 20 70 61 72 61  nd the nArg para
b6e0: 6d 65 74 65 72 20 69 73 20 2d 31 2c 20 74 68 65  meter is -1, the
b6f0: 6e 20 6f 6e 6c 79 20 61 20 66 75 6e 63 74 69 6f  n only a functio
b700: 6e 20 74 68 61 74 20 61 63 63 65 70 74 73 0a 2a  n that accepts.*
b710: 2a 20 61 6e 79 20 6e 75 6d 62 65 72 20 6f 66 20  * any number of 
b720: 61 72 67 75 6d 65 6e 74 73 20 77 69 6c 6c 20 62  arguments will b
b730: 65 20 72 65 74 75 72 6e 65 64 2e 0a 2a 2a 0a 2a  e returned..**.*
b740: 2a 20 49 66 20 63 72 65 61 74 65 46 6c 61 67 20  * If createFlag 
b750: 69 73 20 66 61 6c 73 65 20 61 6e 64 20 6e 41 72  is false and nAr
b760: 67 20 69 73 20 2d 31 2c 20 74 68 65 6e 20 74 68  g is -1, then th
b770: 65 20 66 69 72 73 74 20 76 61 6c 69 64 0a 2a 2a  e first valid.**
b780: 20 66 75 6e 63 74 69 6f 6e 20 66 6f 75 6e 64 20   function found 
b790: 69 73 20 72 65 74 75 72 6e 65 64 2e 20 20 41 20  is returned.  A 
b7a0: 66 75 6e 63 74 69 6f 6e 20 69 73 20 76 61 6c 69  function is vali
b7b0: 64 20 69 66 20 65 69 74 68 65 72 20 78 46 75 6e  d if either xFun
b7c0: 63 0a 2a 2a 20 6f 72 20 78 53 74 65 70 20 69 73  c.** or xStep is
b7d0: 20 6e 6f 6e 2d 7a 65 72 6f 2e 0a 2a 2f 0a 46 75   non-zero..*/.Fu
b7e0: 6e 63 44 65 66 20 2a 73 71 6c 69 74 65 46 69 6e  ncDef *sqliteFin
b7f0: 64 46 75 6e 63 74 69 6f 6e 28 0a 20 20 73 71 6c  dFunction(.  sql
b800: 69 74 65 20 2a 64 62 2c 20 20 20 20 20 20 20 20  ite *db,        
b810: 2f 2a 20 41 6e 20 6f 70 65 6e 20 64 61 74 61 62  /* An open datab
b820: 61 73 65 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63  ase */.  const c
b830: 68 61 72 20 2a 7a 4e 61 6d 65 2c 20 2f 2a 20 4e  har *zName, /* N
b840: 61 6d 65 20 6f 66 20 74 68 65 20 66 75 6e 63 74  ame of the funct
b850: 69 6f 6e 2e 20 20 4e 6f 74 20 6e 75 6c 6c 2d 74  ion.  Not null-t
b860: 65 72 6d 69 6e 61 74 65 64 20 2a 2f 0a 20 20 69  erminated */.  i
b870: 6e 74 20 6e 4e 61 6d 65 2c 20 20 20 20 20 20 20  nt nName,       
b880: 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 63    /* Number of c
b890: 68 61 72 61 63 74 65 72 73 20 69 6e 20 74 68 65  haracters in the
b8a0: 20 6e 61 6d 65 20 2a 2f 0a 20 20 69 6e 74 20 6e   name */.  int n
b8b0: 41 72 67 2c 20 20 20 20 20 20 20 20 20 20 2f 2a  Arg,          /*
b8c0: 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d   Number of argum
b8d0: 65 6e 74 73 2e 20 20 2d 31 20 6d 65 61 6e 73 20  ents.  -1 means 
b8e0: 61 6e 79 20 6e 75 6d 62 65 72 20 2a 2f 0a 20 20  any number */.  
b8f0: 69 6e 74 20 63 72 65 61 74 65 46 6c 61 67 20 20  int createFlag  
b900: 20 20 20 2f 2a 20 43 72 65 61 74 65 20 6e 65 77     /* Create new
b910: 20 65 6e 74 72 79 20 69 66 20 74 72 75 65 20 61   entry if true a
b920: 6e 64 20 64 6f 65 73 20 6e 6f 74 20 6f 74 68 65  nd does not othe
b930: 72 77 69 73 65 20 65 78 69 73 74 20 2a 2f 0a 29  rwise exist */.)
b940: 7b 0a 20 20 46 75 6e 63 44 65 66 20 2a 70 46 69  {.  FuncDef *pFi
b950: 72 73 74 2c 20 2a 70 2c 20 2a 70 4d 61 79 62 65  rst, *p, *pMaybe
b960: 3b 0a 20 20 70 46 69 72 73 74 20 3d 20 70 20 3d  ;.  pFirst = p =
b970: 20 28 46 75 6e 63 44 65 66 2a 29 73 71 6c 69 74   (FuncDef*)sqlit
b980: 65 48 61 73 68 46 69 6e 64 28 26 64 62 2d 3e 61  eHashFind(&db->a
b990: 46 75 6e 63 2c 20 7a 4e 61 6d 65 2c 20 6e 4e 61  Func, zName, nNa
b9a0: 6d 65 29 3b 0a 20 20 69 66 28 20 70 20 26 26 20  me);.  if( p && 
b9b0: 21 63 72 65 61 74 65 46 6c 61 67 20 26 26 20 6e  !createFlag && n
b9c0: 41 72 67 3c 30 20 29 7b 0a 20 20 20 20 77 68 69  Arg<0 ){.    whi
b9d0: 6c 65 28 20 70 20 26 26 20 70 2d 3e 78 46 75 6e  le( p && p->xFun
b9e0: 63 3d 3d 30 20 26 26 20 70 2d 3e 78 53 74 65 70  c==0 && p->xStep
b9f0: 3d 3d 30 20 29 7b 20 70 20 3d 20 70 2d 3e 70 4e  ==0 ){ p = p->pN
ba00: 65 78 74 3b 20 7d 0a 20 20 20 20 72 65 74 75 72  ext; }.    retur
ba10: 6e 20 70 3b 0a 20 20 7d 0a 20 20 70 4d 61 79 62  n p;.  }.  pMayb
ba20: 65 20 3d 20 30 3b 0a 20 20 77 68 69 6c 65 28 20  e = 0;.  while( 
ba30: 70 20 26 26 20 70 2d 3e 6e 41 72 67 21 3d 6e 41  p && p->nArg!=nA
ba40: 72 67 20 29 7b 0a 20 20 20 20 69 66 28 20 70 2d  rg ){.    if( p-
ba50: 3e 6e 41 72 67 3c 30 20 26 26 20 21 63 72 65 61  >nArg<0 && !crea
ba60: 74 65 46 6c 61 67 20 26 26 20 28 70 2d 3e 78 46  teFlag && (p->xF
ba70: 75 6e 63 20 7c 7c 20 70 2d 3e 78 53 74 65 70 29  unc || p->xStep)
ba80: 20 29 20 70 4d 61 79 62 65 20 3d 20 70 3b 0a 20   ) pMaybe = p;. 
ba90: 20 20 20 70 20 3d 20 70 2d 3e 70 4e 65 78 74 3b     p = p->pNext;
baa0: 0a 20 20 7d 0a 20 20 69 66 28 20 70 20 26 26 20  .  }.  if( p && 
bab0: 21 63 72 65 61 74 65 46 6c 61 67 20 26 26 20 70  !createFlag && p
bac0: 2d 3e 78 46 75 6e 63 3d 3d 30 20 26 26 20 70 2d  ->xFunc==0 && p-
bad0: 3e 78 53 74 65 70 3d 3d 30 20 29 7b 0a 20 20 20  >xStep==0 ){.   
bae0: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20   return 0;.  }. 
baf0: 20 69 66 28 20 70 3d 3d 30 20 26 26 20 70 4d 61   if( p==0 && pMa
bb00: 79 62 65 20 29 7b 0a 20 20 20 20 61 73 73 65 72  ybe ){.    asser
bb10: 74 28 20 63 72 65 61 74 65 46 6c 61 67 3d 3d 30  t( createFlag==0
bb20: 20 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 70   );.    return p
bb30: 4d 61 79 62 65 3b 0a 20 20 7d 0a 20 20 69 66 28  Maybe;.  }.  if(
bb40: 20 70 3d 3d 30 20 26 26 20 63 72 65 61 74 65 46   p==0 && createF
bb50: 6c 61 67 20 26 26 20 28 70 20 3d 20 73 71 6c 69  lag && (p = sqli
bb60: 74 65 4d 61 6c 6c 6f 63 28 73 69 7a 65 6f 66 28  teMalloc(sizeof(
bb70: 2a 70 29 29 29 21 3d 30 20 29 7b 0a 20 20 20 20  *p)))!=0 ){.    
bb80: 70 2d 3e 6e 41 72 67 20 3d 20 6e 41 72 67 3b 0a  p->nArg = nArg;.
bb90: 20 20 20 20 70 2d 3e 70 4e 65 78 74 20 3d 20 70      p->pNext = p
bba0: 46 69 72 73 74 3b 0a 20 20 20 20 70 2d 3e 64 61  First;.    p->da
bbb0: 74 61 54 79 70 65 20 3d 20 70 46 69 72 73 74 20  taType = pFirst 
bbc0: 3f 20 70 46 69 72 73 74 2d 3e 64 61 74 61 54 79  ? pFirst->dataTy
bbd0: 70 65 20 3a 20 53 51 4c 49 54 45 5f 4e 55 4d 45  pe : SQLITE_NUME
bbe0: 52 49 43 3b 0a 20 20 20 20 73 71 6c 69 74 65 48  RIC;.    sqliteH
bbf0: 61 73 68 49 6e 73 65 72 74 28 26 64 62 2d 3e 61  ashInsert(&db->a
bc00: 46 75 6e 63 2c 20 7a 4e 61 6d 65 2c 20 6e 4e 61  Func, zName, nNa
bc10: 6d 65 2c 20 28 76 6f 69 64 2a 29 70 29 3b 0a 20  me, (void*)p);. 
bc20: 20 7d 0a 20 20 72 65 74 75 72 6e 20 70 3b 0a 7d   }.  return p;.}
bc30: 0a                                               .