/ Hex Artifact Content
Login

Artifact 3d7f529e00d621953af155d2bc64511710619745:


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 53 51 4c  ile contains SQL
0190: 69 74 65 27 73 20 67 72 61 6d 6d 61 72 20 66 6f  ite's grammar fo
01a0: 72 20 53 51 4c 2e 20 20 50 72 6f 63 65 73 73 20  r SQL.  Process 
01b0: 74 68 69 73 20 66 69 6c 65 0a 2a 2a 20 75 73 69  this file.** usi
01c0: 6e 67 20 74 68 65 20 6c 65 6d 6f 6e 20 70 61 72  ng the lemon par
01d0: 73 65 72 20 67 65 6e 65 72 61 74 6f 72 20 74 6f  ser generator to
01e0: 20 67 65 6e 65 72 61 74 65 20 43 20 63 6f 64 65   generate C code
01f0: 20 74 68 61 74 20 72 75 6e 73 0a 2a 2a 20 74 68   that runs.** th
0200: 65 20 70 61 72 73 65 72 2e 20 20 4c 65 6d 6f 6e  e parser.  Lemon
0210: 20 77 69 6c 6c 20 61 6c 73 6f 20 67 65 6e 65 72   will also gener
0220: 61 74 65 20 61 20 68 65 61 64 65 72 20 66 69 6c  ate a header fil
0230: 65 20 63 6f 6e 74 61 69 6e 69 6e 67 0a 2a 2a 20  e containing.** 
0240: 6e 75 6d 65 72 69 63 20 63 6f 64 65 73 20 66 6f  numeric codes fo
0250: 72 20 61 6c 6c 20 6f 66 20 74 68 65 20 74 6f 6b  r all of the tok
0260: 65 6e 73 2e 0a 2a 2f 0a 0a 2f 2f 20 41 6c 6c 20  ens..*/..// All 
0270: 74 6f 6b 65 6e 20 63 6f 64 65 73 20 61 72 65 20  token codes are 
0280: 73 6d 61 6c 6c 20 69 6e 74 65 67 65 72 73 20 77  small integers w
0290: 69 74 68 20 23 64 65 66 69 6e 65 73 20 74 68 61  ith #defines tha
02a0: 74 20 62 65 67 69 6e 20 77 69 74 68 20 22 54 4b  t begin with "TK
02b0: 5f 22 0a 25 74 6f 6b 65 6e 5f 70 72 65 66 69 78  _".%token_prefix
02c0: 20 54 4b 5f 0a 0a 2f 2f 20 54 68 65 20 74 79 70   TK_..// The typ
02d0: 65 20 6f 66 20 74 68 65 20 64 61 74 61 20 61 74  e of the data at
02e0: 74 61 63 68 65 64 20 74 6f 20 65 61 63 68 20 74  tached to each t
02f0: 6f 6b 65 6e 20 69 73 20 54 6f 6b 65 6e 2e 20 20  oken is Token.  
0300: 54 68 69 73 20 69 73 20 61 6c 73 6f 20 74 68 65  This is also the
0310: 0a 2f 2f 20 64 65 66 61 75 6c 74 20 74 79 70 65  .// default type
0320: 20 66 6f 72 20 6e 6f 6e 2d 74 65 72 6d 69 6e 61   for non-termina
0330: 6c 73 2e 0a 2f 2f 0a 25 74 6f 6b 65 6e 5f 74 79  ls..//.%token_ty
0340: 70 65 20 7b 54 6f 6b 65 6e 7d 0a 25 64 65 66 61  pe {Token}.%defa
0350: 75 6c 74 5f 74 79 70 65 20 7b 54 6f 6b 65 6e 7d  ult_type {Token}
0360: 0a 0a 2f 2f 20 54 68 65 20 67 65 6e 65 72 61 74  ..// The generat
0370: 65 64 20 70 61 72 73 65 72 20 66 75 6e 63 74 69  ed parser functi
0380: 6f 6e 20 74 61 6b 65 73 20 61 20 34 74 68 20 61  on takes a 4th a
0390: 72 67 75 6d 65 6e 74 20 61 73 20 66 6f 6c 6c 6f  rgument as follo
03a0: 77 73 3a 0a 25 65 78 74 72 61 5f 61 72 67 75 6d  ws:.%extra_argum
03b0: 65 6e 74 20 7b 50 61 72 73 65 20 2a 70 50 61 72  ent {Parse *pPar
03c0: 73 65 7d 0a 0a 2f 2f 20 54 68 69 73 20 63 6f 64  se}..// This cod
03d0: 65 20 72 75 6e 73 20 77 68 65 6e 65 76 65 72 20  e runs whenever 
03e0: 74 68 65 72 65 20 69 73 20 61 20 73 79 6e 74 61  there is a synta
03f0: 78 20 65 72 72 6f 72 0a 2f 2f 0a 25 73 79 6e 74  x error.//.%synt
0400: 61 78 5f 65 72 72 6f 72 20 7b 0a 20 20 55 4e 55  ax_error {.  UNU
0410: 53 45 44 5f 50 41 52 41 4d 45 54 45 52 28 79 79  SED_PARAMETER(yy
0420: 6d 61 6a 6f 72 29 3b 20 20 2f 2a 20 53 69 6c 65  major);  /* Sile
0430: 6e 63 65 20 73 6f 6d 65 20 63 6f 6d 70 69 6c 65  nce some compile
0440: 72 20 77 61 72 6e 69 6e 67 73 20 2a 2f 0a 20 20  r warnings */.  
0450: 61 73 73 65 72 74 28 20 54 4f 4b 45 4e 2e 7a 5b  assert( TOKEN.z[
0460: 30 5d 20 29 3b 20 20 2f 2a 20 54 68 65 20 74 6f  0] );  /* The to
0470: 6b 65 6e 69 7a 65 72 20 61 6c 77 61 79 73 20 67  kenizer always g
0480: 69 76 65 73 20 75 73 20 61 20 74 6f 6b 65 6e 20  ives us a token 
0490: 2a 2f 0a 20 20 73 71 6c 69 74 65 33 45 72 72 6f  */.  sqlite3Erro
04a0: 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 6e 65  rMsg(pParse, "ne
04b0: 61 72 20 5c 22 25 54 5c 22 3a 20 73 79 6e 74 61  ar \"%T\": synta
04c0: 78 20 65 72 72 6f 72 22 2c 20 26 54 4f 4b 45 4e  x error", &TOKEN
04d0: 29 3b 0a 20 20 70 50 61 72 73 65 2d 3e 70 61 72  );.  pParse->par
04e0: 73 65 45 72 72 6f 72 20 3d 20 31 3b 0a 7d 0a 25  seError = 1;.}.%
04f0: 73 74 61 63 6b 5f 6f 76 65 72 66 6c 6f 77 20 7b  stack_overflow {
0500: 0a 20 20 55 4e 55 53 45 44 5f 50 41 52 41 4d 45  .  UNUSED_PARAME
0510: 54 45 52 28 79 79 70 4d 69 6e 6f 72 29 3b 20 2f  TER(yypMinor); /
0520: 2a 20 53 69 6c 65 6e 63 65 20 73 6f 6d 65 20 63  * Silence some c
0530: 6f 6d 70 69 6c 65 72 20 77 61 72 6e 69 6e 67 73  ompiler warnings
0540: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 45 72 72   */.  sqlite3Err
0550: 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 70  orMsg(pParse, "p
0560: 61 72 73 65 72 20 73 74 61 63 6b 20 6f 76 65 72  arser stack over
0570: 66 6c 6f 77 22 29 3b 0a 20 20 70 50 61 72 73 65  flow");.  pParse
0580: 2d 3e 70 61 72 73 65 45 72 72 6f 72 20 3d 20 31  ->parseError = 1
0590: 3b 0a 7d 0a 0a 2f 2f 20 54 68 65 20 6e 61 6d 65  ;.}..// The name
05a0: 20 6f 66 20 74 68 65 20 67 65 6e 65 72 61 74 65   of the generate
05b0: 64 20 70 72 6f 63 65 64 75 72 65 20 74 68 61 74  d procedure that
05c0: 20 69 6d 70 6c 65 6d 65 6e 74 73 20 74 68 65 20   implements the 
05d0: 70 61 72 73 65 72 0a 2f 2f 20 69 73 20 61 73 20  parser.// is as 
05e0: 66 6f 6c 6c 6f 77 73 3a 0a 25 6e 61 6d 65 20 73  follows:.%name s
05f0: 71 6c 69 74 65 33 50 61 72 73 65 72 0a 0a 2f 2f  qlite3Parser..//
0600: 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74   The following t
0610: 65 78 74 20 69 73 20 69 6e 63 6c 75 64 65 64 20  ext is included 
0620: 6e 65 61 72 20 74 68 65 20 62 65 67 69 6e 6e 69  near the beginni
0630: 6e 67 20 6f 66 20 74 68 65 20 43 20 73 6f 75 72  ng of the C sour
0640: 63 65 0a 2f 2f 20 63 6f 64 65 20 66 69 6c 65 20  ce.// code file 
0650: 74 68 61 74 20 69 6d 70 6c 65 6d 65 6e 74 73 20  that implements 
0660: 74 68 65 20 70 61 72 73 65 72 2e 0a 2f 2f 0a 25  the parser..//.%
0670: 69 6e 63 6c 75 64 65 20 7b 0a 23 69 6e 63 6c 75  include {.#inclu
0680: 64 65 20 22 73 71 6c 69 74 65 49 6e 74 2e 68 22  de "sqliteInt.h"
0690: 0a 0a 2f 2a 0a 2a 2a 20 44 69 73 61 62 6c 65 20  ../*.** Disable 
06a0: 61 6c 6c 20 65 72 72 6f 72 20 72 65 63 6f 76 65  all error recove
06b0: 72 79 20 70 72 6f 63 65 73 73 69 6e 67 20 69 6e  ry processing in
06c0: 20 74 68 65 20 70 61 72 73 65 72 20 70 75 73 68   the parser push
06d0: 2d 64 6f 77 6e 0a 2a 2a 20 61 75 74 6f 6d 61 74  -down.** automat
06e0: 6f 6e 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 59  on..*/.#define Y
06f0: 59 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59  YNOERRORRECOVERY
0700: 20 31 0a 0a 2f 2a 0a 2a 2a 20 4d 61 6b 65 20 79   1../*.** Make y
0710: 79 74 65 73 74 63 61 73 65 28 29 20 74 68 65 20  ytestcase() the 
0720: 73 61 6d 65 20 61 73 20 74 65 73 74 63 61 73 65  same as testcase
0730: 28 29 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 79 79  ().*/.#define yy
0740: 74 65 73 74 63 61 73 65 28 58 29 20 74 65 73 74  testcase(X) test
0750: 63 61 73 65 28 58 29 0a 0a 2f 2a 0a 2a 2a 20 41  case(X)../*.** A
0760: 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66 20 74 68  n instance of th
0770: 69 73 20 73 74 72 75 63 74 75 72 65 20 68 6f 6c  is structure hol
0780: 64 73 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 61  ds information a
0790: 62 6f 75 74 20 74 68 65 0a 2a 2a 20 4c 49 4d 49  bout the.** LIMI
07a0: 54 20 63 6c 61 75 73 65 20 6f 66 20 61 20 53 45  T clause of a SE
07b0: 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 2e 0a  LECT statement..
07c0: 2a 2f 0a 73 74 72 75 63 74 20 4c 69 6d 69 74 56  */.struct LimitV
07d0: 61 6c 20 7b 0a 20 20 45 78 70 72 20 2a 70 4c 69  al {.  Expr *pLi
07e0: 6d 69 74 3b 20 20 20 20 2f 2a 20 54 68 65 20 4c  mit;    /* The L
07f0: 49 4d 49 54 20 65 78 70 72 65 73 73 69 6f 6e 2e  IMIT expression.
0800: 20 20 4e 55 4c 4c 20 69 66 20 74 68 65 72 65 20    NULL if there 
0810: 69 73 20 6e 6f 20 6c 69 6d 69 74 20 2a 2f 0a 20  is no limit */. 
0820: 20 45 78 70 72 20 2a 70 4f 66 66 73 65 74 3b 20   Expr *pOffset; 
0830: 20 20 2f 2a 20 54 68 65 20 4f 46 46 53 45 54 20    /* The OFFSET 
0840: 65 78 70 72 65 73 73 69 6f 6e 2e 20 20 4e 55 4c  expression.  NUL
0850: 4c 20 69 66 20 74 68 65 72 65 20 69 73 20 6e 6f  L if there is no
0860: 6e 65 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  ne */.};../*.** 
0870: 41 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66 20 74  An instance of t
0880: 68 69 73 20 73 74 72 75 63 74 75 72 65 20 69 73  his structure is
0890: 20 75 73 65 64 20 74 6f 20 73 74 6f 72 65 20 74   used to store t
08a0: 68 65 20 4c 49 4b 45 2c 0a 2a 2a 20 47 4c 4f 42  he LIKE,.** GLOB
08b0: 2c 20 4e 4f 54 20 4c 49 4b 45 2c 20 61 6e 64 20  , NOT LIKE, and 
08c0: 4e 4f 54 20 47 4c 4f 42 20 6f 70 65 72 61 74 6f  NOT GLOB operato
08d0: 72 73 2e 0a 2a 2f 0a 73 74 72 75 63 74 20 4c 69  rs..*/.struct Li
08e0: 6b 65 4f 70 20 7b 0a 20 20 54 6f 6b 65 6e 20 65  keOp {.  Token e
08f0: 4f 70 65 72 61 74 6f 72 3b 20 20 2f 2a 20 22 6c  Operator;  /* "l
0900: 69 6b 65 22 20 6f 72 20 22 67 6c 6f 62 22 20 6f  ike" or "glob" o
0910: 72 20 22 72 65 67 65 78 70 22 20 2a 2f 0a 20 20  r "regexp" */.  
0920: 69 6e 74 20 6e 6f 74 3b 20 20 20 20 20 20 20 20  int not;        
0930: 20 2f 2a 20 54 72 75 65 20 69 66 20 74 68 65 20   /* True if the 
0940: 4e 4f 54 20 6b 65 79 77 6f 72 64 20 69 73 20 70  NOT keyword is p
0950: 72 65 73 65 6e 74 20 2a 2f 0a 7d 3b 0a 0a 2f 2a  resent */.};../*
0960: 0a 2a 2a 20 41 6e 20 69 6e 73 74 61 6e 63 65 20  .** An instance 
0970: 6f 66 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  of the following
0980: 20 73 74 72 75 63 74 75 72 65 20 64 65 73 63 72   structure descr
0990: 69 62 65 73 20 74 68 65 20 65 76 65 6e 74 20 6f  ibes the event o
09a0: 66 20 61 0a 2a 2a 20 54 52 49 47 47 45 52 2e 20  f a.** TRIGGER. 
09b0: 20 22 61 22 20 69 73 20 74 68 65 20 65 76 65 6e   "a" is the even
09c0: 74 20 74 79 70 65 2c 20 6f 6e 65 20 6f 66 20 54  t type, one of T
09d0: 4b 5f 55 50 44 41 54 45 2c 20 54 4b 5f 49 4e 53  K_UPDATE, TK_INS
09e0: 45 52 54 2c 0a 2a 2a 20 54 4b 5f 44 45 4c 45 54  ERT,.** TK_DELET
09f0: 45 2c 20 6f 72 20 54 4b 5f 49 4e 53 54 45 41 44  E, or TK_INSTEAD
0a00: 2e 20 20 49 66 20 74 68 65 20 65 76 65 6e 74 20  .  If the event 
0a10: 69 73 20 6f 66 20 74 68 65 20 66 6f 72 6d 0a 2a  is of the form.*
0a20: 2a 0a 2a 2a 20 20 20 20 20 20 55 50 44 41 54 45  *.**      UPDATE
0a30: 20 4f 4e 20 28 61 2c 62 2c 63 29 0a 2a 2a 0a 2a   ON (a,b,c).**.*
0a40: 2a 20 54 68 65 6e 20 74 68 65 20 22 62 22 20 49  * Then the "b" I
0a50: 64 4c 69 73 74 20 72 65 63 6f 72 64 73 20 74 68  dList records th
0a60: 65 20 6c 69 73 74 20 22 61 2c 62 2c 63 22 2e 0a  e list "a,b,c"..
0a70: 2a 2f 0a 73 74 72 75 63 74 20 54 72 69 67 45 76  */.struct TrigEv
0a80: 65 6e 74 20 7b 20 69 6e 74 20 61 3b 20 49 64 4c  ent { int a; IdL
0a90: 69 73 74 20 2a 20 62 3b 20 7d 3b 0a 0a 2f 2a 0a  ist * b; };../*.
0aa0: 2a 2a 20 41 6e 20 69 6e 73 74 61 6e 63 65 20 6f  ** An instance o
0ab0: 66 20 74 68 69 73 20 73 74 72 75 63 74 75 72 65  f this structure
0ac0: 20 68 6f 6c 64 73 20 74 68 65 20 41 54 54 41 43   holds the ATTAC
0ad0: 48 20 6b 65 79 20 61 6e 64 20 74 68 65 20 6b 65  H key and the ke
0ae0: 79 20 74 79 70 65 2e 0a 2a 2f 0a 73 74 72 75 63  y type..*/.struc
0af0: 74 20 41 74 74 61 63 68 4b 65 79 20 7b 20 69 6e  t AttachKey { in
0b00: 74 20 74 79 70 65 3b 20 20 54 6f 6b 65 6e 20 6b  t type;  Token k
0b10: 65 79 3b 20 7d 3b 0a 0a 7d 20 2f 2f 20 65 6e 64  ey; };..} // end
0b20: 20 25 69 6e 63 6c 75 64 65 0a 0a 2f 2f 20 49 6e   %include..// In
0b30: 70 75 74 20 69 73 20 61 20 73 69 6e 67 6c 65 20  put is a single 
0b40: 53 51 4c 20 63 6f 6d 6d 61 6e 64 0a 69 6e 70 75  SQL command.inpu
0b50: 74 20 3a 3a 3d 20 63 6d 64 6c 69 73 74 2e 0a 63  t ::= cmdlist..c
0b60: 6d 64 6c 69 73 74 20 3a 3a 3d 20 63 6d 64 6c 69  mdlist ::= cmdli
0b70: 73 74 20 65 63 6d 64 2e 0a 63 6d 64 6c 69 73 74  st ecmd..cmdlist
0b80: 20 3a 3a 3d 20 65 63 6d 64 2e 0a 65 63 6d 64 20   ::= ecmd..ecmd 
0b90: 3a 3a 3d 20 53 45 4d 49 2e 0a 65 63 6d 64 20 3a  ::= SEMI..ecmd :
0ba0: 3a 3d 20 65 78 70 6c 61 69 6e 20 63 6d 64 78 20  := explain cmdx 
0bb0: 53 45 4d 49 2e 0a 65 78 70 6c 61 69 6e 20 3a 3a  SEMI..explain ::
0bc0: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 7b 20  = .           { 
0bd0: 73 71 6c 69 74 65 33 42 65 67 69 6e 50 61 72 73  sqlite3BeginPars
0be0: 65 28 70 50 61 72 73 65 2c 20 30 29 3b 20 7d 0a  e(pParse, 0); }.
0bf0: 25 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  %ifndef SQLITE_O
0c00: 4d 49 54 5f 45 58 50 4c 41 49 4e 0a 65 78 70 6c  MIT_EXPLAIN.expl
0c10: 61 69 6e 20 3a 3a 3d 20 45 58 50 4c 41 49 4e 2e  ain ::= EXPLAIN.
0c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20                { 
0c30: 73 71 6c 69 74 65 33 42 65 67 69 6e 50 61 72 73  sqlite3BeginPars
0c40: 65 28 70 50 61 72 73 65 2c 20 31 29 3b 20 7d 0a  e(pParse, 1); }.
0c50: 65 78 70 6c 61 69 6e 20 3a 3a 3d 20 45 58 50 4c  explain ::= EXPL
0c60: 41 49 4e 20 51 55 45 52 59 20 50 4c 41 4e 2e 20  AIN QUERY PLAN. 
0c70: 20 20 7b 20 73 71 6c 69 74 65 33 42 65 67 69 6e    { sqlite3Begin
0c80: 50 61 72 73 65 28 70 50 61 72 73 65 2c 20 32 29  Parse(pParse, 2)
0c90: 3b 20 7d 0a 25 65 6e 64 69 66 20 20 53 51 4c 49  ; }.%endif  SQLI
0ca0: 54 45 5f 4f 4d 49 54 5f 45 58 50 4c 41 49 4e 0a  TE_OMIT_EXPLAIN.
0cb0: 63 6d 64 78 20 3a 3a 3d 20 63 6d 64 2e 20 20 20  cmdx ::= cmd.   
0cc0: 20 20 20 20 20 20 20 20 7b 20 73 71 6c 69 74 65          { sqlite
0cd0: 33 46 69 6e 69 73 68 43 6f 64 69 6e 67 28 70 50  3FinishCoding(pP
0ce0: 61 72 73 65 29 3b 20 7d 0a 0a 2f 2f 2f 2f 2f 2f  arse); }..//////
0cf0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20  /////////////// 
0d00: 42 65 67 69 6e 20 61 6e 64 20 65 6e 64 20 74 72  Begin and end tr
0d10: 61 6e 73 61 63 74 69 6f 6e 73 2e 20 2f 2f 2f 2f  ansactions. ////
0d20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0d30: 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 0a 63 6d 64  ////////.//..cmd
0d40: 20 3a 3a 3d 20 42 45 47 49 4e 20 74 72 61 6e 73   ::= BEGIN trans
0d50: 74 79 70 65 28 59 29 20 74 72 61 6e 73 5f 6f 70  type(Y) trans_op
0d60: 74 2e 20 20 7b 73 71 6c 69 74 65 33 42 65 67 69  t.  {sqlite3Begi
0d70: 6e 54 72 61 6e 73 61 63 74 69 6f 6e 28 70 50 61  nTransaction(pPa
0d80: 72 73 65 2c 20 59 29 3b 7d 0a 74 72 61 6e 73 5f  rse, Y);}.trans_
0d90: 6f 70 74 20 3a 3a 3d 20 2e 0a 74 72 61 6e 73 5f  opt ::= ..trans_
0da0: 6f 70 74 20 3a 3a 3d 20 54 52 41 4e 53 41 43 54  opt ::= TRANSACT
0db0: 49 4f 4e 2e 0a 74 72 61 6e 73 5f 6f 70 74 20 3a  ION..trans_opt :
0dc0: 3a 3d 20 54 52 41 4e 53 41 43 54 49 4f 4e 20 6e  := TRANSACTION n
0dd0: 6d 2e 0a 25 74 79 70 65 20 74 72 61 6e 73 74 79  m..%type transty
0de0: 70 65 20 7b 69 6e 74 7d 0a 74 72 61 6e 73 74 79  pe {int}.transty
0df0: 70 65 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20  pe(A) ::= .     
0e00: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 54 4b 5f          {A = TK_
0e10: 44 45 46 45 52 52 45 44 3b 7d 0a 74 72 61 6e 73  DEFERRED;}.trans
0e20: 74 79 70 65 28 41 29 20 3a 3a 3d 20 44 45 46 45  type(A) ::= DEFE
0e30: 52 52 45 44 28 58 29 2e 20 20 7b 41 20 3d 20 40  RRED(X).  {A = @
0e40: 58 3b 7d 0a 74 72 61 6e 73 74 79 70 65 28 41 29  X;}.transtype(A)
0e50: 20 3a 3a 3d 20 49 4d 4d 45 44 49 41 54 45 28 58   ::= IMMEDIATE(X
0e60: 29 2e 20 7b 41 20 3d 20 40 58 3b 7d 0a 74 72 61  ). {A = @X;}.tra
0e70: 6e 73 74 79 70 65 28 41 29 20 3a 3a 3d 20 45 58  nstype(A) ::= EX
0e80: 43 4c 55 53 49 56 45 28 58 29 2e 20 7b 41 20 3d  CLUSIVE(X). {A =
0e90: 20 40 58 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 43 4f   @X;}.cmd ::= CO
0ea0: 4d 4d 49 54 20 74 72 61 6e 73 5f 6f 70 74 2e 20  MMIT trans_opt. 
0eb0: 20 20 20 20 20 7b 73 71 6c 69 74 65 33 43 6f 6d       {sqlite3Com
0ec0: 6d 69 74 54 72 61 6e 73 61 63 74 69 6f 6e 28 70  mitTransaction(p
0ed0: 50 61 72 73 65 29 3b 7d 0a 63 6d 64 20 3a 3a 3d  Parse);}.cmd ::=
0ee0: 20 45 4e 44 20 74 72 61 6e 73 5f 6f 70 74 2e 20   END trans_opt. 
0ef0: 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33          {sqlite3
0f00: 43 6f 6d 6d 69 74 54 72 61 6e 73 61 63 74 69 6f  CommitTransactio
0f10: 6e 28 70 50 61 72 73 65 29 3b 7d 0a 63 6d 64 20  n(pParse);}.cmd 
0f20: 3a 3a 3d 20 52 4f 4c 4c 42 41 43 4b 20 74 72 61  ::= ROLLBACK tra
0f30: 6e 73 5f 6f 70 74 2e 20 20 20 20 7b 73 71 6c 69  ns_opt.    {sqli
0f40: 74 65 33 52 6f 6c 6c 62 61 63 6b 54 72 61 6e 73  te3RollbackTrans
0f50: 61 63 74 69 6f 6e 28 70 50 61 72 73 65 29 3b 7d  action(pParse);}
0f60: 0a 0a 73 61 76 65 70 6f 69 6e 74 5f 6f 70 74 20  ..savepoint_opt 
0f70: 3a 3a 3d 20 53 41 56 45 50 4f 49 4e 54 2e 0a 73  ::= SAVEPOINT..s
0f80: 61 76 65 70 6f 69 6e 74 5f 6f 70 74 20 3a 3a 3d  avepoint_opt ::=
0f90: 20 2e 0a 63 6d 64 20 3a 3a 3d 20 53 41 56 45 50   ..cmd ::= SAVEP
0fa0: 4f 49 4e 54 20 6e 6d 28 58 29 2e 20 7b 0a 20 20  OINT nm(X). {.  
0fb0: 73 71 6c 69 74 65 33 53 61 76 65 70 6f 69 6e 74  sqlite3Savepoint
0fc0: 28 70 50 61 72 73 65 2c 20 53 41 56 45 50 4f 49  (pParse, SAVEPOI
0fd0: 4e 54 5f 42 45 47 49 4e 2c 20 26 58 29 3b 0a 7d  NT_BEGIN, &X);.}
0fe0: 0a 63 6d 64 20 3a 3a 3d 20 52 45 4c 45 41 53 45  .cmd ::= RELEASE
0ff0: 20 73 61 76 65 70 6f 69 6e 74 5f 6f 70 74 20 6e   savepoint_opt n
1000: 6d 28 58 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65  m(X). {.  sqlite
1010: 33 53 61 76 65 70 6f 69 6e 74 28 70 50 61 72 73  3Savepoint(pPars
1020: 65 2c 20 53 41 56 45 50 4f 49 4e 54 5f 52 45 4c  e, SAVEPOINT_REL
1030: 45 41 53 45 2c 20 26 58 29 3b 0a 7d 0a 63 6d 64  EASE, &X);.}.cmd
1040: 20 3a 3a 3d 20 52 4f 4c 4c 42 41 43 4b 20 74 72   ::= ROLLBACK tr
1050: 61 6e 73 5f 6f 70 74 20 54 4f 20 73 61 76 65 70  ans_opt TO savep
1060: 6f 69 6e 74 5f 6f 70 74 20 6e 6d 28 58 29 2e 20  oint_opt nm(X). 
1070: 7b 0a 20 20 73 71 6c 69 74 65 33 53 61 76 65 70  {.  sqlite3Savep
1080: 6f 69 6e 74 28 70 50 61 72 73 65 2c 20 53 41 56  oint(pParse, SAV
1090: 45 50 4f 49 4e 54 5f 52 4f 4c 4c 42 41 43 4b 2c  EPOINT_ROLLBACK,
10a0: 20 26 58 29 3b 0a 7d 0a 0a 2f 2f 2f 2f 2f 2f 2f   &X);.}..///////
10b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54  ////////////// T
10c0: 68 65 20 43 52 45 41 54 45 20 54 41 42 4c 45 20  he CREATE TABLE 
10d0: 73 74 61 74 65 6d 65 6e 74 20 2f 2f 2f 2f 2f 2f  statement //////
10e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
10f0: 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a 3a  //////.//.cmd ::
1100: 3d 20 63 72 65 61 74 65 5f 74 61 62 6c 65 20 63  = create_table c
1110: 72 65 61 74 65 5f 74 61 62 6c 65 5f 61 72 67 73  reate_table_args
1120: 2e 0a 63 72 65 61 74 65 5f 74 61 62 6c 65 20 3a  ..create_table :
1130: 3a 3d 20 63 72 65 61 74 65 6b 77 20 74 65 6d 70  := createkw temp
1140: 28 54 29 20 54 41 42 4c 45 20 69 66 6e 6f 74 65  (T) TABLE ifnote
1150: 78 69 73 74 73 28 45 29 20 6e 6d 28 59 29 20 64  xists(E) nm(Y) d
1160: 62 6e 6d 28 5a 29 2e 20 7b 0a 20 20 20 73 71 6c  bnm(Z). {.   sql
1170: 69 74 65 33 53 74 61 72 74 54 61 62 6c 65 28 70  ite3StartTable(p
1180: 50 61 72 73 65 2c 26 59 2c 26 5a 2c 54 2c 30 2c  Parse,&Y,&Z,T,0,
1190: 30 2c 45 29 3b 0a 7d 0a 63 72 65 61 74 65 6b 77  0,E);.}.createkw
11a0: 28 41 29 20 3a 3a 3d 20 43 52 45 41 54 45 28 58  (A) ::= CREATE(X
11b0: 29 2e 20 20 7b 0a 20 20 70 50 61 72 73 65 2d 3e  ).  {.  pParse->
11c0: 64 62 2d 3e 6c 6f 6f 6b 61 73 69 64 65 2e 62 45  db->lookaside.bE
11d0: 6e 61 62 6c 65 64 20 3d 20 30 3b 0a 20 20 41 20  nabled = 0;.  A 
11e0: 3d 20 58 3b 0a 7d 0a 25 74 79 70 65 20 69 66 6e  = X;.}.%type ifn
11f0: 6f 74 65 78 69 73 74 73 20 7b 69 6e 74 7d 0a 69  otexists {int}.i
1200: 66 6e 6f 74 65 78 69 73 74 73 28 41 29 20 3a 3a  fnotexists(A) ::
1210: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  = .             
1220: 20 7b 41 20 3d 20 30 3b 7d 0a 69 66 6e 6f 74 65   {A = 0;}.ifnote
1230: 78 69 73 74 73 28 41 29 20 3a 3a 3d 20 49 46 20  xists(A) ::= IF 
1240: 4e 4f 54 20 45 58 49 53 54 53 2e 20 7b 41 20 3d  NOT EXISTS. {A =
1250: 20 31 3b 7d 0a 25 74 79 70 65 20 74 65 6d 70 20   1;}.%type temp 
1260: 7b 69 6e 74 7d 0a 25 69 66 6e 64 65 66 20 53 51  {int}.%ifndef SQ
1270: 4c 49 54 45 5f 4f 4d 49 54 5f 54 45 4d 50 44 42  LITE_OMIT_TEMPDB
1280: 0a 74 65 6d 70 28 41 29 20 3a 3a 3d 20 54 45 4d  .temp(A) ::= TEM
1290: 50 2e 20 20 7b 41 20 3d 20 31 3b 7d 0a 25 65 6e  P.  {A = 1;}.%en
12a0: 64 69 66 20 20 53 51 4c 49 54 45 5f 4f 4d 49 54  dif  SQLITE_OMIT
12b0: 5f 54 45 4d 50 44 42 0a 74 65 6d 70 28 41 29 20  _TEMPDB.temp(A) 
12c0: 3a 3a 3d 20 2e 20 20 20 20 20 20 7b 41 20 3d 20  ::= .      {A = 
12d0: 30 3b 7d 0a 63 72 65 61 74 65 5f 74 61 62 6c 65  0;}.create_table
12e0: 5f 61 72 67 73 20 3a 3a 3d 20 4c 50 20 63 6f 6c  _args ::= LP col
12f0: 75 6d 6e 6c 69 73 74 20 63 6f 6e 73 6c 69 73 74  umnlist conslist
1300: 5f 6f 70 74 28 58 29 20 52 50 28 59 29 2e 20 7b  _opt(X) RP(Y). {
1310: 0a 20 20 73 71 6c 69 74 65 33 45 6e 64 54 61 62  .  sqlite3EndTab
1320: 6c 65 28 70 50 61 72 73 65 2c 26 58 2c 26 59 2c  le(pParse,&X,&Y,
1330: 30 29 3b 0a 7d 0a 63 72 65 61 74 65 5f 74 61 62  0);.}.create_tab
1340: 6c 65 5f 61 72 67 73 20 3a 3a 3d 20 41 53 20 73  le_args ::= AS s
1350: 65 6c 65 63 74 28 53 29 2e 20 7b 0a 20 20 73 71  elect(S). {.  sq
1360: 6c 69 74 65 33 45 6e 64 54 61 62 6c 65 28 70 50  lite3EndTable(pP
1370: 61 72 73 65 2c 30 2c 30 2c 53 29 3b 0a 20 20 73  arse,0,0,S);.  s
1380: 71 6c 69 74 65 33 53 65 6c 65 63 74 44 65 6c 65  qlite3SelectDele
1390: 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 53  te(pParse->db, S
13a0: 29 3b 0a 7d 0a 63 6f 6c 75 6d 6e 6c 69 73 74 20  );.}.columnlist 
13b0: 3a 3a 3d 20 63 6f 6c 75 6d 6e 6c 69 73 74 20 43  ::= columnlist C
13c0: 4f 4d 4d 41 20 63 6f 6c 75 6d 6e 2e 0a 63 6f 6c  OMMA column..col
13d0: 75 6d 6e 6c 69 73 74 20 3a 3a 3d 20 63 6f 6c 75  umnlist ::= colu
13e0: 6d 6e 2e 0a 0a 2f 2f 20 41 20 22 63 6f 6c 75 6d  mn...// A "colum
13f0: 6e 22 20 69 73 20 61 20 63 6f 6d 70 6c 65 74 65  n" is a complete
1400: 20 64 65 73 63 72 69 70 74 69 6f 6e 20 6f 66 20   description of 
1410: 61 20 73 69 6e 67 6c 65 20 63 6f 6c 75 6d 6e 20  a single column 
1420: 69 6e 20 61 0a 2f 2f 20 43 52 45 41 54 45 20 54  in a.// CREATE T
1430: 41 42 4c 45 20 73 74 61 74 65 6d 65 6e 74 2e 20  ABLE statement. 
1440: 20 54 68 69 73 20 69 6e 63 6c 75 64 65 73 20 74   This includes t
1450: 68 65 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 2c 20  he column name, 
1460: 69 74 73 0a 2f 2f 20 64 61 74 61 74 79 70 65 2c  its.// datatype,
1470: 20 61 6e 64 20 6f 74 68 65 72 20 6b 65 79 77 6f   and other keywo
1480: 72 64 73 20 73 75 63 68 20 61 73 20 50 52 49 4d  rds such as PRIM
1490: 41 52 59 20 4b 45 59 2c 20 55 4e 49 51 55 45 2c  ARY KEY, UNIQUE,
14a0: 20 52 45 46 45 52 45 4e 43 45 53 2c 0a 2f 2f 20   REFERENCES,.// 
14b0: 4e 4f 54 20 4e 55 4c 4c 20 61 6e 64 20 73 6f 20  NOT NULL and so 
14c0: 66 6f 72 74 68 2e 0a 2f 2f 0a 63 6f 6c 75 6d 6e  forth..//.column
14d0: 28 41 29 20 3a 3a 3d 20 63 6f 6c 75 6d 6e 69 64  (A) ::= columnid
14e0: 28 58 29 20 74 79 70 65 20 63 61 72 67 6c 69 73  (X) type carglis
14f0: 74 2e 20 7b 0a 20 20 41 2e 7a 20 3d 20 58 2e 7a  t. {.  A.z = X.z
1500: 3b 0a 20 20 41 2e 6e 20 3d 20 28 69 6e 74 29 28  ;.  A.n = (int)(
1510: 70 50 61 72 73 65 2d 3e 73 4c 61 73 74 54 6f 6b  pParse->sLastTok
1520: 65 6e 2e 7a 2d 58 2e 7a 29 20 2b 20 70 50 61 72  en.z-X.z) + pPar
1530: 73 65 2d 3e 73 4c 61 73 74 54 6f 6b 65 6e 2e 6e  se->sLastToken.n
1540: 3b 0a 7d 0a 63 6f 6c 75 6d 6e 69 64 28 41 29 20  ;.}.columnid(A) 
1550: 3a 3a 3d 20 6e 6d 28 58 29 2e 20 7b 0a 20 20 73  ::= nm(X). {.  s
1560: 71 6c 69 74 65 33 41 64 64 43 6f 6c 75 6d 6e 28  qlite3AddColumn(
1570: 70 50 61 72 73 65 2c 26 58 29 3b 0a 20 20 41 20  pParse,&X);.  A 
1580: 3d 20 58 3b 0a 7d 0a 0a 0a 2f 2f 20 41 6e 20 49  = X;.}...// An I
1590: 44 45 4e 54 49 46 49 45 52 20 63 61 6e 20 62 65  DENTIFIER can be
15a0: 20 61 20 67 65 6e 65 72 69 63 20 69 64 65 6e 74   a generic ident
15b0: 69 66 69 65 72 2c 20 6f 72 20 6f 6e 65 20 6f 66  ifier, or one of
15c0: 20 73 65 76 65 72 61 6c 0a 2f 2f 20 6b 65 79 77   several.// keyw
15d0: 6f 72 64 73 2e 20 20 41 6e 79 20 6e 6f 6e 2d 73  ords.  Any non-s
15e0: 74 61 6e 64 61 72 64 20 6b 65 79 77 6f 72 64 20  tandard keyword 
15f0: 63 61 6e 20 61 6c 73 6f 20 62 65 20 61 6e 20 69  can also be an i
1600: 64 65 6e 74 69 66 69 65 72 2e 0a 2f 2f 0a 25 74  dentifier..//.%t
1610: 79 70 65 20 69 64 20 7b 54 6f 6b 65 6e 7d 0a 69  ype id {Token}.i
1620: 64 28 41 29 20 3a 3a 3d 20 49 44 28 58 29 2e 20  d(A) ::= ID(X). 
1630: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d          {A = X;}
1640: 0a 69 64 28 41 29 20 3a 3a 3d 20 49 4e 44 45 58  .id(A) ::= INDEX
1650: 45 44 28 58 29 2e 20 20 20 20 7b 41 20 3d 20 58  ED(X).    {A = X
1660: 3b 7d 0a 0a 2f 2f 20 54 68 65 20 66 6f 6c 6c 6f  ;}..// The follo
1670: 77 69 6e 67 20 64 69 72 65 63 74 69 76 65 20 63  wing directive c
1680: 61 75 73 65 73 20 74 6f 6b 65 6e 73 20 41 42 4f  auses tokens ABO
1690: 52 54 2c 20 41 46 54 45 52 2c 20 41 53 43 2c 20  RT, AFTER, ASC, 
16a0: 65 74 63 2e 20 74 6f 0a 2f 2f 20 66 61 6c 6c 62  etc. to.// fallb
16b0: 61 63 6b 20 74 6f 20 49 44 20 69 66 20 74 68 65  ack to ID if the
16c0: 79 20 77 69 6c 6c 20 6e 6f 74 20 70 61 72 73 65  y will not parse
16d0: 20 61 73 20 74 68 65 69 72 20 6f 72 69 67 69 6e   as their origin
16e0: 61 6c 20 76 61 6c 75 65 2e 0a 2f 2f 20 54 68 69  al value..// Thi
16f0: 73 20 6f 62 76 69 61 74 65 73 20 74 68 65 20 6e  s obviates the n
1700: 65 65 64 20 66 6f 72 20 74 68 65 20 22 69 64 22  eed for the "id"
1710: 20 6e 6f 6e 74 65 72 6d 69 6e 61 6c 2e 0a 2f 2f   nonterminal..//
1720: 0a 25 66 61 6c 6c 62 61 63 6b 20 49 44 0a 20 20  .%fallback ID.  
1730: 41 42 4f 52 54 20 41 43 54 49 4f 4e 20 41 46 54  ABORT ACTION AFT
1740: 45 52 20 41 4e 41 4c 59 5a 45 20 41 53 43 20 41  ER ANALYZE ASC A
1750: 54 54 41 43 48 20 42 45 46 4f 52 45 20 42 45 47  TTACH BEFORE BEG
1760: 49 4e 20 42 59 20 43 41 53 43 41 44 45 20 43 41  IN BY CASCADE CA
1770: 53 54 20 43 4f 4c 55 4d 4e 4b 57 0a 20 20 43 4f  ST COLUMNKW.  CO
1780: 4e 46 4c 49 43 54 20 44 41 54 41 42 41 53 45 20  NFLICT DATABASE 
1790: 44 45 46 45 52 52 45 44 20 44 45 53 43 20 44 45  DEFERRED DESC DE
17a0: 54 41 43 48 20 45 41 43 48 20 45 4e 44 20 45 58  TACH EACH END EX
17b0: 43 4c 55 53 49 56 45 20 45 58 50 4c 41 49 4e 20  CLUSIVE EXPLAIN 
17c0: 46 41 49 4c 20 46 4f 52 0a 20 20 49 47 4e 4f 52  FAIL FOR.  IGNOR
17d0: 45 20 49 4d 4d 45 44 49 41 54 45 20 49 4e 49 54  E IMMEDIATE INIT
17e0: 49 41 4c 4c 59 20 49 4e 53 54 45 41 44 20 4c 49  IALLY INSTEAD LI
17f0: 4b 45 5f 4b 57 20 4d 41 54 43 48 20 4e 4f 20 50  KE_KW MATCH NO P
1800: 4c 41 4e 0a 20 20 51 55 45 52 59 20 4b 45 59 20  LAN.  QUERY KEY 
1810: 4f 46 20 4f 46 46 53 45 54 20 50 52 41 47 4d 41  OF OFFSET PRAGMA
1820: 20 52 41 49 53 45 20 52 45 4c 45 41 53 45 20 52   RAISE RELEASE R
1830: 45 50 4c 41 43 45 20 52 45 53 54 52 49 43 54 20  EPLACE RESTRICT 
1840: 52 4f 57 20 52 4f 4c 4c 42 41 43 4b 0a 20 20 53  ROW ROLLBACK.  S
1850: 41 56 45 50 4f 49 4e 54 20 54 45 4d 50 20 54 52  AVEPOINT TEMP TR
1860: 49 47 47 45 52 20 56 41 43 55 55 4d 20 56 49 45  IGGER VACUUM VIE
1870: 57 20 56 49 52 54 55 41 4c 0a 25 69 66 64 65 66  W VIRTUAL.%ifdef
1880: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 43 4f 4d   SQLITE_OMIT_COM
1890: 50 4f 55 4e 44 5f 53 45 4c 45 43 54 0a 20 20 45  POUND_SELECT.  E
18a0: 58 43 45 50 54 20 49 4e 54 45 52 53 45 43 54 20  XCEPT INTERSECT 
18b0: 55 4e 49 4f 4e 0a 25 65 6e 64 69 66 20 53 51 4c  UNION.%endif SQL
18c0: 49 54 45 5f 4f 4d 49 54 5f 43 4f 4d 50 4f 55 4e  ITE_OMIT_COMPOUN
18d0: 44 5f 53 45 4c 45 43 54 0a 20 20 52 45 49 4e 44  D_SELECT.  REIND
18e0: 45 58 20 52 45 4e 41 4d 45 20 43 54 49 4d 45 5f  EX RENAME CTIME_
18f0: 4b 57 20 49 46 0a 20 20 2e 0a 25 77 69 6c 64 63  KW IF.  ..%wildc
1900: 61 72 64 20 41 4e 59 2e 0a 0a 2f 2f 20 44 65 66  ard ANY...// Def
1910: 69 6e 65 20 6f 70 65 72 61 74 6f 72 20 70 72 65  ine operator pre
1920: 63 65 64 65 6e 63 65 20 65 61 72 6c 79 20 73 6f  cedence early so
1930: 20 74 68 61 74 20 74 68 69 73 20 69 73 20 74 68   that this is th
1940: 65 20 66 69 72 73 74 20 6f 63 63 75 72 61 6e 63  e first occuranc
1950: 65 0a 2f 2f 20 6f 66 20 74 68 65 20 6f 70 65 72  e.// of the oper
1960: 61 74 6f 72 20 74 6f 6b 65 6e 73 20 69 6e 20 74  ator tokens in t
1970: 68 65 20 67 72 61 6d 6d 65 72 2e 20 20 4b 65 65  he grammer.  Kee
1980: 70 69 6e 67 20 74 68 65 20 6f 70 65 72 61 74 6f  ping the operato
1990: 72 73 20 74 6f 67 65 74 68 65 72 0a 2f 2f 20 63  rs together.// c
19a0: 61 75 73 65 73 20 74 68 65 6d 20 74 6f 20 62 65  auses them to be
19b0: 20 61 73 73 69 67 6e 65 64 20 69 6e 74 65 67 65   assigned intege
19c0: 72 20 76 61 6c 75 65 73 20 74 68 61 74 20 61 72  r values that ar
19d0: 65 20 63 6c 6f 73 65 20 74 6f 67 65 74 68 65 72  e close together
19e0: 2c 0a 2f 2f 20 77 68 69 63 68 20 6b 65 65 70 73  ,.// which keeps
19f0: 20 70 61 72 73 65 72 20 74 61 62 6c 65 73 20 73   parser tables s
1a00: 6d 61 6c 6c 65 72 2e 0a 2f 2f 0a 2f 2f 20 54 68  maller..//.// Th
1a10: 65 20 74 6f 6b 65 6e 20 76 61 6c 75 65 73 20 61  e token values a
1a20: 73 73 69 67 6e 65 64 20 74 6f 20 74 68 65 73 65  ssigned to these
1a30: 20 73 79 6d 62 6f 6c 73 20 69 73 20 64 65 74 65   symbols is dete
1a40: 72 6d 69 6e 65 64 20 62 79 20 74 68 65 20 6f 72  rmined by the or
1a50: 64 65 72 0a 2f 2f 20 69 6e 20 77 68 69 63 68 20  der.// in which 
1a60: 6c 65 6d 6f 6e 20 66 69 72 73 74 20 73 65 65 73  lemon first sees
1a70: 20 74 68 65 6d 2e 20 20 49 74 20 6d 75 73 74 20   them.  It must 
1a80: 62 65 20 74 68 65 20 63 61 73 65 20 74 68 61 74  be the case that
1a90: 20 49 53 4e 55 4c 4c 2f 4e 4f 54 4e 55 4c 4c 2c   ISNULL/NOTNULL,
1aa0: 0a 2f 2f 20 4e 45 2f 45 51 2c 20 47 54 2f 4c 45  .// NE/EQ, GT/LE
1ab0: 2c 20 61 6e 64 20 47 45 2f 4c 54 20 61 72 65 20  , and GE/LT are 
1ac0: 73 65 70 61 72 61 74 65 64 20 62 79 20 6f 6e 6c  separated by onl
1ad0: 79 20 61 20 73 69 6e 67 6c 65 20 76 61 6c 75 65  y a single value
1ae0: 2e 20 20 53 65 65 0a 2f 2f 20 74 68 65 20 73 71  .  See.// the sq
1af0: 6c 69 74 65 33 45 78 70 72 49 66 46 61 6c 73 65  lite3ExprIfFalse
1b00: 28 29 20 72 6f 75 74 69 6e 65 20 66 6f 72 20 61  () routine for a
1b10: 64 64 69 74 69 6f 6e 61 6c 20 69 6e 66 6f 72 6d  dditional inform
1b20: 61 74 69 6f 6e 20 6f 6e 20 74 68 69 73 0a 2f 2f  ation on this.//
1b30: 20 63 6f 6e 73 74 72 61 69 6e 74 2e 0a 2f 2f 0a   constraint..//.
1b40: 25 6c 65 66 74 20 4f 52 2e 0a 25 6c 65 66 74 20  %left OR..%left 
1b50: 41 4e 44 2e 0a 25 72 69 67 68 74 20 4e 4f 54 2e  AND..%right NOT.
1b60: 0a 25 6c 65 66 74 20 49 53 20 4d 41 54 43 48 20  .%left IS MATCH 
1b70: 4c 49 4b 45 5f 4b 57 20 42 45 54 57 45 45 4e 20  LIKE_KW BETWEEN 
1b80: 49 4e 20 49 53 4e 55 4c 4c 20 4e 4f 54 4e 55 4c  IN ISNULL NOTNUL
1b90: 4c 20 4e 45 20 45 51 2e 0a 25 6c 65 66 74 20 47  L NE EQ..%left G
1ba0: 54 20 4c 45 20 4c 54 20 47 45 2e 0a 25 72 69 67  T LE LT GE..%rig
1bb0: 68 74 20 45 53 43 41 50 45 2e 0a 25 6c 65 66 74  ht ESCAPE..%left
1bc0: 20 42 49 54 41 4e 44 20 42 49 54 4f 52 20 4c 53   BITAND BITOR LS
1bd0: 48 49 46 54 20 52 53 48 49 46 54 2e 0a 25 6c 65  HIFT RSHIFT..%le
1be0: 66 74 20 50 4c 55 53 20 4d 49 4e 55 53 2e 0a 25  ft PLUS MINUS..%
1bf0: 6c 65 66 74 20 53 54 41 52 20 53 4c 41 53 48 20  left STAR SLASH 
1c00: 52 45 4d 2e 0a 25 6c 65 66 74 20 43 4f 4e 43 41  REM..%left CONCA
1c10: 54 2e 0a 25 6c 65 66 74 20 43 4f 4c 4c 41 54 45  T..%left COLLATE
1c20: 2e 0a 25 72 69 67 68 74 20 42 49 54 4e 4f 54 2e  ..%right BITNOT.
1c30: 0a 0a 2f 2f 20 41 6e 64 20 22 69 64 73 22 20 69  ..// And "ids" i
1c40: 73 20 61 6e 20 69 64 65 6e 74 69 66 65 72 2d 6f  s an identifer-o
1c50: 72 2d 73 74 72 69 6e 67 2e 0a 2f 2f 0a 25 74 79  r-string..//.%ty
1c60: 70 65 20 69 64 73 20 7b 54 6f 6b 65 6e 7d 0a 69  pe ids {Token}.i
1c70: 64 73 28 41 29 20 3a 3a 3d 20 49 44 7c 53 54 52  ds(A) ::= ID|STR
1c80: 49 4e 47 28 58 29 2e 20 20 20 7b 41 20 3d 20 58  ING(X).   {A = X
1c90: 3b 7d 0a 0a 2f 2f 20 54 68 65 20 6e 61 6d 65 20  ;}..// The name 
1ca0: 6f 66 20 61 20 63 6f 6c 75 6d 6e 20 6f 72 20 74  of a column or t
1cb0: 61 62 6c 65 20 63 61 6e 20 62 65 20 61 6e 79 20  able can be any 
1cc0: 6f 66 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  of the following
1cd0: 3a 0a 2f 2f 0a 25 74 79 70 65 20 6e 6d 20 7b 54  :.//.%type nm {T
1ce0: 6f 6b 65 6e 7d 0a 6e 6d 28 41 29 20 3a 3a 3d 20  oken}.nm(A) ::= 
1cf0: 69 64 28 58 29 2e 20 20 20 20 20 20 20 20 20 7b  id(X).         {
1d00: 41 20 3d 20 58 3b 7d 0a 6e 6d 28 41 29 20 3a 3a  A = X;}.nm(A) ::
1d10: 3d 20 53 54 52 49 4e 47 28 58 29 2e 20 20 20 20  = STRING(X).    
1d20: 20 7b 41 20 3d 20 58 3b 7d 0a 6e 6d 28 41 29 20   {A = X;}.nm(A) 
1d30: 3a 3a 3d 20 4a 4f 49 4e 5f 4b 57 28 58 29 2e 20  ::= JOIN_KW(X). 
1d40: 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 0a 2f 2f 20     {A = X;}..// 
1d50: 41 20 74 79 70 65 74 6f 6b 65 6e 20 69 73 20 72  A typetoken is r
1d60: 65 61 6c 6c 79 20 6f 6e 65 20 6f 72 20 6d 6f 72  eally one or mor
1d70: 65 20 74 6f 6b 65 6e 73 20 74 68 61 74 20 66 6f  e tokens that fo
1d80: 72 6d 20 61 20 74 79 70 65 20 6e 61 6d 65 20 73  rm a type name s
1d90: 75 63 68 0a 2f 2f 20 61 73 20 63 61 6e 20 62 65  uch.// as can be
1da0: 20 66 6f 75 6e 64 20 61 66 74 65 72 20 74 68 65   found after the
1db0: 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 20 69 6e 20   column name in 
1dc0: 61 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 73  a CREATE TABLE s
1dd0: 74 61 74 65 6d 65 6e 74 2e 0a 2f 2f 20 4d 75 6c  tatement..// Mul
1de0: 74 69 70 6c 65 20 74 6f 6b 65 6e 73 20 61 72 65  tiple tokens are
1df0: 20 63 6f 6e 63 61 74 65 6e 61 74 65 64 20 74 6f   concatenated to
1e00: 20 66 6f 72 6d 20 74 68 65 20 76 61 6c 75 65 20   form the value 
1e10: 6f 66 20 74 68 65 20 74 79 70 65 74 6f 6b 65 6e  of the typetoken
1e20: 2e 0a 2f 2f 0a 25 74 79 70 65 20 74 79 70 65 74  ..//.%type typet
1e30: 6f 6b 65 6e 20 7b 54 6f 6b 65 6e 7d 0a 74 79 70  oken {Token}.typ
1e40: 65 20 3a 3a 3d 20 2e 0a 74 79 70 65 20 3a 3a 3d  e ::= ..type ::=
1e50: 20 74 79 70 65 74 6f 6b 65 6e 28 58 29 2e 20 20   typetoken(X).  
1e60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1e70: 20 7b 73 71 6c 69 74 65 33 41 64 64 43 6f 6c 75   {sqlite3AddColu
1e80: 6d 6e 54 79 70 65 28 70 50 61 72 73 65 2c 26 58  mnType(pParse,&X
1e90: 29 3b 7d 0a 74 79 70 65 74 6f 6b 65 6e 28 41 29  );}.typetoken(A)
1ea0: 20 3a 3a 3d 20 74 79 70 65 6e 61 6d 65 28 58 29   ::= typename(X)
1eb0: 2e 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 74 79 70  .   {A = X;}.typ
1ec0: 65 74 6f 6b 65 6e 28 41 29 20 3a 3a 3d 20 74 79  etoken(A) ::= ty
1ed0: 70 65 6e 61 6d 65 28 58 29 20 4c 50 20 73 69 67  pename(X) LP sig
1ee0: 6e 65 64 20 52 50 28 59 29 2e 20 7b 0a 20 20 41  ned RP(Y). {.  A
1ef0: 2e 7a 20 3d 20 58 2e 7a 3b 0a 20 20 41 2e 6e 20  .z = X.z;.  A.n 
1f00: 3d 20 28 69 6e 74 29 28 26 59 2e 7a 5b 59 2e 6e  = (int)(&Y.z[Y.n
1f10: 5d 20 2d 20 58 2e 7a 29 3b 0a 7d 0a 74 79 70 65  ] - X.z);.}.type
1f20: 74 6f 6b 65 6e 28 41 29 20 3a 3a 3d 20 74 79 70  token(A) ::= typ
1f30: 65 6e 61 6d 65 28 58 29 20 4c 50 20 73 69 67 6e  ename(X) LP sign
1f40: 65 64 20 43 4f 4d 4d 41 20 73 69 67 6e 65 64 20  ed COMMA signed 
1f50: 52 50 28 59 29 2e 20 7b 0a 20 20 41 2e 7a 20 3d  RP(Y). {.  A.z =
1f60: 20 58 2e 7a 3b 0a 20 20 41 2e 6e 20 3d 20 28 69   X.z;.  A.n = (i
1f70: 6e 74 29 28 26 59 2e 7a 5b 59 2e 6e 5d 20 2d 20  nt)(&Y.z[Y.n] - 
1f80: 58 2e 7a 29 3b 0a 7d 0a 25 74 79 70 65 20 74 79  X.z);.}.%type ty
1f90: 70 65 6e 61 6d 65 20 7b 54 6f 6b 65 6e 7d 0a 74  pename {Token}.t
1fa0: 79 70 65 6e 61 6d 65 28 41 29 20 3a 3a 3d 20 69  ypename(A) ::= i
1fb0: 64 73 28 58 29 2e 20 20 20 20 20 20 20 20 20 20  ds(X).          
1fc0: 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 74 79 70 65     {A = X;}.type
1fd0: 6e 61 6d 65 28 41 29 20 3a 3a 3d 20 74 79 70 65  name(A) ::= type
1fe0: 6e 61 6d 65 28 58 29 20 69 64 73 28 59 29 2e 20  name(X) ids(Y). 
1ff0: 7b 41 2e 7a 3d 58 2e 7a 3b 20 41 2e 6e 3d 59 2e  {A.z=X.z; A.n=Y.
2000: 6e 2b 28 69 6e 74 29 28 59 2e 7a 2d 58 2e 7a 29  n+(int)(Y.z-X.z)
2010: 3b 7d 0a 73 69 67 6e 65 64 20 3a 3a 3d 20 70 6c  ;}.signed ::= pl
2020: 75 73 5f 6e 75 6d 2e 0a 73 69 67 6e 65 64 20 3a  us_num..signed :
2030: 3a 3d 20 6d 69 6e 75 73 5f 6e 75 6d 2e 0a 0a 2f  := minus_num.../
2040: 2f 20 22 63 61 72 67 6c 69 73 74 22 20 69 73 20  / "carglist" is 
2050: 61 20 6c 69 73 74 20 6f 66 20 61 64 64 69 74 69  a list of additi
2060: 6f 6e 61 6c 20 63 6f 6e 73 74 72 61 69 6e 74 73  onal constraints
2070: 20 74 68 61 74 20 63 6f 6d 65 20 61 66 74 65 72   that come after
2080: 20 74 68 65 0a 2f 2f 20 63 6f 6c 75 6d 6e 20 6e   the.// column n
2090: 61 6d 65 20 61 6e 64 20 63 6f 6c 75 6d 6e 20 74  ame and column t
20a0: 79 70 65 20 69 6e 20 61 20 43 52 45 41 54 45 20  ype in a CREATE 
20b0: 54 41 42 4c 45 20 73 74 61 74 65 6d 65 6e 74 2e  TABLE statement.
20c0: 0a 2f 2f 0a 63 61 72 67 6c 69 73 74 20 3a 3a 3d  .//.carglist ::=
20d0: 20 63 61 72 67 6c 69 73 74 20 63 61 72 67 2e 0a   carglist carg..
20e0: 63 61 72 67 6c 69 73 74 20 3a 3a 3d 20 2e 0a 63  carglist ::= ..c
20f0: 61 72 67 20 3a 3a 3d 20 43 4f 4e 53 54 52 41 49  arg ::= CONSTRAI
2100: 4e 54 20 6e 6d 20 63 63 6f 6e 73 2e 0a 63 61 72  NT nm ccons..car
2110: 67 20 3a 3a 3d 20 63 63 6f 6e 73 2e 0a 63 63 6f  g ::= ccons..cco
2120: 6e 73 20 3a 3a 3d 20 44 45 46 41 55 4c 54 20 74  ns ::= DEFAULT t
2130: 65 72 6d 28 58 29 2e 20 20 20 20 20 20 20 20 20  erm(X).         
2140: 20 20 20 7b 73 71 6c 69 74 65 33 41 64 64 44 65     {sqlite3AddDe
2150: 66 61 75 6c 74 56 61 6c 75 65 28 70 50 61 72 73  faultValue(pPars
2160: 65 2c 26 58 29 3b 7d 0a 63 63 6f 6e 73 20 3a 3a  e,&X);}.ccons ::
2170: 3d 20 44 45 46 41 55 4c 54 20 4c 50 20 65 78 70  = DEFAULT LP exp
2180: 72 28 58 29 20 52 50 2e 20 20 20 20 20 20 7b 73  r(X) RP.      {s
2190: 71 6c 69 74 65 33 41 64 64 44 65 66 61 75 6c 74  qlite3AddDefault
21a0: 56 61 6c 75 65 28 70 50 61 72 73 65 2c 26 58 29  Value(pParse,&X)
21b0: 3b 7d 0a 63 63 6f 6e 73 20 3a 3a 3d 20 44 45 46  ;}.ccons ::= DEF
21c0: 41 55 4c 54 20 50 4c 55 53 20 74 65 72 6d 28 58  AULT PLUS term(X
21d0: 29 2e 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65  ).       {sqlite
21e0: 33 41 64 64 44 65 66 61 75 6c 74 56 61 6c 75 65  3AddDefaultValue
21f0: 28 70 50 61 72 73 65 2c 26 58 29 3b 7d 0a 63 63  (pParse,&X);}.cc
2200: 6f 6e 73 20 3a 3a 3d 20 44 45 46 41 55 4c 54 20  ons ::= DEFAULT 
2210: 4d 49 4e 55 53 28 41 29 20 74 65 72 6d 28 58 29  MINUS(A) term(X)
2220: 2e 20 20 20 20 20 20 7b 0a 20 20 45 78 70 72 53  .      {.  ExprS
2230: 70 61 6e 20 76 3b 0a 20 20 76 2e 70 45 78 70 72  pan v;.  v.pExpr
2240: 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72 28   = sqlite3PExpr(
2250: 70 50 61 72 73 65 2c 20 54 4b 5f 55 4d 49 4e 55  pParse, TK_UMINU
2260: 53 2c 20 58 2e 70 45 78 70 72 2c 20 30 2c 20 30  S, X.pExpr, 0, 0
2270: 29 3b 0a 20 20 76 2e 7a 53 74 61 72 74 20 3d 20  );.  v.zStart = 
2280: 41 2e 7a 3b 0a 20 20 76 2e 7a 45 6e 64 20 3d 20  A.z;.  v.zEnd = 
2290: 58 2e 7a 45 6e 64 3b 0a 20 20 73 71 6c 69 74 65  X.zEnd;.  sqlite
22a0: 33 41 64 64 44 65 66 61 75 6c 74 56 61 6c 75 65  3AddDefaultValue
22b0: 28 70 50 61 72 73 65 2c 26 76 29 3b 0a 7d 0a 63  (pParse,&v);.}.c
22c0: 63 6f 6e 73 20 3a 3a 3d 20 44 45 46 41 55 4c 54  cons ::= DEFAULT
22d0: 20 69 64 28 58 29 2e 20 20 20 20 20 20 20 20 20   id(X).         
22e0: 20 20 20 20 20 7b 0a 20 20 45 78 70 72 53 70 61       {.  ExprSpa
22f0: 6e 20 76 3b 0a 20 20 73 70 61 6e 45 78 70 72 28  n v;.  spanExpr(
2300: 26 76 2c 20 70 50 61 72 73 65 2c 20 54 4b 5f 53  &v, pParse, TK_S
2310: 54 52 49 4e 47 2c 20 26 58 29 3b 0a 20 20 73 71  TRING, &X);.  sq
2320: 6c 69 74 65 33 41 64 64 44 65 66 61 75 6c 74 56  lite3AddDefaultV
2330: 61 6c 75 65 28 70 50 61 72 73 65 2c 26 76 29 3b  alue(pParse,&v);
2340: 0a 7d 0a 0a 2f 2f 20 49 6e 20 61 64 64 69 74 69  .}..// In additi
2350: 6f 6e 20 74 6f 20 74 68 65 20 74 79 70 65 20 6e  on to the type n
2360: 61 6d 65 2c 20 77 65 20 61 6c 73 6f 20 63 61 72  ame, we also car
2370: 65 20 61 62 6f 75 74 20 74 68 65 20 70 72 69 6d  e about the prim
2380: 61 72 79 20 6b 65 79 20 61 6e 64 0a 2f 2f 20 55  ary key and.// U
2390: 4e 49 51 55 45 20 63 6f 6e 73 74 72 61 69 6e 74  NIQUE constraint
23a0: 73 2e 0a 2f 2f 0a 63 63 6f 6e 73 20 3a 3a 3d 20  s..//.ccons ::= 
23b0: 4e 55 4c 4c 20 6f 6e 63 6f 6e 66 2e 0a 63 63 6f  NULL onconf..cco
23c0: 6e 73 20 3a 3a 3d 20 4e 4f 54 20 4e 55 4c 4c 20  ns ::= NOT NULL 
23d0: 6f 6e 63 6f 6e 66 28 52 29 2e 20 20 20 20 7b 73  onconf(R).    {s
23e0: 71 6c 69 74 65 33 41 64 64 4e 6f 74 4e 75 6c 6c  qlite3AddNotNull
23f0: 28 70 50 61 72 73 65 2c 20 52 29 3b 7d 0a 63 63  (pParse, R);}.cc
2400: 6f 6e 73 20 3a 3a 3d 20 50 52 49 4d 41 52 59 20  ons ::= PRIMARY 
2410: 4b 45 59 20 73 6f 72 74 6f 72 64 65 72 28 5a 29  KEY sortorder(Z)
2420: 20 6f 6e 63 6f 6e 66 28 52 29 20 61 75 74 6f 69   onconf(R) autoi
2430: 6e 63 28 49 29 2e 0a 20 20 20 20 20 20 20 20 20  nc(I)..         
2440: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2450: 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33          {sqlite3
2460: 41 64 64 50 72 69 6d 61 72 79 4b 65 79 28 70 50  AddPrimaryKey(pP
2470: 61 72 73 65 2c 30 2c 52 2c 49 2c 5a 29 3b 7d 0a  arse,0,R,I,Z);}.
2480: 63 63 6f 6e 73 20 3a 3a 3d 20 55 4e 49 51 55 45  ccons ::= UNIQUE
2490: 20 6f 6e 63 6f 6e 66 28 52 29 2e 20 20 20 20 20   onconf(R).     
24a0: 20 7b 73 71 6c 69 74 65 33 43 72 65 61 74 65 49   {sqlite3CreateI
24b0: 6e 64 65 78 28 70 50 61 72 73 65 2c 30 2c 30 2c  ndex(pParse,0,0,
24c0: 30 2c 30 2c 52 2c 30 2c 30 2c 30 2c 30 29 3b 7d  0,0,R,0,0,0,0);}
24d0: 0a 63 63 6f 6e 73 20 3a 3a 3d 20 43 48 45 43 4b  .ccons ::= CHECK
24e0: 20 4c 50 20 65 78 70 72 28 58 29 20 52 50 2e 20   LP expr(X) RP. 
24f0: 20 20 7b 73 71 6c 69 74 65 33 41 64 64 43 68 65    {sqlite3AddChe
2500: 63 6b 43 6f 6e 73 74 72 61 69 6e 74 28 70 50 61  ckConstraint(pPa
2510: 72 73 65 2c 58 2e 70 45 78 70 72 29 3b 7d 0a 63  rse,X.pExpr);}.c
2520: 63 6f 6e 73 20 3a 3a 3d 20 52 45 46 45 52 45 4e  cons ::= REFEREN
2530: 43 45 53 20 6e 6d 28 54 29 20 69 64 78 6c 69 73  CES nm(T) idxlis
2540: 74 5f 6f 70 74 28 54 41 29 20 72 65 66 61 72 67  t_opt(TA) refarg
2550: 73 28 52 29 2e 0a 20 20 20 20 20 20 20 20 20 20  s(R)..          
2560: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2570: 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33 43         {sqlite3C
2580: 72 65 61 74 65 46 6f 72 65 69 67 6e 4b 65 79 28  reateForeignKey(
2590: 70 50 61 72 73 65 2c 30 2c 26 54 2c 54 41 2c 52  pParse,0,&T,TA,R
25a0: 29 3b 7d 0a 63 63 6f 6e 73 20 3a 3a 3d 20 64 65  );}.ccons ::= de
25b0: 66 65 72 5f 73 75 62 63 6c 61 75 73 65 28 44 29  fer_subclause(D)
25c0: 2e 20 20 20 20 7b 73 71 6c 69 74 65 33 44 65 66  .    {sqlite3Def
25d0: 65 72 46 6f 72 65 69 67 6e 4b 65 79 28 70 50 61  erForeignKey(pPa
25e0: 72 73 65 2c 44 29 3b 7d 0a 63 63 6f 6e 73 20 3a  rse,D);}.ccons :
25f0: 3a 3d 20 43 4f 4c 4c 41 54 45 20 69 64 73 28 43  := COLLATE ids(C
2600: 29 2e 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74  ).        {sqlit
2610: 65 33 41 64 64 43 6f 6c 6c 61 74 65 54 79 70 65  e3AddCollateType
2620: 28 70 50 61 72 73 65 2c 20 26 43 29 3b 7d 0a 0a  (pParse, &C);}..
2630: 2f 2f 20 54 68 65 20 6f 70 74 69 6f 6e 61 6c 20  // The optional 
2640: 41 55 54 4f 49 4e 43 52 45 4d 45 4e 54 20 6b 65  AUTOINCREMENT ke
2650: 79 77 6f 72 64 0a 25 74 79 70 65 20 61 75 74 6f  yword.%type auto
2660: 69 6e 63 20 7b 69 6e 74 7d 0a 61 75 74 6f 69 6e  inc {int}.autoin
2670: 63 28 58 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20  c(X) ::= .      
2680: 20 20 20 20 7b 58 20 3d 20 30 3b 7d 0a 61 75 74      {X = 0;}.aut
2690: 6f 69 6e 63 28 58 29 20 3a 3a 3d 20 41 55 54 4f  oinc(X) ::= AUTO
26a0: 49 4e 43 52 2e 20 20 7b 58 20 3d 20 31 3b 7d 0a  INCR.  {X = 1;}.
26b0: 0a 2f 2f 20 54 68 65 20 6e 65 78 74 20 67 72 6f  .// The next gro
26c0: 75 70 20 6f 66 20 72 75 6c 65 73 20 70 61 72 73  up of rules pars
26d0: 65 73 20 74 68 65 20 61 72 67 75 6d 65 6e 74 73  es the arguments
26e0: 20 74 6f 20 61 20 52 45 46 45 52 45 4e 43 45 53   to a REFERENCES
26f0: 20 63 6c 61 75 73 65 0a 2f 2f 20 74 68 61 74 20   clause.// that 
2700: 64 65 74 65 72 6d 69 6e 65 20 69 66 20 74 68 65  determine if the
2710: 20 72 65 66 65 72 65 6e 74 69 61 6c 20 69 6e 74   referential int
2720: 65 67 72 69 74 79 20 63 68 65 63 6b 69 6e 67 20  egrity checking 
2730: 69 73 20 64 65 66 65 72 72 65 64 20 6f 72 0a 2f  is deferred or./
2740: 2f 20 6f 72 20 69 6d 6d 65 64 69 61 74 65 20 61  / or immediate a
2750: 6e 64 20 77 68 69 63 68 20 64 65 74 65 72 6d 69  nd which determi
2760: 6e 65 20 77 68 61 74 20 61 63 74 69 6f 6e 20 74  ne what action t
2770: 6f 20 74 61 6b 65 20 69 66 20 61 20 72 65 66 2d  o take if a ref-
2780: 69 6e 74 65 67 0a 2f 2f 20 63 68 65 63 6b 20 66  integ.// check f
2790: 61 69 6c 73 2e 0a 2f 2f 0a 25 74 79 70 65 20 72  ails..//.%type r
27a0: 65 66 61 72 67 73 20 7b 69 6e 74 7d 0a 72 65 66  efargs {int}.ref
27b0: 61 72 67 73 28 41 29 20 3a 3a 3d 20 2e 20 20 20  args(A) ::= .   
27c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
27d0: 20 41 20 3d 20 4f 45 5f 4e 6f 6e 65 2a 30 78 30   A = OE_None*0x0
27e0: 31 30 31 3b 20 2f 2a 20 45 56 3a 20 52 2d 31 39  101; /* EV: R-19
27f0: 38 30 33 2d 34 35 38 38 34 20 2a 2f 7d 0a 72 65  803-45884 */}.re
2800: 66 61 72 67 73 28 41 29 20 3a 3a 3d 20 72 65 66  fargs(A) ::= ref
2810: 61 72 67 73 28 58 29 20 72 65 66 61 72 67 28 59  args(X) refarg(Y
2820: 29 2e 20 7b 20 41 20 3d 20 28 58 20 26 20 7e 59  ). { A = (X & ~Y
2830: 2e 6d 61 73 6b 29 20 7c 20 59 2e 76 61 6c 75 65  .mask) | Y.value
2840: 3b 20 7d 0a 25 74 79 70 65 20 72 65 66 61 72 67  ; }.%type refarg
2850: 20 7b 73 74 72 75 63 74 20 7b 69 6e 74 20 76 61   {struct {int va
2860: 6c 75 65 3b 20 69 6e 74 20 6d 61 73 6b 3b 7d 7d  lue; int mask;}}
2870: 0a 72 65 66 61 72 67 28 41 29 20 3a 3a 3d 20 4d  .refarg(A) ::= M
2880: 41 54 43 48 20 6e 6d 2e 20 20 20 20 20 20 20 20  ATCH nm.        
2890: 20 20 20 20 20 20 7b 20 41 2e 76 61 6c 75 65 20        { A.value 
28a0: 3d 20 30 3b 20 20 20 20 20 41 2e 6d 61 73 6b 20  = 0;     A.mask 
28b0: 3d 20 30 78 30 30 30 30 30 30 3b 20 7d 0a 72 65  = 0x000000; }.re
28c0: 66 61 72 67 28 41 29 20 3a 3a 3d 20 4f 4e 20 49  farg(A) ::= ON I
28d0: 4e 53 45 52 54 20 72 65 66 61 63 74 2e 20 20 20  NSERT refact.   
28e0: 20 20 20 7b 20 41 2e 76 61 6c 75 65 20 3d 20 30     { A.value = 0
28f0: 3b 20 20 20 20 20 41 2e 6d 61 73 6b 20 3d 20 30  ;     A.mask = 0
2900: 78 30 30 30 30 30 30 3b 20 7d 0a 72 65 66 61 72  x000000; }.refar
2910: 67 28 41 29 20 3a 3a 3d 20 4f 4e 20 44 45 4c 45  g(A) ::= ON DELE
2920: 54 45 20 72 65 66 61 63 74 28 58 29 2e 20 20 20  TE refact(X).   
2930: 7b 20 41 2e 76 61 6c 75 65 20 3d 20 58 3b 20 20  { A.value = X;  
2940: 20 20 20 41 2e 6d 61 73 6b 20 3d 20 30 78 30 30     A.mask = 0x00
2950: 30 30 66 66 3b 20 7d 0a 72 65 66 61 72 67 28 41  00ff; }.refarg(A
2960: 29 20 3a 3a 3d 20 4f 4e 20 55 50 44 41 54 45 20  ) ::= ON UPDATE 
2970: 72 65 66 61 63 74 28 58 29 2e 20 20 20 7b 20 41  refact(X).   { A
2980: 2e 76 61 6c 75 65 20 3d 20 58 3c 3c 38 3b 20 20  .value = X<<8;  
2990: 41 2e 6d 61 73 6b 20 3d 20 30 78 30 30 66 66 30  A.mask = 0x00ff0
29a0: 30 3b 20 7d 0a 25 74 79 70 65 20 72 65 66 61 63  0; }.%type refac
29b0: 74 20 7b 69 6e 74 7d 0a 72 65 66 61 63 74 28 41  t {int}.refact(A
29c0: 29 20 3a 3a 3d 20 53 45 54 20 4e 55 4c 4c 2e 20  ) ::= SET NULL. 
29d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 41               { A
29e0: 20 3d 20 4f 45 5f 53 65 74 4e 75 6c 6c 3b 20 20   = OE_SetNull;  
29f0: 2f 2a 20 45 56 3a 20 52 2d 33 33 33 32 36 2d 34  /* EV: R-33326-4
2a00: 35 32 35 32 20 2a 2f 7d 0a 72 65 66 61 63 74 28  5252 */}.refact(
2a10: 41 29 20 3a 3a 3d 20 53 45 54 20 44 45 46 41 55  A) ::= SET DEFAU
2a20: 4c 54 2e 20 20 20 20 20 20 20 20 20 20 20 7b 20  LT.           { 
2a30: 41 20 3d 20 4f 45 5f 53 65 74 44 66 6c 74 3b 20  A = OE_SetDflt; 
2a40: 20 2f 2a 20 45 56 3a 20 52 2d 33 33 33 32 36 2d   /* EV: R-33326-
2a50: 34 35 32 35 32 20 2a 2f 7d 0a 72 65 66 61 63 74  45252 */}.refact
2a60: 28 41 29 20 3a 3a 3d 20 43 41 53 43 41 44 45 2e  (A) ::= CASCADE.
2a70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
2a80: 20 41 20 3d 20 4f 45 5f 43 61 73 63 61 64 65 3b   A = OE_Cascade;
2a90: 20 20 2f 2a 20 45 56 3a 20 52 2d 33 33 33 32 36    /* EV: R-33326
2aa0: 2d 34 35 32 35 32 20 2a 2f 7d 0a 72 65 66 61 63  -45252 */}.refac
2ab0: 74 28 41 29 20 3a 3a 3d 20 52 45 53 54 52 49 43  t(A) ::= RESTRIC
2ac0: 54 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20  T.              
2ad0: 7b 20 41 20 3d 20 4f 45 5f 52 65 73 74 72 69 63  { A = OE_Restric
2ae0: 74 3b 20 2f 2a 20 45 56 3a 20 52 2d 33 33 33 32  t; /* EV: R-3332
2af0: 36 2d 34 35 32 35 32 20 2a 2f 7d 0a 72 65 66 61  6-45252 */}.refa
2b00: 63 74 28 41 29 20 3a 3a 3d 20 4e 4f 20 41 43 54  ct(A) ::= NO ACT
2b10: 49 4f 4e 2e 20 20 20 20 20 20 20 20 20 20 20 20  ION.            
2b20: 20 7b 20 41 20 3d 20 4f 45 5f 4e 6f 6e 65 3b 20   { A = OE_None; 
2b30: 20 20 20 20 2f 2a 20 45 56 3a 20 52 2d 33 33 33      /* EV: R-333
2b40: 32 36 2d 34 35 32 35 32 20 2a 2f 7d 0a 25 74 79  26-45252 */}.%ty
2b50: 70 65 20 64 65 66 65 72 5f 73 75 62 63 6c 61 75  pe defer_subclau
2b60: 73 65 20 7b 69 6e 74 7d 0a 64 65 66 65 72 5f 73  se {int}.defer_s
2b70: 75 62 63 6c 61 75 73 65 28 41 29 20 3a 3a 3d 20  ubclause(A) ::= 
2b80: 4e 4f 54 20 44 45 46 45 52 52 41 42 4c 45 20 69  NOT DEFERRABLE i
2b90: 6e 69 74 5f 64 65 66 65 72 72 65 64 5f 70 72 65  nit_deferred_pre
2ba0: 64 5f 6f 70 74 2e 20 20 20 20 20 7b 41 20 3d 20  d_opt.     {A = 
2bb0: 30 3b 7d 0a 64 65 66 65 72 5f 73 75 62 63 6c 61  0;}.defer_subcla
2bc0: 75 73 65 28 41 29 20 3a 3a 3d 20 44 45 46 45 52  use(A) ::= DEFER
2bd0: 52 41 42 4c 45 20 69 6e 69 74 5f 64 65 66 65 72  RABLE init_defer
2be0: 72 65 64 5f 70 72 65 64 5f 6f 70 74 28 58 29 2e  red_pred_opt(X).
2bf0: 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 25        {A = X;}.%
2c00: 74 79 70 65 20 69 6e 69 74 5f 64 65 66 65 72 72  type init_deferr
2c10: 65 64 5f 70 72 65 64 5f 6f 70 74 20 7b 69 6e 74  ed_pred_opt {int
2c20: 7d 0a 69 6e 69 74 5f 64 65 66 65 72 72 65 64 5f  }.init_deferred_
2c30: 70 72 65 64 5f 6f 70 74 28 41 29 20 3a 3a 3d 20  pred_opt(A) ::= 
2c40: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2c50: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30 3b 7d          {A = 0;}
2c60: 0a 69 6e 69 74 5f 64 65 66 65 72 72 65 64 5f 70  .init_deferred_p
2c70: 72 65 64 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 49  red_opt(A) ::= I
2c80: 4e 49 54 49 41 4c 4c 59 20 44 45 46 45 52 52 45  NITIALLY DEFERRE
2c90: 44 2e 20 20 20 20 20 7b 41 20 3d 20 31 3b 7d 0a  D.     {A = 1;}.
2ca0: 69 6e 69 74 5f 64 65 66 65 72 72 65 64 5f 70 72  init_deferred_pr
2cb0: 65 64 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 49 4e  ed_opt(A) ::= IN
2cc0: 49 54 49 41 4c 4c 59 20 49 4d 4d 45 44 49 41 54  ITIALLY IMMEDIAT
2cd0: 45 2e 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 0a  E.    {A = 0;}..
2ce0: 2f 2f 20 46 6f 72 20 74 68 65 20 74 69 6d 65 20  // For the time 
2cf0: 62 65 69 6e 67 2c 20 74 68 65 20 6f 6e 6c 79 20  being, the only 
2d00: 63 6f 6e 73 74 72 61 69 6e 74 20 77 65 20 63 61  constraint we ca
2d10: 72 65 20 61 62 6f 75 74 20 69 73 20 74 68 65 20  re about is the 
2d20: 70 72 69 6d 61 72 79 0a 2f 2f 20 6b 65 79 20 61  primary.// key a
2d30: 6e 64 20 55 4e 49 51 55 45 2e 20 20 42 6f 74 68  nd UNIQUE.  Both
2d40: 20 63 72 65 61 74 65 20 69 6e 64 69 63 65 73 2e   create indices.
2d50: 0a 2f 2f 0a 63 6f 6e 73 6c 69 73 74 5f 6f 70 74  .//.conslist_opt
2d60: 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20  (A) ::= .       
2d70: 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 2e 6e              {A.n
2d80: 20 3d 20 30 3b 20 41 2e 7a 20 3d 20 30 3b 7d 0a   = 0; A.z = 0;}.
2d90: 63 6f 6e 73 6c 69 73 74 5f 6f 70 74 28 41 29 20  conslist_opt(A) 
2da0: 3a 3a 3d 20 43 4f 4d 4d 41 28 58 29 20 63 6f 6e  ::= COMMA(X) con
2db0: 73 6c 69 73 74 2e 20 20 7b 41 20 3d 20 58 3b 7d  slist.  {A = X;}
2dc0: 0a 63 6f 6e 73 6c 69 73 74 20 3a 3a 3d 20 63 6f  .conslist ::= co
2dd0: 6e 73 6c 69 73 74 20 43 4f 4d 4d 41 20 74 63 6f  nslist COMMA tco
2de0: 6e 73 2e 0a 63 6f 6e 73 6c 69 73 74 20 3a 3a 3d  ns..conslist ::=
2df0: 20 63 6f 6e 73 6c 69 73 74 20 74 63 6f 6e 73 2e   conslist tcons.
2e00: 0a 63 6f 6e 73 6c 69 73 74 20 3a 3a 3d 20 74 63  .conslist ::= tc
2e10: 6f 6e 73 2e 0a 74 63 6f 6e 73 20 3a 3a 3d 20 43  ons..tcons ::= C
2e20: 4f 4e 53 54 52 41 49 4e 54 20 6e 6d 2e 0a 74 63  ONSTRAINT nm..tc
2e30: 6f 6e 73 20 3a 3a 3d 20 50 52 49 4d 41 52 59 20  ons ::= PRIMARY 
2e40: 4b 45 59 20 4c 50 20 69 64 78 6c 69 73 74 28 58  KEY LP idxlist(X
2e50: 29 20 61 75 74 6f 69 6e 63 28 49 29 20 52 50 20  ) autoinc(I) RP 
2e60: 6f 6e 63 6f 6e 66 28 52 29 2e 0a 20 20 20 20 20  onconf(R)..     
2e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2e80: 20 20 20 20 20 20 20 20 20 20 20 20 7b 73 71 6c              {sql
2e90: 69 74 65 33 41 64 64 50 72 69 6d 61 72 79 4b 65  ite3AddPrimaryKe
2ea0: 79 28 70 50 61 72 73 65 2c 58 2c 52 2c 49 2c 30  y(pParse,X,R,I,0
2eb0: 29 3b 7d 0a 74 63 6f 6e 73 20 3a 3a 3d 20 55 4e  );}.tcons ::= UN
2ec0: 49 51 55 45 20 4c 50 20 69 64 78 6c 69 73 74 28  IQUE LP idxlist(
2ed0: 58 29 20 52 50 20 6f 6e 63 6f 6e 66 28 52 29 2e  X) RP onconf(R).
2ee0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2ef0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f00: 20 20 7b 73 71 6c 69 74 65 33 43 72 65 61 74 65    {sqlite3Create
2f10: 49 6e 64 65 78 28 70 50 61 72 73 65 2c 30 2c 30  Index(pParse,0,0
2f20: 2c 30 2c 58 2c 52 2c 30 2c 30 2c 30 2c 30 29 3b  ,0,X,R,0,0,0,0);
2f30: 7d 0a 74 63 6f 6e 73 20 3a 3a 3d 20 43 48 45 43  }.tcons ::= CHEC
2f40: 4b 20 4c 50 20 65 78 70 72 28 45 29 20 52 50 20  K LP expr(E) RP 
2f50: 6f 6e 63 6f 6e 66 2e 0a 20 20 20 20 20 20 20 20  onconf..        
2f60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f70: 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65           {sqlite
2f80: 33 41 64 64 43 68 65 63 6b 43 6f 6e 73 74 72 61  3AddCheckConstra
2f90: 69 6e 74 28 70 50 61 72 73 65 2c 45 2e 70 45 78  int(pParse,E.pEx
2fa0: 70 72 29 3b 7d 0a 74 63 6f 6e 73 20 3a 3a 3d 20  pr);}.tcons ::= 
2fb0: 46 4f 52 45 49 47 4e 20 4b 45 59 20 4c 50 20 69  FOREIGN KEY LP i
2fc0: 64 78 6c 69 73 74 28 46 41 29 20 52 50 0a 20 20  dxlist(FA) RP.  
2fd0: 20 20 20 20 20 20 20 20 52 45 46 45 52 45 4e 43          REFERENC
2fe0: 45 53 20 6e 6d 28 54 29 20 69 64 78 6c 69 73 74  ES nm(T) idxlist
2ff0: 5f 6f 70 74 28 54 41 29 20 72 65 66 61 72 67 73  _opt(TA) refargs
3000: 28 52 29 20 64 65 66 65 72 5f 73 75 62 63 6c 61  (R) defer_subcla
3010: 75 73 65 5f 6f 70 74 28 44 29 2e 20 7b 0a 20 20  use_opt(D). {.  
3020: 20 20 73 71 6c 69 74 65 33 43 72 65 61 74 65 46    sqlite3CreateF
3030: 6f 72 65 69 67 6e 4b 65 79 28 70 50 61 72 73 65  oreignKey(pParse
3040: 2c 20 46 41 2c 20 26 54 2c 20 54 41 2c 20 52 29  , FA, &T, TA, R)
3050: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 44 65 66  ;.    sqlite3Def
3060: 65 72 46 6f 72 65 69 67 6e 4b 65 79 28 70 50 61  erForeignKey(pPa
3070: 72 73 65 2c 20 44 29 3b 0a 7d 0a 25 74 79 70 65  rse, D);.}.%type
3080: 20 64 65 66 65 72 5f 73 75 62 63 6c 61 75 73 65   defer_subclause
3090: 5f 6f 70 74 20 7b 69 6e 74 7d 0a 64 65 66 65 72  _opt {int}.defer
30a0: 5f 73 75 62 63 6c 61 75 73 65 5f 6f 70 74 28 41  _subclause_opt(A
30b0: 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20  ) ::= .         
30c0: 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20             {A = 
30d0: 30 3b 7d 0a 64 65 66 65 72 5f 73 75 62 63 6c 61  0;}.defer_subcla
30e0: 75 73 65 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 64  use_opt(A) ::= d
30f0: 65 66 65 72 5f 73 75 62 63 6c 61 75 73 65 28 58  efer_subclause(X
3100: 29 2e 20 20 7b 41 20 3d 20 58 3b 7d 0a 0a 2f 2f  ).  {A = X;}..//
3110: 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 69   The following i
3120: 73 20 61 20 6e 6f 6e 2d 73 74 61 6e 64 61 72 64  s a non-standard
3130: 20 65 78 74 65 6e 73 69 6f 6e 20 74 68 61 74 20   extension that 
3140: 61 6c 6c 6f 77 73 20 75 73 20 74 6f 20 64 65 63  allows us to dec
3150: 6c 61 72 65 20 74 68 65 0a 2f 2f 20 64 65 66 61  lare the.// defa
3160: 75 6c 74 20 62 65 68 61 76 69 6f 72 20 77 68 65  ult behavior whe
3170: 6e 20 74 68 65 72 65 20 69 73 20 61 20 63 6f 6e  n there is a con
3180: 73 74 72 61 69 6e 74 20 63 6f 6e 66 6c 69 63 74  straint conflict
3190: 2e 0a 2f 2f 0a 25 74 79 70 65 20 6f 6e 63 6f 6e  ..//.%type oncon
31a0: 66 20 7b 69 6e 74 7d 0a 25 74 79 70 65 20 6f 72  f {int}.%type or
31b0: 63 6f 6e 66 20 7b 75 38 7d 0a 25 74 79 70 65 20  conf {u8}.%type 
31c0: 72 65 73 6f 6c 76 65 74 79 70 65 20 7b 69 6e 74  resolvetype {int
31d0: 7d 0a 6f 6e 63 6f 6e 66 28 41 29 20 3a 3a 3d 20  }.onconf(A) ::= 
31e0: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
31f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
3200: 41 20 3d 20 4f 45 5f 44 65 66 61 75 6c 74 3b 7d  A = OE_Default;}
3210: 0a 6f 6e 63 6f 6e 66 28 41 29 20 3a 3a 3d 20 4f  .onconf(A) ::= O
3220: 4e 20 43 4f 4e 46 4c 49 43 54 20 72 65 73 6f 6c  N CONFLICT resol
3230: 76 65 74 79 70 65 28 58 29 2e 20 20 20 20 7b 41  vetype(X).    {A
3240: 20 3d 20 58 3b 7d 0a 6f 72 63 6f 6e 66 28 41 29   = X;}.orconf(A)
3250: 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20   ::= .          
3260: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3270: 20 20 20 20 7b 41 20 3d 20 4f 45 5f 44 65 66 61      {A = OE_Defa
3280: 75 6c 74 3b 7d 0a 6f 72 63 6f 6e 66 28 41 29 20  ult;}.orconf(A) 
3290: 3a 3a 3d 20 4f 52 20 72 65 73 6f 6c 76 65 74 79  ::= OR resolvety
32a0: 70 65 28 58 29 2e 20 20 20 20 20 20 20 20 20 20  pe(X).          
32b0: 20 20 20 7b 41 20 3d 20 28 75 38 29 58 3b 7d 0a     {A = (u8)X;}.
32c0: 72 65 73 6f 6c 76 65 74 79 70 65 28 41 29 20 3a  resolvetype(A) :
32d0: 3a 3d 20 72 61 69 73 65 74 79 70 65 28 58 29 2e  := raisetype(X).
32e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20               {A 
32f0: 3d 20 58 3b 7d 0a 72 65 73 6f 6c 76 65 74 79 70  = X;}.resolvetyp
3300: 65 28 41 29 20 3a 3a 3d 20 49 47 4e 4f 52 45 2e  e(A) ::= IGNORE.
3310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3320: 20 20 20 7b 41 20 3d 20 4f 45 5f 49 67 6e 6f 72     {A = OE_Ignor
3330: 65 3b 7d 0a 72 65 73 6f 6c 76 65 74 79 70 65 28  e;}.resolvetype(
3340: 41 29 20 3a 3a 3d 20 52 45 50 4c 41 43 45 2e 20  A) ::= REPLACE. 
3350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3360: 20 7b 41 20 3d 20 4f 45 5f 52 65 70 6c 61 63 65   {A = OE_Replace
3370: 3b 7d 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ;}..////////////
3380: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54  ////////////// T
3390: 68 65 20 44 52 4f 50 20 54 41 42 4c 45 20 2f 2f  he DROP TABLE //
33a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
33b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
33c0: 2f 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a 3a 3d 20 44  ///.//.cmd ::= D
33d0: 52 4f 50 20 54 41 42 4c 45 20 69 66 65 78 69 73  ROP TABLE ifexis
33e0: 74 73 28 45 29 20 66 75 6c 6c 6e 61 6d 65 28 58  ts(E) fullname(X
33f0: 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33 44 72  ). {.  sqlite3Dr
3400: 6f 70 54 61 62 6c 65 28 70 50 61 72 73 65 2c 20  opTable(pParse, 
3410: 58 2c 20 30 2c 20 45 29 3b 0a 7d 0a 25 74 79 70  X, 0, E);.}.%typ
3420: 65 20 69 66 65 78 69 73 74 73 20 7b 69 6e 74 7d  e ifexists {int}
3430: 0a 69 66 65 78 69 73 74 73 28 41 29 20 3a 3a 3d  .ifexists(A) ::=
3440: 20 49 46 20 45 58 49 53 54 53 2e 20 20 20 7b 41   IF EXISTS.   {A
3450: 20 3d 20 31 3b 7d 0a 69 66 65 78 69 73 74 73 28   = 1;}.ifexists(
3460: 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20  A) ::= .        
3470: 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 0a 2f 2f      {A = 0;}..//
3480: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
3490: 2f 2f 2f 20 54 68 65 20 43 52 45 41 54 45 20 56  /// The CREATE V
34a0: 49 45 57 20 73 74 61 74 65 6d 65 6e 74 20 2f 2f  IEW statement //
34b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
34c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 25  ///////////.//.%
34d0: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
34e0: 49 54 5f 56 49 45 57 0a 63 6d 64 20 3a 3a 3d 20  IT_VIEW.cmd ::= 
34f0: 63 72 65 61 74 65 6b 77 28 58 29 20 74 65 6d 70  createkw(X) temp
3500: 28 54 29 20 56 49 45 57 20 69 66 6e 6f 74 65 78  (T) VIEW ifnotex
3510: 69 73 74 73 28 45 29 20 6e 6d 28 59 29 20 64 62  ists(E) nm(Y) db
3520: 6e 6d 28 5a 29 20 41 53 20 73 65 6c 65 63 74 28  nm(Z) AS select(
3530: 53 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33 43  S). {.  sqlite3C
3540: 72 65 61 74 65 56 69 65 77 28 70 50 61 72 73 65  reateView(pParse
3550: 2c 20 26 58 2c 20 26 59 2c 20 26 5a 2c 20 53 2c  , &X, &Y, &Z, S,
3560: 20 54 2c 20 45 29 3b 0a 7d 0a 63 6d 64 20 3a 3a   T, E);.}.cmd ::
3570: 3d 20 44 52 4f 50 20 56 49 45 57 20 69 66 65 78  = DROP VIEW ifex
3580: 69 73 74 73 28 45 29 20 66 75 6c 6c 6e 61 6d 65  ists(E) fullname
3590: 28 58 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33  (X). {.  sqlite3
35a0: 44 72 6f 70 54 61 62 6c 65 28 70 50 61 72 73 65  DropTable(pParse
35b0: 2c 20 58 2c 20 31 2c 20 45 29 3b 0a 7d 0a 25 65  , X, 1, E);.}.%e
35c0: 6e 64 69 66 20 20 53 51 4c 49 54 45 5f 4f 4d 49  ndif  SQLITE_OMI
35d0: 54 5f 56 49 45 57 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f  T_VIEW..////////
35e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
35f0: 20 54 68 65 20 53 45 4c 45 43 54 20 73 74 61 74   The SELECT stat
3600: 65 6d 65 6e 74 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ement //////////
3610: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
3620: 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a  ///////.//.cmd :
3630: 3a 3d 20 73 65 6c 65 63 74 28 58 29 2e 20 20 7b  := select(X).  {
3640: 0a 20 20 53 65 6c 65 63 74 44 65 73 74 20 64 65  .  SelectDest de
3650: 73 74 20 3d 20 7b 53 52 54 5f 4f 75 74 70 75 74  st = {SRT_Output
3660: 2c 20 30 2c 20 30 2c 20 30 2c 20 30 7d 3b 0a 20  , 0, 0, 0, 0};. 
3670: 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 28 70   sqlite3Select(p
3680: 50 61 72 73 65 2c 20 58 2c 20 26 64 65 73 74 29  Parse, X, &dest)
3690: 3b 0a 20 20 73 71 6c 69 74 65 33 53 65 6c 65 63  ;.  sqlite3Selec
36a0: 74 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e  tDelete(pParse->
36b0: 64 62 2c 20 58 29 3b 0a 7d 0a 0a 25 74 79 70 65  db, X);.}..%type
36c0: 20 73 65 6c 65 63 74 20 7b 53 65 6c 65 63 74 2a   select {Select*
36d0: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 73 65  }.%destructor se
36e0: 6c 65 63 74 20 7b 73 71 6c 69 74 65 33 53 65 6c  lect {sqlite3Sel
36f0: 65 63 74 44 65 6c 65 74 65 28 70 50 61 72 73 65  ectDelete(pParse
3700: 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 25 74 79 70  ->db, $$);}.%typ
3710: 65 20 6f 6e 65 73 65 6c 65 63 74 20 7b 53 65 6c  e oneselect {Sel
3720: 65 63 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f  ect*}.%destructo
3730: 72 20 6f 6e 65 73 65 6c 65 63 74 20 7b 73 71 6c  r oneselect {sql
3740: 69 74 65 33 53 65 6c 65 63 74 44 65 6c 65 74 65  ite3SelectDelete
3750: 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 29  (pParse->db, $$)
3760: 3b 7d 0a 0a 73 65 6c 65 63 74 28 41 29 20 3a 3a  ;}..select(A) ::
3770: 3d 20 6f 6e 65 73 65 6c 65 63 74 28 58 29 2e 20  = oneselect(X). 
3780: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3790: 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 25 69       {A = X;}.%i
37a0: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
37b0: 54 5f 43 4f 4d 50 4f 55 4e 44 5f 53 45 4c 45 43  T_COMPOUND_SELEC
37c0: 54 0a 73 65 6c 65 63 74 28 41 29 20 3a 3a 3d 20  T.select(A) ::= 
37d0: 73 65 6c 65 63 74 28 58 29 20 6d 75 6c 74 69 73  select(X) multis
37e0: 65 6c 65 63 74 5f 6f 70 28 59 29 20 6f 6e 65 73  elect_op(Y) ones
37f0: 65 6c 65 63 74 28 5a 29 2e 20 20 7b 0a 20 20 69  elect(Z).  {.  i
3800: 66 28 20 5a 20 29 7b 0a 20 20 20 20 5a 2d 3e 6f  f( Z ){.    Z->o
3810: 70 20 3d 20 28 75 38 29 59 3b 0a 20 20 20 20 5a  p = (u8)Y;.    Z
3820: 2d 3e 70 50 72 69 6f 72 20 3d 20 58 3b 0a 20 20  ->pPrior = X;.  
3830: 7d 65 6c 73 65 7b 0a 20 20 20 20 73 71 6c 69 74  }else{.    sqlit
3840: 65 33 53 65 6c 65 63 74 44 65 6c 65 74 65 28 70  e3SelectDelete(p
3850: 50 61 72 73 65 2d 3e 64 62 2c 20 58 29 3b 0a 20  Parse->db, X);. 
3860: 20 7d 0a 20 20 41 20 3d 20 5a 3b 0a 7d 0a 25 74   }.  A = Z;.}.%t
3870: 79 70 65 20 6d 75 6c 74 69 73 65 6c 65 63 74 5f  ype multiselect_
3880: 6f 70 20 7b 69 6e 74 7d 0a 6d 75 6c 74 69 73 65  op {int}.multise
3890: 6c 65 63 74 5f 6f 70 28 41 29 20 3a 3a 3d 20 55  lect_op(A) ::= U
38a0: 4e 49 4f 4e 28 4f 50 29 2e 20 20 20 20 20 20 20  NION(OP).       
38b0: 20 20 20 20 20 20 7b 41 20 3d 20 40 4f 50 3b 7d        {A = @OP;}
38c0: 0a 6d 75 6c 74 69 73 65 6c 65 63 74 5f 6f 70 28  .multiselect_op(
38d0: 41 29 20 3a 3a 3d 20 55 4e 49 4f 4e 20 41 4c 4c  A) ::= UNION ALL
38e0: 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 41  .             {A
38f0: 20 3d 20 54 4b 5f 41 4c 4c 3b 7d 0a 6d 75 6c 74   = TK_ALL;}.mult
3900: 69 73 65 6c 65 63 74 5f 6f 70 28 41 29 20 3a 3a  iselect_op(A) ::
3910: 3d 20 45 58 43 45 50 54 7c 49 4e 54 45 52 53 45  = EXCEPT|INTERSE
3920: 43 54 28 4f 50 29 2e 20 20 7b 41 20 3d 20 40 4f  CT(OP).  {A = @O
3930: 50 3b 7d 0a 25 65 6e 64 69 66 20 53 51 4c 49 54  P;}.%endif SQLIT
3940: 45 5f 4f 4d 49 54 5f 43 4f 4d 50 4f 55 4e 44 5f  E_OMIT_COMPOUND_
3950: 53 45 4c 45 43 54 0a 6f 6e 65 73 65 6c 65 63 74  SELECT.oneselect
3960: 28 41 29 20 3a 3a 3d 20 53 45 4c 45 43 54 20 64  (A) ::= SELECT d
3970: 69 73 74 69 6e 63 74 28 44 29 20 73 65 6c 63 6f  istinct(D) selco
3980: 6c 6c 69 73 74 28 57 29 20 66 72 6f 6d 28 58 29  llist(W) from(X)
3990: 20 77 68 65 72 65 5f 6f 70 74 28 59 29 0a 20 20   where_opt(Y).  
39a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 67                 g
39b0: 72 6f 75 70 62 79 5f 6f 70 74 28 50 29 20 68 61  roupby_opt(P) ha
39c0: 76 69 6e 67 5f 6f 70 74 28 51 29 20 6f 72 64 65  ving_opt(Q) orde
39d0: 72 62 79 5f 6f 70 74 28 5a 29 20 6c 69 6d 69 74  rby_opt(Z) limit
39e0: 5f 6f 70 74 28 4c 29 2e 20 7b 0a 20 20 41 20 3d  _opt(L). {.  A =
39f0: 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 4e 65   sqlite3SelectNe
3a00: 77 28 70 50 61 72 73 65 2c 57 2c 58 2c 59 2c 50  w(pParse,W,X,Y,P
3a10: 2c 51 2c 5a 2c 44 2c 4c 2e 70 4c 69 6d 69 74 2c  ,Q,Z,D,L.pLimit,
3a20: 4c 2e 70 4f 66 66 73 65 74 29 3b 0a 7d 0a 0a 2f  L.pOffset);.}../
3a30: 2f 20 54 68 65 20 22 64 69 73 74 69 6e 63 74 22  / The "distinct"
3a40: 20 6e 6f 6e 74 65 72 6d 69 6e 61 6c 20 69 73 20   nonterminal is 
3a50: 74 72 75 65 20 28 31 29 20 69 66 20 74 68 65 20  true (1) if the 
3a60: 44 49 53 54 49 4e 43 54 20 6b 65 79 77 6f 72 64  DISTINCT keyword
3a70: 20 69 73 0a 2f 2f 20 70 72 65 73 65 6e 74 20 61   is.// present a
3a80: 6e 64 20 66 61 6c 73 65 20 28 30 29 20 69 66 20  nd false (0) if 
3a90: 69 74 20 69 73 20 6e 6f 74 2e 0a 2f 2f 0a 25 74  it is not..//.%t
3aa0: 79 70 65 20 64 69 73 74 69 6e 63 74 20 7b 69 6e  ype distinct {in
3ab0: 74 7d 0a 64 69 73 74 69 6e 63 74 28 41 29 20 3a  t}.distinct(A) :
3ac0: 3a 3d 20 44 49 53 54 49 4e 43 54 2e 20 20 20 7b  := DISTINCT.   {
3ad0: 41 20 3d 20 31 3b 7d 0a 64 69 73 74 69 6e 63 74  A = 1;}.distinct
3ae0: 28 41 29 20 3a 3a 3d 20 41 4c 4c 2e 20 20 20 20  (A) ::= ALL.    
3af0: 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 64 69 73      {A = 0;}.dis
3b00: 74 69 6e 63 74 28 41 29 20 3a 3a 3d 20 2e 20 20  tinct(A) ::= .  
3b10: 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30 3b           {A = 0;
3b20: 7d 0a 0a 2f 2f 20 73 65 6c 63 6f 6c 6c 69 73 74  }..// selcollist
3b30: 20 69 73 20 61 20 6c 69 73 74 20 6f 66 20 65 78   is a list of ex
3b40: 70 72 65 73 73 69 6f 6e 73 20 74 68 61 74 20 61  pressions that a
3b50: 72 65 20 74 6f 20 62 65 63 6f 6d 65 20 74 68 65  re to become the
3b60: 20 72 65 74 75 72 6e 0a 2f 2f 20 76 61 6c 75 65   return.// value
3b70: 73 20 6f 66 20 74 68 65 20 53 45 4c 45 43 54 20  s of the SELECT 
3b80: 73 74 61 74 65 6d 65 6e 74 2e 20 20 54 68 65 20  statement.  The 
3b90: 22 2a 22 20 69 6e 20 73 74 61 74 65 6d 65 6e 74  "*" in statement
3ba0: 73 20 6c 69 6b 65 0a 2f 2f 20 22 53 45 4c 45 43  s like.// "SELEC
3bb0: 54 20 2a 20 46 52 4f 4d 20 2e 2e 2e 22 20 69 73  T * FROM ..." is
3bc0: 20 65 6e 63 6f 64 65 64 20 61 73 20 61 20 73 70   encoded as a sp
3bd0: 65 63 69 61 6c 20 65 78 70 72 65 73 73 69 6f 6e  ecial expression
3be0: 20 77 69 74 68 20 61 6e 0a 2f 2f 20 6f 70 63 6f   with an.// opco
3bf0: 64 65 20 6f 66 20 54 4b 5f 41 4c 4c 2e 0a 2f 2f  de of TK_ALL..//
3c00: 0a 25 74 79 70 65 20 73 65 6c 63 6f 6c 6c 69 73  .%type selcollis
3c10: 74 20 7b 45 78 70 72 4c 69 73 74 2a 7d 0a 25 64  t {ExprList*}.%d
3c20: 65 73 74 72 75 63 74 6f 72 20 73 65 6c 63 6f 6c  estructor selcol
3c30: 6c 69 73 74 20 7b 73 71 6c 69 74 65 33 45 78 70  list {sqlite3Exp
3c40: 72 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61 72  rListDelete(pPar
3c50: 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 25 74  se->db, $$);}.%t
3c60: 79 70 65 20 73 63 6c 70 20 7b 45 78 70 72 4c 69  ype sclp {ExprLi
3c70: 73 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72  st*}.%destructor
3c80: 20 73 63 6c 70 20 7b 73 71 6c 69 74 65 33 45 78   sclp {sqlite3Ex
3c90: 70 72 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61  prListDelete(pPa
3ca0: 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 73  rse->db, $$);}.s
3cb0: 63 6c 70 28 41 29 20 3a 3a 3d 20 73 65 6c 63 6f  clp(A) ::= selco
3cc0: 6c 6c 69 73 74 28 58 29 20 43 4f 4d 4d 41 2e 20  llist(X) COMMA. 
3cd0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d              {A =
3ce0: 20 58 3b 7d 0a 73 63 6c 70 28 41 29 20 3a 3a 3d   X;}.sclp(A) ::=
3cf0: 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20   .              
3d00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3d10: 20 20 7b 41 20 3d 20 30 3b 7d 0a 73 65 6c 63 6f    {A = 0;}.selco
3d20: 6c 6c 69 73 74 28 41 29 20 3a 3a 3d 20 73 63 6c  llist(A) ::= scl
3d30: 70 28 50 29 20 65 78 70 72 28 58 29 20 61 73 28  p(P) expr(X) as(
3d40: 59 29 2e 20 20 20 20 20 7b 0a 20 20 20 41 20 3d  Y).     {.   A =
3d50: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
3d60: 41 70 70 65 6e 64 28 70 50 61 72 73 65 2c 20 50  Append(pParse, P
3d70: 2c 20 58 2e 70 45 78 70 72 29 3b 0a 20 20 20 69  , X.pExpr);.   i
3d80: 66 28 20 59 2e 6e 3e 30 20 29 20 73 71 6c 69 74  f( Y.n>0 ) sqlit
3d90: 65 33 45 78 70 72 4c 69 73 74 53 65 74 4e 61 6d  e3ExprListSetNam
3da0: 65 28 70 50 61 72 73 65 2c 20 41 2c 20 26 59 2c  e(pParse, A, &Y,
3db0: 20 31 29 3b 0a 20 20 20 73 71 6c 69 74 65 33 45   1);.   sqlite3E
3dc0: 78 70 72 4c 69 73 74 53 65 74 53 70 61 6e 28 70  xprListSetSpan(p
3dd0: 50 61 72 73 65 2c 41 2c 26 58 29 3b 0a 7d 0a 73  Parse,A,&X);.}.s
3de0: 65 6c 63 6f 6c 6c 69 73 74 28 41 29 20 3a 3a 3d  elcollist(A) ::=
3df0: 20 73 63 6c 70 28 50 29 20 53 54 41 52 2e 20 7b   sclp(P) STAR. {
3e00: 0a 20 20 45 78 70 72 20 2a 70 20 3d 20 73 71 6c  .  Expr *p = sql
3e10: 69 74 65 33 45 78 70 72 28 70 50 61 72 73 65 2d  ite3Expr(pParse-
3e20: 3e 64 62 2c 20 54 4b 5f 41 4c 4c 2c 20 30 29 3b  >db, TK_ALL, 0);
3e30: 0a 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78  .  A = sqlite3Ex
3e40: 70 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61  prListAppend(pPa
3e50: 72 73 65 2c 20 50 2c 20 70 29 3b 0a 7d 0a 73 65  rse, P, p);.}.se
3e60: 6c 63 6f 6c 6c 69 73 74 28 41 29 20 3a 3a 3d 20  lcollist(A) ::= 
3e70: 73 63 6c 70 28 50 29 20 6e 6d 28 58 29 20 44 4f  sclp(P) nm(X) DO
3e80: 54 20 53 54 41 52 28 59 29 2e 20 7b 0a 20 20 45  T STAR(Y). {.  E
3e90: 78 70 72 20 2a 70 52 69 67 68 74 20 3d 20 73 71  xpr *pRight = sq
3ea0: 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73  lite3PExpr(pPars
3eb0: 65 2c 20 54 4b 5f 41 4c 4c 2c 20 30 2c 20 30 2c  e, TK_ALL, 0, 0,
3ec0: 20 26 59 29 3b 0a 20 20 45 78 70 72 20 2a 70 4c   &Y);.  Expr *pL
3ed0: 65 66 74 20 3d 20 73 71 6c 69 74 65 33 50 45 78  eft = sqlite3PEx
3ee0: 70 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 49 44  pr(pParse, TK_ID
3ef0: 2c 20 30 2c 20 30 2c 20 26 58 29 3b 0a 20 20 45  , 0, 0, &X);.  E
3f00: 78 70 72 20 2a 70 44 6f 74 20 3d 20 73 71 6c 69  xpr *pDot = sqli
3f10: 74 65 33 50 45 78 70 72 28 70 50 61 72 73 65 2c  te3PExpr(pParse,
3f20: 20 54 4b 5f 44 4f 54 2c 20 70 4c 65 66 74 2c 20   TK_DOT, pLeft, 
3f30: 70 52 69 67 68 74 2c 20 30 29 3b 0a 20 20 41 20  pRight, 0);.  A 
3f40: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73  = sqlite3ExprLis
3f50: 74 41 70 70 65 6e 64 28 70 50 61 72 73 65 2c 50  tAppend(pParse,P
3f60: 2c 20 70 44 6f 74 29 3b 0a 7d 0a 0a 2f 2f 20 41  , pDot);.}..// A
3f70: 6e 20 6f 70 74 69 6f 6e 20 22 41 53 20 3c 69 64  n option "AS <id
3f80: 3e 22 20 70 68 72 61 73 65 20 74 68 61 74 20 63  >" phrase that c
3f90: 61 6e 20 66 6f 6c 6c 6f 77 20 6f 6e 65 20 6f 66  an follow one of
3fa0: 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e 73   the expressions
3fb0: 20 74 68 61 74 0a 2f 2f 20 64 65 66 69 6e 65 20   that.// define 
3fc0: 74 68 65 20 72 65 73 75 6c 74 20 73 65 74 2c 20  the result set, 
3fd0: 6f 72 20 6f 6e 65 20 6f 66 20 74 68 65 20 74 61  or one of the ta
3fe0: 62 6c 65 73 20 69 6e 20 74 68 65 20 46 52 4f 4d  bles in the FROM
3ff0: 20 63 6c 61 75 73 65 2e 0a 2f 2f 0a 25 74 79 70   clause..//.%typ
4000: 65 20 61 73 20 7b 54 6f 6b 65 6e 7d 0a 61 73 28  e as {Token}.as(
4010: 58 29 20 3a 3a 3d 20 41 53 20 6e 6d 28 59 29 2e  X) ::= AS nm(Y).
4020: 20 20 20 20 7b 58 20 3d 20 59 3b 7d 0a 61 73 28      {X = Y;}.as(
4030: 58 29 20 3a 3a 3d 20 69 64 73 28 59 29 2e 20 20  X) ::= ids(Y).  
4040: 20 20 20 20 7b 58 20 3d 20 59 3b 7d 0a 61 73 28      {X = Y;}.as(
4050: 58 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20  X) ::= .        
4060: 20 20 20 20 7b 58 2e 6e 20 3d 20 30 3b 7d 0a 0a      {X.n = 0;}..
4070: 0a 25 74 79 70 65 20 73 65 6c 74 61 62 6c 69 73  .%type seltablis
4080: 74 20 7b 53 72 63 4c 69 73 74 2a 7d 0a 25 64 65  t {SrcList*}.%de
4090: 73 74 72 75 63 74 6f 72 20 73 65 6c 74 61 62 6c  structor seltabl
40a0: 69 73 74 20 7b 73 71 6c 69 74 65 33 53 72 63 4c  ist {sqlite3SrcL
40b0: 69 73 74 44 65 6c 65 74 65 28 70 50 61 72 73 65  istDelete(pParse
40c0: 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 25 74 79 70  ->db, $$);}.%typ
40d0: 65 20 73 74 6c 5f 70 72 65 66 69 78 20 7b 53 72  e stl_prefix {Sr
40e0: 63 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72 75 63  cList*}.%destruc
40f0: 74 6f 72 20 73 74 6c 5f 70 72 65 66 69 78 20 7b  tor stl_prefix {
4100: 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74 44 65  sqlite3SrcListDe
4110: 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c  lete(pParse->db,
4120: 20 24 24 29 3b 7d 0a 25 74 79 70 65 20 66 72 6f   $$);}.%type fro
4130: 6d 20 7b 53 72 63 4c 69 73 74 2a 7d 0a 25 64 65  m {SrcList*}.%de
4140: 73 74 72 75 63 74 6f 72 20 66 72 6f 6d 20 7b 73  structor from {s
4150: 71 6c 69 74 65 33 53 72 63 4c 69 73 74 44 65 6c  qlite3SrcListDel
4160: 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c 20  ete(pParse->db, 
4170: 24 24 29 3b 7d 0a 0a 2f 2f 20 41 20 63 6f 6d 70  $$);}..// A comp
4180: 6c 65 74 65 20 46 52 4f 4d 20 63 6c 61 75 73 65  lete FROM clause
4190: 2e 0a 2f 2f 0a 66 72 6f 6d 28 41 29 20 3a 3a 3d  ..//.from(A) ::=
41a0: 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20   .              
41b0: 20 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 44 62    {A = sqlite3Db
41c0: 4d 61 6c 6c 6f 63 5a 65 72 6f 28 70 50 61 72 73  MallocZero(pPars
41d0: 65 2d 3e 64 62 2c 20 73 69 7a 65 6f 66 28 2a 41  e->db, sizeof(*A
41e0: 29 29 3b 7d 0a 66 72 6f 6d 28 41 29 20 3a 3a 3d  ));}.from(A) ::=
41f0: 20 46 52 4f 4d 20 73 65 6c 74 61 62 6c 69 73 74   FROM seltablist
4200: 28 58 29 2e 20 7b 0a 20 20 41 20 3d 20 58 3b 0a  (X). {.  A = X;.
4210: 20 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74    sqlite3SrcList
4220: 53 68 69 66 74 4a 6f 69 6e 54 79 70 65 28 41 29  ShiftJoinType(A)
4230: 3b 0a 7d 0a 0a 2f 2f 20 22 73 65 6c 74 61 62 6c  ;.}..// "seltabl
4240: 69 73 74 22 20 69 73 20 61 20 22 53 65 6c 65 63  ist" is a "Selec
4250: 74 20 54 61 62 6c 65 20 4c 69 73 74 22 20 2d 20  t Table List" - 
4260: 74 68 65 20 63 6f 6e 74 65 6e 74 20 6f 66 20 74  the content of t
4270: 68 65 20 46 52 4f 4d 20 63 6c 61 75 73 65 0a 2f  he FROM clause./
4280: 2f 20 69 6e 20 61 20 53 45 4c 45 43 54 20 73 74  / in a SELECT st
4290: 61 74 65 6d 65 6e 74 2e 20 20 22 73 74 6c 5f 70  atement.  "stl_p
42a0: 72 65 66 69 78 22 20 69 73 20 61 20 70 72 65 66  refix" is a pref
42b0: 69 78 20 6f 66 20 74 68 69 73 20 6c 69 73 74 2e  ix of this list.
42c0: 0a 2f 2f 0a 73 74 6c 5f 70 72 65 66 69 78 28 41  .//.stl_prefix(A
42d0: 29 20 3a 3a 3d 20 73 65 6c 74 61 62 6c 69 73 74  ) ::= seltablist
42e0: 28 58 29 20 6a 6f 69 6e 6f 70 28 59 29 2e 20 20  (X) joinop(Y).  
42f0: 20 20 7b 0a 20 20 20 41 20 3d 20 58 3b 0a 20 20    {.   A = X;.  
4300: 20 69 66 28 20 41 4c 57 41 59 53 28 41 20 26 26   if( ALWAYS(A &&
4310: 20 41 2d 3e 6e 53 72 63 3e 30 29 20 29 20 41 2d   A->nSrc>0) ) A-
4320: 3e 61 5b 41 2d 3e 6e 53 72 63 2d 31 5d 2e 6a 6f  >a[A->nSrc-1].jo
4330: 69 6e 74 79 70 65 20 3d 20 28 75 38 29 59 3b 0a  intype = (u8)Y;.
4340: 7d 0a 73 74 6c 5f 70 72 65 66 69 78 28 41 29 20  }.stl_prefix(A) 
4350: 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20  ::= .           
4360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4370: 7b 41 20 3d 20 30 3b 7d 0a 73 65 6c 74 61 62 6c  {A = 0;}.seltabl
4380: 69 73 74 28 41 29 20 3a 3a 3d 20 73 74 6c 5f 70  ist(A) ::= stl_p
4390: 72 65 66 69 78 28 58 29 20 6e 6d 28 59 29 20 64  refix(X) nm(Y) d
43a0: 62 6e 6d 28 44 29 20 61 73 28 5a 29 20 69 6e 64  bnm(D) as(Z) ind
43b0: 65 78 65 64 5f 6f 70 74 28 49 29 20 6f 6e 5f 6f  exed_opt(I) on_o
43c0: 70 74 28 4e 29 20 75 73 69 6e 67 5f 6f 70 74 28  pt(N) using_opt(
43d0: 55 29 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69  U). {.  A = sqli
43e0: 74 65 33 53 72 63 4c 69 73 74 41 70 70 65 6e 64  te3SrcListAppend
43f0: 46 72 6f 6d 54 65 72 6d 28 70 50 61 72 73 65 2c  FromTerm(pParse,
4400: 58 2c 26 59 2c 26 44 2c 26 5a 2c 30 2c 4e 2c 55  X,&Y,&D,&Z,0,N,U
4410: 29 3b 0a 20 20 73 71 6c 69 74 65 33 53 72 63 4c  );.  sqlite3SrcL
4420: 69 73 74 49 6e 64 65 78 65 64 42 79 28 70 50 61  istIndexedBy(pPa
4430: 72 73 65 2c 20 41 2c 20 26 49 29 3b 0a 7d 0a 25  rse, A, &I);.}.%
4440: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
4450: 49 54 5f 53 55 42 51 55 45 52 59 0a 20 20 73 65  IT_SUBQUERY.  se
4460: 6c 74 61 62 6c 69 73 74 28 41 29 20 3a 3a 3d 20  ltablist(A) ::= 
4470: 73 74 6c 5f 70 72 65 66 69 78 28 58 29 20 4c 50  stl_prefix(X) LP
4480: 20 73 65 6c 65 63 74 28 53 29 20 52 50 0a 20 20   select(S) RP.  
4490: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
44a0: 20 20 61 73 28 5a 29 20 6f 6e 5f 6f 70 74 28 4e    as(Z) on_opt(N
44b0: 29 20 75 73 69 6e 67 5f 6f 70 74 28 55 29 2e 20  ) using_opt(U). 
44c0: 7b 0a 20 20 20 20 41 20 3d 20 73 71 6c 69 74 65  {.    A = sqlite
44d0: 33 53 72 63 4c 69 73 74 41 70 70 65 6e 64 46 72  3SrcListAppendFr
44e0: 6f 6d 54 65 72 6d 28 70 50 61 72 73 65 2c 58 2c  omTerm(pParse,X,
44f0: 30 2c 30 2c 26 5a 2c 53 2c 4e 2c 55 29 3b 0a 20  0,0,&Z,S,N,U);. 
4500: 20 7d 0a 20 20 73 65 6c 74 61 62 6c 69 73 74 28   }.  seltablist(
4510: 41 29 20 3a 3a 3d 20 73 74 6c 5f 70 72 65 66 69  A) ::= stl_prefi
4520: 78 28 58 29 20 4c 50 20 73 65 6c 74 61 62 6c 69  x(X) LP seltabli
4530: 73 74 28 46 29 20 52 50 0a 20 20 20 20 20 20 20  st(F) RP.       
4540: 20 20 20 20 20 20 20 20 20 20 20 20 20 61 73 28               as(
4550: 5a 29 20 6f 6e 5f 6f 70 74 28 4e 29 20 75 73 69  Z) on_opt(N) usi
4560: 6e 67 5f 6f 70 74 28 55 29 2e 20 7b 0a 20 20 20  ng_opt(U). {.   
4570: 20 69 66 28 20 58 3d 3d 30 20 26 26 20 5a 2e 6e   if( X==0 && Z.n
4580: 3d 3d 30 20 26 26 20 4e 3d 3d 30 20 26 26 20 55  ==0 && N==0 && U
4590: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 41 20 3d  ==0 ){.      A =
45a0: 20 46 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20   F;.    }else{. 
45b0: 20 20 20 20 20 53 65 6c 65 63 74 20 2a 70 53 75       Select *pSu
45c0: 62 71 75 65 72 79 3b 0a 20 20 20 20 20 20 73 71  bquery;.      sq
45d0: 6c 69 74 65 33 53 72 63 4c 69 73 74 53 68 69 66  lite3SrcListShif
45e0: 74 4a 6f 69 6e 54 79 70 65 28 46 29 3b 0a 20 20  tJoinType(F);.  
45f0: 20 20 20 20 70 53 75 62 71 75 65 72 79 20 3d 20      pSubquery = 
4600: 73 71 6c 69 74 65 33 53 65 6c 65 63 74 4e 65 77  sqlite3SelectNew
4610: 28 70 50 61 72 73 65 2c 30 2c 46 2c 30 2c 30 2c  (pParse,0,F,0,0,
4620: 30 2c 30 2c 30 2c 30 2c 30 29 3b 0a 20 20 20 20  0,0,0,0,0);.    
4630: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 53 72 63    A = sqlite3Src
4640: 4c 69 73 74 41 70 70 65 6e 64 46 72 6f 6d 54 65  ListAppendFromTe
4650: 72 6d 28 70 50 61 72 73 65 2c 58 2c 30 2c 30 2c  rm(pParse,X,0,0,
4660: 26 5a 2c 70 53 75 62 71 75 65 72 79 2c 4e 2c 55  &Z,pSubquery,N,U
4670: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 0a  );.    }.  }.  .
4680: 20 20 2f 2f 20 41 20 73 65 6c 74 61 62 6c 69 73    // A seltablis
4690: 74 5f 70 61 72 65 6e 20 6e 6f 6e 74 65 72 6d 69  t_paren nontermi
46a0: 6e 61 6c 20 72 65 70 72 65 73 65 6e 74 73 20 61  nal represents a
46b0: 6e 79 74 68 69 6e 67 20 69 6e 20 61 20 46 52 4f  nything in a FRO
46c0: 4d 20 74 68 61 74 0a 20 20 2f 2f 20 69 73 20 63  M that.  // is c
46d0: 6f 6e 74 61 69 6e 65 64 20 69 6e 73 69 64 65 20  ontained inside 
46e0: 70 61 72 65 6e 74 68 65 73 65 73 2e 20 20 54 68  parentheses.  Th
46f0: 69 73 20 63 61 6e 20 62 65 20 65 69 74 68 65 72  is can be either
4700: 20 61 20 73 75 62 71 75 65 72 79 20 6f 72 0a 20   a subquery or. 
4710: 20 2f 2f 20 61 20 67 72 6f 75 70 69 6e 67 20 6f   // a grouping o
4720: 66 20 74 61 62 6c 65 20 61 6e 64 20 73 75 62 71  f table and subq
4730: 75 65 72 69 65 73 2e 0a 20 20 2f 2f 0a 2f 2f 20  ueries..  //.// 
4740: 20 25 74 79 70 65 20 73 65 6c 74 61 62 6c 69 73   %type seltablis
4750: 74 5f 70 61 72 65 6e 20 7b 53 65 6c 65 63 74 2a  t_paren {Select*
4760: 7d 0a 2f 2f 20 20 25 64 65 73 74 72 75 63 74 6f  }.//  %destructo
4770: 72 20 73 65 6c 74 61 62 6c 69 73 74 5f 70 61 72  r seltablist_par
4780: 65 6e 20 7b 73 71 6c 69 74 65 33 53 65 6c 65 63  en {sqlite3Selec
4790: 74 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e  tDelete(pParse->
47a0: 64 62 2c 20 24 24 29 3b 7d 0a 2f 2f 20 20 73 65  db, $$);}.//  se
47b0: 6c 74 61 62 6c 69 73 74 5f 70 61 72 65 6e 28 41  ltablist_paren(A
47c0: 29 20 3a 3a 3d 20 73 65 6c 65 63 74 28 53 29 2e  ) ::= select(S).
47d0: 20 20 20 20 20 20 7b 41 20 3d 20 53 3b 7d 0a 2f        {A = S;}./
47e0: 2f 20 20 73 65 6c 74 61 62 6c 69 73 74 5f 70 61  /  seltablist_pa
47f0: 72 65 6e 28 41 29 20 3a 3a 3d 20 73 65 6c 74 61  ren(A) ::= selta
4800: 62 6c 69 73 74 28 46 29 2e 20 20 7b 0a 2f 2f 20  blist(F).  {.// 
4810: 20 20 20 20 73 71 6c 69 74 65 33 53 72 63 4c 69      sqlite3SrcLi
4820: 73 74 53 68 69 66 74 4a 6f 69 6e 54 79 70 65 28  stShiftJoinType(
4830: 46 29 3b 0a 2f 2f 20 20 20 20 20 41 20 3d 20 73  F);.//     A = s
4840: 71 6c 69 74 65 33 53 65 6c 65 63 74 4e 65 77 28  qlite3SelectNew(
4850: 70 50 61 72 73 65 2c 30 2c 46 2c 30 2c 30 2c 30  pParse,0,F,0,0,0
4860: 2c 30 2c 30 2c 30 2c 30 29 3b 0a 2f 2f 20 20 7d  ,0,0,0,0);.//  }
4870: 0a 25 65 6e 64 69 66 20 20 53 51 4c 49 54 45 5f  .%endif  SQLITE_
4880: 4f 4d 49 54 5f 53 55 42 51 55 45 52 59 0a 0a 25  OMIT_SUBQUERY..%
4890: 74 79 70 65 20 64 62 6e 6d 20 7b 54 6f 6b 65 6e  type dbnm {Token
48a0: 7d 0a 64 62 6e 6d 28 41 29 20 3a 3a 3d 20 2e 20  }.dbnm(A) ::= . 
48b0: 20 20 20 20 20 20 20 20 20 7b 41 2e 7a 3d 30 3b           {A.z=0;
48c0: 20 41 2e 6e 3d 30 3b 7d 0a 64 62 6e 6d 28 41 29   A.n=0;}.dbnm(A)
48d0: 20 3a 3a 3d 20 44 4f 54 20 6e 6d 28 58 29 2e 20   ::= DOT nm(X). 
48e0: 7b 41 20 3d 20 58 3b 7d 0a 0a 25 74 79 70 65 20  {A = X;}..%type 
48f0: 66 75 6c 6c 6e 61 6d 65 20 7b 53 72 63 4c 69 73  fullname {SrcLis
4900: 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20  t*}.%destructor 
4910: 66 75 6c 6c 6e 61 6d 65 20 7b 73 71 6c 69 74 65  fullname {sqlite
4920: 33 53 72 63 4c 69 73 74 44 65 6c 65 74 65 28 70  3SrcListDelete(p
4930: 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d  Parse->db, $$);}
4940: 0a 66 75 6c 6c 6e 61 6d 65 28 41 29 20 3a 3a 3d  .fullname(A) ::=
4950: 20 6e 6d 28 58 29 20 64 62 6e 6d 28 59 29 2e 20   nm(X) dbnm(Y). 
4960: 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 53 72 63   {A = sqlite3Src
4970: 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72 73  ListAppend(pPars
4980: 65 2d 3e 64 62 2c 30 2c 26 58 2c 26 59 29 3b 7d  e->db,0,&X,&Y);}
4990: 0a 0a 25 74 79 70 65 20 6a 6f 69 6e 6f 70 20 7b  ..%type joinop {
49a0: 69 6e 74 7d 0a 25 74 79 70 65 20 6a 6f 69 6e 6f  int}.%type joino
49b0: 70 32 20 7b 69 6e 74 7d 0a 6a 6f 69 6e 6f 70 28  p2 {int}.joinop(
49c0: 58 29 20 3a 3a 3d 20 43 4f 4d 4d 41 7c 4a 4f 49  X) ::= COMMA|JOI
49d0: 4e 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20  N.              
49e0: 7b 20 58 20 3d 20 4a 54 5f 49 4e 4e 45 52 3b 20  { X = JT_INNER; 
49f0: 7d 0a 6a 6f 69 6e 6f 70 28 58 29 20 3a 3a 3d 20  }.joinop(X) ::= 
4a00: 4a 4f 49 4e 5f 4b 57 28 41 29 20 4a 4f 49 4e 2e  JOIN_KW(A) JOIN.
4a10: 20 20 20 20 20 20 20 20 20 7b 20 58 20 3d 20 73           { X = s
4a20: 71 6c 69 74 65 33 4a 6f 69 6e 54 79 70 65 28 70  qlite3JoinType(p
4a30: 50 61 72 73 65 2c 26 41 2c 30 2c 30 29 3b 20 7d  Parse,&A,0,0); }
4a40: 0a 6a 6f 69 6e 6f 70 28 58 29 20 3a 3a 3d 20 4a  .joinop(X) ::= J
4a50: 4f 49 4e 5f 4b 57 28 41 29 20 6e 6d 28 42 29 20  OIN_KW(A) nm(B) 
4a60: 4a 4f 49 4e 2e 20 20 20 7b 20 58 20 3d 20 73 71  JOIN.   { X = sq
4a70: 6c 69 74 65 33 4a 6f 69 6e 54 79 70 65 28 70 50  lite3JoinType(pP
4a80: 61 72 73 65 2c 26 41 2c 26 42 2c 30 29 3b 20 7d  arse,&A,&B,0); }
4a90: 0a 6a 6f 69 6e 6f 70 28 58 29 20 3a 3a 3d 20 4a  .joinop(X) ::= J
4aa0: 4f 49 4e 5f 4b 57 28 41 29 20 6e 6d 28 42 29 20  OIN_KW(A) nm(B) 
4ab0: 6e 6d 28 43 29 20 4a 4f 49 4e 2e 0a 20 20 20 20  nm(C) JOIN..    
4ac0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4ae0: 20 20 20 7b 20 58 20 3d 20 73 71 6c 69 74 65 33     { X = sqlite3
4af0: 4a 6f 69 6e 54 79 70 65 28 70 50 61 72 73 65 2c  JoinType(pParse,
4b00: 26 41 2c 26 42 2c 26 43 29 3b 20 7d 0a 0a 25 74  &A,&B,&C); }..%t
4b10: 79 70 65 20 6f 6e 5f 6f 70 74 20 7b 45 78 70 72  ype on_opt {Expr
4b20: 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 6f  *}.%destructor o
4b30: 6e 5f 6f 70 74 20 7b 73 71 6c 69 74 65 33 45 78  n_opt {sqlite3Ex
4b40: 70 72 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d  prDelete(pParse-
4b50: 3e 64 62 2c 20 24 24 29 3b 7d 0a 6f 6e 5f 6f 70  >db, $$);}.on_op
4b60: 74 28 4e 29 20 3a 3a 3d 20 4f 4e 20 65 78 70 72  t(N) ::= ON expr
4b70: 28 45 29 2e 20 20 20 7b 4e 20 3d 20 45 2e 70 45  (E).   {N = E.pE
4b80: 78 70 72 3b 7d 0a 6f 6e 5f 6f 70 74 28 4e 29 20  xpr;}.on_opt(N) 
4b90: 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20  ::= .           
4ba0: 20 20 7b 4e 20 3d 20 30 3b 7d 0a 0a 2f 2f 20 4e    {N = 0;}..// N
4bb0: 6f 74 65 20 74 68 61 74 20 74 68 69 73 20 62 6c  ote that this bl
4bc0: 6f 63 6b 20 61 62 75 73 65 73 20 74 68 65 20 54  ock abuses the T
4bd0: 6f 6b 65 6e 20 74 79 70 65 20 6a 75 73 74 20 61  oken type just a
4be0: 20 6c 69 74 74 6c 65 2e 20 49 66 20 74 68 65 72   little. If ther
4bf0: 65 20 69 73 0a 2f 2f 20 6e 6f 20 22 49 4e 44 45  e is.// no "INDE
4c00: 58 45 44 20 42 59 22 20 63 6c 61 75 73 65 2c 20  XED BY" clause, 
4c10: 74 68 65 20 72 65 74 75 72 6e 65 64 20 74 6f 6b  the returned tok
4c20: 65 6e 20 69 73 20 65 6d 70 74 79 20 28 7a 3d 3d  en is empty (z==
4c30: 30 20 26 26 20 6e 3d 3d 30 29 2e 20 49 66 0a 2f  0 && n==0). If./
4c40: 2f 20 74 68 65 72 65 20 69 73 20 61 6e 20 49 4e  / there is an IN
4c50: 44 45 58 45 44 20 42 59 20 63 6c 61 75 73 65 2c  DEXED BY clause,
4c60: 20 74 68 65 6e 20 74 68 65 20 74 6f 6b 65 6e 20   then the token 
4c70: 69 73 20 70 6f 70 75 6c 61 74 65 64 20 61 73 20  is populated as 
4c80: 70 65 72 20 6e 6f 72 6d 61 6c 2c 0a 2f 2f 20 77  per normal,.// w
4c90: 69 74 68 20 7a 20 70 6f 69 6e 74 69 6e 67 20 74  ith z pointing t
4ca0: 6f 20 74 68 65 20 74 6f 6b 65 6e 20 64 61 74 61  o the token data
4cb0: 20 61 6e 64 20 6e 20 63 6f 6e 74 61 69 6e 69 6e   and n containin
4cc0: 67 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20  g the number of 
4cd0: 62 79 74 65 73 0a 2f 2f 20 69 6e 20 74 68 65 20  bytes.// in the 
4ce0: 74 6f 6b 65 6e 2e 0a 2f 2f 0a 2f 2f 20 49 66 20  token..//.// If 
4cf0: 74 68 65 72 65 20 69 73 20 61 20 22 4e 4f 54 20  there is a "NOT 
4d00: 49 4e 44 45 58 45 44 22 20 63 6c 61 75 73 65 2c  INDEXED" clause,
4d10: 20 74 68 65 6e 20 28 7a 3d 3d 30 20 26 26 20 6e   then (z==0 && n
4d20: 3d 3d 31 29 2c 20 77 68 69 63 68 20 69 73 20 0a  ==1), which is .
4d30: 2f 2f 20 6e 6f 72 6d 61 6c 6c 79 20 69 6c 6c 65  // normally ille
4d40: 67 61 6c 2e 20 54 68 65 20 73 71 6c 69 74 65 33  gal. The sqlite3
4d50: 53 72 63 4c 69 73 74 49 6e 64 65 78 65 64 42 79  SrcListIndexedBy
4d60: 28 29 20 66 75 6e 63 74 69 6f 6e 20 0a 2f 2f 20  () function .// 
4d70: 72 65 63 6f 67 6e 69 7a 65 73 20 61 6e 64 20 69  recognizes and i
4d80: 6e 74 65 72 70 72 65 74 73 20 74 68 69 73 20 61  nterprets this a
4d90: 73 20 61 20 73 70 65 63 69 61 6c 20 63 61 73 65  s a special case
4da0: 2e 0a 2f 2f 0a 25 74 79 70 65 20 69 6e 64 65 78  ..//.%type index
4db0: 65 64 5f 6f 70 74 20 7b 54 6f 6b 65 6e 7d 0a 69  ed_opt {Token}.i
4dc0: 6e 64 65 78 65 64 5f 6f 70 74 28 41 29 20 3a 3a  ndexed_opt(A) ::
4dd0: 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  = .             
4de0: 20 20 20 20 7b 41 2e 7a 3d 30 3b 20 41 2e 6e 3d      {A.z=0; A.n=
4df0: 30 3b 7d 0a 69 6e 64 65 78 65 64 5f 6f 70 74 28  0;}.indexed_opt(
4e00: 41 29 20 3a 3a 3d 20 49 4e 44 45 58 45 44 20 42  A) ::= INDEXED B
4e10: 59 20 6e 6d 28 58 29 2e 20 7b 41 20 3d 20 58 3b  Y nm(X). {A = X;
4e20: 7d 0a 69 6e 64 65 78 65 64 5f 6f 70 74 28 41 29  }.indexed_opt(A)
4e30: 20 3a 3a 3d 20 4e 4f 54 20 49 4e 44 45 58 45 44   ::= NOT INDEXED
4e40: 2e 20 20 20 20 20 20 7b 41 2e 7a 3d 30 3b 20 41  .      {A.z=0; A
4e50: 2e 6e 3d 31 3b 7d 0a 0a 25 74 79 70 65 20 75 73  .n=1;}..%type us
4e60: 69 6e 67 5f 6f 70 74 20 7b 49 64 4c 69 73 74 2a  ing_opt {IdList*
4e70: 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 75 73  }.%destructor us
4e80: 69 6e 67 5f 6f 70 74 20 7b 73 71 6c 69 74 65 33  ing_opt {sqlite3
4e90: 49 64 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61  IdListDelete(pPa
4ea0: 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 75  rse->db, $$);}.u
4eb0: 73 69 6e 67 5f 6f 70 74 28 55 29 20 3a 3a 3d 20  sing_opt(U) ::= 
4ec0: 55 53 49 4e 47 20 4c 50 20 69 6e 73 63 6f 6c 6c  USING LP inscoll
4ed0: 69 73 74 28 4c 29 20 52 50 2e 20 20 7b 55 20 3d  ist(L) RP.  {U =
4ee0: 20 4c 3b 7d 0a 75 73 69 6e 67 5f 6f 70 74 28 55   L;}.using_opt(U
4ef0: 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20  ) ::= .         
4f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
4f10: 55 20 3d 20 30 3b 7d 0a 0a 0a 25 74 79 70 65 20  U = 0;}...%type 
4f20: 6f 72 64 65 72 62 79 5f 6f 70 74 20 7b 45 78 70  orderby_opt {Exp
4f30: 72 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72 75 63  rList*}.%destruc
4f40: 74 6f 72 20 6f 72 64 65 72 62 79 5f 6f 70 74 20  tor orderby_opt 
4f50: 7b 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74  {sqlite3ExprList
4f60: 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64  Delete(pParse->d
4f70: 62 2c 20 24 24 29 3b 7d 0a 25 74 79 70 65 20 73  b, $$);}.%type s
4f80: 6f 72 74 6c 69 73 74 20 7b 45 78 70 72 4c 69 73  ortlist {ExprLis
4f90: 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20  t*}.%destructor 
4fa0: 73 6f 72 74 6c 69 73 74 20 7b 73 71 6c 69 74 65  sortlist {sqlite
4fb0: 33 45 78 70 72 4c 69 73 74 44 65 6c 65 74 65 28  3ExprListDelete(
4fc0: 70 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b  pParse->db, $$);
4fd0: 7d 0a 25 74 79 70 65 20 73 6f 72 74 69 74 65 6d  }.%type sortitem
4fe0: 20 7b 45 78 70 72 2a 7d 0a 25 64 65 73 74 72 75   {Expr*}.%destru
4ff0: 63 74 6f 72 20 73 6f 72 74 69 74 65 6d 20 7b 73  ctor sortitem {s
5000: 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65  qlite3ExprDelete
5010: 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 29  (pParse->db, $$)
5020: 3b 7d 0a 0a 6f 72 64 65 72 62 79 5f 6f 70 74 28  ;}..orderby_opt(
5030: 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20  A) ::= .        
5040: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5050: 20 20 7b 41 20 3d 20 30 3b 7d 0a 6f 72 64 65 72    {A = 0;}.order
5060: 62 79 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 4f 52  by_opt(A) ::= OR
5070: 44 45 52 20 42 59 20 73 6f 72 74 6c 69 73 74 28  DER BY sortlist(
5080: 58 29 2e 20 20 20 20 20 20 7b 41 20 3d 20 58 3b  X).      {A = X;
5090: 7d 0a 73 6f 72 74 6c 69 73 74 28 41 29 20 3a 3a  }.sortlist(A) ::
50a0: 3d 20 73 6f 72 74 6c 69 73 74 28 58 29 20 43 4f  = sortlist(X) CO
50b0: 4d 4d 41 20 73 6f 72 74 69 74 65 6d 28 59 29 20  MMA sortitem(Y) 
50c0: 73 6f 72 74 6f 72 64 65 72 28 5a 29 2e 20 7b 0a  sortorder(Z). {.
50d0: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
50e0: 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72  rListAppend(pPar
50f0: 73 65 2c 58 2c 59 29 3b 0a 20 20 69 66 28 20 41  se,X,Y);.  if( A
5100: 20 29 20 41 2d 3e 61 5b 41 2d 3e 6e 45 78 70 72   ) A->a[A->nExpr
5110: 2d 31 5d 2e 73 6f 72 74 4f 72 64 65 72 20 3d 20  -1].sortOrder = 
5120: 28 75 38 29 5a 3b 0a 7d 0a 73 6f 72 74 6c 69 73  (u8)Z;.}.sortlis
5130: 74 28 41 29 20 3a 3a 3d 20 73 6f 72 74 69 74 65  t(A) ::= sortite
5140: 6d 28 59 29 20 73 6f 72 74 6f 72 64 65 72 28 5a  m(Y) sortorder(Z
5150: 29 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69 74  ). {.  A = sqlit
5160: 65 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64  e3ExprListAppend
5170: 28 70 50 61 72 73 65 2c 30 2c 59 29 3b 0a 20 20  (pParse,0,Y);.  
5180: 69 66 28 20 41 20 26 26 20 41 4c 57 41 59 53 28  if( A && ALWAYS(
5190: 41 2d 3e 61 29 20 29 20 41 2d 3e 61 5b 30 5d 2e  A->a) ) A->a[0].
51a0: 73 6f 72 74 4f 72 64 65 72 20 3d 20 28 75 38 29  sortOrder = (u8)
51b0: 5a 3b 0a 7d 0a 73 6f 72 74 69 74 65 6d 28 41 29  Z;.}.sortitem(A)
51c0: 20 3a 3a 3d 20 65 78 70 72 28 58 29 2e 20 20 20   ::= expr(X).   
51d0: 7b 41 20 3d 20 58 2e 70 45 78 70 72 3b 7d 0a 0a  {A = X.pExpr;}..
51e0: 25 74 79 70 65 20 73 6f 72 74 6f 72 64 65 72 20  %type sortorder 
51f0: 7b 69 6e 74 7d 0a 0a 73 6f 72 74 6f 72 64 65 72  {int}..sortorder
5200: 28 41 29 20 3a 3a 3d 20 41 53 43 2e 20 20 20 20  (A) ::= ASC.    
5210: 20 20 20 20 20 20 20 7b 41 20 3d 20 53 51 4c 49         {A = SQLI
5220: 54 45 5f 53 4f 5f 41 53 43 3b 7d 0a 73 6f 72 74  TE_SO_ASC;}.sort
5230: 6f 72 64 65 72 28 41 29 20 3a 3a 3d 20 44 45 53  order(A) ::= DES
5240: 43 2e 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d  C.          {A =
5250: 20 53 51 4c 49 54 45 5f 53 4f 5f 44 45 53 43 3b   SQLITE_SO_DESC;
5260: 7d 0a 73 6f 72 74 6f 72 64 65 72 28 41 29 20 3a  }.sortorder(A) :
5270: 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20  := .            
5280: 20 20 7b 41 20 3d 20 53 51 4c 49 54 45 5f 53 4f    {A = SQLITE_SO
5290: 5f 41 53 43 3b 7d 0a 0a 25 74 79 70 65 20 67 72  _ASC;}..%type gr
52a0: 6f 75 70 62 79 5f 6f 70 74 20 7b 45 78 70 72 4c  oupby_opt {ExprL
52b0: 69 73 74 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f  ist*}.%destructo
52c0: 72 20 67 72 6f 75 70 62 79 5f 6f 70 74 20 7b 73  r groupby_opt {s
52d0: 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 44 65  qlite3ExprListDe
52e0: 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c  lete(pParse->db,
52f0: 20 24 24 29 3b 7d 0a 67 72 6f 75 70 62 79 5f 6f   $$);}.groupby_o
5300: 70 74 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20  pt(A) ::= .     
5310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5320: 20 7b 41 20 3d 20 30 3b 7d 0a 67 72 6f 75 70 62   {A = 0;}.groupb
5330: 79 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 47 52 4f  y_opt(A) ::= GRO
5340: 55 50 20 42 59 20 6e 65 78 70 72 6c 69 73 74 28  UP BY nexprlist(
5350: 58 29 2e 20 7b 41 20 3d 20 58 3b 7d 0a 0a 25 74  X). {A = X;}..%t
5360: 79 70 65 20 68 61 76 69 6e 67 5f 6f 70 74 20 7b  ype having_opt {
5370: 45 78 70 72 2a 7d 0a 25 64 65 73 74 72 75 63 74  Expr*}.%destruct
5380: 6f 72 20 68 61 76 69 6e 67 5f 6f 70 74 20 7b 73  or having_opt {s
5390: 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65  qlite3ExprDelete
53a0: 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 29  (pParse->db, $$)
53b0: 3b 7d 0a 68 61 76 69 6e 67 5f 6f 70 74 28 41 29  ;}.having_opt(A)
53c0: 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20   ::= .          
53d0: 20 20 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 68        {A = 0;}.h
53e0: 61 76 69 6e 67 5f 6f 70 74 28 41 29 20 3a 3a 3d  aving_opt(A) ::=
53f0: 20 48 41 56 49 4e 47 20 65 78 70 72 28 58 29 2e   HAVING expr(X).
5400: 20 20 7b 41 20 3d 20 58 2e 70 45 78 70 72 3b 7d    {A = X.pExpr;}
5410: 0a 0a 25 74 79 70 65 20 6c 69 6d 69 74 5f 6f 70  ..%type limit_op
5420: 74 20 7b 73 74 72 75 63 74 20 4c 69 6d 69 74 56  t {struct LimitV
5430: 61 6c 7d 0a 0a 2f 2f 20 54 68 65 20 64 65 73 74  al}..// The dest
5440: 72 75 63 74 6f 72 20 66 6f 72 20 6c 69 6d 69 74  ructor for limit
5450: 5f 6f 70 74 20 77 69 6c 6c 20 6e 65 76 65 72 20  _opt will never 
5460: 66 69 72 65 20 69 6e 20 74 68 65 20 63 75 72 72  fire in the curr
5470: 65 6e 74 20 67 72 61 6d 6d 61 72 2e 0a 2f 2f 20  ent grammar..// 
5480: 54 68 65 20 6c 69 6d 69 74 5f 6f 70 74 20 6e 6f  The limit_opt no
5490: 6e 2d 74 65 72 6d 69 6e 61 6c 20 6f 6e 6c 79 20  n-terminal only 
54a0: 6f 63 63 75 72 73 20 61 74 20 74 68 65 20 65 6e  occurs at the en
54b0: 64 20 6f 66 20 61 20 73 69 6e 67 6c 65 20 70 72  d of a single pr
54c0: 6f 64 75 63 74 69 6f 6e 0a 2f 2f 20 72 75 6c 65  oduction.// rule
54d0: 20 66 6f 72 20 53 45 4c 45 43 54 20 73 74 61 74   for SELECT stat
54e0: 65 6d 65 6e 74 73 2e 20 20 41 73 20 73 6f 6f 6e  ements.  As soon
54f0: 20 61 73 20 74 68 65 20 72 75 6c 65 20 74 68 61   as the rule tha
5500: 74 20 63 72 65 61 74 65 20 74 68 65 20 0a 2f 2f  t create the .//
5510: 20 6c 69 6d 69 74 5f 6f 70 74 20 6e 6f 6e 2d 74   limit_opt non-t
5520: 65 72 6d 69 6e 61 6c 20 72 65 64 75 63 65 73 2c  erminal reduces,
5530: 20 74 68 65 20 53 45 4c 45 43 54 20 73 74 61 74   the SELECT stat
5540: 65 6d 65 6e 74 20 72 75 6c 65 20 77 69 6c 6c 20  ement rule will 
5550: 61 6c 73 6f 0a 2f 2f 20 72 65 64 75 63 65 2e 20  also.// reduce. 
5560: 20 53 6f 20 74 68 65 72 65 20 69 73 20 6e 65 76   So there is nev
5570: 65 72 20 61 20 6c 69 6d 69 74 5f 6f 70 74 20 6e  er a limit_opt n
5580: 6f 6e 2d 74 65 72 6d 69 6e 61 6c 20 6f 6e 20 74  on-terminal on t
5590: 68 65 20 73 74 61 63 6b 20 0a 2f 2f 20 65 78 63  he stack .// exc
55a0: 65 70 74 20 61 73 20 61 20 74 72 61 6e 73 69 65  ept as a transie
55b0: 6e 74 2e 20 20 53 6f 20 74 68 65 72 65 20 69 73  nt.  So there is
55c0: 20 6e 65 76 65 72 20 61 6e 79 74 68 69 6e 67 20   never anything 
55d0: 74 6f 20 64 65 73 74 72 6f 79 2e 0a 2f 2f 0a 2f  to destroy..//./
55e0: 2f 25 64 65 73 74 72 75 63 74 6f 72 20 6c 69 6d  /%destructor lim
55f0: 69 74 5f 6f 70 74 20 7b 0a 2f 2f 20 20 73 71 6c  it_opt {.//  sql
5600: 69 74 65 33 45 78 70 72 44 65 6c 65 74 65 28 70  ite3ExprDelete(p
5610: 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 2e 70 4c  Parse->db, $$.pL
5620: 69 6d 69 74 29 3b 0a 2f 2f 20 20 73 71 6c 69 74  imit);.//  sqlit
5630: 65 33 45 78 70 72 44 65 6c 65 74 65 28 70 50 61  e3ExprDelete(pPa
5640: 72 73 65 2d 3e 64 62 2c 20 24 24 2e 70 4f 66 66  rse->db, $$.pOff
5650: 73 65 74 29 3b 0a 2f 2f 7d 0a 6c 69 6d 69 74 5f  set);.//}.limit_
5660: 6f 70 74 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20  opt(A) ::= .    
5670: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5680: 7b 41 2e 70 4c 69 6d 69 74 20 3d 20 30 3b 20 41  {A.pLimit = 0; A
5690: 2e 70 4f 66 66 73 65 74 20 3d 20 30 3b 7d 0a 6c  .pOffset = 0;}.l
56a0: 69 6d 69 74 5f 6f 70 74 28 41 29 20 3a 3a 3d 20  imit_opt(A) ::= 
56b0: 4c 49 4d 49 54 20 65 78 70 72 28 58 29 2e 20 20  LIMIT expr(X).  
56c0: 20 20 20 20 20 7b 41 2e 70 4c 69 6d 69 74 20 3d       {A.pLimit =
56d0: 20 58 2e 70 45 78 70 72 3b 20 41 2e 70 4f 66 66   X.pExpr; A.pOff
56e0: 73 65 74 20 3d 20 30 3b 7d 0a 6c 69 6d 69 74 5f  set = 0;}.limit_
56f0: 6f 70 74 28 41 29 20 3a 3a 3d 20 4c 49 4d 49 54  opt(A) ::= LIMIT
5700: 20 65 78 70 72 28 58 29 20 4f 46 46 53 45 54 20   expr(X) OFFSET 
5710: 65 78 70 72 28 59 29 2e 20 0a 20 20 20 20 20 20  expr(Y). .      
5720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5730: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5740: 7b 41 2e 70 4c 69 6d 69 74 20 3d 20 58 2e 70 45  {A.pLimit = X.pE
5750: 78 70 72 3b 20 41 2e 70 4f 66 66 73 65 74 20 3d  xpr; A.pOffset =
5760: 20 59 2e 70 45 78 70 72 3b 7d 0a 6c 69 6d 69 74   Y.pExpr;}.limit
5770: 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 4c 49 4d 49  _opt(A) ::= LIMI
5780: 54 20 65 78 70 72 28 58 29 20 43 4f 4d 4d 41 20  T expr(X) COMMA 
5790: 65 78 70 72 28 59 29 2e 20 0a 20 20 20 20 20 20  expr(Y). .      
57a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
57b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
57c0: 7b 41 2e 70 4f 66 66 73 65 74 20 3d 20 58 2e 70  {A.pOffset = X.p
57d0: 45 78 70 72 3b 20 41 2e 70 4c 69 6d 69 74 20 3d  Expr; A.pLimit =
57e0: 20 59 2e 70 45 78 70 72 3b 7d 0a 0a 2f 2f 2f 2f   Y.pExpr;}..////
57f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
5800: 2f 2f 2f 2f 2f 2f 2f 20 54 68 65 20 44 45 4c 45  /////// The DELE
5810: 54 45 20 73 74 61 74 65 6d 65 6e 74 20 2f 2f 2f  TE statement ///
5820: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
5830: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a 25 69  //////////.//.%i
5840: 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42  fdef SQLITE_ENAB
5850: 4c 45 5f 55 50 44 41 54 45 5f 44 45 4c 45 54 45  LE_UPDATE_DELETE
5860: 5f 4c 49 4d 49 54 0a 63 6d 64 20 3a 3a 3d 20 44  _LIMIT.cmd ::= D
5870: 45 4c 45 54 45 20 46 52 4f 4d 20 66 75 6c 6c 6e  ELETE FROM fulln
5880: 61 6d 65 28 58 29 20 69 6e 64 65 78 65 64 5f 6f  ame(X) indexed_o
5890: 70 74 28 49 29 20 77 68 65 72 65 5f 6f 70 74 28  pt(I) where_opt(
58a0: 57 29 20 0a 20 20 20 20 20 20 20 20 6f 72 64 65  W) .        orde
58b0: 72 62 79 5f 6f 70 74 28 4f 29 20 6c 69 6d 69 74  rby_opt(O) limit
58c0: 5f 6f 70 74 28 4c 29 2e 20 7b 0a 20 20 73 71 6c  _opt(L). {.  sql
58d0: 69 74 65 33 53 72 63 4c 69 73 74 49 6e 64 65 78  ite3SrcListIndex
58e0: 65 64 42 79 28 70 50 61 72 73 65 2c 20 58 2c 20  edBy(pParse, X, 
58f0: 26 49 29 3b 0a 20 20 57 20 3d 20 73 71 6c 69 74  &I);.  W = sqlit
5900: 65 33 4c 69 6d 69 74 57 68 65 72 65 28 70 50 61  e3LimitWhere(pPa
5910: 72 73 65 2c 20 58 2c 20 57 2c 20 4f 2c 20 4c 2e  rse, X, W, O, L.
5920: 70 4c 69 6d 69 74 2c 20 4c 2e 70 4f 66 66 73 65  pLimit, L.pOffse
5930: 74 2c 20 22 44 45 4c 45 54 45 22 29 3b 0a 20 20  t, "DELETE");.  
5940: 73 71 6c 69 74 65 33 44 65 6c 65 74 65 46 72 6f  sqlite3DeleteFro
5950: 6d 28 70 50 61 72 73 65 2c 58 2c 57 29 3b 0a 7d  m(pParse,X,W);.}
5960: 0a 25 65 6e 64 69 66 0a 25 69 66 6e 64 65 66 20  .%endif.%ifndef 
5970: 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 55 50  SQLITE_ENABLE_UP
5980: 44 41 54 45 5f 44 45 4c 45 54 45 5f 4c 49 4d 49  DATE_DELETE_LIMI
5990: 54 0a 63 6d 64 20 3a 3a 3d 20 44 45 4c 45 54 45  T.cmd ::= DELETE
59a0: 20 46 52 4f 4d 20 66 75 6c 6c 6e 61 6d 65 28 58   FROM fullname(X
59b0: 29 20 69 6e 64 65 78 65 64 5f 6f 70 74 28 49 29  ) indexed_opt(I)
59c0: 20 77 68 65 72 65 5f 6f 70 74 28 57 29 2e 20 7b   where_opt(W). {
59d0: 0a 20 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73  .  sqlite3SrcLis
59e0: 74 49 6e 64 65 78 65 64 42 79 28 70 50 61 72 73  tIndexedBy(pPars
59f0: 65 2c 20 58 2c 20 26 49 29 3b 0a 20 20 73 71 6c  e, X, &I);.  sql
5a00: 69 74 65 33 44 65 6c 65 74 65 46 72 6f 6d 28 70  ite3DeleteFrom(p
5a10: 50 61 72 73 65 2c 58 2c 57 29 3b 0a 7d 0a 25 65  Parse,X,W);.}.%e
5a20: 6e 64 69 66 0a 0a 25 74 79 70 65 20 77 68 65 72  ndif..%type wher
5a30: 65 5f 6f 70 74 20 7b 45 78 70 72 2a 7d 0a 25 64  e_opt {Expr*}.%d
5a40: 65 73 74 72 75 63 74 6f 72 20 77 68 65 72 65 5f  estructor where_
5a50: 6f 70 74 20 7b 73 71 6c 69 74 65 33 45 78 70 72  opt {sqlite3Expr
5a60: 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64  Delete(pParse->d
5a70: 62 2c 20 24 24 29 3b 7d 0a 0a 77 68 65 72 65 5f  b, $$);}..where_
5a80: 6f 70 74 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20  opt(A) ::= .    
5a90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5aa0: 7b 41 20 3d 20 30 3b 7d 0a 77 68 65 72 65 5f 6f  {A = 0;}.where_o
5ab0: 70 74 28 41 29 20 3a 3a 3d 20 57 48 45 52 45 20  pt(A) ::= WHERE 
5ac0: 65 78 70 72 28 58 29 2e 20 20 20 20 20 20 20 7b  expr(X).       {
5ad0: 41 20 3d 20 58 2e 70 45 78 70 72 3b 7d 0a 0a 2f  A = X.pExpr;}../
5ae0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
5af0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68 65 20 55 50  ///////// The UP
5b00: 44 41 54 45 20 63 6f 6d 6d 61 6e 64 20 2f 2f 2f  DATE command ///
5b10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
5b20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f  /////////////.//
5b30: 0a 25 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45  .%ifdef SQLITE_E
5b40: 4e 41 42 4c 45 5f 55 50 44 41 54 45 5f 44 45 4c  NABLE_UPDATE_DEL
5b50: 45 54 45 5f 4c 49 4d 49 54 0a 63 6d 64 20 3a 3a  ETE_LIMIT.cmd ::
5b60: 3d 20 55 50 44 41 54 45 20 6f 72 63 6f 6e 66 28  = UPDATE orconf(
5b70: 52 29 20 66 75 6c 6c 6e 61 6d 65 28 58 29 20 69  R) fullname(X) i
5b80: 6e 64 65 78 65 64 5f 6f 70 74 28 49 29 20 53 45  ndexed_opt(I) SE
5b90: 54 20 73 65 74 6c 69 73 74 28 59 29 20 77 68 65  T setlist(Y) whe
5ba0: 72 65 5f 6f 70 74 28 57 29 20 6f 72 64 65 72 62  re_opt(W) orderb
5bb0: 79 5f 6f 70 74 28 4f 29 20 6c 69 6d 69 74 5f 6f  y_opt(O) limit_o
5bc0: 70 74 28 4c 29 2e 20 20 7b 0a 20 20 73 71 6c 69  pt(L).  {.  sqli
5bd0: 74 65 33 53 72 63 4c 69 73 74 49 6e 64 65 78 65  te3SrcListIndexe
5be0: 64 42 79 28 70 50 61 72 73 65 2c 20 58 2c 20 26  dBy(pParse, X, &
5bf0: 49 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70  I);.  sqlite3Exp
5c00: 72 4c 69 73 74 43 68 65 63 6b 4c 65 6e 67 74 68  rListCheckLength
5c10: 28 70 50 61 72 73 65 2c 59 2c 22 73 65 74 20 6c  (pParse,Y,"set l
5c20: 69 73 74 22 29 3b 20 0a 20 20 57 20 3d 20 73 71  ist"); .  W = sq
5c30: 6c 69 74 65 33 4c 69 6d 69 74 57 68 65 72 65 28  lite3LimitWhere(
5c40: 70 50 61 72 73 65 2c 20 58 2c 20 57 2c 20 4f 2c  pParse, X, W, O,
5c50: 20 4c 2e 70 4c 69 6d 69 74 2c 20 4c 2e 70 4f 66   L.pLimit, L.pOf
5c60: 66 73 65 74 2c 20 22 55 50 44 41 54 45 22 29 3b  fset, "UPDATE");
5c70: 0a 20 20 73 71 6c 69 74 65 33 55 70 64 61 74 65  .  sqlite3Update
5c80: 28 70 50 61 72 73 65 2c 58 2c 59 2c 57 2c 52 29  (pParse,X,Y,W,R)
5c90: 3b 0a 7d 0a 25 65 6e 64 69 66 0a 25 69 66 6e 64  ;.}.%endif.%ifnd
5ca0: 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45  ef SQLITE_ENABLE
5cb0: 5f 55 50 44 41 54 45 5f 44 45 4c 45 54 45 5f 4c  _UPDATE_DELETE_L
5cc0: 49 4d 49 54 0a 63 6d 64 20 3a 3a 3d 20 55 50 44  IMIT.cmd ::= UPD
5cd0: 41 54 45 20 6f 72 63 6f 6e 66 28 52 29 20 66 75  ATE orconf(R) fu
5ce0: 6c 6c 6e 61 6d 65 28 58 29 20 69 6e 64 65 78 65  llname(X) indexe
5cf0: 64 5f 6f 70 74 28 49 29 20 53 45 54 20 73 65 74  d_opt(I) SET set
5d00: 6c 69 73 74 28 59 29 20 77 68 65 72 65 5f 6f 70  list(Y) where_op
5d10: 74 28 57 29 2e 20 20 7b 0a 20 20 73 71 6c 69 74  t(W).  {.  sqlit
5d20: 65 33 53 72 63 4c 69 73 74 49 6e 64 65 78 65 64  e3SrcListIndexed
5d30: 42 79 28 70 50 61 72 73 65 2c 20 58 2c 20 26 49  By(pParse, X, &I
5d40: 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72  );.  sqlite3Expr
5d50: 4c 69 73 74 43 68 65 63 6b 4c 65 6e 67 74 68 28  ListCheckLength(
5d60: 70 50 61 72 73 65 2c 59 2c 22 73 65 74 20 6c 69  pParse,Y,"set li
5d70: 73 74 22 29 3b 20 0a 20 20 73 71 6c 69 74 65 33  st"); .  sqlite3
5d80: 55 70 64 61 74 65 28 70 50 61 72 73 65 2c 58 2c  Update(pParse,X,
5d90: 59 2c 57 2c 52 29 3b 0a 7d 0a 25 65 6e 64 69 66  Y,W,R);.}.%endif
5da0: 0a 0a 25 74 79 70 65 20 73 65 74 6c 69 73 74 20  ..%type setlist 
5db0: 7b 45 78 70 72 4c 69 73 74 2a 7d 0a 25 64 65 73  {ExprList*}.%des
5dc0: 74 72 75 63 74 6f 72 20 73 65 74 6c 69 73 74 20  tructor setlist 
5dd0: 7b 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74  {sqlite3ExprList
5de0: 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64  Delete(pParse->d
5df0: 62 2c 20 24 24 29 3b 7d 0a 0a 73 65 74 6c 69 73  b, $$);}..setlis
5e00: 74 28 41 29 20 3a 3a 3d 20 73 65 74 6c 69 73 74  t(A) ::= setlist
5e10: 28 5a 29 20 43 4f 4d 4d 41 20 6e 6d 28 58 29 20  (Z) COMMA nm(X) 
5e20: 45 51 20 65 78 70 72 28 59 29 2e 20 7b 0a 20 20  EQ expr(Y). {.  
5e30: 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c  A = sqlite3ExprL
5e40: 69 73 74 41 70 70 65 6e 64 28 70 50 61 72 73 65  istAppend(pParse
5e50: 2c 20 5a 2c 20 59 2e 70 45 78 70 72 29 3b 0a 20  , Z, Y.pExpr);. 
5e60: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
5e70: 53 65 74 4e 61 6d 65 28 70 50 61 72 73 65 2c 20  SetName(pParse, 
5e80: 41 2c 20 26 58 2c 20 31 29 3b 0a 7d 0a 73 65 74  A, &X, 1);.}.set
5e90: 6c 69 73 74 28 41 29 20 3a 3a 3d 20 6e 6d 28 58  list(A) ::= nm(X
5ea0: 29 20 45 51 20 65 78 70 72 28 59 29 2e 20 7b 0a  ) EQ expr(Y). {.
5eb0: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
5ec0: 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72  rListAppend(pPar
5ed0: 73 65 2c 20 30 2c 20 59 2e 70 45 78 70 72 29 3b  se, 0, Y.pExpr);
5ee0: 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69  .  sqlite3ExprLi
5ef0: 73 74 53 65 74 4e 61 6d 65 28 70 50 61 72 73 65  stSetName(pParse
5f00: 2c 20 41 2c 20 26 58 2c 20 31 29 3b 0a 7d 0a 0a  , A, &X, 1);.}..
5f10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
5f20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68 65 20 49  ////////// The I
5f30: 4e 53 45 52 54 20 63 6f 6d 6d 61 6e 64 20 2f 2f  NSERT command //
5f40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
5f50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a  ///////////////.
5f60: 2f 2f 0a 63 6d 64 20 3a 3a 3d 20 69 6e 73 65 72  //.cmd ::= inser
5f70: 74 5f 63 6d 64 28 52 29 20 49 4e 54 4f 20 66 75  t_cmd(R) INTO fu
5f80: 6c 6c 6e 61 6d 65 28 58 29 20 69 6e 73 63 6f 6c  llname(X) inscol
5f90: 6c 69 73 74 5f 6f 70 74 28 46 29 20 0a 20 20 20  list_opt(F) .   
5fa0: 20 20 20 20 20 56 41 4c 55 45 53 20 4c 50 20 69       VALUES LP i
5fb0: 74 65 6d 6c 69 73 74 28 59 29 20 52 50 2e 0a 20  temlist(Y) RP.. 
5fc0: 20 20 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69             {sqli
5fd0: 74 65 33 49 6e 73 65 72 74 28 70 50 61 72 73 65  te3Insert(pParse
5fe0: 2c 20 58 2c 20 59 2c 20 30 2c 20 46 2c 20 52 29  , X, Y, 0, F, R)
5ff0: 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 69 6e 73 65 72  ;}.cmd ::= inser
6000: 74 5f 63 6d 64 28 52 29 20 49 4e 54 4f 20 66 75  t_cmd(R) INTO fu
6010: 6c 6c 6e 61 6d 65 28 58 29 20 69 6e 73 63 6f 6c  llname(X) inscol
6020: 6c 69 73 74 5f 6f 70 74 28 46 29 20 73 65 6c 65  list_opt(F) sele
6030: 63 74 28 53 29 2e 0a 20 20 20 20 20 20 20 20 20  ct(S)..         
6040: 20 20 20 7b 73 71 6c 69 74 65 33 49 6e 73 65 72     {sqlite3Inser
6050: 74 28 70 50 61 72 73 65 2c 20 58 2c 20 30 2c 20  t(pParse, X, 0, 
6060: 53 2c 20 46 2c 20 52 29 3b 7d 0a 63 6d 64 20 3a  S, F, R);}.cmd :
6070: 3a 3d 20 69 6e 73 65 72 74 5f 63 6d 64 28 52 29  := insert_cmd(R)
6080: 20 49 4e 54 4f 20 66 75 6c 6c 6e 61 6d 65 28 58   INTO fullname(X
6090: 29 20 69 6e 73 63 6f 6c 6c 69 73 74 5f 6f 70 74  ) inscollist_opt
60a0: 28 46 29 20 44 45 46 41 55 4c 54 20 56 41 4c 55  (F) DEFAULT VALU
60b0: 45 53 2e 0a 20 20 20 20 20 20 20 20 20 20 20 20  ES..            
60c0: 7b 73 71 6c 69 74 65 33 49 6e 73 65 72 74 28 70  {sqlite3Insert(p
60d0: 50 61 72 73 65 2c 20 58 2c 20 30 2c 20 30 2c 20  Parse, X, 0, 0, 
60e0: 46 2c 20 52 29 3b 7d 0a 0a 25 74 79 70 65 20 69  F, R);}..%type i
60f0: 6e 73 65 72 74 5f 63 6d 64 20 7b 75 38 7d 0a 69  nsert_cmd {u8}.i
6100: 6e 73 65 72 74 5f 63 6d 64 28 41 29 20 3a 3a 3d  nsert_cmd(A) ::=
6110: 20 49 4e 53 45 52 54 20 6f 72 63 6f 6e 66 28 52   INSERT orconf(R
6120: 29 2e 20 20 20 7b 41 20 3d 20 52 3b 7d 0a 69 6e  ).   {A = R;}.in
6130: 73 65 72 74 5f 63 6d 64 28 41 29 20 3a 3a 3d 20  sert_cmd(A) ::= 
6140: 52 45 50 4c 41 43 45 2e 20 20 20 20 20 20 20 20  REPLACE.        
6150: 20 20 20 20 7b 41 20 3d 20 4f 45 5f 52 65 70 6c      {A = OE_Repl
6160: 61 63 65 3b 7d 0a 0a 0a 25 74 79 70 65 20 69 74  ace;}...%type it
6170: 65 6d 6c 69 73 74 20 7b 45 78 70 72 4c 69 73 74  emlist {ExprList
6180: 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72 20 69  *}.%destructor i
6190: 74 65 6d 6c 69 73 74 20 7b 73 71 6c 69 74 65 33  temlist {sqlite3
61a0: 45 78 70 72 4c 69 73 74 44 65 6c 65 74 65 28 70  ExprListDelete(p
61b0: 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d  Parse->db, $$);}
61c0: 0a 0a 69 74 65 6d 6c 69 73 74 28 41 29 20 3a 3a  ..itemlist(A) ::
61d0: 3d 20 69 74 65 6d 6c 69 73 74 28 58 29 20 43 4f  = itemlist(X) CO
61e0: 4d 4d 41 20 65 78 70 72 28 59 29 2e 0a 20 20 20  MMA expr(Y)..   
61f0: 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70   {A = sqlite3Exp
6200: 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72  rListAppend(pPar
6210: 73 65 2c 58 2c 59 2e 70 45 78 70 72 29 3b 7d 0a  se,X,Y.pExpr);}.
6220: 69 74 65 6d 6c 69 73 74 28 41 29 20 3a 3a 3d 20  itemlist(A) ::= 
6230: 65 78 70 72 28 58 29 2e 0a 20 20 20 20 7b 41 20  expr(X)..    {A 
6240: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73  = sqlite3ExprLis
6250: 74 41 70 70 65 6e 64 28 70 50 61 72 73 65 2c 30  tAppend(pParse,0
6260: 2c 58 2e 70 45 78 70 72 29 3b 7d 0a 0a 25 74 79  ,X.pExpr);}..%ty
6270: 70 65 20 69 6e 73 63 6f 6c 6c 69 73 74 5f 6f 70  pe inscollist_op
6280: 74 20 7b 49 64 4c 69 73 74 2a 7d 0a 25 64 65 73  t {IdList*}.%des
6290: 74 72 75 63 74 6f 72 20 69 6e 73 63 6f 6c 6c 69  tructor inscolli
62a0: 73 74 5f 6f 70 74 20 7b 73 71 6c 69 74 65 33 49  st_opt {sqlite3I
62b0: 64 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61 72  dListDelete(pPar
62c0: 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 25 74  se->db, $$);}.%t
62d0: 79 70 65 20 69 6e 73 63 6f 6c 6c 69 73 74 20 7b  ype inscollist {
62e0: 49 64 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72 75  IdList*}.%destru
62f0: 63 74 6f 72 20 69 6e 73 63 6f 6c 6c 69 73 74 20  ctor inscollist 
6300: 7b 73 71 6c 69 74 65 33 49 64 4c 69 73 74 44 65  {sqlite3IdListDe
6310: 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c  lete(pParse->db,
6320: 20 24 24 29 3b 7d 0a 0a 69 6e 73 63 6f 6c 6c 69   $$);}..inscolli
6330: 73 74 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 2e 20  st_opt(A) ::= . 
6340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6350: 20 20 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 69        {A = 0;}.i
6360: 6e 73 63 6f 6c 6c 69 73 74 5f 6f 70 74 28 41 29  nscollist_opt(A)
6370: 20 3a 3a 3d 20 4c 50 20 69 6e 73 63 6f 6c 6c 69   ::= LP inscolli
6380: 73 74 28 58 29 20 52 50 2e 20 20 20 20 7b 41 20  st(X) RP.    {A 
6390: 3d 20 58 3b 7d 0a 69 6e 73 63 6f 6c 6c 69 73 74  = X;}.inscollist
63a0: 28 41 29 20 3a 3a 3d 20 69 6e 73 63 6f 6c 6c 69  (A) ::= inscolli
63b0: 73 74 28 58 29 20 43 4f 4d 4d 41 20 6e 6d 28 59  st(X) COMMA nm(Y
63c0: 29 2e 0a 20 20 20 20 7b 41 20 3d 20 73 71 6c 69  )..    {A = sqli
63d0: 74 65 33 49 64 4c 69 73 74 41 70 70 65 6e 64 28  te3IdListAppend(
63e0: 70 50 61 72 73 65 2d 3e 64 62 2c 58 2c 26 59 29  pParse->db,X,&Y)
63f0: 3b 7d 0a 69 6e 73 63 6f 6c 6c 69 73 74 28 41 29  ;}.inscollist(A)
6400: 20 3a 3a 3d 20 6e 6d 28 59 29 2e 0a 20 20 20 20   ::= nm(Y)..    
6410: 7b 41 20 3d 20 73 71 6c 69 74 65 33 49 64 4c 69  {A = sqlite3IdLi
6420: 73 74 41 70 70 65 6e 64 28 70 50 61 72 73 65 2d  stAppend(pParse-
6430: 3e 64 62 2c 30 2c 26 59 29 3b 7d 0a 0a 2f 2f 2f  >db,0,&Y);}..///
6440: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6450: 2f 2f 2f 2f 2f 2f 2f 2f 20 45 78 70 72 65 73 73  //////// Express
6460: 69 6f 6e 20 50 72 6f 63 65 73 73 69 6e 67 20 2f  ion Processing /
6470: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
6480: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f 0a  ////////////.//.
6490: 0a 25 74 79 70 65 20 65 78 70 72 20 7b 45 78 70  .%type expr {Exp
64a0: 72 53 70 61 6e 7d 0a 25 64 65 73 74 72 75 63 74  rSpan}.%destruct
64b0: 6f 72 20 65 78 70 72 20 7b 73 71 6c 69 74 65 33  or expr {sqlite3
64c0: 45 78 70 72 44 65 6c 65 74 65 28 70 50 61 72 73  ExprDelete(pPars
64d0: 65 2d 3e 64 62 2c 20 24 24 2e 70 45 78 70 72 29  e->db, $$.pExpr)
64e0: 3b 7d 0a 25 74 79 70 65 20 74 65 72 6d 20 7b 45  ;}.%type term {E
64f0: 78 70 72 53 70 61 6e 7d 0a 25 64 65 73 74 72 75  xprSpan}.%destru
6500: 63 74 6f 72 20 74 65 72 6d 20 7b 73 71 6c 69 74  ctor term {sqlit
6510: 65 33 45 78 70 72 44 65 6c 65 74 65 28 70 50 61  e3ExprDelete(pPa
6520: 72 73 65 2d 3e 64 62 2c 20 24 24 2e 70 45 78 70  rse->db, $$.pExp
6530: 72 29 3b 7d 0a 0a 25 69 6e 63 6c 75 64 65 20 7b  r);}..%include {
6540: 0a 20 20 2f 2a 20 54 68 69 73 20 69 73 20 61 20  .  /* This is a 
6550: 75 74 69 6c 69 74 79 20 72 6f 75 74 69 6e 65 20  utility routine 
6560: 75 73 65 64 20 74 6f 20 73 65 74 20 74 68 65 20  used to set the 
6570: 45 78 70 72 53 70 61 6e 2e 7a 53 74 61 72 74 20  ExprSpan.zStart 
6580: 61 6e 64 0a 20 20 2a 2a 20 45 78 70 72 53 70 61  and.  ** ExprSpa
6590: 6e 2e 7a 45 6e 64 20 76 61 6c 75 65 73 20 6f 66  n.zEnd values of
65a0: 20 70 4f 75 74 20 73 6f 20 74 68 61 74 20 74 68   pOut so that th
65b0: 65 20 73 70 61 6e 20 63 6f 76 65 72 73 20 74 68  e span covers th
65c0: 65 20 63 6f 6d 70 6c 65 74 65 0a 20 20 2a 2a 20  e complete.  ** 
65d0: 72 61 6e 67 65 20 6f 66 20 74 65 78 74 20 62 65  range of text be
65e0: 67 69 6e 6e 69 6e 67 20 77 69 74 68 20 70 53 74  ginning with pSt
65f0: 61 72 74 20 61 6e 64 20 67 6f 69 6e 67 20 74 6f  art and going to
6600: 20 74 68 65 20 65 6e 64 20 6f 66 20 70 45 6e 64   the end of pEnd
6610: 2e 0a 20 20 2a 2f 0a 20 20 73 74 61 74 69 63 20  ..  */.  static 
6620: 76 6f 69 64 20 73 70 61 6e 53 65 74 28 45 78 70  void spanSet(Exp
6630: 72 53 70 61 6e 20 2a 70 4f 75 74 2c 20 54 6f 6b  rSpan *pOut, Tok
6640: 65 6e 20 2a 70 53 74 61 72 74 2c 20 54 6f 6b 65  en *pStart, Toke
6650: 6e 20 2a 70 45 6e 64 29 7b 0a 20 20 20 20 70 4f  n *pEnd){.    pO
6660: 75 74 2d 3e 7a 53 74 61 72 74 20 3d 20 70 53 74  ut->zStart = pSt
6670: 61 72 74 2d 3e 7a 3b 0a 20 20 20 20 70 4f 75 74  art->z;.    pOut
6680: 2d 3e 7a 45 6e 64 20 3d 20 26 70 45 6e 64 2d 3e  ->zEnd = &pEnd->
6690: 7a 5b 70 45 6e 64 2d 3e 6e 5d 3b 0a 20 20 7d 0a  z[pEnd->n];.  }.
66a0: 0a 20 20 2f 2a 20 43 6f 6e 73 74 72 75 63 74 20  .  /* Construct 
66b0: 61 20 6e 65 77 20 45 78 70 72 20 6f 62 6a 65 63  a new Expr objec
66c0: 74 20 66 72 6f 6d 20 61 20 73 69 6e 67 6c 65 20  t from a single 
66d0: 69 64 65 6e 74 69 66 69 65 72 2e 20 20 55 73 65  identifier.  Use
66e0: 20 74 68 65 0a 20 20 2a 2a 20 6e 65 77 20 45 78   the.  ** new Ex
66f0: 70 72 20 74 6f 20 70 6f 70 75 6c 61 74 65 20 70  pr to populate p
6700: 4f 75 74 2e 20 20 53 65 74 20 74 68 65 20 73 70  Out.  Set the sp
6710: 61 6e 20 6f 66 20 70 4f 75 74 20 74 6f 20 62 65  an of pOut to be
6720: 20 74 68 65 20 69 64 65 6e 74 69 66 69 65 72 0a   the identifier.
6730: 20 20 2a 2a 20 74 68 61 74 20 63 72 65 61 74 65    ** that create
6740: 64 20 74 68 65 20 65 78 70 72 65 73 73 69 6f 6e  d the expression
6750: 2e 0a 20 20 2a 2f 0a 20 20 73 74 61 74 69 63 20  ..  */.  static 
6760: 76 6f 69 64 20 73 70 61 6e 45 78 70 72 28 45 78  void spanExpr(Ex
6770: 70 72 53 70 61 6e 20 2a 70 4f 75 74 2c 20 50 61  prSpan *pOut, Pa
6780: 72 73 65 20 2a 70 50 61 72 73 65 2c 20 69 6e 74  rse *pParse, int
6790: 20 6f 70 2c 20 54 6f 6b 65 6e 20 2a 70 56 61 6c   op, Token *pVal
67a0: 75 65 29 7b 0a 20 20 20 20 70 4f 75 74 2d 3e 70  ue){.    pOut->p
67b0: 45 78 70 72 20 3d 20 73 71 6c 69 74 65 33 50 45  Expr = sqlite3PE
67c0: 78 70 72 28 70 50 61 72 73 65 2c 20 6f 70 2c 20  xpr(pParse, op, 
67d0: 30 2c 20 30 2c 20 70 56 61 6c 75 65 29 3b 0a 20  0, 0, pValue);. 
67e0: 20 20 20 70 4f 75 74 2d 3e 7a 53 74 61 72 74 20     pOut->zStart 
67f0: 3d 20 70 56 61 6c 75 65 2d 3e 7a 3b 0a 20 20 20  = pValue->z;.   
6800: 20 70 4f 75 74 2d 3e 7a 45 6e 64 20 3d 20 26 70   pOut->zEnd = &p
6810: 56 61 6c 75 65 2d 3e 7a 5b 70 56 61 6c 75 65 2d  Value->z[pValue-
6820: 3e 6e 5d 3b 0a 20 20 7d 0a 7d 0a 0a 65 78 70 72  >n];.  }.}..expr
6830: 28 41 29 20 3a 3a 3d 20 74 65 72 6d 28 58 29 2e  (A) ::= term(X).
6840: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 41 20               {A 
6850: 3d 20 58 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a  = X;}.expr(A) ::
6860: 3d 20 4c 50 28 42 29 20 65 78 70 72 28 58 29 20  = LP(B) expr(X) 
6870: 52 50 28 45 29 2e 20 7b 41 2e 70 45 78 70 72 20  RP(E). {A.pExpr 
6880: 3d 20 58 2e 70 45 78 70 72 3b 20 73 70 61 6e 53  = X.pExpr; spanS
6890: 65 74 28 26 41 2c 26 42 2c 26 45 29 3b 7d 0a 74  et(&A,&B,&E);}.t
68a0: 65 72 6d 28 41 29 20 3a 3a 3d 20 4e 55 4c 4c 28  erm(A) ::= NULL(
68b0: 58 29 2e 20 20 20 20 20 20 20 20 20 20 20 20 20  X).             
68c0: 7b 73 70 61 6e 45 78 70 72 28 26 41 2c 20 70 50  {spanExpr(&A, pP
68d0: 61 72 73 65 2c 20 40 58 2c 20 26 58 29 3b 7d 0a  arse, @X, &X);}.
68e0: 65 78 70 72 28 41 29 20 3a 3a 3d 20 69 64 28 58  expr(A) ::= id(X
68f0: 29 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ).              
6900: 20 7b 73 70 61 6e 45 78 70 72 28 26 41 2c 20 70   {spanExpr(&A, p
6910: 50 61 72 73 65 2c 20 54 4b 5f 49 44 2c 20 26 58  Parse, TK_ID, &X
6920: 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20  );}.expr(A) ::= 
6930: 4a 4f 49 4e 5f 4b 57 28 58 29 2e 20 20 20 20 20  JOIN_KW(X).     
6940: 20 20 20 20 20 7b 73 70 61 6e 45 78 70 72 28 26       {spanExpr(&
6950: 41 2c 20 70 50 61 72 73 65 2c 20 54 4b 5f 49 44  A, pParse, TK_ID
6960: 2c 20 26 58 29 3b 7d 0a 65 78 70 72 28 41 29 20  , &X);}.expr(A) 
6970: 3a 3a 3d 20 6e 6d 28 58 29 20 44 4f 54 20 6e 6d  ::= nm(X) DOT nm
6980: 28 59 29 2e 20 7b 0a 20 20 45 78 70 72 20 2a 74  (Y). {.  Expr *t
6990: 65 6d 70 31 20 3d 20 73 71 6c 69 74 65 33 50 45  emp1 = sqlite3PE
69a0: 78 70 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 49  xpr(pParse, TK_I
69b0: 44 2c 20 30 2c 20 30 2c 20 26 58 29 3b 0a 20 20  D, 0, 0, &X);.  
69c0: 45 78 70 72 20 2a 74 65 6d 70 32 20 3d 20 73 71  Expr *temp2 = sq
69d0: 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73  lite3PExpr(pPars
69e0: 65 2c 20 54 4b 5f 49 44 2c 20 30 2c 20 30 2c 20  e, TK_ID, 0, 0, 
69f0: 26 59 29 3b 0a 20 20 41 2e 70 45 78 70 72 20 3d  &Y);.  A.pExpr =
6a00: 20 73 71 6c 69 74 65 33 50 45 78 70 72 28 70 50   sqlite3PExpr(pP
6a10: 61 72 73 65 2c 20 54 4b 5f 44 4f 54 2c 20 74 65  arse, TK_DOT, te
6a20: 6d 70 31 2c 20 74 65 6d 70 32 2c 20 30 29 3b 0a  mp1, temp2, 0);.
6a30: 20 20 73 70 61 6e 53 65 74 28 26 41 2c 26 58 2c    spanSet(&A,&X,
6a40: 26 59 29 3b 0a 7d 0a 65 78 70 72 28 41 29 20 3a  &Y);.}.expr(A) :
6a50: 3a 3d 20 6e 6d 28 58 29 20 44 4f 54 20 6e 6d 28  := nm(X) DOT nm(
6a60: 59 29 20 44 4f 54 20 6e 6d 28 5a 29 2e 20 7b 0a  Y) DOT nm(Z). {.
6a70: 20 20 45 78 70 72 20 2a 74 65 6d 70 31 20 3d 20    Expr *temp1 = 
6a80: 73 71 6c 69 74 65 33 50 45 78 70 72 28 70 50 61  sqlite3PExpr(pPa
6a90: 72 73 65 2c 20 54 4b 5f 49 44 2c 20 30 2c 20 30  rse, TK_ID, 0, 0
6aa0: 2c 20 26 58 29 3b 0a 20 20 45 78 70 72 20 2a 74  , &X);.  Expr *t
6ab0: 65 6d 70 32 20 3d 20 73 71 6c 69 74 65 33 50 45  emp2 = sqlite3PE
6ac0: 78 70 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 49  xpr(pParse, TK_I
6ad0: 44 2c 20 30 2c 20 30 2c 20 26 59 29 3b 0a 20 20  D, 0, 0, &Y);.  
6ae0: 45 78 70 72 20 2a 74 65 6d 70 33 20 3d 20 73 71  Expr *temp3 = sq
6af0: 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73  lite3PExpr(pPars
6b00: 65 2c 20 54 4b 5f 49 44 2c 20 30 2c 20 30 2c 20  e, TK_ID, 0, 0, 
6b10: 26 5a 29 3b 0a 20 20 45 78 70 72 20 2a 74 65 6d  &Z);.  Expr *tem
6b20: 70 34 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70  p4 = sqlite3PExp
6b30: 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 44 4f 54  r(pParse, TK_DOT
6b40: 2c 20 74 65 6d 70 32 2c 20 74 65 6d 70 33 2c 20  , temp2, temp3, 
6b50: 30 29 3b 0a 20 20 41 2e 70 45 78 70 72 20 3d 20  0);.  A.pExpr = 
6b60: 73 71 6c 69 74 65 33 50 45 78 70 72 28 70 50 61  sqlite3PExpr(pPa
6b70: 72 73 65 2c 20 54 4b 5f 44 4f 54 2c 20 74 65 6d  rse, TK_DOT, tem
6b80: 70 31 2c 20 74 65 6d 70 34 2c 20 30 29 3b 0a 20  p1, temp4, 0);. 
6b90: 20 73 70 61 6e 53 65 74 28 26 41 2c 26 58 2c 26   spanSet(&A,&X,&
6ba0: 5a 29 3b 0a 7d 0a 74 65 72 6d 28 41 29 20 3a 3a  Z);.}.term(A) ::
6bb0: 3d 20 49 4e 54 45 47 45 52 7c 46 4c 4f 41 54 7c  = INTEGER|FLOAT|
6bc0: 42 4c 4f 42 28 58 29 2e 20 20 7b 73 70 61 6e 45  BLOB(X).  {spanE
6bd0: 78 70 72 28 26 41 2c 20 70 50 61 72 73 65 2c 20  xpr(&A, pParse, 
6be0: 40 58 2c 20 26 58 29 3b 7d 0a 74 65 72 6d 28 41  @X, &X);}.term(A
6bf0: 29 20 3a 3a 3d 20 53 54 52 49 4e 47 28 58 29 2e  ) ::= STRING(X).
6c00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 73                {s
6c10: 70 61 6e 45 78 70 72 28 26 41 2c 20 70 50 61 72  panExpr(&A, pPar
6c20: 73 65 2c 20 40 58 2c 20 26 58 29 3b 7d 0a 65 78  se, @X, &X);}.ex
6c30: 70 72 28 41 29 20 3a 3a 3d 20 52 45 47 49 53 54  pr(A) ::= REGIST
6c40: 45 52 28 58 29 2e 20 20 20 20 20 7b 0a 20 20 2f  ER(X).     {.  /
6c50: 2a 20 57 68 65 6e 20 64 6f 69 6e 67 20 61 20 6e  * When doing a n
6c60: 65 73 74 65 64 20 70 61 72 73 65 2c 20 6f 6e 65  ested parse, one
6c70: 20 63 61 6e 20 69 6e 63 6c 75 64 65 20 74 65 72   can include ter
6c80: 6d 73 20 69 6e 20 61 6e 20 65 78 70 72 65 73 73  ms in an express
6c90: 69 6f 6e 0a 20 20 2a 2a 20 74 68 61 74 20 6c 6f  ion.  ** that lo
6ca0: 6f 6b 20 6c 69 6b 65 20 74 68 69 73 3a 20 20 20  ok like this:   
6cb0: 23 31 20 23 32 20 2e 2e 2e 20 20 54 68 65 73 65  #1 #2 ...  These
6cc0: 20 74 65 72 6d 73 20 72 65 66 65 72 20 74 6f 20   terms refer to 
6cd0: 72 65 67 69 73 74 65 72 73 0a 20 20 2a 2a 20 69  registers.  ** i
6ce0: 6e 20 74 68 65 20 76 69 72 74 75 61 6c 20 6d 61  n the virtual ma
6cf0: 63 68 69 6e 65 2e 20 20 23 4e 20 69 73 20 74 68  chine.  #N is th
6d00: 65 20 4e 2d 74 68 20 72 65 67 69 73 74 65 72 2e  e N-th register.
6d10: 20 2a 2f 0a 20 20 69 66 28 20 70 50 61 72 73 65   */.  if( pParse
6d20: 2d 3e 6e 65 73 74 65 64 3d 3d 30 20 29 7b 0a 20  ->nested==0 ){. 
6d30: 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d     sqlite3ErrorM
6d40: 73 67 28 70 50 61 72 73 65 2c 20 22 6e 65 61 72  sg(pParse, "near
6d50: 20 5c 22 25 54 5c 22 3a 20 73 79 6e 74 61 78 20   \"%T\": syntax 
6d60: 65 72 72 6f 72 22 2c 20 26 58 29 3b 0a 20 20 20  error", &X);.   
6d70: 20 41 2e 70 45 78 70 72 20 3d 20 30 3b 0a 20 20   A.pExpr = 0;.  
6d80: 7d 65 6c 73 65 7b 0a 20 20 20 20 41 2e 70 45 78  }else{.    A.pEx
6d90: 70 72 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70  pr = sqlite3PExp
6da0: 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 52 45 47  r(pParse, TK_REG
6db0: 49 53 54 45 52 2c 20 30 2c 20 30 2c 20 26 58 29  ISTER, 0, 0, &X)
6dc0: 3b 0a 20 20 20 20 69 66 28 20 41 2e 70 45 78 70  ;.    if( A.pExp
6dd0: 72 20 29 20 73 71 6c 69 74 65 33 47 65 74 49 6e  r ) sqlite3GetIn
6de0: 74 33 32 28 26 58 2e 7a 5b 31 5d 2c 20 26 41 2e  t32(&X.z[1], &A.
6df0: 70 45 78 70 72 2d 3e 69 54 61 62 6c 65 29 3b 0a  pExpr->iTable);.
6e00: 20 20 7d 0a 20 20 73 70 61 6e 53 65 74 28 26 41    }.  spanSet(&A
6e10: 2c 20 26 58 2c 20 26 58 29 3b 0a 7d 0a 65 78 70  , &X, &X);.}.exp
6e20: 72 28 41 29 20 3a 3a 3d 20 56 41 52 49 41 42 4c  r(A) ::= VARIABL
6e30: 45 28 58 29 2e 20 20 20 20 20 7b 0a 20 20 73 70  E(X).     {.  sp
6e40: 61 6e 45 78 70 72 28 26 41 2c 20 70 50 61 72 73  anExpr(&A, pPars
6e50: 65 2c 20 54 4b 5f 56 41 52 49 41 42 4c 45 2c 20  e, TK_VARIABLE, 
6e60: 26 58 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78  &X);.  sqlite3Ex
6e70: 70 72 41 73 73 69 67 6e 56 61 72 4e 75 6d 62 65  prAssignVarNumbe
6e80: 72 28 70 50 61 72 73 65 2c 20 41 2e 70 45 78 70  r(pParse, A.pExp
6e90: 72 29 3b 0a 20 20 73 70 61 6e 53 65 74 28 26 41  r);.  spanSet(&A
6ea0: 2c 20 26 58 2c 20 26 58 29 3b 0a 7d 0a 65 78 70  , &X, &X);.}.exp
6eb0: 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 45 29  r(A) ::= expr(E)
6ec0: 20 43 4f 4c 4c 41 54 45 20 69 64 73 28 43 29 2e   COLLATE ids(C).
6ed0: 20 7b 0a 20 20 41 2e 70 45 78 70 72 20 3d 20 73   {.  A.pExpr = s
6ee0: 71 6c 69 74 65 33 45 78 70 72 53 65 74 43 6f 6c  qlite3ExprSetCol
6ef0: 6c 28 70 50 61 72 73 65 2c 20 45 2e 70 45 78 70  l(pParse, E.pExp
6f00: 72 2c 20 26 43 29 3b 0a 20 20 41 2e 7a 53 74 61  r, &C);.  A.zSta
6f10: 72 74 20 3d 20 45 2e 7a 53 74 61 72 74 3b 0a 20  rt = E.zStart;. 
6f20: 20 41 2e 7a 45 6e 64 20 3d 20 26 43 2e 7a 5b 43   A.zEnd = &C.z[C
6f30: 2e 6e 5d 3b 0a 7d 0a 25 69 66 6e 64 65 66 20 53  .n];.}.%ifndef S
6f40: 51 4c 49 54 45 5f 4f 4d 49 54 5f 43 41 53 54 0a  QLITE_OMIT_CAST.
6f50: 65 78 70 72 28 41 29 20 3a 3a 3d 20 43 41 53 54  expr(A) ::= CAST
6f60: 28 58 29 20 4c 50 20 65 78 70 72 28 45 29 20 41  (X) LP expr(E) A
6f70: 53 20 74 79 70 65 74 6f 6b 65 6e 28 54 29 20 52  S typetoken(T) R
6f80: 50 28 59 29 2e 20 7b 0a 20 20 41 2e 70 45 78 70  P(Y). {.  A.pExp
6f90: 72 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72  r = sqlite3PExpr
6fa0: 28 70 50 61 72 73 65 2c 20 54 4b 5f 43 41 53 54  (pParse, TK_CAST
6fb0: 2c 20 45 2e 70 45 78 70 72 2c 20 30 2c 20 26 54  , E.pExpr, 0, &T
6fc0: 29 3b 0a 20 20 73 70 61 6e 53 65 74 28 26 41 2c  );.  spanSet(&A,
6fd0: 26 58 2c 26 59 29 3b 0a 7d 0a 25 65 6e 64 69 66  &X,&Y);.}.%endif
6fe0: 20 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 43 41    SQLITE_OMIT_CA
6ff0: 53 54 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 49  ST.expr(A) ::= I
7000: 44 28 58 29 20 4c 50 20 64 69 73 74 69 6e 63 74  D(X) LP distinct
7010: 28 44 29 20 65 78 70 72 6c 69 73 74 28 59 29 20  (D) exprlist(Y) 
7020: 52 50 28 45 29 2e 20 7b 0a 20 20 69 66 28 20 59  RP(E). {.  if( Y
7030: 20 26 26 20 59 2d 3e 6e 45 78 70 72 3e 70 50 61   && Y->nExpr>pPa
7040: 72 73 65 2d 3e 64 62 2d 3e 61 4c 69 6d 69 74 5b  rse->db->aLimit[
7050: 53 51 4c 49 54 45 5f 4c 49 4d 49 54 5f 46 55 4e  SQLITE_LIMIT_FUN
7060: 43 54 49 4f 4e 5f 41 52 47 5d 20 29 7b 0a 20 20  CTION_ARG] ){.  
7070: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73    sqlite3ErrorMs
7080: 67 28 70 50 61 72 73 65 2c 20 22 74 6f 6f 20 6d  g(pParse, "too m
7090: 61 6e 79 20 61 72 67 75 6d 65 6e 74 73 20 6f 6e  any arguments on
70a0: 20 66 75 6e 63 74 69 6f 6e 20 25 54 22 2c 20 26   function %T", &
70b0: 58 29 3b 0a 20 20 7d 0a 20 20 41 2e 70 45 78 70  X);.  }.  A.pExp
70c0: 72 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 46  r = sqlite3ExprF
70d0: 75 6e 63 74 69 6f 6e 28 70 50 61 72 73 65 2c 20  unction(pParse, 
70e0: 59 2c 20 26 58 29 3b 0a 20 20 73 70 61 6e 53 65  Y, &X);.  spanSe
70f0: 74 28 26 41 2c 26 58 2c 26 45 29 3b 0a 20 20 69  t(&A,&X,&E);.  i
7100: 66 28 20 44 20 26 26 20 41 2e 70 45 78 70 72 20  f( D && A.pExpr 
7110: 29 7b 0a 20 20 20 20 41 2e 70 45 78 70 72 2d 3e  ){.    A.pExpr->
7120: 66 6c 61 67 73 20 7c 3d 20 45 50 5f 44 69 73 74  flags |= EP_Dist
7130: 69 6e 63 74 3b 0a 20 20 7d 0a 7d 0a 65 78 70 72  inct;.  }.}.expr
7140: 28 41 29 20 3a 3a 3d 20 49 44 28 58 29 20 4c 50  (A) ::= ID(X) LP
7150: 20 53 54 41 52 20 52 50 28 45 29 2e 20 7b 0a 20   STAR RP(E). {. 
7160: 20 41 2e 70 45 78 70 72 20 3d 20 73 71 6c 69 74   A.pExpr = sqlit
7170: 65 33 45 78 70 72 46 75 6e 63 74 69 6f 6e 28 70  e3ExprFunction(p
7180: 50 61 72 73 65 2c 20 30 2c 20 26 58 29 3b 0a 20  Parse, 0, &X);. 
7190: 20 73 70 61 6e 53 65 74 28 26 41 2c 26 58 2c 26   spanSet(&A,&X,&
71a0: 45 29 3b 0a 7d 0a 74 65 72 6d 28 41 29 20 3a 3a  E);.}.term(A) ::
71b0: 3d 20 43 54 49 4d 45 5f 4b 57 28 4f 50 29 2e 20  = CTIME_KW(OP). 
71c0: 7b 0a 20 20 2f 2a 20 54 68 65 20 43 55 52 52 45  {.  /* The CURRE
71d0: 4e 54 5f 54 49 4d 45 2c 20 43 55 52 52 45 4e 54  NT_TIME, CURRENT
71e0: 5f 44 41 54 45 2c 20 61 6e 64 20 43 55 52 52 45  _DATE, and CURRE
71f0: 4e 54 5f 54 49 4d 45 53 54 41 4d 50 20 76 61 6c  NT_TIMESTAMP val
7200: 75 65 73 20 61 72 65 0a 20 20 2a 2a 20 74 72 65  ues are.  ** tre
7210: 61 74 65 64 20 61 73 20 66 75 6e 63 74 69 6f 6e  ated as function
7220: 73 20 74 68 61 74 20 72 65 74 75 72 6e 20 63 6f  s that return co
7230: 6e 73 74 61 6e 74 73 20 2a 2f 0a 20 20 41 2e 70  nstants */.  A.p
7240: 45 78 70 72 20 3d 20 73 71 6c 69 74 65 33 45 78  Expr = sqlite3Ex
7250: 70 72 46 75 6e 63 74 69 6f 6e 28 70 50 61 72 73  prFunction(pPars
7260: 65 2c 20 30 2c 26 4f 50 29 3b 0a 20 20 69 66 28  e, 0,&OP);.  if(
7270: 20 41 2e 70 45 78 70 72 20 29 7b 0a 20 20 20 20   A.pExpr ){.    
7280: 41 2e 70 45 78 70 72 2d 3e 6f 70 20 3d 20 54 4b  A.pExpr->op = TK
7290: 5f 43 4f 4e 53 54 5f 46 55 4e 43 3b 20 20 0a 20  _CONST_FUNC;  . 
72a0: 20 7d 0a 20 20 73 70 61 6e 53 65 74 28 26 41 2c   }.  spanSet(&A,
72b0: 20 26 4f 50 2c 20 26 4f 50 29 3b 0a 7d 0a 0a 25   &OP, &OP);.}..%
72c0: 69 6e 63 6c 75 64 65 20 7b 0a 20 20 2f 2a 20 54  include {.  /* T
72d0: 68 69 73 20 72 6f 75 74 69 6e 65 20 63 6f 6e 73  his routine cons
72e0: 74 72 75 63 74 73 20 61 20 62 69 6e 61 72 79 20  tructs a binary 
72f0: 65 78 70 72 65 73 73 69 6f 6e 20 6e 6f 64 65 20  expression node 
7300: 6f 75 74 20 6f 66 20 74 77 6f 20 45 78 70 72 53  out of two ExprS
7310: 70 61 6e 0a 20 20 2a 2a 20 6f 62 6a 65 63 74 73  pan.  ** objects
7320: 20 61 6e 64 20 75 73 65 73 20 74 68 65 20 72 65   and uses the re
7330: 73 75 6c 74 20 74 6f 20 70 6f 70 75 6c 61 74 65  sult to populate
7340: 20 61 20 6e 65 77 20 45 78 70 72 53 70 61 6e 20   a new ExprSpan 
7350: 6f 62 6a 65 63 74 2e 0a 20 20 2a 2f 0a 20 20 73  object..  */.  s
7360: 74 61 74 69 63 20 76 6f 69 64 20 73 70 61 6e 42  tatic void spanB
7370: 69 6e 61 72 79 45 78 70 72 28 0a 20 20 20 20 45  inaryExpr(.    E
7380: 78 70 72 53 70 61 6e 20 2a 70 4f 75 74 2c 20 20  xprSpan *pOut,  
7390: 20 20 20 2f 2a 20 57 72 69 74 65 20 74 68 65 20     /* Write the 
73a0: 72 65 73 75 6c 74 20 68 65 72 65 20 2a 2f 0a 20  result here */. 
73b0: 20 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65     Parse *pParse
73c0: 2c 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61  ,      /* The pa
73d0: 72 73 69 6e 67 20 63 6f 6e 74 65 78 74 2e 20 20  rsing context.  
73e0: 45 72 72 6f 72 73 20 61 63 63 75 6d 75 6c 61 74  Errors accumulat
73f0: 65 20 68 65 72 65 20 2a 2f 0a 20 20 20 20 69 6e  e here */.    in
7400: 74 20 6f 70 2c 20 20 20 20 20 20 20 20 20 20 20  t op,           
7410: 20 20 2f 2a 20 54 68 65 20 62 69 6e 61 72 79 20    /* The binary 
7420: 6f 70 65 72 61 74 69 6f 6e 20 2a 2f 0a 20 20 20  operation */.   
7430: 20 45 78 70 72 53 70 61 6e 20 2a 70 4c 65 66 74   ExprSpan *pLeft
7440: 2c 20 20 20 20 2f 2a 20 54 68 65 20 6c 65 66 74  ,    /* The left
7450: 20 6f 70 65 72 61 6e 64 20 2a 2f 0a 20 20 20 20   operand */.    
7460: 45 78 70 72 53 70 61 6e 20 2a 70 52 69 67 68 74  ExprSpan *pRight
7470: 20 20 20 20 2f 2a 20 54 68 65 20 72 69 67 68 74      /* The right
7480: 20 6f 70 65 72 61 6e 64 20 2a 2f 0a 20 20 29 7b   operand */.  ){
7490: 0a 20 20 20 20 70 4f 75 74 2d 3e 70 45 78 70 72  .    pOut->pExpr
74a0: 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72 28   = sqlite3PExpr(
74b0: 70 50 61 72 73 65 2c 20 6f 70 2c 20 70 4c 65 66  pParse, op, pLef
74c0: 74 2d 3e 70 45 78 70 72 2c 20 70 52 69 67 68 74  t->pExpr, pRight
74d0: 2d 3e 70 45 78 70 72 2c 20 30 29 3b 0a 20 20 20  ->pExpr, 0);.   
74e0: 20 70 4f 75 74 2d 3e 7a 53 74 61 72 74 20 3d 20   pOut->zStart = 
74f0: 70 4c 65 66 74 2d 3e 7a 53 74 61 72 74 3b 0a 20  pLeft->zStart;. 
7500: 20 20 20 70 4f 75 74 2d 3e 7a 45 6e 64 20 3d 20     pOut->zEnd = 
7510: 70 52 69 67 68 74 2d 3e 7a 45 6e 64 3b 0a 20 20  pRight->zEnd;.  
7520: 7d 0a 7d 0a 0a 65 78 70 72 28 41 29 20 3a 3a 3d  }.}..expr(A) ::=
7530: 20 65 78 70 72 28 58 29 20 41 4e 44 28 4f 50 29   expr(X) AND(OP)
7540: 20 65 78 70 72 28 59 29 2e 20 20 20 20 7b 73 70   expr(Y).    {sp
7550: 61 6e 42 69 6e 61 72 79 45 78 70 72 28 26 41 2c  anBinaryExpr(&A,
7560: 70 50 61 72 73 65 2c 40 4f 50 2c 26 58 2c 26 59  pParse,@OP,&X,&Y
7570: 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20  );}.expr(A) ::= 
7580: 65 78 70 72 28 58 29 20 4f 52 28 4f 50 29 20 65  expr(X) OR(OP) e
7590: 78 70 72 28 59 29 2e 20 20 20 20 20 7b 73 70 61  xpr(Y).     {spa
75a0: 6e 42 69 6e 61 72 79 45 78 70 72 28 26 41 2c 70  nBinaryExpr(&A,p
75b0: 50 61 72 73 65 2c 40 4f 50 2c 26 58 2c 26 59 29  Parse,@OP,&X,&Y)
75c0: 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65  ;}.expr(A) ::= e
75d0: 78 70 72 28 58 29 20 4c 54 7c 47 54 7c 47 45 7c  xpr(X) LT|GT|GE|
75e0: 4c 45 28 4f 50 29 20 65 78 70 72 28 59 29 2e 0a  LE(OP) expr(Y)..
75f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7600: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7610: 20 20 20 20 20 20 20 20 7b 73 70 61 6e 42 69 6e          {spanBin
7620: 61 72 79 45 78 70 72 28 26 41 2c 70 50 61 72 73  aryExpr(&A,pPars
7630: 65 2c 40 4f 50 2c 26 58 2c 26 59 29 3b 7d 0a 65  e,@OP,&X,&Y);}.e
7640: 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28  xpr(A) ::= expr(
7650: 58 29 20 45 51 7c 4e 45 28 4f 50 29 20 65 78 70  X) EQ|NE(OP) exp
7660: 72 28 59 29 2e 20 20 7b 73 70 61 6e 42 69 6e 61  r(Y).  {spanBina
7670: 72 79 45 78 70 72 28 26 41 2c 70 50 61 72 73 65  ryExpr(&A,pParse
7680: 2c 40 4f 50 2c 26 58 2c 26 59 29 3b 7d 0a 65 78  ,@OP,&X,&Y);}.ex
7690: 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 58  pr(A) ::= expr(X
76a0: 29 20 42 49 54 41 4e 44 7c 42 49 54 4f 52 7c 4c  ) BITAND|BITOR|L
76b0: 53 48 49 46 54 7c 52 53 48 49 46 54 28 4f 50 29  SHIFT|RSHIFT(OP)
76c0: 20 65 78 70 72 28 59 29 2e 0a 20 20 20 20 20 20   expr(Y)..      
76d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
76e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
76f0: 20 20 7b 73 70 61 6e 42 69 6e 61 72 79 45 78 70    {spanBinaryExp
7700: 72 28 26 41 2c 70 50 61 72 73 65 2c 40 4f 50 2c  r(&A,pParse,@OP,
7710: 26 58 2c 26 59 29 3b 7d 0a 65 78 70 72 28 41 29  &X,&Y);}.expr(A)
7720: 20 3a 3a 3d 20 65 78 70 72 28 58 29 20 50 4c 55   ::= expr(X) PLU
7730: 53 7c 4d 49 4e 55 53 28 4f 50 29 20 65 78 70 72  S|MINUS(OP) expr
7740: 28 59 29 2e 0a 20 20 20 20 20 20 20 20 20 20 20  (Y)..           
7750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7760: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 73 70               {sp
7770: 61 6e 42 69 6e 61 72 79 45 78 70 72 28 26 41 2c  anBinaryExpr(&A,
7780: 70 50 61 72 73 65 2c 40 4f 50 2c 26 58 2c 26 59  pParse,@OP,&X,&Y
7790: 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20  );}.expr(A) ::= 
77a0: 65 78 70 72 28 58 29 20 53 54 41 52 7c 53 4c 41  expr(X) STAR|SLA
77b0: 53 48 7c 52 45 4d 28 4f 50 29 20 65 78 70 72 28  SH|REM(OP) expr(
77c0: 59 29 2e 0a 20 20 20 20 20 20 20 20 20 20 20 20  Y)..            
77d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
77e0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 73 70 61              {spa
77f0: 6e 42 69 6e 61 72 79 45 78 70 72 28 26 41 2c 70  nBinaryExpr(&A,p
7800: 50 61 72 73 65 2c 40 4f 50 2c 26 58 2c 26 59 29  Parse,@OP,&X,&Y)
7810: 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 65  ;}.expr(A) ::= e
7820: 78 70 72 28 58 29 20 43 4f 4e 43 41 54 28 4f 50  xpr(X) CONCAT(OP
7830: 29 20 65 78 70 72 28 59 29 2e 20 7b 73 70 61 6e  ) expr(Y). {span
7840: 42 69 6e 61 72 79 45 78 70 72 28 26 41 2c 70 50  BinaryExpr(&A,pP
7850: 61 72 73 65 2c 40 4f 50 2c 26 58 2c 26 59 29 3b  arse,@OP,&X,&Y);
7860: 7d 0a 25 74 79 70 65 20 6c 69 6b 65 6f 70 20 7b  }.%type likeop {
7870: 73 74 72 75 63 74 20 4c 69 6b 65 4f 70 7d 0a 6c  struct LikeOp}.l
7880: 69 6b 65 6f 70 28 41 29 20 3a 3a 3d 20 4c 49 4b  ikeop(A) ::= LIK
7890: 45 5f 4b 57 28 58 29 2e 20 20 20 20 20 7b 41 2e  E_KW(X).     {A.
78a0: 65 4f 70 65 72 61 74 6f 72 20 3d 20 58 3b 20 41  eOperator = X; A
78b0: 2e 6e 6f 74 20 3d 20 30 3b 7d 0a 6c 69 6b 65 6f  .not = 0;}.likeo
78c0: 70 28 41 29 20 3a 3a 3d 20 4e 4f 54 20 4c 49 4b  p(A) ::= NOT LIK
78d0: 45 5f 4b 57 28 58 29 2e 20 7b 41 2e 65 4f 70 65  E_KW(X). {A.eOpe
78e0: 72 61 74 6f 72 20 3d 20 58 3b 20 41 2e 6e 6f 74  rator = X; A.not
78f0: 20 3d 20 31 3b 7d 0a 6c 69 6b 65 6f 70 28 41 29   = 1;}.likeop(A)
7900: 20 3a 3a 3d 20 4d 41 54 43 48 28 58 29 2e 20 20   ::= MATCH(X).  
7910: 20 20 20 20 20 7b 41 2e 65 4f 70 65 72 61 74 6f       {A.eOperato
7920: 72 20 3d 20 58 3b 20 41 2e 6e 6f 74 20 3d 20 30  r = X; A.not = 0
7930: 3b 7d 0a 6c 69 6b 65 6f 70 28 41 29 20 3a 3a 3d  ;}.likeop(A) ::=
7940: 20 4e 4f 54 20 4d 41 54 43 48 28 58 29 2e 20 20   NOT MATCH(X).  
7950: 20 7b 41 2e 65 4f 70 65 72 61 74 6f 72 20 3d 20   {A.eOperator = 
7960: 58 3b 20 41 2e 6e 6f 74 20 3d 20 31 3b 7d 0a 25  X; A.not = 1;}.%
7970: 74 79 70 65 20 65 73 63 61 70 65 20 7b 45 78 70  type escape {Exp
7980: 72 53 70 61 6e 7d 0a 25 64 65 73 74 72 75 63 74  rSpan}.%destruct
7990: 6f 72 20 65 73 63 61 70 65 20 7b 73 71 6c 69 74  or escape {sqlit
79a0: 65 33 45 78 70 72 44 65 6c 65 74 65 28 70 50 61  e3ExprDelete(pPa
79b0: 72 73 65 2d 3e 64 62 2c 20 24 24 2e 70 45 78 70  rse->db, $$.pExp
79c0: 72 29 3b 7d 0a 65 73 63 61 70 65 28 58 29 20 3a  r);}.escape(X) :
79d0: 3a 3d 20 45 53 43 41 50 45 20 65 78 70 72 28 41  := ESCAPE expr(A
79e0: 29 2e 20 5b 45 53 43 41 50 45 5d 20 7b 58 20 3d  ). [ESCAPE] {X =
79f0: 20 41 3b 7d 0a 65 73 63 61 70 65 28 58 29 20 3a   A;}.escape(X) :
7a00: 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20 20  := .            
7a10: 20 20 20 5b 45 53 43 41 50 45 5d 20 7b 6d 65 6d     [ESCAPE] {mem
7a20: 73 65 74 28 26 58 2c 30 2c 73 69 7a 65 6f 66 28  set(&X,0,sizeof(
7a30: 58 29 29 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a  X));}.expr(A) ::
7a40: 3d 20 65 78 70 72 28 58 29 20 6c 69 6b 65 6f 70  = expr(X) likeop
7a50: 28 4f 50 29 20 65 78 70 72 28 59 29 20 65 73 63  (OP) expr(Y) esc
7a60: 61 70 65 28 45 29 2e 20 20 5b 4c 49 4b 45 5f 4b  ape(E).  [LIKE_K
7a70: 57 5d 20 20 7b 0a 20 20 45 78 70 72 4c 69 73 74  W]  {.  ExprList
7a80: 20 2a 70 4c 69 73 74 3b 0a 20 20 70 4c 69 73 74   *pList;.  pList
7a90: 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69   = sqlite3ExprLi
7aa0: 73 74 41 70 70 65 6e 64 28 70 50 61 72 73 65 2c  stAppend(pParse,
7ab0: 30 2c 20 59 2e 70 45 78 70 72 29 3b 0a 20 20 70  0, Y.pExpr);.  p
7ac0: 4c 69 73 74 20 3d 20 73 71 6c 69 74 65 33 45 78  List = sqlite3Ex
7ad0: 70 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61  prListAppend(pPa
7ae0: 72 73 65 2c 70 4c 69 73 74 2c 20 58 2e 70 45 78  rse,pList, X.pEx
7af0: 70 72 29 3b 0a 20 20 69 66 28 20 45 2e 70 45 78  pr);.  if( E.pEx
7b00: 70 72 20 29 7b 0a 20 20 20 20 70 4c 69 73 74 20  pr ){.    pList 
7b10: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73  = sqlite3ExprLis
7b20: 74 41 70 70 65 6e 64 28 70 50 61 72 73 65 2c 70  tAppend(pParse,p
7b30: 4c 69 73 74 2c 20 45 2e 70 45 78 70 72 29 3b 0a  List, E.pExpr);.
7b40: 20 20 7d 0a 20 20 41 2e 70 45 78 70 72 20 3d 20    }.  A.pExpr = 
7b50: 73 71 6c 69 74 65 33 45 78 70 72 46 75 6e 63 74  sqlite3ExprFunct
7b60: 69 6f 6e 28 70 50 61 72 73 65 2c 20 70 4c 69 73  ion(pParse, pLis
7b70: 74 2c 20 26 4f 50 2e 65 4f 70 65 72 61 74 6f 72  t, &OP.eOperator
7b80: 29 3b 0a 20 20 69 66 28 20 4f 50 2e 6e 6f 74 20  );.  if( OP.not 
7b90: 29 20 41 2e 70 45 78 70 72 20 3d 20 73 71 6c 69  ) A.pExpr = sqli
7ba0: 74 65 33 50 45 78 70 72 28 70 50 61 72 73 65 2c  te3PExpr(pParse,
7bb0: 20 54 4b 5f 4e 4f 54 2c 20 41 2e 70 45 78 70 72   TK_NOT, A.pExpr
7bc0: 2c 20 30 2c 20 30 29 3b 0a 20 20 41 2e 7a 53 74  , 0, 0);.  A.zSt
7bd0: 61 72 74 20 3d 20 58 2e 7a 53 74 61 72 74 3b 0a  art = X.zStart;.
7be0: 20 20 41 2e 7a 45 6e 64 20 3d 20 59 2e 7a 45 6e    A.zEnd = Y.zEn
7bf0: 64 3b 0a 20 20 69 66 28 20 41 2e 70 45 78 70 72  d;.  if( A.pExpr
7c00: 20 29 20 41 2e 70 45 78 70 72 2d 3e 66 6c 61 67   ) A.pExpr->flag
7c10: 73 20 7c 3d 20 45 50 5f 49 6e 66 69 78 46 75 6e  s |= EP_InfixFun
7c20: 63 3b 0a 7d 0a 0a 25 69 6e 63 6c 75 64 65 20 7b  c;.}..%include {
7c30: 0a 20 20 2f 2a 20 43 6f 6e 73 74 72 75 63 74 20  .  /* Construct 
7c40: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 6e 6f  an expression no
7c50: 64 65 20 66 6f 72 20 61 20 75 6e 61 72 79 20 70  de for a unary p
7c60: 6f 73 74 66 69 78 20 6f 70 65 72 61 74 6f 72 0a  ostfix operator.
7c70: 20 20 2a 2f 0a 20 20 73 74 61 74 69 63 20 76 6f    */.  static vo
7c80: 69 64 20 73 70 61 6e 55 6e 61 72 79 50 6f 73 74  id spanUnaryPost
7c90: 66 69 78 28 0a 20 20 20 20 45 78 70 72 53 70 61  fix(.    ExprSpa
7ca0: 6e 20 2a 70 4f 75 74 2c 20 20 20 20 20 20 20 20  n *pOut,        
7cb0: 2f 2a 20 57 72 69 74 65 20 74 68 65 20 6e 65 77  /* Write the new
7cc0: 20 65 78 70 72 65 73 73 69 6f 6e 20 6e 6f 64 65   expression node
7cd0: 20 68 65 72 65 20 2a 2f 0a 20 20 20 20 50 61 72   here */.    Par
7ce0: 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20 20  se *pParse,     
7cf0: 20 20 20 20 2f 2a 20 50 61 72 73 69 6e 67 20 63      /* Parsing c
7d00: 6f 6e 74 65 78 74 20 74 6f 20 72 65 63 6f 72 64  ontext to record
7d10: 20 65 72 72 6f 72 73 20 2a 2f 0a 20 20 20 20 69   errors */.    i
7d20: 6e 74 20 6f 70 2c 20 20 20 20 20 20 20 20 20 20  nt op,          
7d30: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6f 70 65        /* The ope
7d40: 72 61 74 6f 72 20 2a 2f 0a 20 20 20 20 45 78 70  rator */.    Exp
7d50: 72 53 70 61 6e 20 2a 70 4f 70 65 72 61 6e 64 2c  rSpan *pOperand,
7d60: 20 20 20 20 2f 2a 20 54 68 65 20 6f 70 65 72 61      /* The opera
7d70: 6e 64 20 2a 2f 0a 20 20 20 20 54 6f 6b 65 6e 20  nd */.    Token 
7d80: 2a 70 50 6f 73 74 4f 70 20 20 20 20 20 20 20 20  *pPostOp        
7d90: 20 2f 2a 20 54 68 65 20 6f 70 65 72 61 6e 64 20   /* The operand 
7da0: 74 6f 6b 65 6e 20 66 6f 72 20 73 65 74 74 69 6e  token for settin
7db0: 67 20 74 68 65 20 73 70 61 6e 20 2a 2f 0a 20 20  g the span */.  
7dc0: 29 7b 0a 20 20 20 20 70 4f 75 74 2d 3e 70 45 78  ){.    pOut->pEx
7dd0: 70 72 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70  pr = sqlite3PExp
7de0: 72 28 70 50 61 72 73 65 2c 20 6f 70 2c 20 70 4f  r(pParse, op, pO
7df0: 70 65 72 61 6e 64 2d 3e 70 45 78 70 72 2c 20 30  perand->pExpr, 0
7e00: 2c 20 30 29 3b 0a 20 20 20 20 70 4f 75 74 2d 3e  , 0);.    pOut->
7e10: 7a 53 74 61 72 74 20 3d 20 70 4f 70 65 72 61 6e  zStart = pOperan
7e20: 64 2d 3e 7a 53 74 61 72 74 3b 0a 20 20 20 20 70  d->zStart;.    p
7e30: 4f 75 74 2d 3e 7a 45 6e 64 20 3d 20 26 70 50 6f  Out->zEnd = &pPo
7e40: 73 74 4f 70 2d 3e 7a 5b 70 50 6f 73 74 4f 70 2d  stOp->z[pPostOp-
7e50: 3e 6e 5d 3b 0a 20 20 7d 20 20 20 20 20 20 20 20  >n];.  }        
7e60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7e70: 20 20 20 0a 7d 0a 0a 65 78 70 72 28 41 29 20 3a     .}..expr(A) :
7e80: 3a 3d 20 65 78 70 72 28 58 29 20 49 53 4e 55 4c  := expr(X) ISNUL
7e90: 4c 7c 4e 4f 54 4e 55 4c 4c 28 45 29 2e 20 20 20  L|NOTNULL(E).   
7ea0: 7b 73 70 61 6e 55 6e 61 72 79 50 6f 73 74 66 69  {spanUnaryPostfi
7eb0: 78 28 26 41 2c 70 50 61 72 73 65 2c 40 45 2c 26  x(&A,pParse,@E,&
7ec0: 58 2c 26 45 29 3b 7d 0a 65 78 70 72 28 41 29 20  X,&E);}.expr(A) 
7ed0: 3a 3a 3d 20 65 78 70 72 28 58 29 20 4e 4f 54 20  ::= expr(X) NOT 
7ee0: 4e 55 4c 4c 28 45 29 2e 20 7b 73 70 61 6e 55 6e  NULL(E). {spanUn
7ef0: 61 72 79 50 6f 73 74 66 69 78 28 26 41 2c 70 50  aryPostfix(&A,pP
7f00: 61 72 73 65 2c 54 4b 5f 4e 4f 54 4e 55 4c 4c 2c  arse,TK_NOTNULL,
7f10: 26 58 2c 26 45 29 3b 7d 0a 0a 25 69 6e 63 6c 75  &X,&E);}..%inclu
7f20: 64 65 20 7b 0a 20 20 2f 2a 20 41 20 72 6f 75 74  de {.  /* A rout
7f30: 69 6e 65 20 74 6f 20 63 6f 6e 76 65 72 74 20 61  ine to convert a
7f40: 20 62 69 6e 61 72 79 20 54 4b 5f 49 53 20 6f 72   binary TK_IS or
7f50: 20 54 4b 5f 49 53 4e 4f 54 20 65 78 70 72 65 73   TK_ISNOT expres
7f60: 73 69 6f 6e 20 69 6e 74 6f 20 61 0a 20 20 2a 2a  sion into a.  **
7f70: 20 75 6e 61 72 79 20 54 4b 5f 49 53 4e 55 4c 4c   unary TK_ISNULL
7f80: 20 6f 72 20 54 4b 5f 4e 4f 54 4e 55 4c 4c 20 65   or TK_NOTNULL e
7f90: 78 70 72 65 73 73 69 6f 6e 2e 20 2a 2f 0a 20 20  xpression. */.  
7fa0: 73 74 61 74 69 63 20 76 6f 69 64 20 62 69 6e 61  static void bina
7fb0: 72 79 54 6f 55 6e 61 72 79 49 66 4e 75 6c 6c 28  ryToUnaryIfNull(
7fc0: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 45  Parse *pParse, E
7fd0: 78 70 72 20 2a 70 59 2c 20 45 78 70 72 20 2a 70  xpr *pY, Expr *p
7fe0: 41 2c 20 69 6e 74 20 6f 70 29 7b 0a 20 20 20 20  A, int op){.    
7ff0: 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70 50  sqlite3 *db = pP
8000: 61 72 73 65 2d 3e 64 62 3b 0a 20 20 20 20 69 66  arse->db;.    if
8010: 28 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c  ( db->mallocFail
8020: 65 64 3d 3d 30 20 26 26 20 70 59 2d 3e 6f 70 3d  ed==0 && pY->op=
8030: 3d 54 4b 5f 4e 55 4c 4c 20 29 7b 0a 20 20 20 20  =TK_NULL ){.    
8040: 20 20 70 41 2d 3e 6f 70 20 3d 20 28 75 38 29 6f    pA->op = (u8)o
8050: 70 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  p;.      sqlite3
8060: 45 78 70 72 44 65 6c 65 74 65 28 64 62 2c 20 70  ExprDelete(db, p
8070: 41 2d 3e 70 52 69 67 68 74 29 3b 0a 20 20 20 20  A->pRight);.    
8080: 20 20 70 41 2d 3e 70 52 69 67 68 74 20 3d 20 30    pA->pRight = 0
8090: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f  ;.    }.  }.}../
80a0: 2f 20 20 20 20 65 78 70 72 31 20 49 53 20 65 78  /    expr1 IS ex
80b0: 70 72 32 0a 2f 2f 20 20 20 20 65 78 70 72 31 20  pr2.//    expr1 
80c0: 49 53 20 4e 4f 54 20 65 78 70 72 32 0a 2f 2f 0a  IS NOT expr2.//.
80d0: 2f 2f 20 49 66 20 65 78 70 72 32 20 69 73 20 4e  // If expr2 is N
80e0: 55 4c 4c 20 74 68 65 6e 20 63 6f 64 65 20 61 73  ULL then code as
80f0: 20 54 4b 5f 49 53 4e 55 4c 4c 20 6f 72 20 54 4b   TK_ISNULL or TK
8100: 5f 4e 4f 54 4e 55 4c 4c 2e 20 20 49 66 20 65 78  _NOTNULL.  If ex
8110: 70 72 32 0a 2f 2f 20 69 73 20 61 6e 79 20 6f 74  pr2.// is any ot
8120: 68 65 72 20 65 78 70 72 65 73 73 69 6f 6e 2c 20  her expression, 
8130: 63 6f 64 65 20 61 73 20 54 4b 5f 49 53 20 6f 72  code as TK_IS or
8140: 20 54 4b 5f 49 53 4e 4f 54 2e 0a 2f 2f 20 0a 65   TK_ISNOT..// .e
8150: 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28  xpr(A) ::= expr(
8160: 58 29 20 49 53 20 65 78 70 72 28 59 29 2e 20 20  X) IS expr(Y).  
8170: 20 20 20 7b 0a 20 20 73 70 61 6e 42 69 6e 61 72     {.  spanBinar
8180: 79 45 78 70 72 28 26 41 2c 70 50 61 72 73 65 2c  yExpr(&A,pParse,
8190: 54 4b 5f 49 53 2c 26 58 2c 26 59 29 3b 0a 20 20  TK_IS,&X,&Y);.  
81a0: 62 69 6e 61 72 79 54 6f 55 6e 61 72 79 49 66 4e  binaryToUnaryIfN
81b0: 75 6c 6c 28 70 50 61 72 73 65 2c 20 59 2e 70 45  ull(pParse, Y.pE
81c0: 78 70 72 2c 20 41 2e 70 45 78 70 72 2c 20 54 4b  xpr, A.pExpr, TK
81d0: 5f 49 53 4e 55 4c 4c 29 3b 0a 7d 0a 65 78 70 72  _ISNULL);.}.expr
81e0: 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 58 29 20  (A) ::= expr(X) 
81f0: 49 53 20 4e 4f 54 20 65 78 70 72 28 59 29 2e 20  IS NOT expr(Y). 
8200: 7b 0a 20 20 73 70 61 6e 42 69 6e 61 72 79 45 78  {.  spanBinaryEx
8210: 70 72 28 26 41 2c 70 50 61 72 73 65 2c 54 4b 5f  pr(&A,pParse,TK_
8220: 49 53 4e 4f 54 2c 26 58 2c 26 59 29 3b 0a 20 20  ISNOT,&X,&Y);.  
8230: 62 69 6e 61 72 79 54 6f 55 6e 61 72 79 49 66 4e  binaryToUnaryIfN
8240: 75 6c 6c 28 70 50 61 72 73 65 2c 20 59 2e 70 45  ull(pParse, Y.pE
8250: 78 70 72 2c 20 41 2e 70 45 78 70 72 2c 20 54 4b  xpr, A.pExpr, TK
8260: 5f 4e 4f 54 4e 55 4c 4c 29 3b 0a 7d 0a 0a 25 69  _NOTNULL);.}..%i
8270: 6e 63 6c 75 64 65 20 7b 0a 20 20 2f 2a 20 43 6f  nclude {.  /* Co
8280: 6e 73 74 72 75 63 74 20 61 6e 20 65 78 70 72 65  nstruct an expre
8290: 73 73 69 6f 6e 20 6e 6f 64 65 20 66 6f 72 20 61  ssion node for a
82a0: 20 75 6e 61 72 79 20 70 72 65 66 69 78 20 6f 70   unary prefix op
82b0: 65 72 61 74 6f 72 0a 20 20 2a 2f 0a 20 20 73 74  erator.  */.  st
82c0: 61 74 69 63 20 76 6f 69 64 20 73 70 61 6e 55 6e  atic void spanUn
82d0: 61 72 79 50 72 65 66 69 78 28 0a 20 20 20 20 45  aryPrefix(.    E
82e0: 78 70 72 53 70 61 6e 20 2a 70 4f 75 74 2c 20 20  xprSpan *pOut,  
82f0: 20 20 20 20 20 20 2f 2a 20 57 72 69 74 65 20 74        /* Write t
8300: 68 65 20 6e 65 77 20 65 78 70 72 65 73 73 69 6f  he new expressio
8310: 6e 20 6e 6f 64 65 20 68 65 72 65 20 2a 2f 0a 20  n node here */. 
8320: 20 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65     Parse *pParse
8330: 2c 20 20 20 20 20 20 20 20 20 2f 2a 20 50 61 72  ,         /* Par
8340: 73 69 6e 67 20 63 6f 6e 74 65 78 74 20 74 6f 20  sing context to 
8350: 72 65 63 6f 72 64 20 65 72 72 6f 72 73 20 2a 2f  record errors */
8360: 0a 20 20 20 20 69 6e 74 20 6f 70 2c 20 20 20 20  .    int op,    
8370: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
8380: 68 65 20 6f 70 65 72 61 74 6f 72 20 2a 2f 0a 20  he operator */. 
8390: 20 20 20 45 78 70 72 53 70 61 6e 20 2a 70 4f 70     ExprSpan *pOp
83a0: 65 72 61 6e 64 2c 20 20 20 20 2f 2a 20 54 68 65  erand,    /* The
83b0: 20 6f 70 65 72 61 6e 64 20 2a 2f 0a 20 20 20 20   operand */.    
83c0: 54 6f 6b 65 6e 20 2a 70 50 72 65 4f 70 20 20 20  Token *pPreOp   
83d0: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6f 70 65        /* The ope
83e0: 72 61 6e 64 20 74 6f 6b 65 6e 20 66 6f 72 20 73  rand token for s
83f0: 65 74 74 69 6e 67 20 74 68 65 20 73 70 61 6e 20  etting the span 
8400: 2a 2f 0a 20 20 29 7b 0a 20 20 20 20 70 4f 75 74  */.  ){.    pOut
8410: 2d 3e 70 45 78 70 72 20 3d 20 73 71 6c 69 74 65  ->pExpr = sqlite
8420: 33 50 45 78 70 72 28 70 50 61 72 73 65 2c 20 6f  3PExpr(pParse, o
8430: 70 2c 20 70 4f 70 65 72 61 6e 64 2d 3e 70 45 78  p, pOperand->pEx
8440: 70 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 70  pr, 0, 0);.    p
8450: 4f 75 74 2d 3e 7a 53 74 61 72 74 20 3d 20 70 50  Out->zStart = pP
8460: 72 65 4f 70 2d 3e 7a 3b 0a 20 20 20 20 70 4f 75  reOp->z;.    pOu
8470: 74 2d 3e 7a 45 6e 64 20 3d 20 70 4f 70 65 72 61  t->zEnd = pOpera
8480: 6e 64 2d 3e 7a 45 6e 64 3b 0a 20 20 7d 0a 7d 0a  nd->zEnd;.  }.}.
8490: 0a 0a 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 4e  ...expr(A) ::= N
84a0: 4f 54 28 42 29 20 65 78 70 72 28 58 29 2e 20 20  OT(B) expr(X).  
84b0: 20 20 7b 73 70 61 6e 55 6e 61 72 79 50 72 65 66    {spanUnaryPref
84c0: 69 78 28 26 41 2c 70 50 61 72 73 65 2c 40 42 2c  ix(&A,pParse,@B,
84d0: 26 58 2c 26 42 29 3b 7d 0a 65 78 70 72 28 41 29  &X,&B);}.expr(A)
84e0: 20 3a 3a 3d 20 42 49 54 4e 4f 54 28 42 29 20 65   ::= BITNOT(B) e
84f0: 78 70 72 28 58 29 2e 20 7b 73 70 61 6e 55 6e 61  xpr(X). {spanUna
8500: 72 79 50 72 65 66 69 78 28 26 41 2c 70 50 61 72  ryPrefix(&A,pPar
8510: 73 65 2c 40 42 2c 26 58 2c 26 42 29 3b 7d 0a 65  se,@B,&X,&B);}.e
8520: 78 70 72 28 41 29 20 3a 3a 3d 20 4d 49 4e 55 53  xpr(A) ::= MINUS
8530: 28 42 29 20 65 78 70 72 28 58 29 2e 20 5b 42 49  (B) expr(X). [BI
8540: 54 4e 4f 54 5d 0a 20 20 20 20 20 20 20 20 20 20  TNOT].          
8550: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8560: 20 20 20 20 20 7b 73 70 61 6e 55 6e 61 72 79 50       {spanUnaryP
8570: 72 65 66 69 78 28 26 41 2c 70 50 61 72 73 65 2c  refix(&A,pParse,
8580: 54 4b 5f 55 4d 49 4e 55 53 2c 26 58 2c 26 42 29  TK_UMINUS,&X,&B)
8590: 3b 7d 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 50  ;}.expr(A) ::= P
85a0: 4c 55 53 28 42 29 20 65 78 70 72 28 58 29 2e 20  LUS(B) expr(X). 
85b0: 5b 42 49 54 4e 4f 54 5d 0a 20 20 20 20 20 20 20  [BITNOT].       
85c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
85d0: 20 20 20 20 20 20 20 20 7b 73 70 61 6e 55 6e 61          {spanUna
85e0: 72 79 50 72 65 66 69 78 28 26 41 2c 70 50 61 72  ryPrefix(&A,pPar
85f0: 73 65 2c 54 4b 5f 55 50 4c 55 53 2c 26 58 2c 26  se,TK_UPLUS,&X,&
8600: 42 29 3b 7d 0a 0a 25 74 79 70 65 20 62 65 74 77  B);}..%type betw
8610: 65 65 6e 5f 6f 70 20 7b 69 6e 74 7d 0a 62 65 74  een_op {int}.bet
8620: 77 65 65 6e 5f 6f 70 28 41 29 20 3a 3a 3d 20 42  ween_op(A) ::= B
8630: 45 54 57 45 45 4e 2e 20 20 20 20 20 7b 41 20 3d  ETWEEN.     {A =
8640: 20 30 3b 7d 0a 62 65 74 77 65 65 6e 5f 6f 70 28   0;}.between_op(
8650: 41 29 20 3a 3a 3d 20 4e 4f 54 20 42 45 54 57 45  A) ::= NOT BETWE
8660: 45 4e 2e 20 7b 41 20 3d 20 31 3b 7d 0a 65 78 70  EN. {A = 1;}.exp
8670: 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 57 29  r(A) ::= expr(W)
8680: 20 62 65 74 77 65 65 6e 5f 6f 70 28 4e 29 20 65   between_op(N) e
8690: 78 70 72 28 58 29 20 41 4e 44 20 65 78 70 72 28  xpr(X) AND expr(
86a0: 59 29 2e 20 5b 42 45 54 57 45 45 4e 5d 20 7b 0a  Y). [BETWEEN] {.
86b0: 20 20 45 78 70 72 4c 69 73 74 20 2a 70 4c 69 73    ExprList *pLis
86c0: 74 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c  t = sqlite3ExprL
86d0: 69 73 74 41 70 70 65 6e 64 28 70 50 61 72 73 65  istAppend(pParse
86e0: 2c 30 2c 20 58 2e 70 45 78 70 72 29 3b 0a 20 20  ,0, X.pExpr);.  
86f0: 70 4c 69 73 74 20 3d 20 73 71 6c 69 74 65 33 45  pList = sqlite3E
8700: 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50  xprListAppend(pP
8710: 61 72 73 65 2c 70 4c 69 73 74 2c 20 59 2e 70 45  arse,pList, Y.pE
8720: 78 70 72 29 3b 0a 20 20 41 2e 70 45 78 70 72 20  xpr);.  A.pExpr 
8730: 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72 28 70  = sqlite3PExpr(p
8740: 50 61 72 73 65 2c 20 54 4b 5f 42 45 54 57 45 45  Parse, TK_BETWEE
8750: 4e 2c 20 57 2e 70 45 78 70 72 2c 20 30 2c 20 30  N, W.pExpr, 0, 0
8760: 29 3b 0a 20 20 69 66 28 20 41 2e 70 45 78 70 72  );.  if( A.pExpr
8770: 20 29 7b 0a 20 20 20 20 41 2e 70 45 78 70 72 2d   ){.    A.pExpr-
8780: 3e 78 2e 70 4c 69 73 74 20 3d 20 70 4c 69 73 74  >x.pList = pList
8790: 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 73  ;.  }else{.    s
87a0: 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 44 65  qlite3ExprListDe
87b0: 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c  lete(pParse->db,
87c0: 20 70 4c 69 73 74 29 3b 0a 20 20 7d 20 0a 20 20   pList);.  } .  
87d0: 69 66 28 20 4e 20 29 20 41 2e 70 45 78 70 72 20  if( N ) A.pExpr 
87e0: 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72 28 70  = sqlite3PExpr(p
87f0: 50 61 72 73 65 2c 20 54 4b 5f 4e 4f 54 2c 20 41  Parse, TK_NOT, A
8800: 2e 70 45 78 70 72 2c 20 30 2c 20 30 29 3b 0a 20  .pExpr, 0, 0);. 
8810: 20 41 2e 7a 53 74 61 72 74 20 3d 20 57 2e 7a 53   A.zStart = W.zS
8820: 74 61 72 74 3b 0a 20 20 41 2e 7a 45 6e 64 20 3d  tart;.  A.zEnd =
8830: 20 59 2e 7a 45 6e 64 3b 0a 7d 0a 25 69 66 6e 64   Y.zEnd;.}.%ifnd
8840: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53  ef SQLITE_OMIT_S
8850: 55 42 51 55 45 52 59 0a 20 20 25 74 79 70 65 20  UBQUERY.  %type 
8860: 69 6e 5f 6f 70 20 7b 69 6e 74 7d 0a 20 20 69 6e  in_op {int}.  in
8870: 5f 6f 70 28 41 29 20 3a 3a 3d 20 49 4e 2e 20 20  _op(A) ::= IN.  
8880: 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 20 20 69      {A = 0;}.  i
8890: 6e 5f 6f 70 28 41 29 20 3a 3a 3d 20 4e 4f 54 20  n_op(A) ::= NOT 
88a0: 49 4e 2e 20 20 7b 41 20 3d 20 31 3b 7d 0a 20 20  IN.  {A = 1;}.  
88b0: 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72  expr(A) ::= expr
88c0: 28 58 29 20 69 6e 5f 6f 70 28 4e 29 20 4c 50 20  (X) in_op(N) LP 
88d0: 65 78 70 72 6c 69 73 74 28 59 29 20 52 50 28 45  exprlist(Y) RP(E
88e0: 29 2e 20 5b 49 4e 5d 20 7b 0a 20 20 20 20 69 66  ). [IN] {.    if
88f0: 28 20 59 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  ( Y==0 ){.      
8900: 2f 2f 20 45 78 70 72 65 73 73 69 6f 6e 73 20 6f  // Expressions o
8910: 66 20 74 68 65 20 66 6f 72 6d 0a 20 20 20 20 20  f the form.     
8920: 20 2f 2f 0a 20 20 20 20 20 20 2f 2f 20 20 20 20   //.      //    
8930: 20 20 65 78 70 72 31 20 49 4e 20 28 29 0a 20 20    expr1 IN ().  
8940: 20 20 20 20 2f 2f 20 20 20 20 20 20 65 78 70 72      //      expr
8950: 31 20 4e 4f 54 20 49 4e 20 28 29 0a 20 20 20 20  1 NOT IN ().    
8960: 20 20 2f 2f 0a 20 20 20 20 20 20 2f 2f 20 73 69    //.      // si
8970: 6d 70 6c 69 66 79 20 74 6f 20 63 6f 6e 73 74 61  mplify to consta
8980: 6e 74 73 20 30 20 28 66 61 6c 73 65 29 20 61 6e  nts 0 (false) an
8990: 64 20 31 20 28 74 72 75 65 29 2c 20 72 65 73 70  d 1 (true), resp
89a0: 65 63 74 69 76 65 6c 79 2c 0a 20 20 20 20 20 20  ectively,.      
89b0: 2f 2f 20 72 65 67 61 72 64 6c 65 73 73 20 6f 66  // regardless of
89c0: 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20 65 78   the value of ex
89d0: 70 72 31 2e 0a 20 20 20 20 20 20 2f 2f 0a 20 20  pr1..      //.  
89e0: 20 20 20 20 41 2e 70 45 78 70 72 20 3d 20 73 71      A.pExpr = sq
89f0: 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73  lite3PExpr(pPars
8a00: 65 2c 20 54 4b 5f 49 4e 54 45 47 45 52 2c 20 30  e, TK_INTEGER, 0
8a10: 2c 20 30 2c 20 26 73 71 6c 69 74 65 33 49 6e 74  , 0, &sqlite3Int
8a20: 54 6f 6b 65 6e 73 5b 4e 5d 29 3b 0a 20 20 20 20  Tokens[N]);.    
8a30: 20 20 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c    sqlite3ExprDel
8a40: 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c 20  ete(pParse->db, 
8a50: 58 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 7d 65  X.pExpr);.    }e
8a60: 6c 73 65 7b 0a 20 20 20 20 20 20 41 2e 70 45 78  lse{.      A.pEx
8a70: 70 72 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70  pr = sqlite3PExp
8a80: 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 49 4e 2c  r(pParse, TK_IN,
8a90: 20 58 2e 70 45 78 70 72 2c 20 30 2c 20 30 29 3b   X.pExpr, 0, 0);
8aa0: 0a 20 20 20 20 20 20 69 66 28 20 41 2e 70 45 78  .      if( A.pEx
8ab0: 70 72 20 29 7b 0a 20 20 20 20 20 20 20 20 41 2e  pr ){.        A.
8ac0: 70 45 78 70 72 2d 3e 78 2e 70 4c 69 73 74 20 3d  pExpr->x.pList =
8ad0: 20 59 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   Y;.        sqli
8ae0: 74 65 33 45 78 70 72 53 65 74 48 65 69 67 68 74  te3ExprSetHeight
8af0: 28 70 50 61 72 73 65 2c 20 41 2e 70 45 78 70 72  (pParse, A.pExpr
8b00: 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a  );.      }else{.
8b10: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 45          sqlite3E
8b20: 78 70 72 4c 69 73 74 44 65 6c 65 74 65 28 70 50  xprListDelete(pP
8b30: 61 72 73 65 2d 3e 64 62 2c 20 59 29 3b 0a 20 20  arse->db, Y);.  
8b40: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
8b50: 4e 20 29 20 41 2e 70 45 78 70 72 20 3d 20 73 71  N ) A.pExpr = sq
8b60: 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73  lite3PExpr(pPars
8b70: 65 2c 20 54 4b 5f 4e 4f 54 2c 20 41 2e 70 45 78  e, TK_NOT, A.pEx
8b80: 70 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 7d  pr, 0, 0);.    }
8b90: 0a 20 20 20 20 41 2e 7a 53 74 61 72 74 20 3d 20  .    A.zStart = 
8ba0: 58 2e 7a 53 74 61 72 74 3b 0a 20 20 20 20 41 2e  X.zStart;.    A.
8bb0: 7a 45 6e 64 20 3d 20 26 45 2e 7a 5b 45 2e 6e 5d  zEnd = &E.z[E.n]
8bc0: 3b 0a 20 20 7d 0a 20 20 65 78 70 72 28 41 29 20  ;.  }.  expr(A) 
8bd0: 3a 3a 3d 20 4c 50 28 42 29 20 73 65 6c 65 63 74  ::= LP(B) select
8be0: 28 58 29 20 52 50 28 45 29 2e 20 7b 0a 20 20 20  (X) RP(E). {.   
8bf0: 20 41 2e 70 45 78 70 72 20 3d 20 73 71 6c 69 74   A.pExpr = sqlit
8c00: 65 33 50 45 78 70 72 28 70 50 61 72 73 65 2c 20  e3PExpr(pParse, 
8c10: 54 4b 5f 53 45 4c 45 43 54 2c 20 30 2c 20 30 2c  TK_SELECT, 0, 0,
8c20: 20 30 29 3b 0a 20 20 20 20 69 66 28 20 41 2e 70   0);.    if( A.p
8c30: 45 78 70 72 20 29 7b 0a 20 20 20 20 20 20 41 2e  Expr ){.      A.
8c40: 70 45 78 70 72 2d 3e 78 2e 70 53 65 6c 65 63 74  pExpr->x.pSelect
8c50: 20 3d 20 58 3b 0a 20 20 20 20 20 20 45 78 70 72   = X;.      Expr
8c60: 53 65 74 50 72 6f 70 65 72 74 79 28 41 2e 70 45  SetProperty(A.pE
8c70: 78 70 72 2c 20 45 50 5f 78 49 73 53 65 6c 65 63  xpr, EP_xIsSelec
8c80: 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  t);.      sqlite
8c90: 33 45 78 70 72 53 65 74 48 65 69 67 68 74 28 70  3ExprSetHeight(p
8ca0: 50 61 72 73 65 2c 20 41 2e 70 45 78 70 72 29 3b  Parse, A.pExpr);
8cb0: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
8cc0: 20 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 44    sqlite3SelectD
8cd0: 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62  elete(pParse->db
8ce0: 2c 20 58 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  , X);.    }.    
8cf0: 41 2e 7a 53 74 61 72 74 20 3d 20 42 2e 7a 3b 0a  A.zStart = B.z;.
8d00: 20 20 20 20 41 2e 7a 45 6e 64 20 3d 20 26 45 2e      A.zEnd = &E.
8d10: 7a 5b 45 2e 6e 5d 3b 0a 20 20 7d 0a 20 20 65 78  z[E.n];.  }.  ex
8d20: 70 72 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 58  pr(A) ::= expr(X
8d30: 29 20 69 6e 5f 6f 70 28 4e 29 20 4c 50 20 73 65  ) in_op(N) LP se
8d40: 6c 65 63 74 28 59 29 20 52 50 28 45 29 2e 20 20  lect(Y) RP(E).  
8d50: 5b 49 4e 5d 20 7b 0a 20 20 20 20 41 2e 70 45 78  [IN] {.    A.pEx
8d60: 70 72 20 3d 20 73 71 6c 69 74 65 33 50 45 78 70  pr = sqlite3PExp
8d70: 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 49 4e 2c  r(pParse, TK_IN,
8d80: 20 58 2e 70 45 78 70 72 2c 20 30 2c 20 30 29 3b   X.pExpr, 0, 0);
8d90: 0a 20 20 20 20 69 66 28 20 41 2e 70 45 78 70 72  .    if( A.pExpr
8da0: 20 29 7b 0a 20 20 20 20 20 20 41 2e 70 45 78 70   ){.      A.pExp
8db0: 72 2d 3e 78 2e 70 53 65 6c 65 63 74 20 3d 20 59  r->x.pSelect = Y
8dc0: 3b 0a 20 20 20 20 20 20 45 78 70 72 53 65 74 50  ;.      ExprSetP
8dd0: 72 6f 70 65 72 74 79 28 41 2e 70 45 78 70 72 2c  roperty(A.pExpr,
8de0: 20 45 50 5f 78 49 73 53 65 6c 65 63 74 29 3b 0a   EP_xIsSelect);.
8df0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 78 70        sqlite3Exp
8e00: 72 53 65 74 48 65 69 67 68 74 28 70 50 61 72 73  rSetHeight(pPars
8e10: 65 2c 20 41 2e 70 45 78 70 72 29 3b 0a 20 20 20  e, A.pExpr);.   
8e20: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 71   }else{.      sq
8e30: 6c 69 74 65 33 53 65 6c 65 63 74 44 65 6c 65 74  lite3SelectDelet
8e40: 65 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 59 29  e(pParse->db, Y)
8e50: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20  ;.    }.    if( 
8e60: 4e 20 29 20 41 2e 70 45 78 70 72 20 3d 20 73 71  N ) A.pExpr = sq
8e70: 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73  lite3PExpr(pPars
8e80: 65 2c 20 54 4b 5f 4e 4f 54 2c 20 41 2e 70 45 78  e, TK_NOT, A.pEx
8e90: 70 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 41  pr, 0, 0);.    A
8ea0: 2e 7a 53 74 61 72 74 20 3d 20 58 2e 7a 53 74 61  .zStart = X.zSta
8eb0: 72 74 3b 0a 20 20 20 20 41 2e 7a 45 6e 64 20 3d  rt;.    A.zEnd =
8ec0: 20 26 45 2e 7a 5b 45 2e 6e 5d 3b 0a 20 20 7d 0a   &E.z[E.n];.  }.
8ed0: 20 20 65 78 70 72 28 41 29 20 3a 3a 3d 20 65 78    expr(A) ::= ex
8ee0: 70 72 28 58 29 20 69 6e 5f 6f 70 28 4e 29 20 6e  pr(X) in_op(N) n
8ef0: 6d 28 59 29 20 64 62 6e 6d 28 5a 29 2e 20 5b 49  m(Y) dbnm(Z). [I
8f00: 4e 5d 20 7b 0a 20 20 20 20 53 72 63 4c 69 73 74  N] {.    SrcList
8f10: 20 2a 70 53 72 63 20 3d 20 73 71 6c 69 74 65 33   *pSrc = sqlite3
8f20: 53 72 63 4c 69 73 74 41 70 70 65 6e 64 28 70 50  SrcListAppend(pP
8f30: 61 72 73 65 2d 3e 64 62 2c 20 30 2c 26 59 2c 26  arse->db, 0,&Y,&
8f40: 5a 29 3b 0a 20 20 20 20 41 2e 70 45 78 70 72 20  Z);.    A.pExpr 
8f50: 3d 20 73 71 6c 69 74 65 33 50 45 78 70 72 28 70  = sqlite3PExpr(p
8f60: 50 61 72 73 65 2c 20 54 4b 5f 49 4e 2c 20 58 2e  Parse, TK_IN, X.
8f70: 70 45 78 70 72 2c 20 30 2c 20 30 29 3b 0a 20 20  pExpr, 0, 0);.  
8f80: 20 20 69 66 28 20 41 2e 70 45 78 70 72 20 29 7b    if( A.pExpr ){
8f90: 0a 20 20 20 20 20 20 41 2e 70 45 78 70 72 2d 3e  .      A.pExpr->
8fa0: 78 2e 70 53 65 6c 65 63 74 20 3d 20 73 71 6c 69  x.pSelect = sqli
8fb0: 74 65 33 53 65 6c 65 63 74 4e 65 77 28 70 50 61  te3SelectNew(pPa
8fc0: 72 73 65 2c 20 30 2c 70 53 72 63 2c 30 2c 30 2c  rse, 0,pSrc,0,0,
8fd0: 30 2c 30 2c 30 2c 30 2c 30 29 3b 0a 20 20 20 20  0,0,0,0,0);.    
8fe0: 20 20 45 78 70 72 53 65 74 50 72 6f 70 65 72 74    ExprSetPropert
8ff0: 79 28 41 2e 70 45 78 70 72 2c 20 45 50 5f 78 49  y(A.pExpr, EP_xI
9000: 73 53 65 6c 65 63 74 29 3b 0a 20 20 20 20 20 20  sSelect);.      
9010: 73 71 6c 69 74 65 33 45 78 70 72 53 65 74 48 65  sqlite3ExprSetHe
9020: 69 67 68 74 28 70 50 61 72 73 65 2c 20 41 2e 70  ight(pParse, A.p
9030: 45 78 70 72 29 3b 0a 20 20 20 20 7d 65 6c 73 65  Expr);.    }else
9040: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 53  {.      sqlite3S
9050: 72 63 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61  rcListDelete(pPa
9060: 72 73 65 2d 3e 64 62 2c 20 70 53 72 63 29 3b 0a  rse->db, pSrc);.
9070: 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 4e 20      }.    if( N 
9080: 29 20 41 2e 70 45 78 70 72 20 3d 20 73 71 6c 69  ) A.pExpr = sqli
9090: 74 65 33 50 45 78 70 72 28 70 50 61 72 73 65 2c  te3PExpr(pParse,
90a0: 20 54 4b 5f 4e 4f 54 2c 20 41 2e 70 45 78 70 72   TK_NOT, A.pExpr
90b0: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 41 2e 7a  , 0, 0);.    A.z
90c0: 53 74 61 72 74 20 3d 20 58 2e 7a 53 74 61 72 74  Start = X.zStart
90d0: 3b 0a 20 20 20 20 41 2e 7a 45 6e 64 20 3d 20 5a  ;.    A.zEnd = Z
90e0: 2e 7a 20 3f 20 26 5a 2e 7a 5b 5a 2e 6e 5d 20 3a  .z ? &Z.z[Z.n] :
90f0: 20 26 59 2e 7a 5b 59 2e 6e 5d 3b 0a 20 20 7d 0a   &Y.z[Y.n];.  }.
9100: 20 20 65 78 70 72 28 41 29 20 3a 3a 3d 20 45 58    expr(A) ::= EX
9110: 49 53 54 53 28 42 29 20 4c 50 20 73 65 6c 65 63  ISTS(B) LP selec
9120: 74 28 59 29 20 52 50 28 45 29 2e 20 7b 0a 20 20  t(Y) RP(E). {.  
9130: 20 20 45 78 70 72 20 2a 70 20 3d 20 41 2e 70 45    Expr *p = A.pE
9140: 78 70 72 20 3d 20 73 71 6c 69 74 65 33 50 45 78  xpr = sqlite3PEx
9150: 70 72 28 70 50 61 72 73 65 2c 20 54 4b 5f 45 58  pr(pParse, TK_EX
9160: 49 53 54 53 2c 20 30 2c 20 30 2c 20 30 29 3b 0a  ISTS, 0, 0, 0);.
9170: 20 20 20 20 69 66 28 20 70 20 29 7b 0a 20 20 20      if( p ){.   
9180: 20 20 20 70 2d 3e 78 2e 70 53 65 6c 65 63 74 20     p->x.pSelect 
9190: 3d 20 59 3b 0a 20 20 20 20 20 20 45 78 70 72 53  = Y;.      ExprS
91a0: 65 74 50 72 6f 70 65 72 74 79 28 70 2c 20 45 50  etProperty(p, EP
91b0: 5f 78 49 73 53 65 6c 65 63 74 29 3b 0a 20 20 20  _xIsSelect);.   
91c0: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 53 65     sqlite3ExprSe
91d0: 74 48 65 69 67 68 74 28 70 50 61 72 73 65 2c 20  tHeight(pParse, 
91e0: 70 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20  p);.    }else{. 
91f0: 20 20 20 20 20 73 71 6c 69 74 65 33 53 65 6c 65       sqlite3Sele
9200: 63 74 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d  ctDelete(pParse-
9210: 3e 64 62 2c 20 59 29 3b 0a 20 20 20 20 7d 0a 20  >db, Y);.    }. 
9220: 20 20 20 41 2e 7a 53 74 61 72 74 20 3d 20 42 2e     A.zStart = B.
9230: 7a 3b 0a 20 20 20 20 41 2e 7a 45 6e 64 20 3d 20  z;.    A.zEnd = 
9240: 26 45 2e 7a 5b 45 2e 6e 5d 3b 0a 20 20 7d 0a 25  &E.z[E.n];.  }.%
9250: 65 6e 64 69 66 20 53 51 4c 49 54 45 5f 4f 4d 49  endif SQLITE_OMI
9260: 54 5f 53 55 42 51 55 45 52 59 0a 0a 2f 2a 20 43  T_SUBQUERY../* C
9270: 41 53 45 20 65 78 70 72 65 73 73 69 6f 6e 73 20  ASE expressions 
9280: 2a 2f 0a 65 78 70 72 28 41 29 20 3a 3a 3d 20 43  */.expr(A) ::= C
9290: 41 53 45 28 43 29 20 63 61 73 65 5f 6f 70 65 72  ASE(C) case_oper
92a0: 61 6e 64 28 58 29 20 63 61 73 65 5f 65 78 70 72  and(X) case_expr
92b0: 6c 69 73 74 28 59 29 20 63 61 73 65 5f 65 6c 73  list(Y) case_els
92c0: 65 28 5a 29 20 45 4e 44 28 45 29 2e 20 7b 0a 20  e(Z) END(E). {. 
92d0: 20 41 2e 70 45 78 70 72 20 3d 20 73 71 6c 69 74   A.pExpr = sqlit
92e0: 65 33 50 45 78 70 72 28 70 50 61 72 73 65 2c 20  e3PExpr(pParse, 
92f0: 54 4b 5f 43 41 53 45 2c 20 58 2c 20 5a 2c 20 30  TK_CASE, X, Z, 0
9300: 29 3b 0a 20 20 69 66 28 20 41 2e 70 45 78 70 72  );.  if( A.pExpr
9310: 20 29 7b 0a 20 20 20 20 41 2e 70 45 78 70 72 2d   ){.    A.pExpr-
9320: 3e 78 2e 70 4c 69 73 74 20 3d 20 59 3b 0a 20 20  >x.pList = Y;.  
9330: 20 20 73 71 6c 69 74 65 33 45 78 70 72 53 65 74    sqlite3ExprSet
9340: 48 65 69 67 68 74 28 70 50 61 72 73 65 2c 20 41  Height(pParse, A
9350: 2e 70 45 78 70 72 29 3b 0a 20 20 7d 65 6c 73 65  .pExpr);.  }else
9360: 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45 78 70  {.    sqlite3Exp
9370: 72 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61 72  rListDelete(pPar
9380: 73 65 2d 3e 64 62 2c 20 59 29 3b 0a 20 20 7d 0a  se->db, Y);.  }.
9390: 20 20 41 2e 7a 53 74 61 72 74 20 3d 20 43 2e 7a    A.zStart = C.z
93a0: 3b 0a 20 20 41 2e 7a 45 6e 64 20 3d 20 26 45 2e  ;.  A.zEnd = &E.
93b0: 7a 5b 45 2e 6e 5d 3b 0a 7d 0a 25 74 79 70 65 20  z[E.n];.}.%type 
93c0: 63 61 73 65 5f 65 78 70 72 6c 69 73 74 20 7b 45  case_exprlist {E
93d0: 78 70 72 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72  xprList*}.%destr
93e0: 75 63 74 6f 72 20 63 61 73 65 5f 65 78 70 72 6c  uctor case_exprl
93f0: 69 73 74 20 7b 73 71 6c 69 74 65 33 45 78 70 72  ist {sqlite3Expr
9400: 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61 72 73  ListDelete(pPars
9410: 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 63 61 73  e->db, $$);}.cas
9420: 65 5f 65 78 70 72 6c 69 73 74 28 41 29 20 3a 3a  e_exprlist(A) ::
9430: 3d 20 63 61 73 65 5f 65 78 70 72 6c 69 73 74 28  = case_exprlist(
9440: 58 29 20 57 48 45 4e 20 65 78 70 72 28 59 29 20  X) WHEN expr(Y) 
9450: 54 48 45 4e 20 65 78 70 72 28 5a 29 2e 20 7b 0a  THEN expr(Z). {.
9460: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
9470: 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72  rListAppend(pPar
9480: 73 65 2c 58 2c 20 59 2e 70 45 78 70 72 29 3b 0a  se,X, Y.pExpr);.
9490: 20 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70    A = sqlite3Exp
94a0: 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72  rListAppend(pPar
94b0: 73 65 2c 41 2c 20 5a 2e 70 45 78 70 72 29 3b 0a  se,A, Z.pExpr);.
94c0: 7d 0a 63 61 73 65 5f 65 78 70 72 6c 69 73 74 28  }.case_exprlist(
94d0: 41 29 20 3a 3a 3d 20 57 48 45 4e 20 65 78 70 72  A) ::= WHEN expr
94e0: 28 59 29 20 54 48 45 4e 20 65 78 70 72 28 5a 29  (Y) THEN expr(Z)
94f0: 2e 20 7b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65  . {.  A = sqlite
9500: 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28  3ExprListAppend(
9510: 70 50 61 72 73 65 2c 30 2c 20 59 2e 70 45 78 70  pParse,0, Y.pExp
9520: 72 29 3b 0a 20 20 41 20 3d 20 73 71 6c 69 74 65  r);.  A = sqlite
9530: 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28  3ExprListAppend(
9540: 70 50 61 72 73 65 2c 41 2c 20 5a 2e 70 45 78 70  pParse,A, Z.pExp
9550: 72 29 3b 0a 7d 0a 25 74 79 70 65 20 63 61 73 65  r);.}.%type case
9560: 5f 65 6c 73 65 20 7b 45 78 70 72 2a 7d 0a 25 64  _else {Expr*}.%d
9570: 65 73 74 72 75 63 74 6f 72 20 63 61 73 65 5f 65  estructor case_e
9580: 6c 73 65 20 7b 73 71 6c 69 74 65 33 45 78 70 72  lse {sqlite3Expr
9590: 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64  Delete(pParse->d
95a0: 62 2c 20 24 24 29 3b 7d 0a 63 61 73 65 5f 65 6c  b, $$);}.case_el
95b0: 73 65 28 41 29 20 3a 3a 3d 20 20 45 4c 53 45 20  se(A) ::=  ELSE 
95c0: 65 78 70 72 28 58 29 2e 20 20 20 20 20 20 20 20  expr(X).        
95d0: 20 7b 41 20 3d 20 58 2e 70 45 78 70 72 3b 7d 0a   {A = X.pExpr;}.
95e0: 63 61 73 65 5f 65 6c 73 65 28 41 29 20 3a 3a 3d  case_else(A) ::=
95f0: 20 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20    .             
9600: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 30 3b 7d          {A = 0;}
9610: 20 0a 25 74 79 70 65 20 63 61 73 65 5f 6f 70 65   .%type case_ope
9620: 72 61 6e 64 20 7b 45 78 70 72 2a 7d 0a 25 64 65  rand {Expr*}.%de
9630: 73 74 72 75 63 74 6f 72 20 63 61 73 65 5f 6f 70  structor case_op
9640: 65 72 61 6e 64 20 7b 73 71 6c 69 74 65 33 45 78  erand {sqlite3Ex
9650: 70 72 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d  prDelete(pParse-
9660: 3e 64 62 2c 20 24 24 29 3b 7d 0a 63 61 73 65 5f  >db, $$);}.case_
9670: 6f 70 65 72 61 6e 64 28 41 29 20 3a 3a 3d 20 65  operand(A) ::= e
9680: 78 70 72 28 58 29 2e 20 20 20 20 20 20 20 20 20  xpr(X).         
9690: 20 20 20 7b 41 20 3d 20 58 2e 70 45 78 70 72 3b     {A = X.pExpr;
96a0: 7d 20 0a 63 61 73 65 5f 6f 70 65 72 61 6e 64 28  } .case_operand(
96b0: 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20  A) ::= .        
96c0: 20 20 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20             {A = 
96d0: 30 3b 7d 20 0a 0a 25 74 79 70 65 20 65 78 70 72  0;} ..%type expr
96e0: 6c 69 73 74 20 7b 45 78 70 72 4c 69 73 74 2a 7d  list {ExprList*}
96f0: 0a 25 64 65 73 74 72 75 63 74 6f 72 20 65 78 70  .%destructor exp
9700: 72 6c 69 73 74 20 7b 73 71 6c 69 74 65 33 45 78  rlist {sqlite3Ex
9710: 70 72 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61  prListDelete(pPa
9720: 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 25  rse->db, $$);}.%
9730: 74 79 70 65 20 6e 65 78 70 72 6c 69 73 74 20 7b  type nexprlist {
9740: 45 78 70 72 4c 69 73 74 2a 7d 0a 25 64 65 73 74  ExprList*}.%dest
9750: 72 75 63 74 6f 72 20 6e 65 78 70 72 6c 69 73 74  ructor nexprlist
9760: 20 7b 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73   {sqlite3ExprLis
9770: 74 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e  tDelete(pParse->
9780: 64 62 2c 20 24 24 29 3b 7d 0a 0a 65 78 70 72 6c  db, $$);}..exprl
9790: 69 73 74 28 41 29 20 3a 3a 3d 20 6e 65 78 70 72  ist(A) ::= nexpr
97a0: 6c 69 73 74 28 58 29 2e 20 20 20 20 20 20 20 20  list(X).        
97b0: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d          {A = X;}
97c0: 0a 65 78 70 72 6c 69 73 74 28 41 29 20 3a 3a 3d  .exprlist(A) ::=
97d0: 20 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20   .              
97e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 41                {A
97f0: 20 3d 20 30 3b 7d 0a 6e 65 78 70 72 6c 69 73 74   = 0;}.nexprlist
9800: 28 41 29 20 3a 3a 3d 20 6e 65 78 70 72 6c 69 73  (A) ::= nexprlis
9810: 74 28 58 29 20 43 4f 4d 4d 41 20 65 78 70 72 28  t(X) COMMA expr(
9820: 59 29 2e 0a 20 20 20 20 7b 41 20 3d 20 73 71 6c  Y)..    {A = sql
9830: 69 74 65 33 45 78 70 72 4c 69 73 74 41 70 70 65  ite3ExprListAppe
9840: 6e 64 28 70 50 61 72 73 65 2c 58 2c 59 2e 70 45  nd(pParse,X,Y.pE
9850: 78 70 72 29 3b 7d 0a 6e 65 78 70 72 6c 69 73 74  xpr);}.nexprlist
9860: 28 41 29 20 3a 3a 3d 20 65 78 70 72 28 59 29 2e  (A) ::= expr(Y).
9870: 0a 20 20 20 20 7b 41 20 3d 20 73 71 6c 69 74 65  .    {A = sqlite
9880: 33 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28  3ExprListAppend(
9890: 70 50 61 72 73 65 2c 30 2c 59 2e 70 45 78 70 72  pParse,0,Y.pExpr
98a0: 29 3b 7d 0a 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  );}...//////////
98b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
98c0: 2f 2f 2f 20 54 68 65 20 43 52 45 41 54 45 20 49  /// The CREATE I
98d0: 4e 44 45 58 20 63 6f 6d 6d 61 6e 64 20 2f 2f 2f  NDEX command ///
98e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
98f0: 2f 2f 2f 2f 0a 2f 2f 0a 63 6d 64 20 3a 3a 3d 20  ////.//.cmd ::= 
9900: 63 72 65 61 74 65 6b 77 28 53 29 20 75 6e 69 71  createkw(S) uniq
9910: 75 65 66 6c 61 67 28 55 29 20 49 4e 44 45 58 20  ueflag(U) INDEX 
9920: 69 66 6e 6f 74 65 78 69 73 74 73 28 4e 45 29 20  ifnotexists(NE) 
9930: 6e 6d 28 58 29 20 64 62 6e 6d 28 44 29 0a 20 20  nm(X) dbnm(D).  
9940: 20 20 20 20 20 20 4f 4e 20 6e 6d 28 59 29 20 4c        ON nm(Y) L
9950: 50 20 69 64 78 6c 69 73 74 28 5a 29 20 52 50 28  P idxlist(Z) RP(
9960: 45 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33 43  E). {.  sqlite3C
9970: 72 65 61 74 65 49 6e 64 65 78 28 70 50 61 72 73  reateIndex(pPars
9980: 65 2c 20 26 58 2c 20 26 44 2c 20 0a 20 20 20 20  e, &X, &D, .    
9990: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
99a0: 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74 41   sqlite3SrcListA
99b0: 70 70 65 6e 64 28 70 50 61 72 73 65 2d 3e 64 62  ppend(pParse->db
99c0: 2c 30 2c 26 59 2c 30 29 2c 20 5a 2c 20 55 2c 0a  ,0,&Y,0), Z, U,.
99d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
99e0: 20 20 20 20 20 20 26 53 2c 20 26 45 2c 20 53 51        &S, &E, SQ
99f0: 4c 49 54 45 5f 53 4f 5f 41 53 43 2c 20 4e 45 29  LITE_SO_ASC, NE)
9a00: 3b 0a 7d 0a 0a 25 74 79 70 65 20 75 6e 69 71 75  ;.}..%type uniqu
9a10: 65 66 6c 61 67 20 7b 69 6e 74 7d 0a 75 6e 69 71  eflag {int}.uniq
9a20: 75 65 66 6c 61 67 28 41 29 20 3a 3a 3d 20 55 4e  ueflag(A) ::= UN
9a30: 49 51 55 45 2e 20 20 7b 41 20 3d 20 4f 45 5f 41  IQUE.  {A = OE_A
9a40: 62 6f 72 74 3b 7d 0a 75 6e 69 71 75 65 66 6c 61  bort;}.uniquefla
9a50: 67 28 41 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20  g(A) ::= .      
9a60: 20 20 7b 41 20 3d 20 4f 45 5f 4e 6f 6e 65 3b 7d    {A = OE_None;}
9a70: 0a 0a 25 74 79 70 65 20 69 64 78 6c 69 73 74 20  ..%type idxlist 
9a80: 7b 45 78 70 72 4c 69 73 74 2a 7d 0a 25 64 65 73  {ExprList*}.%des
9a90: 74 72 75 63 74 6f 72 20 69 64 78 6c 69 73 74 20  tructor idxlist 
9aa0: 7b 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74  {sqlite3ExprList
9ab0: 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64  Delete(pParse->d
9ac0: 62 2c 20 24 24 29 3b 7d 0a 25 74 79 70 65 20 69  b, $$);}.%type i
9ad0: 64 78 6c 69 73 74 5f 6f 70 74 20 7b 45 78 70 72  dxlist_opt {Expr
9ae0: 4c 69 73 74 2a 7d 0a 25 64 65 73 74 72 75 63 74  List*}.%destruct
9af0: 6f 72 20 69 64 78 6c 69 73 74 5f 6f 70 74 20 7b  or idxlist_opt {
9b00: 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74 44  sqlite3ExprListD
9b10: 65 6c 65 74 65 28 70 50 61 72 73 65 2d 3e 64 62  elete(pParse->db
9b20: 2c 20 24 24 29 3b 7d 0a 0a 69 64 78 6c 69 73 74  , $$);}..idxlist
9b30: 5f 6f 70 74 28 41 29 20 3a 3a 3d 20 2e 20 20 20  _opt(A) ::= .   
9b40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9b50: 20 20 20 20 20 20 7b 41 20 3d 20 30 3b 7d 0a 69        {A = 0;}.i
9b60: 64 78 6c 69 73 74 5f 6f 70 74 28 41 29 20 3a 3a  dxlist_opt(A) ::
9b70: 3d 20 4c 50 20 69 64 78 6c 69 73 74 28 58 29 20  = LP idxlist(X) 
9b80: 52 50 2e 20 20 20 20 20 20 20 20 20 7b 41 20 3d  RP.         {A =
9b90: 20 58 3b 7d 0a 69 64 78 6c 69 73 74 28 41 29 20   X;}.idxlist(A) 
9ba0: 3a 3a 3d 20 69 64 78 6c 69 73 74 28 58 29 20 43  ::= idxlist(X) C
9bb0: 4f 4d 4d 41 20 6e 6d 28 59 29 20 63 6f 6c 6c 61  OMMA nm(Y) colla
9bc0: 74 65 28 43 29 20 73 6f 72 74 6f 72 64 65 72 28  te(C) sortorder(
9bd0: 5a 29 2e 20 20 7b 0a 20 20 45 78 70 72 20 2a 70  Z).  {.  Expr *p
9be0: 20 3d 20 30 3b 0a 20 20 69 66 28 20 43 2e 6e 3e   = 0;.  if( C.n>
9bf0: 30 20 29 7b 0a 20 20 20 20 70 20 3d 20 73 71 6c  0 ){.    p = sql
9c00: 69 74 65 33 45 78 70 72 28 70 50 61 72 73 65 2d  ite3Expr(pParse-
9c10: 3e 64 62 2c 20 54 4b 5f 43 4f 4c 55 4d 4e 2c 20  >db, TK_COLUMN, 
9c20: 30 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 45  0);.    sqlite3E
9c30: 78 70 72 53 65 74 43 6f 6c 6c 28 70 50 61 72 73  xprSetColl(pPars
9c40: 65 2c 20 70 2c 20 26 43 29 3b 0a 20 20 7d 0a 20  e, p, &C);.  }. 
9c50: 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72   A = sqlite3Expr
9c60: 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72 73  ListAppend(pPars
9c70: 65 2c 58 2c 20 70 29 3b 0a 20 20 73 71 6c 69 74  e,X, p);.  sqlit
9c80: 65 33 45 78 70 72 4c 69 73 74 53 65 74 4e 61 6d  e3ExprListSetNam
9c90: 65 28 70 50 61 72 73 65 2c 41 2c 26 59 2c 31 29  e(pParse,A,&Y,1)
9ca0: 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72 4c  ;.  sqlite3ExprL
9cb0: 69 73 74 43 68 65 63 6b 4c 65 6e 67 74 68 28 70  istCheckLength(p
9cc0: 50 61 72 73 65 2c 20 41 2c 20 22 69 6e 64 65 78  Parse, A, "index
9cd0: 22 29 3b 0a 20 20 69 66 28 20 41 20 29 20 41 2d  ");.  if( A ) A-
9ce0: 3e 61 5b 41 2d 3e 6e 45 78 70 72 2d 31 5d 2e 73  >a[A->nExpr-1].s
9cf0: 6f 72 74 4f 72 64 65 72 20 3d 20 28 75 38 29 5a  ortOrder = (u8)Z
9d00: 3b 0a 7d 0a 69 64 78 6c 69 73 74 28 41 29 20 3a  ;.}.idxlist(A) :
9d10: 3a 3d 20 6e 6d 28 59 29 20 63 6f 6c 6c 61 74 65  := nm(Y) collate
9d20: 28 43 29 20 73 6f 72 74 6f 72 64 65 72 28 5a 29  (C) sortorder(Z)
9d30: 2e 20 7b 0a 20 20 45 78 70 72 20 2a 70 20 3d 20  . {.  Expr *p = 
9d40: 30 3b 0a 20 20 69 66 28 20 43 2e 6e 3e 30 20 29  0;.  if( C.n>0 )
9d50: 7b 0a 20 20 20 20 70 20 3d 20 73 71 6c 69 74 65  {.    p = sqlite
9d60: 33 50 45 78 70 72 28 70 50 61 72 73 65 2c 20 54  3PExpr(pParse, T
9d70: 4b 5f 43 4f 4c 55 4d 4e 2c 20 30 2c 20 30 2c 20  K_COLUMN, 0, 0, 
9d80: 30 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 45  0);.    sqlite3E
9d90: 78 70 72 53 65 74 43 6f 6c 6c 28 70 50 61 72 73  xprSetColl(pPars
9da0: 65 2c 20 70 2c 20 26 43 29 3b 0a 20 20 7d 0a 20  e, p, &C);.  }. 
9db0: 20 41 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72   A = sqlite3Expr
9dc0: 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72 73  ListAppend(pPars
9dd0: 65 2c 30 2c 20 70 29 3b 0a 20 20 73 71 6c 69 74  e,0, p);.  sqlit
9de0: 65 33 45 78 70 72 4c 69 73 74 53 65 74 4e 61 6d  e3ExprListSetNam
9df0: 65 28 70 50 61 72 73 65 2c 20 41 2c 20 26 59 2c  e(pParse, A, &Y,
9e00: 20 31 29 3b 0a 20 20 73 71 6c 69 74 65 33 45 78   1);.  sqlite3Ex
9e10: 70 72 4c 69 73 74 43 68 65 63 6b 4c 65 6e 67 74  prListCheckLengt
9e20: 68 28 70 50 61 72 73 65 2c 20 41 2c 20 22 69 6e  h(pParse, A, "in
9e30: 64 65 78 22 29 3b 0a 20 20 69 66 28 20 41 20 29  dex");.  if( A )
9e40: 20 41 2d 3e 61 5b 41 2d 3e 6e 45 78 70 72 2d 31   A->a[A->nExpr-1
9e50: 5d 2e 73 6f 72 74 4f 72 64 65 72 20 3d 20 28 75  ].sortOrder = (u
9e60: 38 29 5a 3b 0a 7d 0a 0a 25 74 79 70 65 20 63 6f  8)Z;.}..%type co
9e70: 6c 6c 61 74 65 20 7b 54 6f 6b 65 6e 7d 0a 63 6f  llate {Token}.co
9e80: 6c 6c 61 74 65 28 43 29 20 3a 3a 3d 20 2e 20 20  llate(C) ::= .  
9e90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
9ea0: 43 2e 7a 20 3d 20 30 3b 20 43 2e 6e 20 3d 20 30  C.z = 0; C.n = 0
9eb0: 3b 7d 0a 63 6f 6c 6c 61 74 65 28 43 29 20 3a 3a  ;}.collate(C) ::
9ec0: 3d 20 43 4f 4c 4c 41 54 45 20 69 64 73 28 58 29  = COLLATE ids(X)
9ed0: 2e 20 20 20 7b 43 20 3d 20 58 3b 7d 0a 0a 0a 2f  .   {C = X;}.../
9ee0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
9ef0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54 68 65  //////////// The
9f00: 20 44 52 4f 50 20 49 4e 44 45 58 20 63 6f 6d 6d   DROP INDEX comm
9f10: 61 6e 64 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  and ////////////
9f20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 2f 2f  /////////////.//
9f30: 0a 63 6d 64 20 3a 3a 3d 20 44 52 4f 50 20 49 4e  .cmd ::= DROP IN
9f40: 44 45 58 20 69 66 65 78 69 73 74 73 28 45 29 20  DEX ifexists(E) 
9f50: 66 75 6c 6c 6e 61 6d 65 28 58 29 2e 20 20 20 7b  fullname(X).   {
9f60: 73 71 6c 69 74 65 33 44 72 6f 70 49 6e 64 65 78  sqlite3DropIndex
9f70: 28 70 50 61 72 73 65 2c 20 58 2c 20 45 29 3b 7d  (pParse, X, E);}
9f80: 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ..//////////////
9f90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20  /////////////// 
9fa0: 54 68 65 20 56 41 43 55 55 4d 20 63 6f 6d 6d 61  The VACUUM comma
9fb0: 6e 64 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  nd /////////////
9fc0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
9fd0: 0a 2f 2f 0a 25 69 66 6e 64 65 66 20 53 51 4c 49  .//.%ifndef SQLI
9fe0: 54 45 5f 4f 4d 49 54 5f 56 41 43 55 55 4d 0a 25  TE_OMIT_VACUUM.%
9ff0: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
a000: 49 54 5f 41 54 54 41 43 48 0a 63 6d 64 20 3a 3a  IT_ATTACH.cmd ::
a010: 3d 20 56 41 43 55 55 4d 2e 20 20 20 20 20 20 20  = VACUUM.       
a020: 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65           {sqlite
a030: 33 56 61 63 75 75 6d 28 70 50 61 72 73 65 29 3b  3Vacuum(pParse);
a040: 7d 0a 63 6d 64 20 3a 3a 3d 20 56 41 43 55 55 4d  }.cmd ::= VACUUM
a050: 20 6e 6d 2e 20 20 20 20 20 20 20 20 20 20 20 20   nm.            
a060: 20 7b 73 71 6c 69 74 65 33 56 61 63 75 75 6d 28   {sqlite3Vacuum(
a070: 70 50 61 72 73 65 29 3b 7d 0a 25 65 6e 64 69 66  pParse);}.%endif
a080: 20 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 54    SQLITE_OMIT_AT
a090: 54 41 43 48 0a 25 65 6e 64 69 66 20 20 53 51 4c  TACH.%endif  SQL
a0a0: 49 54 45 5f 4f 4d 49 54 5f 56 41 43 55 55 4d 0a  ITE_OMIT_VACUUM.
a0b0: 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .///////////////
a0c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 54  ////////////// T
a0d0: 68 65 20 50 52 41 47 4d 41 20 63 6f 6d 6d 61 6e  he PRAGMA comman
a0e0: 64 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  d //////////////
a0f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a  ///////////////.
a100: 2f 2f 0a 25 69 66 6e 64 65 66 20 53 51 4c 49 54  //.%ifndef SQLIT
a110: 45 5f 4f 4d 49 54 5f 50 52 41 47 4d 41 0a 63 6d  E_OMIT_PRAGMA.cm
a120: 64 20 3a 3a 3d 20 50 52 41 47 4d 41 20 6e 6d 28  d ::= PRAGMA nm(
a130: 58 29 20 64 62 6e 6d 28 5a 29 2e 20 20 20 20 20  X) dbnm(Z).     
a140: 20 20 20 20 20 20 20 20 20 20 20 7b 73 71 6c 69             {sqli
a150: 74 65 33 50 72 61 67 6d 61 28 70 50 61 72 73 65  te3Pragma(pParse
a160: 2c 26 58 2c 26 5a 2c 30 2c 30 29 3b 7d 0a 63 6d  ,&X,&Z,0,0);}.cm
a170: 64 20 3a 3a 3d 20 50 52 41 47 4d 41 20 6e 6d 28  d ::= PRAGMA nm(
a180: 58 29 20 64 62 6e 6d 28 5a 29 20 45 51 20 6e 6d  X) dbnm(Z) EQ nm
a190: 6e 75 6d 28 59 29 2e 20 20 20 20 7b 73 71 6c 69  num(Y).    {sqli
a1a0: 74 65 33 50 72 61 67 6d 61 28 70 50 61 72 73 65  te3Pragma(pParse
a1b0: 2c 26 58 2c 26 5a 2c 26 59 2c 30 29 3b 7d 0a 63  ,&X,&Z,&Y,0);}.c
a1c0: 6d 64 20 3a 3a 3d 20 50 52 41 47 4d 41 20 6e 6d  md ::= PRAGMA nm
a1d0: 28 58 29 20 64 62 6e 6d 28 5a 29 20 4c 50 20 6e  (X) dbnm(Z) LP n
a1e0: 6d 6e 75 6d 28 59 29 20 52 50 2e 20 7b 73 71 6c  mnum(Y) RP. {sql
a1f0: 69 74 65 33 50 72 61 67 6d 61 28 70 50 61 72 73  ite3Pragma(pPars
a200: 65 2c 26 58 2c 26 5a 2c 26 59 2c 30 29 3b 7d 0a  e,&X,&Z,&Y,0);}.
a210: 63 6d 64 20 3a 3a 3d 20 50 52 41 47 4d 41 20 6e  cmd ::= PRAGMA n
a220: 6d 28 58 29 20 64 62 6e 6d 28 5a 29 20 45 51 20  m(X) dbnm(Z) EQ 
a230: 6d 69 6e 75 73 5f 6e 75 6d 28 59 29 2e 20 0a 20  minus_num(Y). . 
a240: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
a250: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
a260: 20 20 20 20 20 20 20 20 20 20 20 20 7b 73 71 6c              {sql
a270: 69 74 65 33 50 72 61 67 6d 61 28 70 50 61 72 73  ite3Pragma(pPars
a280: 65 2c 26 58 2c 26 5a 2c 26 59 2c 31 29 3b 7d 0a  e,&X,&Z,&Y,1);}.
a290: 63 6d 64 20 3a 3a 3d 20 50 52 41 47 4d 41 20 6e  cmd ::= PRAGMA n
a2a0: 6d 28 58 29 20 64 62 6e 6d 28 5a 29 20 4c 50 20  m(X) dbnm(Z) LP 
a2b0: 6d 69 6e 75 73 5f 6e 75 6d 28 59 29 20 52 50 2e  minus_num(Y) RP.
a2c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
a2d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
a2e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 73                {s
a2f0: 71 6c 69 74 65 33 50 72 61 67 6d 61 28 70 50 61  qlite3Pragma(pPa
a300: 72 73 65 2c 26 58 2c 26 5a 2c 26 59 2c 31 29 3b  rse,&X,&Z,&Y,1);
a310: 7d 0a 0a 6e 6d 6e 75 6d 28 41 29 20 3a 3a 3d 20  }..nmnum(A) ::= 
a320: 70 6c 75 73 5f 6e 75 6d 28 58 29 2e 20 20 20 20  plus_num(X).    
a330: 20 20 20 20 20 20 20 20 20 7b 41 20 3d 20 58 3b           {A = X;
a340: 7d 0a 6e 6d 6e 75 6d 28 41 29 20 3a 3a 3d 20 6e  }.nmnum(A) ::= n
a350: 6d 28 58 29 2e 20 20 20 20 20 20 20 20 20 20 20  m(X).           
a360: 20 20 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d          {A = X;}
a370: 0a 6e 6d 6e 75 6d 28 41 29 20 3a 3a 3d 20 4f 4e  .nmnum(A) ::= ON
a380: 28 58 29 2e 20 20 20 20 20 20 20 20 20 20 20 20  (X).            
a390: 20 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a         {A = X;}.
a3a0: 6e 6d 6e 75 6d 28 41 29 20 3a 3a 3d 20 44 45 4c  nmnum(A) ::= DEL
a3b0: 45 54 45 28 58 29 2e 20 20 20 20 20 20 20 20 20  ETE(X).         
a3c0: 20 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 6e        {A = X;}.n
a3d0: 6d 6e 75 6d 28 41 29 20 3a 3a 3d 20 44 45 46 41  mnum(A) ::= DEFA
a3e0: 55 4c 54 28 58 29 2e 20 20 20 20 20 20 20 20 20  ULT(X).         
a3f0: 20 20 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 25 65       {A = X;}.%e
a400: 6e 64 69 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  ndif SQLITE_OMIT
a410: 5f 50 52 41 47 4d 41 0a 70 6c 75 73 5f 6e 75 6d  _PRAGMA.plus_num
a420: 28 41 29 20 3a 3a 3d 20 70 6c 75 73 5f 6f 70 74  (A) ::= plus_opt
a430: 20 6e 75 6d 62 65 72 28 58 29 2e 20 20 20 7b 41   number(X).   {A
a440: 20 3d 20 58 3b 7d 0a 6d 69 6e 75 73 5f 6e 75 6d   = X;}.minus_num
a450: 28 41 29 20 3a 3a 3d 20 4d 49 4e 55 53 20 6e 75  (A) ::= MINUS nu
a460: 6d 62 65 72 28 58 29 2e 20 20 20 20 20 7b 41 20  mber(X).     {A 
a470: 3d 20 58 3b 7d 0a 6e 75 6d 62 65 72 28 41 29 20  = X;}.number(A) 
a480: 3a 3a 3d 20 49 4e 54 45 47 45 52 7c 46 4c 4f 41  ::= INTEGER|FLOA
a490: 54 28 58 29 2e 20 20 20 20 20 20 20 7b 41 20 3d  T(X).       {A =
a4a0: 20 58 3b 7d 0a 70 6c 75 73 5f 6f 70 74 20 3a 3a   X;}.plus_opt ::
a4b0: 3d 20 50 4c 55 53 2e 0a 70 6c 75 73 5f 6f 70 74  = PLUS..plus_opt
a4c0: 20 3a 3a 3d 20 2e 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f   ::= ...////////
a4d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
a4e0: 2f 2f 2f 2f 20 54 68 65 20 43 52 45 41 54 45 20  //// The CREATE 
a4f0: 54 52 49 47 47 45 52 20 63 6f 6d 6d 61 6e 64 20  TRIGGER command 
a500: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
a510: 2f 2f 2f 2f 2f 0a 0a 25 69 66 6e 64 65 66 20 53  /////..%ifndef S
a520: 51 4c 49 54 45 5f 4f 4d 49 54 5f 54 52 49 47 47  QLITE_OMIT_TRIGG
a530: 45 52 0a 0a 63 6d 64 20 3a 3a 3d 20 63 72 65 61  ER..cmd ::= crea
a540: 74 65 6b 77 20 74 72 69 67 67 65 72 5f 64 65 63  tekw trigger_dec
a550: 6c 28 41 29 20 42 45 47 49 4e 20 74 72 69 67 67  l(A) BEGIN trigg
a560: 65 72 5f 63 6d 64 5f 6c 69 73 74 28 53 29 20 45  er_cmd_list(S) E
a570: 4e 44 28 5a 29 2e 20 7b 0a 20 20 54 6f 6b 65 6e  ND(Z). {.  Token
a580: 20 61 6c 6c 3b 0a 20 20 61 6c 6c 2e 7a 20 3d 20   all;.  all.z = 
a590: 41 2e 7a 3b 0a 20 20 61 6c 6c 2e 6e 20 3d 20 28  A.z;.  all.n = (
a5a0: 69 6e 74 29 28 5a 2e 7a 20 2d 20 41 2e 7a 29 20  int)(Z.z - A.z) 
a5b0: 2b 20 5a 2e 6e 3b 0a 20 20 73 71 6c 69 74 65 33  + Z.n;.  sqlite3
a5c0: 46 69 6e 69 73 68 54 72 69 67 67 65 72 28 70 50  FinishTrigger(pP
a5d0: 61 72 73 65 2c 20 53 2c 20 26 61 6c 6c 29 3b 0a  arse, S, &all);.
a5e0: 7d 0a 0a 74 72 69 67 67 65 72 5f 64 65 63 6c 28  }..trigger_decl(
a5f0: 41 29 20 3a 3a 3d 20 74 65 6d 70 28 54 29 20 54  A) ::= temp(T) T
a600: 52 49 47 47 45 52 20 69 66 6e 6f 74 65 78 69 73  RIGGER ifnotexis
a610: 74 73 28 4e 4f 45 52 52 29 20 6e 6d 28 42 29 20  ts(NOERR) nm(B) 
a620: 64 62 6e 6d 28 5a 29 20 0a 20 20 20 20 20 20 20  dbnm(Z) .       
a630: 20 20 20 20 20 20 20 20 20 20 20 20 20 74 72 69               tri
a640: 67 67 65 72 5f 74 69 6d 65 28 43 29 20 74 72 69  gger_time(C) tri
a650: 67 67 65 72 5f 65 76 65 6e 74 28 44 29 0a 20 20  gger_event(D).  
a660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
a670: 20 20 4f 4e 20 66 75 6c 6c 6e 61 6d 65 28 45 29    ON fullname(E)
a680: 20 66 6f 72 65 61 63 68 5f 63 6c 61 75 73 65 20   foreach_clause 
a690: 77 68 65 6e 5f 63 6c 61 75 73 65 28 47 29 2e 20  when_clause(G). 
a6a0: 7b 0a 20 20 73 71 6c 69 74 65 33 42 65 67 69 6e  {.  sqlite3Begin
a6b0: 54 72 69 67 67 65 72 28 70 50 61 72 73 65 2c 20  Trigger(pParse, 
a6c0: 26 42 2c 20 26 5a 2c 20 43 2c 20 44 2e 61 2c 20  &B, &Z, C, D.a, 
a6d0: 44 2e 62 2c 20 45 2c 20 47 2c 20 54 2c 20 4e 4f  D.b, E, G, T, NO
a6e0: 45 52 52 29 3b 0a 20 20 41 20 3d 20 28 5a 2e 6e  ERR);.  A = (Z.n
a6f0: 3d 3d 30 3f 42 3a 5a 29 3b 0a 7d 0a 0a 25 74 79  ==0?B:Z);.}..%ty
a700: 70 65 20 74 72 69 67 67 65 72 5f 74 69 6d 65 20  pe trigger_time 
a710: 7b 69 6e 74 7d 0a 74 72 69 67 67 65 72 5f 74 69  {int}.trigger_ti
a720: 6d 65 28 41 29 20 3a 3a 3d 20 42 45 46 4f 52 45  me(A) ::= BEFORE
a730: 2e 20 20 20 20 20 20 7b 20 41 20 3d 20 54 4b 5f  .      { A = TK_
a740: 42 45 46 4f 52 45 3b 20 7d 0a 74 72 69 67 67 65  BEFORE; }.trigge
a750: 72 5f 74 69 6d 65 28 41 29 20 3a 3a 3d 20 41 46  r_time(A) ::= AF
a760: 54 45 52 2e 20 20 20 20 20 20 20 7b 20 41 20 3d  TER.       { A =
a770: 20 54 4b 5f 41 46 54 45 52 3b 20 20 7d 0a 74 72   TK_AFTER;  }.tr
a780: 69 67 67 65 72 5f 74 69 6d 65 28 41 29 20 3a 3a  igger_time(A) ::
a790: 3d 20 49 4e 53 54 45 41 44 20 4f 46 2e 20 20 7b  = INSTEAD OF.  {
a7a0: 20 41 20 3d 20 54 4b 5f 49 4e 53 54 45 41 44 3b   A = TK_INSTEAD;
a7b0: 7d 0a 74 72 69 67 67 65 72 5f 74 69 6d 65 28 41  }.trigger_time(A
a7c0: 29 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20  ) ::= .         
a7d0: 20 20 20 7b 20 41 20 3d 20 54 4b 5f 42 45 46 4f     { A = TK_BEFO
a7e0: 52 45 3b 20 7d 0a 0a 25 74 79 70 65 20 74 72 69  RE; }..%type tri
a7f0: 67 67 65 72 5f 65 76 65 6e 74 20 7b 73 74 72 75  gger_event {stru
a800: 63 74 20 54 72 69 67 45 76 65 6e 74 7d 0a 25 64  ct TrigEvent}.%d
a810: 65 73 74 72 75 63 74 6f 72 20 74 72 69 67 67 65  estructor trigge
a820: 72 5f 65 76 65 6e 74 20 7b 73 71 6c 69 74 65 33  r_event {sqlite3
a830: 49 64 4c 69 73 74 44 65 6c 65 74 65 28 70 50 61  IdListDelete(pPa
a840: 72 73 65 2d 3e 64 62 2c 20 24 24 2e 62 29 3b 7d  rse->db, $$.b);}
a850: 0a 74 72 69 67 67 65 72 5f 65 76 65 6e 74 28 41  .trigger_event(A
a860: 29 20 3a 3a 3d 20 44 45 4c 45 54 45 7c 49 4e 53  ) ::= DELETE|INS
a870: 45 52 54 28 4f 50 29 2e 20 20 20 20 20 20 20 7b  ERT(OP).       {
a880: 41 2e 61 20 3d 20 40 4f 50 3b 20 41 2e 62 20 3d  A.a = @OP; A.b =
a890: 20 30 3b 7d 0a 74 72 69 67 67 65 72 5f 65 76 65   0;}.trigger_eve
a8a0: 6e 74 28 41 29 20 3a 3a 3d 20 55 50 44 41 54 45  nt(A) ::= UPDATE
a8b0: 28 4f 50 29 2e 20 20 20 20 20 20 20 20 20 20 20  (OP).           
a8c0: 20 20 20 7b 41 2e 61 20 3d 20 40 4f 50 3b 20 41     {A.a = @OP; A
a8d0: 2e 62 20 3d 20 30 3b 7d 0a 74 72 69 67 67 65 72  .b = 0;}.trigger
a8e0: 5f 65 76 65 6e 74 28 41 29 20 3a 3a 3d 20 55 50  _event(A) ::= UP
a8f0: 44 41 54 45 20 4f 46 20 69 6e 73 63 6f 6c 6c 69  DATE OF inscolli
a900: 73 74 28 58 29 2e 20 7b 41 2e 61 20 3d 20 54 4b  st(X). {A.a = TK
a910: 5f 55 50 44 41 54 45 3b 20 41 2e 62 20 3d 20 58  _UPDATE; A.b = X
a920: 3b 7d 0a 0a 66 6f 72 65 61 63 68 5f 63 6c 61 75  ;}..foreach_clau
a930: 73 65 20 3a 3a 3d 20 2e 0a 66 6f 72 65 61 63 68  se ::= ..foreach
a940: 5f 63 6c 61 75 73 65 20 3a 3a 3d 20 46 4f 52 20  _clause ::= FOR 
a950: 45 41 43 48 20 52 4f 57 2e 0a 0a 25 74 79 70 65  EACH ROW...%type
a960: 20 77 68 65 6e 5f 63 6c 61 75 73 65 20 7b 45 78   when_clause {Ex
a970: 70 72 2a 7d 0a 25 64 65 73 74 72 75 63 74 6f 72  pr*}.%destructor
a980: 20 77 68 65 6e 5f 63 6c 61 75 73 65 20 7b 73 71   when_clause {sq
a990: 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65 28  lite3ExprDelete(
a9a0: 70 50 61 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b  pParse->db, $$);
a9b0: 7d 0a 77 68 65 6e 5f 63 6c 61 75 73 65 28 41 29  }.when_clause(A)
a9c0: 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20   ::= .          
a9d0: 20 20 20 7b 20 41 20 3d 20 30 3b 20 7d 0a 77 68     { A = 0; }.wh
a9e0: 65 6e 5f 63 6c 61 75 73 65 28 41 29 20 3a 3a 3d  en_clause(A) ::=
a9f0: 20 57 48 45 4e 20 65 78 70 72 28 58 29 2e 20 7b   WHEN expr(X). {
aa00: 20 41 20 3d 20 58 2e 70 45 78 70 72 3b 20 7d 0a   A = X.pExpr; }.
aa10: 0a 25 74 79 70 65 20 74 72 69 67 67 65 72 5f 63  .%type trigger_c
aa20: 6d 64 5f 6c 69 73 74 20 7b 54 72 69 67 67 65 72  md_list {Trigger
aa30: 53 74 65 70 2a 7d 0a 25 64 65 73 74 72 75 63 74  Step*}.%destruct
aa40: 6f 72 20 74 72 69 67 67 65 72 5f 63 6d 64 5f 6c  or trigger_cmd_l
aa50: 69 73 74 20 7b 73 71 6c 69 74 65 33 44 65 6c 65  ist {sqlite3Dele
aa60: 74 65 54 72 69 67 67 65 72 53 74 65 70 28 70 50  teTriggerStep(pP
aa70: 61 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a  arse->db, $$);}.
aa80: 74 72 69 67 67 65 72 5f 63 6d 64 5f 6c 69 73 74  trigger_cmd_list
aa90: 28 41 29 20 3a 3a 3d 20 74 72 69 67 67 65 72 5f  (A) ::= trigger_
aaa0: 63 6d 64 5f 6c 69 73 74 28 59 29 20 74 72 69 67  cmd_list(Y) trig
aab0: 67 65 72 5f 63 6d 64 28 58 29 20 53 45 4d 49 2e  ger_cmd(X) SEMI.
aac0: 20 7b 0a 20 20 61 73 73 65 72 74 28 20 59 21 3d   {.  assert( Y!=
aad0: 30 20 29 3b 0a 20 20 59 2d 3e 70 4c 61 73 74 2d  0 );.  Y->pLast-
aae0: 3e 70 4e 65 78 74 20 3d 20 58 3b 0a 20 20 59 2d  >pNext = X;.  Y-
aaf0: 3e 70 4c 61 73 74 20 3d 20 58 3b 0a 20 20 41 20  >pLast = X;.  A 
ab00: 3d 20 59 3b 0a 7d 0a 74 72 69 67 67 65 72 5f 63  = Y;.}.trigger_c
ab10: 6d 64 5f 6c 69 73 74 28 41 29 20 3a 3a 3d 20 74  md_list(A) ::= t
ab20: 72 69 67 67 65 72 5f 63 6d 64 28 58 29 20 53 45  rigger_cmd(X) SE
ab30: 4d 49 2e 20 7b 20 0a 20 20 61 73 73 65 72 74 28  MI. { .  assert(
ab40: 20 58 21 3d 30 20 29 3b 0a 20 20 58 2d 3e 70 4c   X!=0 );.  X->pL
ab50: 61 73 74 20 3d 20 58 3b 0a 20 20 41 20 3d 20 58  ast = X;.  A = X
ab60: 3b 0a 7d 0a 0a 2f 2f 20 44 69 73 61 6c 6c 6f 77  ;.}..// Disallow
ab70: 20 71 75 61 6c 69 66 69 65 64 20 74 61 62 6c 65   qualified table
ab80: 20 6e 61 6d 65 73 20 6f 6e 20 49 4e 53 45 52 54   names on INSERT
ab90: 2c 20 55 50 44 41 54 45 2c 20 61 6e 64 20 44 45  , UPDATE, and DE
aba0: 4c 45 54 45 20 73 74 61 74 65 6d 65 6e 74 73 0a  LETE statements.
abb0: 2f 2f 20 77 69 74 68 69 6e 20 61 20 74 72 69 67  // within a trig
abc0: 67 65 72 2e 20 20 54 68 65 20 74 61 62 6c 65 20  ger.  The table 
abd0: 74 6f 20 49 4e 53 45 52 54 2c 20 55 50 44 41 54  to INSERT, UPDAT
abe0: 45 2c 20 6f 72 20 44 45 4c 45 54 45 20 69 73 20  E, or DELETE is 
abf0: 61 6c 77 61 79 73 20 69 6e 20 0a 2f 2f 20 74 68  always in .// th
ac00: 65 20 73 61 6d 65 20 64 61 74 61 62 61 73 65 20  e same database 
ac10: 61 73 20 74 68 65 20 74 61 62 6c 65 20 74 68 61  as the table tha
ac20: 74 20 74 68 65 20 74 72 69 67 67 65 72 20 66 69  t the trigger fi
ac30: 72 65 73 20 6f 6e 2e 0a 2f 2f 0a 25 74 79 70 65  res on..//.%type
ac40: 20 74 72 6e 6d 20 7b 54 6f 6b 65 6e 7d 0a 74 72   trnm {Token}.tr
ac50: 6e 6d 28 41 29 20 3a 3a 3d 20 6e 6d 28 58 29 2e  nm(A) ::= nm(X).
ac60: 20 20 20 7b 41 20 3d 20 58 3b 7d 0a 74 72 6e 6d     {A = X;}.trnm
ac70: 28 41 29 20 3a 3a 3d 20 6e 6d 20 44 4f 54 20 6e  (A) ::= nm DOT n
ac80: 6d 28 58 29 2e 20 7b 0a 20 20 41 20 3d 20 58 3b  m(X). {.  A = X;
ac90: 0a 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d  .  sqlite3ErrorM
aca0: 73 67 28 70 50 61 72 73 65 2c 20 0a 20 20 20 20  sg(pParse, .    
acb0: 20 20 20 20 22 71 75 61 6c 69 66 69 65 64 20 74      "qualified t
acc0: 61 62 6c 65 20 6e 61 6d 65 73 20 61 72 65 20 6e  able names are n
acd0: 6f 74 20 61 6c 6c 6f 77 65 64 20 6f 6e 20 49 4e  ot allowed on IN
ace0: 53 45 52 54 2c 20 55 50 44 41 54 45 2c 20 61 6e  SERT, UPDATE, an
acf0: 64 20 44 45 4c 45 54 45 20 22 0a 20 20 20 20 20  d DELETE ".     
ad00: 20 20 20 22 73 74 61 74 65 6d 65 6e 74 73 20 77     "statements w
ad10: 69 74 68 69 6e 20 74 72 69 67 67 65 72 73 22 29  ithin triggers")
ad20: 3b 0a 7d 0a 0a 2f 2f 20 44 69 73 61 6c 6c 6f 77  ;.}..// Disallow
ad30: 20 74 68 65 20 49 4e 44 45 58 20 42 59 20 61 6e   the INDEX BY an
ad40: 64 20 4e 4f 54 20 49 4e 44 45 58 45 44 20 63 6c  d NOT INDEXED cl
ad50: 61 75 73 65 73 20 6f 6e 20 55 50 44 41 54 45 20  auses on UPDATE 
ad60: 61 6e 64 20 44 45 4c 45 54 45 0a 2f 2f 20 73 74  and DELETE.// st
ad70: 61 74 65 6d 65 6e 74 73 20 77 69 74 68 69 6e 20  atements within 
ad80: 74 72 69 67 67 65 72 73 2e 20 20 57 65 20 6d 61  triggers.  We ma
ad90: 6b 65 20 61 20 73 70 65 63 69 66 69 63 20 65 72  ke a specific er
ada0: 72 6f 72 20 6d 65 73 73 61 67 65 20 66 6f 72 20  ror message for 
adb0: 74 68 69 73 0a 2f 2f 20 73 69 6e 63 65 20 69 74  this.// since it
adc0: 20 69 73 20 61 6e 20 65 78 63 65 70 74 69 6f 6e   is an exception
add0: 20 74 6f 20 74 68 65 20 64 65 66 61 75 6c 74 20   to the default 
ade0: 67 72 61 6d 6d 61 72 20 72 75 6c 65 73 2e 0a 2f  grammar rules../
adf0: 2f 0a 74 72 69 64 78 62 79 20 3a 3a 3d 20 2e 0a  /.tridxby ::= ..
ae00: 74 72 69 64 78 62 79 20 3a 3a 3d 20 49 4e 44 45  tridxby ::= INDE
ae10: 58 45 44 20 42 59 20 6e 6d 2e 20 7b 0a 20 20 73  XED BY nm. {.  s
ae20: 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70  qlite3ErrorMsg(p
ae30: 50 61 72 73 65 2c 0a 20 20 20 20 20 20 20 20 22  Parse,.        "
ae40: 74 68 65 20 49 4e 44 45 58 45 44 20 42 59 20 63  the INDEXED BY c
ae50: 6c 61 75 73 65 20 69 73 20 6e 6f 74 20 61 6c 6c  lause is not all
ae60: 6f 77 65 64 20 6f 6e 20 55 50 44 41 54 45 20 6f  owed on UPDATE o
ae70: 72 20 44 45 4c 45 54 45 20 73 74 61 74 65 6d 65  r DELETE stateme
ae80: 6e 74 73 20 22 0a 20 20 20 20 20 20 20 20 22 77  nts ".        "w
ae90: 69 74 68 69 6e 20 74 72 69 67 67 65 72 73 22 29  ithin triggers")
aea0: 3b 0a 7d 0a 74 72 69 64 78 62 79 20 3a 3a 3d 20  ;.}.tridxby ::= 
aeb0: 4e 4f 54 20 49 4e 44 45 58 45 44 2e 20 7b 0a 20  NOT INDEXED. {. 
aec0: 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67   sqlite3ErrorMsg
aed0: 28 70 50 61 72 73 65 2c 0a 20 20 20 20 20 20 20  (pParse,.       
aee0: 20 22 74 68 65 20 4e 4f 54 20 49 4e 44 45 58 45   "the NOT INDEXE
aef0: 44 20 63 6c 61 75 73 65 20 69 73 20 6e 6f 74 20  D clause is not 
af00: 61 6c 6c 6f 77 65 64 20 6f 6e 20 55 50 44 41 54  allowed on UPDAT
af10: 45 20 6f 72 20 44 45 4c 45 54 45 20 73 74 61 74  E or DELETE stat
af20: 65 6d 65 6e 74 73 20 22 0a 20 20 20 20 20 20 20  ements ".       
af30: 20 22 77 69 74 68 69 6e 20 74 72 69 67 67 65 72   "within trigger
af40: 73 22 29 3b 0a 7d 0a 0a 0a 0a 25 74 79 70 65 20  s");.}....%type 
af50: 74 72 69 67 67 65 72 5f 63 6d 64 20 7b 54 72 69  trigger_cmd {Tri
af60: 67 67 65 72 53 74 65 70 2a 7d 0a 25 64 65 73 74  ggerStep*}.%dest
af70: 72 75 63 74 6f 72 20 74 72 69 67 67 65 72 5f 63  ructor trigger_c
af80: 6d 64 20 7b 73 71 6c 69 74 65 33 44 65 6c 65 74  md {sqlite3Delet
af90: 65 54 72 69 67 67 65 72 53 74 65 70 28 70 50 61  eTriggerStep(pPa
afa0: 72 73 65 2d 3e 64 62 2c 20 24 24 29 3b 7d 0a 2f  rse->db, $$);}./
afb0: 2f 20 55 50 44 41 54 45 20 0a 74 72 69 67 67 65  / UPDATE .trigge
afc0: 72 5f 63 6d 64 28 41 29 20 3a 3a 3d 0a 20 20 20  r_cmd(A) ::=.   
afd0: 55 50 44 41 54 45 20 6f 72 63 6f 6e 66 28 52 29  UPDATE orconf(R)
afe0: 20 74 72 6e 6d 28 58 29 20 74 72 69 64 78 62 79   trnm(X) tridxby
aff0: 20 53 45 54 20 73 65 74 6c 69 73 74 28 59 29 20   SET setlist(Y) 
b000: 77 68 65 72 65 5f 6f 70 74 28 5a 29 2e 20 20 0a  where_opt(Z).  .
b010: 20 20 20 7b 20 41 20 3d 20 73 71 6c 69 74 65 33     { A = sqlite3
b020: 54 72 69 67 67 65 72 55 70 64 61 74 65 53 74 65  TriggerUpdateSte
b030: 70 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 26 58  p(pParse->db, &X
b040: 2c 20 59 2c 20 5a 2c 20 52 29 3b 20 7d 0a 0a 2f  , Y, Z, R); }../
b050: 2f 20 49 4e 53 45 52 54 0a 74 72 69 67 67 65 72  / INSERT.trigger
b060: 5f 63 6d 64 28 41 29 20 3a 3a 3d 0a 20 20 20 69  _cmd(A) ::=.   i
b070: 6e 73 65 72 74 5f 63 6d 64 28 52 29 20 49 4e 54  nsert_cmd(R) INT
b080: 4f 20 74 72 6e 6d 28 58 29 20 69 6e 73 63 6f 6c  O trnm(X) inscol
b090: 6c 69 73 74 5f 6f 70 74 28 46 29 20 56 41 4c 55  list_opt(F) VALU
b0a0: 45 53 20 4c 50 20 69 74 65 6d 6c 69 73 74 28 59  ES LP itemlist(Y
b0b0: 29 20 52 50 2e 20 20 0a 20 20 20 7b 41 20 3d 20  ) RP.  .   {A = 
b0c0: 73 71 6c 69 74 65 33 54 72 69 67 67 65 72 49 6e  sqlite3TriggerIn
b0d0: 73 65 72 74 53 74 65 70 28 70 50 61 72 73 65 2d  sertStep(pParse-
b0e0: 3e 64 62 2c 20 26 58 2c 20 46 2c 20 59 2c 20 30  >db, &X, F, Y, 0
b0f0: 2c 20 52 29 3b 7d 0a 0a 74 72 69 67 67 65 72 5f  , R);}..trigger_
b100: 63 6d 64 28 41 29 20 3a 3a 3d 20 69 6e 73 65 72  cmd(A) ::= inser
b110: 74 5f 63 6d 64 28 52 29 20 49 4e 54 4f 20 74 72  t_cmd(R) INTO tr
b120: 6e 6d 28 58 29 20 69 6e 73 63 6f 6c 6c 69 73 74  nm(X) inscollist
b130: 5f 6f 70 74 28 46 29 20 73 65 6c 65 63 74 28 53  _opt(F) select(S
b140: 29 2e 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  )..             
b150: 20 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 54 72    {A = sqlite3Tr
b160: 69 67 67 65 72 49 6e 73 65 72 74 53 74 65 70 28  iggerInsertStep(
b170: 70 50 61 72 73 65 2d 3e 64 62 2c 20 26 58 2c 20  pParse->db, &X, 
b180: 46 2c 20 30 2c 20 53 2c 20 52 29 3b 7d 0a 0a 2f  F, 0, S, R);}../
b190: 2f 20 44 45 4c 45 54 45 0a 74 72 69 67 67 65 72  / DELETE.trigger
b1a0: 5f 63 6d 64 28 41 29 20 3a 3a 3d 20 44 45 4c 45  _cmd(A) ::= DELE
b1b0: 54 45 20 46 52 4f 4d 20 74 72 6e 6d 28 58 29 20  TE FROM trnm(X) 
b1c0: 74 72 69 64 78 62 79 20 77 68 65 72 65 5f 6f 70  tridxby where_op
b1d0: 74 28 59 29 2e 0a 20 20 20 20 20 20 20 20 20 20  t(Y)..          
b1e0: 20 20 20 20 20 7b 41 20 3d 20 73 71 6c 69 74 65       {A = sqlite
b1f0: 33 54 72 69 67 67 65 72 44 65 6c 65 74 65 53 74  3TriggerDeleteSt
b200: 65 70 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 26  ep(pParse->db, &
b210: 58 2c 20 59 29 3b 7d 0a 0a 2f 2f 20 53 45 4c 45  X, Y);}..// SELE
b220: 43 54 0a 74 72 69 67 67 65 72 5f 63 6d 64 28 41  CT.trigger_cmd(A
b230: 29 20 3a 3a 3d 20 73 65 6c 65 63 74 28 58 29 2e  ) ::= select(X).
b240: 20 20 7b 41 20 3d 20 73 71 6c 69 74 65 33 54 72    {A = sqlite3Tr
b250: 69 67 67 65 72 53 65 6c 65 63 74 53 74 65 70 28  iggerSelectStep(
b260: 70 50 61 72 73 65 2d 3e 64 62 2c 20 58 29 3b 20  pParse->db, X); 
b270: 7d 0a 0a 2f 2f 20 54 68 65 20 73 70 65 63 69 61  }..// The specia
b280: 6c 20 52 41 49 53 45 20 65 78 70 72 65 73 73 69  l RAISE expressi
b290: 6f 6e 20 74 68 61 74 20 6d 61 79 20 6f 63 63 75  on that may occu
b2a0: 72 20 69 6e 20 74 72 69 67 67 65 72 20 70 72 6f  r in trigger pro
b2b0: 67 72 61 6d 73 0a 65 78 70 72 28 41 29 20 3a 3a  grams.expr(A) ::
b2c0: 3d 20 52 41 49 53 45 28 58 29 20 4c 50 20 49 47  = RAISE(X) LP IG
b2d0: 4e 4f 52 45 20 52 50 28 59 29 2e 20 20 7b 0a 20  NORE RP(Y).  {. 
b2e0: 20 41 2e 70 45 78 70 72 20 3d 20 73 71 6c 69 74   A.pExpr = sqlit
b2f0: 65 33 50 45 78 70 72 28 70 50 61 72 73 65 2c 20  e3PExpr(pParse, 
b300: 54 4b 5f 52 41 49 53 45 2c 20 30 2c 20 30 2c 20  TK_RAISE, 0, 0, 
b310: 30 29 3b 20 0a 20 20 69 66 28 20 41 2e 70 45 78  0); .  if( A.pEx
b320: 70 72 20 29 7b 0a 20 20 20 20 41 2e 70 45 78 70  pr ){.    A.pExp
b330: 72 2d 3e 61 66 66 69 6e 69 74 79 20 3d 20 4f 45  r->affinity = OE
b340: 5f 49 67 6e 6f 72 65 3b 0a 20 20 7d 0a 20 20 41  _Ignore;.  }.  A
b350: 2e 7a 53 74 61 72 74 20 3d 20 58 2e 7a 3b 0a 20  .zStart = X.z;. 
b360: 20 41 2e 7a 45 6e 64 20 3d 20 26 59 2e 7a 5b 59   A.zEnd = &Y.z[Y
b370: 2e 6e 5d 3b 0a 7d 0a 65 78 70 72 28 41 29 20 3a  .n];.}.expr(A) :
b380: 3a 3d 20 52 41 49 53 45 28 58 29 20 4c 50 20 72  := RAISE(X) LP r
b390: 61 69 73 65 74 79 70 65 28 54 29 20 43 4f 4d 4d  aisetype(T) COMM
b3a0: 41 20 6e 6d 28 5a 29 20 52 50 28 59 29 2e 20 20  A nm(Z) RP(Y).  
b3b0: 7b 0a 20 20 41 2e 70 45 78 70 72 20 3d 20 73 71  {.  A.pExpr = sq
b3c0: 6c 69 74 65 33 50 45 78 70 72 28 70 50 61 72 73  lite3PExpr(pPars
b3d0: 65 2c 20 54 4b 5f 52 41 49 53 45 2c 20 30 2c 20  e, TK_RAISE, 0, 
b3e0: 30 2c 20 26 5a 29 3b 20 0a 20 20 69 66 28 20 41  0, &Z); .  if( A
b3f0: 2e 70 45 78 70 72 20 29 20 7b 0a 20 20 20 20 41  .pExpr ) {.    A
b400: 2e 70 45 78 70 72 2d 3e 61 66 66 69 6e 69 74 79  .pExpr->affinity
b410: 20 3d 20 28 63 68 61 72 29 54 3b 0a 20 20 7d 0a   = (char)T;.  }.
b420: 20 20 41 2e 7a 53 74 61 72 74 20 3d 20 58 2e 7a    A.zStart = X.z
b430: 3b 0a 20 20 41 2e 7a 45 6e 64 20 3d 20 26 59 2e  ;.  A.zEnd = &Y.
b440: 7a 5b 59 2e 6e 5d 3b 0a 7d 0a 25 65 6e 64 69 66  z[Y.n];.}.%endif
b450: 20 20 21 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 54    !SQLITE_OMIT_T
b460: 52 49 47 47 45 52 0a 0a 25 74 79 70 65 20 72 61  RIGGER..%type ra
b470: 69 73 65 74 79 70 65 20 7b 69 6e 74 7d 0a 72 61  isetype {int}.ra
b480: 69 73 65 74 79 70 65 28 41 29 20 3a 3a 3d 20 52  isetype(A) ::= R
b490: 4f 4c 4c 42 41 43 4b 2e 20 20 7b 41 20 3d 20 4f  OLLBACK.  {A = O
b4a0: 45 5f 52 6f 6c 6c 62 61 63 6b 3b 7d 0a 72 61 69  E_Rollback;}.rai
b4b0: 73 65 74 79 70 65 28 41 29 20 3a 3a 3d 20 41 42  setype(A) ::= AB
b4c0: 4f 52 54 2e 20 20 20 20 20 7b 41 20 3d 20 4f 45  ORT.     {A = OE
b4d0: 5f 41 62 6f 72 74 3b 7d 0a 72 61 69 73 65 74 79  _Abort;}.raisety
b4e0: 70 65 28 41 29 20 3a 3a 3d 20 46 41 49 4c 2e 20  pe(A) ::= FAIL. 
b4f0: 20 20 20 20 20 7b 41 20 3d 20 4f 45 5f 46 61 69       {A = OE_Fai
b500: 6c 3b 7d 0a 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  l;}...//////////
b510: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 20  //////////////  
b520: 44 52 4f 50 20 54 52 49 47 47 45 52 20 73 74 61  DROP TRIGGER sta
b530: 74 65 6d 65 6e 74 20 2f 2f 2f 2f 2f 2f 2f 2f 2f  tement /////////
b540: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b550: 2f 2f 2f 2f 2f 0a 25 69 66 6e 64 65 66 20 53 51  /////.%ifndef SQ
b560: 4c 49 54 45 5f 4f 4d 49 54 5f 54 52 49 47 47 45  LITE_OMIT_TRIGGE
b570: 52 0a 63 6d 64 20 3a 3a 3d 20 44 52 4f 50 20 54  R.cmd ::= DROP T
b580: 52 49 47 47 45 52 20 69 66 65 78 69 73 74 73 28  RIGGER ifexists(
b590: 4e 4f 45 52 52 29 20 66 75 6c 6c 6e 61 6d 65 28  NOERR) fullname(
b5a0: 58 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33 44  X). {.  sqlite3D
b5b0: 72 6f 70 54 72 69 67 67 65 72 28 70 50 61 72 73  ropTrigger(pPars
b5c0: 65 2c 58 2c 4e 4f 45 52 52 29 3b 0a 7d 0a 25 65  e,X,NOERR);.}.%e
b5d0: 6e 64 69 66 20 20 21 53 51 4c 49 54 45 5f 4f 4d  ndif  !SQLITE_OM
b5e0: 49 54 5f 54 52 49 47 47 45 52 0a 0a 2f 2f 2f 2f  IT_TRIGGER..////
b5f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b600: 2f 2f 2f 2f 20 41 54 54 41 43 48 20 44 41 54 41  //// ATTACH DATA
b610: 42 41 53 45 20 66 69 6c 65 20 41 53 20 6e 61 6d  BASE file AS nam
b620: 65 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  e //////////////
b630: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 25 69 66 6e  ///////////.%ifn
b640: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
b650: 41 54 54 41 43 48 0a 63 6d 64 20 3a 3a 3d 20 41  ATTACH.cmd ::= A
b660: 54 54 41 43 48 20 64 61 74 61 62 61 73 65 5f 6b  TTACH database_k
b670: 77 5f 6f 70 74 20 65 78 70 72 28 46 29 20 41 53  w_opt expr(F) AS
b680: 20 65 78 70 72 28 44 29 20 6b 65 79 5f 6f 70 74   expr(D) key_opt
b690: 28 4b 29 2e 20 7b 0a 20 20 73 71 6c 69 74 65 33  (K). {.  sqlite3
b6a0: 41 74 74 61 63 68 28 70 50 61 72 73 65 2c 20 46  Attach(pParse, F
b6b0: 2e 70 45 78 70 72 2c 20 44 2e 70 45 78 70 72 2c  .pExpr, D.pExpr,
b6c0: 20 4b 29 3b 0a 7d 0a 63 6d 64 20 3a 3a 3d 20 44   K);.}.cmd ::= D
b6d0: 45 54 41 43 48 20 64 61 74 61 62 61 73 65 5f 6b  ETACH database_k
b6e0: 77 5f 6f 70 74 20 65 78 70 72 28 44 29 2e 20 7b  w_opt expr(D). {
b6f0: 0a 20 20 73 71 6c 69 74 65 33 44 65 74 61 63 68  .  sqlite3Detach
b700: 28 70 50 61 72 73 65 2c 20 44 2e 70 45 78 70 72  (pParse, D.pExpr
b710: 29 3b 0a 7d 0a 0a 25 74 79 70 65 20 6b 65 79 5f  );.}..%type key_
b720: 6f 70 74 20 7b 45 78 70 72 2a 7d 0a 25 64 65 73  opt {Expr*}.%des
b730: 74 72 75 63 74 6f 72 20 6b 65 79 5f 6f 70 74 20  tructor key_opt 
b740: 7b 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65  {sqlite3ExprDele
b750: 74 65 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 24  te(pParse->db, $
b760: 24 29 3b 7d 0a 6b 65 79 5f 6f 70 74 28 41 29 20  $);}.key_opt(A) 
b770: 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20 20 20  ::= .           
b780: 20 20 20 20 20 20 20 20 20 20 7b 20 41 20 3d 20            { A = 
b790: 30 3b 20 7d 0a 6b 65 79 5f 6f 70 74 28 41 29 20  0; }.key_opt(A) 
b7a0: 3a 3a 3d 20 4b 45 59 20 65 78 70 72 28 58 29 2e  ::= KEY expr(X).
b7b0: 20 20 20 20 20 20 20 20 20 20 7b 20 41 20 3d 20            { A = 
b7c0: 58 2e 70 45 78 70 72 3b 20 7d 0a 0a 64 61 74 61  X.pExpr; }..data
b7d0: 62 61 73 65 5f 6b 77 5f 6f 70 74 20 3a 3a 3d 20  base_kw_opt ::= 
b7e0: 44 41 54 41 42 41 53 45 2e 0a 64 61 74 61 62 61  DATABASE..databa
b7f0: 73 65 5f 6b 77 5f 6f 70 74 20 3a 3a 3d 20 2e 0a  se_kw_opt ::= ..
b800: 25 65 6e 64 69 66 20 53 51 4c 49 54 45 5f 4f 4d  %endif SQLITE_OM
b810: 49 54 5f 41 54 54 41 43 48 0a 0a 2f 2f 2f 2f 2f  IT_ATTACH../////
b820: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b830: 2f 2f 2f 2f 2f 20 52 45 49 4e 44 45 58 20 63 6f  ///// REINDEX co
b840: 6c 6c 61 74 69 6f 6e 20 2f 2f 2f 2f 2f 2f 2f 2f  llation ////////
b850: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b860: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 25 69 66 6e 64  //////////.%ifnd
b870: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 52  ef SQLITE_OMIT_R
b880: 45 49 4e 44 45 58 0a 63 6d 64 20 3a 3a 3d 20 52  EINDEX.cmd ::= R
b890: 45 49 4e 44 45 58 2e 20 20 20 20 20 20 20 20 20  EINDEX.         
b8a0: 20 20 20 20 20 20 20 7b 73 71 6c 69 74 65 33 52         {sqlite3R
b8b0: 65 69 6e 64 65 78 28 70 50 61 72 73 65 2c 20 30  eindex(pParse, 0
b8c0: 2c 20 30 29 3b 7d 0a 63 6d 64 20 3a 3a 3d 20 52  , 0);}.cmd ::= R
b8d0: 45 49 4e 44 45 58 20 6e 6d 28 58 29 20 64 62 6e  EINDEX nm(X) dbn
b8e0: 6d 28 59 29 2e 20 20 7b 73 71 6c 69 74 65 33 52  m(Y).  {sqlite3R
b8f0: 65 69 6e 64 65 78 28 70 50 61 72 73 65 2c 20 26  eindex(pParse, &
b900: 58 2c 20 26 59 29 3b 7d 0a 25 65 6e 64 69 66 20  X, &Y);}.%endif 
b910: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 52 45 49   SQLITE_OMIT_REI
b920: 4e 44 45 58 0a 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  NDEX..//////////
b930: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b940: 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 41 4e 41 4c 59 5a  ///////// ANALYZ
b950: 45 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  E //////////////
b960: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b970: 2f 2f 2f 2f 2f 0a 25 69 66 6e 64 65 66 20 53 51  /////.%ifndef SQ
b980: 4c 49 54 45 5f 4f 4d 49 54 5f 41 4e 41 4c 59 5a  LITE_OMIT_ANALYZ
b990: 45 0a 63 6d 64 20 3a 3a 3d 20 41 4e 41 4c 59 5a  E.cmd ::= ANALYZ
b9a0: 45 2e 20 20 20 20 20 20 20 20 20 20 20 20 20 20  E.              
b9b0: 20 20 7b 73 71 6c 69 74 65 33 41 6e 61 6c 79 7a    {sqlite3Analyz
b9c0: 65 28 70 50 61 72 73 65 2c 20 30 2c 20 30 29 3b  e(pParse, 0, 0);
b9d0: 7d 0a 63 6d 64 20 3a 3a 3d 20 41 4e 41 4c 59 5a  }.cmd ::= ANALYZ
b9e0: 45 20 6e 6d 28 58 29 20 64 62 6e 6d 28 59 29 2e  E nm(X) dbnm(Y).
b9f0: 20 20 7b 73 71 6c 69 74 65 33 41 6e 61 6c 79 7a    {sqlite3Analyz
ba00: 65 28 70 50 61 72 73 65 2c 20 26 58 2c 20 26 59  e(pParse, &X, &Y
ba10: 29 3b 7d 0a 25 65 6e 64 69 66 0a 0a 2f 2f 2f 2f  );}.%endif..////
ba20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
ba30: 2f 2f 2f 2f 20 41 4c 54 45 52 20 54 41 42 4c 45  //// ALTER TABLE
ba40: 20 74 61 62 6c 65 20 2e 2e 2e 20 2f 2f 2f 2f 2f   table ... /////
ba50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
ba60: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0a 25 69 66 6e  ///////////.%ifn
ba70: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
ba80: 41 4c 54 45 52 54 41 42 4c 45 0a 63 6d 64 20 3a  ALTERTABLE.cmd :
ba90: 3a 3d 20 41 4c 54 45 52 20 54 41 42 4c 45 20 66  := ALTER TABLE f
baa0: 75 6c 6c 6e 61 6d 65 28 58 29 20 52 45 4e 41 4d  ullname(X) RENAM
bab0: 45 20 54 4f 20 6e 6d 28 5a 29 2e 20 7b 0a 20 20  E TO nm(Z). {.  
bac0: 73 71 6c 69 74 65 33 41 6c 74 65 72 52 65 6e 61  sqlite3AlterRena
bad0: 6d 65 54 61 62 6c 65 28 70 50 61 72 73 65 2c 58  meTable(pParse,X
bae0: 2c 26 5a 29 3b 0a 7d 0a 63 6d 64 20 3a 3a 3d 20  ,&Z);.}.cmd ::= 
baf0: 41 4c 54 45 52 20 54 41 42 4c 45 20 61 64 64 5f  ALTER TABLE add_
bb00: 63 6f 6c 75 6d 6e 5f 66 75 6c 6c 6e 61 6d 65 20  column_fullname 
bb10: 41 44 44 20 6b 77 63 6f 6c 75 6d 6e 5f 6f 70 74  ADD kwcolumn_opt
bb20: 20 63 6f 6c 75 6d 6e 28 59 29 2e 20 7b 0a 20 20   column(Y). {.  
bb30: 73 71 6c 69 74 65 33 41 6c 74 65 72 46 69 6e 69  sqlite3AlterFini
bb40: 73 68 41 64 64 43 6f 6c 75 6d 6e 28 70 50 61 72  shAddColumn(pPar
bb50: 73 65 2c 20 26 59 29 3b 0a 7d 0a 61 64 64 5f 63  se, &Y);.}.add_c
bb60: 6f 6c 75 6d 6e 5f 66 75 6c 6c 6e 61 6d 65 20 3a  olumn_fullname :
bb70: 3a 3d 20 66 75 6c 6c 6e 61 6d 65 28 58 29 2e 20  := fullname(X). 
bb80: 7b 0a 20 20 70 50 61 72 73 65 2d 3e 64 62 2d 3e  {.  pParse->db->
bb90: 6c 6f 6f 6b 61 73 69 64 65 2e 62 45 6e 61 62 6c  lookaside.bEnabl
bba0: 65 64 20 3d 20 30 3b 0a 20 20 73 71 6c 69 74 65  ed = 0;.  sqlite
bbb0: 33 41 6c 74 65 72 42 65 67 69 6e 41 64 64 43 6f  3AlterBeginAddCo
bbc0: 6c 75 6d 6e 28 70 50 61 72 73 65 2c 20 58 29 3b  lumn(pParse, X);
bbd0: 0a 7d 0a 6b 77 63 6f 6c 75 6d 6e 5f 6f 70 74 20  .}.kwcolumn_opt 
bbe0: 3a 3a 3d 20 2e 0a 6b 77 63 6f 6c 75 6d 6e 5f 6f  ::= ..kwcolumn_o
bbf0: 70 74 20 3a 3a 3d 20 43 4f 4c 55 4d 4e 4b 57 2e  pt ::= COLUMNKW.
bc00: 0a 25 65 6e 64 69 66 20 20 53 51 4c 49 54 45 5f  .%endif  SQLITE_
bc10: 4f 4d 49 54 5f 41 4c 54 45 52 54 41 42 4c 45 0a  OMIT_ALTERTABLE.
bc20: 0a 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .///////////////
bc30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 20 43 52 45 41 54 45  ///////// CREATE
bc40: 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45 20 2e   VIRTUAL TABLE .
bc50: 2e 2e 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .. /////////////
bc60: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
bc70: 0a 25 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .%ifndef SQLITE_
bc80: 4f 4d 49 54 5f 56 49 52 54 55 41 4c 54 41 42 4c  OMIT_VIRTUALTABL
bc90: 45 0a 63 6d 64 20 3a 3a 3d 20 63 72 65 61 74 65  E.cmd ::= create
bca0: 5f 76 74 61 62 2e 20 20 20 20 20 20 20 20 20 20  _vtab.          
bcb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 73 71               {sq
bcc0: 6c 69 74 65 33 56 74 61 62 46 69 6e 69 73 68 50  lite3VtabFinishP
bcd0: 61 72 73 65 28 70 50 61 72 73 65 2c 30 29 3b 7d  arse(pParse,0);}
bce0: 0a 63 6d 64 20 3a 3a 3d 20 63 72 65 61 74 65 5f  .cmd ::= create_
bcf0: 76 74 61 62 20 4c 50 20 76 74 61 62 61 72 67 6c  vtab LP vtabargl
bd00: 69 73 74 20 52 50 28 58 29 2e 20 20 7b 73 71 6c  ist RP(X).  {sql
bd10: 69 74 65 33 56 74 61 62 46 69 6e 69 73 68 50 61  ite3VtabFinishPa
bd20: 72 73 65 28 70 50 61 72 73 65 2c 26 58 29 3b 7d  rse(pParse,&X);}
bd30: 0a 63 72 65 61 74 65 5f 76 74 61 62 20 3a 3a 3d  .create_vtab ::=
bd40: 20 63 72 65 61 74 65 6b 77 20 56 49 52 54 55 41   createkw VIRTUA
bd50: 4c 20 54 41 42 4c 45 20 6e 6d 28 58 29 20 64 62  L TABLE nm(X) db
bd60: 6e 6d 28 59 29 20 55 53 49 4e 47 20 6e 6d 28 5a  nm(Y) USING nm(Z
bd70: 29 2e 20 7b 0a 20 20 20 20 73 71 6c 69 74 65 33  ). {.    sqlite3
bd80: 56 74 61 62 42 65 67 69 6e 50 61 72 73 65 28 70  VtabBeginParse(p
bd90: 50 61 72 73 65 2c 20 26 58 2c 20 26 59 2c 20 26  Parse, &X, &Y, &
bda0: 5a 29 3b 0a 7d 0a 76 74 61 62 61 72 67 6c 69 73  Z);.}.vtabarglis
bdb0: 74 20 3a 3a 3d 20 76 74 61 62 61 72 67 2e 0a 76  t ::= vtabarg..v
bdc0: 74 61 62 61 72 67 6c 69 73 74 20 3a 3a 3d 20 76  tabarglist ::= v
bdd0: 74 61 62 61 72 67 6c 69 73 74 20 43 4f 4d 4d 41  tabarglist COMMA
bde0: 20 76 74 61 62 61 72 67 2e 0a 76 74 61 62 61 72   vtabarg..vtabar
bdf0: 67 20 3a 3a 3d 20 2e 20 20 20 20 20 20 20 20 20  g ::= .         
be00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 73                {s
be10: 71 6c 69 74 65 33 56 74 61 62 41 72 67 49 6e 69  qlite3VtabArgIni
be20: 74 28 70 50 61 72 73 65 29 3b 7d 0a 76 74 61 62  t(pParse);}.vtab
be30: 61 72 67 20 3a 3a 3d 20 76 74 61 62 61 72 67 20  arg ::= vtabarg 
be40: 76 74 61 62 61 72 67 74 6f 6b 65 6e 2e 0a 76 74  vtabargtoken..vt
be50: 61 62 61 72 67 74 6f 6b 65 6e 20 3a 3a 3d 20 41  abargtoken ::= A
be60: 4e 59 28 58 29 2e 20 20 20 20 20 20 20 20 20 20  NY(X).          
be70: 20 20 7b 73 71 6c 69 74 65 33 56 74 61 62 41 72    {sqlite3VtabAr
be80: 67 45 78 74 65 6e 64 28 70 50 61 72 73 65 2c 26  gExtend(pParse,&
be90: 58 29 3b 7d 0a 76 74 61 62 61 72 67 74 6f 6b 65  X);}.vtabargtoke
bea0: 6e 20 3a 3a 3d 20 6c 70 20 61 6e 79 6c 69 73 74  n ::= lp anylist
beb0: 20 52 50 28 58 29 2e 20 20 7b 73 71 6c 69 74 65   RP(X).  {sqlite
bec0: 33 56 74 61 62 41 72 67 45 78 74 65 6e 64 28 70  3VtabArgExtend(p
bed0: 50 61 72 73 65 2c 26 58 29 3b 7d 0a 6c 70 20 3a  Parse,&X);}.lp :
bee0: 3a 3d 20 4c 50 28 58 29 2e 20 20 20 20 20 20 20  := LP(X).       
bef0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bf00: 7b 73 71 6c 69 74 65 33 56 74 61 62 41 72 67 45  {sqlite3VtabArgE
bf10: 78 74 65 6e 64 28 70 50 61 72 73 65 2c 26 58 29  xtend(pParse,&X)
bf20: 3b 7d 0a 61 6e 79 6c 69 73 74 20 3a 3a 3d 20 2e  ;}.anylist ::= .
bf30: 0a 61 6e 79 6c 69 73 74 20 3a 3a 3d 20 61 6e 79  .anylist ::= any
bf40: 6c 69 73 74 20 4c 50 20 61 6e 79 6c 69 73 74 20  list LP anylist 
bf50: 52 50 2e 0a 61 6e 79 6c 69 73 74 20 3a 3a 3d 20  RP..anylist ::= 
bf60: 61 6e 79 6c 69 73 74 20 41 4e 59 2e 0a 25 65 6e  anylist ANY..%en
bf70: 64 69 66 20 20 53 51 4c 49 54 45 5f 4f 4d 49 54  dif  SQLITE_OMIT
bf80: 5f 56 49 52 54 55 41 4c 54 41 42 4c 45 0a        _VIRTUALTABLE.