/ Hex Artifact Content
Login
SQLite training in Houston TX on 2019-11-05 (details)
Part of the 2019 Tcl Conference

Artifact aeeba7dc5bc32a6f0980e6516cb2a48a50973fab:


0000: 2f 2a 0a 2a 2a 20 32 30 30 33 20 41 70 72 69 6c  /*.** 2003 April
0010: 20 36 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74   6.**.** The aut
0020: 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f  hor disclaims co
0030: 70 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20  pyright to this 
0040: 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e  source code.  In
0050: 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c   place of.** a l
0060: 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72  egal notice, her
0070: 65 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a  e is a blessing:
0080: 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f  .**.**    May yo
0090: 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f  u do good and no
00a0: 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61  t evil..**    Ma
00b0: 79 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69  y you find forgi
00c0: 76 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73  veness for yours
00d0: 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20  elf and forgive 
00e0: 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61  others..**    Ma
00f0: 79 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65  y you share free
0100: 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67  ly, never taking
0110: 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67   more than you g
0120: 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a  ive..**.********
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 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63  *.** This file c
0180: 6f 6e 74 61 69 6e 73 20 63 6f 64 65 20 75 73 65  ontains code use
0190: 64 20 74 6f 20 69 6d 70 6c 65 6d 65 6e 74 20 74  d to implement t
01a0: 68 65 20 50 52 41 47 4d 41 20 63 6f 6d 6d 61 6e  he PRAGMA comman
01b0: 64 2e 0a 2a 2a 0a 2a 2a 20 24 49 64 3a 20 70 72  d..**.** $Id: pr
01c0: 61 67 6d 61 2e 63 2c 76 20 31 2e 32 37 20 32 30  agma.c,v 1.27 20
01d0: 30 34 2f 30 35 2f 32 30 20 32 32 3a 31 36 3a 32  04/05/20 22:16:2
01e0: 39 20 64 72 68 20 45 78 70 20 24 0a 2a 2f 0a 23  9 drh Exp $.*/.#
01f0: 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65 49  include "sqliteI
0200: 6e 74 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 3c  nt.h".#include <
0210: 63 74 79 70 65 2e 68 3e 0a 0a 2f 2a 0a 2a 2a 20  ctype.h>../*.** 
0220: 49 6e 74 65 72 70 72 65 74 20 74 68 65 20 67 69  Interpret the gi
0230: 76 65 6e 20 73 74 72 69 6e 67 20 61 73 20 61 20  ven string as a 
0240: 62 6f 6f 6c 65 61 6e 20 76 61 6c 75 65 2e 0a 2a  boolean value..*
0250: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 67 65 74  /.static int get
0260: 42 6f 6f 6c 65 61 6e 28 63 6f 6e 73 74 20 63 68  Boolean(const ch
0270: 61 72 20 2a 7a 29 7b 0a 20 20 73 74 61 74 69 63  ar *z){.  static
0280: 20 63 68 61 72 20 2a 61 7a 54 72 75 65 5b 5d 20   char *azTrue[] 
0290: 3d 20 7b 20 22 79 65 73 22 2c 20 22 6f 6e 22 2c  = { "yes", "on",
02a0: 20 22 74 72 75 65 22 20 7d 3b 0a 20 20 69 6e 74   "true" };.  int
02b0: 20 69 3b 0a 20 20 69 66 28 20 7a 5b 30 5d 3d 3d   i;.  if( z[0]==
02c0: 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  0 ) return 0;.  
02d0: 69 66 28 20 69 73 64 69 67 69 74 28 7a 5b 30 5d  if( isdigit(z[0]
02e0: 29 20 7c 7c 20 28 7a 5b 30 5d 3d 3d 27 2d 27 20  ) || (z[0]=='-' 
02f0: 26 26 20 69 73 64 69 67 69 74 28 7a 5b 31 5d 29  && isdigit(z[1])
0300: 29 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20  ) ){.    return 
0310: 61 74 6f 69 28 7a 29 3b 0a 20 20 7d 0a 20 20 66  atoi(z);.  }.  f
0320: 6f 72 28 69 3d 30 3b 20 69 3c 73 69 7a 65 6f 66  or(i=0; i<sizeof
0330: 28 61 7a 54 72 75 65 29 2f 73 69 7a 65 6f 66 28  (azTrue)/sizeof(
0340: 61 7a 54 72 75 65 5b 30 5d 29 3b 20 69 2b 2b 29  azTrue[0]); i++)
0350: 7b 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65  {.    if( sqlite
0360: 33 53 74 72 49 43 6d 70 28 7a 2c 61 7a 54 72 75  3StrICmp(z,azTru
0370: 65 5b 69 5d 29 3d 3d 30 20 29 20 72 65 74 75 72  e[i])==0 ) retur
0380: 6e 20 31 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  n 1;.  }.  retur
0390: 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e  n 0;.}../*.** In
03a0: 74 65 72 70 72 65 74 20 74 68 65 20 67 69 76 65  terpret the give
03b0: 6e 20 73 74 72 69 6e 67 20 61 73 20 61 20 73 61  n string as a sa
03c0: 66 65 74 79 20 6c 65 76 65 6c 2e 20 20 52 65 74  fety level.  Ret
03d0: 75 72 6e 20 30 20 66 6f 72 20 4f 46 46 2c 0a 2a  urn 0 for OFF,.*
03e0: 2a 20 31 20 66 6f 72 20 4f 4e 20 6f 72 20 4e 4f  * 1 for ON or NO
03f0: 52 4d 41 4c 20 61 6e 64 20 32 20 66 6f 72 20 46  RMAL and 2 for F
0400: 55 4c 4c 2e 20 20 52 65 74 75 72 6e 20 31 20 66  ULL.  Return 1 f
0410: 6f 72 20 61 6e 20 65 6d 70 74 79 20 6f 72 20 0a  or an empty or .
0420: 2a 2a 20 75 6e 72 65 63 6f 67 6e 69 7a 65 64 20  ** unrecognized 
0430: 73 74 72 69 6e 67 20 61 72 67 75 6d 65 6e 74 2e  string argument.
0440: 0a 2a 2a 0a 2a 2a 20 4e 6f 74 65 20 74 68 61 74  .**.** Note that
0450: 20 74 68 65 20 76 61 6c 75 65 73 20 72 65 74 75   the values retu
0460: 72 6e 65 64 20 61 72 65 20 6f 6e 65 20 6c 65 73  rned are one les
0470: 73 20 74 68 61 74 20 74 68 65 20 76 61 6c 75 65  s that the value
0480: 73 20 74 68 61 74 0a 2a 2a 20 73 68 6f 75 6c 64  s that.** should
0490: 20 62 65 20 70 61 73 73 65 64 20 69 6e 74 6f 20   be passed into 
04a0: 73 71 6c 69 74 65 33 42 74 72 65 65 53 65 74 53  sqlite3BtreeSetS
04b0: 61 66 65 74 79 4c 65 76 65 6c 28 29 2e 20 20 54  afetyLevel().  T
04c0: 68 65 20 69 73 20 64 6f 6e 65 0a 2a 2a 20 74 6f  he is done.** to
04d0: 20 73 75 70 70 6f 72 74 20 6c 65 67 61 63 79 20   support legacy 
04e0: 53 51 4c 20 63 6f 64 65 2e 20 20 54 68 65 20 73  SQL code.  The s
04f0: 61 66 65 74 79 20 6c 65 76 65 6c 20 75 73 65 64  afety level used
0500: 20 74 6f 20 62 65 20 62 6f 6f 6c 65 61 6e 0a 2a   to be boolean.*
0510: 2a 20 61 6e 64 20 6f 6c 64 65 72 20 73 63 72 69  * and older scri
0520: 70 74 73 20 6d 61 79 20 68 61 76 65 20 75 73 65  pts may have use
0530: 64 20 6e 75 6d 62 65 72 73 20 30 20 66 6f 72 20  d numbers 0 for 
0540: 4f 46 46 20 61 6e 64 20 31 20 66 6f 72 20 4f 4e  OFF and 1 for ON
0550: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
0560: 67 65 74 53 61 66 65 74 79 4c 65 76 65 6c 28 63  getSafetyLevel(c
0570: 68 61 72 20 2a 7a 29 7b 0a 20 20 73 74 61 74 69  har *z){.  stati
0580: 63 20 63 6f 6e 73 74 20 73 74 72 75 63 74 20 7b  c const struct {
0590: 0a 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20  .    const char 
05a0: 2a 7a 57 6f 72 64 3b 0a 20 20 20 20 69 6e 74 20  *zWord;.    int 
05b0: 76 61 6c 3b 0a 20 20 7d 20 61 4b 65 79 5b 5d 20  val;.  } aKey[] 
05c0: 3d 20 7b 0a 20 20 20 20 7b 20 22 6e 6f 22 2c 20  = {.    { "no", 
05d0: 20 20 20 30 20 7d 2c 0a 20 20 20 20 7b 20 22 6f     0 },.    { "o
05e0: 66 66 22 2c 20 20 20 30 20 7d 2c 0a 20 20 20 20  ff",   0 },.    
05f0: 7b 20 22 66 61 6c 73 65 22 2c 20 30 20 7d 2c 0a  { "false", 0 },.
0600: 20 20 20 20 7b 20 22 79 65 73 22 2c 20 20 20 31      { "yes",   1
0610: 20 7d 2c 0a 20 20 20 20 7b 20 22 6f 6e 22 2c 20   },.    { "on", 
0620: 20 20 20 31 20 7d 2c 0a 20 20 20 20 7b 20 22 74     1 },.    { "t
0630: 72 75 65 22 2c 20 20 31 20 7d 2c 0a 20 20 20 20  rue",  1 },.    
0640: 7b 20 22 66 75 6c 6c 22 2c 20 20 32 20 7d 2c 0a  { "full",  2 },.
0650: 20 20 7d 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20    };.  int i;.  
0660: 69 66 28 20 7a 5b 30 5d 3d 3d 30 20 29 20 72 65  if( z[0]==0 ) re
0670: 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20 69 73  turn 1;.  if( is
0680: 64 69 67 69 74 28 7a 5b 30 5d 29 20 7c 7c 20 28  digit(z[0]) || (
0690: 7a 5b 30 5d 3d 3d 27 2d 27 20 26 26 20 69 73 64  z[0]=='-' && isd
06a0: 69 67 69 74 28 7a 5b 31 5d 29 29 20 29 7b 0a 20  igit(z[1])) ){. 
06b0: 20 20 20 72 65 74 75 72 6e 20 61 74 6f 69 28 7a     return atoi(z
06c0: 29 3b 0a 20 20 7d 0a 20 20 66 6f 72 28 69 3d 30  );.  }.  for(i=0
06d0: 3b 20 69 3c 73 69 7a 65 6f 66 28 61 4b 65 79 29  ; i<sizeof(aKey)
06e0: 2f 73 69 7a 65 6f 66 28 61 4b 65 79 5b 30 5d 29  /sizeof(aKey[0])
06f0: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20  ; i++){.    if( 
0700: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
0710: 2c 61 4b 65 79 5b 69 5d 2e 7a 57 6f 72 64 29 3d  ,aKey[i].zWord)=
0720: 3d 30 20 29 20 72 65 74 75 72 6e 20 61 4b 65 79  =0 ) return aKey
0730: 5b 69 5d 2e 76 61 6c 3b 0a 20 20 7d 0a 20 20 72  [i].val;.  }.  r
0740: 65 74 75 72 6e 20 31 3b 0a 7d 0a 0a 2f 2a 0a 2a  eturn 1;.}../*.*
0750: 2a 20 49 6e 74 65 72 70 72 65 74 20 74 68 65 20  * Interpret the 
0760: 67 69 76 65 6e 20 73 74 72 69 6e 67 20 61 73 20  given string as 
0770: 61 20 74 65 6d 70 20 64 62 20 6c 6f 63 61 74 69  a temp db locati
0780: 6f 6e 2e 20 52 65 74 75 72 6e 20 31 20 66 6f 72  on. Return 1 for
0790: 20 66 69 6c 65 0a 2a 2a 20 62 61 63 6b 65 64 20   file.** backed 
07a0: 74 65 6d 70 6f 72 61 72 79 20 64 61 74 61 62 61  temporary databa
07b0: 73 65 73 2c 20 32 20 66 6f 72 20 74 68 65 20 52  ses, 2 for the R
07c0: 65 64 2d 42 6c 61 63 6b 20 74 72 65 65 20 69 6e  ed-Black tree in
07d0: 20 6d 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65   memory database
07e0: 0a 2a 2a 20 61 6e 64 20 30 20 74 6f 20 75 73 65  .** and 0 to use
07f0: 20 74 68 65 20 63 6f 6d 70 69 6c 65 2d 74 69 6d   the compile-tim
0800: 65 20 64 65 66 61 75 6c 74 2e 0a 2a 2f 0a 73 74  e default..*/.st
0810: 61 74 69 63 20 69 6e 74 20 67 65 74 54 65 6d 70  atic int getTemp
0820: 53 74 6f 72 65 28 63 6f 6e 73 74 20 63 68 61 72  Store(const char
0830: 20 2a 7a 29 7b 0a 20 20 69 66 28 20 7a 5b 30 5d   *z){.  if( z[0]
0840: 3e 3d 27 30 27 20 26 26 20 7a 5b 30 5d 3c 3d 27  >='0' && z[0]<='
0850: 32 27 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e  2' ){.    return
0860: 20 7a 5b 30 5d 20 2d 20 27 30 27 3b 0a 20 20 7d   z[0] - '0';.  }
0870: 65 6c 73 65 20 69 66 28 20 73 71 6c 69 74 65 33  else if( sqlite3
0880: 53 74 72 49 43 6d 70 28 7a 2c 20 22 66 69 6c 65  StrICmp(z, "file
0890: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65 74  ")==0 ){.    ret
08a0: 75 72 6e 20 31 3b 0a 20 20 7d 65 6c 73 65 20 69  urn 1;.  }else i
08b0: 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d  f( sqlite3StrICm
08c0: 70 28 7a 2c 20 22 6d 65 6d 6f 72 79 22 29 3d 3d  p(z, "memory")==
08d0: 30 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20  0 ){.    return 
08e0: 32 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  2;.  }else{.    
08f0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 7d 0a  return 0;.  }.}.
0900: 0a 2f 2a 0a 2a 2a 20 49 66 20 74 68 65 20 54 45  ./*.** If the TE
0910: 4d 50 20 64 61 74 61 62 61 73 65 20 69 73 20 6f  MP database is o
0920: 70 65 6e 2c 20 63 6c 6f 73 65 20 69 74 20 61 6e  pen, close it an
0930: 64 20 6d 61 72 6b 20 74 68 65 20 64 61 74 61 62  d mark the datab
0940: 61 73 65 20 73 63 68 65 6d 61 0a 2a 2a 20 61 73  ase schema.** as
0950: 20 6e 65 65 64 69 6e 67 20 72 65 6c 6f 61 64 69   needing reloadi
0960: 6e 67 2e 20 20 54 68 69 73 20 6d 75 73 74 20 62  ng.  This must b
0970: 65 20 64 6f 6e 65 20 77 68 65 6e 20 75 73 69 6e  e done when usin
0980: 67 20 74 68 65 20 54 45 4d 50 5f 53 54 4f 52 45  g the TEMP_STORE
0990: 0a 2a 2a 20 6f 72 20 44 45 46 41 55 4c 54 5f 54  .** or DEFAULT_T
09a0: 45 4d 50 5f 53 54 4f 52 45 20 70 72 61 67 6d 61  EMP_STORE pragma
09b0: 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  s..*/.static int
09c0: 20 63 68 61 6e 67 65 54 65 6d 70 53 74 6f 72 61   changeTempStora
09d0: 67 65 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  ge(Parse *pParse
09e0: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53  , const char *zS
09f0: 74 6f 72 61 67 65 54 79 70 65 29 7b 0a 20 20 69  torageType){.  i
0a00: 6e 74 20 74 73 20 3d 20 67 65 74 54 65 6d 70 53  nt ts = getTempS
0a10: 74 6f 72 65 28 7a 53 74 6f 72 61 67 65 54 79 70  tore(zStorageTyp
0a20: 65 29 3b 0a 20 20 73 71 6c 69 74 65 20 2a 64 62  e);.  sqlite *db
0a30: 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b 0a 20   = pParse->db;. 
0a40: 20 69 66 28 20 64 62 2d 3e 74 65 6d 70 5f 73 74   if( db->temp_st
0a50: 6f 72 65 3d 3d 74 73 20 29 20 72 65 74 75 72 6e  ore==ts ) return
0a60: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 66   SQLITE_OK;.  if
0a70: 28 20 64 62 2d 3e 61 44 62 5b 31 5d 2e 70 42 74  ( db->aDb[1].pBt
0a80: 21 3d 30 20 29 7b 0a 20 20 20 20 69 66 28 20 64  !=0 ){.    if( d
0a90: 62 2d 3e 66 6c 61 67 73 20 26 20 53 51 4c 49 54  b->flags & SQLIT
0aa0: 45 5f 49 6e 54 72 61 6e 73 20 29 7b 0a 20 20 20  E_InTrans ){.   
0ab0: 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d     sqlite3ErrorM
0ac0: 73 67 28 70 50 61 72 73 65 2c 20 22 74 65 6d 70  sg(pParse, "temp
0ad0: 6f 72 61 72 79 20 73 74 6f 72 61 67 65 20 63 61  orary storage ca
0ae0: 6e 6e 6f 74 20 62 65 20 63 68 61 6e 67 65 64 20  nnot be changed 
0af0: 22 0a 20 20 20 20 20 20 20 20 22 66 72 6f 6d 20  ".        "from 
0b00: 77 69 74 68 69 6e 20 61 20 74 72 61 6e 73 61 63  within a transac
0b10: 74 69 6f 6e 22 29 3b 0a 20 20 20 20 20 20 72 65  tion");.      re
0b20: 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f  turn SQLITE_ERRO
0b30: 52 3b 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c  R;.    }.    sql
0b40: 69 74 65 33 42 74 72 65 65 43 6c 6f 73 65 28 64  ite3BtreeClose(d
0b50: 62 2d 3e 61 44 62 5b 31 5d 2e 70 42 74 29 3b 0a  b->aDb[1].pBt);.
0b60: 20 20 20 20 64 62 2d 3e 61 44 62 5b 31 5d 2e 70      db->aDb[1].p
0b70: 42 74 20 3d 20 30 3b 0a 20 20 20 20 73 71 6c 69  Bt = 0;.    sqli
0b80: 74 65 33 52 65 73 65 74 49 6e 74 65 72 6e 61 6c  te3ResetInternal
0b90: 53 63 68 65 6d 61 28 64 62 2c 20 30 29 3b 0a 20  Schema(db, 0);. 
0ba0: 20 7d 0a 20 20 64 62 2d 3e 74 65 6d 70 5f 73 74   }.  db->temp_st
0bb0: 6f 72 65 20 3d 20 74 73 3b 0a 20 20 72 65 74 75  ore = ts;.  retu
0bc0: 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a  rn SQLITE_OK;.}.
0bd0: 0a 2f 2a 0a 2a 2a 20 43 68 65 63 6b 20 74 6f 20  ./*.** Check to 
0be0: 73 65 65 20 69 66 20 7a 52 69 67 68 74 20 61 6e  see if zRight an
0bf0: 64 20 7a 4c 65 66 74 20 72 65 66 65 72 20 74 6f  d zLeft refer to
0c00: 20 61 20 70 72 61 67 6d 61 20 74 68 61 74 20 71   a pragma that q
0c10: 75 65 72 69 65 73 0a 2a 2a 20 6f 72 20 63 68 61  ueries.** or cha
0c20: 6e 67 65 73 20 6f 6e 65 20 6f 66 20 74 68 65 20  nges one of the 
0c30: 66 6c 61 67 73 20 69 6e 20 64 62 2d 3e 66 6c 61  flags in db->fla
0c40: 67 73 2e 20 20 52 65 74 75 72 6e 20 31 20 69 66  gs.  Return 1 if
0c50: 20 73 6f 20 61 6e 64 20 30 20 69 66 20 6e 6f 74   so and 0 if not
0c60: 2e 0a 2a 2a 20 41 6c 73 6f 2c 20 69 6d 70 6c 65  ..** Also, imple
0c70: 6d 65 6e 74 20 74 68 65 20 70 72 61 67 6d 61 2e  ment the pragma.
0c80: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 66  .*/.static int f
0c90: 6c 61 67 50 72 61 67 6d 61 28 50 61 72 73 65 20  lagPragma(Parse 
0ca0: 2a 70 50 61 72 73 65 2c 20 63 6f 6e 73 74 20 63  *pParse, const c
0cb0: 68 61 72 20 2a 7a 4c 65 66 74 2c 20 63 6f 6e 73  har *zLeft, cons
0cc0: 74 20 63 68 61 72 20 2a 7a 52 69 67 68 74 29 7b  t char *zRight){
0cd0: 0a 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20  .  static const 
0ce0: 73 74 72 75 63 74 20 7b 0a 20 20 20 20 63 6f 6e  struct {.    con
0cf0: 73 74 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b 20  st char *zName; 
0d00: 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 74 68 65 20   /* Name of the 
0d10: 70 72 61 67 6d 61 20 2a 2f 0a 20 20 20 20 69 6e  pragma */.    in
0d20: 74 20 6d 61 73 6b 3b 20 20 20 20 20 20 20 20 20  t mask;         
0d30: 20 20 2f 2a 20 4d 61 73 6b 20 66 6f 72 20 74 68    /* Mask for th
0d40: 65 20 64 62 2d 3e 66 6c 61 67 73 20 76 61 6c 75  e db->flags valu
0d50: 65 20 2a 2f 0a 20 20 7d 20 61 50 72 61 67 6d 61  e */.  } aPragma
0d60: 5b 5d 20 3d 20 7b 0a 20 20 20 20 7b 20 22 76 64  [] = {.    { "vd
0d70: 62 65 5f 74 72 61 63 65 22 2c 20 20 20 20 20 20  be_trace",      
0d80: 20 20 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f           SQLITE_
0d90: 56 64 62 65 54 72 61 63 65 20 20 20 20 20 7d 2c  VdbeTrace     },
0da0: 0a 20 20 20 20 7b 20 22 66 75 6c 6c 5f 63 6f 6c  .    { "full_col
0db0: 75 6d 6e 5f 6e 61 6d 65 73 22 2c 20 20 20 20 20  umn_names",     
0dc0: 20 20 20 53 51 4c 49 54 45 5f 46 75 6c 6c 43 6f     SQLITE_FullCo
0dd0: 6c 4e 61 6d 65 73 20 20 7d 2c 0a 20 20 20 20 7b  lNames  },.    {
0de0: 20 22 73 68 6f 72 74 5f 63 6f 6c 75 6d 6e 5f 6e   "short_column_n
0df0: 61 6d 65 73 22 2c 20 20 20 20 20 20 20 53 51 4c  ames",       SQL
0e00: 49 54 45 5f 53 68 6f 72 74 43 6f 6c 4e 61 6d 65  ITE_ShortColName
0e10: 73 20 7d 2c 0a 20 20 20 20 7b 20 22 73 68 6f 77  s },.    { "show
0e20: 5f 64 61 74 61 74 79 70 65 73 22 2c 20 20 20 20  _datatypes",    
0e30: 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f 52 65         SQLITE_Re
0e40: 70 6f 72 74 54 79 70 65 73 20 20 20 7d 2c 0a 20  portTypes   },. 
0e50: 20 20 20 7b 20 22 63 6f 75 6e 74 5f 63 68 61 6e     { "count_chan
0e60: 67 65 73 22 2c 20 20 20 20 20 20 20 20 20 20 20  ges",           
0e70: 20 53 51 4c 49 54 45 5f 43 6f 75 6e 74 52 6f 77   SQLITE_CountRow
0e80: 73 20 20 20 20 20 7d 2c 0a 20 20 20 20 7b 20 22  s     },.    { "
0e90: 65 6d 70 74 79 5f 72 65 73 75 6c 74 5f 63 61 6c  empty_result_cal
0ea0: 6c 62 61 63 6b 73 22 2c 20 20 20 53 51 4c 49 54  lbacks",   SQLIT
0eb0: 45 5f 4e 75 6c 6c 43 61 6c 6c 62 61 63 6b 20 20  E_NullCallback  
0ec0: 7d 2c 0a 20 20 7d 3b 0a 20 20 69 6e 74 20 69 3b  },.  };.  int i;
0ed0: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 73 69  .  for(i=0; i<si
0ee0: 7a 65 6f 66 28 61 50 72 61 67 6d 61 29 2f 73 69  zeof(aPragma)/si
0ef0: 7a 65 6f 66 28 61 50 72 61 67 6d 61 5b 30 5d 29  zeof(aPragma[0])
0f00: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20  ; i++){.    if( 
0f10: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
0f20: 4c 65 66 74 2c 20 61 50 72 61 67 6d 61 5b 69 5d  Left, aPragma[i]
0f30: 2e 7a 4e 61 6d 65 29 3d 3d 30 20 29 7b 0a 20 20  .zName)==0 ){.  
0f40: 20 20 20 20 73 71 6c 69 74 65 20 2a 64 62 20 3d      sqlite *db =
0f50: 20 70 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 20   pParse->db;.   
0f60: 20 20 20 56 64 62 65 20 2a 76 3b 0a 20 20 20 20     Vdbe *v;.    
0f70: 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 4c 65    if( strcmp(zLe
0f80: 66 74 2c 7a 52 69 67 68 74 29 3d 3d 30 20 26 26  ft,zRight)==0 &&
0f90: 20 28 76 20 3d 20 73 71 6c 69 74 65 33 47 65 74   (v = sqlite3Get
0fa0: 56 64 62 65 28 70 50 61 72 73 65 29 29 21 3d 30  Vdbe(pParse))!=0
0fb0: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
0fc0: 74 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50  te3VdbeOp3(v, OP
0fd0: 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 30 2c 20  _ColumnName, 0, 
0fe0: 31 2c 20 61 50 72 61 67 6d 61 5b 69 5d 2e 7a 4e  1, aPragma[i].zN
0ff0: 61 6d 65 2c 20 50 33 5f 53 54 41 54 49 43 29 3b  ame, P3_STATIC);
1000: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
1010: 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 43 6f  VdbeOp3(v, OP_Co
1020: 6c 75 6d 6e 4e 61 6d 65 2c 20 31 2c 20 30 2c 20  lumnName, 1, 0, 
1030: 22 62 6f 6f 6c 65 61 6e 22 2c 20 50 33 5f 53 54  "boolean", P3_ST
1040: 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 73  ATIC);.        s
1050: 71 6c 69 74 65 33 56 64 62 65 43 6f 64 65 28 76  qlite3VdbeCode(v
1060: 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 28 64  , OP_Integer, (d
1070: 62 2d 3e 66 6c 61 67 73 20 26 20 61 50 72 61 67  b->flags & aPrag
1080: 6d 61 5b 69 5d 2e 6d 61 73 6b 29 21 3d 30 2c 20  ma[i].mask)!=0, 
1090: 30 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  0,.             
10a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 4f 50 5f               OP_
10b0: 43 61 6c 6c 62 61 63 6b 2c 20 31 2c 20 30 2c 0a  Callback, 1, 0,.
10c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
10d0: 20 20 20 20 20 20 20 20 20 20 30 29 3b 0a 20 20            0);.  
10e0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 67 65      }else if( ge
10f0: 74 42 6f 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29  tBoolean(zRight)
1100: 20 29 7b 0a 20 20 20 20 20 20 20 20 64 62 2d 3e   ){.        db->
1110: 66 6c 61 67 73 20 7c 3d 20 61 50 72 61 67 6d 61  flags |= aPragma
1120: 5b 69 5d 2e 6d 61 73 6b 3b 0a 20 20 20 20 20 20  [i].mask;.      
1130: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 64  }else{.        d
1140: 62 2d 3e 66 6c 61 67 73 20 26 3d 20 7e 61 50 72  b->flags &= ~aPr
1150: 61 67 6d 61 5b 69 5d 2e 6d 61 73 6b 3b 0a 20 20  agma[i].mask;.  
1160: 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65 74 75      }.      retu
1170: 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  rn 1;.    }.  }.
1180: 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f    return 0;.}../
1190: 2a 0a 2a 2a 20 50 72 6f 63 65 73 73 20 61 20 70  *.** Process a p
11a0: 72 61 67 6d 61 20 73 74 61 74 65 6d 65 6e 74 2e  ragma statement.
11b0: 20 20 0a 2a 2a 0a 2a 2a 20 50 72 61 67 6d 61 73    .**.** Pragmas
11c0: 20 61 72 65 20 6f 66 20 74 68 69 73 20 66 6f 72   are of this for
11d0: 6d 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 20 50 52  m:.**.**      PR
11e0: 41 47 4d 41 20 69 64 20 3d 20 76 61 6c 75 65 0a  AGMA id = value.
11f0: 2a 2a 0a 2a 2a 20 54 68 65 20 69 64 65 6e 74 69  **.** The identi
1200: 66 69 65 72 20 6d 69 67 68 74 20 61 6c 73 6f 20  fier might also 
1210: 62 65 20 61 20 73 74 72 69 6e 67 2e 20 20 54 68  be a string.  Th
1220: 65 20 76 61 6c 75 65 20 69 73 20 61 20 73 74 72  e value is a str
1230: 69 6e 67 2c 20 61 6e 64 0a 2a 2a 20 69 64 65 6e  ing, and.** iden
1240: 74 69 66 69 65 72 2c 20 6f 72 20 61 20 6e 75 6d  tifier, or a num
1250: 62 65 72 2e 20 20 49 66 20 6d 69 6e 75 73 46 6c  ber.  If minusFl
1260: 61 67 20 69 73 20 74 72 75 65 2c 20 74 68 65 6e  ag is true, then
1270: 20 74 68 65 20 76 61 6c 75 65 20 69 73 0a 2a 2a   the value is.**
1280: 20 61 20 6e 75 6d 62 65 72 20 74 68 61 74 20 77   a number that w
1290: 61 73 20 70 72 65 63 65 64 65 64 20 62 79 20 61  as preceded by a
12a0: 20 6d 69 6e 75 73 20 73 69 67 6e 2e 0a 2a 2f 0a   minus sign..*/.
12b0: 76 6f 69 64 20 73 71 6c 69 74 65 33 50 72 61 67  void sqlite3Prag
12c0: 6d 61 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  ma(Parse *pParse
12d0: 2c 20 54 6f 6b 65 6e 20 2a 70 4c 65 66 74 2c 20  , Token *pLeft, 
12e0: 54 6f 6b 65 6e 20 2a 70 52 69 67 68 74 2c 20 69  Token *pRight, i
12f0: 6e 74 20 6d 69 6e 75 73 46 6c 61 67 29 7b 0a 20  nt minusFlag){. 
1300: 20 63 68 61 72 20 2a 7a 4c 65 66 74 20 3d 20 30   char *zLeft = 0
1310: 3b 0a 20 20 63 68 61 72 20 2a 7a 52 69 67 68 74  ;.  char *zRight
1320: 20 3d 20 30 3b 0a 20 20 73 71 6c 69 74 65 20 2a   = 0;.  sqlite *
1330: 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b  db = pParse->db;
1340: 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71 6c  .  Vdbe *v = sql
1350: 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72  ite3GetVdbe(pPar
1360: 73 65 29 3b 0a 20 20 69 66 28 20 76 3d 3d 30 20  se);.  if( v==0 
1370: 29 20 72 65 74 75 72 6e 3b 0a 0a 20 20 7a 4c 65  ) return;..  zLe
1380: 66 74 20 3d 20 73 71 6c 69 74 65 53 74 72 4e 44  ft = sqliteStrND
1390: 75 70 28 70 4c 65 66 74 2d 3e 7a 2c 20 70 4c 65  up(pLeft->z, pLe
13a0: 66 74 2d 3e 6e 29 3b 0a 20 20 73 71 6c 69 74 65  ft->n);.  sqlite
13b0: 33 44 65 71 75 6f 74 65 28 7a 4c 65 66 74 29 3b  3Dequote(zLeft);
13c0: 0a 20 20 69 66 28 20 6d 69 6e 75 73 46 6c 61 67  .  if( minusFlag
13d0: 20 29 7b 0a 20 20 20 20 7a 52 69 67 68 74 20 3d   ){.    zRight =
13e0: 20 30 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 53   0;.    sqlite3S
13f0: 65 74 4e 53 74 72 69 6e 67 28 26 7a 52 69 67 68  etNString(&zRigh
1400: 74 2c 20 22 2d 22 2c 20 31 2c 20 70 52 69 67 68  t, "-", 1, pRigh
1410: 74 2d 3e 7a 2c 20 70 52 69 67 68 74 2d 3e 6e 2c  t->z, pRight->n,
1420: 20 30 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20   0);.  }else{.  
1430: 20 20 7a 52 69 67 68 74 20 3d 20 73 71 6c 69 74    zRight = sqlit
1440: 65 53 74 72 4e 44 75 70 28 70 52 69 67 68 74 2d  eStrNDup(pRight-
1450: 3e 7a 2c 20 70 52 69 67 68 74 2d 3e 6e 29 3b 0a  >z, pRight->n);.
1460: 20 20 20 20 73 71 6c 69 74 65 33 44 65 71 75 6f      sqlite3Dequo
1470: 74 65 28 7a 52 69 67 68 74 29 3b 0a 20 20 7d 0a  te(zRight);.  }.
1480: 20 20 69 66 28 20 73 71 6c 69 74 65 33 41 75 74    if( sqlite3Aut
1490: 68 43 68 65 63 6b 28 70 50 61 72 73 65 2c 20 53  hCheck(pParse, S
14a0: 51 4c 49 54 45 5f 50 52 41 47 4d 41 2c 20 7a 4c  QLITE_PRAGMA, zL
14b0: 65 66 74 2c 20 7a 52 69 67 68 74 2c 20 30 29 20  eft, zRight, 0) 
14c0: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 46 72 65  ){.    sqliteFre
14d0: 65 28 7a 4c 65 66 74 29 3b 0a 20 20 20 20 73 71  e(zLeft);.    sq
14e0: 6c 69 74 65 46 72 65 65 28 7a 52 69 67 68 74 29  liteFree(zRight)
14f0: 3b 0a 20 20 20 20 72 65 74 75 72 6e 3b 0a 20 20  ;.    return;.  
1500: 7d 0a 20 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 50  }. .  /*.  **  P
1510: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61  RAGMA default_ca
1520: 63 68 65 5f 73 69 7a 65 0a 20 20 2a 2a 20 20 50  che_size.  **  P
1530: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61  RAGMA default_ca
1540: 63 68 65 5f 73 69 7a 65 3d 4e 0a 20 20 2a 2a 0a  che_size=N.  **.
1550: 20 20 2a 2a 20 54 68 65 20 66 69 72 73 74 20 66    ** The first f
1560: 6f 72 6d 20 72 65 70 6f 72 74 73 20 74 68 65 20  orm reports the 
1570: 63 75 72 72 65 6e 74 20 70 65 72 73 69 73 74 65  current persiste
1580: 6e 74 20 73 65 74 74 69 6e 67 20 66 6f 72 20 74  nt setting for t
1590: 68 65 0a 20 20 2a 2a 20 70 61 67 65 20 63 61 63  he.  ** page cac
15a0: 68 65 20 73 69 7a 65 2e 20 20 54 68 65 20 76 61  he size.  The va
15b0: 6c 75 65 20 72 65 74 75 72 6e 65 64 20 69 73 20  lue returned is 
15c0: 74 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  the maximum numb
15d0: 65 72 20 6f 66 0a 20 20 2a 2a 20 70 61 67 65 73  er of.  ** pages
15e0: 20 69 6e 20 74 68 65 20 70 61 67 65 20 63 61 63   in the page cac
15f0: 68 65 2e 20 20 54 68 65 20 73 65 63 6f 6e 64 20  he.  The second 
1600: 66 6f 72 6d 20 73 65 74 73 20 62 6f 74 68 20 74  form sets both t
1610: 68 65 20 63 75 72 72 65 6e 74 0a 20 20 2a 2a 20  he current.  ** 
1620: 70 61 67 65 20 63 61 63 68 65 20 73 69 7a 65 20  page cache size 
1630: 76 61 6c 75 65 20 61 6e 64 20 74 68 65 20 70 65  value and the pe
1640: 72 73 69 73 74 65 6e 74 20 70 61 67 65 20 63 61  rsistent page ca
1650: 63 68 65 20 73 69 7a 65 20 76 61 6c 75 65 0a 20  che size value. 
1660: 20 2a 2a 20 73 74 6f 72 65 64 20 69 6e 20 74 68   ** stored in th
1670: 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  e database file.
1680: 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 64  .  **.  ** The d
1690: 65 66 61 75 6c 74 20 63 61 63 68 65 20 73 69 7a  efault cache siz
16a0: 65 20 69 73 20 73 74 6f 72 65 64 20 69 6e 20 6d  e is stored in m
16b0: 65 74 61 2d 76 61 6c 75 65 20 32 20 6f 66 20 70  eta-value 2 of p
16c0: 61 67 65 20 31 20 6f 66 20 74 68 65 0a 20 20 2a  age 1 of the.  *
16d0: 2a 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  * database file.
16e0: 20 20 54 68 65 20 63 61 63 68 65 20 73 69 7a 65    The cache size
16f0: 20 69 73 20 61 63 74 75 61 6c 6c 79 20 74 68 65   is actually the
1700: 20 61 62 73 6f 6c 75 74 65 20 76 61 6c 75 65 20   absolute value 
1710: 6f 66 0a 20 20 2a 2a 20 74 68 69 73 20 6d 65 6d  of.  ** this mem
1720: 6f 72 79 20 6c 6f 63 61 74 69 6f 6e 2e 20 20 54  ory location.  T
1730: 68 65 20 73 69 67 6e 20 6f 66 20 6d 65 74 61 2d  he sign of meta-
1740: 76 61 6c 75 65 20 32 20 64 65 74 65 72 6d 69 6e  value 2 determin
1750: 65 73 20 74 68 65 0a 20 20 2a 2a 20 73 79 6e 63  es the.  ** sync
1760: 68 72 6f 6e 6f 75 73 20 73 65 74 74 69 6e 67 2e  hronous setting.
1770: 20 20 41 20 6e 65 67 61 74 69 76 65 20 76 61 6c    A negative val
1780: 75 65 20 6d 65 61 6e 73 20 73 79 6e 63 68 72 6f  ue means synchro
1790: 6e 6f 75 73 20 69 73 20 6f 66 66 0a 20 20 2a 2a  nous is off.  **
17a0: 20 61 6e 64 20 61 20 70 6f 73 69 74 69 76 65 20   and a positive 
17b0: 76 61 6c 75 65 20 6d 65 61 6e 73 20 73 79 6e 63  value means sync
17c0: 68 72 6f 6e 6f 75 73 20 69 73 20 6f 6e 2e 0a 20  hronous is on.. 
17d0: 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65   */.  if( sqlite
17e0: 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 22  3StrICmp(zLeft,"
17f0: 64 65 66 61 75 6c 74 5f 63 61 63 68 65 5f 73 69  default_cache_si
1800: 7a 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73  ze")==0 ){.    s
1810: 74 61 74 69 63 20 56 64 62 65 4f 70 4c 69 73 74  tatic VdbeOpList
1820: 20 67 65 74 43 61 63 68 65 53 69 7a 65 5b 5d 20   getCacheSize[] 
1830: 3d 20 7b 0a 20 20 20 20 20 20 7b 20 4f 50 5f 52  = {.      { OP_R
1840: 65 61 64 43 6f 6f 6b 69 65 2c 20 20 30 2c 20 32  eadCookie,  0, 2
1850: 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20  ,        0},.   
1860: 20 20 20 7b 20 4f 50 5f 41 62 73 56 61 6c 75 65     { OP_AbsValue
1870: 2c 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20  ,    0, 0,      
1880: 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50    0},.      { OP
1890: 5f 44 75 70 2c 20 20 20 20 20 20 20 20 20 30 2c  _Dup,         0,
18a0: 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20   0,        0},. 
18b0: 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67 65       { OP_Intege
18c0: 72 2c 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20  r,     0, 0,    
18d0: 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20      0},.      { 
18e0: 4f 50 5f 4e 65 2c 20 20 20 20 20 20 20 20 20 20  OP_Ne,          
18f0: 30 2c 20 36 2c 20 20 20 20 20 20 20 20 30 7d 2c  0, 6,        0},
1900: 0a 20 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65  .      { OP_Inte
1910: 67 65 72 2c 20 20 20 20 20 30 2c 20 30 2c 20 20  ger,     0, 0,  
1920: 20 20 20 20 20 20 30 7d 2c 20 20 2f 2a 20 35 20        0},  /* 5 
1930: 2a 2f 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f  */.      { OP_Co
1940: 6c 75 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 31 2c  lumnName,  0, 1,
1950: 20 20 20 20 20 20 20 20 22 63 61 63 68 65 5f 73          "cache_s
1960: 69 7a 65 22 7d 2c 0a 20 20 20 20 20 20 7b 20 4f  ize"},.      { O
1970: 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 20 20 20 31  P_Callback,    1
1980: 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a  , 0,        0},.
1990: 20 20 20 20 7d 3b 0a 20 20 20 20 69 6e 74 20 61      };.    int a
19a0: 64 64 72 3b 0a 20 20 20 20 69 66 28 20 70 52 69  ddr;.    if( pRi
19b0: 67 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a  ght->z==pLeft->z
19c0: 20 29 7b 0a 20 20 20 20 20 20 61 64 64 72 20 3d   ){.      addr =
19d0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
19e0: 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53 69  pList(v, ArraySi
19f0: 7a 65 28 67 65 74 43 61 63 68 65 53 69 7a 65 29  ze(getCacheSize)
1a00: 2c 20 67 65 74 43 61 63 68 65 53 69 7a 65 29 3b  , getCacheSize);
1a10: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
1a20: 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20 61 64  beChangeP1(v, ad
1a30: 64 72 2b 35 2c 20 4d 41 58 5f 50 41 47 45 53 29  dr+5, MAX_PAGES)
1a40: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
1a50: 20 20 20 69 6e 74 20 73 69 7a 65 20 3d 20 61 74     int size = at
1a60: 6f 69 28 7a 52 69 67 68 74 29 3b 0a 20 20 20 20  oi(zRight);.    
1a70: 20 20 69 66 28 20 73 69 7a 65 3c 30 20 29 20 73    if( size<0 ) s
1a80: 69 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a 20 20 20  ize = -size;.   
1a90: 20 20 20 73 71 6c 69 74 65 33 42 65 67 69 6e 57     sqlite3BeginW
1aa0: 72 69 74 65 4f 70 65 72 61 74 69 6f 6e 28 70 50  riteOperation(pP
1ab0: 61 72 73 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20  arse, 0, 0);.   
1ac0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
1ad0: 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65  dOp(v, OP_Intege
1ae0: 72 2c 20 73 69 7a 65 2c 20 30 29 3b 0a 20 20 20  r, size, 0);.   
1af0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
1b00: 64 4f 70 28 76 2c 20 4f 50 5f 52 65 61 64 43 6f  dOp(v, OP_ReadCo
1b10: 6f 6b 69 65 2c 20 30 2c 20 32 29 3b 0a 20 20 20  okie, 0, 2);.   
1b20: 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65     addr = sqlite
1b30: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
1b40: 5f 49 6e 74 65 67 65 72 2c 20 30 2c 20 30 29 3b  _Integer, 0, 0);
1b50: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
1b60: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 47 65  beAddOp(v, OP_Ge
1b70: 2c 20 30 2c 20 61 64 64 72 2b 33 29 3b 0a 20 20  , 0, addr+3);.  
1b80: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
1b90: 64 64 4f 70 28 76 2c 20 4f 50 5f 4e 65 67 61 74  ddOp(v, OP_Negat
1ba0: 69 76 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  ive, 0, 0);.    
1bb0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
1bc0: 4f 70 28 76 2c 20 4f 50 5f 53 65 74 43 6f 6f 6b  Op(v, OP_SetCook
1bd0: 69 65 2c 20 30 2c 20 32 29 3b 0a 20 20 20 20 20  ie, 0, 2);.     
1be0: 20 73 71 6c 69 74 65 33 45 6e 64 57 72 69 74 65   sqlite3EndWrite
1bf0: 4f 70 65 72 61 74 69 6f 6e 28 70 50 61 72 73 65  Operation(pParse
1c00: 29 3b 0a 20 20 20 20 20 20 64 62 2d 3e 63 61 63  );.      db->cac
1c10: 68 65 5f 73 69 7a 65 20 3d 20 64 62 2d 3e 63 61  he_size = db->ca
1c20: 63 68 65 5f 73 69 7a 65 3c 30 20 3f 20 2d 73 69  che_size<0 ? -si
1c30: 7a 65 20 3a 20 73 69 7a 65 3b 0a 20 20 20 20 20  ze : size;.     
1c40: 20 73 71 6c 69 74 65 33 42 74 72 65 65 53 65 74   sqlite3BtreeSet
1c50: 43 61 63 68 65 53 69 7a 65 28 64 62 2d 3e 61 44  CacheSize(db->aD
1c60: 62 5b 30 5d 2e 70 42 74 2c 20 64 62 2d 3e 63 61  b[0].pBt, db->ca
1c70: 63 68 65 5f 73 69 7a 65 29 3b 0a 20 20 20 20 7d  che_size);.    }
1c80: 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20  .  }else..  /*. 
1c90: 20 2a 2a 20 20 50 52 41 47 4d 41 20 63 61 63 68   **  PRAGMA cach
1ca0: 65 5f 73 69 7a 65 0a 20 20 2a 2a 20 20 50 52 41  e_size.  **  PRA
1cb0: 47 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 3d 4e  GMA cache_size=N
1cc0: 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 66  .  **.  ** The f
1cd0: 69 72 73 74 20 66 6f 72 6d 20 72 65 70 6f 72 74  irst form report
1ce0: 73 20 74 68 65 20 63 75 72 72 65 6e 74 20 6c 6f  s the current lo
1cf0: 63 61 6c 20 73 65 74 74 69 6e 67 20 66 6f 72 20  cal setting for 
1d00: 74 68 65 0a 20 20 2a 2a 20 70 61 67 65 20 63 61  the.  ** page ca
1d10: 63 68 65 20 73 69 7a 65 2e 20 20 54 68 65 20 6c  che size.  The l
1d20: 6f 63 61 6c 20 73 65 74 74 69 6e 67 20 63 61 6e  ocal setting can
1d30: 20 62 65 20 64 69 66 66 65 72 65 6e 74 20 66 72   be different fr
1d40: 6f 6d 0a 20 20 2a 2a 20 74 68 65 20 70 65 72 73  om.  ** the pers
1d50: 69 73 74 65 6e 74 20 63 61 63 68 65 20 73 69 7a  istent cache siz
1d60: 65 20 76 61 6c 75 65 20 74 68 61 74 20 69 73 20  e value that is 
1d70: 73 74 6f 72 65 64 20 69 6e 20 74 68 65 20 64 61  stored in the da
1d80: 74 61 62 61 73 65 0a 20 20 2a 2a 20 66 69 6c 65  tabase.  ** file
1d90: 20 69 74 73 65 6c 66 2e 20 20 54 68 65 20 76 61   itself.  The va
1da0: 6c 75 65 20 72 65 74 75 72 6e 65 64 20 69 73 20  lue returned is 
1db0: 74 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  the maximum numb
1dc0: 65 72 20 6f 66 0a 20 20 2a 2a 20 70 61 67 65 73  er of.  ** pages
1dd0: 20 69 6e 20 74 68 65 20 70 61 67 65 20 63 61 63   in the page cac
1de0: 68 65 2e 20 20 54 68 65 20 73 65 63 6f 6e 64 20  he.  The second 
1df0: 66 6f 72 6d 20 73 65 74 73 20 74 68 65 20 6c 6f  form sets the lo
1e00: 63 61 6c 0a 20 20 2a 2a 20 70 61 67 65 20 63 61  cal.  ** page ca
1e10: 63 68 65 20 73 69 7a 65 20 76 61 6c 75 65 2e 20  che size value. 
1e20: 20 49 74 20 64 6f 65 73 20 6e 6f 74 20 63 68 61   It does not cha
1e30: 6e 67 65 20 74 68 65 20 70 65 72 73 69 73 74 65  nge the persiste
1e40: 6e 74 0a 20 20 2a 2a 20 63 61 63 68 65 20 73 69  nt.  ** cache si
1e50: 7a 65 20 73 74 6f 72 65 64 20 6f 6e 20 74 68 65  ze stored on the
1e60: 20 64 69 73 6b 20 73 6f 20 74 68 65 20 63 61 63   disk so the cac
1e70: 68 65 20 73 69 7a 65 20 77 69 6c 6c 20 72 65 76  he size will rev
1e80: 65 72 74 0a 20 20 2a 2a 20 74 6f 20 69 74 73 20  ert.  ** to its 
1e90: 64 65 66 61 75 6c 74 20 76 61 6c 75 65 20 77 68  default value wh
1ea0: 65 6e 20 74 68 65 20 64 61 74 61 62 61 73 65 20  en the database 
1eb0: 69 73 20 63 6c 6f 73 65 64 20 61 6e 64 20 72 65  is closed and re
1ec0: 6f 70 65 6e 65 64 2e 0a 20 20 2a 2a 20 4e 20 73  opened..  ** N s
1ed0: 68 6f 75 6c 64 20 62 65 20 61 20 70 6f 73 69 74  hould be a posit
1ee0: 69 76 65 20 69 6e 74 65 67 65 72 2e 0a 20 20 2a  ive integer..  *
1ef0: 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 53  /.  if( sqlite3S
1f00: 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 22 63 61  trICmp(zLeft,"ca
1f10: 63 68 65 5f 73 69 7a 65 22 29 3d 3d 30 20 29 7b  che_size")==0 ){
1f20: 0a 20 20 20 20 73 74 61 74 69 63 20 56 64 62 65  .    static Vdbe
1f30: 4f 70 4c 69 73 74 20 67 65 74 43 61 63 68 65 53  OpList getCacheS
1f40: 69 7a 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20  ize[] = {.      
1f50: 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c  { OP_ColumnName,
1f60: 20 20 30 2c 20 31 2c 20 20 20 20 20 20 20 20 22    0, 1,        "
1f70: 63 61 63 68 65 5f 73 69 7a 65 22 7d 2c 0a 20 20  cache_size"},.  
1f80: 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c 62 61 63      { OP_Callbac
1f90: 6b 2c 20 20 20 20 31 2c 20 30 2c 20 20 20 20 20  k,    1, 0,     
1fa0: 20 20 20 30 7d 2c 0a 20 20 20 20 7d 3b 0a 20 20     0},.    };.  
1fb0: 20 20 69 66 28 20 70 52 69 67 68 74 2d 3e 7a 3d    if( pRight->z=
1fc0: 3d 70 4c 65 66 74 2d 3e 7a 20 29 7b 0a 20 20 20  =pLeft->z ){.   
1fd0: 20 20 20 69 6e 74 20 73 69 7a 65 20 3d 20 64 62     int size = db
1fe0: 2d 3e 63 61 63 68 65 5f 73 69 7a 65 3b 3b 0a 20  ->cache_size;;. 
1ff0: 20 20 20 20 20 69 66 28 20 73 69 7a 65 3c 30 20       if( size<0 
2000: 29 20 73 69 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a  ) size = -size;.
2010: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
2020: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74  eAddOp(v, OP_Int
2030: 65 67 65 72 2c 20 73 69 7a 65 2c 20 30 29 3b 0a  eger, size, 0);.
2040: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
2050: 65 41 64 64 4f 70 4c 69 73 74 28 76 2c 20 41 72  eAddOpList(v, Ar
2060: 72 61 79 53 69 7a 65 28 67 65 74 43 61 63 68 65  raySize(getCache
2070: 53 69 7a 65 29 2c 20 67 65 74 43 61 63 68 65 53  Size), getCacheS
2080: 69 7a 65 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  ize);.    }else{
2090: 0a 20 20 20 20 20 20 69 6e 74 20 73 69 7a 65 20  .      int size 
20a0: 3d 20 61 74 6f 69 28 7a 52 69 67 68 74 29 3b 0a  = atoi(zRight);.
20b0: 20 20 20 20 20 20 69 66 28 20 73 69 7a 65 3c 30        if( size<0
20c0: 20 29 20 73 69 7a 65 20 3d 20 2d 73 69 7a 65 3b   ) size = -size;
20d0: 0a 20 20 20 20 20 20 69 66 28 20 64 62 2d 3e 63  .      if( db->c
20e0: 61 63 68 65 5f 73 69 7a 65 3c 30 20 29 20 73 69  ache_size<0 ) si
20f0: 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a 20 20 20 20  ze = -size;.    
2100: 20 20 64 62 2d 3e 63 61 63 68 65 5f 73 69 7a 65    db->cache_size
2110: 20 3d 20 73 69 7a 65 3b 0a 20 20 20 20 20 20 73   = size;.      s
2120: 71 6c 69 74 65 33 42 74 72 65 65 53 65 74 43 61  qlite3BtreeSetCa
2130: 63 68 65 53 69 7a 65 28 64 62 2d 3e 61 44 62 5b  cheSize(db->aDb[
2140: 30 5d 2e 70 42 74 2c 20 64 62 2d 3e 63 61 63 68  0].pBt, db->cach
2150: 65 5f 73 69 7a 65 29 3b 0a 20 20 20 20 7d 0a 20  e_size);.    }. 
2160: 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20 20 2a   }else..  /*.  *
2170: 2a 20 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c  *  PRAGMA defaul
2180: 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 0a 20 20  t_synchronous.  
2190: 2a 2a 20 20 50 52 41 47 4d 41 20 64 65 66 61 75  **  PRAGMA defau
21a0: 6c 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f  lt_synchronous=O
21b0: 4e 7c 4f 46 46 7c 4e 4f 52 4d 41 4c 7c 46 55 4c  N|OFF|NORMAL|FUL
21c0: 4c 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20  L.  **.  ** The 
21d0: 66 69 72 73 74 20 66 6f 72 6d 20 72 65 74 75 72  first form retur
21e0: 6e 73 20 74 68 65 20 70 65 72 73 69 73 74 65 6e  ns the persisten
21f0: 74 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20 22  t value of the "
2200: 73 79 6e 63 68 72 6f 6e 6f 75 73 22 20 73 65 74  synchronous" set
2210: 74 69 6e 67 0a 20 20 2a 2a 20 74 68 61 74 20 69  ting.  ** that i
2220: 73 20 73 74 6f 72 65 64 20 69 6e 20 74 68 65 20  s stored in the 
2230: 64 61 74 61 62 61 73 65 2e 20 20 54 68 69 73 20  database.  This 
2240: 69 73 20 74 68 65 20 73 79 6e 63 68 72 6f 6e 6f  is the synchrono
2250: 75 73 20 73 65 74 74 69 6e 67 20 74 68 61 74 0a  us setting that.
2260: 20 20 2a 2a 20 69 73 20 75 73 65 64 20 77 68 65    ** is used whe
2270: 6e 65 76 65 72 20 74 68 65 20 64 61 74 61 62 61  never the databa
2280: 73 65 20 69 73 20 6f 70 65 6e 65 64 20 75 6e 6c  se is opened unl
2290: 65 73 73 20 6f 76 65 72 72 69 64 64 65 6e 20 62  ess overridden b
22a0: 79 20 61 20 73 65 70 61 72 61 74 65 0a 20 20 2a  y a separate.  *
22b0: 2a 20 22 73 79 6e 63 68 72 6f 6e 6f 75 73 22 20  * "synchronous" 
22c0: 70 72 61 67 6d 61 2e 20 20 54 68 65 20 73 65 63  pragma.  The sec
22d0: 6f 6e 64 20 66 6f 72 6d 20 63 68 61 6e 67 65 73  ond form changes
22e0: 20 74 68 65 20 70 65 72 73 69 73 74 65 6e 74 20   the persistent 
22f0: 61 6e 64 20 74 68 65 0a 20 20 2a 2a 20 6c 6f 63  and the.  ** loc
2300: 61 6c 20 73 79 6e 63 68 72 6f 6e 6f 75 73 20 73  al synchronous s
2310: 65 74 74 69 6e 67 20 74 6f 20 74 68 65 20 76 61  etting to the va
2320: 6c 75 65 20 67 69 76 65 6e 2e 0a 20 20 2a 2a 0a  lue given..  **.
2330: 20 20 2a 2a 20 49 66 20 73 79 6e 63 68 72 6f 6e    ** If synchron
2340: 6f 75 73 20 69 73 20 4f 46 46 2c 20 53 51 4c 69  ous is OFF, SQLi
2350: 74 65 20 64 6f 65 73 20 6e 6f 74 20 61 74 74 65  te does not atte
2360: 6d 70 74 20 61 6e 79 20 66 73 79 6e 63 28 29 20  mpt any fsync() 
2370: 73 79 73 74 65 6d 73 20 63 61 6c 6c 73 0a 20 20  systems calls.  
2380: 2a 2a 20 74 6f 20 6d 61 6b 65 20 73 75 72 65 20  ** to make sure 
2390: 64 61 74 61 20 69 73 20 63 6f 6d 6d 69 74 74 65  data is committe
23a0: 64 20 74 6f 20 64 69 73 6b 2e 20 20 57 72 69 74  d to disk.  Writ
23b0: 65 20 6f 70 65 72 61 74 69 6f 6e 73 20 61 72 65  e operations are
23c0: 20 76 65 72 79 20 66 61 73 74 2c 0a 20 20 2a 2a   very fast,.  **
23d0: 20 62 75 74 20 61 20 70 6f 77 65 72 20 66 61 69   but a power fai
23e0: 6c 75 72 65 20 63 61 6e 20 6c 65 61 76 65 20 74  lure can leave t
23f0: 68 65 20 64 61 74 61 62 61 73 65 20 69 6e 20 61  he database in a
2400: 6e 20 69 6e 63 6f 6e 73 69 73 74 65 6e 74 20 73  n inconsistent s
2410: 74 61 74 65 2e 0a 20 20 2a 2a 20 49 66 20 73 79  tate..  ** If sy
2420: 6e 63 68 72 6f 6e 6f 75 73 20 69 73 20 4f 4e 20  nchronous is ON 
2430: 6f 72 20 4e 4f 52 4d 41 4c 2c 20 53 51 4c 69 74  or NORMAL, SQLit
2440: 65 20 77 69 6c 6c 20 64 6f 20 61 6e 20 66 73 79  e will do an fsy
2450: 6e 63 28 29 20 73 79 73 74 65 6d 20 63 61 6c 6c  nc() system call
2460: 20 74 6f 0a 20 20 2a 2a 20 6d 61 6b 65 20 73 75   to.  ** make su
2470: 72 65 20 64 61 74 61 20 69 73 20 62 65 69 6e 67  re data is being
2480: 20 77 72 69 74 74 65 6e 20 74 6f 20 64 69 73 6b   written to disk
2490: 2e 20 20 54 68 65 20 72 69 73 6b 20 6f 66 20 63  .  The risk of c
24a0: 6f 72 72 75 70 74 69 6f 6e 20 64 75 65 20 74 6f  orruption due to
24b0: 0a 20 20 2a 2a 20 61 20 70 6f 77 65 72 20 6c 6f  .  ** a power lo
24c0: 73 73 20 69 6e 20 74 68 69 73 20 6d 6f 64 65 20  ss in this mode 
24d0: 69 73 20 6e 65 67 6c 69 67 69 62 6c 65 20 62 75  is negligible bu
24e0: 74 20 6e 6f 6e 2d 7a 65 72 6f 2e 20 20 49 66 20  t non-zero.  If 
24f0: 73 79 6e 63 68 72 6f 6e 6f 75 73 0a 20 20 2a 2a  synchronous.  **
2500: 20 69 73 20 46 55 4c 4c 2c 20 65 78 74 72 61 20   is FULL, extra 
2510: 66 73 79 6e 63 28 29 73 20 6f 63 63 75 72 20 74  fsync()s occur t
2520: 6f 20 72 65 64 75 63 65 20 74 68 65 20 72 69 73  o reduce the ris
2530: 6b 20 6f 66 20 63 6f 72 72 75 70 74 69 6f 6e 20  k of corruption 
2540: 74 6f 20 6e 65 61 72 0a 20 20 2a 2a 20 7a 65 72  to near.  ** zer
2550: 6f 2c 20 62 75 74 20 77 69 74 68 20 61 20 77 72  o, but with a wr
2560: 69 74 65 20 70 65 72 66 6f 72 6d 61 6e 63 65 20  ite performance 
2570: 70 65 6e 61 6c 74 79 2e 20 20 54 68 65 20 64 65  penalty.  The de
2580: 66 61 75 6c 74 20 6d 6f 64 65 20 69 73 20 4e 4f  fault mode is NO
2590: 52 4d 41 4c 2e 0a 20 20 2a 2f 0a 20 20 69 66 28  RMAL..  */.  if(
25a0: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
25b0: 7a 4c 65 66 74 2c 22 64 65 66 61 75 6c 74 5f 73  zLeft,"default_s
25c0: 79 6e 63 68 72 6f 6e 6f 75 73 22 29 3d 3d 30 20  ynchronous")==0 
25d0: 29 7b 0a 20 20 20 20 73 74 61 74 69 63 20 56 64  ){.    static Vd
25e0: 62 65 4f 70 4c 69 73 74 20 67 65 74 53 79 6e 63  beOpList getSync
25f0: 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 7b 20 4f  [] = {.      { O
2600: 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 20 30  P_ColumnName,  0
2610: 2c 20 31 2c 20 20 20 20 20 20 20 20 22 73 79 6e  , 1,        "syn
2620: 63 68 72 6f 6e 6f 75 73 22 7d 2c 0a 20 20 20 20  chronous"},.    
2630: 20 20 7b 20 4f 50 5f 52 65 61 64 43 6f 6f 6b 69    { OP_ReadCooki
2640: 65 2c 20 20 30 2c 20 33 2c 20 20 20 20 20 20 20  e,  0, 3,       
2650: 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f   0},.      { OP_
2660: 44 75 70 2c 20 20 20 20 20 20 20 20 20 30 2c 20  Dup,         0, 
2670: 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20  0,        0},.  
2680: 20 20 20 20 7b 20 4f 50 5f 49 66 2c 20 20 20 20      { OP_If,    
2690: 20 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20        0, 0,     
26a0: 20 20 20 30 7d 2c 20 20 2f 2a 20 33 20 2a 2f 0a     0},  /* 3 */.
26b0: 20 20 20 20 20 20 7b 20 4f 50 5f 52 65 61 64 43        { OP_ReadC
26c0: 6f 6f 6b 69 65 2c 20 20 30 2c 20 32 2c 20 20 20  ookie,  0, 2,   
26d0: 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b       0},.      {
26e0: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20   OP_Integer,    
26f0: 20 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d   0, 0,        0}
2700: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 4c 74 2c  ,.      { OP_Lt,
2710: 20 20 20 20 20 20 20 20 20 20 30 2c 20 35 2c 20            0, 5, 
2720: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20         0},.     
2730: 20 7b 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 20 20   { OP_AddImm,   
2740: 20 20 20 31 2c 20 30 2c 20 20 20 20 20 20 20 20     1, 0,        
2750: 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43  0},.      { OP_C
2760: 61 6c 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30  allback,    1, 0
2770: 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20  ,        0},.   
2780: 20 20 20 7b 20 4f 50 5f 48 61 6c 74 2c 20 20 20     { OP_Halt,   
2790: 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20       0, 0,      
27a0: 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50    0},.      { OP
27b0: 5f 41 64 64 49 6d 6d 2c 20 20 20 20 20 2d 31 2c  _AddImm,     -1,
27c0: 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 20 20   0,        0},  
27d0: 2f 2a 20 31 30 20 2a 2f 0a 20 20 20 20 20 20 7b  /* 10 */.      {
27e0: 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 20 20   OP_Callback,   
27f0: 20 31 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d   1, 0,        0}
2800: 0a 20 20 20 20 7d 3b 0a 20 20 20 20 69 66 28 20  .    };.    if( 
2810: 70 52 69 67 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74  pRight->z==pLeft
2820: 2d 3e 7a 20 29 7b 0a 20 20 20 20 20 20 69 6e 74  ->z ){.      int
2830: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56   addr = sqlite3V
2840: 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c 20  dbeAddOpList(v, 
2850: 41 72 72 61 79 53 69 7a 65 28 67 65 74 53 79 6e  ArraySize(getSyn
2860: 63 29 2c 20 67 65 74 53 79 6e 63 29 3b 0a 20 20  c), getSync);.  
2870: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43      sqlite3VdbeC
2880: 68 61 6e 67 65 50 32 28 76 2c 20 61 64 64 72 2b  hangeP2(v, addr+
2890: 33 2c 20 61 64 64 72 2b 31 30 29 3b 0a 20 20 20  3, addr+10);.   
28a0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e   }else{.      in
28b0: 74 20 61 64 64 72 3b 0a 20 20 20 20 20 20 69 6e  t addr;.      in
28c0: 74 20 73 69 7a 65 20 3d 20 64 62 2d 3e 63 61 63  t size = db->cac
28d0: 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 20 20 69  he_size;.      i
28e0: 66 28 20 73 69 7a 65 3c 30 20 29 20 73 69 7a 65  f( size<0 ) size
28f0: 20 3d 20 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20   = -size;.      
2900: 73 71 6c 69 74 65 33 42 65 67 69 6e 57 72 69 74  sqlite3BeginWrit
2910: 65 4f 70 65 72 61 74 69 6f 6e 28 70 50 61 72 73  eOperation(pPars
2920: 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  e, 0, 0);.      
2930: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
2940: 28 76 2c 20 4f 50 5f 52 65 61 64 43 6f 6f 6b 69  (v, OP_ReadCooki
2950: 65 2c 20 30 2c 20 32 29 3b 0a 20 20 20 20 20 20  e, 0, 2);.      
2960: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
2970: 28 76 2c 20 4f 50 5f 44 75 70 2c 20 30 2c 20 30  (v, OP_Dup, 0, 0
2980: 29 3b 0a 20 20 20 20 20 20 61 64 64 72 20 3d 20  );.      addr = 
2990: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
29a0: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
29b0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
29c0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
29d0: 20 4f 50 5f 4e 65 2c 20 30 2c 20 61 64 64 72 2b   OP_Ne, 0, addr+
29e0: 33 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  3);.      sqlite
29f0: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
2a00: 5f 41 64 64 49 6d 6d 2c 20 4d 41 58 5f 50 41 47  _AddImm, MAX_PAG
2a10: 45 53 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71  ES, 0);.      sq
2a20: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
2a30: 2c 20 4f 50 5f 41 62 73 56 61 6c 75 65 2c 20 30  , OP_AbsValue, 0
2a40: 2c 20 30 29 3b 0a 20 20 20 20 20 20 64 62 2d 3e  , 0);.      db->
2a50: 73 61 66 65 74 79 5f 6c 65 76 65 6c 20 3d 20 67  safety_level = g
2a60: 65 74 53 61 66 65 74 79 4c 65 76 65 6c 28 7a 52  etSafetyLevel(zR
2a70: 69 67 68 74 29 2b 31 3b 0a 20 20 20 20 20 20 69  ight)+1;.      i
2a80: 66 28 20 64 62 2d 3e 73 61 66 65 74 79 5f 6c 65  f( db->safety_le
2a90: 76 65 6c 3d 3d 31 20 29 7b 0a 20 20 20 20 20 20  vel==1 ){.      
2aa0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
2ab0: 4f 70 28 76 2c 20 4f 50 5f 4e 65 67 61 74 69 76  Op(v, OP_Negativ
2ac0: 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  e, 0, 0);.      
2ad0: 20 20 73 69 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a    size = -size;.
2ae0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71        }.      sq
2af0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
2b00: 2c 20 4f 50 5f 53 65 74 43 6f 6f 6b 69 65 2c 20  , OP_SetCookie, 
2b10: 30 2c 20 32 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 2);.      sql
2b20: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
2b30: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 64 62 2d   OP_Integer, db-
2b40: 3e 73 61 66 65 74 79 5f 6c 65 76 65 6c 2c 20 30  >safety_level, 0
2b50: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
2b60: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
2b70: 53 65 74 43 6f 6f 6b 69 65 2c 20 30 2c 20 33 29  SetCookie, 0, 3)
2b80: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 45  ;.      sqlite3E
2b90: 6e 64 57 72 69 74 65 4f 70 65 72 61 74 69 6f 6e  ndWriteOperation
2ba0: 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20  (pParse);.      
2bb0: 64 62 2d 3e 63 61 63 68 65 5f 73 69 7a 65 20 3d  db->cache_size =
2bc0: 20 73 69 7a 65 3b 0a 20 20 20 20 20 20 73 71 6c   size;.      sql
2bd0: 69 74 65 33 42 74 72 65 65 53 65 74 43 61 63 68  ite3BtreeSetCach
2be0: 65 53 69 7a 65 28 64 62 2d 3e 61 44 62 5b 30 5d  eSize(db->aDb[0]
2bf0: 2e 70 42 74 2c 20 64 62 2d 3e 63 61 63 68 65 5f  .pBt, db->cache_
2c00: 73 69 7a 65 29 3b 0a 20 20 20 20 20 20 73 71 6c  size);.      sql
2c10: 69 74 65 33 42 74 72 65 65 53 65 74 53 61 66 65  ite3BtreeSetSafe
2c20: 74 79 4c 65 76 65 6c 28 64 62 2d 3e 61 44 62 5b  tyLevel(db->aDb[
2c30: 30 5d 2e 70 42 74 2c 20 64 62 2d 3e 73 61 66 65  0].pBt, db->safe
2c40: 74 79 5f 6c 65 76 65 6c 29 3b 0a 20 20 20 20 7d  ty_level);.    }
2c50: 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20  .  }else..  /*. 
2c60: 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 73 79 6e   **   PRAGMA syn
2c70: 63 68 72 6f 6e 6f 75 73 0a 20 20 2a 2a 20 20 20  chronous.  **   
2c80: 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f  PRAGMA synchrono
2c90: 75 73 3d 4f 46 46 7c 4f 4e 7c 4e 4f 52 4d 41 4c  us=OFF|ON|NORMAL
2ca0: 7c 46 55 4c 4c 0a 20 20 2a 2a 0a 20 20 2a 2a 20  |FULL.  **.  ** 
2cb0: 52 65 74 75 72 6e 20 6f 72 20 73 65 74 20 74 68  Return or set th
2cc0: 65 20 6c 6f 63 61 6c 20 76 61 6c 75 65 20 6f 66  e local value of
2cd0: 20 74 68 65 20 73 79 6e 63 68 72 6f 6e 6f 75 73   the synchronous
2ce0: 20 66 6c 61 67 2e 20 20 43 68 61 6e 67 69 6e 67   flag.  Changing
2cf0: 0a 20 20 2a 2a 20 74 68 65 20 6c 6f 63 61 6c 20  .  ** the local 
2d00: 76 61 6c 75 65 20 64 6f 65 73 20 6e 6f 74 20 6d  value does not m
2d10: 61 6b 65 20 63 68 61 6e 67 65 73 20 74 6f 20 74  ake changes to t
2d20: 68 65 20 64 69 73 6b 20 66 69 6c 65 20 61 6e 64  he disk file and
2d30: 20 74 68 65 0a 20 20 2a 2a 20 64 65 66 61 75 6c   the.  ** defaul
2d40: 74 20 76 61 6c 75 65 20 77 69 6c 6c 20 62 65 20  t value will be 
2d50: 72 65 73 74 6f 72 65 64 20 74 68 65 20 6e 65 78  restored the nex
2d60: 74 20 74 69 6d 65 20 74 68 65 20 64 61 74 61 62  t time the datab
2d70: 61 73 65 20 69 73 0a 20 20 2a 2a 20 6f 70 65 6e  ase is.  ** open
2d80: 65 64 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73  ed..  */.  if( s
2d90: 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c  qlite3StrICmp(zL
2da0: 65 66 74 2c 22 73 79 6e 63 68 72 6f 6e 6f 75 73  eft,"synchronous
2db0: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73 74 61  ")==0 ){.    sta
2dc0: 74 69 63 20 56 64 62 65 4f 70 4c 69 73 74 20 67  tic VdbeOpList g
2dd0: 65 74 53 79 6e 63 5b 5d 20 3d 20 7b 0a 20 20 20  etSync[] = {.   
2de0: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
2df0: 6d 65 2c 20 20 30 2c 20 31 2c 20 20 20 20 20 20  me,  0, 1,      
2e00: 20 20 22 73 79 6e 63 68 72 6f 6e 6f 75 73 22 7d    "synchronous"}
2e10: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c  ,.      { OP_Cal
2e20: 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30 2c 20  lback,    1, 0, 
2e30: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 7d         0},.    }
2e40: 3b 0a 20 20 20 20 69 66 28 20 70 52 69 67 68 74  ;.    if( pRight
2e50: 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a 20 29 7b  ->z==pLeft->z ){
2e60: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
2e70: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e  beAddOp(v, OP_In
2e80: 74 65 67 65 72 2c 20 64 62 2d 3e 73 61 66 65 74  teger, db->safet
2e90: 79 5f 6c 65 76 65 6c 2d 31 2c 20 30 29 3b 0a 20  y_level-1, 0);. 
2ea0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
2eb0: 41 64 64 4f 70 4c 69 73 74 28 76 2c 20 41 72 72  AddOpList(v, Arr
2ec0: 61 79 53 69 7a 65 28 67 65 74 53 79 6e 63 29 2c  aySize(getSync),
2ed0: 20 67 65 74 53 79 6e 63 29 3b 0a 20 20 20 20 7d   getSync);.    }
2ee0: 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74 20  else{.      int 
2ef0: 73 69 7a 65 20 3d 20 64 62 2d 3e 63 61 63 68 65  size = db->cache
2f00: 5f 73 69 7a 65 3b 0a 20 20 20 20 20 20 69 66 28  _size;.      if(
2f10: 20 73 69 7a 65 3c 30 20 29 20 73 69 7a 65 20 3d   size<0 ) size =
2f20: 20 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20 64 62   -size;.      db
2f30: 2d 3e 73 61 66 65 74 79 5f 6c 65 76 65 6c 20 3d  ->safety_level =
2f40: 20 67 65 74 53 61 66 65 74 79 4c 65 76 65 6c 28   getSafetyLevel(
2f50: 7a 52 69 67 68 74 29 2b 31 3b 0a 20 20 20 20 20  zRight)+1;.     
2f60: 20 69 66 28 20 64 62 2d 3e 73 61 66 65 74 79 5f   if( db->safety_
2f70: 6c 65 76 65 6c 3d 3d 31 20 29 20 73 69 7a 65 20  level==1 ) size 
2f80: 3d 20 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20 64  = -size;.      d
2f90: 62 2d 3e 63 61 63 68 65 5f 73 69 7a 65 20 3d 20  b->cache_size = 
2fa0: 73 69 7a 65 3b 0a 20 20 20 20 20 20 73 71 6c 69  size;.      sqli
2fb0: 74 65 33 42 74 72 65 65 53 65 74 43 61 63 68 65  te3BtreeSetCache
2fc0: 53 69 7a 65 28 64 62 2d 3e 61 44 62 5b 30 5d 2e  Size(db->aDb[0].
2fd0: 70 42 74 2c 20 64 62 2d 3e 63 61 63 68 65 5f 73  pBt, db->cache_s
2fe0: 69 7a 65 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  ize);.      sqli
2ff0: 74 65 33 42 74 72 65 65 53 65 74 53 61 66 65 74  te3BtreeSetSafet
3000: 79 4c 65 76 65 6c 28 64 62 2d 3e 61 44 62 5b 30  yLevel(db->aDb[0
3010: 5d 2e 70 42 74 2c 20 64 62 2d 3e 73 61 66 65 74  ].pBt, db->safet
3020: 79 5f 6c 65 76 65 6c 29 3b 0a 20 20 20 20 7d 0a  y_level);.    }.
3030: 20 20 7d 65 6c 73 65 0a 0a 23 69 66 6e 64 65 66    }else..#ifndef
3040: 20 4e 44 45 42 55 47 0a 20 20 69 66 28 20 73 71   NDEBUG.  if( sq
3050: 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65  lite3StrICmp(zLe
3060: 66 74 2c 20 22 74 72 69 67 67 65 72 5f 6f 76 65  ft, "trigger_ove
3070: 72 68 65 61 64 5f 74 65 73 74 22 29 3d 3d 30 20  rhead_test")==0 
3080: 29 7b 0a 20 20 20 20 69 66 28 20 67 65 74 42 6f  ){.    if( getBo
3090: 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29 20 29 7b  olean(zRight) ){
30a0: 0a 20 20 20 20 20 20 61 6c 77 61 79 73 5f 63 6f  .      always_co
30b0: 64 65 5f 74 72 69 67 67 65 72 5f 73 65 74 75 70  de_trigger_setup
30c0: 20 3d 20 31 3b 0a 20 20 20 20 7d 65 6c 73 65 7b   = 1;.    }else{
30d0: 0a 20 20 20 20 20 20 61 6c 77 61 79 73 5f 63 6f  .      always_co
30e0: 64 65 5f 74 72 69 67 67 65 72 5f 73 65 74 75 70  de_trigger_setup
30f0: 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 65   = 0;.    }.  }e
3100: 6c 73 65 0a 23 65 6e 64 69 66 0a 0a 20 20 69 66  lse.#endif..  if
3110: 28 20 66 6c 61 67 50 72 61 67 6d 61 28 70 50 61  ( flagPragma(pPa
3120: 72 73 65 2c 20 7a 4c 65 66 74 2c 20 7a 52 69 67  rse, zLeft, zRig
3130: 68 74 29 20 29 7b 0a 20 20 20 20 2f 2a 20 54 68  ht) ){.    /* Th
3140: 65 20 66 6c 61 67 50 72 61 67 6d 61 28 29 20 63  e flagPragma() c
3150: 61 6c 6c 20 61 6c 73 6f 20 67 65 6e 65 72 61 74  all also generat
3160: 65 73 20 61 6e 79 20 6e 65 63 65 73 73 61 72 79  es any necessary
3170: 20 63 6f 64 65 20 2a 2f 0a 20 20 7d 65 6c 73 65   code */.  }else
3180: 0a 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 53  ..  if( sqlite3S
3190: 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 74  trICmp(zLeft, "t
31a0: 61 62 6c 65 5f 69 6e 66 6f 22 29 3d 3d 30 20 29  able_info")==0 )
31b0: 7b 0a 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61  {.    Table *pTa
31c0: 62 3b 0a 20 20 20 20 70 54 61 62 20 3d 20 73 71  b;.    pTab = sq
31d0: 6c 69 74 65 33 46 69 6e 64 54 61 62 6c 65 28 64  lite3FindTable(d
31e0: 62 2c 20 7a 52 69 67 68 74 2c 20 30 29 3b 0a 20  b, zRight, 0);. 
31f0: 20 20 20 69 66 28 20 70 54 61 62 20 29 7b 0a 20     if( pTab ){. 
3200: 20 20 20 20 20 73 74 61 74 69 63 20 56 64 62 65       static Vdbe
3210: 4f 70 4c 69 73 74 20 74 61 62 6c 65 49 6e 66 6f  OpList tableInfo
3220: 50 72 65 66 61 63 65 5b 5d 20 3d 20 7b 0a 20 20  Preface[] = {.  
3230: 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d        { OP_Colum
3240: 6e 4e 61 6d 65 2c 20 20 30 2c 20 30 2c 20 20 20  nName,  0, 0,   
3250: 20 20 20 20 22 63 69 64 22 7d 2c 0a 20 20 20 20      "cid"},.    
3260: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3270: 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20 20  ame,  1, 0,     
3280: 20 20 22 6e 61 6d 65 22 7d 2c 0a 20 20 20 20 20    "name"},.     
3290: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
32a0: 6d 65 2c 20 20 32 2c 20 30 2c 20 20 20 20 20 20  me,  2, 0,      
32b0: 20 22 74 79 70 65 22 7d 2c 0a 20 20 20 20 20 20   "type"},.      
32c0: 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d    { OP_ColumnNam
32d0: 65 2c 20 20 33 2c 20 30 2c 20 20 20 20 20 20 20  e,  3, 0,       
32e0: 22 6e 6f 74 6e 75 6c 6c 22 7d 2c 0a 20 20 20 20  "notnull"},.    
32f0: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3300: 61 6d 65 2c 20 20 34 2c 20 30 2c 20 20 20 20 20  ame,  4, 0,     
3310: 20 20 22 64 66 6c 74 5f 76 61 6c 75 65 22 7d 2c    "dflt_value"},
3320: 0a 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f  .        { OP_Co
3330: 6c 75 6d 6e 4e 61 6d 65 2c 20 20 35 2c 20 31 2c  lumnName,  5, 1,
3340: 20 20 20 20 20 20 20 22 70 6b 22 7d 2c 0a 20 20         "pk"},.  
3350: 20 20 20 20 7d 3b 0a 20 20 20 20 20 20 69 6e 74      };.      int
3360: 20 69 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   i;.      sqlite
3370: 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76  3VdbeAddOpList(v
3380: 2c 20 41 72 72 61 79 53 69 7a 65 28 74 61 62 6c  , ArraySize(tabl
3390: 65 49 6e 66 6f 50 72 65 66 61 63 65 29 2c 20 74  eInfoPreface), t
33a0: 61 62 6c 65 49 6e 66 6f 50 72 65 66 61 63 65 29  ableInfoPreface)
33b0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
33c0: 69 65 77 47 65 74 43 6f 6c 75 6d 6e 4e 61 6d 65  iewGetColumnName
33d0: 73 28 70 50 61 72 73 65 2c 20 70 54 61 62 29 3b  s(pParse, pTab);
33e0: 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20  .      for(i=0; 
33f0: 69 3c 70 54 61 62 2d 3e 6e 43 6f 6c 3b 20 69 2b  i<pTab->nCol; i+
3400: 2b 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  +){.        sqli
3410: 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20  te3VdbeAddOp(v, 
3420: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20 30  OP_Integer, i, 0
3430: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
3440: 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f  e3VdbeOp3(v, OP_
3450: 53 74 72 69 6e 67 2c 20 30 2c 20 30 2c 20 70 54  String, 0, 0, pT
3460: 61 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 7a 4e 61 6d  ab->aCol[i].zNam
3470: 65 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  e, 0);.        s
3480: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
3490: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
34a0: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 70 54 61  ,.           pTa
34b0: 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 7a 54 79 70 65  b->aCol[i].zType
34c0: 20 3f 20 70 54 61 62 2d 3e 61 43 6f 6c 5b 69 5d   ? pTab->aCol[i]
34d0: 2e 7a 54 79 70 65 20 3a 20 22 6e 75 6d 65 72 69  .zType : "numeri
34e0: 63 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20  c", 0);.        
34f0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3500: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
3510: 70 54 61 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 6e 6f  pTab->aCol[i].no
3520: 74 4e 75 6c 6c 2c 20 30 29 3b 0a 20 20 20 20 20  tNull, 0);.     
3530: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 4f 70     sqlite3VdbeOp
3540: 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20  3(v, OP_String, 
3550: 30 2c 20 30 2c 0a 20 20 20 20 20 20 20 20 20 20  0, 0,.          
3560: 20 70 54 61 62 2d 3e 61 43 6f 6c 5b 69 5d 2e 7a   pTab->aCol[i].z
3570: 44 66 6c 74 2c 20 50 33 5f 53 54 41 54 49 43 29  Dflt, P3_STATIC)
3580: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
3590: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
35a0: 5f 49 6e 74 65 67 65 72 2c 20 70 54 61 62 2d 3e  _Integer, pTab->
35b0: 61 43 6f 6c 5b 69 5d 2e 69 73 50 72 69 6d 4b 65  aCol[i].isPrimKe
35c0: 79 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  y, 0);.        s
35d0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
35e0: 76 2c 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20  v, OP_Callback, 
35f0: 36 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20  6, 0);.      }. 
3600: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20     }.  }else..  
3610: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
3620: 6d 70 28 7a 4c 65 66 74 2c 20 22 69 6e 64 65 78  mp(zLeft, "index
3630: 5f 69 6e 66 6f 22 29 3d 3d 30 20 29 7b 0a 20 20  _info")==0 ){.  
3640: 20 20 49 6e 64 65 78 20 2a 70 49 64 78 3b 0a 20    Index *pIdx;. 
3650: 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a     Table *pTab;.
3660: 20 20 20 20 70 49 64 78 20 3d 20 73 71 6c 69 74      pIdx = sqlit
3670: 65 33 46 69 6e 64 49 6e 64 65 78 28 64 62 2c 20  e3FindIndex(db, 
3680: 7a 52 69 67 68 74 2c 20 30 29 3b 0a 20 20 20 20  zRight, 0);.    
3690: 69 66 28 20 70 49 64 78 20 29 7b 0a 20 20 20 20  if( pIdx ){.    
36a0: 20 20 73 74 61 74 69 63 20 56 64 62 65 4f 70 4c    static VdbeOpL
36b0: 69 73 74 20 74 61 62 6c 65 49 6e 66 6f 50 72 65  ist tableInfoPre
36c0: 66 61 63 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20  face[] = {.     
36d0: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
36e0: 6d 65 2c 20 20 30 2c 20 30 2c 20 20 20 20 20 20  me,  0, 0,      
36f0: 20 22 73 65 71 6e 6f 22 7d 2c 0a 20 20 20 20 20   "seqno"},.     
3700: 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61     { OP_ColumnNa
3710: 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20 20 20  me,  1, 0,      
3720: 20 22 63 69 64 22 7d 2c 0a 20 20 20 20 20 20 20   "cid"},.       
3730: 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65   { OP_ColumnName
3740: 2c 20 20 32 2c 20 31 2c 20 20 20 20 20 20 20 22  ,  2, 1,       "
3750: 6e 61 6d 65 22 7d 2c 0a 20 20 20 20 20 20 7d 3b  name"},.      };
3760: 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20 20  .      int i;.  
3770: 20 20 20 20 70 54 61 62 20 3d 20 70 49 64 78 2d      pTab = pIdx-
3780: 3e 70 54 61 62 6c 65 3b 0a 20 20 20 20 20 20 73  >pTable;.      s
3790: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c  qlite3VdbeAddOpL
37a0: 69 73 74 28 76 2c 20 41 72 72 61 79 53 69 7a 65  ist(v, ArraySize
37b0: 28 74 61 62 6c 65 49 6e 66 6f 50 72 65 66 61 63  (tableInfoPrefac
37c0: 65 29 2c 20 74 61 62 6c 65 49 6e 66 6f 50 72 65  e), tableInfoPre
37d0: 66 61 63 65 29 3b 0a 20 20 20 20 20 20 66 6f 72  face);.      for
37e0: 28 69 3d 30 3b 20 69 3c 70 49 64 78 2d 3e 6e 43  (i=0; i<pIdx->nC
37f0: 6f 6c 75 6d 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20  olumn; i++){.   
3800: 20 20 20 20 20 69 6e 74 20 63 6e 75 6d 20 3d 20       int cnum = 
3810: 70 49 64 78 2d 3e 61 69 43 6f 6c 75 6d 6e 5b 69  pIdx->aiColumn[i
3820: 5d 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ];.        sqlit
3830: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
3840: 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20 30 29  P_Integer, i, 0)
3850: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
3860: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
3870: 5f 49 6e 74 65 67 65 72 2c 20 63 6e 75 6d 2c 20  _Integer, cnum, 
3880: 30 29 3b 0a 20 20 20 20 20 20 20 20 61 73 73 65  0);.        asse
3890: 72 74 28 20 70 54 61 62 2d 3e 6e 43 6f 6c 3e 63  rt( pTab->nCol>c
38a0: 6e 75 6d 20 29 3b 0a 20 20 20 20 20 20 20 20 73  num );.        s
38b0: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
38c0: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
38d0: 2c 20 70 54 61 62 2d 3e 61 43 6f 6c 5b 63 6e 75  , pTab->aCol[cnu
38e0: 6d 5d 2e 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20  m].zName, 0);.  
38f0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
3900: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 43 61 6c  eAddOp(v, OP_Cal
3910: 6c 62 61 63 6b 2c 20 33 2c 20 30 29 3b 0a 20 20  lback, 3, 0);.  
3920: 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 65      }.    }.  }e
3930: 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c 69 74  lse..  if( sqlit
3940: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
3950: 20 22 69 6e 64 65 78 5f 6c 69 73 74 22 29 3d 3d   "index_list")==
3960: 30 20 29 7b 0a 20 20 20 20 49 6e 64 65 78 20 2a  0 ){.    Index *
3970: 70 49 64 78 3b 0a 20 20 20 20 54 61 62 6c 65 20  pIdx;.    Table 
3980: 2a 70 54 61 62 3b 0a 20 20 20 20 70 54 61 62 20  *pTab;.    pTab 
3990: 3d 20 73 71 6c 69 74 65 33 46 69 6e 64 54 61 62  = sqlite3FindTab
39a0: 6c 65 28 64 62 2c 20 7a 52 69 67 68 74 2c 20 30  le(db, zRight, 0
39b0: 29 3b 0a 20 20 20 20 69 66 28 20 70 54 61 62 20  );.    if( pTab 
39c0: 29 7b 0a 20 20 20 20 20 20 76 20 3d 20 73 71 6c  ){.      v = sql
39d0: 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72  ite3GetVdbe(pPar
39e0: 73 65 29 3b 0a 20 20 20 20 20 20 70 49 64 78 20  se);.      pIdx 
39f0: 3d 20 70 54 61 62 2d 3e 70 49 6e 64 65 78 3b 0a  = pTab->pIndex;.
3a00: 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 70 54      }.    if( pT
3a10: 61 62 20 26 26 20 70 49 64 78 20 29 7b 0a 20 20  ab && pIdx ){.  
3a20: 20 20 20 20 69 6e 74 20 69 20 3d 20 30 3b 20 0a      int i = 0; .
3a30: 20 20 20 20 20 20 73 74 61 74 69 63 20 56 64 62        static Vdb
3a40: 65 4f 70 4c 69 73 74 20 69 6e 64 65 78 4c 69 73  eOpList indexLis
3a50: 74 50 72 65 66 61 63 65 5b 5d 20 3d 20 7b 0a 20  tPreface[] = {. 
3a60: 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75         { OP_Colu
3a70: 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 30 2c 20 20  mnName,  0, 0,  
3a80: 20 20 20 20 20 22 73 65 71 22 7d 2c 0a 20 20 20       "seq"},.   
3a90: 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e       { OP_Column
3aa0: 4e 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20  Name,  1, 0,    
3ab0: 20 20 20 22 6e 61 6d 65 22 7d 2c 0a 20 20 20 20     "name"},.    
3ac0: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3ad0: 61 6d 65 2c 20 20 32 2c 20 31 2c 20 20 20 20 20  ame,  2, 1,     
3ae0: 20 20 22 75 6e 69 71 75 65 22 7d 2c 0a 20 20 20    "unique"},.   
3af0: 20 20 20 7d 3b 0a 0a 20 20 20 20 20 20 73 71 6c     };..      sql
3b00: 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73  ite3VdbeAddOpLis
3b10: 74 28 76 2c 20 41 72 72 61 79 53 69 7a 65 28 69  t(v, ArraySize(i
3b20: 6e 64 65 78 4c 69 73 74 50 72 65 66 61 63 65 29  ndexListPreface)
3b30: 2c 20 69 6e 64 65 78 4c 69 73 74 50 72 65 66 61  , indexListPrefa
3b40: 63 65 29 3b 0a 20 20 20 20 20 20 77 68 69 6c 65  ce);.      while
3b50: 28 70 49 64 78 29 7b 0a 20 20 20 20 20 20 20 20  (pIdx){.        
3b60: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3b70: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
3b80: 69 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  i, 0);.        s
3b90: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
3ba0: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
3bb0: 2c 20 70 49 64 78 2d 3e 7a 4e 61 6d 65 2c 20 30  , pIdx->zName, 0
3bc0: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
3bd0: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
3be0: 50 5f 49 6e 74 65 67 65 72 2c 20 70 49 64 78 2d  P_Integer, pIdx-
3bf0: 3e 6f 6e 45 72 72 6f 72 21 3d 4f 45 5f 4e 6f 6e  >onError!=OE_Non
3c00: 65 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  e, 0);.        s
3c10: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
3c20: 76 2c 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20  v, OP_Callback, 
3c30: 33 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 2b  3, 0);.        +
3c40: 2b 69 3b 0a 20 20 20 20 20 20 20 20 70 49 64 78  +i;.        pIdx
3c50: 20 3d 20 70 49 64 78 2d 3e 70 4e 65 78 74 3b 0a   = pIdx->pNext;.
3c60: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
3c70: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c  }else..  if( sql
3c80: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
3c90: 74 2c 20 22 66 6f 72 65 69 67 6e 5f 6b 65 79 5f  t, "foreign_key_
3ca0: 6c 69 73 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20  list")==0 ){.   
3cb0: 20 46 4b 65 79 20 2a 70 46 4b 3b 0a 20 20 20 20   FKey *pFK;.    
3cc0: 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a 20 20 20  Table *pTab;.   
3cd0: 20 70 54 61 62 20 3d 20 73 71 6c 69 74 65 33 46   pTab = sqlite3F
3ce0: 69 6e 64 54 61 62 6c 65 28 64 62 2c 20 7a 52 69  indTable(db, zRi
3cf0: 67 68 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28  ght, 0);.    if(
3d00: 20 70 54 61 62 20 29 7b 0a 20 20 20 20 20 20 76   pTab ){.      v
3d10: 20 3d 20 73 71 6c 69 74 65 33 47 65 74 56 64 62   = sqlite3GetVdb
3d20: 65 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20  e(pParse);.     
3d30: 20 70 46 4b 20 3d 20 70 54 61 62 2d 3e 70 46 4b   pFK = pTab->pFK
3d40: 65 79 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  ey;.    }.    if
3d50: 28 20 70 54 61 62 20 26 26 20 70 46 4b 20 29 7b  ( pTab && pFK ){
3d60: 0a 20 20 20 20 20 20 69 6e 74 20 69 20 3d 20 30  .      int i = 0
3d70: 3b 20 0a 20 20 20 20 20 20 73 74 61 74 69 63 20  ; .      static 
3d80: 56 64 62 65 4f 70 4c 69 73 74 20 69 6e 64 65 78  VdbeOpList index
3d90: 4c 69 73 74 50 72 65 66 61 63 65 5b 5d 20 3d 20  ListPreface[] = 
3da0: 7b 0a 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 43  {.        { OP_C
3db0: 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 30  olumnName,  0, 0
3dc0: 2c 20 20 20 20 20 20 20 22 69 64 22 7d 2c 0a 20  ,       "id"},. 
3dd0: 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75         { OP_Colu
3de0: 6d 6e 4e 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20  mnName,  1, 0,  
3df0: 20 20 20 20 20 22 73 65 71 22 7d 2c 0a 20 20 20       "seq"},.   
3e00: 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e       { OP_Column
3e10: 4e 61 6d 65 2c 20 20 32 2c 20 30 2c 20 20 20 20  Name,  2, 0,    
3e20: 20 20 20 22 74 61 62 6c 65 22 7d 2c 0a 20 20 20     "table"},.   
3e30: 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e       { OP_Column
3e40: 4e 61 6d 65 2c 20 20 33 2c 20 30 2c 20 20 20 20  Name,  3, 0,    
3e50: 20 20 20 22 66 72 6f 6d 22 7d 2c 0a 20 20 20 20     "from"},.    
3e60: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
3e70: 61 6d 65 2c 20 20 34 2c 20 31 2c 20 20 20 20 20  ame,  4, 1,     
3e80: 20 20 22 74 6f 22 7d 2c 0a 20 20 20 20 20 20 7d    "to"},.      }
3e90: 3b 0a 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ;..      sqlite3
3ea0: 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c  VdbeAddOpList(v,
3eb0: 20 41 72 72 61 79 53 69 7a 65 28 69 6e 64 65 78   ArraySize(index
3ec0: 4c 69 73 74 50 72 65 66 61 63 65 29 2c 20 69 6e  ListPreface), in
3ed0: 64 65 78 4c 69 73 74 50 72 65 66 61 63 65 29 3b  dexListPreface);
3ee0: 0a 20 20 20 20 20 20 77 68 69 6c 65 28 70 46 4b  .      while(pFK
3ef0: 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6a  ){.        int j
3f00: 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 6a 3d  ;.        for(j=
3f10: 30 3b 20 6a 3c 70 46 4b 2d 3e 6e 43 6f 6c 3b 20  0; j<pFK->nCol; 
3f20: 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20  j++){.          
3f30: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3f40: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
3f50: 69 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20  i, 0);.         
3f60: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
3f70: 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  p(v, OP_Integer,
3f80: 20 6a 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20   j, 0);.        
3f90: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4f 70 33    sqlite3VdbeOp3
3fa0: 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30  (v, OP_String, 0
3fb0: 2c 20 30 2c 20 70 46 4b 2d 3e 7a 54 6f 2c 20 30  , 0, pFK->zTo, 0
3fc0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  );.          sql
3fd0: 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f  ite3VdbeOp3(v, O
3fe0: 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30 2c 0a  P_String, 0, 0,.
3ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4000: 20 20 20 20 20 20 20 20 20 20 20 70 54 61 62 2d             pTab-
4010: 3e 61 43 6f 6c 5b 70 46 4b 2d 3e 61 43 6f 6c 5b  >aCol[pFK->aCol[
4020: 6a 5d 2e 69 46 72 6f 6d 5d 2e 7a 4e 61 6d 65 2c  j].iFrom].zName,
4030: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73   0);.          s
4040: 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c  qlite3VdbeOp3(v,
4050: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 30 2c 20 30   OP_String, 0, 0
4060: 2c 20 70 46 4b 2d 3e 61 43 6f 6c 5b 6a 5d 2e 7a  , pFK->aCol[j].z
4070: 43 6f 6c 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  Col, 0);.       
4080: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
4090: 64 4f 70 28 76 2c 20 4f 50 5f 43 61 6c 6c 62 61  dOp(v, OP_Callba
40a0: 63 6b 2c 20 35 2c 20 30 29 3b 0a 20 20 20 20 20  ck, 5, 0);.     
40b0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 2b 2b 69     }.        ++i
40c0: 3b 0a 20 20 20 20 20 20 20 20 70 46 4b 20 3d 20  ;.        pFK = 
40d0: 70 46 4b 2d 3e 70 4e 65 78 74 46 72 6f 6d 3b 0a  pFK->pNextFrom;.
40e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
40f0: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c  }else..  if( sql
4100: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
4110: 74 2c 20 22 64 61 74 61 62 61 73 65 5f 6c 69 73  t, "database_lis
4120: 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 69 6e  t")==0 ){.    in
4130: 74 20 69 3b 0a 20 20 20 20 73 74 61 74 69 63 20  t i;.    static 
4140: 56 64 62 65 4f 70 4c 69 73 74 20 69 6e 64 65 78  VdbeOpList index
4150: 4c 69 73 74 50 72 65 66 61 63 65 5b 5d 20 3d 20  ListPreface[] = 
4160: 7b 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c  {.      { OP_Col
4170: 75 6d 6e 4e 61 6d 65 2c 20 20 30 2c 20 30 2c 20  umnName,  0, 0, 
4180: 20 20 20 20 20 20 22 73 65 71 22 7d 2c 0a 20 20        "seq"},.  
4190: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
41a0: 61 6d 65 2c 20 20 31 2c 20 30 2c 20 20 20 20 20  ame,  1, 0,     
41b0: 20 20 22 6e 61 6d 65 22 7d 2c 0a 20 20 20 20 20    "name"},.     
41c0: 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65   { OP_ColumnName
41d0: 2c 20 20 32 2c 20 31 2c 20 20 20 20 20 20 20 22  ,  2, 1,       "
41e0: 66 69 6c 65 22 7d 2c 0a 20 20 20 20 7d 3b 0a 0a  file"},.    };..
41f0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
4200: 64 64 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61  ddOpList(v, Arra
4210: 79 53 69 7a 65 28 69 6e 64 65 78 4c 69 73 74 50  ySize(indexListP
4220: 72 65 66 61 63 65 29 2c 20 69 6e 64 65 78 4c 69  reface), indexLi
4230: 73 74 50 72 65 66 61 63 65 29 3b 0a 20 20 20 20  stPreface);.    
4240: 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62 2d 3e 6e  for(i=0; i<db->n
4250: 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  Db; i++){.      
4260: 69 66 28 20 64 62 2d 3e 61 44 62 5b 69 5d 2e 70  if( db->aDb[i].p
4270: 42 74 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65  Bt==0 ) continue
4280: 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20  ;.      assert( 
4290: 64 62 2d 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65  db->aDb[i].zName
42a0: 21 3d 30 20 29 3b 0a 20 20 20 20 20 20 73 71 6c  !=0 );.      sql
42b0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
42c0: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20   OP_Integer, i, 
42d0: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
42e0: 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53  3VdbeOp3(v, OP_S
42f0: 74 72 69 6e 67 2c 20 30 2c 20 30 2c 20 64 62 2d  tring, 0, 0, db-
4300: 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 2c 20 30  >aDb[i].zName, 0
4310: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
4320: 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74  VdbeOp3(v, OP_St
4330: 72 69 6e 67 2c 20 30 2c 20 30 2c 0a 20 20 20 20  ring, 0, 0,.    
4340: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 42 74         sqlite3Bt
4350: 72 65 65 47 65 74 46 69 6c 65 6e 61 6d 65 28 64  reeGetFilename(d
4360: 62 2d 3e 61 44 62 5b 69 5d 2e 70 42 74 29 2c 20  b->aDb[i].pBt), 
4370: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
4380: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
4390: 5f 43 61 6c 6c 62 61 63 6b 2c 20 33 2c 20 30 29  _Callback, 3, 0)
43a0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a  ;.    }.  }else.
43b0: 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20 50 52  ..  /*.  **   PR
43c0: 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 0a  AGMA temp_store.
43d0: 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 74 65    **   PRAGMA te
43e0: 6d 70 5f 73 74 6f 72 65 20 3d 20 22 64 65 66 61  mp_store = "defa
43f0: 75 6c 74 22 7c 22 6d 65 6d 6f 72 79 22 7c 22 66  ult"|"memory"|"f
4400: 69 6c 65 22 0a 20 20 2a 2a 0a 20 20 2a 2a 20 52  ile".  **.  ** R
4410: 65 74 75 72 6e 20 6f 72 20 73 65 74 20 74 68 65  eturn or set the
4420: 20 6c 6f 63 61 6c 20 76 61 6c 75 65 20 6f 66 20   local value of 
4430: 74 68 65 20 74 65 6d 70 5f 73 74 6f 72 65 20 66  the temp_store f
4440: 6c 61 67 2e 20 20 43 68 61 6e 67 69 6e 67 0a 20  lag.  Changing. 
4450: 20 2a 2a 20 74 68 65 20 6c 6f 63 61 6c 20 76 61   ** the local va
4460: 6c 75 65 20 64 6f 65 73 20 6e 6f 74 20 6d 61 6b  lue does not mak
4470: 65 20 63 68 61 6e 67 65 73 20 74 6f 20 74 68 65  e changes to the
4480: 20 64 69 73 6b 20 66 69 6c 65 20 61 6e 64 20 74   disk file and t
4490: 68 65 20 64 65 66 61 75 6c 74 0a 20 20 2a 2a 20  he default.  ** 
44a0: 76 61 6c 75 65 20 77 69 6c 6c 20 62 65 20 72 65  value will be re
44b0: 73 74 6f 72 65 64 20 74 68 65 20 6e 65 78 74 20  stored the next 
44c0: 74 69 6d 65 20 74 68 65 20 64 61 74 61 62 61 73  time the databas
44d0: 65 20 69 73 20 6f 70 65 6e 65 64 2e 0a 20 20 2a  e is opened..  *
44e0: 2a 0a 20 20 2a 2a 20 4e 6f 74 65 20 74 68 61 74  *.  ** Note that
44f0: 20 69 74 20 69 73 20 70 6f 73 73 69 62 6c 65 20   it is possible 
4500: 66 6f 72 20 74 68 65 20 6c 69 62 72 61 72 79 20  for the library 
4510: 63 6f 6d 70 69 6c 65 2d 74 69 6d 65 20 6f 70 74  compile-time opt
4520: 69 6f 6e 73 20 74 6f 0a 20 20 2a 2a 20 6f 76 65  ions to.  ** ove
4530: 72 72 69 64 65 20 74 68 69 73 20 73 65 74 74 69  rride this setti
4540: 6e 67 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71  ng.  */.  if( sq
4550: 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65  lite3StrICmp(zLe
4560: 66 74 2c 20 22 74 65 6d 70 5f 73 74 6f 72 65 22  ft, "temp_store"
4570: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73 74 61 74  )==0 ){.    stat
4580: 69 63 20 56 64 62 65 4f 70 4c 69 73 74 20 67 65  ic VdbeOpList ge
4590: 74 54 6d 70 44 62 4c 6f 63 5b 5d 20 3d 20 7b 0a  tTmpDbLoc[] = {.
45a0: 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d        { OP_Colum
45b0: 6e 4e 61 6d 65 2c 20 20 30 2c 20 31 2c 20 20 20  nName,  0, 1,   
45c0: 20 20 20 20 20 22 74 65 6d 70 5f 73 74 6f 72 65       "temp_store
45d0: 22 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43  "},.      { OP_C
45e0: 61 6c 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30  allback,    1, 0
45f0: 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20  ,        0},.   
4600: 20 7d 3b 0a 20 20 20 20 69 66 28 20 70 52 69 67   };.    if( pRig
4610: 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a 20  ht->z==pLeft->z 
4620: 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ){.      sqlite3
4630: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
4640: 49 6e 74 65 67 65 72 2c 20 64 62 2d 3e 74 65 6d  Integer, db->tem
4650: 70 5f 73 74 6f 72 65 2c 20 30 29 3b 0a 20 20 20  p_store, 0);.   
4660: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
4670: 64 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79  dOpList(v, Array
4680: 53 69 7a 65 28 67 65 74 54 6d 70 44 62 4c 6f 63  Size(getTmpDbLoc
4690: 29 2c 20 67 65 74 54 6d 70 44 62 4c 6f 63 29 3b  ), getTmpDbLoc);
46a0: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
46b0: 20 20 63 68 61 6e 67 65 54 65 6d 70 53 74 6f 72    changeTempStor
46c0: 61 67 65 28 70 50 61 72 73 65 2c 20 7a 52 69 67  age(pParse, zRig
46d0: 68 74 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c  ht);.    }.  }el
46e0: 73 65 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20  se..  /*.  **   
46f0: 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 74  PRAGMA default_t
4700: 65 6d 70 5f 73 74 6f 72 65 0a 20 20 2a 2a 20 20  emp_store.  **  
4710: 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f   PRAGMA default_
4720: 74 65 6d 70 5f 73 74 6f 72 65 20 3d 20 22 64 65  temp_store = "de
4730: 66 61 75 6c 74 22 7c 22 6d 65 6d 6f 72 79 22 7c  fault"|"memory"|
4740: 22 66 69 6c 65 22 0a 20 20 2a 2a 0a 20 20 2a 2a  "file".  **.  **
4750: 20 52 65 74 75 72 6e 20 6f 72 20 73 65 74 20 74   Return or set t
4760: 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20  he value of the 
4770: 70 65 72 73 69 73 74 65 6e 74 20 74 65 6d 70 5f  persistent temp_
4780: 73 74 6f 72 65 20 66 6c 61 67 2e 20 20 41 6e 79  store flag.  Any
4790: 0a 20 20 2a 2a 20 63 68 61 6e 67 65 20 64 6f 65  .  ** change doe
47a0: 73 20 6e 6f 74 20 74 61 6b 65 20 65 66 66 65 63  s not take effec
47b0: 74 20 75 6e 74 69 6c 20 74 68 65 20 6e 65 78 74  t until the next
47c0: 20 74 69 6d 65 20 74 68 65 20 64 61 74 61 62 61   time the databa
47d0: 73 65 20 69 73 0a 20 20 2a 2a 20 6f 70 65 6e 65  se is.  ** opene
47e0: 64 2e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 4e 6f 74  d..  **.  ** Not
47f0: 65 20 74 68 61 74 20 69 74 20 69 73 20 70 6f 73  e that it is pos
4800: 73 69 62 6c 65 20 66 6f 72 20 74 68 65 20 6c 69  sible for the li
4810: 62 72 61 72 79 20 63 6f 6d 70 69 6c 65 2d 74 69  brary compile-ti
4820: 6d 65 20 6f 70 74 69 6f 6e 73 20 74 6f 0a 20 20  me options to.  
4830: 2a 2a 20 6f 76 65 72 72 69 64 65 20 74 68 69 73  ** override this
4840: 20 73 65 74 74 69 6e 67 0a 20 20 2a 2f 0a 20 20   setting.  */.  
4850: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
4860: 6d 70 28 7a 4c 65 66 74 2c 20 22 64 65 66 61 75  mp(zLeft, "defau
4870: 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65 22 29 3d  lt_temp_store")=
4880: 3d 30 20 29 7b 0a 20 20 20 20 73 74 61 74 69 63  =0 ){.    static
4890: 20 56 64 62 65 4f 70 4c 69 73 74 20 67 65 74 54   VdbeOpList getT
48a0: 6d 70 44 62 4c 6f 63 5b 5d 20 3d 20 7b 0a 20 20  mpDbLoc[] = {.  
48b0: 20 20 20 20 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e      { OP_ColumnN
48c0: 61 6d 65 2c 20 20 30 2c 20 31 2c 20 20 20 20 20  ame,  0, 1,     
48d0: 20 20 20 22 74 65 6d 70 5f 73 74 6f 72 65 22 7d     "temp_store"}
48e0: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 52 65 61  ,.      { OP_Rea
48f0: 64 43 6f 6f 6b 69 65 2c 20 20 30 2c 20 35 2c 20  dCookie,  0, 5, 
4900: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20         0},.     
4910: 20 7b 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20   { OP_Callback, 
4920: 20 20 20 31 2c 20 30 2c 20 20 20 20 20 20 20 20     1, 0,        
4930: 30 7d 7d 3b 0a 20 20 20 20 69 66 28 20 70 52 69  0}};.    if( pRi
4940: 67 68 74 2d 3e 7a 3d 3d 70 4c 65 66 74 2d 3e 7a  ght->z==pLeft->z
4950: 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   ){.      sqlite
4960: 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76  3VdbeAddOpList(v
4970: 2c 20 41 72 72 61 79 53 69 7a 65 28 67 65 74 54  , ArraySize(getT
4980: 6d 70 44 62 4c 6f 63 29 2c 20 67 65 74 54 6d 70  mpDbLoc), getTmp
4990: 44 62 4c 6f 63 29 3b 0a 20 20 20 20 7d 65 6c 73  DbLoc);.    }els
49a0: 65 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  e{.      sqlite3
49b0: 42 65 67 69 6e 57 72 69 74 65 4f 70 65 72 61 74  BeginWriteOperat
49c0: 69 6f 6e 28 70 50 61 72 73 65 2c 20 30 2c 20 30  ion(pParse, 0, 0
49d0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
49e0: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
49f0: 49 6e 74 65 67 65 72 2c 20 67 65 74 54 65 6d 70  Integer, getTemp
4a00: 53 74 6f 72 65 28 7a 52 69 67 68 74 29 2c 20 30  Store(zRight), 0
4a10: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
4a20: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
4a30: 53 65 74 43 6f 6f 6b 69 65 2c 20 30 2c 20 35 29  SetCookie, 0, 5)
4a40: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 45  ;.      sqlite3E
4a50: 6e 64 57 72 69 74 65 4f 70 65 72 61 74 69 6f 6e  ndWriteOperation
4a60: 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 7d 0a  (pParse);.    }.
4a70: 20 20 7d 65 6c 73 65 0a 0a 23 69 66 6e 64 65 66    }else..#ifndef
4a80: 20 4e 44 45 42 55 47 0a 20 20 69 66 28 20 73 71   NDEBUG.  if( sq
4a90: 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65  lite3StrICmp(zLe
4aa0: 66 74 2c 20 22 70 61 72 73 65 72 5f 74 72 61 63  ft, "parser_trac
4ab0: 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 65 78  e")==0 ){.    ex
4ac0: 74 65 72 6e 20 76 6f 69 64 20 73 71 6c 69 74 65  tern void sqlite
4ad0: 33 50 61 72 73 65 72 54 72 61 63 65 28 46 49 4c  3ParserTrace(FIL
4ae0: 45 2a 2c 20 63 68 61 72 20 2a 29 3b 0a 20 20 20  E*, char *);.   
4af0: 20 69 66 28 20 67 65 74 42 6f 6f 6c 65 61 6e 28   if( getBoolean(
4b00: 7a 52 69 67 68 74 29 20 29 7b 0a 20 20 20 20 20  zRight) ){.     
4b10: 20 73 71 6c 69 74 65 33 50 61 72 73 65 72 54 72   sqlite3ParserTr
4b20: 61 63 65 28 73 74 64 6f 75 74 2c 20 22 70 61 72  ace(stdout, "par
4b30: 73 65 72 3a 20 22 29 3b 0a 20 20 20 20 7d 65 6c  ser: ");.    }el
4b40: 73 65 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  se{.      sqlite
4b50: 33 50 61 72 73 65 72 54 72 61 63 65 28 30 2c 20  3ParserTrace(0, 
4b60: 30 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73  0);.    }.  }els
4b70: 65 0a 23 65 6e 64 69 66 0a 0a 20 20 69 66 28 20  e.#endif..  if( 
4b80: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
4b90: 4c 65 66 74 2c 20 22 69 6e 74 65 67 72 69 74 79  Left, "integrity
4ba0: 5f 63 68 65 63 6b 22 29 3d 3d 30 20 29 7b 0a 20  _check")==0 ){. 
4bb0: 20 20 20 69 6e 74 20 69 2c 20 6a 2c 20 61 64 64     int i, j, add
4bc0: 72 3b 0a 0a 20 20 20 20 2f 2a 20 43 6f 64 65 20  r;..    /* Code 
4bd0: 74 68 61 74 20 69 6e 69 74 69 61 6c 69 7a 65 73  that initializes
4be0: 20 74 68 65 20 69 6e 74 65 67 72 69 74 79 20 63   the integrity c
4bf0: 68 65 63 6b 20 70 72 6f 67 72 61 6d 2e 20 20 53  heck program.  S
4c00: 65 74 20 74 68 65 0a 20 20 20 20 2a 2a 20 65 72  et the.    ** er
4c10: 72 6f 72 20 63 6f 75 6e 74 20 30 0a 20 20 20 20  ror count 0.    
4c20: 2a 2f 0a 20 20 20 20 73 74 61 74 69 63 20 56 64  */.    static Vd
4c30: 62 65 4f 70 4c 69 73 74 20 69 6e 69 74 43 6f 64  beOpList initCod
4c40: 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 7b 20  e[] = {.      { 
4c50: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20 20  OP_Integer,     
4c60: 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c  0, 0,        0},
4c70: 0a 20 20 20 20 20 20 7b 20 4f 50 5f 4d 65 6d 53  .      { OP_MemS
4c80: 74 6f 72 65 2c 20 20 20 20 30 2c 20 31 2c 20 20  tore,    0, 1,  
4c90: 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20        0},.      
4ca0: 7b 20 4f 50 5f 43 6f 6c 75 6d 6e 4e 61 6d 65 2c  { OP_ColumnName,
4cb0: 20 20 30 2c 20 31 2c 20 20 20 20 20 20 20 20 22    0, 1,        "
4cc0: 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63 6b 22  integrity_check"
4cd0: 7d 2c 0a 20 20 20 20 7d 3b 0a 0a 20 20 20 20 2f  },.    };..    /
4ce0: 2a 20 43 6f 64 65 20 74 6f 20 64 6f 20 61 6e 20  * Code to do an 
4cf0: 42 54 72 65 65 20 69 6e 74 65 67 72 69 74 79 20  BTree integrity 
4d00: 63 68 65 63 6b 20 6f 6e 20 61 20 73 69 6e 67 6c  check on a singl
4d10: 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  e database file.
4d20: 0a 20 20 20 20 2a 2f 0a 20 20 20 20 73 74 61 74  .    */.    stat
4d30: 69 63 20 56 64 62 65 4f 70 4c 69 73 74 20 63 68  ic VdbeOpList ch
4d40: 65 63 6b 44 62 5b 5d 20 3d 20 7b 0a 20 20 20 20  eckDb[] = {.    
4d50: 20 20 7b 20 4f 50 5f 53 65 74 49 6e 73 65 72 74    { OP_SetInsert
4d60: 2c 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20 20  ,   0, 0,       
4d70: 20 22 31 22 7d 2c 0a 20 20 20 20 20 20 7b 20 4f   "1"},.      { O
4d80: 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20 20 30  P_Integer,     0
4d90: 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 20  , 0,        0}, 
4da0: 20 20 20 2f 2a 20 31 20 2a 2f 0a 20 20 20 20 20     /* 1 */.     
4db0: 20 7b 20 4f 50 5f 4f 70 65 6e 52 65 61 64 2c 20   { OP_OpenRead, 
4dc0: 20 20 20 30 2c 20 4d 41 53 54 45 52 5f 52 4f 4f     0, MASTER_ROO
4dd0: 54 2c 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f  T, 0},.      { O
4de0: 50 5f 53 65 74 4e 75 6d 43 6f 6c 75 6d 6e 73 2c  P_SetNumColumns,
4df0: 30 2c 35 2c 20 20 20 20 20 20 20 20 30 7d 2c 20  0,5,        0}, 
4e00: 20 20 20 2f 2a 20 73 71 6c 69 74 65 5f 6d 61 73     /* sqlite_mas
4e10: 74 65 72 20 68 61 73 20 35 20 63 6f 6c 73 20 2a  ter has 5 cols *
4e20: 2f 0a 0a 20 20 20 20 20 20 7b 20 4f 50 5f 52 65  /..      { OP_Re
4e30: 77 69 6e 64 2c 20 20 20 20 20 20 30 2c 20 38 2c  wind,      0, 8,
4e40: 20 20 20 20 20 20 20 20 30 7d 2c 20 20 20 20 2f          0},    /
4e50: 2a 20 34 20 2a 2f 0a 20 20 20 20 20 20 7b 20 4f  * 4 */.      { O
4e60: 50 5f 43 6f 6c 75 6d 6e 2c 20 20 20 20 20 20 30  P_Column,      0
4e70: 2c 20 33 2c 20 20 20 20 20 20 20 20 30 7d 2c 20  , 3,        0}, 
4e80: 20 20 20 2f 2a 20 35 20 2a 2f 0a 20 20 20 20 20     /* 5 */.     
4e90: 20 7b 20 4f 50 5f 53 65 74 49 6e 73 65 72 74 2c   { OP_SetInsert,
4ea0: 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20 20 20     0, 0,        
4eb0: 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 4e  0},.      { OP_N
4ec0: 65 78 74 2c 20 20 20 20 20 20 20 20 30 2c 20 35  ext,        0, 5
4ed0: 2c 20 20 20 20 20 20 20 20 30 7d 2c 20 20 20 20  ,        0},    
4ee0: 2f 2a 20 37 20 2a 2f 0a 20 20 20 20 20 20 7b 20  /* 7 */.      { 
4ef0: 4f 50 5f 49 6e 74 65 67 72 69 74 79 43 6b 2c 20  OP_IntegrityCk, 
4f00: 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c  0, 0,        0},
4f10: 20 20 20 20 2f 2a 20 38 20 2a 2f 0a 20 20 20 20      /* 8 */.    
4f20: 20 20 7b 20 4f 50 5f 44 75 70 2c 20 20 20 20 20    { OP_Dup,     
4f30: 20 20 20 20 30 2c 20 31 2c 20 20 20 20 20 20 20      0, 1,       
4f40: 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f   0},.      { OP_
4f50: 53 74 72 69 6e 67 2c 20 20 20 20 20 20 30 2c 20  String,      0, 
4f60: 30 2c 20 20 20 20 20 20 20 20 22 6f 6b 22 7d 2c  0,        "ok"},
4f70: 0a 20 20 20 20 20 20 7b 20 4f 50 5f 45 71 2c 20  .      { OP_Eq, 
4f80: 20 20 20 20 20 20 20 20 20 30 2c 20 31 33 2c 20           0, 13, 
4f90: 20 20 20 20 20 20 30 7d 2c 20 20 20 20 2f 2a 20        0},    /* 
4fa0: 31 31 20 2a 2f 0a 20 20 20 20 20 20 7b 20 4f 50  11 */.      { OP
4fb0: 5f 4d 65 6d 49 6e 63 72 2c 20 20 20 20 20 30 2c  _MemIncr,     0,
4fc0: 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20   0,        0},. 
4fd0: 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67       { OP_String
4fe0: 2c 20 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20  ,      0, 0,    
4ff0: 20 20 20 20 22 2a 2a 2a 20 69 6e 20 64 61 74 61      "*** in data
5000: 62 61 73 65 20 22 7d 2c 0a 20 20 20 20 20 20 7b  base "},.      {
5010: 20 4f 50 5f 53 74 72 69 6e 67 2c 20 20 20 20 20   OP_String,     
5020: 20 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d   0, 0,        0}
5030: 2c 20 20 20 20 2f 2a 20 31 34 20 2a 2f 0a 20 20  ,    /* 14 */.  
5040: 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67 2c      { OP_String,
5050: 20 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20        0, 0,     
5060: 20 20 20 22 20 2a 2a 2a 5c 6e 22 7d 2c 0a 20 20     " ***\n"},.  
5070: 20 20 20 20 7b 20 4f 50 5f 50 75 6c 6c 2c 20 20      { OP_Pull,  
5080: 20 20 20 20 20 20 33 2c 20 30 2c 20 20 20 20 20        3, 0,     
5090: 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f     0},.      { O
50a0: 50 5f 43 6f 6e 63 61 74 2c 20 20 20 20 20 20 34  P_Concat,      4
50b0: 2c 20 31 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a  , 1,        0},.
50c0: 20 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c 62        { OP_Callb
50d0: 61 63 6b 2c 20 20 20 20 31 2c 20 30 2c 20 20 20  ack,    1, 0,   
50e0: 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 7d 3b 0a       0},.    };.
50f0: 0a 20 20 20 20 2f 2a 20 43 6f 64 65 20 74 68 61  .    /* Code tha
5100: 74 20 61 70 70 65 61 72 73 20 61 74 20 74 68 65  t appears at the
5110: 20 65 6e 64 20 6f 66 20 74 68 65 20 69 6e 74 65   end of the inte
5120: 67 72 69 74 79 20 63 68 65 63 6b 2e 20 20 49 66  grity check.  If
5130: 20 6e 6f 20 65 72 72 6f 72 0a 20 20 20 20 2a 2a   no error.    **
5140: 20 6d 65 73 73 61 67 65 73 20 68 61 76 65 20 62   messages have b
5150: 65 65 6e 20 67 65 6e 65 72 61 74 65 64 2c 20 6f  een generated, o
5160: 75 74 70 75 74 20 4f 4b 2e 20 20 4f 74 68 65 72  utput OK.  Other
5170: 77 69 73 65 20 6f 75 74 70 75 74 20 74 68 65 0a  wise output the.
5180: 20 20 20 20 2a 2a 20 65 72 72 6f 72 20 6d 65 73      ** error mes
5190: 73 61 67 65 0a 20 20 20 20 2a 2f 0a 20 20 20 20  sage.    */.    
51a0: 73 74 61 74 69 63 20 56 64 62 65 4f 70 4c 69 73  static VdbeOpLis
51b0: 74 20 65 6e 64 43 6f 64 65 5b 5d 20 3d 20 7b 0a  t endCode[] = {.
51c0: 20 20 20 20 20 20 7b 20 4f 50 5f 4d 65 6d 4c 6f        { OP_MemLo
51d0: 61 64 2c 20 20 20 20 20 30 2c 20 30 2c 20 20 20  ad,     0, 0,   
51e0: 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b       0},.      {
51f0: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20   OP_Integer,    
5200: 20 30 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d   0, 0,        0}
5210: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 4e 65 2c  ,.      { OP_Ne,
5220: 20 20 20 20 20 20 20 20 20 20 30 2c 20 30 2c 20            0, 0, 
5230: 20 20 20 20 20 20 20 30 7d 2c 20 20 20 20 2f 2a         0},    /*
5240: 20 32 20 2a 2f 0a 20 20 20 20 20 20 7b 20 4f 50   2 */.      { OP
5250: 5f 53 74 72 69 6e 67 2c 20 20 20 20 20 20 30 2c  _String,      0,
5260: 20 30 2c 20 20 20 20 20 20 20 20 22 6f 6b 22 7d   0,        "ok"}
5270: 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c  ,.      { OP_Cal
5280: 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30 2c 20  lback,    1, 0, 
5290: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 7d         0},.    }
52a0: 3b 0a 0a 20 20 20 20 2f 2a 20 49 6e 69 74 69 61  ;..    /* Initia
52b0: 6c 69 7a 65 20 74 68 65 20 56 44 42 45 20 70 72  lize the VDBE pr
52c0: 6f 67 72 61 6d 20 2a 2f 0a 20 20 20 20 73 71 6c  ogram */.    sql
52d0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73  ite3VdbeAddOpLis
52e0: 74 28 76 2c 20 41 72 72 61 79 53 69 7a 65 28 69  t(v, ArraySize(i
52f0: 6e 69 74 43 6f 64 65 29 2c 20 69 6e 69 74 43 6f  nitCode), initCo
5300: 64 65 29 3b 0a 0a 20 20 20 20 2f 2a 20 44 6f 20  de);..    /* Do 
5310: 61 6e 20 69 6e 74 65 67 72 69 74 79 20 63 68 65  an integrity che
5320: 63 6b 20 6f 6e 20 65 61 63 68 20 64 61 74 61 62  ck on each datab
5330: 61 73 65 20 66 69 6c 65 20 2a 2f 0a 20 20 20 20  ase file */.    
5340: 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62 2d 3e 6e  for(i=0; i<db->n
5350: 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  Db; i++){.      
5360: 48 61 73 68 45 6c 65 6d 20 2a 78 3b 0a 0a 20 20  HashElem *x;..  
5370: 20 20 20 20 2f 2a 20 44 6f 20 61 6e 20 69 6e 74      /* Do an int
5380: 65 67 72 69 74 79 20 63 68 65 63 6b 20 6f 66 20  egrity check of 
5390: 74 68 65 20 42 2d 54 72 65 65 0a 20 20 20 20 20  the B-Tree.     
53a0: 20 2a 2f 0a 20 20 20 20 20 20 61 64 64 72 20 3d   */.      addr =
53b0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
53c0: 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53 69  pList(v, ArraySi
53d0: 7a 65 28 63 68 65 63 6b 44 62 29 2c 20 63 68 65  ze(checkDb), che
53e0: 63 6b 44 62 29 3b 0a 20 20 20 20 20 20 73 71 6c  ckDb);.      sql
53f0: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 31  ite3VdbeChangeP1
5400: 28 76 2c 20 61 64 64 72 2b 31 2c 20 69 29 3b 0a  (v, addr+1, i);.
5410: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
5420: 65 43 68 61 6e 67 65 50 32 28 76 2c 20 61 64 64  eChangeP2(v, add
5430: 72 2b 34 2c 20 61 64 64 72 2b 38 29 3b 0a 20 20  r+4, addr+8);.  
5440: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43      sqlite3VdbeC
5450: 68 61 6e 67 65 50 32 28 76 2c 20 61 64 64 72 2b  hangeP2(v, addr+
5460: 37 2c 20 61 64 64 72 2b 35 29 3b 0a 20 20 20 20  7, addr+5);.    
5470: 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61    sqlite3VdbeCha
5480: 6e 67 65 50 32 28 76 2c 20 61 64 64 72 2b 38 2c  ngeP2(v, addr+8,
5490: 20 69 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   i);.      sqlit
54a0: 65 33 56 64 62 65 43 68 61 6e 67 65 50 32 28 76  e3VdbeChangeP2(v
54b0: 2c 20 61 64 64 72 2b 31 31 2c 20 61 64 64 72 2b  , addr+11, addr+
54c0: 41 72 72 61 79 53 69 7a 65 28 63 68 65 63 6b 44  ArraySize(checkD
54d0: 62 29 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  b));.      sqlit
54e0: 65 33 56 64 62 65 43 68 61 6e 67 65 50 33 28 76  e3VdbeChangeP3(v
54f0: 2c 20 61 64 64 72 2b 31 34 2c 20 64 62 2d 3e 61  , addr+14, db->a
5500: 44 62 5b 69 5d 2e 7a 4e 61 6d 65 2c 20 50 33 5f  Db[i].zName, P3_
5510: 53 54 41 54 49 43 29 3b 0a 0a 20 20 20 20 20 20  STATIC);..      
5520: 2f 2a 20 4d 61 6b 65 20 73 75 72 65 20 61 6c 6c  /* Make sure all
5530: 20 74 68 65 20 69 6e 64 69 63 65 73 20 61 72 65   the indices are
5540: 20 63 6f 6e 73 74 72 75 63 74 65 64 20 63 6f 72   constructed cor
5550: 72 65 63 74 6c 79 2e 0a 20 20 20 20 20 20 2a 2f  rectly..      */
5560: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 43 6f  .      sqlite3Co
5570: 64 65 56 65 72 69 66 79 53 63 68 65 6d 61 28 70  deVerifySchema(p
5580: 50 61 72 73 65 2c 20 69 29 3b 0a 20 20 20 20 20  Parse, i);.     
5590: 20 66 6f 72 28 78 3d 73 71 6c 69 74 65 48 61 73   for(x=sqliteHas
55a0: 68 46 69 72 73 74 28 26 64 62 2d 3e 61 44 62 5b  hFirst(&db->aDb[
55b0: 69 5d 2e 74 62 6c 48 61 73 68 29 3b 20 78 3b 20  i].tblHash); x; 
55c0: 78 3d 73 71 6c 69 74 65 48 61 73 68 4e 65 78 74  x=sqliteHashNext
55d0: 28 78 29 29 7b 0a 20 20 20 20 20 20 20 20 54 61  (x)){.        Ta
55e0: 62 6c 65 20 2a 70 54 61 62 20 3d 20 73 71 6c 69  ble *pTab = sqli
55f0: 74 65 48 61 73 68 44 61 74 61 28 78 29 3b 0a 20  teHashData(x);. 
5600: 20 20 20 20 20 20 20 49 6e 64 65 78 20 2a 70 49         Index *pI
5610: 64 78 3b 0a 20 20 20 20 20 20 20 20 69 6e 74 20  dx;.        int 
5620: 6c 6f 6f 70 54 6f 70 3b 0a 0a 20 20 20 20 20 20  loopTop;..      
5630: 20 20 69 66 28 20 70 54 61 62 2d 3e 70 49 6e 64    if( pTab->pInd
5640: 65 78 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65  ex==0 ) continue
5650: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
5660: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
5670: 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20 30 29 3b  _Integer, i, 0);
5680: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
5690: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
56a0: 4f 70 65 6e 52 65 61 64 2c 20 31 2c 20 70 54 61  OpenRead, 1, pTa
56b0: 62 2d 3e 74 6e 75 6d 29 3b 0a 20 20 20 20 20 20  b->tnum);.      
56c0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
56d0: 4f 70 28 76 2c 20 4f 50 5f 53 65 74 4e 75 6d 43  Op(v, OP_SetNumC
56e0: 6f 6c 75 6d 6e 73 2c 20 31 2c 20 70 54 61 62 2d  olumns, 1, pTab-
56f0: 3e 6e 43 6f 6c 29 3b 0a 20 20 20 20 20 20 20 20  >nCol);.        
5700: 66 6f 72 28 6a 3d 30 2c 20 70 49 64 78 3d 70 54  for(j=0, pIdx=pT
5710: 61 62 2d 3e 70 49 6e 64 65 78 3b 20 70 49 64 78  ab->pIndex; pIdx
5720: 3b 20 70 49 64 78 3d 70 49 64 78 2d 3e 70 4e 65  ; pIdx=pIdx->pNe
5730: 78 74 2c 20 6a 2b 2b 29 7b 0a 20 20 20 20 20 20  xt, j++){.      
5740: 20 20 20 20 69 66 28 20 70 49 64 78 2d 3e 74 6e      if( pIdx->tn
5750: 75 6d 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65  um==0 ) continue
5760: 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  ;.          sqli
5770: 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20  te3VdbeAddOp(v, 
5780: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 70 49 64 78  OP_Integer, pIdx
5790: 2d 3e 69 44 62 2c 20 30 29 3b 0a 20 20 20 20 20  ->iDb, 0);.     
57a0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
57b0: 4f 70 33 28 76 2c 20 4f 50 5f 4f 70 65 6e 52 65  Op3(v, OP_OpenRe
57c0: 61 64 2c 20 6a 2b 32 2c 20 70 49 64 78 2d 3e 74  ad, j+2, pIdx->t
57d0: 6e 75 6d 2c 20 0a 20 20 20 20 20 20 20 20 20 20  num, .          
57e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28                 (
57f0: 63 68 61 72 2a 29 26 70 49 64 78 2d 3e 6b 65 79  char*)&pIdx->key
5800: 49 6e 66 6f 2c 20 50 33 5f 4b 45 59 49 4e 46 4f  Info, P3_KEYINFO
5810: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
5820: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
5830: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65  AddOp(v, OP_Inte
5840: 67 65 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  ger, 0, 0);.    
5850: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
5860: 64 64 4f 70 28 76 2c 20 4f 50 5f 4d 65 6d 53 74  ddOp(v, OP_MemSt
5870: 6f 72 65 2c 20 31 2c 20 31 29 3b 0a 20 20 20 20  ore, 1, 1);.    
5880: 20 20 20 20 6c 6f 6f 70 54 6f 70 20 3d 20 73 71      loopTop = sq
5890: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
58a0: 2c 20 4f 50 5f 52 65 77 69 6e 64 2c 20 31 2c 20  , OP_Rewind, 1, 
58b0: 30 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  0);.        sqli
58c0: 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20  te3VdbeAddOp(v, 
58d0: 4f 50 5f 4d 65 6d 49 6e 63 72 2c 20 31 2c 20 30  OP_MemIncr, 1, 0
58e0: 29 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 6a  );.        for(j
58f0: 3d 30 2c 20 70 49 64 78 3d 70 54 61 62 2d 3e 70  =0, pIdx=pTab->p
5900: 49 6e 64 65 78 3b 20 70 49 64 78 3b 20 70 49 64  Index; pIdx; pId
5910: 78 3d 70 49 64 78 2d 3e 70 4e 65 78 74 2c 20 6a  x=pIdx->pNext, j
5920: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69  ++){.          i
5930: 6e 74 20 6b 2c 20 6a 6d 70 32 3b 0a 20 20 20 20  nt k, jmp2;.    
5940: 20 20 20 20 20 20 73 74 61 74 69 63 20 56 64 62        static Vdb
5950: 65 4f 70 4c 69 73 74 20 69 64 78 45 72 72 5b 5d  eOpList idxErr[]
5960: 20 3d 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20   = {.           
5970: 20 7b 20 4f 50 5f 4d 65 6d 49 6e 63 72 2c 20 20   { OP_MemIncr,  
5980: 20 20 20 30 2c 20 20 30 2c 20 20 30 7d 2c 0a 20     0,  0,  0},. 
5990: 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f             { OP_
59a0: 53 74 72 69 6e 67 2c 20 20 20 20 20 20 30 2c 20  String,      0, 
59b0: 20 30 2c 20 20 22 72 6f 77 69 64 20 22 7d 2c 0a   0,  "rowid "},.
59c0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50              { OP
59d0: 5f 52 65 63 6e 6f 2c 20 20 20 20 20 20 20 31 2c  _Recno,       1,
59e0: 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20    0,  0},.      
59f0: 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e        { OP_Strin
5a00: 67 2c 20 20 20 20 20 20 30 2c 20 20 30 2c 20 20  g,      0,  0,  
5a10: 22 20 6d 69 73 73 69 6e 67 20 66 72 6f 6d 20 69  " missing from i
5a20: 6e 64 65 78 20 22 7d 2c 0a 20 20 20 20 20 20 20  ndex "},.       
5a30: 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67       { OP_String
5a40: 2c 20 20 20 20 20 20 30 2c 20 20 30 2c 20 20 30  ,      0,  0,  0
5a50: 7d 2c 20 20 20 20 2f 2a 20 34 20 2a 2f 0a 20 20  },    /* 4 */.  
5a60: 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 43            { OP_C
5a70: 6f 6e 63 61 74 2c 20 20 20 20 20 20 34 2c 20 20  oncat,      4,  
5a80: 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20  0,  0},.        
5a90: 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c 62 61 63      { OP_Callbac
5aa0: 6b 2c 20 20 20 20 31 2c 20 20 30 2c 20 20 30 7d  k,    1,  0,  0}
5ab0: 2c 0a 20 20 20 20 20 20 20 20 20 20 7d 3b 0a 20  ,.          };. 
5ac0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
5ad0: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
5ae0: 52 65 63 6e 6f 2c 20 31 2c 20 30 29 3b 0a 20 20  Recno, 1, 0);.  
5af0: 20 20 20 20 20 20 20 20 66 6f 72 28 6b 3d 30 3b          for(k=0;
5b00: 20 6b 3c 70 49 64 78 2d 3e 6e 43 6f 6c 75 6d 6e   k<pIdx->nColumn
5b10: 3b 20 6b 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  ; k++){.        
5b20: 20 20 20 20 69 6e 74 20 69 64 78 20 3d 20 70 49      int idx = pI
5b30: 64 78 2d 3e 61 69 43 6f 6c 75 6d 6e 5b 6b 5d 3b  dx->aiColumn[k];
5b40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 28  .            if(
5b50: 20 69 64 78 3d 3d 70 54 61 62 2d 3e 69 50 4b 65   idx==pTab->iPKe
5b60: 79 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  y ){.           
5b70: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
5b80: 64 4f 70 28 76 2c 20 4f 50 5f 52 65 63 6e 6f 2c  dOp(v, OP_Recno,
5b90: 20 31 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20   1, 0);.        
5ba0: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
5bb0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
5bc0: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
5bd0: 43 6f 6c 75 6d 6e 2c 20 31 2c 20 69 64 78 29 3b  Column, 1, idx);
5be0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20  .            }. 
5bf0: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20           }.     
5c00: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
5c10: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 4d 61 6b 65  AddOp(v, OP_Make
5c20: 49 64 78 4b 65 79 2c 20 70 49 64 78 2d 3e 6e 43  IdxKey, pIdx->nC
5c30: 6f 6c 75 6d 6e 2c 20 30 29 3b 0a 20 20 20 20 20  olumn, 0);.     
5c40: 20 20 20 20 20 73 71 6c 69 74 65 33 49 6e 64 65       sqlite3Inde
5c50: 78 41 66 66 69 6e 69 74 79 53 74 72 28 76 2c 20  xAffinityStr(v, 
5c60: 70 49 64 78 29 3b 0a 20 20 20 20 20 20 20 20 20  pIdx);.         
5c70: 20 6a 6d 70 32 20 3d 20 73 71 6c 69 74 65 33 56   jmp2 = sqlite3V
5c80: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 46  dbeAddOp(v, OP_F
5c90: 6f 75 6e 64 2c 20 6a 2b 32 2c 20 30 29 3b 0a 20  ound, j+2, 0);. 
5ca0: 20 20 20 20 20 20 20 20 20 61 64 64 72 20 3d 20           addr = 
5cb0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
5cc0: 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53 69 7a  List(v, ArraySiz
5cd0: 65 28 69 64 78 45 72 72 29 2c 20 69 64 78 45 72  e(idxErr), idxEr
5ce0: 72 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71  r);.          sq
5cf0: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
5d00: 33 28 76 2c 20 61 64 64 72 2b 34 2c 20 70 49 64  3(v, addr+4, pId
5d10: 78 2d 3e 7a 4e 61 6d 65 2c 20 50 33 5f 53 54 41  x->zName, P3_STA
5d20: 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 20 20  TIC);.          
5d30: 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67  sqlite3VdbeChang
5d40: 65 50 32 28 76 2c 20 6a 6d 70 32 2c 20 73 71 6c  eP2(v, jmp2, sql
5d50: 69 74 65 33 56 64 62 65 43 75 72 72 65 6e 74 41  ite3VdbeCurrentA
5d60: 64 64 72 28 76 29 29 3b 0a 20 20 20 20 20 20 20  ddr(v));.       
5d70: 20 7d 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74   }.        sqlit
5d80: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
5d90: 50 5f 4e 65 78 74 2c 20 31 2c 20 6c 6f 6f 70 54  P_Next, 1, loopT
5da0: 6f 70 2b 31 29 3b 0a 20 20 20 20 20 20 20 20 73  op+1);.        s
5db0: 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65  qlite3VdbeChange
5dc0: 50 32 28 76 2c 20 6c 6f 6f 70 54 6f 70 2c 20 73  P2(v, loopTop, s
5dd0: 71 6c 69 74 65 33 56 64 62 65 43 75 72 72 65 6e  qlite3VdbeCurren
5de0: 74 41 64 64 72 28 76 29 29 3b 0a 20 20 20 20 20  tAddr(v));.     
5df0: 20 20 20 66 6f 72 28 6a 3d 30 2c 20 70 49 64 78     for(j=0, pIdx
5e00: 3d 70 54 61 62 2d 3e 70 49 6e 64 65 78 3b 20 70  =pTab->pIndex; p
5e10: 49 64 78 3b 20 70 49 64 78 3d 70 49 64 78 2d 3e  Idx; pIdx=pIdx->
5e20: 70 4e 65 78 74 2c 20 6a 2b 2b 29 7b 0a 20 20 20  pNext, j++){.   
5e30: 20 20 20 20 20 20 20 73 74 61 74 69 63 20 56 64         static Vd
5e40: 62 65 4f 70 4c 69 73 74 20 63 6e 74 49 64 78 5b  beOpList cntIdx[
5e50: 5d 20 3d 20 7b 0a 20 20 20 20 20 20 20 20 20 20  ] = {.          
5e60: 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67 65 72 2c     { OP_Integer,
5e70: 20 20 20 20 20 20 30 2c 20 20 30 2c 20 20 30 7d        0,  0,  0}
5e80: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  ,.             {
5e90: 20 4f 50 5f 4d 65 6d 53 74 6f 72 65 2c 20 20 20   OP_MemStore,   
5ea0: 20 20 32 2c 20 20 31 2c 20 20 30 7d 2c 0a 20 20    2,  1,  0},.  
5eb0: 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f             { OP_
5ec0: 52 65 77 69 6e 64 2c 20 20 20 20 20 20 20 30 2c  Rewind,       0,
5ed0: 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a 20 32 20    0,  0},  /* 2 
5ee0: 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  */.             
5ef0: 7b 20 4f 50 5f 4d 65 6d 49 6e 63 72 2c 20 20 20  { OP_MemIncr,   
5f00: 20 20 20 32 2c 20 20 30 2c 20 20 30 7d 2c 0a 20     2,  0,  0},. 
5f10: 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50              { OP
5f20: 5f 4e 65 78 74 2c 20 20 20 20 20 20 20 20 20 30  _Next,         0
5f30: 2c 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a 20 34  ,  0,  0},  /* 4
5f40: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20   */.            
5f50: 20 7b 20 4f 50 5f 4d 65 6d 4c 6f 61 64 2c 20 20   { OP_MemLoad,  
5f60: 20 20 20 20 31 2c 20 20 30 2c 20 20 30 7d 2c 0a      1,  0,  0},.
5f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f               { O
5f80: 50 5f 4d 65 6d 4c 6f 61 64 2c 20 20 20 20 20 20  P_MemLoad,      
5f90: 32 2c 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20  2,  0,  0},.    
5fa0: 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 45 71           { OP_Eq
5fb0: 2c 20 20 20 20 20 20 20 20 20 20 20 30 2c 20 20  ,           0,  
5fc0: 30 2c 20 20 30 7d 2c 20 20 2f 2a 20 37 20 2a 2f  0,  0},  /* 7 */
5fd0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20  .             { 
5fe0: 4f 50 5f 4d 65 6d 49 6e 63 72 2c 20 20 20 20 20  OP_MemIncr,     
5ff0: 20 30 2c 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20   0,  0,  0},.   
6000: 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 53            { OP_S
6010: 74 72 69 6e 67 2c 20 20 20 20 20 20 20 30 2c 20  tring,       0, 
6020: 20 30 2c 20 20 22 77 72 6f 6e 67 20 23 20 6f 66   0,  "wrong # of
6030: 20 65 6e 74 72 69 65 73 20 69 6e 20 69 6e 64 65   entries in inde
6040: 78 20 22 7d 2c 0a 20 20 20 20 20 20 20 20 20 20  x "},.          
6050: 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67 2c 20     { OP_String, 
6060: 20 20 20 20 20 20 30 2c 20 20 30 2c 20 20 30 7d        0,  0,  0}
6070: 2c 20 20 2f 2a 20 31 30 20 2a 2f 0a 20 20 20 20  ,  /* 10 */.    
6080: 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f           { OP_Co
6090: 6e 63 61 74 2c 20 20 20 20 20 20 20 32 2c 20 20  ncat,       2,  
60a0: 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20  0,  0},.        
60b0: 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c 62 61       { OP_Callba
60c0: 63 6b 2c 20 20 20 20 20 31 2c 20 20 30 2c 20 20  ck,     1,  0,  
60d0: 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 7d 3b  0},.          };
60e0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20 70  .          if( p
60f0: 49 64 78 2d 3e 74 6e 75 6d 3d 3d 30 20 29 20 63  Idx->tnum==0 ) c
6100: 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20  ontinue;.       
6110: 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65     addr = sqlite
6120: 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76  3VdbeAddOpList(v
6130: 2c 20 41 72 72 61 79 53 69 7a 65 28 63 6e 74 49  , ArraySize(cntI
6140: 64 78 29 2c 20 63 6e 74 49 64 78 29 3b 0a 20 20  dx), cntIdx);.  
6150: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
6160: 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20 61  dbeChangeP1(v, a
6170: 64 64 72 2b 32 2c 20 6a 2b 32 29 3b 0a 20 20 20  ddr+2, j+2);.   
6180: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
6190: 62 65 43 68 61 6e 67 65 50 32 28 76 2c 20 61 64  beChangeP2(v, ad
61a0: 64 72 2b 32 2c 20 61 64 64 72 2b 35 29 3b 0a 20  dr+2, addr+5);. 
61b0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
61c0: 56 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20  VdbeChangeP1(v, 
61d0: 61 64 64 72 2b 34 2c 20 6a 2b 32 29 3b 0a 20 20  addr+4, j+2);.  
61e0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
61f0: 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c 20 61  dbeChangeP2(v, a
6200: 64 64 72 2b 34 2c 20 61 64 64 72 2b 33 29 3b 0a  ddr+4, addr+3);.
6210: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
6220: 33 56 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c  3VdbeChangeP2(v,
6230: 20 61 64 64 72 2b 37 2c 20 61 64 64 72 2b 41 72   addr+7, addr+Ar
6240: 72 61 79 53 69 7a 65 28 63 6e 74 49 64 78 29 29  raySize(cntIdx))
6250: 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  ;.          sqli
6260: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 33 28  te3VdbeChangeP3(
6270: 76 2c 20 61 64 64 72 2b 31 30 2c 20 70 49 64 78  v, addr+10, pIdx
6280: 2d 3e 7a 4e 61 6d 65 2c 20 50 33 5f 53 54 41 54  ->zName, P3_STAT
6290: 49 43 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  IC);.        }. 
62a0: 20 20 20 20 20 7d 20 0a 20 20 20 20 7d 0a 20 20       } .    }.  
62b0: 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33    addr = sqlite3
62c0: 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c  VdbeAddOpList(v,
62d0: 20 41 72 72 61 79 53 69 7a 65 28 65 6e 64 43 6f   ArraySize(endCo
62e0: 64 65 29 2c 20 65 6e 64 43 6f 64 65 29 3b 0a 20  de), endCode);. 
62f0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68     sqlite3VdbeCh
6300: 61 6e 67 65 50 32 28 76 2c 20 61 64 64 72 2b 32  angeP2(v, addr+2
6310: 2c 20 61 64 64 72 2b 41 72 72 61 79 53 69 7a 65  , addr+ArraySize
6320: 28 65 6e 64 43 6f 64 65 29 29 3b 0a 20 20 7d 65  (endCode));.  }e
6330: 6c 73 65 0a 0a 20 20 7b 7d 0a 20 20 73 71 6c 69  lse..  {}.  sqli
6340: 74 65 46 72 65 65 28 7a 4c 65 66 74 29 3b 0a 20  teFree(zLeft);. 
6350: 20 73 71 6c 69 74 65 46 72 65 65 28 7a 52 69 67   sqliteFree(zRig
6360: 68 74 29 3b 0a 7d 0a                             ht);.}.