/ Hex Artifact Content
Login

Artifact 9cb8b94e7d38ba35a86037bd517d07ba9870b4b2:


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 31 33 30 20 32  agma.c,v 1.130 2
01d0: 30 30 37 2f 30 33 2f 32 34 20 31 36 3a 34 35 3a  007/03/24 16:45:
01e0: 30 35 20 64 61 6e 69 65 6c 6b 31 39 37 37 20 45  05 danielk1977 E
01f0: 78 70 20 24 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65  xp $.*/.#include
0200: 20 22 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a 23   "sqliteInt.h".#
0210: 69 6e 63 6c 75 64 65 20 22 6f 73 2e 68 22 0a 23  include "os.h".#
0220: 69 6e 63 6c 75 64 65 20 3c 63 74 79 70 65 2e 68  include <ctype.h
0230: 3e 0a 0a 2f 2a 20 49 67 6e 6f 72 65 20 74 68 69  >../* Ignore thi
0240: 73 20 77 68 6f 6c 65 20 66 69 6c 65 20 69 66 20  s whole file if 
0250: 70 72 61 67 6d 61 73 20 61 72 65 20 64 69 73 61  pragmas are disa
0260: 62 6c 65 64 0a 2a 2f 0a 23 69 66 20 21 64 65 66  bled.*/.#if !def
0270: 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54  ined(SQLITE_OMIT
0280: 5f 50 52 41 47 4d 41 29 20 26 26 20 21 64 65 66  _PRAGMA) && !def
0290: 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54  ined(SQLITE_OMIT
02a0: 5f 50 41 52 53 45 52 29 0a 0a 23 69 66 20 64 65  _PARSER)..#if de
02b0: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 44 45 42  fined(SQLITE_DEB
02c0: 55 47 29 20 7c 7c 20 64 65 66 69 6e 65 64 28 53  UG) || defined(S
02d0: 51 4c 49 54 45 5f 54 45 53 54 29 0a 23 20 69 6e  QLITE_TEST).# in
02e0: 63 6c 75 64 65 20 22 70 61 67 65 72 2e 68 22 0a  clude "pager.h".
02f0: 23 20 69 6e 63 6c 75 64 65 20 22 62 74 72 65 65  # include "btree
0300: 2e 68 22 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a  .h".#endif../*.*
0310: 2a 20 49 6e 74 65 72 70 72 65 74 20 74 68 65 20  * Interpret the 
0320: 67 69 76 65 6e 20 73 74 72 69 6e 67 20 61 73 20  given string as 
0330: 61 20 73 61 66 65 74 79 20 6c 65 76 65 6c 2e 20  a safety level. 
0340: 20 52 65 74 75 72 6e 20 30 20 66 6f 72 20 4f 46   Return 0 for OF
0350: 46 2c 0a 2a 2a 20 31 20 66 6f 72 20 4f 4e 20 6f  F,.** 1 for ON o
0360: 72 20 4e 4f 52 4d 41 4c 20 61 6e 64 20 32 20 66  r NORMAL and 2 f
0370: 6f 72 20 46 55 4c 4c 2e 20 20 52 65 74 75 72 6e  or FULL.  Return
0380: 20 31 20 66 6f 72 20 61 6e 20 65 6d 70 74 79 20   1 for an empty 
0390: 6f 72 20 0a 2a 2a 20 75 6e 72 65 63 6f 67 6e 69  or .** unrecogni
03a0: 7a 65 64 20 73 74 72 69 6e 67 20 61 72 67 75 6d  zed string argum
03b0: 65 6e 74 2e 0a 2a 2a 0a 2a 2a 20 4e 6f 74 65 20  ent..**.** Note 
03c0: 74 68 61 74 20 74 68 65 20 76 61 6c 75 65 73 20  that the values 
03d0: 72 65 74 75 72 6e 65 64 20 61 72 65 20 6f 6e 65  returned are one
03e0: 20 6c 65 73 73 20 74 68 61 74 20 74 68 65 20 76   less that the v
03f0: 61 6c 75 65 73 20 74 68 61 74 0a 2a 2a 20 73 68  alues that.** sh
0400: 6f 75 6c 64 20 62 65 20 70 61 73 73 65 64 20 69  ould be passed i
0410: 6e 74 6f 20 73 71 6c 69 74 65 33 42 74 72 65 65  nto sqlite3Btree
0420: 53 65 74 53 61 66 65 74 79 4c 65 76 65 6c 28 29  SetSafetyLevel()
0430: 2e 20 20 54 68 65 20 69 73 20 64 6f 6e 65 0a 2a  .  The is done.*
0440: 2a 20 74 6f 20 73 75 70 70 6f 72 74 20 6c 65 67  * to support leg
0450: 61 63 79 20 53 51 4c 20 63 6f 64 65 2e 20 20 54  acy SQL code.  T
0460: 68 65 20 73 61 66 65 74 79 20 6c 65 76 65 6c 20  he safety level 
0470: 75 73 65 64 20 74 6f 20 62 65 20 62 6f 6f 6c 65  used to be boole
0480: 61 6e 0a 2a 2a 20 61 6e 64 20 6f 6c 64 65 72 20  an.** and older 
0490: 73 63 72 69 70 74 73 20 6d 61 79 20 68 61 76 65  scripts may have
04a0: 20 75 73 65 64 20 6e 75 6d 62 65 72 73 20 30 20   used numbers 0 
04b0: 66 6f 72 20 4f 46 46 20 61 6e 64 20 31 20 66 6f  for OFF and 1 fo
04c0: 72 20 4f 4e 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  r ON..*/.static 
04d0: 69 6e 74 20 67 65 74 53 61 66 65 74 79 4c 65 76  int getSafetyLev
04e0: 65 6c 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  el(const char *z
04f0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ){.             
0500: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0510: 2f 2a 20 31 32 33 34 35 36 37 38 39 20 31 32 33  /* 123456789 123
0520: 34 35 36 37 38 39 20 2a 2f 0a 20 20 73 74 61 74  456789 */.  stat
0530: 69 63 20 63 6f 6e 73 74 20 63 68 61 72 20 7a 54  ic const char zT
0540: 65 78 74 5b 5d 20 3d 20 22 6f 6e 6f 66 66 61 6c  ext[] = "onoffal
0550: 73 65 79 65 73 74 72 75 65 66 75 6c 6c 22 3b 0a  seyestruefull";.
0560: 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20 75    static const u
0570: 38 20 69 4f 66 66 73 65 74 5b 5d 20 3d 20 7b 30  8 iOffset[] = {0
0580: 2c 20 31 2c 20 32 2c 20 34 2c 20 39 2c 20 31 32  , 1, 2, 4, 9, 12
0590: 2c 20 31 36 7d 3b 0a 20 20 73 74 61 74 69 63 20  , 16};.  static 
05a0: 63 6f 6e 73 74 20 75 38 20 69 4c 65 6e 67 74 68  const u8 iLength
05b0: 5b 5d 20 3d 20 7b 32 2c 20 32 2c 20 33 2c 20 35  [] = {2, 2, 3, 5
05c0: 2c 20 33 2c 20 34 2c 20 34 7d 3b 0a 20 20 73 74  , 3, 4, 4};.  st
05d0: 61 74 69 63 20 63 6f 6e 73 74 20 75 38 20 69 56  atic const u8 iV
05e0: 61 6c 75 65 5b 5d 20 3d 20 20 7b 31 2c 20 30 2c  alue[] =  {1, 0,
05f0: 20 30 2c 20 30 2c 20 31 2c 20 31 2c 20 32 7d 3b   0, 0, 1, 1, 2};
0600: 0a 20 20 69 6e 74 20 69 2c 20 6e 3b 0a 20 20 69  .  int i, n;.  i
0610: 66 28 20 69 73 64 69 67 69 74 28 2a 7a 29 20 29  f( isdigit(*z) )
0620: 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 61 74 6f  {.    return ato
0630: 69 28 7a 29 3b 0a 20 20 7d 0a 20 20 6e 20 3d 20  i(z);.  }.  n = 
0640: 73 74 72 6c 65 6e 28 7a 29 3b 0a 20 20 66 6f 72  strlen(z);.  for
0650: 28 69 3d 30 3b 20 69 3c 73 69 7a 65 6f 66 28 69  (i=0; i<sizeof(i
0660: 4c 65 6e 67 74 68 29 3b 20 69 2b 2b 29 7b 0a 20  Length); i++){. 
0670: 20 20 20 69 66 28 20 69 4c 65 6e 67 74 68 5b 69     if( iLength[i
0680: 5d 3d 3d 6e 20 26 26 20 73 71 6c 69 74 65 33 53  ]==n && sqlite3S
0690: 74 72 4e 49 43 6d 70 28 26 7a 54 65 78 74 5b 69  trNICmp(&zText[i
06a0: 4f 66 66 73 65 74 5b 69 5d 5d 2c 7a 2c 6e 29 3d  Offset[i]],z,n)=
06b0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 72 65 74 75  =0 ){.      retu
06c0: 72 6e 20 69 56 61 6c 75 65 5b 69 5d 3b 0a 20 20  rn iValue[i];.  
06d0: 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e    }.  }.  return
06e0: 20 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74   1;.}../*.** Int
06f0: 65 72 70 72 65 74 20 74 68 65 20 67 69 76 65 6e  erpret the given
0700: 20 73 74 72 69 6e 67 20 61 73 20 61 20 62 6f 6f   string as a boo
0710: 6c 65 61 6e 20 76 61 6c 75 65 2e 0a 2a 2f 0a 73  lean value..*/.s
0720: 74 61 74 69 63 20 69 6e 74 20 67 65 74 42 6f 6f  tatic int getBoo
0730: 6c 65 61 6e 28 63 6f 6e 73 74 20 63 68 61 72 20  lean(const char 
0740: 2a 7a 29 7b 0a 20 20 72 65 74 75 72 6e 20 67 65  *z){.  return ge
0750: 74 53 61 66 65 74 79 4c 65 76 65 6c 28 7a 29 26  tSafetyLevel(z)&
0760: 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74 65  1;.}../*.** Inte
0770: 72 70 72 65 74 20 74 68 65 20 67 69 76 65 6e 20  rpret the given 
0780: 73 74 72 69 6e 67 20 61 73 20 61 20 6c 6f 63 6b  string as a lock
0790: 69 6e 67 20 6d 6f 64 65 20 76 61 6c 75 65 2e 0a  ing mode value..
07a0: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 67 65  */.static int ge
07b0: 74 4c 6f 63 6b 69 6e 67 4d 6f 64 65 28 63 6f 6e  tLockingMode(con
07c0: 73 74 20 63 68 61 72 20 2a 7a 29 7b 0a 20 20 69  st char *z){.  i
07d0: 66 28 20 7a 20 29 7b 0a 20 20 20 20 69 66 28 20  f( z ){.    if( 
07e0: 30 3d 3d 73 71 6c 69 74 65 33 53 74 72 49 43 6d  0==sqlite3StrICm
07f0: 70 28 7a 2c 20 22 65 78 63 6c 75 73 69 76 65 22  p(z, "exclusive"
0800: 29 20 29 20 72 65 74 75 72 6e 20 50 41 47 45 52  ) ) return PAGER
0810: 5f 4c 4f 43 4b 49 4e 47 4d 4f 44 45 5f 45 58 43  _LOCKINGMODE_EXC
0820: 4c 55 53 49 56 45 3b 0a 20 20 20 20 69 66 28 20  LUSIVE;.    if( 
0830: 30 3d 3d 73 71 6c 69 74 65 33 53 74 72 49 43 6d  0==sqlite3StrICm
0840: 70 28 7a 2c 20 22 6e 6f 72 6d 61 6c 22 29 20 29  p(z, "normal") )
0850: 20 72 65 74 75 72 6e 20 50 41 47 45 52 5f 4c 4f   return PAGER_LO
0860: 43 4b 49 4e 47 4d 4f 44 45 5f 4e 4f 52 4d 41 4c  CKINGMODE_NORMAL
0870: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 50  ;.  }.  return P
0880: 41 47 45 52 5f 4c 4f 43 4b 49 4e 47 4d 4f 44 45  AGER_LOCKINGMODE
0890: 5f 51 55 45 52 59 3b 0a 7d 0a 0a 23 69 66 6e 64  _QUERY;.}..#ifnd
08a0: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50  ef SQLITE_OMIT_P
08b0: 41 47 45 52 5f 50 52 41 47 4d 41 53 0a 2f 2a 0a  AGER_PRAGMAS./*.
08c0: 2a 2a 20 49 6e 74 65 72 70 72 65 74 20 74 68 65  ** Interpret the
08d0: 20 67 69 76 65 6e 20 73 74 72 69 6e 67 20 61 73   given string as
08e0: 20 61 20 74 65 6d 70 20 64 62 20 6c 6f 63 61 74   a temp db locat
08f0: 69 6f 6e 2e 20 52 65 74 75 72 6e 20 31 20 66 6f  ion. Return 1 fo
0900: 72 20 66 69 6c 65 0a 2a 2a 20 62 61 63 6b 65 64  r file.** backed
0910: 20 74 65 6d 70 6f 72 61 72 79 20 64 61 74 61 62   temporary datab
0920: 61 73 65 73 2c 20 32 20 66 6f 72 20 74 68 65 20  ases, 2 for the 
0930: 52 65 64 2d 42 6c 61 63 6b 20 74 72 65 65 20 69  Red-Black tree i
0940: 6e 20 6d 65 6d 6f 72 79 20 64 61 74 61 62 61 73  n memory databas
0950: 65 0a 2a 2a 20 61 6e 64 20 30 20 74 6f 20 75 73  e.** and 0 to us
0960: 65 20 74 68 65 20 63 6f 6d 70 69 6c 65 2d 74 69  e the compile-ti
0970: 6d 65 20 64 65 66 61 75 6c 74 2e 0a 2a 2f 0a 73  me default..*/.s
0980: 74 61 74 69 63 20 69 6e 74 20 67 65 74 54 65 6d  tatic int getTem
0990: 70 53 74 6f 72 65 28 63 6f 6e 73 74 20 63 68 61  pStore(const cha
09a0: 72 20 2a 7a 29 7b 0a 20 20 69 66 28 20 7a 5b 30  r *z){.  if( z[0
09b0: 5d 3e 3d 27 30 27 20 26 26 20 7a 5b 30 5d 3c 3d  ]>='0' && z[0]<=
09c0: 27 32 27 20 29 7b 0a 20 20 20 20 72 65 74 75 72  '2' ){.    retur
09d0: 6e 20 7a 5b 30 5d 20 2d 20 27 30 27 3b 0a 20 20  n z[0] - '0';.  
09e0: 7d 65 6c 73 65 20 69 66 28 20 73 71 6c 69 74 65  }else if( sqlite
09f0: 33 53 74 72 49 43 6d 70 28 7a 2c 20 22 66 69 6c  3StrICmp(z, "fil
0a00: 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65  e")==0 ){.    re
0a10: 74 75 72 6e 20 31 3b 0a 20 20 7d 65 6c 73 65 20  turn 1;.  }else 
0a20: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
0a30: 6d 70 28 7a 2c 20 22 6d 65 6d 6f 72 79 22 29 3d  mp(z, "memory")=
0a40: 3d 30 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e  =0 ){.    return
0a50: 20 32 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20   2;.  }else{.   
0a60: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 7d   return 0;.  }.}
0a70: 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54  .#endif /* SQLIT
0a80: 45 5f 50 41 47 45 52 5f 50 52 41 47 4d 41 53 20  E_PAGER_PRAGMAS 
0a90: 2a 2f 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  */..#ifndef SQLI
0aa0: 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52  TE_OMIT_PAGER_PR
0ab0: 41 47 4d 41 53 0a 2f 2a 0a 2a 2a 20 49 6e 76 61  AGMAS./*.** Inva
0ac0: 6c 69 64 61 74 65 20 74 65 6d 70 20 73 74 6f 72  lidate temp stor
0ad0: 61 67 65 2c 20 65 69 74 68 65 72 20 77 68 65 6e  age, either when
0ae0: 20 74 68 65 20 74 65 6d 70 20 73 74 6f 72 61 67   the temp storag
0af0: 65 20 69 73 20 63 68 61 6e 67 65 64 0a 2a 2a 20  e is changed.** 
0b00: 66 72 6f 6d 20 64 65 66 61 75 6c 74 2c 20 6f 72  from default, or
0b10: 20 77 68 65 6e 20 27 66 69 6c 65 27 20 61 6e 64   when 'file' and
0b20: 20 74 68 65 20 74 65 6d 70 5f 73 74 6f 72 65 5f   the temp_store_
0b30: 64 69 72 65 63 74 6f 72 79 20 68 61 73 20 63 68  directory has ch
0b40: 61 6e 67 65 64 0a 2a 2f 0a 73 74 61 74 69 63 20  anged.*/.static 
0b50: 69 6e 74 20 69 6e 76 61 6c 69 64 61 74 65 54 65  int invalidateTe
0b60: 6d 70 53 74 6f 72 61 67 65 28 50 61 72 73 65 20  mpStorage(Parse 
0b70: 2a 70 50 61 72 73 65 29 7b 0a 20 20 73 71 6c 69  *pParse){.  sqli
0b80: 74 65 33 20 2a 64 62 20 3d 20 70 50 61 72 73 65  te3 *db = pParse
0b90: 2d 3e 64 62 3b 0a 20 20 69 66 28 20 64 62 2d 3e  ->db;.  if( db->
0ba0: 61 44 62 5b 31 5d 2e 70 42 74 21 3d 30 20 29 7b  aDb[1].pBt!=0 ){
0bb0: 0a 20 20 20 20 69 66 28 20 64 62 2d 3e 66 6c 61  .    if( db->fla
0bc0: 67 73 20 26 20 53 51 4c 49 54 45 5f 49 6e 54 72  gs & SQLITE_InTr
0bd0: 61 6e 73 20 29 7b 0a 20 20 20 20 20 20 73 71 6c  ans ){.      sql
0be0: 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61  ite3ErrorMsg(pPa
0bf0: 72 73 65 2c 20 22 74 65 6d 70 6f 72 61 72 79 20  rse, "temporary 
0c00: 73 74 6f 72 61 67 65 20 63 61 6e 6e 6f 74 20 62  storage cannot b
0c10: 65 20 63 68 61 6e 67 65 64 20 22 0a 20 20 20 20  e changed ".    
0c20: 20 20 20 20 22 66 72 6f 6d 20 77 69 74 68 69 6e      "from within
0c30: 20 61 20 74 72 61 6e 73 61 63 74 69 6f 6e 22 29   a transaction")
0c40: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 53  ;.      return S
0c50: 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20 20 20  QLITE_ERROR;.   
0c60: 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 42 74   }.    sqlite3Bt
0c70: 72 65 65 43 6c 6f 73 65 28 64 62 2d 3e 61 44 62  reeClose(db->aDb
0c80: 5b 31 5d 2e 70 42 74 29 3b 0a 20 20 20 20 64 62  [1].pBt);.    db
0c90: 2d 3e 61 44 62 5b 31 5d 2e 70 42 74 20 3d 20 30  ->aDb[1].pBt = 0
0ca0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 52 65 73  ;.    sqlite3Res
0cb0: 65 74 49 6e 74 65 72 6e 61 6c 53 63 68 65 6d 61  etInternalSchema
0cc0: 28 64 62 2c 20 30 29 3b 0a 20 20 7d 0a 20 20 72  (db, 0);.  }.  r
0cd0: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b  eturn SQLITE_OK;
0ce0: 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c  .}.#endif /* SQL
0cf0: 49 54 45 5f 50 41 47 45 52 5f 50 52 41 47 4d 41  ITE_PAGER_PRAGMA
0d00: 53 20 2a 2f 0a 0a 23 69 66 6e 64 65 66 20 53 51  S */..#ifndef SQ
0d10: 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52 5f  LITE_OMIT_PAGER_
0d20: 50 52 41 47 4d 41 53 0a 2f 2a 0a 2a 2a 20 49 66  PRAGMAS./*.** If
0d30: 20 74 68 65 20 54 45 4d 50 20 64 61 74 61 62 61   the TEMP databa
0d40: 73 65 20 69 73 20 6f 70 65 6e 2c 20 63 6c 6f 73  se is open, clos
0d50: 65 20 69 74 20 61 6e 64 20 6d 61 72 6b 20 74 68  e it and mark th
0d60: 65 20 64 61 74 61 62 61 73 65 20 73 63 68 65 6d  e database schem
0d70: 61 0a 2a 2a 20 61 73 20 6e 65 65 64 69 6e 67 20  a.** as needing 
0d80: 72 65 6c 6f 61 64 69 6e 67 2e 20 20 54 68 69 73  reloading.  This
0d90: 20 6d 75 73 74 20 62 65 20 64 6f 6e 65 20 77 68   must be done wh
0da0: 65 6e 20 75 73 69 6e 67 20 74 68 65 20 54 45 4d  en using the TEM
0db0: 50 5f 53 54 4f 52 45 0a 2a 2a 20 6f 72 20 44 45  P_STORE.** or DE
0dc0: 46 41 55 4c 54 5f 54 45 4d 50 5f 53 54 4f 52 45  FAULT_TEMP_STORE
0dd0: 20 70 72 61 67 6d 61 73 2e 0a 2a 2f 0a 73 74 61   pragmas..*/.sta
0de0: 74 69 63 20 69 6e 74 20 63 68 61 6e 67 65 54 65  tic int changeTe
0df0: 6d 70 53 74 6f 72 61 67 65 28 50 61 72 73 65 20  mpStorage(Parse 
0e00: 2a 70 50 61 72 73 65 2c 20 63 6f 6e 73 74 20 63  *pParse, const c
0e10: 68 61 72 20 2a 7a 53 74 6f 72 61 67 65 54 79 70  har *zStorageTyp
0e20: 65 29 7b 0a 20 20 69 6e 74 20 74 73 20 3d 20 67  e){.  int ts = g
0e30: 65 74 54 65 6d 70 53 74 6f 72 65 28 7a 53 74 6f  etTempStore(zSto
0e40: 72 61 67 65 54 79 70 65 29 3b 0a 20 20 73 71 6c  rageType);.  sql
0e50: 69 74 65 33 20 2a 64 62 20 3d 20 70 50 61 72 73  ite3 *db = pPars
0e60: 65 2d 3e 64 62 3b 0a 20 20 69 66 28 20 64 62 2d  e->db;.  if( db-
0e70: 3e 74 65 6d 70 5f 73 74 6f 72 65 3d 3d 74 73 20  >temp_store==ts 
0e80: 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f  ) return SQLITE_
0e90: 4f 4b 3b 0a 20 20 69 66 28 20 69 6e 76 61 6c 69  OK;.  if( invali
0ea0: 64 61 74 65 54 65 6d 70 53 74 6f 72 61 67 65 28  dateTempStorage(
0eb0: 20 70 50 61 72 73 65 20 29 20 21 3d 20 53 51 4c   pParse ) != SQL
0ec0: 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 72 65  ITE_OK ){.    re
0ed0: 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f  turn SQLITE_ERRO
0ee0: 52 3b 0a 20 20 7d 0a 20 20 64 62 2d 3e 74 65 6d  R;.  }.  db->tem
0ef0: 70 5f 73 74 6f 72 65 20 3d 20 74 73 3b 0a 20 20  p_store = ts;.  
0f00: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
0f10: 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51  ;.}.#endif /* SQ
0f20: 4c 49 54 45 5f 50 41 47 45 52 5f 50 52 41 47 4d  LITE_PAGER_PRAGM
0f30: 41 53 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e  AS */../*.** Gen
0f40: 65 72 61 74 65 20 63 6f 64 65 20 74 6f 20 72 65  erate code to re
0f50: 74 75 72 6e 20 61 20 73 69 6e 67 6c 65 20 69 6e  turn a single in
0f60: 74 65 67 65 72 20 76 61 6c 75 65 2e 0a 2a 2f 0a  teger value..*/.
0f70: 73 74 61 74 69 63 20 76 6f 69 64 20 72 65 74 75  static void retu
0f80: 72 6e 53 69 6e 67 6c 65 49 6e 74 28 50 61 72 73  rnSingleInt(Pars
0f90: 65 20 2a 70 50 61 72 73 65 2c 20 63 6f 6e 73 74  e *pParse, const
0fa0: 20 63 68 61 72 20 2a 7a 4c 61 62 65 6c 2c 20 69   char *zLabel, i
0fb0: 6e 74 20 76 61 6c 75 65 29 7b 0a 20 20 56 64 62  nt value){.  Vdb
0fc0: 65 20 2a 76 20 3d 20 73 71 6c 69 74 65 33 47 65  e *v = sqlite3Ge
0fd0: 74 56 64 62 65 28 70 50 61 72 73 65 29 3b 0a 20  tVdbe(pParse);. 
0fe0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
0ff0: 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  p(v, OP_Integer,
1000: 20 76 61 6c 75 65 2c 20 30 29 3b 0a 20 20 69 66   value, 0);.  if
1010: 28 20 70 50 61 72 73 65 2d 3e 65 78 70 6c 61 69  ( pParse->explai
1020: 6e 3d 3d 30 20 29 7b 0a 20 20 20 20 73 71 6c 69  n==0 ){.    sqli
1030: 74 65 33 56 64 62 65 53 65 74 4e 75 6d 43 6f 6c  te3VdbeSetNumCol
1040: 73 28 76 2c 20 31 29 3b 0a 20 20 20 20 73 71 6c  s(v, 1);.    sql
1050: 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61  ite3VdbeSetColNa
1060: 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45  me(v, 0, COLNAME
1070: 5f 4e 41 4d 45 2c 20 7a 4c 61 62 65 6c 2c 20 50  _NAME, zLabel, P
1080: 33 5f 53 54 41 54 49 43 29 3b 0a 20 20 7d 0a 20  3_STATIC);.  }. 
1090: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
10a0: 70 28 76 2c 20 4f 50 5f 43 61 6c 6c 62 61 63 6b  p(v, OP_Callback
10b0: 2c 20 31 2c 20 30 29 3b 0a 7d 0a 0a 23 69 66 6e  , 1, 0);.}..#ifn
10c0: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
10d0: 46 4c 41 47 5f 50 52 41 47 4d 41 53 0a 2f 2a 0a  FLAG_PRAGMAS./*.
10e0: 2a 2a 20 43 68 65 63 6b 20 74 6f 20 73 65 65 20  ** Check to see 
10f0: 69 66 20 7a 52 69 67 68 74 20 61 6e 64 20 7a 4c  if zRight and zL
1100: 65 66 74 20 72 65 66 65 72 20 74 6f 20 61 20 70  eft refer to a p
1110: 72 61 67 6d 61 20 74 68 61 74 20 71 75 65 72 69  ragma that queri
1120: 65 73 0a 2a 2a 20 6f 72 20 63 68 61 6e 67 65 73  es.** or changes
1130: 20 6f 6e 65 20 6f 66 20 74 68 65 20 66 6c 61 67   one of the flag
1140: 73 20 69 6e 20 64 62 2d 3e 66 6c 61 67 73 2e 20  s in db->flags. 
1150: 20 52 65 74 75 72 6e 20 31 20 69 66 20 73 6f 20   Return 1 if so 
1160: 61 6e 64 20 30 20 69 66 20 6e 6f 74 2e 0a 2a 2a  and 0 if not..**
1170: 20 41 6c 73 6f 2c 20 69 6d 70 6c 65 6d 65 6e 74   Also, implement
1180: 20 74 68 65 20 70 72 61 67 6d 61 2e 0a 2a 2f 0a   the pragma..*/.
1190: 73 74 61 74 69 63 20 69 6e 74 20 66 6c 61 67 50  static int flagP
11a0: 72 61 67 6d 61 28 50 61 72 73 65 20 2a 70 50 61  ragma(Parse *pPa
11b0: 72 73 65 2c 20 63 6f 6e 73 74 20 63 68 61 72 20  rse, const char 
11c0: 2a 7a 4c 65 66 74 2c 20 63 6f 6e 73 74 20 63 68  *zLeft, const ch
11d0: 61 72 20 2a 7a 52 69 67 68 74 29 7b 0a 20 20 73  ar *zRight){.  s
11e0: 74 61 74 69 63 20 63 6f 6e 73 74 20 73 74 72 75  tatic const stru
11f0: 63 74 20 73 50 72 61 67 6d 61 54 79 70 65 20 7b  ct sPragmaType {
1200: 0a 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20  .    const char 
1210: 2a 7a 4e 61 6d 65 3b 20 20 2f 2a 20 4e 61 6d 65  *zName;  /* Name
1220: 20 6f 66 20 74 68 65 20 70 72 61 67 6d 61 20 2a   of the pragma *
1230: 2f 0a 20 20 20 20 69 6e 74 20 6d 61 73 6b 3b 20  /.    int mask; 
1240: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4d 61 73            /* Mas
1250: 6b 20 66 6f 72 20 74 68 65 20 64 62 2d 3e 66 6c  k for the db->fl
1260: 61 67 73 20 76 61 6c 75 65 20 2a 2f 0a 20 20 7d  ags value */.  }
1270: 20 61 50 72 61 67 6d 61 5b 5d 20 3d 20 7b 0a 20   aPragma[] = {. 
1280: 20 20 20 7b 20 22 76 64 62 65 5f 74 72 61 63 65     { "vdbe_trace
1290: 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ",              
12a0: 20 53 51 4c 49 54 45 5f 56 64 62 65 54 72 61 63   SQLITE_VdbeTrac
12b0: 65 20 20 20 20 20 7d 2c 0a 20 20 20 20 7b 20 22  e     },.    { "
12c0: 73 71 6c 5f 74 72 61 63 65 22 2c 20 20 20 20 20  sql_trace",     
12d0: 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 49 54             SQLIT
12e0: 45 5f 53 71 6c 54 72 61 63 65 20 20 20 20 20 20  E_SqlTrace      
12f0: 7d 2c 0a 20 20 20 20 7b 20 22 76 64 62 65 5f 6c  },.    { "vdbe_l
1300: 69 73 74 69 6e 67 22 2c 20 20 20 20 20 20 20 20  isting",        
1310: 20 20 20 20 20 53 51 4c 49 54 45 5f 56 64 62 65       SQLITE_Vdbe
1320: 4c 69 73 74 69 6e 67 20 20 20 7d 2c 0a 20 20 20  Listing   },.   
1330: 20 7b 20 22 66 75 6c 6c 5f 63 6f 6c 75 6d 6e 5f   { "full_column_
1340: 6e 61 6d 65 73 22 2c 20 20 20 20 20 20 20 20 53  names",        S
1350: 51 4c 49 54 45 5f 46 75 6c 6c 43 6f 6c 4e 61 6d  QLITE_FullColNam
1360: 65 73 20 20 7d 2c 0a 20 20 20 20 7b 20 22 73 68  es  },.    { "sh
1370: 6f 72 74 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 73  ort_column_names
1380: 22 2c 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f  ",       SQLITE_
1390: 53 68 6f 72 74 43 6f 6c 4e 61 6d 65 73 20 7d 2c  ShortColNames },
13a0: 0a 20 20 20 20 7b 20 22 63 6f 75 6e 74 5f 63 68  .    { "count_ch
13b0: 61 6e 67 65 73 22 2c 20 20 20 20 20 20 20 20 20  anges",         
13c0: 20 20 20 53 51 4c 49 54 45 5f 43 6f 75 6e 74 52     SQLITE_CountR
13d0: 6f 77 73 20 20 20 20 20 7d 2c 0a 20 20 20 20 7b  ows     },.    {
13e0: 20 22 65 6d 70 74 79 5f 72 65 73 75 6c 74 5f 63   "empty_result_c
13f0: 61 6c 6c 62 61 63 6b 73 22 2c 20 20 20 53 51 4c  allbacks",   SQL
1400: 49 54 45 5f 4e 75 6c 6c 43 61 6c 6c 62 61 63 6b  ITE_NullCallback
1410: 20 20 7d 2c 0a 20 20 20 20 7b 20 22 6c 65 67 61    },.    { "lega
1420: 63 79 5f 66 69 6c 65 5f 66 6f 72 6d 61 74 22 2c  cy_file_format",
1430: 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f 4c 65         SQLITE_Le
1440: 67 61 63 79 46 69 6c 65 46 6d 74 20 7d 2c 0a 20  gacyFileFmt },. 
1450: 20 20 20 7b 20 22 66 75 6c 6c 66 73 79 6e 63 22     { "fullfsync"
1460: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
1470: 20 53 51 4c 49 54 45 5f 46 75 6c 6c 46 53 79 6e   SQLITE_FullFSyn
1480: 63 20 20 20 20 20 7d 2c 0a 23 69 66 6e 64 65 66  c     },.#ifndef
1490: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 43 48 45   SQLITE_OMIT_CHE
14a0: 43 4b 0a 20 20 20 20 7b 20 22 69 67 6e 6f 72 65  CK.    { "ignore
14b0: 5f 63 68 65 63 6b 5f 63 6f 6e 73 74 72 61 69 6e  _check_constrain
14c0: 74 73 22 2c 20 53 51 4c 49 54 45 5f 49 67 6e 6f  ts", SQLITE_Igno
14d0: 72 65 43 68 65 63 6b 73 20 20 7d 2c 0a 23 65 6e  reChecks  },.#en
14e0: 64 69 66 0a 20 20 20 20 2f 2a 20 54 68 65 20 66  dif.    /* The f
14f0: 6f 6c 6c 6f 77 69 6e 67 20 69 73 20 56 45 52 59  ollowing is VERY
1500: 20 65 78 70 65 72 69 6d 65 6e 74 61 6c 20 2a 2f   experimental */
1510: 0a 20 20 20 20 7b 20 22 77 72 69 74 61 62 6c 65  .    { "writable
1520: 5f 73 63 68 65 6d 61 22 2c 20 20 20 20 20 20 20  _schema",       
1530: 20 20 20 53 51 4c 49 54 45 5f 57 72 69 74 65 53     SQLITE_WriteS
1540: 63 68 65 6d 61 7c 53 51 4c 49 54 45 5f 52 65 63  chema|SQLITE_Rec
1550: 6f 76 65 72 79 4d 6f 64 65 20 7d 2c 0a 20 20 20  overyMode },.   
1560: 20 7b 20 22 6f 6d 69 74 5f 72 65 61 64 6c 6f 63   { "omit_readloc
1570: 6b 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 53  k",            S
1580: 51 4c 49 54 45 5f 4e 6f 52 65 61 64 6c 6f 63 6b  QLITE_NoReadlock
1590: 20 20 20 20 7d 2c 0a 0a 20 20 20 20 2f 2a 20 54      },..    /* T
15a0: 4f 44 4f 3a 20 4d 61 79 62 65 20 69 74 20 73 68  ODO: Maybe it sh
15b0: 6f 75 6c 64 6e 27 74 20 62 65 20 70 6f 73 73 69  ouldn't be possi
15c0: 62 6c 65 20 74 6f 20 63 68 61 6e 67 65 20 74 68  ble to change th
15d0: 65 20 52 65 61 64 55 6e 63 6f 6d 6d 69 74 74 65  e ReadUncommitte
15e0: 64 0a 20 20 20 20 2a 2a 20 66 6c 61 67 20 69 66  d.    ** flag if
15f0: 20 74 68 65 72 65 20 61 72 65 20 61 6e 79 20 61   there are any a
1600: 63 74 69 76 65 20 73 74 61 74 65 6d 65 6e 74 73  ctive statements
1610: 2e 20 2a 2f 0a 20 20 20 20 7b 20 22 72 65 61 64  . */.    { "read
1620: 5f 75 6e 63 6f 6d 6d 69 74 74 65 64 22 2c 20 20  _uncommitted",  
1630: 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f 52 65         SQLITE_Re
1640: 61 64 55 6e 63 6f 6d 6d 69 74 74 65 64 20 7d 2c  adUncommitted },
1650: 0a 20 20 7d 3b 0a 20 20 69 6e 74 20 69 3b 0a 20  .  };.  int i;. 
1660: 20 63 6f 6e 73 74 20 73 74 72 75 63 74 20 73 50   const struct sP
1670: 72 61 67 6d 61 54 79 70 65 20 2a 70 3b 0a 20 20  ragmaType *p;.  
1680: 66 6f 72 28 69 3d 30 2c 20 70 3d 61 50 72 61 67  for(i=0, p=aPrag
1690: 6d 61 3b 20 69 3c 73 69 7a 65 6f 66 28 61 50 72  ma; i<sizeof(aPr
16a0: 61 67 6d 61 29 2f 73 69 7a 65 6f 66 28 61 50 72  agma)/sizeof(aPr
16b0: 61 67 6d 61 5b 30 5d 29 3b 20 69 2b 2b 2c 20 70  agma[0]); i++, p
16c0: 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 73 71 6c  ++){.    if( sql
16d0: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
16e0: 74 2c 20 70 2d 3e 7a 4e 61 6d 65 29 3d 3d 30 20  t, p->zName)==0 
16f0: 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ){.      sqlite3
1700: 20 2a 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64   *db = pParse->d
1710: 62 3b 0a 20 20 20 20 20 20 56 64 62 65 20 2a 76  b;.      Vdbe *v
1720: 3b 0a 20 20 20 20 20 20 76 20 3d 20 73 71 6c 69  ;.      v = sqli
1730: 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72 73  te3GetVdbe(pPars
1740: 65 29 3b 0a 20 20 20 20 20 20 69 66 28 20 76 20  e);.      if( v 
1750: 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 7a  ){.        if( z
1760: 52 69 67 68 74 3d 3d 30 20 29 7b 0a 20 20 20 20  Right==0 ){.    
1770: 20 20 20 20 20 20 72 65 74 75 72 6e 53 69 6e 67        returnSing
1780: 6c 65 49 6e 74 28 70 50 61 72 73 65 2c 20 70 2d  leInt(pParse, p-
1790: 3e 7a 4e 61 6d 65 2c 20 28 64 62 2d 3e 66 6c 61  >zName, (db->fla
17a0: 67 73 20 26 20 70 2d 3e 6d 61 73 6b 29 21 3d 30  gs & p->mask)!=0
17b0: 20 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73   );.        }els
17c0: 65 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  e{.          if(
17d0: 20 67 65 74 42 6f 6f 6c 65 61 6e 28 7a 52 69 67   getBoolean(zRig
17e0: 68 74 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ht) ){.         
17f0: 20 20 20 64 62 2d 3e 66 6c 61 67 73 20 7c 3d 20     db->flags |= 
1800: 70 2d 3e 6d 61 73 6b 3b 0a 20 20 20 20 20 20 20  p->mask;.       
1810: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
1820: 20 20 20 20 20 20 64 62 2d 3e 66 6c 61 67 73 20        db->flags 
1830: 26 3d 20 7e 70 2d 3e 6d 61 73 6b 3b 0a 20 20 20  &= ~p->mask;.   
1840: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
1850: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20   }.      }.     
1860: 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 7d   return 1;.    }
1870: 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 30 3b  .  }.  return 0;
1880: 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c  .}.#endif /* SQL
1890: 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52  ITE_OMIT_FLAG_PR
18a0: 41 47 4d 41 53 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20  AGMAS */../*.** 
18b0: 50 72 6f 63 65 73 73 20 61 20 70 72 61 67 6d 61  Process a pragma
18c0: 20 73 74 61 74 65 6d 65 6e 74 2e 20 20 0a 2a 2a   statement.  .**
18d0: 0a 2a 2a 20 50 72 61 67 6d 61 73 20 61 72 65 20  .** Pragmas are 
18e0: 6f 66 20 74 68 69 73 20 66 6f 72 6d 3a 0a 2a 2a  of this form:.**
18f0: 0a 2a 2a 20 20 20 20 20 20 50 52 41 47 4d 41 20  .**      PRAGMA 
1900: 5b 64 61 74 61 62 61 73 65 2e 5d 69 64 20 5b 3d  [database.]id [=
1910: 20 76 61 6c 75 65 5d 0a 2a 2a 0a 2a 2a 20 54 68   value].**.** Th
1920: 65 20 69 64 65 6e 74 69 66 69 65 72 20 6d 69 67  e identifier mig
1930: 68 74 20 61 6c 73 6f 20 62 65 20 61 20 73 74 72  ht also be a str
1940: 69 6e 67 2e 20 20 54 68 65 20 76 61 6c 75 65 20  ing.  The value 
1950: 69 73 20 61 20 73 74 72 69 6e 67 2c 20 61 6e 64  is a string, and
1960: 0a 2a 2a 20 69 64 65 6e 74 69 66 69 65 72 2c 20  .** identifier, 
1970: 6f 72 20 61 20 6e 75 6d 62 65 72 2e 20 20 49 66  or a number.  If
1980: 20 6d 69 6e 75 73 46 6c 61 67 20 69 73 20 74 72   minusFlag is tr
1990: 75 65 2c 20 74 68 65 6e 20 74 68 65 20 76 61 6c  ue, then the val
19a0: 75 65 20 69 73 0a 2a 2a 20 61 20 6e 75 6d 62 65  ue is.** a numbe
19b0: 72 20 74 68 61 74 20 77 61 73 20 70 72 65 63 65  r that was prece
19c0: 64 65 64 20 62 79 20 61 20 6d 69 6e 75 73 20 73  ded by a minus s
19d0: 69 67 6e 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68  ign..**.** If th
19e0: 65 20 6c 65 66 74 20 73 69 64 65 20 69 73 20 22  e left side is "
19f0: 64 61 74 61 62 61 73 65 2e 69 64 22 20 74 68 65  database.id" the
1a00: 6e 20 70 49 64 31 20 69 73 20 74 68 65 20 64 61  n pId1 is the da
1a10: 74 61 62 61 73 65 20 6e 61 6d 65 0a 2a 2a 20 61  tabase name.** a
1a20: 6e 64 20 70 49 64 32 20 69 73 20 74 68 65 20 69  nd pId2 is the i
1a30: 64 2e 20 20 49 66 20 74 68 65 20 6c 65 66 74 20  d.  If the left 
1a40: 73 69 64 65 20 69 73 20 6a 75 73 74 20 22 69 64  side is just "id
1a50: 22 20 74 68 65 6e 20 70 49 64 31 20 69 73 20 74  " then pId1 is t
1a60: 68 65 0a 2a 2a 20 69 64 20 61 6e 64 20 70 49 64  he.** id and pId
1a70: 32 20 69 73 20 61 6e 79 20 65 6d 70 74 79 20 73  2 is any empty s
1a80: 74 72 69 6e 67 2e 0a 2a 2f 0a 76 6f 69 64 20 73  tring..*/.void s
1a90: 71 6c 69 74 65 33 50 72 61 67 6d 61 28 0a 20 20  qlite3Pragma(.  
1aa0: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 0a  Parse *pParse, .
1ab0: 20 20 54 6f 6b 65 6e 20 2a 70 49 64 31 2c 20 20    Token *pId1,  
1ac0: 20 20 20 20 20 20 2f 2a 20 46 69 72 73 74 20 70        /* First p
1ad0: 61 72 74 20 6f 66 20 5b 64 61 74 61 62 61 73 65  art of [database
1ae0: 2e 5d 69 64 20 66 69 65 6c 64 20 2a 2f 0a 20 20  .]id field */.  
1af0: 54 6f 6b 65 6e 20 2a 70 49 64 32 2c 20 20 20 20  Token *pId2,    
1b00: 20 20 20 20 2f 2a 20 53 65 63 6f 6e 64 20 70 61      /* Second pa
1b10: 72 74 20 6f 66 20 5b 64 61 74 61 62 61 73 65 2e  rt of [database.
1b20: 5d 69 64 20 66 69 65 6c 64 2c 20 6f 72 20 4e 55  ]id field, or NU
1b30: 4c 4c 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a 70  LL */.  Token *p
1b40: 56 61 6c 75 65 2c 20 20 20 20 20 20 2f 2a 20 54  Value,      /* T
1b50: 6f 6b 65 6e 20 66 6f 72 20 3c 76 61 6c 75 65 3e  oken for <value>
1b60: 2c 20 6f 72 20 4e 55 4c 4c 20 2a 2f 0a 20 20 69  , or NULL */.  i
1b70: 6e 74 20 6d 69 6e 75 73 46 6c 61 67 20 20 20 20  nt minusFlag    
1b80: 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20 61 20     /* True if a 
1b90: 27 2d 27 20 73 69 67 6e 20 70 72 65 63 65 64 65  '-' sign precede
1ba0: 64 20 3c 76 61 6c 75 65 3e 20 2a 2f 0a 29 7b 0a  d <value> */.){.
1bb0: 20 20 63 68 61 72 20 2a 7a 4c 65 66 74 20 3d 20    char *zLeft = 
1bc0: 30 3b 20 20 20 20 20 20 20 2f 2a 20 4e 75 6c 2d  0;       /* Nul-
1bd0: 74 65 72 6d 69 6e 61 74 65 64 20 55 54 46 2d 38  terminated UTF-8
1be0: 20 73 74 72 69 6e 67 20 3c 69 64 3e 20 2a 2f 0a   string <id> */.
1bf0: 20 20 63 68 61 72 20 2a 7a 52 69 67 68 74 20 3d    char *zRight =
1c00: 20 30 3b 20 20 20 20 20 20 2f 2a 20 4e 75 6c 2d   0;      /* Nul-
1c10: 74 65 72 6d 69 6e 61 74 65 64 20 55 54 46 2d 38  terminated UTF-8
1c20: 20 73 74 72 69 6e 67 20 3c 76 61 6c 75 65 3e 2c   string <value>,
1c30: 20 6f 72 20 4e 55 4c 4c 20 2a 2f 0a 20 20 63 6f   or NULL */.  co
1c40: 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 20 3d 20  nst char *zDb = 
1c50: 30 3b 20 20 20 2f 2a 20 54 68 65 20 64 61 74 61  0;   /* The data
1c60: 62 61 73 65 20 6e 61 6d 65 20 2a 2f 0a 20 20 54  base name */.  T
1c70: 6f 6b 65 6e 20 2a 70 49 64 3b 20 20 20 20 20 20  oken *pId;      
1c80: 20 20 20 20 20 20 2f 2a 20 50 6f 69 6e 74 65 72        /* Pointer
1c90: 20 74 6f 20 3c 69 64 3e 20 74 6f 6b 65 6e 20 2a   to <id> token *
1ca0: 2f 0a 20 20 69 6e 74 20 69 44 62 3b 20 20 20 20  /.  int iDb;    
1cb0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 61             /* Da
1cc0: 74 61 62 61 73 65 20 69 6e 64 65 78 20 66 6f 72  tabase index for
1cd0: 20 3c 64 61 74 61 62 61 73 65 3e 20 2a 2f 0a 20   <database> */. 
1ce0: 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70   sqlite3 *db = p
1cf0: 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 44 62 20  Parse->db;.  Db 
1d00: 2a 70 44 62 3b 0a 20 20 56 64 62 65 20 2a 76 20  *pDb;.  Vdbe *v 
1d10: 3d 20 73 71 6c 69 74 65 33 47 65 74 56 64 62 65  = sqlite3GetVdbe
1d20: 28 70 50 61 72 73 65 29 3b 0a 20 20 69 66 28 20  (pParse);.  if( 
1d30: 76 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 0a  v==0 ) return;..
1d40: 20 20 2f 2a 20 49 6e 74 65 72 70 72 65 74 20 74    /* Interpret t
1d50: 68 65 20 5b 64 61 74 61 62 61 73 65 2e 5d 20 70  he [database.] p
1d60: 61 72 74 20 6f 66 20 74 68 65 20 70 72 61 67 6d  art of the pragm
1d70: 61 20 73 74 61 74 65 6d 65 6e 74 2e 20 69 44 62  a statement. iDb
1d80: 20 69 73 20 74 68 65 0a 20 20 2a 2a 20 69 6e 64   is the.  ** ind
1d90: 65 78 20 6f 66 20 74 68 65 20 64 61 74 61 62 61  ex of the databa
1da0: 73 65 20 74 68 69 73 20 70 72 61 67 6d 61 20 69  se this pragma i
1db0: 73 20 62 65 69 6e 67 20 61 70 70 6c 69 65 64 20  s being applied 
1dc0: 74 6f 20 69 6e 20 64 62 2e 61 44 62 5b 5d 2e 20  to in db.aDb[]. 
1dd0: 2a 2f 0a 20 20 69 44 62 20 3d 20 73 71 6c 69 74  */.  iDb = sqlit
1de0: 65 33 54 77 6f 50 61 72 74 4e 61 6d 65 28 70 50  e3TwoPartName(pP
1df0: 61 72 73 65 2c 20 70 49 64 31 2c 20 70 49 64 32  arse, pId1, pId2
1e00: 2c 20 26 70 49 64 29 3b 0a 20 20 69 66 28 20 69  , &pId);.  if( i
1e10: 44 62 3c 30 20 29 20 72 65 74 75 72 6e 3b 0a 20  Db<0 ) return;. 
1e20: 20 70 44 62 20 3d 20 26 64 62 2d 3e 61 44 62 5b   pDb = &db->aDb[
1e30: 69 44 62 5d 3b 0a 0a 20 20 2f 2a 20 49 66 20 74  iDb];..  /* If t
1e40: 68 65 20 74 65 6d 70 20 64 61 74 61 62 61 73 65  he temp database
1e50: 20 68 61 73 20 62 65 65 6e 20 65 78 70 6c 69 63   has been explic
1e60: 69 74 6c 79 20 6e 61 6d 65 64 20 61 73 20 70 61  itly named as pa
1e70: 72 74 20 6f 66 20 74 68 65 20 0a 20 20 2a 2a 20  rt of the .  ** 
1e80: 70 72 61 67 6d 61 2c 20 6d 61 6b 65 20 73 75 72  pragma, make sur
1e90: 65 20 69 74 20 69 73 20 6f 70 65 6e 2e 20 0a 20  e it is open. . 
1ea0: 20 2a 2f 0a 20 20 69 66 28 20 69 44 62 3d 3d 31   */.  if( iDb==1
1eb0: 20 26 26 20 73 71 6c 69 74 65 33 4f 70 65 6e 54   && sqlite3OpenT
1ec0: 65 6d 70 44 61 74 61 62 61 73 65 28 70 50 61 72  empDatabase(pPar
1ed0: 73 65 29 20 29 7b 0a 20 20 20 20 72 65 74 75 72  se) ){.    retur
1ee0: 6e 3b 0a 20 20 7d 0a 0a 20 20 7a 4c 65 66 74 20  n;.  }..  zLeft 
1ef0: 3d 20 73 71 6c 69 74 65 33 4e 61 6d 65 46 72 6f  = sqlite3NameFro
1f00: 6d 54 6f 6b 65 6e 28 70 49 64 29 3b 0a 20 20 69  mToken(pId);.  i
1f10: 66 28 20 21 7a 4c 65 66 74 20 29 20 72 65 74 75  f( !zLeft ) retu
1f20: 72 6e 3b 0a 20 20 69 66 28 20 6d 69 6e 75 73 46  rn;.  if( minusF
1f30: 6c 61 67 20 29 7b 0a 20 20 20 20 7a 52 69 67 68  lag ){.    zRigh
1f40: 74 20 3d 20 73 71 6c 69 74 65 33 4d 50 72 69 6e  t = sqlite3MPrin
1f50: 74 66 28 22 2d 25 54 22 2c 20 70 56 61 6c 75 65  tf("-%T", pValue
1f60: 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  );.  }else{.    
1f70: 7a 52 69 67 68 74 20 3d 20 73 71 6c 69 74 65 33  zRight = sqlite3
1f80: 4e 61 6d 65 46 72 6f 6d 54 6f 6b 65 6e 28 70 56  NameFromToken(pV
1f90: 61 6c 75 65 29 3b 0a 20 20 7d 0a 0a 20 20 7a 44  alue);.  }..  zD
1fa0: 62 20 3d 20 28 28 69 44 62 3e 30 29 3f 70 44 62  b = ((iDb>0)?pDb
1fb0: 2d 3e 7a 4e 61 6d 65 3a 30 29 3b 0a 20 20 69 66  ->zName:0);.  if
1fc0: 28 20 73 71 6c 69 74 65 33 41 75 74 68 43 68 65  ( sqlite3AuthChe
1fd0: 63 6b 28 70 50 61 72 73 65 2c 20 53 51 4c 49 54  ck(pParse, SQLIT
1fe0: 45 5f 50 52 41 47 4d 41 2c 20 7a 4c 65 66 74 2c  E_PRAGMA, zLeft,
1ff0: 20 7a 52 69 67 68 74 2c 20 7a 44 62 29 20 29 7b   zRight, zDb) ){
2000: 0a 20 20 20 20 67 6f 74 6f 20 70 72 61 67 6d 61  .    goto pragma
2010: 5f 6f 75 74 3b 0a 20 20 7d 0a 20 0a 23 69 66 6e  _out;.  }. .#ifn
2020: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
2030: 50 41 47 45 52 5f 50 52 41 47 4d 41 53 0a 20 20  PAGER_PRAGMAS.  
2040: 2f 2a 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41 20  /*.  **  PRAGMA 
2050: 5b 64 61 74 61 62 61 73 65 2e 5d 64 65 66 61 75  [database.]defau
2060: 6c 74 5f 63 61 63 68 65 5f 73 69 7a 65 0a 20 20  lt_cache_size.  
2070: 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64 61 74 61  **  PRAGMA [data
2080: 62 61 73 65 2e 5d 64 65 66 61 75 6c 74 5f 63 61  base.]default_ca
2090: 63 68 65 5f 73 69 7a 65 3d 4e 0a 20 20 2a 2a 0a  che_size=N.  **.
20a0: 20 20 2a 2a 20 54 68 65 20 66 69 72 73 74 20 66    ** The first f
20b0: 6f 72 6d 20 72 65 70 6f 72 74 73 20 74 68 65 20  orm reports the 
20c0: 63 75 72 72 65 6e 74 20 70 65 72 73 69 73 74 65  current persiste
20d0: 6e 74 20 73 65 74 74 69 6e 67 20 66 6f 72 20 74  nt setting for t
20e0: 68 65 0a 20 20 2a 2a 20 70 61 67 65 20 63 61 63  he.  ** page cac
20f0: 68 65 20 73 69 7a 65 2e 20 20 54 68 65 20 76 61  he size.  The va
2100: 6c 75 65 20 72 65 74 75 72 6e 65 64 20 69 73 20  lue returned is 
2110: 74 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  the maximum numb
2120: 65 72 20 6f 66 0a 20 20 2a 2a 20 70 61 67 65 73  er of.  ** pages
2130: 20 69 6e 20 74 68 65 20 70 61 67 65 20 63 61 63   in the page cac
2140: 68 65 2e 20 20 54 68 65 20 73 65 63 6f 6e 64 20  he.  The second 
2150: 66 6f 72 6d 20 73 65 74 73 20 62 6f 74 68 20 74  form sets both t
2160: 68 65 20 63 75 72 72 65 6e 74 0a 20 20 2a 2a 20  he current.  ** 
2170: 70 61 67 65 20 63 61 63 68 65 20 73 69 7a 65 20  page cache size 
2180: 76 61 6c 75 65 20 61 6e 64 20 74 68 65 20 70 65  value and the pe
2190: 72 73 69 73 74 65 6e 74 20 70 61 67 65 20 63 61  rsistent page ca
21a0: 63 68 65 20 73 69 7a 65 20 76 61 6c 75 65 0a 20  che size value. 
21b0: 20 2a 2a 20 73 74 6f 72 65 64 20 69 6e 20 74 68   ** stored in th
21c0: 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  e database file.
21d0: 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 64  .  **.  ** The d
21e0: 65 66 61 75 6c 74 20 63 61 63 68 65 20 73 69 7a  efault cache siz
21f0: 65 20 69 73 20 73 74 6f 72 65 64 20 69 6e 20 6d  e is stored in m
2200: 65 74 61 2d 76 61 6c 75 65 20 32 20 6f 66 20 70  eta-value 2 of p
2210: 61 67 65 20 31 20 6f 66 20 74 68 65 0a 20 20 2a  age 1 of the.  *
2220: 2a 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  * database file.
2230: 20 20 54 68 65 20 63 61 63 68 65 20 73 69 7a 65    The cache size
2240: 20 69 73 20 61 63 74 75 61 6c 6c 79 20 74 68 65   is actually the
2250: 20 61 62 73 6f 6c 75 74 65 20 76 61 6c 75 65 20   absolute value 
2260: 6f 66 0a 20 20 2a 2a 20 74 68 69 73 20 6d 65 6d  of.  ** this mem
2270: 6f 72 79 20 6c 6f 63 61 74 69 6f 6e 2e 20 20 54  ory location.  T
2280: 68 65 20 73 69 67 6e 20 6f 66 20 6d 65 74 61 2d  he sign of meta-
2290: 76 61 6c 75 65 20 32 20 64 65 74 65 72 6d 69 6e  value 2 determin
22a0: 65 73 20 74 68 65 0a 20 20 2a 2a 20 73 79 6e 63  es the.  ** sync
22b0: 68 72 6f 6e 6f 75 73 20 73 65 74 74 69 6e 67 2e  hronous setting.
22c0: 20 20 41 20 6e 65 67 61 74 69 76 65 20 76 61 6c    A negative val
22d0: 75 65 20 6d 65 61 6e 73 20 73 79 6e 63 68 72 6f  ue means synchro
22e0: 6e 6f 75 73 20 69 73 20 6f 66 66 0a 20 20 2a 2a  nous is off.  **
22f0: 20 61 6e 64 20 61 20 70 6f 73 69 74 69 76 65 20   and a positive 
2300: 76 61 6c 75 65 20 6d 65 61 6e 73 20 73 79 6e 63  value means sync
2310: 68 72 6f 6e 6f 75 73 20 69 73 20 6f 6e 2e 0a 20  hronous is on.. 
2320: 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65   */.  if( sqlite
2330: 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 22  3StrICmp(zLeft,"
2340: 64 65 66 61 75 6c 74 5f 63 61 63 68 65 5f 73 69  default_cache_si
2350: 7a 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73  ze")==0 ){.    s
2360: 74 61 74 69 63 20 63 6f 6e 73 74 20 56 64 62 65  tatic const Vdbe
2370: 4f 70 4c 69 73 74 20 67 65 74 43 61 63 68 65 53  OpList getCacheS
2380: 69 7a 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20  ize[] = {.      
2390: 7b 20 4f 50 5f 52 65 61 64 43 6f 6f 6b 69 65 2c  { OP_ReadCookie,
23a0: 20 20 30 2c 20 32 2c 20 20 20 20 20 20 20 20 30    0, 2,        0
23b0: 7d 2c 20 20 2f 2a 20 30 20 2a 2f 0a 20 20 20 20  },  /* 0 */.    
23c0: 20 20 7b 20 4f 50 5f 41 62 73 56 61 6c 75 65 2c    { OP_AbsValue,
23d0: 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20 20      0, 0,       
23e0: 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f   0},.      { OP_
23f0: 44 75 70 2c 20 20 20 20 20 20 20 20 20 30 2c 20  Dup,         0, 
2400: 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20  0,        0},.  
2410: 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67 65 72      { OP_Integer
2420: 2c 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20  ,     0, 0,     
2430: 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f     0},.      { O
2440: 50 5f 4e 65 2c 20 20 20 20 20 20 20 20 20 20 30  P_Ne,          0
2450: 2c 20 36 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a  , 6,        0},.
2460: 20 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67        { OP_Integ
2470: 65 72 2c 20 20 20 20 20 30 2c 20 30 2c 20 20 20  er,     0, 0,   
2480: 20 20 20 20 20 30 7d 2c 20 20 2f 2a 20 35 20 2a       0},  /* 5 *
2490: 2f 0a 20 20 20 20 20 20 7b 20 4f 50 5f 43 61 6c  /.      { OP_Cal
24a0: 6c 62 61 63 6b 2c 20 20 20 20 31 2c 20 30 2c 20  lback,    1, 0, 
24b0: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 7d         0},.    }
24c0: 3b 0a 20 20 20 20 69 6e 74 20 61 64 64 72 3b 0a  ;.    int addr;.
24d0: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 52      if( sqlite3R
24e0: 65 61 64 53 63 68 65 6d 61 28 70 50 61 72 73 65  eadSchema(pParse
24f0: 29 20 29 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f  ) ) goto pragma_
2500: 6f 75 74 3b 0a 20 20 20 20 69 66 28 20 21 7a 52  out;.    if( !zR
2510: 69 67 68 74 20 29 7b 0a 20 20 20 20 20 20 73 71  ight ){.      sq
2520: 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75 6d 43  lite3VdbeSetNumC
2530: 6f 6c 73 28 76 2c 20 31 29 3b 0a 20 20 20 20 20  ols(v, 1);.     
2540: 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43   sqlite3VdbeSetC
2550: 6f 6c 4e 61 6d 65 28 76 2c 20 30 2c 20 43 4f 4c  olName(v, 0, COL
2560: 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 63 61 63 68  NAME_NAME, "cach
2570: 65 5f 73 69 7a 65 22 2c 20 50 33 5f 53 54 41 54  e_size", P3_STAT
2580: 49 43 29 3b 0a 20 20 20 20 20 20 61 64 64 72 20  IC);.      addr 
2590: 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64  = sqlite3VdbeAdd
25a0: 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53  OpList(v, ArrayS
25b0: 69 7a 65 28 67 65 74 43 61 63 68 65 53 69 7a 65  ize(getCacheSize
25c0: 29 2c 20 67 65 74 43 61 63 68 65 53 69 7a 65 29  ), getCacheSize)
25d0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
25e0: 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20 61  dbeChangeP1(v, a
25f0: 64 64 72 2c 20 69 44 62 29 3b 0a 20 20 20 20 20  ddr, iDb);.     
2600: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
2610: 67 65 50 31 28 76 2c 20 61 64 64 72 2b 35 2c 20  geP1(v, addr+5, 
2620: 4d 41 58 5f 50 41 47 45 53 29 3b 0a 20 20 20 20  MAX_PAGES);.    
2630: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74  }else{.      int
2640: 20 73 69 7a 65 20 3d 20 61 74 6f 69 28 7a 52 69   size = atoi(zRi
2650: 67 68 74 29 3b 0a 20 20 20 20 20 20 69 66 28 20  ght);.      if( 
2660: 73 69 7a 65 3c 30 20 29 20 73 69 7a 65 20 3d 20  size<0 ) size = 
2670: 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20 73 71 6c  -size;.      sql
2680: 69 74 65 33 42 65 67 69 6e 57 72 69 74 65 4f 70  ite3BeginWriteOp
2690: 65 72 61 74 69 6f 6e 28 70 50 61 72 73 65 2c 20  eration(pParse, 
26a0: 30 2c 20 69 44 62 29 3b 0a 20 20 20 20 20 20 73  0, iDb);.      s
26b0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
26c0: 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 73  v, OP_Integer, s
26d0: 69 7a 65 2c 20 30 29 3b 0a 20 20 20 20 20 20 73  ize, 0);.      s
26e0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
26f0: 76 2c 20 4f 50 5f 52 65 61 64 43 6f 6f 6b 69 65  v, OP_ReadCookie
2700: 2c 20 69 44 62 2c 20 32 29 3b 0a 20 20 20 20 20  , iDb, 2);.     
2710: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56   addr = sqlite3V
2720: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49  dbeAddOp(v, OP_I
2730: 6e 74 65 67 65 72 2c 20 30 2c 20 30 29 3b 0a 20  nteger, 0, 0);. 
2740: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
2750: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 47 65 2c 20  AddOp(v, OP_Ge, 
2760: 30 2c 20 61 64 64 72 2b 33 29 3b 0a 20 20 20 20  0, addr+3);.    
2770: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
2780: 4f 70 28 76 2c 20 4f 50 5f 4e 65 67 61 74 69 76  Op(v, OP_Negativ
2790: 65 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  e, 0, 0);.      
27a0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
27b0: 28 76 2c 20 4f 50 5f 53 65 74 43 6f 6f 6b 69 65  (v, OP_SetCookie
27c0: 2c 20 69 44 62 2c 20 32 29 3b 0a 20 20 20 20 20  , iDb, 2);.     
27d0: 20 70 44 62 2d 3e 70 53 63 68 65 6d 61 2d 3e 63   pDb->pSchema->c
27e0: 61 63 68 65 5f 73 69 7a 65 20 3d 20 73 69 7a 65  ache_size = size
27f0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 42  ;.      sqlite3B
2800: 74 72 65 65 53 65 74 43 61 63 68 65 53 69 7a 65  treeSetCacheSize
2810: 28 70 44 62 2d 3e 70 42 74 2c 20 70 44 62 2d 3e  (pDb->pBt, pDb->
2820: 70 53 63 68 65 6d 61 2d 3e 63 61 63 68 65 5f 73  pSchema->cache_s
2830: 69 7a 65 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65  ize);.    }.  }e
2840: 6c 73 65 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20  lse..  /*.  **  
2850: 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65  PRAGMA [database
2860: 2e 5d 70 61 67 65 5f 73 69 7a 65 0a 20 20 2a 2a  .]page_size.  **
2870: 20 20 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61    PRAGMA [databa
2880: 73 65 2e 5d 70 61 67 65 5f 73 69 7a 65 3d 4e 0a  se.]page_size=N.
2890: 20 20 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 66 69    **.  ** The fi
28a0: 72 73 74 20 66 6f 72 6d 20 72 65 70 6f 72 74 73  rst form reports
28b0: 20 74 68 65 20 63 75 72 72 65 6e 74 20 73 65 74   the current set
28c0: 74 69 6e 67 20 66 6f 72 20 74 68 65 0a 20 20 2a  ting for the.  *
28d0: 2a 20 64 61 74 61 62 61 73 65 20 70 61 67 65 20  * database page 
28e0: 73 69 7a 65 20 69 6e 20 62 79 74 65 73 2e 20 20  size in bytes.  
28f0: 54 68 65 20 73 65 63 6f 6e 64 20 66 6f 72 6d 20  The second form 
2900: 73 65 74 73 20 74 68 65 0a 20 20 2a 2a 20 64 61  sets the.  ** da
2910: 74 61 62 61 73 65 20 70 61 67 65 20 73 69 7a 65  tabase page size
2920: 20 76 61 6c 75 65 2e 20 20 54 68 65 20 76 61 6c   value.  The val
2930: 75 65 20 63 61 6e 20 6f 6e 6c 79 20 62 65 20 73  ue can only be s
2940: 65 74 20 69 66 0a 20 20 2a 2a 20 74 68 65 20 64  et if.  ** the d
2950: 61 74 61 62 61 73 65 20 68 61 73 20 6e 6f 74 20  atabase has not 
2960: 79 65 74 20 62 65 65 6e 20 63 72 65 61 74 65 64  yet been created
2970: 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c  ..  */.  if( sql
2980: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
2990: 74 2c 22 70 61 67 65 5f 73 69 7a 65 22 29 3d 3d  t,"page_size")==
29a0: 30 20 29 7b 0a 20 20 20 20 42 74 72 65 65 20 2a  0 ){.    Btree *
29b0: 70 42 74 20 3d 20 70 44 62 2d 3e 70 42 74 3b 0a  pBt = pDb->pBt;.
29c0: 20 20 20 20 69 66 28 20 21 7a 52 69 67 68 74 20      if( !zRight 
29d0: 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 73 69 7a  ){.      int siz
29e0: 65 20 3d 20 70 42 74 20 3f 20 73 71 6c 69 74 65  e = pBt ? sqlite
29f0: 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69 7a  3BtreeGetPageSiz
2a00: 65 28 70 42 74 29 20 3a 20 30 3b 0a 20 20 20 20  e(pBt) : 0;.    
2a10: 20 20 72 65 74 75 72 6e 53 69 6e 67 6c 65 49 6e    returnSingleIn
2a20: 74 28 70 50 61 72 73 65 2c 20 22 70 61 67 65 5f  t(pParse, "page_
2a30: 73 69 7a 65 22 2c 20 73 69 7a 65 29 3b 0a 20 20  size", size);.  
2a40: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 73    }else{.      s
2a50: 71 6c 69 74 65 33 42 74 72 65 65 53 65 74 50 61  qlite3BtreeSetPa
2a60: 67 65 53 69 7a 65 28 70 42 74 2c 20 61 74 6f 69  geSize(pBt, atoi
2a70: 28 7a 52 69 67 68 74 29 2c 20 2d 31 29 3b 0a 20  (zRight), -1);. 
2a80: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20     }.  }else..  
2a90: 2f 2a 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41 20  /*.  **  PRAGMA 
2aa0: 5b 64 61 74 61 62 61 73 65 2e 5d 6c 6f 63 6b 69  [database.]locki
2ab0: 6e 67 5f 6d 6f 64 65 0a 20 20 2a 2a 20 20 50 52  ng_mode.  **  PR
2ac0: 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d  AGMA [database.]
2ad0: 6c 6f 63 6b 69 6e 67 5f 6d 6f 64 65 20 3d 20 28  locking_mode = (
2ae0: 6e 6f 72 6d 61 6c 7c 65 78 63 6c 75 73 69 76 65  normal|exclusive
2af0: 29 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c  ).  */.  if( sql
2b00: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
2b10: 74 2c 22 6c 6f 63 6b 69 6e 67 5f 6d 6f 64 65 22  t,"locking_mode"
2b20: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 63 6f 6e 73  )==0 ){.    cons
2b30: 74 20 63 68 61 72 20 2a 7a 52 65 74 20 3d 20 22  t char *zRet = "
2b40: 6e 6f 72 6d 61 6c 22 3b 0a 20 20 20 20 69 6e 74  normal";.    int
2b50: 20 65 4d 6f 64 65 20 3d 20 67 65 74 4c 6f 63 6b   eMode = getLock
2b60: 69 6e 67 4d 6f 64 65 28 7a 52 69 67 68 74 29 3b  ingMode(zRight);
2b70: 0a 0a 20 20 20 20 69 66 28 20 70 49 64 32 2d 3e  ..    if( pId2->
2b80: 6e 3d 3d 30 20 26 26 20 65 4d 6f 64 65 3d 3d 50  n==0 && eMode==P
2b90: 41 47 45 52 5f 4c 4f 43 4b 49 4e 47 4d 4f 44 45  AGER_LOCKINGMODE
2ba0: 5f 51 55 45 52 59 20 29 7b 0a 20 20 20 20 20 20  _QUERY ){.      
2bb0: 2f 2a 20 53 69 6d 70 6c 65 20 22 50 52 41 47 4d  /* Simple "PRAGM
2bc0: 41 20 6c 6f 63 6b 69 6e 67 5f 6d 6f 64 65 3b 22  A locking_mode;"
2bd0: 20 73 74 61 74 65 6d 65 6e 74 2e 20 54 68 69 73   statement. This
2be0: 20 69 73 20 61 20 71 75 65 72 79 20 66 6f 72 0a   is a query for.
2bf0: 20 20 20 20 20 20 2a 2a 20 74 68 65 20 63 75 72        ** the cur
2c00: 72 65 6e 74 20 64 65 66 61 75 6c 74 20 6c 6f 63  rent default loc
2c10: 6b 69 6e 67 20 6d 6f 64 65 20 28 77 68 69 63 68  king mode (which
2c20: 20 6d 61 79 20 62 65 20 64 69 66 66 65 72 65 6e   may be differen
2c30: 74 20 74 6f 0a 20 20 20 20 20 20 2a 2a 20 74 68  t to.      ** th
2c40: 65 20 6c 6f 63 6b 69 6e 67 2d 6d 6f 64 65 20 6f  e locking-mode o
2c50: 66 20 74 68 65 20 6d 61 69 6e 20 64 61 74 61 62  f the main datab
2c60: 61 73 65 29 2e 0a 20 20 20 20 20 20 2a 2f 0a 20  ase)..      */. 
2c70: 20 20 20 20 20 65 4d 6f 64 65 20 3d 20 64 62 2d       eMode = db-
2c80: 3e 64 66 6c 74 4c 6f 63 6b 4d 6f 64 65 3b 0a 20  >dfltLockMode;. 
2c90: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
2ca0: 50 61 67 65 72 20 2a 70 50 61 67 65 72 3b 0a 20  Pager *pPager;. 
2cb0: 20 20 20 20 20 69 66 28 20 70 49 64 32 2d 3e 6e       if( pId2->n
2cc0: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 2f  ==0 ){.        /
2cd0: 2a 20 54 68 69 73 20 69 6e 64 69 63 61 74 65 73  * This indicates
2ce0: 20 74 68 61 74 20 6e 6f 20 64 61 74 61 62 61 73   that no databas
2cf0: 65 20 6e 61 6d 65 20 77 61 73 20 73 70 65 63 69  e name was speci
2d00: 66 69 65 64 20 61 73 20 70 61 72 74 0a 20 20 20  fied as part.   
2d10: 20 20 20 20 20 2a 2a 20 6f 66 20 74 68 65 20 50       ** of the P
2d20: 52 41 47 4d 41 20 63 6f 6d 6d 61 6e 64 2e 20 49  RAGMA command. I
2d30: 6e 20 74 68 69 73 20 63 61 73 65 20 74 68 65 20  n this case the 
2d40: 6c 6f 63 6b 69 6e 67 2d 6d 6f 64 65 20 6d 75 73  locking-mode mus
2d50: 74 20 62 65 0a 20 20 20 20 20 20 20 20 2a 2a 20  t be.        ** 
2d60: 73 65 74 20 6f 6e 20 61 6c 6c 20 61 74 74 61 63  set on all attac
2d70: 68 65 64 20 64 61 74 61 62 61 73 65 73 2c 20 61  hed databases, a
2d80: 73 20 77 65 6c 6c 20 61 73 20 74 68 65 20 6d 61  s well as the ma
2d90: 69 6e 20 64 62 20 66 69 6c 65 2e 0a 20 20 20 20  in db file..    
2da0: 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20 20 2a      **.        *
2db0: 2a 20 41 6c 73 6f 2c 20 74 68 65 20 73 71 6c 69  * Also, the sqli
2dc0: 74 65 33 2e 64 66 6c 74 4c 6f 63 6b 4d 6f 64 65  te3.dfltLockMode
2dd0: 20 76 61 72 69 61 62 6c 65 20 69 73 20 73 65 74   variable is set
2de0: 20 73 6f 20 74 68 61 74 0a 20 20 20 20 20 20 20   so that.       
2df0: 20 2a 2a 20 61 6e 79 20 73 75 62 73 65 71 75 65   ** any subseque
2e00: 6e 74 6c 79 20 61 74 74 61 63 68 65 64 20 64 61  ntly attached da
2e10: 74 61 62 61 73 65 73 20 61 6c 73 6f 20 75 73 65  tabases also use
2e20: 20 74 68 65 20 73 70 65 63 69 66 69 65 64 0a 20   the specified. 
2e30: 20 20 20 20 20 20 20 2a 2a 20 6c 6f 63 6b 69 6e         ** lockin
2e40: 67 20 6d 6f 64 65 2e 0a 20 20 20 20 20 20 20 20  g mode..        
2e50: 2a 2f 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69  */.        int i
2e60: 69 3b 0a 20 20 20 20 20 20 20 20 61 73 73 65 72  i;.        asser
2e70: 74 28 70 44 62 3d 3d 26 64 62 2d 3e 61 44 62 5b  t(pDb==&db->aDb[
2e80: 30 5d 29 3b 0a 20 20 20 20 20 20 20 20 66 6f 72  0]);.        for
2e90: 28 69 69 3d 32 3b 20 69 69 3c 64 62 2d 3e 6e 44  (ii=2; ii<db->nD
2ea0: 62 3b 20 69 69 2b 2b 29 7b 0a 20 20 20 20 20 20  b; ii++){.      
2eb0: 20 20 20 20 70 50 61 67 65 72 20 3d 20 73 71 6c      pPager = sql
2ec0: 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28 64  ite3BtreePager(d
2ed0: 62 2d 3e 61 44 62 5b 69 69 5d 2e 70 42 74 29 3b  b->aDb[ii].pBt);
2ee0: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
2ef0: 65 33 50 61 67 65 72 4c 6f 63 6b 69 6e 67 4d 6f  e3PagerLockingMo
2f00: 64 65 28 70 50 61 67 65 72 2c 20 65 4d 6f 64 65  de(pPager, eMode
2f10: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
2f20: 20 20 20 20 20 64 62 2d 3e 64 66 6c 74 4c 6f 63       db->dfltLoc
2f30: 6b 4d 6f 64 65 20 3d 20 65 4d 6f 64 65 3b 0a 20  kMode = eMode;. 
2f40: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 70 50 61       }.      pPa
2f50: 67 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74 72  ger = sqlite3Btr
2f60: 65 65 50 61 67 65 72 28 70 44 62 2d 3e 70 42 74  eePager(pDb->pBt
2f70: 29 3b 0a 20 20 20 20 20 20 65 4d 6f 64 65 20 3d  );.      eMode =
2f80: 20 73 71 6c 69 74 65 33 50 61 67 65 72 4c 6f 63   sqlite3PagerLoc
2f90: 6b 69 6e 67 4d 6f 64 65 28 70 50 61 67 65 72 2c  kingMode(pPager,
2fa0: 20 65 4d 6f 64 65 29 3b 0a 20 20 20 20 7d 0a 0a   eMode);.    }..
2fb0: 20 20 20 20 61 73 73 65 72 74 28 65 4d 6f 64 65      assert(eMode
2fc0: 3d 3d 50 41 47 45 52 5f 4c 4f 43 4b 49 4e 47 4d  ==PAGER_LOCKINGM
2fd0: 4f 44 45 5f 4e 4f 52 4d 41 4c 7c 7c 65 4d 6f 64  ODE_NORMAL||eMod
2fe0: 65 3d 3d 50 41 47 45 52 5f 4c 4f 43 4b 49 4e 47  e==PAGER_LOCKING
2ff0: 4d 4f 44 45 5f 45 58 43 4c 55 53 49 56 45 29 3b  MODE_EXCLUSIVE);
3000: 0a 20 20 20 20 69 66 28 20 65 4d 6f 64 65 3d 3d  .    if( eMode==
3010: 50 41 47 45 52 5f 4c 4f 43 4b 49 4e 47 4d 4f 44  PAGER_LOCKINGMOD
3020: 45 5f 45 58 43 4c 55 53 49 56 45 20 29 7b 0a 20  E_EXCLUSIVE ){. 
3030: 20 20 20 20 20 7a 52 65 74 20 3d 20 22 65 78 63       zRet = "exc
3040: 6c 75 73 69 76 65 22 3b 0a 20 20 20 20 7d 0a 20  lusive";.    }. 
3050: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65     sqlite3VdbeSe
3060: 74 4e 75 6d 43 6f 6c 73 28 76 2c 20 31 29 3b 0a  tNumCols(v, 1);.
3070: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
3080: 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 30 2c 20  etColName(v, 0, 
3090: 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 6c  COLNAME_NAME, "l
30a0: 6f 63 6b 69 6e 67 5f 6d 6f 64 65 22 2c 20 50 33  ocking_mode", P3
30b0: 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 73 71  _STATIC);.    sq
30c0: 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76 2c 20  lite3VdbeOp3(v, 
30d0: 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20 30  OP_String8, 0, 0
30e0: 2c 20 7a 52 65 74 2c 20 30 29 3b 0a 20 20 20 20  , zRet, 0);.    
30f0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
3100: 28 76 2c 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c  (v, OP_Callback,
3110: 20 31 2c 20 30 29 3b 0a 20 20 7d 65 6c 73 65 0a   1, 0);.  }else.
3120: 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45  #endif /* SQLITE
3130: 5f 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52 41 47  _OMIT_PAGER_PRAG
3140: 4d 41 53 20 2a 2f 0a 0a 20 20 2f 2a 0a 20 20 2a  MAS */..  /*.  *
3150: 2a 20 20 50 52 41 47 4d 41 20 5b 64 61 74 61 62  *  PRAGMA [datab
3160: 61 73 65 2e 5d 61 75 74 6f 5f 76 61 63 75 75 6d  ase.]auto_vacuum
3170: 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64  .  **  PRAGMA [d
3180: 61 74 61 62 61 73 65 2e 5d 61 75 74 6f 5f 76 61  atabase.]auto_va
3190: 63 75 75 6d 3d 4e 0a 20 20 2a 2a 0a 20 20 2a 2a  cuum=N.  **.  **
31a0: 20 47 65 74 20 6f 72 20 73 65 74 20 74 68 65 20   Get or set the 
31b0: 28 62 6f 6f 6c 65 61 6e 29 20 76 61 6c 75 65 20  (boolean) value 
31c0: 6f 66 20 74 68 65 20 64 61 74 61 62 61 73 65 20  of the database 
31d0: 27 61 75 74 6f 2d 76 61 63 75 75 6d 27 20 70 61  'auto-vacuum' pa
31e0: 72 61 6d 65 74 65 72 2e 0a 20 20 2a 2f 0a 23 69  rameter..  */.#i
31f0: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
3200: 54 5f 41 55 54 4f 56 41 43 55 55 4d 0a 20 20 69  T_AUTOVACUUM.  i
3210: 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d  f( sqlite3StrICm
3220: 70 28 7a 4c 65 66 74 2c 22 61 75 74 6f 5f 76 61  p(zLeft,"auto_va
3230: 63 75 75 6d 22 29 3d 3d 30 20 29 7b 0a 20 20 20  cuum")==0 ){.   
3240: 20 42 74 72 65 65 20 2a 70 42 74 20 3d 20 70 44   Btree *pBt = pD
3250: 62 2d 3e 70 42 74 3b 0a 20 20 20 20 69 66 28 20  b->pBt;.    if( 
3260: 21 7a 52 69 67 68 74 20 29 7b 0a 20 20 20 20 20  !zRight ){.     
3270: 20 69 6e 74 20 61 75 74 6f 5f 76 61 63 75 75 6d   int auto_vacuum
3280: 20 3d 20 0a 20 20 20 20 20 20 20 20 20 20 70 42   = .          pB
3290: 74 20 3f 20 73 71 6c 69 74 65 33 42 74 72 65 65  t ? sqlite3Btree
32a0: 47 65 74 41 75 74 6f 56 61 63 75 75 6d 28 70 42  GetAutoVacuum(pB
32b0: 74 29 20 3a 20 53 51 4c 49 54 45 5f 44 45 46 41  t) : SQLITE_DEFA
32c0: 55 4c 54 5f 41 55 54 4f 56 41 43 55 55 4d 3b 0a  ULT_AUTOVACUUM;.
32d0: 20 20 20 20 20 20 72 65 74 75 72 6e 53 69 6e 67        returnSing
32e0: 6c 65 49 6e 74 28 70 50 61 72 73 65 2c 20 22 61  leInt(pParse, "a
32f0: 75 74 6f 5f 76 61 63 75 75 6d 22 2c 20 61 75 74  uto_vacuum", aut
3300: 6f 5f 76 61 63 75 75 6d 29 3b 0a 20 20 20 20 7d  o_vacuum);.    }
3310: 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 71 6c 69  else{.      sqli
3320: 74 65 33 42 74 72 65 65 53 65 74 41 75 74 6f 56  te3BtreeSetAutoV
3330: 61 63 75 75 6d 28 70 42 74 2c 20 67 65 74 42 6f  acuum(pBt, getBo
3340: 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29 29 3b 0a  olean(zRight));.
3350: 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 23 65      }.  }else.#e
3360: 6e 64 69 66 0a 0a 23 69 66 6e 64 65 66 20 53 51  ndif..#ifndef SQ
3370: 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52 5f  LITE_OMIT_PAGER_
3380: 50 52 41 47 4d 41 53 0a 20 20 2f 2a 0a 20 20 2a  PRAGMAS.  /*.  *
3390: 2a 20 20 50 52 41 47 4d 41 20 5b 64 61 74 61 62  *  PRAGMA [datab
33a0: 61 73 65 2e 5d 63 61 63 68 65 5f 73 69 7a 65 0a  ase.]cache_size.
33b0: 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64 61    **  PRAGMA [da
33c0: 74 61 62 61 73 65 2e 5d 63 61 63 68 65 5f 73 69  tabase.]cache_si
33d0: 7a 65 3d 4e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54  ze=N.  **.  ** T
33e0: 68 65 20 66 69 72 73 74 20 66 6f 72 6d 20 72 65  he first form re
33f0: 70 6f 72 74 73 20 74 68 65 20 63 75 72 72 65 6e  ports the curren
3400: 74 20 6c 6f 63 61 6c 20 73 65 74 74 69 6e 67 20  t local setting 
3410: 66 6f 72 20 74 68 65 0a 20 20 2a 2a 20 70 61 67  for the.  ** pag
3420: 65 20 63 61 63 68 65 20 73 69 7a 65 2e 20 20 54  e cache size.  T
3430: 68 65 20 6c 6f 63 61 6c 20 73 65 74 74 69 6e 67  he local setting
3440: 20 63 61 6e 20 62 65 20 64 69 66 66 65 72 65 6e   can be differen
3450: 74 20 66 72 6f 6d 0a 20 20 2a 2a 20 74 68 65 20  t from.  ** the 
3460: 70 65 72 73 69 73 74 65 6e 74 20 63 61 63 68 65  persistent cache
3470: 20 73 69 7a 65 20 76 61 6c 75 65 20 74 68 61 74   size value that
3480: 20 69 73 20 73 74 6f 72 65 64 20 69 6e 20 74 68   is stored in th
3490: 65 20 64 61 74 61 62 61 73 65 0a 20 20 2a 2a 20  e database.  ** 
34a0: 66 69 6c 65 20 69 74 73 65 6c 66 2e 20 20 54 68  file itself.  Th
34b0: 65 20 76 61 6c 75 65 20 72 65 74 75 72 6e 65 64  e value returned
34c0: 20 69 73 20 74 68 65 20 6d 61 78 69 6d 75 6d 20   is the maximum 
34d0: 6e 75 6d 62 65 72 20 6f 66 0a 20 20 2a 2a 20 70  number of.  ** p
34e0: 61 67 65 73 20 69 6e 20 74 68 65 20 70 61 67 65  ages in the page
34f0: 20 63 61 63 68 65 2e 20 20 54 68 65 20 73 65 63   cache.  The sec
3500: 6f 6e 64 20 66 6f 72 6d 20 73 65 74 73 20 74 68  ond form sets th
3510: 65 20 6c 6f 63 61 6c 0a 20 20 2a 2a 20 70 61 67  e local.  ** pag
3520: 65 20 63 61 63 68 65 20 73 69 7a 65 20 76 61 6c  e cache size val
3530: 75 65 2e 20 20 49 74 20 64 6f 65 73 20 6e 6f 74  ue.  It does not
3540: 20 63 68 61 6e 67 65 20 74 68 65 20 70 65 72 73   change the pers
3550: 69 73 74 65 6e 74 0a 20 20 2a 2a 20 63 61 63 68  istent.  ** cach
3560: 65 20 73 69 7a 65 20 73 74 6f 72 65 64 20 6f 6e  e size stored on
3570: 20 74 68 65 20 64 69 73 6b 20 73 6f 20 74 68 65   the disk so the
3580: 20 63 61 63 68 65 20 73 69 7a 65 20 77 69 6c 6c   cache size will
3590: 20 72 65 76 65 72 74 0a 20 20 2a 2a 20 74 6f 20   revert.  ** to 
35a0: 69 74 73 20 64 65 66 61 75 6c 74 20 76 61 6c 75  its default valu
35b0: 65 20 77 68 65 6e 20 74 68 65 20 64 61 74 61 62  e when the datab
35c0: 61 73 65 20 69 73 20 63 6c 6f 73 65 64 20 61 6e  ase is closed an
35d0: 64 20 72 65 6f 70 65 6e 65 64 2e 0a 20 20 2a 2a  d reopened..  **
35e0: 20 4e 20 73 68 6f 75 6c 64 20 62 65 20 61 20 70   N should be a p
35f0: 6f 73 69 74 69 76 65 20 69 6e 74 65 67 65 72 2e  ositive integer.
3600: 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69  .  */.  if( sqli
3610: 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74  te3StrICmp(zLeft
3620: 2c 22 63 61 63 68 65 5f 73 69 7a 65 22 29 3d 3d  ,"cache_size")==
3630: 30 20 29 7b 0a 20 20 20 20 69 66 28 20 73 71 6c  0 ){.    if( sql
3640: 69 74 65 33 52 65 61 64 53 63 68 65 6d 61 28 70  ite3ReadSchema(p
3650: 50 61 72 73 65 29 20 29 20 67 6f 74 6f 20 70 72  Parse) ) goto pr
3660: 61 67 6d 61 5f 6f 75 74 3b 0a 20 20 20 20 69 66  agma_out;.    if
3670: 28 20 21 7a 52 69 67 68 74 20 29 7b 0a 20 20 20  ( !zRight ){.   
3680: 20 20 20 72 65 74 75 72 6e 53 69 6e 67 6c 65 49     returnSingleI
3690: 6e 74 28 70 50 61 72 73 65 2c 20 22 63 61 63 68  nt(pParse, "cach
36a0: 65 5f 73 69 7a 65 22 2c 20 70 44 62 2d 3e 70 53  e_size", pDb->pS
36b0: 63 68 65 6d 61 2d 3e 63 61 63 68 65 5f 73 69 7a  chema->cache_siz
36c0: 65 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20  e);.    }else{. 
36d0: 20 20 20 20 20 69 6e 74 20 73 69 7a 65 20 3d 20       int size = 
36e0: 61 74 6f 69 28 7a 52 69 67 68 74 29 3b 0a 20 20  atoi(zRight);.  
36f0: 20 20 20 20 69 66 28 20 73 69 7a 65 3c 30 20 29      if( size<0 )
3700: 20 73 69 7a 65 20 3d 20 2d 73 69 7a 65 3b 0a 20   size = -size;. 
3710: 20 20 20 20 20 70 44 62 2d 3e 70 53 63 68 65 6d       pDb->pSchem
3720: 61 2d 3e 63 61 63 68 65 5f 73 69 7a 65 20 3d 20  a->cache_size = 
3730: 73 69 7a 65 3b 0a 20 20 20 20 20 20 73 71 6c 69  size;.      sqli
3740: 74 65 33 42 74 72 65 65 53 65 74 43 61 63 68 65  te3BtreeSetCache
3750: 53 69 7a 65 28 70 44 62 2d 3e 70 42 74 2c 20 70  Size(pDb->pBt, p
3760: 44 62 2d 3e 70 53 63 68 65 6d 61 2d 3e 63 61 63  Db->pSchema->cac
3770: 68 65 5f 73 69 7a 65 29 3b 0a 20 20 20 20 7d 0a  he_size);.    }.
3780: 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20 20    }else..  /*.  
3790: 2a 2a 20 20 20 50 52 41 47 4d 41 20 74 65 6d 70  **   PRAGMA temp
37a0: 5f 73 74 6f 72 65 0a 20 20 2a 2a 20 20 20 50 52  _store.  **   PR
37b0: 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 20  AGMA temp_store 
37c0: 3d 20 22 64 65 66 61 75 6c 74 22 7c 22 6d 65 6d  = "default"|"mem
37d0: 6f 72 79 22 7c 22 66 69 6c 65 22 0a 20 20 2a 2a  ory"|"file".  **
37e0: 0a 20 20 2a 2a 20 52 65 74 75 72 6e 20 6f 72 20  .  ** Return or 
37f0: 73 65 74 20 74 68 65 20 6c 6f 63 61 6c 20 76 61  set the local va
3800: 6c 75 65 20 6f 66 20 74 68 65 20 74 65 6d 70 5f  lue of the temp_
3810: 73 74 6f 72 65 20 66 6c 61 67 2e 20 20 43 68 61  store flag.  Cha
3820: 6e 67 69 6e 67 0a 20 20 2a 2a 20 74 68 65 20 6c  nging.  ** the l
3830: 6f 63 61 6c 20 76 61 6c 75 65 20 64 6f 65 73 20  ocal value does 
3840: 6e 6f 74 20 6d 61 6b 65 20 63 68 61 6e 67 65 73  not make changes
3850: 20 74 6f 20 74 68 65 20 64 69 73 6b 20 66 69 6c   to the disk fil
3860: 65 20 61 6e 64 20 74 68 65 20 64 65 66 61 75 6c  e and the defaul
3870: 74 0a 20 20 2a 2a 20 76 61 6c 75 65 20 77 69 6c  t.  ** value wil
3880: 6c 20 62 65 20 72 65 73 74 6f 72 65 64 20 74 68  l be restored th
3890: 65 20 6e 65 78 74 20 74 69 6d 65 20 74 68 65 20  e next time the 
38a0: 64 61 74 61 62 61 73 65 20 69 73 20 6f 70 65 6e  database is open
38b0: 65 64 2e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 4e 6f  ed..  **.  ** No
38c0: 74 65 20 74 68 61 74 20 69 74 20 69 73 20 70 6f  te that it is po
38d0: 73 73 69 62 6c 65 20 66 6f 72 20 74 68 65 20 6c  ssible for the l
38e0: 69 62 72 61 72 79 20 63 6f 6d 70 69 6c 65 2d 74  ibrary compile-t
38f0: 69 6d 65 20 6f 70 74 69 6f 6e 73 20 74 6f 0a 20  ime options to. 
3900: 20 2a 2a 20 6f 76 65 72 72 69 64 65 20 74 68 69   ** override thi
3910: 73 20 73 65 74 74 69 6e 67 0a 20 20 2a 2f 0a 20  s setting.  */. 
3920: 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49   if( sqlite3StrI
3930: 43 6d 70 28 7a 4c 65 66 74 2c 20 22 74 65 6d 70  Cmp(zLeft, "temp
3940: 5f 73 74 6f 72 65 22 29 3d 3d 30 20 29 7b 0a 20  _store")==0 ){. 
3950: 20 20 20 69 66 28 20 21 7a 52 69 67 68 74 20 29     if( !zRight )
3960: 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 53 69  {.      returnSi
3970: 6e 67 6c 65 49 6e 74 28 70 50 61 72 73 65 2c 20  ngleInt(pParse, 
3980: 22 74 65 6d 70 5f 73 74 6f 72 65 22 2c 20 64 62  "temp_store", db
3990: 2d 3e 74 65 6d 70 5f 73 74 6f 72 65 29 3b 0a 20  ->temp_store);. 
39a0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
39b0: 63 68 61 6e 67 65 54 65 6d 70 53 74 6f 72 61 67  changeTempStorag
39c0: 65 28 70 50 61 72 73 65 2c 20 7a 52 69 67 68 74  e(pParse, zRight
39d0: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65  );.    }.  }else
39e0: 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20 50 52  ..  /*.  **   PR
39f0: 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 5f  AGMA temp_store_
3a00: 64 69 72 65 63 74 6f 72 79 0a 20 20 2a 2a 20 20  directory.  **  
3a10: 20 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f   PRAGMA temp_sto
3a20: 72 65 5f 64 69 72 65 63 74 6f 72 79 20 3d 20 22  re_directory = "
3a30: 22 7c 22 64 69 72 65 63 74 6f 72 79 5f 6e 61 6d  "|"directory_nam
3a40: 65 22 0a 20 20 2a 2a 0a 20 20 2a 2a 20 52 65 74  e".  **.  ** Ret
3a50: 75 72 6e 20 6f 72 20 73 65 74 20 74 68 65 20 6c  urn or set the l
3a60: 6f 63 61 6c 20 76 61 6c 75 65 20 6f 66 20 74 68  ocal value of th
3a70: 65 20 74 65 6d 70 5f 73 74 6f 72 65 5f 64 69 72  e temp_store_dir
3a80: 65 63 74 6f 72 79 20 66 6c 61 67 2e 20 20 43 68  ectory flag.  Ch
3a90: 61 6e 67 69 6e 67 0a 20 20 2a 2a 20 74 68 65 20  anging.  ** the 
3aa0: 76 61 6c 75 65 20 73 65 74 73 20 61 20 73 70 65  value sets a spe
3ab0: 63 69 66 69 63 20 64 69 72 65 63 74 6f 72 79 20  cific directory 
3ac0: 74 6f 20 62 65 20 75 73 65 64 20 66 6f 72 20 74  to be used for t
3ad0: 65 6d 70 6f 72 61 72 79 20 66 69 6c 65 73 2e 0a  emporary files..
3ae0: 20 20 2a 2a 20 53 65 74 74 69 6e 67 20 74 6f 20    ** Setting to 
3af0: 61 20 6e 75 6c 6c 20 73 74 72 69 6e 67 20 72 65  a null string re
3b00: 76 65 72 74 73 20 74 6f 20 74 68 65 20 64 65 66  verts to the def
3b10: 61 75 6c 74 20 74 65 6d 70 6f 72 61 72 79 20 64  ault temporary d
3b20: 69 72 65 63 74 6f 72 79 20 73 65 61 72 63 68 2e  irectory search.
3b30: 0a 20 20 2a 2a 20 49 66 20 74 65 6d 70 6f 72 61  .  ** If tempora
3b40: 72 79 20 64 69 72 65 63 74 6f 72 79 20 69 73 20  ry directory is 
3b50: 63 68 61 6e 67 65 64 2c 20 74 68 65 6e 20 69 6e  changed, then in
3b60: 76 61 6c 69 64 61 74 65 54 65 6d 70 53 74 6f 72  validateTempStor
3b70: 61 67 65 2e 0a 20 20 2a 2a 0a 20 20 2a 2f 0a 20  age..  **.  */. 
3b80: 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49   if( sqlite3StrI
3b90: 43 6d 70 28 7a 4c 65 66 74 2c 20 22 74 65 6d 70  Cmp(zLeft, "temp
3ba0: 5f 73 74 6f 72 65 5f 64 69 72 65 63 74 6f 72 79  _store_directory
3bb0: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 69 66 28  ")==0 ){.    if(
3bc0: 20 21 7a 52 69 67 68 74 20 29 7b 0a 20 20 20 20   !zRight ){.    
3bd0: 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f 74 65    if( sqlite3_te
3be0: 6d 70 5f 64 69 72 65 63 74 6f 72 79 20 29 7b 0a  mp_directory ){.
3bf0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
3c00: 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c  dbeSetNumCols(v,
3c10: 20 31 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c   1);.        sql
3c20: 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61  ite3VdbeSetColNa
3c30: 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45  me(v, 0, COLNAME
3c40: 5f 4e 41 4d 45 2c 20 0a 20 20 20 20 20 20 20 20  _NAME, .        
3c50: 20 20 20 20 22 74 65 6d 70 5f 73 74 6f 72 65 5f      "temp_store_
3c60: 64 69 72 65 63 74 6f 72 79 22 2c 20 50 33 5f 53  directory", P3_S
3c70: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20  TATIC);.        
3c80: 73 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76  sqlite3VdbeOp3(v
3c90: 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c  , OP_String8, 0,
3ca0: 20 30 2c 20 73 71 6c 69 74 65 33 5f 74 65 6d 70   0, sqlite3_temp
3cb0: 5f 64 69 72 65 63 74 6f 72 79 2c 20 30 29 3b 0a  _directory, 0);.
3cc0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
3cd0: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 43  dbeAddOp(v, OP_C
3ce0: 61 6c 6c 62 61 63 6b 2c 20 31 2c 20 30 29 3b 0a  allback, 1, 0);.
3cf0: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 65 6c 73        }.    }els
3d00: 65 7b 0a 20 20 20 20 20 20 69 66 28 20 7a 52 69  e{.      if( zRi
3d10: 67 68 74 5b 30 5d 20 26 26 20 21 73 71 6c 69 74  ght[0] && !sqlit
3d20: 65 33 4f 73 49 73 44 69 72 57 72 69 74 61 62 6c  e3OsIsDirWritabl
3d30: 65 28 7a 52 69 67 68 74 29 20 29 7b 0a 20 20 20  e(zRight) ){.   
3d40: 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f       sqlite3Erro
3d50: 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 6e 6f  rMsg(pParse, "no
3d60: 74 20 61 20 77 72 69 74 61 62 6c 65 20 64 69 72  t a writable dir
3d70: 65 63 74 6f 72 79 22 29 3b 0a 20 20 20 20 20 20  ectory");.      
3d80: 20 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75    goto pragma_ou
3d90: 74 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  t;.      }.     
3da0: 20 69 66 28 20 54 45 4d 50 5f 53 54 4f 52 45 3d   if( TEMP_STORE=
3db0: 3d 30 0a 20 20 20 20 20 20 20 7c 7c 20 28 54 45  =0.       || (TE
3dc0: 4d 50 5f 53 54 4f 52 45 3d 3d 31 20 26 26 20 64  MP_STORE==1 && d
3dd0: 62 2d 3e 74 65 6d 70 5f 73 74 6f 72 65 3c 3d 31  b->temp_store<=1
3de0: 29 0a 20 20 20 20 20 20 20 7c 7c 20 28 54 45 4d  ).       || (TEM
3df0: 50 5f 53 54 4f 52 45 3d 3d 32 20 26 26 20 64 62  P_STORE==2 && db
3e00: 2d 3e 74 65 6d 70 5f 73 74 6f 72 65 3d 3d 31 29  ->temp_store==1)
3e10: 0a 20 20 20 20 20 20 29 7b 0a 20 20 20 20 20 20  .      ){.      
3e20: 20 20 69 6e 76 61 6c 69 64 61 74 65 54 65 6d 70    invalidateTemp
3e30: 53 74 6f 72 61 67 65 28 70 50 61 72 73 65 29 3b  Storage(pParse);
3e40: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73  .      }.      s
3e50: 71 6c 69 74 65 46 72 65 65 28 73 71 6c 69 74 65  qliteFree(sqlite
3e60: 33 5f 74 65 6d 70 5f 64 69 72 65 63 74 6f 72 79  3_temp_directory
3e70: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 7a 52 69  );.      if( zRi
3e80: 67 68 74 5b 30 5d 20 29 7b 0a 20 20 20 20 20 20  ght[0] ){.      
3e90: 20 20 73 71 6c 69 74 65 33 5f 74 65 6d 70 5f 64    sqlite3_temp_d
3ea0: 69 72 65 63 74 6f 72 79 20 3d 20 7a 52 69 67 68  irectory = zRigh
3eb0: 74 3b 0a 20 20 20 20 20 20 20 20 7a 52 69 67 68  t;.        zRigh
3ec0: 74 20 3d 20 30 3b 0a 20 20 20 20 20 20 7d 65 6c  t = 0;.      }el
3ed0: 73 65 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  se{.        sqli
3ee0: 74 65 33 5f 74 65 6d 70 5f 64 69 72 65 63 74 6f  te3_temp_directo
3ef0: 72 79 20 3d 20 30 3b 0a 20 20 20 20 20 20 7d 0a  ry = 0;.      }.
3f00: 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20      }.  }else.. 
3f10: 20 2f 2a 0a 20 20 2a 2a 20 20 20 50 52 41 47 4d   /*.  **   PRAGM
3f20: 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 73 79 6e  A [database.]syn
3f30: 63 68 72 6f 6e 6f 75 73 0a 20 20 2a 2a 20 20 20  chronous.  **   
3f40: 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65  PRAGMA [database
3f50: 2e 5d 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f 46  .]synchronous=OF
3f60: 46 7c 4f 4e 7c 4e 4f 52 4d 41 4c 7c 46 55 4c 4c  F|ON|NORMAL|FULL
3f70: 0a 20 20 2a 2a 0a 20 20 2a 2a 20 52 65 74 75 72  .  **.  ** Retur
3f80: 6e 20 6f 72 20 73 65 74 20 74 68 65 20 6c 6f 63  n or set the loc
3f90: 61 6c 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20  al value of the 
3fa0: 73 79 6e 63 68 72 6f 6e 6f 75 73 20 66 6c 61 67  synchronous flag
3fb0: 2e 20 20 43 68 61 6e 67 69 6e 67 0a 20 20 2a 2a  .  Changing.  **
3fc0: 20 74 68 65 20 6c 6f 63 61 6c 20 76 61 6c 75 65   the local value
3fd0: 20 64 6f 65 73 20 6e 6f 74 20 6d 61 6b 65 20 63   does not make c
3fe0: 68 61 6e 67 65 73 20 74 6f 20 74 68 65 20 64 69  hanges to the di
3ff0: 73 6b 20 66 69 6c 65 20 61 6e 64 20 74 68 65 0a  sk file and the.
4000: 20 20 2a 2a 20 64 65 66 61 75 6c 74 20 76 61 6c    ** default val
4010: 75 65 20 77 69 6c 6c 20 62 65 20 72 65 73 74 6f  ue will be resto
4020: 72 65 64 20 74 68 65 20 6e 65 78 74 20 74 69 6d  red the next tim
4030: 65 20 74 68 65 20 64 61 74 61 62 61 73 65 20 69  e the database i
4040: 73 0a 20 20 2a 2a 20 6f 70 65 6e 65 64 2e 0a 20  s.  ** opened.. 
4050: 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65   */.  if( sqlite
4060: 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 22  3StrICmp(zLeft,"
4070: 73 79 6e 63 68 72 6f 6e 6f 75 73 22 29 3d 3d 30  synchronous")==0
4080: 20 29 7b 0a 20 20 20 20 69 66 28 20 73 71 6c 69   ){.    if( sqli
4090: 74 65 33 52 65 61 64 53 63 68 65 6d 61 28 70 50  te3ReadSchema(pP
40a0: 61 72 73 65 29 20 29 20 67 6f 74 6f 20 70 72 61  arse) ) goto pra
40b0: 67 6d 61 5f 6f 75 74 3b 0a 20 20 20 20 69 66 28  gma_out;.    if(
40c0: 20 21 7a 52 69 67 68 74 20 29 7b 0a 20 20 20 20   !zRight ){.    
40d0: 20 20 72 65 74 75 72 6e 53 69 6e 67 6c 65 49 6e    returnSingleIn
40e0: 74 28 70 50 61 72 73 65 2c 20 22 73 79 6e 63 68  t(pParse, "synch
40f0: 72 6f 6e 6f 75 73 22 2c 20 70 44 62 2d 3e 73 61  ronous", pDb->sa
4100: 66 65 74 79 5f 6c 65 76 65 6c 2d 31 29 3b 0a 20  fety_level-1);. 
4110: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
4120: 69 66 28 20 21 64 62 2d 3e 61 75 74 6f 43 6f 6d  if( !db->autoCom
4130: 6d 69 74 20 29 7b 0a 20 20 20 20 20 20 20 20 73  mit ){.        s
4140: 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70  qlite3ErrorMsg(p
4150: 50 61 72 73 65 2c 20 0a 20 20 20 20 20 20 20 20  Parse, .        
4160: 20 20 20 20 22 53 61 66 65 74 79 20 6c 65 76 65      "Safety leve
4170: 6c 20 6d 61 79 20 6e 6f 74 20 62 65 20 63 68 61  l may not be cha
4180: 6e 67 65 64 20 69 6e 73 69 64 65 20 61 20 74 72  nged inside a tr
4190: 61 6e 73 61 63 74 69 6f 6e 22 29 3b 0a 20 20 20  ansaction");.   
41a0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
41b0: 20 20 70 44 62 2d 3e 73 61 66 65 74 79 5f 6c 65    pDb->safety_le
41c0: 76 65 6c 20 3d 20 67 65 74 53 61 66 65 74 79 4c  vel = getSafetyL
41d0: 65 76 65 6c 28 7a 52 69 67 68 74 29 2b 31 3b 0a  evel(zRight)+1;.
41e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
41f0: 7d 65 6c 73 65 0a 23 65 6e 64 69 66 20 2f 2a 20  }else.#endif /* 
4200: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45  SQLITE_OMIT_PAGE
4210: 52 5f 50 52 41 47 4d 41 53 20 2a 2f 0a 0a 23 69  R_PRAGMAS */..#i
4220: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
4230: 54 5f 46 4c 41 47 5f 50 52 41 47 4d 41 53 0a 20  T_FLAG_PRAGMAS. 
4240: 20 69 66 28 20 66 6c 61 67 50 72 61 67 6d 61 28   if( flagPragma(
4250: 70 50 61 72 73 65 2c 20 7a 4c 65 66 74 2c 20 7a  pParse, zLeft, z
4260: 52 69 67 68 74 29 20 29 7b 0a 20 20 20 20 2f 2a  Right) ){.    /*
4270: 20 54 68 65 20 66 6c 61 67 50 72 61 67 6d 61 28   The flagPragma(
4280: 29 20 73 75 62 72 6f 75 74 69 6e 65 20 61 6c 73  ) subroutine als
4290: 6f 20 67 65 6e 65 72 61 74 65 73 20 61 6e 79 20  o generates any 
42a0: 6e 65 63 65 73 73 61 72 79 20 63 6f 64 65 0a 20  necessary code. 
42b0: 20 20 20 2a 2a 20 74 68 65 72 65 20 69 73 20 6e     ** there is n
42c0: 6f 74 68 69 6e 67 20 6d 6f 72 65 20 74 6f 20 64  othing more to d
42d0: 6f 20 68 65 72 65 20 2a 2f 0a 20 20 7d 65 6c 73  o here */.  }els
42e0: 65 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49  e.#endif /* SQLI
42f0: 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41  TE_OMIT_FLAG_PRA
4300: 47 4d 41 53 20 2a 2f 0a 0a 23 69 66 6e 64 65 66  GMAS */..#ifndef
4310: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48   SQLITE_OMIT_SCH
4320: 45 4d 41 5f 50 52 41 47 4d 41 53 0a 20 20 2f 2a  EMA_PRAGMAS.  /*
4330: 0a 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 74  .  **   PRAGMA t
4340: 61 62 6c 65 5f 69 6e 66 6f 28 3c 74 61 62 6c 65  able_info(<table
4350: 3e 29 0a 20 20 2a 2a 0a 20 20 2a 2a 20 52 65 74  >).  **.  ** Ret
4360: 75 72 6e 20 61 20 73 69 6e 67 6c 65 20 72 6f 77  urn a single row
4370: 20 66 6f 72 20 65 61 63 68 20 63 6f 6c 75 6d 6e   for each column
4380: 20 6f 66 20 74 68 65 20 6e 61 6d 65 64 20 74 61   of the named ta
4390: 62 6c 65 2e 20 54 68 65 20 63 6f 6c 75 6d 6e 73  ble. The columns
43a0: 20 6f 66 0a 20 20 2a 2a 20 74 68 65 20 72 65 74   of.  ** the ret
43b0: 75 72 6e 65 64 20 64 61 74 61 20 73 65 74 20 61  urned data set a
43c0: 72 65 3a 0a 20 20 2a 2a 0a 20 20 2a 2a 20 63 69  re:.  **.  ** ci
43d0: 64 3a 20 20 20 20 20 20 20 20 43 6f 6c 75 6d 6e  d:        Column
43e0: 20 69 64 20 28 6e 75 6d 62 65 72 65 64 20 66 72   id (numbered fr
43f0: 6f 6d 20 6c 65 66 74 20 74 6f 20 72 69 67 68 74  om left to right
4400: 2c 20 73 74 61 72 74 69 6e 67 20 61 74 20 30 29  , starting at 0)
4410: 0a 20 20 2a 2a 20 6e 61 6d 65 3a 20 20 20 20 20  .  ** name:     
4420: 20 20 43 6f 6c 75 6d 6e 20 6e 61 6d 65 0a 20 20    Column name.  
4430: 2a 2a 20 74 79 70 65 3a 20 20 20 20 20 20 20 43  ** type:       C
4440: 6f 6c 75 6d 6e 20 64 65 63 6c 61 72 61 74 69 6f  olumn declaratio
4450: 6e 20 74 79 70 65 2e 0a 20 20 2a 2a 20 6e 6f 74  n type..  ** not
4460: 6e 75 6c 6c 3a 20 20 20 20 54 72 75 65 20 69 66  null:    True if
4470: 20 27 4e 4f 54 20 4e 55 4c 4c 27 20 69 73 20 70   'NOT NULL' is p
4480: 61 72 74 20 6f 66 20 63 6f 6c 75 6d 6e 20 64 65  art of column de
4490: 63 6c 61 72 61 74 69 6f 6e 0a 20 20 2a 2a 20 64  claration.  ** d
44a0: 66 6c 74 5f 76 61 6c 75 65 3a 20 54 68 65 20 64  flt_value: The d
44b0: 65 66 61 75 6c 74 20 76 61 6c 75 65 20 66 6f 72  efault value for
44c0: 20 74 68 65 20 63 6f 6c 75 6d 6e 2c 20 69 66 20   the column, if 
44d0: 61 6e 79 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20  any..  */.  if( 
44e0: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
44f0: 4c 65 66 74 2c 20 22 74 61 62 6c 65 5f 69 6e 66  Left, "table_inf
4500: 6f 22 29 3d 3d 30 20 26 26 20 7a 52 69 67 68 74  o")==0 && zRight
4510: 20 29 7b 0a 20 20 20 20 54 61 62 6c 65 20 2a 70   ){.    Table *p
4520: 54 61 62 3b 0a 20 20 20 20 69 66 28 20 73 71 6c  Tab;.    if( sql
4530: 69 74 65 33 52 65 61 64 53 63 68 65 6d 61 28 70  ite3ReadSchema(p
4540: 50 61 72 73 65 29 20 29 20 67 6f 74 6f 20 70 72  Parse) ) goto pr
4550: 61 67 6d 61 5f 6f 75 74 3b 0a 20 20 20 20 70 54  agma_out;.    pT
4560: 61 62 20 3d 20 73 71 6c 69 74 65 33 46 69 6e 64  ab = sqlite3Find
4570: 54 61 62 6c 65 28 64 62 2c 20 7a 52 69 67 68 74  Table(db, zRight
4580: 2c 20 7a 44 62 29 3b 0a 20 20 20 20 69 66 28 20  , zDb);.    if( 
4590: 70 54 61 62 20 29 7b 0a 20 20 20 20 20 20 69 6e  pTab ){.      in
45a0: 74 20 69 3b 0a 20 20 20 20 20 20 43 6f 6c 75 6d  t i;.      Colum
45b0: 6e 20 2a 70 43 6f 6c 3b 0a 20 20 20 20 20 20 73  n *pCol;.      s
45c0: 71 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75 6d  qlite3VdbeSetNum
45d0: 43 6f 6c 73 28 76 2c 20 36 29 3b 0a 20 20 20 20  Cols(v, 6);.    
45e0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74    sqlite3VdbeSet
45f0: 43 6f 6c 4e 61 6d 65 28 76 2c 20 30 2c 20 43 4f  ColName(v, 0, CO
4600: 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 63 69 64  LNAME_NAME, "cid
4610: 22 2c 20 50 33 5f 53 54 41 54 49 43 29 3b 0a 20  ", P3_STATIC);. 
4620: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
4630: 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 31 2c  SetColName(v, 1,
4640: 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22   COLNAME_NAME, "
4650: 6e 61 6d 65 22 2c 20 50 33 5f 53 54 41 54 49 43  name", P3_STATIC
4660: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
4670: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
4680: 2c 20 32 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 2, COLNAME_NAM
4690: 45 2c 20 22 74 79 70 65 22 2c 20 50 33 5f 53 54  E, "type", P3_ST
46a0: 41 54 49 43 29 3b 0a 20 20 20 20 20 20 73 71 6c  ATIC);.      sql
46b0: 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61  ite3VdbeSetColNa
46c0: 6d 65 28 76 2c 20 33 2c 20 43 4f 4c 4e 41 4d 45  me(v, 3, COLNAME
46d0: 5f 4e 41 4d 45 2c 20 22 6e 6f 74 6e 75 6c 6c 22  _NAME, "notnull"
46e0: 2c 20 50 33 5f 53 54 41 54 49 43 29 3b 0a 20 20  , P3_STATIC);.  
46f0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
4700: 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 34 2c 20  etColName(v, 4, 
4710: 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 64  COLNAME_NAME, "d
4720: 66 6c 74 5f 76 61 6c 75 65 22 2c 20 50 33 5f 53  flt_value", P3_S
4730: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 73 71  TATIC);.      sq
4740: 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e  lite3VdbeSetColN
4750: 61 6d 65 28 76 2c 20 35 2c 20 43 4f 4c 4e 41 4d  ame(v, 5, COLNAM
4760: 45 5f 4e 41 4d 45 2c 20 22 70 6b 22 2c 20 50 33  E_NAME, "pk", P3
4770: 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20  _STATIC);.      
4780: 73 71 6c 69 74 65 33 56 69 65 77 47 65 74 43 6f  sqlite3ViewGetCo
4790: 6c 75 6d 6e 4e 61 6d 65 73 28 70 50 61 72 73 65  lumnNames(pParse
47a0: 2c 20 70 54 61 62 29 3b 0a 20 20 20 20 20 20 66  , pTab);.      f
47b0: 6f 72 28 69 3d 30 2c 20 70 43 6f 6c 3d 70 54 61  or(i=0, pCol=pTa
47c0: 62 2d 3e 61 43 6f 6c 3b 20 69 3c 70 54 61 62 2d  b->aCol; i<pTab-
47d0: 3e 6e 43 6f 6c 3b 20 69 2b 2b 2c 20 70 43 6f 6c  >nCol; i++, pCol
47e0: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 63 6f 6e  ++){.        con
47f0: 73 74 20 54 6f 6b 65 6e 20 2a 70 44 66 6c 74 3b  st Token *pDflt;
4800: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
4810: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
4820: 49 6e 74 65 67 65 72 2c 20 69 2c 20 30 29 3b 0a  Integer, i, 0);.
4830: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
4840: 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72  dbeOp3(v, OP_Str
4850: 69 6e 67 38 2c 20 30 2c 20 30 2c 20 70 43 6f 6c  ing8, 0, 0, pCol
4860: 2d 3e 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 20  ->zName, 0);.   
4870: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
4880: 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67  Op3(v, OP_String
4890: 38 2c 20 30 2c 20 30 2c 0a 20 20 20 20 20 20 20  8, 0, 0,.       
48a0: 20 20 20 20 70 43 6f 6c 2d 3e 7a 54 79 70 65 20      pCol->zType 
48b0: 3f 20 70 43 6f 6c 2d 3e 7a 54 79 70 65 20 3a 20  ? pCol->zType : 
48c0: 22 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20  "", 0);.        
48d0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
48e0: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
48f0: 70 43 6f 6c 2d 3e 6e 6f 74 4e 75 6c 6c 2c 20 30  pCol->notNull, 0
4900: 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70  );.        if( p
4910: 43 6f 6c 2d 3e 70 44 66 6c 74 20 26 26 20 28 70  Col->pDflt && (p
4920: 44 66 6c 74 20 3d 20 26 70 43 6f 6c 2d 3e 70 44  Dflt = &pCol->pD
4930: 66 6c 74 2d 3e 73 70 61 6e 29 2d 3e 7a 20 29 7b  flt->span)->z ){
4940: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
4950: 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f  e3VdbeOp3(v, OP_
4960: 53 74 72 69 6e 67 38 2c 20 30 2c 20 30 2c 20 28  String8, 0, 0, (
4970: 63 68 61 72 2a 29 70 44 66 6c 74 2d 3e 7a 2c 20  char*)pDflt->z, 
4980: 70 44 66 6c 74 2d 3e 6e 29 3b 0a 20 20 20 20 20  pDflt->n);.     
4990: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
49a0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
49b0: 64 64 4f 70 28 76 2c 20 4f 50 5f 4e 75 6c 6c 2c  ddOp(v, OP_Null,
49c0: 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20   0, 0);.        
49d0: 7d 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  }.        sqlite
49e0: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
49f0: 5f 49 6e 74 65 67 65 72 2c 20 70 43 6f 6c 2d 3e  _Integer, pCol->
4a00: 69 73 50 72 69 6d 4b 65 79 2c 20 30 29 3b 0a 20  isPrimKey, 0);. 
4a10: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
4a20: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 43 61  beAddOp(v, OP_Ca
4a30: 6c 6c 62 61 63 6b 2c 20 36 2c 20 30 29 3b 0a 20  llback, 6, 0);. 
4a40: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d       }.    }.  }
4a50: 65 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c 69  else..  if( sqli
4a60: 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74  te3StrICmp(zLeft
4a70: 2c 20 22 69 6e 64 65 78 5f 69 6e 66 6f 22 29 3d  , "index_info")=
4a80: 3d 30 20 26 26 20 7a 52 69 67 68 74 20 29 7b 0a  =0 && zRight ){.
4a90: 20 20 20 20 49 6e 64 65 78 20 2a 70 49 64 78 3b      Index *pIdx;
4aa0: 0a 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62  .    Table *pTab
4ab0: 3b 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65  ;.    if( sqlite
4ac0: 33 52 65 61 64 53 63 68 65 6d 61 28 70 50 61 72  3ReadSchema(pPar
4ad0: 73 65 29 20 29 20 67 6f 74 6f 20 70 72 61 67 6d  se) ) goto pragm
4ae0: 61 5f 6f 75 74 3b 0a 20 20 20 20 70 49 64 78 20  a_out;.    pIdx 
4af0: 3d 20 73 71 6c 69 74 65 33 46 69 6e 64 49 6e 64  = sqlite3FindInd
4b00: 65 78 28 64 62 2c 20 7a 52 69 67 68 74 2c 20 7a  ex(db, zRight, z
4b10: 44 62 29 3b 0a 20 20 20 20 69 66 28 20 70 49 64  Db);.    if( pId
4b20: 78 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69  x ){.      int i
4b30: 3b 0a 20 20 20 20 20 20 70 54 61 62 20 3d 20 70  ;.      pTab = p
4b40: 49 64 78 2d 3e 70 54 61 62 6c 65 3b 0a 20 20 20  Idx->pTable;.   
4b50: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65     sqlite3VdbeSe
4b60: 74 4e 75 6d 43 6f 6c 73 28 76 2c 20 33 29 3b 0a  tNumCols(v, 3);.
4b70: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
4b80: 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 30  eSetColName(v, 0
4b90: 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20  , COLNAME_NAME, 
4ba0: 22 73 65 71 6e 6f 22 2c 20 50 33 5f 53 54 41 54  "seqno", P3_STAT
4bb0: 49 43 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  IC);.      sqlit
4bc0: 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65  e3VdbeSetColName
4bd0: 28 76 2c 20 31 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  (v, 1, COLNAME_N
4be0: 41 4d 45 2c 20 22 63 69 64 22 2c 20 50 33 5f 53  AME, "cid", P3_S
4bf0: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 73 71  TATIC);.      sq
4c00: 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e  lite3VdbeSetColN
4c10: 61 6d 65 28 76 2c 20 32 2c 20 43 4f 4c 4e 41 4d  ame(v, 2, COLNAM
4c20: 45 5f 4e 41 4d 45 2c 20 22 6e 61 6d 65 22 2c 20  E_NAME, "name", 
4c30: 50 33 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  P3_STATIC);.    
4c40: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 49 64    for(i=0; i<pId
4c50: 78 2d 3e 6e 43 6f 6c 75 6d 6e 3b 20 69 2b 2b 29  x->nColumn; i++)
4c60: 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 63 6e  {.        int cn
4c70: 75 6d 20 3d 20 70 49 64 78 2d 3e 61 69 43 6f 6c  um = pIdx->aiCol
4c80: 75 6d 6e 5b 69 5d 3b 0a 20 20 20 20 20 20 20 20  umn[i];.        
4c90: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
4ca0: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
4cb0: 69 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  i, 0);.        s
4cc0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28  qlite3VdbeAddOp(
4cd0: 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 63  v, OP_Integer, c
4ce0: 6e 75 6d 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  num, 0);.       
4cf0: 20 61 73 73 65 72 74 28 20 70 54 61 62 2d 3e 6e   assert( pTab->n
4d00: 43 6f 6c 3e 63 6e 75 6d 20 29 3b 0a 20 20 20 20  Col>cnum );.    
4d10: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 4f      sqlite3VdbeO
4d20: 70 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38  p3(v, OP_String8
4d30: 2c 20 30 2c 20 30 2c 20 70 54 61 62 2d 3e 61 43  , 0, 0, pTab->aC
4d40: 6f 6c 5b 63 6e 75 6d 5d 2e 7a 4e 61 6d 65 2c 20  ol[cnum].zName, 
4d50: 30 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  0);.        sqli
4d60: 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20  te3VdbeAddOp(v, 
4d70: 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 33 2c 20  OP_Callback, 3, 
4d80: 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  0);.      }.    
4d90: 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 69 66 28  }.  }else..  if(
4da0: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
4db0: 7a 4c 65 66 74 2c 20 22 69 6e 64 65 78 5f 6c 69  zLeft, "index_li
4dc0: 73 74 22 29 3d 3d 30 20 26 26 20 7a 52 69 67 68  st")==0 && zRigh
4dd0: 74 20 29 7b 0a 20 20 20 20 49 6e 64 65 78 20 2a  t ){.    Index *
4de0: 70 49 64 78 3b 0a 20 20 20 20 54 61 62 6c 65 20  pIdx;.    Table 
4df0: 2a 70 54 61 62 3b 0a 20 20 20 20 69 66 28 20 73  *pTab;.    if( s
4e00: 71 6c 69 74 65 33 52 65 61 64 53 63 68 65 6d 61  qlite3ReadSchema
4e10: 28 70 50 61 72 73 65 29 20 29 20 67 6f 74 6f 20  (pParse) ) goto 
4e20: 70 72 61 67 6d 61 5f 6f 75 74 3b 0a 20 20 20 20  pragma_out;.    
4e30: 70 54 61 62 20 3d 20 73 71 6c 69 74 65 33 46 69  pTab = sqlite3Fi
4e40: 6e 64 54 61 62 6c 65 28 64 62 2c 20 7a 52 69 67  ndTable(db, zRig
4e50: 68 74 2c 20 7a 44 62 29 3b 0a 20 20 20 20 69 66  ht, zDb);.    if
4e60: 28 20 70 54 61 62 20 29 7b 0a 20 20 20 20 20 20  ( pTab ){.      
4e70: 76 20 3d 20 73 71 6c 69 74 65 33 47 65 74 56 64  v = sqlite3GetVd
4e80: 62 65 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20  be(pParse);.    
4e90: 20 20 70 49 64 78 20 3d 20 70 54 61 62 2d 3e 70    pIdx = pTab->p
4ea0: 49 6e 64 65 78 3b 0a 20 20 20 20 20 20 69 66 28  Index;.      if(
4eb0: 20 70 49 64 78 20 29 7b 0a 20 20 20 20 20 20 20   pIdx ){.       
4ec0: 20 69 6e 74 20 69 20 3d 20 30 3b 20 0a 20 20 20   int i = 0; .   
4ed0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
4ee0: 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20 33 29  SetNumCols(v, 3)
4ef0: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
4f00: 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28  3VdbeSetColName(
4f10: 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41  v, 0, COLNAME_NA
4f20: 4d 45 2c 20 22 73 65 71 22 2c 20 50 33 5f 53 54  ME, "seq", P3_ST
4f30: 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 73  ATIC);.        s
4f40: 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c  qlite3VdbeSetCol
4f50: 4e 61 6d 65 28 76 2c 20 31 2c 20 43 4f 4c 4e 41  Name(v, 1, COLNA
4f60: 4d 45 5f 4e 41 4d 45 2c 20 22 6e 61 6d 65 22 2c  ME_NAME, "name",
4f70: 20 50 33 5f 53 54 41 54 49 43 29 3b 0a 20 20 20   P3_STATIC);.   
4f80: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
4f90: 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 32 2c  SetColName(v, 2,
4fa0: 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22   COLNAME_NAME, "
4fb0: 75 6e 69 71 75 65 22 2c 20 50 33 5f 53 54 41 54  unique", P3_STAT
4fc0: 49 43 29 3b 0a 20 20 20 20 20 20 20 20 77 68 69  IC);.        whi
4fd0: 6c 65 28 70 49 64 78 29 7b 0a 20 20 20 20 20 20  le(pIdx){.      
4fe0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
4ff0: 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67  ddOp(v, OP_Integ
5000: 65 72 2c 20 69 2c 20 30 29 3b 0a 20 20 20 20 20  er, i, 0);.     
5010: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
5020: 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67  Op3(v, OP_String
5030: 38 2c 20 30 2c 20 30 2c 20 70 49 64 78 2d 3e 7a  8, 0, 0, pIdx->z
5040: 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 20 20 20 20  Name, 0);.      
5050: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
5060: 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67  ddOp(v, OP_Integ
5070: 65 72 2c 20 70 49 64 78 2d 3e 6f 6e 45 72 72 6f  er, pIdx->onErro
5080: 72 21 3d 4f 45 5f 4e 6f 6e 65 2c 20 30 29 3b 0a  r!=OE_None, 0);.
5090: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
50a0: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
50b0: 5f 43 61 6c 6c 62 61 63 6b 2c 20 33 2c 20 30 29  _Callback, 3, 0)
50c0: 3b 0a 20 20 20 20 20 20 20 20 20 20 2b 2b 69 3b  ;.          ++i;
50d0: 0a 20 20 20 20 20 20 20 20 20 20 70 49 64 78 20  .          pIdx 
50e0: 3d 20 70 49 64 78 2d 3e 70 4e 65 78 74 3b 0a 20  = pIdx->pNext;. 
50f0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
5100: 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a  .    }.  }else..
5110: 20 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72    if( sqlite3Str
5120: 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 64 61 74  ICmp(zLeft, "dat
5130: 61 62 61 73 65 5f 6c 69 73 74 22 29 3d 3d 30 20  abase_list")==0 
5140: 29 7b 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20 20  ){.    int i;.  
5150: 20 20 69 66 28 20 73 71 6c 69 74 65 33 52 65 61    if( sqlite3Rea
5160: 64 53 63 68 65 6d 61 28 70 50 61 72 73 65 29 20  dSchema(pParse) 
5170: 29 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75  ) goto pragma_ou
5180: 74 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  t;.    sqlite3Vd
5190: 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20  beSetNumCols(v, 
51a0: 33 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  3);.    sqlite3V
51b0: 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c  dbeSetColName(v,
51c0: 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45   0, COLNAME_NAME
51d0: 2c 20 22 73 65 71 22 2c 20 50 33 5f 53 54 41 54  , "seq", P3_STAT
51e0: 49 43 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  IC);.    sqlite3
51f0: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
5200: 2c 20 31 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 1, COLNAME_NAM
5210: 45 2c 20 22 6e 61 6d 65 22 2c 20 50 33 5f 53 54  E, "name", P3_ST
5220: 41 54 49 43 29 3b 0a 20 20 20 20 73 71 6c 69 74  ATIC);.    sqlit
5230: 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65  e3VdbeSetColName
5240: 28 76 2c 20 32 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  (v, 2, COLNAME_N
5250: 41 4d 45 2c 20 22 66 69 6c 65 22 2c 20 50 33 5f  AME, "file", P3_
5260: 53 54 41 54 49 43 29 3b 0a 20 20 20 20 66 6f 72  STATIC);.    for
5270: 28 69 3d 30 3b 20 69 3c 64 62 2d 3e 6e 44 62 3b  (i=0; i<db->nDb;
5280: 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 69 66 28   i++){.      if(
5290: 20 64 62 2d 3e 61 44 62 5b 69 5d 2e 70 42 74 3d   db->aDb[i].pBt=
52a0: 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20  =0 ) continue;. 
52b0: 20 20 20 20 20 61 73 73 65 72 74 28 20 64 62 2d       assert( db-
52c0: 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 21 3d 30  >aDb[i].zName!=0
52d0: 20 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   );.      sqlite
52e0: 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50  3VdbeAddOp(v, OP
52f0: 5f 49 6e 74 65 67 65 72 2c 20 69 2c 20 30 29 3b  _Integer, i, 0);
5300: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
5310: 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72 69  beOp3(v, OP_Stri
5320: 6e 67 38 2c 20 30 2c 20 30 2c 20 64 62 2d 3e 61  ng8, 0, 0, db->a
5330: 44 62 5b 69 5d 2e 7a 4e 61 6d 65 2c 20 30 29 3b  Db[i].zName, 0);
5340: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
5350: 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72 69  beOp3(v, OP_Stri
5360: 6e 67 38 2c 20 30 2c 20 30 2c 0a 20 20 20 20 20  ng8, 0, 0,.     
5370: 20 20 20 20 20 20 73 71 6c 69 74 65 33 42 74 72        sqlite3Btr
5380: 65 65 47 65 74 46 69 6c 65 6e 61 6d 65 28 64 62  eeGetFilename(db
5390: 2d 3e 61 44 62 5b 69 5d 2e 70 42 74 29 2c 20 30  ->aDb[i].pBt), 0
53a0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
53b0: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
53c0: 43 61 6c 6c 62 61 63 6b 2c 20 33 2c 20 30 29 3b  Callback, 3, 0);
53d0: 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a  .    }.  }else..
53e0: 20 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72    if( sqlite3Str
53f0: 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 63 6f 6c  ICmp(zLeft, "col
5400: 6c 61 74 69 6f 6e 5f 6c 69 73 74 22 29 3d 3d 30  lation_list")==0
5410: 20 29 7b 0a 20 20 20 20 69 6e 74 20 69 20 3d 20   ){.    int i = 
5420: 30 3b 0a 20 20 20 20 48 61 73 68 45 6c 65 6d 20  0;.    HashElem 
5430: 2a 70 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  *p;.    sqlite3V
5440: 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c  dbeSetNumCols(v,
5450: 20 32 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33   2);.    sqlite3
5460: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
5470: 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 0, COLNAME_NAM
5480: 45 2c 20 22 73 65 71 22 2c 20 50 33 5f 53 54 41  E, "seq", P3_STA
5490: 54 49 43 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  TIC);.    sqlite
54a0: 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28  3VdbeSetColName(
54b0: 76 2c 20 31 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41  v, 1, COLNAME_NA
54c0: 4d 45 2c 20 22 6e 61 6d 65 22 2c 20 50 33 5f 53  ME, "name", P3_S
54d0: 54 41 54 49 43 29 3b 0a 20 20 20 20 66 6f 72 28  TATIC);.    for(
54e0: 70 3d 73 71 6c 69 74 65 48 61 73 68 46 69 72 73  p=sqliteHashFirs
54f0: 74 28 26 64 62 2d 3e 61 43 6f 6c 6c 53 65 71 29  t(&db->aCollSeq)
5500: 3b 20 70 3b 20 70 3d 73 71 6c 69 74 65 48 61 73  ; p; p=sqliteHas
5510: 68 4e 65 78 74 28 70 29 29 7b 0a 20 20 20 20 20  hNext(p)){.     
5520: 20 43 6f 6c 6c 53 65 71 20 2a 70 43 6f 6c 6c 20   CollSeq *pColl 
5530: 3d 20 28 43 6f 6c 6c 53 65 71 20 2a 29 73 71 6c  = (CollSeq *)sql
5540: 69 74 65 48 61 73 68 44 61 74 61 28 70 29 3b 0a  iteHashData(p);.
5550: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
5560: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74  eAddOp(v, OP_Int
5570: 65 67 65 72 2c 20 69 2b 2b 2c 20 30 29 3b 0a 20  eger, i++, 0);. 
5580: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
5590: 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67  Op3(v, OP_String
55a0: 38 2c 20 30 2c 20 30 2c 20 70 43 6f 6c 6c 2d 3e  8, 0, 0, pColl->
55b0: 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 20 20 20  zName, 0);.     
55c0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
55d0: 70 28 76 2c 20 4f 50 5f 43 61 6c 6c 62 61 63 6b  p(v, OP_Callback
55e0: 2c 20 32 2c 20 30 29 3b 0a 20 20 20 20 7d 0a 20  , 2, 0);.    }. 
55f0: 20 7d 65 6c 73 65 0a 23 65 6e 64 69 66 20 2f 2a   }else.#endif /*
5600: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48   SQLITE_OMIT_SCH
5610: 45 4d 41 5f 50 52 41 47 4d 41 53 20 2a 2f 0a 0a  EMA_PRAGMAS */..
5620: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
5630: 4d 49 54 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 0a  MIT_FOREIGN_KEY.
5640: 20 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72    if( sqlite3Str
5650: 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 66 6f 72  ICmp(zLeft, "for
5660: 65 69 67 6e 5f 6b 65 79 5f 6c 69 73 74 22 29 3d  eign_key_list")=
5670: 3d 30 20 26 26 20 7a 52 69 67 68 74 20 29 7b 0a  =0 && zRight ){.
5680: 20 20 20 20 46 4b 65 79 20 2a 70 46 4b 3b 0a 20      FKey *pFK;. 
5690: 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a     Table *pTab;.
56a0: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 52      if( sqlite3R
56b0: 65 61 64 53 63 68 65 6d 61 28 70 50 61 72 73 65  eadSchema(pParse
56c0: 29 20 29 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f  ) ) goto pragma_
56d0: 6f 75 74 3b 0a 20 20 20 20 70 54 61 62 20 3d 20  out;.    pTab = 
56e0: 73 71 6c 69 74 65 33 46 69 6e 64 54 61 62 6c 65  sqlite3FindTable
56f0: 28 64 62 2c 20 7a 52 69 67 68 74 2c 20 7a 44 62  (db, zRight, zDb
5700: 29 3b 0a 20 20 20 20 69 66 28 20 70 54 61 62 20  );.    if( pTab 
5710: 29 7b 0a 20 20 20 20 20 20 76 20 3d 20 73 71 6c  ){.      v = sql
5720: 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72  ite3GetVdbe(pPar
5730: 73 65 29 3b 0a 20 20 20 20 20 20 70 46 4b 20 3d  se);.      pFK =
5740: 20 70 54 61 62 2d 3e 70 46 4b 65 79 3b 0a 20 20   pTab->pFKey;.  
5750: 20 20 20 20 69 66 28 20 70 46 4b 20 29 7b 0a 20      if( pFK ){. 
5760: 20 20 20 20 20 20 20 69 6e 74 20 69 20 3d 20 30         int i = 0
5770: 3b 20 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ; .        sqlit
5780: 65 33 56 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73  e3VdbeSetNumCols
5790: 28 76 2c 20 35 29 3b 0a 20 20 20 20 20 20 20 20  (v, 5);.        
57a0: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f  sqlite3VdbeSetCo
57b0: 6c 4e 61 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e  lName(v, 0, COLN
57c0: 41 4d 45 5f 4e 41 4d 45 2c 20 22 69 64 22 2c 20  AME_NAME, "id", 
57d0: 50 33 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  P3_STATIC);.    
57e0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
57f0: 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 31 2c 20  etColName(v, 1, 
5800: 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 73  COLNAME_NAME, "s
5810: 65 71 22 2c 20 50 33 5f 53 54 41 54 49 43 29 3b  eq", P3_STATIC);
5820: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
5830: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
5840: 2c 20 32 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 2, COLNAME_NAM
5850: 45 2c 20 22 74 61 62 6c 65 22 2c 20 50 33 5f 53  E, "table", P3_S
5860: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20  TATIC);.        
5870: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f  sqlite3VdbeSetCo
5880: 6c 4e 61 6d 65 28 76 2c 20 33 2c 20 43 4f 4c 4e  lName(v, 3, COLN
5890: 41 4d 45 5f 4e 41 4d 45 2c 20 22 66 72 6f 6d 22  AME_NAME, "from"
58a0: 2c 20 50 33 5f 53 54 41 54 49 43 29 3b 0a 20 20  , P3_STATIC);.  
58b0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
58c0: 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 34  eSetColName(v, 4
58d0: 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20  , COLNAME_NAME, 
58e0: 22 74 6f 22 2c 20 50 33 5f 53 54 41 54 49 43 29  "to", P3_STATIC)
58f0: 3b 0a 20 20 20 20 20 20 20 20 77 68 69 6c 65 28  ;.        while(
5900: 70 46 4b 29 7b 0a 20 20 20 20 20 20 20 20 20 20  pFK){.          
5910: 69 6e 74 20 6a 3b 0a 20 20 20 20 20 20 20 20 20  int j;.         
5920: 20 66 6f 72 28 6a 3d 30 3b 20 6a 3c 70 46 4b 2d   for(j=0; j<pFK-
5930: 3e 6e 43 6f 6c 3b 20 6a 2b 2b 29 7b 0a 20 20 20  >nCol; j++){.   
5940: 20 20 20 20 20 20 20 20 20 63 68 61 72 20 2a 7a           char *z
5950: 43 6f 6c 20 3d 20 70 46 4b 2d 3e 61 43 6f 6c 5b  Col = pFK->aCol[
5960: 6a 5d 2e 7a 43 6f 6c 3b 0a 20 20 20 20 20 20 20  j].zCol;.       
5970: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
5980: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65  AddOp(v, OP_Inte
5990: 67 65 72 2c 20 69 2c 20 30 29 3b 0a 20 20 20 20  ger, i, 0);.    
59a0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
59b0: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49  dbeAddOp(v, OP_I
59c0: 6e 74 65 67 65 72 2c 20 6a 2c 20 30 29 3b 0a 20  nteger, j, 0);. 
59d0: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
59e0: 65 33 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f  e3VdbeOp3(v, OP_
59f0: 53 74 72 69 6e 67 38 2c 20 30 2c 20 30 2c 20 70  String8, 0, 0, p
5a00: 46 4b 2d 3e 7a 54 6f 2c 20 30 29 3b 0a 20 20 20  FK->zTo, 0);.   
5a10: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
5a20: 56 64 62 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74  VdbeOp3(v, OP_St
5a30: 72 69 6e 67 38 2c 20 30 2c 20 30 2c 0a 20 20 20  ring8, 0, 0,.   
5a40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5a50: 20 20 20 20 20 20 20 20 20 20 70 54 61 62 2d 3e            pTab->
5a60: 61 43 6f 6c 5b 70 46 4b 2d 3e 61 43 6f 6c 5b 6a  aCol[pFK->aCol[j
5a70: 5d 2e 69 46 72 6f 6d 5d 2e 7a 4e 61 6d 65 2c 20  ].iFrom].zName, 
5a80: 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  0);.            
5a90: 73 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76  sqlite3VdbeOp3(v
5aa0: 2c 20 7a 43 6f 6c 20 3f 20 4f 50 5f 53 74 72 69  , zCol ? OP_Stri
5ab0: 6e 67 38 20 3a 20 4f 50 5f 4e 75 6c 6c 2c 20 30  ng8 : OP_Null, 0
5ac0: 2c 20 30 2c 20 7a 43 6f 6c 2c 20 30 29 3b 0a 20  , 0, zCol, 0);. 
5ad0: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
5ae0: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
5af0: 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 35 2c 20 30  P_Callback, 5, 0
5b00: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  );.          }. 
5b10: 20 20 20 20 20 20 20 20 20 2b 2b 69 3b 0a 20 20           ++i;.  
5b20: 20 20 20 20 20 20 20 20 70 46 4b 20 3d 20 70 46          pFK = pF
5b30: 4b 2d 3e 70 4e 65 78 74 46 72 6f 6d 3b 0a 20 20  K->pNextFrom;.  
5b40: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
5b50: 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 23 65      }.  }else.#e
5b60: 6e 64 69 66 20 2f 2a 20 21 64 65 66 69 6e 65 64  ndif /* !defined
5b70: 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4f 52  (SQLITE_OMIT_FOR
5b80: 45 49 47 4e 5f 4b 45 59 29 20 2a 2f 0a 0a 23 69  EIGN_KEY) */..#i
5b90: 66 6e 64 65 66 20 4e 44 45 42 55 47 0a 20 20 69  fndef NDEBUG.  i
5ba0: 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d  f( sqlite3StrICm
5bb0: 70 28 7a 4c 65 66 74 2c 20 22 70 61 72 73 65 72  p(zLeft, "parser
5bc0: 5f 74 72 61 63 65 22 29 3d 3d 30 20 29 7b 0a 20  _trace")==0 ){. 
5bd0: 20 20 20 65 78 74 65 72 6e 20 76 6f 69 64 20 73     extern void s
5be0: 71 6c 69 74 65 33 50 61 72 73 65 72 54 72 61 63  qlite3ParserTrac
5bf0: 65 28 46 49 4c 45 2a 2c 20 63 68 61 72 20 2a 29  e(FILE*, char *)
5c00: 3b 0a 20 20 20 20 69 66 28 20 7a 52 69 67 68 74  ;.    if( zRight
5c10: 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20 67 65   ){.      if( ge
5c20: 74 42 6f 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29  tBoolean(zRight)
5c30: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
5c40: 74 65 33 50 61 72 73 65 72 54 72 61 63 65 28 73  te3ParserTrace(s
5c50: 74 64 65 72 72 2c 20 22 70 61 72 73 65 72 3a 20  tderr, "parser: 
5c60: 22 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b  ");.      }else{
5c70: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
5c80: 50 61 72 73 65 72 54 72 61 63 65 28 30 2c 20 30  ParserTrace(0, 0
5c90: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
5ca0: 0a 20 20 7d 65 6c 73 65 0a 23 65 6e 64 69 66 0a  .  }else.#endif.
5cb0: 0a 20 20 2f 2a 20 52 65 69 6e 73 74 61 6c 6c 20  .  /* Reinstall 
5cc0: 74 68 65 20 4c 49 4b 45 20 61 6e 64 20 47 4c 4f  the LIKE and GLO
5cd0: 42 20 66 75 6e 63 74 69 6f 6e 73 2e 20 20 54 68  B functions.  Th
5ce0: 65 20 76 61 72 69 61 6e 74 20 6f 66 20 4c 49 4b  e variant of LIK
5cf0: 45 0a 20 20 2a 2a 20 75 73 65 64 20 77 69 6c 6c  E.  ** used will
5d00: 20 62 65 20 63 61 73 65 20 73 65 6e 73 69 74 69   be case sensiti
5d10: 76 65 20 6f 72 20 6e 6f 74 20 64 65 70 65 6e 64  ve or not depend
5d20: 69 6e 67 20 6f 6e 20 74 68 65 20 52 48 53 2e 0a  ing on the RHS..
5d30: 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74    */.  if( sqlit
5d40: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
5d50: 20 22 63 61 73 65 5f 73 65 6e 73 69 74 69 76 65   "case_sensitive
5d60: 5f 6c 69 6b 65 22 29 3d 3d 30 20 29 7b 0a 20 20  _like")==0 ){.  
5d70: 20 20 69 66 28 20 7a 52 69 67 68 74 20 29 7b 0a    if( zRight ){.
5d80: 20 20 20 20 20 20 73 71 6c 69 74 65 33 52 65 67        sqlite3Reg
5d90: 69 73 74 65 72 4c 69 6b 65 46 75 6e 63 74 69 6f  isterLikeFunctio
5da0: 6e 73 28 64 62 2c 20 67 65 74 42 6f 6f 6c 65 61  ns(db, getBoolea
5db0: 6e 28 7a 52 69 67 68 74 29 29 3b 0a 20 20 20 20  n(zRight));.    
5dc0: 7d 0a 20 20 7d 65 6c 73 65 0a 0a 23 69 66 6e 64  }.  }else..#ifnd
5dd0: 65 66 20 53 51 4c 49 54 45 5f 49 4e 54 45 47 52  ef SQLITE_INTEGR
5de0: 49 54 59 5f 43 48 45 43 4b 5f 45 52 52 4f 52 5f  ITY_CHECK_ERROR_
5df0: 4d 41 58 0a 23 20 64 65 66 69 6e 65 20 53 51 4c  MAX.# define SQL
5e00: 49 54 45 5f 49 4e 54 45 47 52 49 54 59 5f 43 48  ITE_INTEGRITY_CH
5e10: 45 43 4b 5f 45 52 52 4f 52 5f 4d 41 58 20 31 30  ECK_ERROR_MAX 10
5e20: 30 0a 23 65 6e 64 69 66 0a 0a 23 69 66 6e 64 65  0.#endif..#ifnde
5e30: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 49 4e  f SQLITE_OMIT_IN
5e40: 54 45 47 52 49 54 59 5f 43 48 45 43 4b 0a 20 20  TEGRITY_CHECK.  
5e50: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
5e60: 6d 70 28 7a 4c 65 66 74 2c 20 22 69 6e 74 65 67  mp(zLeft, "integ
5e70: 72 69 74 79 5f 63 68 65 63 6b 22 29 3d 3d 30 20  rity_check")==0 
5e80: 29 7b 0a 20 20 20 20 69 6e 74 20 69 2c 20 6a 2c  ){.    int i, j,
5e90: 20 61 64 64 72 2c 20 6d 78 45 72 72 3b 0a 0a 20   addr, mxErr;.. 
5ea0: 20 20 20 2f 2a 20 43 6f 64 65 20 74 68 61 74 20     /* Code that 
5eb0: 61 70 70 65 61 72 73 20 61 74 20 74 68 65 20 65  appears at the e
5ec0: 6e 64 20 6f 66 20 74 68 65 20 69 6e 74 65 67 72  nd of the integr
5ed0: 69 74 79 20 63 68 65 63 6b 2e 20 20 49 66 20 6e  ity check.  If n
5ee0: 6f 20 65 72 72 6f 72 0a 20 20 20 20 2a 2a 20 6d  o error.    ** m
5ef0: 65 73 73 61 67 65 73 20 68 61 76 65 20 62 65 65  essages have bee
5f00: 6e 20 67 65 6e 65 72 61 74 65 64 2c 20 6f 75 74  n generated, out
5f10: 70 75 74 20 4f 4b 2e 20 20 4f 74 68 65 72 77 69  put OK.  Otherwi
5f20: 73 65 20 6f 75 74 70 75 74 20 74 68 65 0a 20 20  se output the.  
5f30: 20 20 2a 2a 20 65 72 72 6f 72 20 6d 65 73 73 61    ** error messa
5f40: 67 65 0a 20 20 20 20 2a 2f 0a 20 20 20 20 73 74  ge.    */.    st
5f50: 61 74 69 63 20 63 6f 6e 73 74 20 56 64 62 65 4f  atic const VdbeO
5f60: 70 4c 69 73 74 20 65 6e 64 43 6f 64 65 5b 5d 20  pList endCode[] 
5f70: 3d 20 7b 0a 20 20 20 20 20 20 7b 20 4f 50 5f 4d  = {.      { OP_M
5f80: 65 6d 4c 6f 61 64 2c 20 20 20 20 20 30 2c 20 30  emLoad,     0, 0
5f90: 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20  ,        0},.   
5fa0: 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67 65 72 2c     { OP_Integer,
5fb0: 20 20 20 20 20 30 2c 20 30 2c 20 20 20 20 20 20       0, 0,      
5fc0: 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50    0},.      { OP
5fd0: 5f 4e 65 2c 20 20 20 20 20 20 20 20 20 20 30 2c  _Ne,          0,
5fe0: 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 20 20   0,        0},  
5ff0: 20 20 2f 2a 20 32 20 2a 2f 0a 20 20 20 20 20 20    /* 2 */.      
6000: 7b 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 20 20  { OP_String8,   
6010: 20 20 30 2c 20 30 2c 20 20 20 20 20 20 20 20 22    0, 0,        "
6020: 6f 6b 22 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50  ok"},.      { OP
6030: 5f 43 61 6c 6c 62 61 63 6b 2c 20 20 20 20 31 2c  _Callback,    1,
6040: 20 30 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20   0,        0},. 
6050: 20 20 20 7d 3b 0a 0a 20 20 20 20 2f 2a 20 49 6e     };..    /* In
6060: 69 74 69 61 6c 69 7a 65 20 74 68 65 20 56 44 42  itialize the VDB
6070: 45 20 70 72 6f 67 72 61 6d 20 2a 2f 0a 20 20 20  E program */.   
6080: 20 69 66 28 20 73 71 6c 69 74 65 33 52 65 61 64   if( sqlite3Read
6090: 53 63 68 65 6d 61 28 70 50 61 72 73 65 29 20 29  Schema(pParse) )
60a0: 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75 74   goto pragma_out
60b0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  ;.    sqlite3Vdb
60c0: 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20 31  eSetNumCols(v, 1
60d0: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
60e0: 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20  beSetColName(v, 
60f0: 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c  0, COLNAME_NAME,
6100: 20 22 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63   "integrity_chec
6110: 6b 22 2c 20 50 33 5f 53 54 41 54 49 43 29 3b 0a  k", P3_STATIC);.
6120: 0a 20 20 20 20 2f 2a 20 53 65 74 20 74 68 65 20  .    /* Set the 
6130: 6d 61 78 69 6d 75 6d 20 65 72 72 6f 72 20 63 6f  maximum error co
6140: 75 6e 74 20 2a 2f 0a 20 20 20 20 6d 78 45 72 72  unt */.    mxErr
6150: 20 3d 20 53 51 4c 49 54 45 5f 49 4e 54 45 47 52   = SQLITE_INTEGR
6160: 49 54 59 5f 43 48 45 43 4b 5f 45 52 52 4f 52 5f  ITY_CHECK_ERROR_
6170: 4d 41 58 3b 0a 20 20 20 20 69 66 28 20 7a 52 69  MAX;.    if( zRi
6180: 67 68 74 20 29 7b 0a 20 20 20 20 20 20 6d 78 45  ght ){.      mxE
6190: 72 72 20 3d 20 61 74 6f 69 28 7a 52 69 67 68 74  rr = atoi(zRight
61a0: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 6d 78 45  );.      if( mxE
61b0: 72 72 3c 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  rr<=0 ){.       
61c0: 20 6d 78 45 72 72 20 3d 20 53 51 4c 49 54 45 5f   mxErr = SQLITE_
61d0: 49 4e 54 45 47 52 49 54 59 5f 43 48 45 43 4b 5f  INTEGRITY_CHECK_
61e0: 45 52 52 4f 52 5f 4d 41 58 3b 0a 20 20 20 20 20  ERROR_MAX;.     
61f0: 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c   }.    }.    sql
6200: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
6210: 20 4f 50 5f 4d 65 6d 49 6e 74 2c 20 6d 78 45 72   OP_MemInt, mxEr
6220: 72 2c 20 30 29 3b 0a 0a 20 20 20 20 2f 2a 20 44  r, 0);..    /* D
6230: 6f 20 61 6e 20 69 6e 74 65 67 72 69 74 79 20 63  o an integrity c
6240: 68 65 63 6b 20 6f 6e 20 65 61 63 68 20 64 61 74  heck on each dat
6250: 61 62 61 73 65 20 66 69 6c 65 20 2a 2f 0a 20 20  abase file */.  
6260: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62 2d    for(i=0; i<db-
6270: 3e 6e 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20 20  >nDb; i++){.    
6280: 20 20 48 61 73 68 45 6c 65 6d 20 2a 78 3b 0a 20    HashElem *x;. 
6290: 20 20 20 20 20 48 61 73 68 20 2a 70 54 62 6c 73       Hash *pTbls
62a0: 3b 0a 20 20 20 20 20 20 69 6e 74 20 63 6e 74 20  ;.      int cnt 
62b0: 3d 20 30 3b 0a 0a 20 20 20 20 20 20 69 66 28 20  = 0;..      if( 
62c0: 4f 4d 49 54 5f 54 45 4d 50 44 42 20 26 26 20 69  OMIT_TEMPDB && i
62d0: 3d 3d 31 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a  ==1 ) continue;.
62e0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 43 6f  .      sqlite3Co
62f0: 64 65 56 65 72 69 66 79 53 63 68 65 6d 61 28 70  deVerifySchema(p
6300: 50 61 72 73 65 2c 20 69 29 3b 0a 20 20 20 20 20  Parse, i);.     
6310: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56   addr = sqlite3V
6320: 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49  dbeAddOp(v, OP_I
6330: 66 4d 65 6d 50 6f 73 2c 20 30 2c 20 30 29 3b 0a  fMemPos, 0, 0);.
6340: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
6350: 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 48 61 6c  eAddOp(v, OP_Hal
6360: 74 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  t, 0, 0);.      
6370: 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48  sqlite3VdbeJumpH
6380: 65 72 65 28 76 2c 20 61 64 64 72 29 3b 0a 0a 20  ere(v, addr);.. 
6390: 20 20 20 20 20 2f 2a 20 44 6f 20 61 6e 20 69 6e       /* Do an in
63a0: 74 65 67 72 69 74 79 20 63 68 65 63 6b 20 6f 66  tegrity check of
63b0: 20 74 68 65 20 42 2d 54 72 65 65 0a 20 20 20 20   the B-Tree.    
63c0: 20 20 2a 2f 0a 20 20 20 20 20 20 70 54 62 6c 73    */.      pTbls
63d0: 20 3d 20 26 64 62 2d 3e 61 44 62 5b 69 5d 2e 70   = &db->aDb[i].p
63e0: 53 63 68 65 6d 61 2d 3e 74 62 6c 48 61 73 68 3b  Schema->tblHash;
63f0: 0a 20 20 20 20 20 20 66 6f 72 28 78 3d 73 71 6c  .      for(x=sql
6400: 69 74 65 48 61 73 68 46 69 72 73 74 28 70 54 62  iteHashFirst(pTb
6410: 6c 73 29 3b 20 78 3b 20 78 3d 73 71 6c 69 74 65  ls); x; x=sqlite
6420: 48 61 73 68 4e 65 78 74 28 78 29 29 7b 0a 20 20  HashNext(x)){.  
6430: 20 20 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61        Table *pTa
6440: 62 20 3d 20 73 71 6c 69 74 65 48 61 73 68 44 61  b = sqliteHashDa
6450: 74 61 28 78 29 3b 0a 20 20 20 20 20 20 20 20 49  ta(x);.        I
6460: 6e 64 65 78 20 2a 70 49 64 78 3b 0a 20 20 20 20  ndex *pIdx;.    
6470: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
6480: 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65 67  ddOp(v, OP_Integ
6490: 65 72 2c 20 70 54 61 62 2d 3e 74 6e 75 6d 2c 20  er, pTab->tnum, 
64a0: 30 29 3b 0a 20 20 20 20 20 20 20 20 63 6e 74 2b  0);.        cnt+
64b0: 2b 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 70  +;.        for(p
64c0: 49 64 78 3d 70 54 61 62 2d 3e 70 49 6e 64 65 78  Idx=pTab->pIndex
64d0: 3b 20 70 49 64 78 3b 20 70 49 64 78 3d 70 49 64  ; pIdx; pIdx=pId
64e0: 78 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 20  x->pNext){.     
64f0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
6500: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 49 6e 74 65  AddOp(v, OP_Inte
6510: 67 65 72 2c 20 70 49 64 78 2d 3e 74 6e 75 6d 2c  ger, pIdx->tnum,
6520: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 63   0);.          c
6530: 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 20 20 7d 0a  nt++;.        }.
6540: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
6550: 28 20 63 6e 74 3d 3d 30 20 29 20 63 6f 6e 74 69  ( cnt==0 ) conti
6560: 6e 75 65 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  nue;.      sqlit
6570: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
6580: 50 5f 49 6e 74 65 67 72 69 74 79 43 6b 2c 20 30  P_IntegrityCk, 0
6590: 2c 20 69 29 3b 0a 20 20 20 20 20 20 61 64 64 72  , i);.      addr
65a0: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64   = sqlite3VdbeAd
65b0: 64 4f 70 28 76 2c 20 4f 50 5f 49 73 4e 75 6c 6c  dOp(v, OP_IsNull
65c0: 2c 20 2d 31 2c 20 30 29 3b 0a 20 20 20 20 20 20  , -1, 0);.      
65d0: 73 71 6c 69 74 65 33 56 64 62 65 4f 70 33 28 76  sqlite3VdbeOp3(v
65e0: 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c  , OP_String8, 0,
65f0: 20 30 2c 0a 20 20 20 20 20 20 20 20 20 73 71 6c   0,.         sql
6600: 69 74 65 33 4d 50 72 69 6e 74 66 28 22 2a 2a 2a  ite3MPrintf("***
6610: 20 69 6e 20 64 61 74 61 62 61 73 65 20 25 73 20   in database %s 
6620: 2a 2a 2a 5c 6e 22 2c 20 64 62 2d 3e 61 44 62 5b  ***\n", db->aDb[
6630: 69 5d 2e 7a 4e 61 6d 65 29 2c 0a 20 20 20 20 20  i].zName),.     
6640: 20 20 20 20 50 33 5f 44 59 4e 41 4d 49 43 29 3b      P3_DYNAMIC);
6650: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
6660: 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f 50 75  beAddOp(v, OP_Pu
6670: 6c 6c 2c 20 31 2c 20 30 29 3b 0a 20 20 20 20 20  ll, 1, 0);.     
6680: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
6690: 70 28 76 2c 20 4f 50 5f 43 6f 6e 63 61 74 2c 20  p(v, OP_Concat, 
66a0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
66b0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
66c0: 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 31 2c   OP_Callback, 1,
66d0: 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   0);.      sqlit
66e0: 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65 28 76  e3VdbeJumpHere(v
66f0: 2c 20 61 64 64 72 29 3b 0a 0a 20 20 20 20 20 20  , addr);..      
6700: 2f 2a 20 4d 61 6b 65 20 73 75 72 65 20 61 6c 6c  /* Make sure all
6710: 20 74 68 65 20 69 6e 64 69 63 65 73 20 61 72 65   the indices are
6720: 20 63 6f 6e 73 74 72 75 63 74 65 64 20 63 6f 72   constructed cor
6730: 72 65 63 74 6c 79 2e 0a 20 20 20 20 20 20 2a 2f  rectly..      */
6740: 0a 20 20 20 20 20 20 66 6f 72 28 78 3d 73 71 6c  .      for(x=sql
6750: 69 74 65 48 61 73 68 46 69 72 73 74 28 70 54 62  iteHashFirst(pTb
6760: 6c 73 29 3b 20 78 3b 20 78 3d 73 71 6c 69 74 65  ls); x; x=sqlite
6770: 48 61 73 68 4e 65 78 74 28 78 29 29 7b 0a 20 20  HashNext(x)){.  
6780: 20 20 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61        Table *pTa
6790: 62 20 3d 20 73 71 6c 69 74 65 48 61 73 68 44 61  b = sqliteHashDa
67a0: 74 61 28 78 29 3b 0a 20 20 20 20 20 20 20 20 49  ta(x);.        I
67b0: 6e 64 65 78 20 2a 70 49 64 78 3b 0a 20 20 20 20  ndex *pIdx;.    
67c0: 20 20 20 20 69 6e 74 20 6c 6f 6f 70 54 6f 70 3b      int loopTop;
67d0: 0a 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 54  ..        if( pT
67e0: 61 62 2d 3e 70 49 6e 64 65 78 3d 3d 30 20 29 20  ab->pIndex==0 ) 
67f0: 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20  continue;.      
6800: 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33    addr = sqlite3
6810: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
6820: 49 66 4d 65 6d 50 6f 73 2c 20 30 2c 20 30 29 3b  IfMemPos, 0, 0);
6830: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
6840: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
6850: 48 61 6c 74 2c 20 30 2c 20 30 29 3b 0a 20 20 20  Halt, 0, 0);.   
6860: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
6870: 4a 75 6d 70 48 65 72 65 28 76 2c 20 61 64 64 72  JumpHere(v, addr
6880: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
6890: 65 33 4f 70 65 6e 54 61 62 6c 65 41 6e 64 49 6e  e3OpenTableAndIn
68a0: 64 69 63 65 73 28 70 50 61 72 73 65 2c 20 70 54  dices(pParse, pT
68b0: 61 62 2c 20 31 2c 20 4f 50 5f 4f 70 65 6e 52 65  ab, 1, OP_OpenRe
68c0: 61 64 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c  ad);.        sql
68d0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
68e0: 20 4f 50 5f 4d 65 6d 49 6e 74 2c 20 30 2c 20 31   OP_MemInt, 0, 1
68f0: 29 3b 0a 20 20 20 20 20 20 20 20 6c 6f 6f 70 54  );.        loopT
6900: 6f 70 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65  op = sqlite3Vdbe
6910: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 52 65 77 69  AddOp(v, OP_Rewi
6920: 6e 64 2c 20 31 2c 20 30 29 3b 0a 20 20 20 20 20  nd, 1, 0);.     
6930: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
6940: 64 4f 70 28 76 2c 20 4f 50 5f 4d 65 6d 49 6e 63  dOp(v, OP_MemInc
6950: 72 2c 20 31 2c 20 31 29 3b 0a 20 20 20 20 20 20  r, 1, 1);.      
6960: 20 20 66 6f 72 28 6a 3d 30 2c 20 70 49 64 78 3d    for(j=0, pIdx=
6970: 70 54 61 62 2d 3e 70 49 6e 64 65 78 3b 20 70 49  pTab->pIndex; pI
6980: 64 78 3b 20 70 49 64 78 3d 70 49 64 78 2d 3e 70  dx; pIdx=pIdx->p
6990: 4e 65 78 74 2c 20 6a 2b 2b 29 7b 0a 20 20 20 20  Next, j++){.    
69a0: 20 20 20 20 20 20 69 6e 74 20 6a 6d 70 32 3b 0a        int jmp2;.
69b0: 20 20 20 20 20 20 20 20 20 20 73 74 61 74 69 63            static
69c0: 20 63 6f 6e 73 74 20 56 64 62 65 4f 70 4c 69 73   const VdbeOpLis
69d0: 74 20 69 64 78 45 72 72 5b 5d 20 3d 20 7b 0a 20  t idxErr[] = {. 
69e0: 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f             { OP_
69f0: 4d 65 6d 49 6e 63 72 2c 20 20 20 20 2d 31 2c 20  MemIncr,    -1, 
6a00: 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20   0,  0},.       
6a10: 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67       { OP_String
6a20: 38 2c 20 20 20 20 20 30 2c 20 20 30 2c 20 20 22  8,     0,  0,  "
6a30: 72 6f 77 69 64 20 22 7d 2c 0a 20 20 20 20 20 20  rowid "},.      
6a40: 20 20 20 20 20 20 7b 20 4f 50 5f 52 6f 77 69 64        { OP_Rowid
6a50: 2c 20 20 20 20 20 20 20 31 2c 20 20 30 2c 20 20  ,       1,  0,  
6a60: 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  0},.            
6a70: 7b 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 20 20  { OP_String8,   
6a80: 20 20 30 2c 20 20 30 2c 20 20 22 20 6d 69 73 73    0,  0,  " miss
6a90: 69 6e 67 20 66 72 6f 6d 20 69 6e 64 65 78 20 22  ing from index "
6aa0: 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  },.            {
6ab0: 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 20 20 20   OP_String8,    
6ac0: 20 30 2c 20 20 30 2c 20 20 30 7d 2c 20 20 20 20   0,  0,  0},    
6ad0: 2f 2a 20 34 20 2a 2f 0a 20 20 20 20 20 20 20 20  /* 4 */.        
6ae0: 20 20 20 20 7b 20 4f 50 5f 43 6f 6e 63 61 74 2c      { OP_Concat,
6af0: 20 20 20 20 20 20 32 2c 20 20 30 2c 20 20 30 7d        2,  0,  0}
6b00: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 20  ,.            { 
6b10: 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 20 20 20  OP_Callback,    
6b20: 31 2c 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20  1,  0,  0},.    
6b30: 20 20 20 20 20 20 7d 3b 0a 20 20 20 20 20 20 20        };.       
6b40: 20 20 20 73 71 6c 69 74 65 33 47 65 6e 65 72 61     sqlite3Genera
6b50: 74 65 49 6e 64 65 78 4b 65 79 28 76 2c 20 70 49  teIndexKey(v, pI
6b60: 64 78 2c 20 31 29 3b 0a 20 20 20 20 20 20 20 20  dx, 1);.        
6b70: 20 20 6a 6d 70 32 20 3d 20 73 71 6c 69 74 65 33    jmp2 = sqlite3
6b80: 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f 50 5f  VdbeAddOp(v, OP_
6b90: 46 6f 75 6e 64 2c 20 6a 2b 32 2c 20 30 29 3b 0a  Found, j+2, 0);.
6ba0: 20 20 20 20 20 20 20 20 20 20 61 64 64 72 20 3d            addr =
6bb0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
6bc0: 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53 69  pList(v, ArraySi
6bd0: 7a 65 28 69 64 78 45 72 72 29 2c 20 69 64 78 45  ze(idxErr), idxE
6be0: 72 72 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73  rr);.          s
6bf0: 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65  qlite3VdbeChange
6c00: 50 33 28 76 2c 20 61 64 64 72 2b 34 2c 20 70 49  P3(v, addr+4, pI
6c10: 64 78 2d 3e 7a 4e 61 6d 65 2c 20 50 33 5f 53 54  dx->zName, P3_ST
6c20: 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 20  ATIC);.         
6c30: 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70   sqlite3VdbeJump
6c40: 48 65 72 65 28 76 2c 20 6a 6d 70 32 29 3b 0a 20  Here(v, jmp2);. 
6c50: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
6c60: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
6c70: 70 28 76 2c 20 4f 50 5f 4e 65 78 74 2c 20 31 2c  p(v, OP_Next, 1,
6c80: 20 6c 6f 6f 70 54 6f 70 2b 31 29 3b 0a 20 20 20   loopTop+1);.   
6c90: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
6ca0: 4a 75 6d 70 48 65 72 65 28 76 2c 20 6c 6f 6f 70  JumpHere(v, loop
6cb0: 54 6f 70 29 3b 0a 20 20 20 20 20 20 20 20 66 6f  Top);.        fo
6cc0: 72 28 6a 3d 30 2c 20 70 49 64 78 3d 70 54 61 62  r(j=0, pIdx=pTab
6cd0: 2d 3e 70 49 6e 64 65 78 3b 20 70 49 64 78 3b 20  ->pIndex; pIdx; 
6ce0: 70 49 64 78 3d 70 49 64 78 2d 3e 70 4e 65 78 74  pIdx=pIdx->pNext
6cf0: 2c 20 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  , j++){.        
6d00: 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20 56    static const V
6d10: 64 62 65 4f 70 4c 69 73 74 20 63 6e 74 49 64 78  dbeOpList cntIdx
6d20: 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 20 20 20  [] = {.         
6d30: 20 20 20 20 7b 20 4f 50 5f 4d 65 6d 49 6e 74 2c      { OP_MemInt,
6d40: 20 20 20 20 20 20 20 30 2c 20 20 32 2c 20 20 30         0,  2,  0
6d50: 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  },.             
6d60: 7b 20 4f 50 5f 52 65 77 69 6e 64 2c 20 20 20 20  { OP_Rewind,    
6d70: 20 20 20 30 2c 20 20 30 2c 20 20 30 7d 2c 20 20     0,  0,  0},  
6d80: 2f 2a 20 31 20 2a 2f 0a 20 20 20 20 20 20 20 20  /* 1 */.        
6d90: 20 20 20 20 20 7b 20 4f 50 5f 4d 65 6d 49 6e 63       { OP_MemInc
6da0: 72 2c 20 20 20 20 20 20 31 2c 20 20 32 2c 20 20  r,      1,  2,  
6db0: 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  0},.            
6dc0: 20 7b 20 4f 50 5f 4e 65 78 74 2c 20 20 20 20 20   { OP_Next,     
6dd0: 20 20 20 20 30 2c 20 20 30 2c 20 20 30 7d 2c 20      0,  0,  0}, 
6de0: 20 2f 2a 20 33 20 2a 2f 0a 20 20 20 20 20 20 20   /* 3 */.       
6df0: 20 20 20 20 20 20 7b 20 4f 50 5f 4d 65 6d 4c 6f        { OP_MemLo
6e00: 61 64 2c 20 20 20 20 20 20 31 2c 20 20 30 2c 20  ad,      1,  0, 
6e10: 20 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 20   0},.           
6e20: 20 20 7b 20 4f 50 5f 4d 65 6d 4c 6f 61 64 2c 20    { OP_MemLoad, 
6e30: 20 20 20 20 20 32 2c 20 20 30 2c 20 20 30 7d 2c       2,  0,  0},
6e40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20  .             { 
6e50: 4f 50 5f 45 71 2c 20 20 20 20 20 20 20 20 20 20  OP_Eq,          
6e60: 20 30 2c 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a   0,  0,  0},  /*
6e70: 20 36 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20   6 */.          
6e80: 20 20 20 7b 20 4f 50 5f 4d 65 6d 49 6e 63 72 2c     { OP_MemIncr,
6e90: 20 20 20 20 20 2d 31 2c 20 20 30 2c 20 20 30 7d       -1,  0,  0}
6ea0: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  ,.             {
6eb0: 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 20 20 20   OP_String8,    
6ec0: 20 20 30 2c 20 20 30 2c 20 20 22 77 72 6f 6e 67    0,  0,  "wrong
6ed0: 20 23 20 6f 66 20 65 6e 74 72 69 65 73 20 69 6e   # of entries in
6ee0: 20 69 6e 64 65 78 20 22 7d 2c 0a 20 20 20 20 20   index "},.     
6ef0: 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72          { OP_Str
6f00: 69 6e 67 38 2c 20 20 20 20 20 20 30 2c 20 20 30  ing8,      0,  0
6f10: 2c 20 20 30 7d 2c 20 20 2f 2a 20 39 20 2a 2f 0a  ,  0},  /* 9 */.
6f20: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f               { O
6f30: 50 5f 43 6f 6e 63 61 74 2c 20 20 20 20 20 20 20  P_Concat,       
6f40: 30 2c 20 20 30 2c 20 20 30 7d 2c 0a 20 20 20 20  0,  0,  0},.    
6f50: 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 61           { OP_Ca
6f60: 6c 6c 62 61 63 6b 2c 20 20 20 20 20 31 2c 20 20  llback,     1,  
6f70: 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20  0,  0},.        
6f80: 20 20 7d 3b 0a 20 20 20 20 20 20 20 20 20 20 69    };.          i
6f90: 66 28 20 70 49 64 78 2d 3e 74 6e 75 6d 3d 3d 30  f( pIdx->tnum==0
6fa0: 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20   ) continue;.   
6fb0: 20 20 20 20 20 20 20 61 64 64 72 20 3d 20 73 71         addr = sq
6fc0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76  lite3VdbeAddOp(v
6fd0: 2c 20 4f 50 5f 49 66 4d 65 6d 50 6f 73 2c 20 30  , OP_IfMemPos, 0
6fe0: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20  , 0);.          
6ff0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
7000: 28 76 2c 20 4f 50 5f 48 61 6c 74 2c 20 30 2c 20  (v, OP_Halt, 0, 
7010: 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71  0);.          sq
7020: 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72  lite3VdbeJumpHer
7030: 65 28 76 2c 20 61 64 64 72 29 3b 0a 20 20 20 20  e(v, addr);.    
7040: 20 20 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c        addr = sql
7050: 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73  ite3VdbeAddOpLis
7060: 74 28 76 2c 20 41 72 72 61 79 53 69 7a 65 28 63  t(v, ArraySize(c
7070: 6e 74 49 64 78 29 2c 20 63 6e 74 49 64 78 29 3b  ntIdx), cntIdx);
7080: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
7090: 65 33 56 64 62 65 43 68 61 6e 67 65 50 31 28 76  e3VdbeChangeP1(v
70a0: 2c 20 61 64 64 72 2b 31 2c 20 6a 2b 32 29 3b 0a  , addr+1, j+2);.
70b0: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
70c0: 33 56 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c  3VdbeChangeP2(v,
70d0: 20 61 64 64 72 2b 31 2c 20 61 64 64 72 2b 34 29   addr+1, addr+4)
70e0: 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  ;.          sqli
70f0: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 31 28  te3VdbeChangeP1(
7100: 76 2c 20 61 64 64 72 2b 33 2c 20 6a 2b 32 29 3b  v, addr+3, j+2);
7110: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
7120: 65 33 56 64 62 65 43 68 61 6e 67 65 50 32 28 76  e3VdbeChangeP2(v
7130: 2c 20 61 64 64 72 2b 33 2c 20 61 64 64 72 2b 32  , addr+3, addr+2
7140: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  );.          sql
7150: 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65  ite3VdbeJumpHere
7160: 28 76 2c 20 61 64 64 72 2b 36 29 3b 0a 20 20 20  (v, addr+6);.   
7170: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
7180: 62 65 43 68 61 6e 67 65 50 33 28 76 2c 20 61 64  beChangeP3(v, ad
7190: 64 72 2b 39 2c 20 70 49 64 78 2d 3e 7a 4e 61 6d  dr+9, pIdx->zNam
71a0: 65 2c 20 50 33 5f 53 54 41 54 49 43 29 3b 0a 20  e, P3_STATIC);. 
71b0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
71c0: 20 0a 20 20 20 20 7d 0a 20 20 20 20 61 64 64 72   .    }.    addr
71d0: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64   = sqlite3VdbeAd
71e0: 64 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79  dOpList(v, Array
71f0: 53 69 7a 65 28 65 6e 64 43 6f 64 65 29 2c 20 65  Size(endCode), e
7200: 6e 64 43 6f 64 65 29 3b 0a 20 20 20 20 73 71 6c  ndCode);.    sql
7210: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 31  ite3VdbeChangeP1
7220: 28 76 2c 20 61 64 64 72 2b 31 2c 20 6d 78 45 72  (v, addr+1, mxEr
7230: 72 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  r);.    sqlite3V
7240: 64 62 65 4a 75 6d 70 48 65 72 65 28 76 2c 20 61  dbeJumpHere(v, a
7250: 64 64 72 2b 32 29 3b 0a 20 20 7d 65 6c 73 65 0a  ddr+2);.  }else.
7260: 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45  #endif /* SQLITE
7270: 5f 4f 4d 49 54 5f 49 4e 54 45 47 52 49 54 59 5f  _OMIT_INTEGRITY_
7280: 43 48 45 43 4b 20 2a 2f 0a 0a 23 69 66 6e 64 65  CHECK */..#ifnde
7290: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54  f SQLITE_OMIT_UT
72a0: 46 31 36 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20  F16.  /*.  **   
72b0: 50 52 41 47 4d 41 20 65 6e 63 6f 64 69 6e 67 0a  PRAGMA encoding.
72c0: 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 65 6e    **   PRAGMA en
72d0: 63 6f 64 69 6e 67 20 3d 20 22 75 74 66 2d 38 22  coding = "utf-8"
72e0: 7c 22 75 74 66 2d 31 36 22 7c 22 75 74 66 2d 31  |"utf-16"|"utf-1
72f0: 36 6c 65 22 7c 22 75 74 66 2d 31 36 62 65 22 0a  6le"|"utf-16be".
7300: 20 20 2a 2a 0a 20 20 2a 2a 20 49 6e 20 69 74 27    **.  ** In it'
7310: 73 20 66 69 72 73 74 20 66 6f 72 6d 2c 20 74 68  s first form, th
7320: 69 73 20 70 72 61 67 6d 61 20 72 65 74 75 72 6e  is pragma return
7330: 73 20 74 68 65 20 65 6e 63 6f 64 69 6e 67 20 6f  s the encoding o
7340: 66 20 74 68 65 20 6d 61 69 6e 0a 20 20 2a 2a 20  f the main.  ** 
7350: 64 61 74 61 62 61 73 65 2e 20 49 66 20 74 68 65  database. If the
7360: 20 64 61 74 61 62 61 73 65 20 69 73 20 6e 6f 74   database is not
7370: 20 69 6e 69 74 69 61 6c 69 7a 65 64 2c 20 69 74   initialized, it
7380: 20 69 73 20 69 6e 69 74 69 61 6c 69 7a 65 64 20   is initialized 
7390: 6e 6f 77 2e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54  now..  **.  ** T
73a0: 68 65 20 73 65 63 6f 6e 64 20 66 6f 72 6d 20 6f  he second form o
73b0: 66 20 74 68 69 73 20 70 72 61 67 6d 61 20 69 73  f this pragma is
73c0: 20 61 20 6e 6f 2d 6f 70 20 69 66 20 74 68 65 20   a no-op if the 
73d0: 6d 61 69 6e 20 64 61 74 61 62 61 73 65 20 66 69  main database fi
73e0: 6c 65 0a 20 20 2a 2a 20 68 61 73 20 6e 6f 74 20  le.  ** has not 
73f0: 61 6c 72 65 61 64 79 20 62 65 65 6e 20 69 6e 69  already been ini
7400: 74 69 61 6c 69 7a 65 64 2e 20 49 6e 20 74 68 69  tialized. In thi
7410: 73 20 63 61 73 65 20 69 74 20 73 65 74 73 20 74  s case it sets t
7420: 68 65 20 64 65 66 61 75 6c 74 0a 20 20 2a 2a 20  he default.  ** 
7430: 65 6e 63 6f 64 69 6e 67 20 74 68 61 74 20 77 69  encoding that wi
7440: 6c 6c 20 62 65 20 75 73 65 64 20 66 6f 72 20 74  ll be used for t
7450: 68 65 20 6d 61 69 6e 20 64 61 74 61 62 61 73 65  he main database
7460: 20 66 69 6c 65 20 69 66 20 61 20 6e 65 77 20 66   file if a new f
7470: 69 6c 65 0a 20 20 2a 2a 20 69 73 20 63 72 65 61  ile.  ** is crea
7480: 74 65 64 2e 20 49 66 20 61 6e 20 65 78 69 73 74  ted. If an exist
7490: 69 6e 67 20 6d 61 69 6e 20 64 61 74 61 62 61 73  ing main databas
74a0: 65 20 66 69 6c 65 20 69 73 20 6f 70 65 6e 65 64  e file is opened
74b0: 2c 20 74 68 65 6e 20 74 68 65 0a 20 20 2a 2a 20  , then the.  ** 
74c0: 64 65 66 61 75 6c 74 20 74 65 78 74 20 65 6e 63  default text enc
74d0: 6f 64 69 6e 67 20 66 6f 72 20 74 68 65 20 65 78  oding for the ex
74e0: 69 73 74 69 6e 67 20 64 61 74 61 62 61 73 65 20  isting database 
74f0: 69 73 20 75 73 65 64 2e 0a 20 20 2a 2a 20 0a 20  is used..  ** . 
7500: 20 2a 2a 20 49 6e 20 61 6c 6c 20 63 61 73 65 73   ** In all cases
7510: 20 6e 65 77 20 64 61 74 61 62 61 73 65 73 20 63   new databases c
7520: 72 65 61 74 65 64 20 75 73 69 6e 67 20 74 68 65  reated using the
7530: 20 41 54 54 41 43 48 20 63 6f 6d 6d 61 6e 64 20   ATTACH command 
7540: 61 72 65 0a 20 20 2a 2a 20 63 72 65 61 74 65 64  are.  ** created
7550: 20 74 6f 20 75 73 65 20 74 68 65 20 73 61 6d 65   to use the same
7560: 20 64 65 66 61 75 6c 74 20 74 65 78 74 20 65 6e   default text en
7570: 63 6f 64 69 6e 67 20 61 73 20 74 68 65 20 6d 61  coding as the ma
7580: 69 6e 20 64 61 74 61 62 61 73 65 2e 20 49 66 0a  in database. If.
7590: 20 20 2a 2a 20 74 68 65 20 6d 61 69 6e 20 64 61    ** the main da
75a0: 74 61 62 61 73 65 20 68 61 73 20 6e 6f 74 20 62  tabase has not b
75b0: 65 65 6e 20 69 6e 69 74 69 61 6c 69 7a 65 64 20  een initialized 
75c0: 61 6e 64 2f 6f 72 20 63 72 65 61 74 65 64 20 77  and/or created w
75d0: 68 65 6e 20 41 54 54 41 43 48 0a 20 20 2a 2a 20  hen ATTACH.  ** 
75e0: 69 73 20 65 78 65 63 75 74 65 64 2c 20 74 68 69  is executed, thi
75f0: 73 20 69 73 20 64 6f 6e 65 20 62 65 66 6f 72 65  s is done before
7600: 20 74 68 65 20 41 54 54 41 43 48 20 6f 70 65 72   the ATTACH oper
7610: 61 74 69 6f 6e 2e 0a 20 20 2a 2a 0a 20 20 2a 2a  ation..  **.  **
7620: 20 49 6e 20 74 68 65 20 73 65 63 6f 6e 64 20 66   In the second f
7630: 6f 72 6d 20 74 68 69 73 20 70 72 61 67 6d 61 20  orm this pragma 
7640: 73 65 74 73 20 74 68 65 20 74 65 78 74 20 65 6e  sets the text en
7650: 63 6f 64 69 6e 67 20 74 6f 20 62 65 20 75 73 65  coding to be use
7660: 64 20 69 6e 0a 20 20 2a 2a 20 6e 65 77 20 64 61  d in.  ** new da
7670: 74 61 62 61 73 65 20 66 69 6c 65 73 20 63 72 65  tabase files cre
7680: 61 74 65 64 20 75 73 69 6e 67 20 74 68 69 73 20  ated using this 
7690: 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65 2e  database handle.
76a0: 20 49 74 20 69 73 20 6f 6e 6c 79 0a 20 20 2a 2a   It is only.  **
76b0: 20 75 73 65 66 75 6c 20 69 66 20 69 6e 76 6f 6b   useful if invok
76c0: 65 64 20 69 6d 6d 65 64 69 61 74 65 6c 79 20 61  ed immediately a
76d0: 66 74 65 72 20 74 68 65 20 6d 61 69 6e 20 64 61  fter the main da
76e0: 74 61 62 61 73 65 20 69 0a 20 20 2a 2f 0a 20 20  tabase i.  */.  
76f0: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
7700: 6d 70 28 7a 4c 65 66 74 2c 20 22 65 6e 63 6f 64  mp(zLeft, "encod
7710: 69 6e 67 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ing")==0 ){.    
7720: 73 74 61 74 69 63 20 63 6f 6e 73 74 20 73 74 72  static const str
7730: 75 63 74 20 45 6e 63 4e 61 6d 65 20 7b 0a 20 20  uct EncName {.  
7740: 20 20 20 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b      char *zName;
7750: 0a 20 20 20 20 20 20 75 38 20 65 6e 63 3b 0a 20  .      u8 enc;. 
7760: 20 20 20 7d 20 65 6e 63 6e 61 6d 65 73 5b 5d 20     } encnames[] 
7770: 3d 20 7b 0a 20 20 20 20 20 20 7b 20 22 55 54 46  = {.      { "UTF
7780: 2d 38 22 2c 20 20 20 20 53 51 4c 49 54 45 5f 55  -8",    SQLITE_U
7790: 54 46 38 20 20 20 20 20 20 20 20 7d 2c 0a 20 20  TF8        },.  
77a0: 20 20 20 20 7b 20 22 55 54 46 38 22 2c 20 20 20      { "UTF8",   
77b0: 20 20 53 51 4c 49 54 45 5f 55 54 46 38 20 20 20    SQLITE_UTF8   
77c0: 20 20 20 20 20 7d 2c 0a 20 20 20 20 20 20 7b 20       },.      { 
77d0: 22 55 54 46 2d 31 36 6c 65 22 2c 20 53 51 4c 49  "UTF-16le", SQLI
77e0: 54 45 5f 55 54 46 31 36 4c 45 20 20 20 20 20 7d  TE_UTF16LE     }
77f0: 2c 0a 20 20 20 20 20 20 7b 20 22 55 54 46 31 36  ,.      { "UTF16
7800: 6c 65 22 2c 20 20 53 51 4c 49 54 45 5f 55 54 46  le",  SQLITE_UTF
7810: 31 36 4c 45 20 20 20 20 20 7d 2c 0a 20 20 20 20  16LE     },.    
7820: 20 20 7b 20 22 55 54 46 2d 31 36 62 65 22 2c 20    { "UTF-16be", 
7830: 53 51 4c 49 54 45 5f 55 54 46 31 36 42 45 20 20  SQLITE_UTF16BE  
7840: 20 20 20 7d 2c 0a 20 20 20 20 20 20 7b 20 22 55     },.      { "U
7850: 54 46 31 36 62 65 22 2c 20 20 53 51 4c 49 54 45  TF16be",  SQLITE
7860: 5f 55 54 46 31 36 42 45 20 20 20 20 20 7d 2c 0a  _UTF16BE     },.
7870: 20 20 20 20 20 20 7b 20 22 55 54 46 2d 31 36 22        { "UTF-16"
7880: 2c 20 20 20 30 20 20 20 20 20 20 20 20 20 20 20  ,   0           
7890: 20 20 20 20 20 20 20 7d 2c 20 2f 2a 20 53 51 4c         }, /* SQL
78a0: 49 54 45 5f 55 54 46 31 36 4e 41 54 49 56 45 20  ITE_UTF16NATIVE 
78b0: 2a 2f 0a 20 20 20 20 20 20 7b 20 22 55 54 46 31  */.      { "UTF1
78c0: 36 22 2c 20 20 20 20 30 20 20 20 20 20 20 20 20  6",    0        
78d0: 20 20 20 20 20 20 20 20 20 20 7d 2c 20 2f 2a 20            }, /* 
78e0: 53 51 4c 49 54 45 5f 55 54 46 31 36 4e 41 54 49  SQLITE_UTF16NATI
78f0: 56 45 20 2a 2f 0a 20 20 20 20 20 20 7b 20 30 2c  VE */.      { 0,
7900: 20 30 20 7d 0a 20 20 20 20 7d 3b 0a 20 20 20 20   0 }.    };.    
7910: 63 6f 6e 73 74 20 73 74 72 75 63 74 20 45 6e 63  const struct Enc
7920: 4e 61 6d 65 20 2a 70 45 6e 63 3b 0a 20 20 20 20  Name *pEnc;.    
7930: 69 66 28 20 21 7a 52 69 67 68 74 20 29 7b 20 20  if( !zRight ){  
7940: 20 20 2f 2a 20 22 50 52 41 47 4d 41 20 65 6e 63    /* "PRAGMA enc
7950: 6f 64 69 6e 67 22 20 2a 2f 0a 20 20 20 20 20 20  oding" */.      
7960: 69 66 28 20 73 71 6c 69 74 65 33 52 65 61 64 53  if( sqlite3ReadS
7970: 63 68 65 6d 61 28 70 50 61 72 73 65 29 20 29 20  chema(pParse) ) 
7980: 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75 74 3b  goto pragma_out;
7990: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
79a0: 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20  beSetNumCols(v, 
79b0: 31 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  1);.      sqlite
79c0: 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28  3VdbeSetColName(
79d0: 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41  v, 0, COLNAME_NA
79e0: 4d 45 2c 20 22 65 6e 63 6f 64 69 6e 67 22 2c 20  ME, "encoding", 
79f0: 50 33 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  P3_STATIC);.    
7a00: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
7a10: 4f 70 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38  Op(v, OP_String8
7a20: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 66  , 0, 0);.      f
7a30: 6f 72 28 70 45 6e 63 3d 26 65 6e 63 6e 61 6d 65  or(pEnc=&encname
7a40: 73 5b 30 5d 3b 20 70 45 6e 63 2d 3e 7a 4e 61 6d  s[0]; pEnc->zNam
7a50: 65 3b 20 70 45 6e 63 2b 2b 29 7b 0a 20 20 20 20  e; pEnc++){.    
7a60: 20 20 20 20 69 66 28 20 70 45 6e 63 2d 3e 65 6e      if( pEnc->en
7a70: 63 3d 3d 45 4e 43 28 70 50 61 72 73 65 2d 3e 64  c==ENC(pParse->d
7a80: 62 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  b) ){.          
7a90: 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67  sqlite3VdbeChang
7aa0: 65 50 33 28 76 2c 20 2d 31 2c 20 70 45 6e 63 2d  eP3(v, -1, pEnc-
7ab0: 3e 7a 4e 61 6d 65 2c 20 50 33 5f 53 54 41 54 49  >zName, P3_STATI
7ac0: 43 29 3b 0a 20 20 20 20 20 20 20 20 20 20 62 72  C);.          br
7ad0: 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  eak;.        }. 
7ae0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c       }.      sql
7af0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c  ite3VdbeAddOp(v,
7b00: 20 4f 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 31 2c   OP_Callback, 1,
7b10: 20 30 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 20   0);.    }else{ 
7b20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7b30: 20 20 20 20 20 20 20 2f 2a 20 22 50 52 41 47 4d         /* "PRAGM
7b40: 41 20 65 6e 63 6f 64 69 6e 67 20 3d 20 58 58 58  A encoding = XXX
7b50: 22 20 2a 2f 0a 20 20 20 20 20 20 2f 2a 20 4f 6e  " */.      /* On
7b60: 6c 79 20 63 68 61 6e 67 65 20 74 68 65 20 76 61  ly change the va
7b70: 6c 75 65 20 6f 66 20 73 71 6c 69 74 65 2e 65 6e  lue of sqlite.en
7b80: 63 20 69 66 20 74 68 65 20 64 61 74 61 62 61 73  c if the databas
7b90: 65 20 68 61 6e 64 6c 65 20 69 73 20 6e 6f 74 0a  e handle is not.
7ba0: 20 20 20 20 20 20 2a 2a 20 69 6e 69 74 69 61 6c        ** initial
7bb0: 69 7a 65 64 2e 20 49 66 20 74 68 65 20 6d 61 69  ized. If the mai
7bc0: 6e 20 64 61 74 61 62 61 73 65 20 65 78 69 73 74  n database exist
7bd0: 73 2c 20 74 68 65 20 6e 65 77 20 73 71 6c 69 74  s, the new sqlit
7be0: 65 2e 65 6e 63 20 76 61 6c 75 65 0a 20 20 20 20  e.enc value.    
7bf0: 20 20 2a 2a 20 77 69 6c 6c 20 62 65 20 6f 76 65    ** will be ove
7c00: 72 77 72 69 74 74 65 6e 20 77 68 65 6e 20 74 68  rwritten when th
7c10: 65 20 73 63 68 65 6d 61 20 69 73 20 6e 65 78 74  e schema is next
7c20: 20 6c 6f 61 64 65 64 2e 20 49 66 20 69 74 20 64   loaded. If it d
7c30: 6f 65 73 20 6e 6f 74 0a 20 20 20 20 20 20 2a 2a  oes not.      **
7c40: 20 61 6c 72 65 61 64 79 20 65 78 69 73 74 73 2c   already exists,
7c50: 20 69 74 20 77 69 6c 6c 20 62 65 20 63 72 65 61   it will be crea
7c60: 74 65 64 20 74 6f 20 75 73 65 20 74 68 65 20 6e  ted to use the n
7c70: 65 77 20 65 6e 63 6f 64 69 6e 67 20 76 61 6c 75  ew encoding valu
7c80: 65 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20 20  e..      */.    
7c90: 20 20 69 66 28 20 0a 20 20 20 20 20 20 20 20 21    if( .        !
7ca0: 28 44 62 48 61 73 50 72 6f 70 65 72 74 79 28 64  (DbHasProperty(d
7cb0: 62 2c 20 30 2c 20 44 42 5f 53 63 68 65 6d 61 4c  b, 0, DB_SchemaL
7cc0: 6f 61 64 65 64 29 29 20 7c 7c 20 0a 20 20 20 20  oaded)) || .    
7cd0: 20 20 20 20 44 62 48 61 73 50 72 6f 70 65 72 74      DbHasPropert
7ce0: 79 28 64 62 2c 20 30 2c 20 44 42 5f 45 6d 70 74  y(db, 0, DB_Empt
7cf0: 79 29 20 0a 20 20 20 20 20 20 29 7b 0a 20 20 20  y) .      ){.   
7d00: 20 20 20 20 20 66 6f 72 28 70 45 6e 63 3d 26 65       for(pEnc=&e
7d10: 6e 63 6e 61 6d 65 73 5b 30 5d 3b 20 70 45 6e 63  ncnames[0]; pEnc
7d20: 2d 3e 7a 4e 61 6d 65 3b 20 70 45 6e 63 2b 2b 29  ->zName; pEnc++)
7d30: 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  {.          if( 
7d40: 30 3d 3d 73 71 6c 69 74 65 33 53 74 72 49 43 6d  0==sqlite3StrICm
7d50: 70 28 7a 52 69 67 68 74 2c 20 70 45 6e 63 2d 3e  p(zRight, pEnc->
7d60: 7a 4e 61 6d 65 29 20 29 7b 0a 20 20 20 20 20 20  zName) ){.      
7d70: 20 20 20 20 20 20 45 4e 43 28 70 50 61 72 73 65        ENC(pParse
7d80: 2d 3e 64 62 29 20 3d 20 70 45 6e 63 2d 3e 65 6e  ->db) = pEnc->en
7d90: 63 20 3f 20 70 45 6e 63 2d 3e 65 6e 63 20 3a 20  c ? pEnc->enc : 
7da0: 53 51 4c 49 54 45 5f 55 54 46 31 36 4e 41 54 49  SQLITE_UTF16NATI
7db0: 56 45 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  VE;.            
7dc0: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20  break;.         
7dd0: 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20   }.        }.   
7de0: 20 20 20 20 20 69 66 28 20 21 70 45 6e 63 2d 3e       if( !pEnc->
7df0: 7a 4e 61 6d 65 20 29 7b 0a 20 20 20 20 20 20 20  zName ){.       
7e00: 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d     sqlite3ErrorM
7e10: 73 67 28 70 50 61 72 73 65 2c 20 22 75 6e 73 75  sg(pParse, "unsu
7e20: 70 70 6f 72 74 65 64 20 65 6e 63 6f 64 69 6e 67  pported encoding
7e30: 3a 20 25 73 22 2c 20 7a 52 69 67 68 74 29 3b 0a  : %s", zRight);.
7e40: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
7e50: 7d 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a  }.    }.  }else.
7e60: 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45  #endif /* SQLITE
7e70: 5f 4f 4d 49 54 5f 55 54 46 31 36 20 2a 2f 0a 0a  _OMIT_UTF16 */..
7e80: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
7e90: 4d 49 54 5f 53 43 48 45 4d 41 5f 56 45 52 53 49  MIT_SCHEMA_VERSI
7ea0: 4f 4e 5f 50 52 41 47 4d 41 53 0a 20 20 2f 2a 0a  ON_PRAGMAS.  /*.
7eb0: 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 5b 64    **   PRAGMA [d
7ec0: 61 74 61 62 61 73 65 2e 5d 73 63 68 65 6d 61 5f  atabase.]schema_
7ed0: 76 65 72 73 69 6f 6e 0a 20 20 2a 2a 20 20 20 50  version.  **   P
7ee0: 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65 2e  RAGMA [database.
7ef0: 5d 73 63 68 65 6d 61 5f 76 65 72 73 69 6f 6e 20  ]schema_version 
7f00: 3d 20 3c 69 6e 74 65 67 65 72 3e 0a 20 20 2a 2a  = <integer>.  **
7f10: 0a 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 5b  .  **   PRAGMA [
7f20: 64 61 74 61 62 61 73 65 2e 5d 75 73 65 72 5f 76  database.]user_v
7f30: 65 72 73 69 6f 6e 0a 20 20 2a 2a 20 20 20 50 52  ersion.  **   PR
7f40: 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d  AGMA [database.]
7f50: 75 73 65 72 5f 76 65 72 73 69 6f 6e 20 3d 20 3c  user_version = <
7f60: 69 6e 74 65 67 65 72 3e 0a 20 20 2a 2a 0a 20 20  integer>.  **.  
7f70: 2a 2a 20 54 68 65 20 70 72 61 67 6d 61 27 73 20  ** The pragma's 
7f80: 73 63 68 65 6d 61 5f 76 65 72 73 69 6f 6e 20 61  schema_version a
7f90: 6e 64 20 75 73 65 72 5f 76 65 72 73 69 6f 6e 20  nd user_version 
7fa0: 61 72 65 20 75 73 65 64 20 74 6f 20 73 65 74 20  are used to set 
7fb0: 6f 72 20 67 65 74 0a 20 20 2a 2a 20 74 68 65 20  or get.  ** the 
7fc0: 76 61 6c 75 65 20 6f 66 20 74 68 65 20 73 63 68  value of the sch
7fd0: 65 6d 61 2d 76 65 72 73 69 6f 6e 20 61 6e 64 20  ema-version and 
7fe0: 75 73 65 72 2d 76 65 72 73 69 6f 6e 2c 20 72 65  user-version, re
7ff0: 73 70 65 63 74 69 76 65 6c 79 2e 20 42 6f 74 68  spectively. Both
8000: 0a 20 20 2a 2a 20 74 68 65 20 73 63 68 65 6d 61  .  ** the schema
8010: 2d 76 65 72 73 69 6f 6e 20 61 6e 64 20 74 68 65  -version and the
8020: 20 75 73 65 72 2d 76 65 72 73 69 6f 6e 20 61 72   user-version ar
8030: 65 20 33 32 2d 62 69 74 20 73 69 67 6e 65 64 20  e 32-bit signed 
8040: 69 6e 74 65 67 65 72 73 0a 20 20 2a 2a 20 73 74  integers.  ** st
8050: 6f 72 65 64 20 69 6e 20 74 68 65 20 64 61 74 61  ored in the data
8060: 62 61 73 65 20 68 65 61 64 65 72 2e 0a 20 20 2a  base header..  *
8070: 2a 0a 20 20 2a 2a 20 54 68 65 20 73 63 68 65 6d  *.  ** The schem
8080: 61 2d 63 6f 6f 6b 69 65 20 69 73 20 75 73 75 61  a-cookie is usua
8090: 6c 6c 79 20 6f 6e 6c 79 20 6d 61 6e 69 70 75 6c  lly only manipul
80a0: 61 74 65 64 20 69 6e 74 65 72 6e 61 6c 6c 79 20  ated internally 
80b0: 62 79 20 53 51 4c 69 74 65 2e 20 49 74 0a 20 20  by SQLite. It.  
80c0: 2a 2a 20 69 73 20 69 6e 63 72 65 6d 65 6e 74 65  ** is incremente
80d0: 64 20 62 79 20 53 51 4c 69 74 65 20 77 68 65 6e  d by SQLite when
80e0: 65 76 65 72 20 74 68 65 20 64 61 74 61 62 61 73  ever the databas
80f0: 65 20 73 63 68 65 6d 61 20 69 73 20 6d 6f 64 69  e schema is modi
8100: 66 69 65 64 20 28 62 79 0a 20 20 2a 2a 20 63 72  fied (by.  ** cr
8110: 65 61 74 69 6e 67 20 6f 72 20 64 72 6f 70 70 69  eating or droppi
8120: 6e 67 20 61 20 74 61 62 6c 65 20 6f 72 20 69 6e  ng a table or in
8130: 64 65 78 29 2e 20 54 68 65 20 73 63 68 65 6d 61  dex). The schema
8140: 20 76 65 72 73 69 6f 6e 20 69 73 20 75 73 65 64   version is used
8150: 20 62 79 0a 20 20 2a 2a 20 53 51 4c 69 74 65 20   by.  ** SQLite 
8160: 65 61 63 68 20 74 69 6d 65 20 61 20 71 75 65 72  each time a quer
8170: 79 20 69 73 20 65 78 65 63 75 74 65 64 20 74 6f  y is executed to
8180: 20 65 6e 73 75 72 65 20 74 68 61 74 20 74 68 65   ensure that the
8190: 20 69 6e 74 65 72 6e 61 6c 20 63 61 63 68 65 0a   internal cache.
81a0: 20 20 2a 2a 20 6f 66 20 74 68 65 20 73 63 68 65    ** of the sche
81b0: 6d 61 20 75 73 65 64 20 77 68 65 6e 20 63 6f 6d  ma used when com
81c0: 70 69 6c 69 6e 67 20 74 68 65 20 53 51 4c 20 71  piling the SQL q
81d0: 75 65 72 79 20 6d 61 74 63 68 65 73 20 74 68 65  uery matches the
81e0: 20 73 63 68 65 6d 61 20 6f 66 0a 20 20 2a 2a 20   schema of.  ** 
81f0: 74 68 65 20 64 61 74 61 62 61 73 65 20 61 67 61  the database aga
8200: 69 6e 73 74 20 77 68 69 63 68 20 74 68 65 20 63  inst which the c
8210: 6f 6d 70 69 6c 65 64 20 71 75 65 72 79 20 69 73  ompiled query is
8220: 20 61 63 74 75 61 6c 6c 79 20 65 78 65 63 75 74   actually execut
8230: 65 64 2e 0a 20 20 2a 2a 20 53 75 62 76 65 72 74  ed..  ** Subvert
8240: 69 6e 67 20 74 68 69 73 20 6d 65 63 68 61 6e 69  ing this mechani
8250: 73 6d 20 62 79 20 75 73 69 6e 67 20 22 50 52 41  sm by using "PRA
8260: 47 4d 41 20 73 63 68 65 6d 61 5f 76 65 72 73 69  GMA schema_versi
8270: 6f 6e 22 20 74 6f 20 6d 6f 64 69 66 79 0a 20 20  on" to modify.  
8280: 2a 2a 20 74 68 65 20 73 63 68 65 6d 61 2d 76 65  ** the schema-ve
8290: 72 73 69 6f 6e 20 69 73 20 70 6f 74 65 6e 74 69  rsion is potenti
82a0: 61 6c 6c 79 20 64 61 6e 67 65 72 6f 75 73 20 61  ally dangerous a
82b0: 6e 64 20 6d 61 79 20 6c 65 61 64 20 74 6f 20 70  nd may lead to p
82c0: 72 6f 67 72 61 6d 0a 20 20 2a 2a 20 63 72 61 73  rogram.  ** cras
82d0: 68 65 73 20 6f 72 20 64 61 74 61 62 61 73 65 20  hes or database 
82e0: 63 6f 72 72 75 70 74 69 6f 6e 2e 20 55 73 65 20  corruption. Use 
82f0: 77 69 74 68 20 63 61 75 74 69 6f 6e 21 0a 20 20  with caution!.  
8300: 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 75 73 65 72  **.  ** The user
8310: 2d 76 65 72 73 69 6f 6e 20 69 73 20 6e 6f 74 20  -version is not 
8320: 75 73 65 64 20 69 6e 74 65 72 6e 61 6c 6c 79 20  used internally 
8330: 62 79 20 53 51 4c 69 74 65 2e 20 49 74 20 6d 61  by SQLite. It ma
8340: 79 20 62 65 20 75 73 65 64 20 62 79 0a 20 20 2a  y be used by.  *
8350: 2a 20 61 70 70 6c 69 63 61 74 69 6f 6e 73 20 66  * applications f
8360: 6f 72 20 61 6e 79 20 70 75 72 70 6f 73 65 2e 0a  or any purpose..
8370: 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74    */.  if( sqlit
8380: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
8390: 20 22 73 63 68 65 6d 61 5f 76 65 72 73 69 6f 6e   "schema_version
83a0: 22 29 3d 3d 30 20 7c 7c 0a 20 20 20 20 20 20 73  ")==0 ||.      s
83b0: 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c  qlite3StrICmp(zL
83c0: 65 66 74 2c 20 22 75 73 65 72 5f 76 65 72 73 69  eft, "user_versi
83d0: 6f 6e 22 29 3d 3d 30 20 29 7b 0a 0a 20 20 20 20  on")==0 ){..    
83e0: 69 6e 74 20 69 43 6f 6f 6b 69 65 3b 20 20 20 2f  int iCookie;   /
83f0: 2a 20 43 6f 6f 6b 69 65 20 69 6e 64 65 78 2e 20  * Cookie index. 
8400: 30 20 66 6f 72 20 73 63 68 65 6d 61 2d 63 6f 6f  0 for schema-coo
8410: 6b 69 65 2c 20 36 20 66 6f 72 20 75 73 65 72 2d  kie, 6 for user-
8420: 63 6f 6f 6b 69 65 2e 20 2a 2f 0a 20 20 20 20 69  cookie. */.    i
8430: 66 28 20 7a 4c 65 66 74 5b 30 5d 3d 3d 27 73 27  f( zLeft[0]=='s'
8440: 20 7c 7c 20 7a 4c 65 66 74 5b 30 5d 3d 3d 27 53   || zLeft[0]=='S
8450: 27 20 29 7b 0a 20 20 20 20 20 20 69 43 6f 6f 6b  ' ){.      iCook
8460: 69 65 20 3d 20 30 3b 0a 20 20 20 20 7d 65 6c 73  ie = 0;.    }els
8470: 65 7b 0a 20 20 20 20 20 20 69 43 6f 6f 6b 69 65  e{.      iCookie
8480: 20 3d 20 35 3b 0a 20 20 20 20 7d 0a 0a 20 20 20   = 5;.    }..   
8490: 20 69 66 28 20 7a 52 69 67 68 74 20 29 7b 0a 20   if( zRight ){. 
84a0: 20 20 20 20 20 2f 2a 20 57 72 69 74 65 20 74 68       /* Write th
84b0: 65 20 73 70 65 63 69 66 69 65 64 20 63 6f 6f 6b  e specified cook
84c0: 69 65 20 76 61 6c 75 65 20 2a 2f 0a 20 20 20 20  ie value */.    
84d0: 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20 56    static const V
84e0: 64 62 65 4f 70 4c 69 73 74 20 73 65 74 43 6f 6f  dbeOpList setCoo
84f0: 6b 69 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20  kie[] = {.      
8500: 20 20 7b 20 4f 50 5f 54 72 61 6e 73 61 63 74 69    { OP_Transacti
8510: 6f 6e 2c 20 20 20 20 30 2c 20 20 31 2c 20 20 30  on,    0,  1,  0
8520: 7d 2c 20 20 20 20 2f 2a 20 30 20 2a 2f 0a 20 20  },    /* 0 */.  
8530: 20 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67        { OP_Integ
8540: 65 72 2c 20 20 20 20 20 20 20 20 30 2c 20 20 30  er,        0,  0
8550: 2c 20 20 30 7d 2c 20 20 20 20 2f 2a 20 31 20 2a  ,  0},    /* 1 *
8560: 2f 0a 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 53  /.        { OP_S
8570: 65 74 43 6f 6f 6b 69 65 2c 20 20 20 20 20 20 30  etCookie,      0
8580: 2c 20 20 30 2c 20 20 30 7d 2c 20 20 20 20 2f 2a  ,  0,  0},    /*
8590: 20 32 20 2a 2f 0a 20 20 20 20 20 20 7d 3b 0a 20   2 */.      };. 
85a0: 20 20 20 20 20 69 6e 74 20 61 64 64 72 20 3d 20       int addr = 
85b0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
85c0: 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53 69 7a  List(v, ArraySiz
85d0: 65 28 73 65 74 43 6f 6f 6b 69 65 29 2c 20 73 65  e(setCookie), se
85e0: 74 43 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 20 20  tCookie);.      
85f0: 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67  sqlite3VdbeChang
8600: 65 50 31 28 76 2c 20 61 64 64 72 2c 20 69 44 62  eP1(v, addr, iDb
8610: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
8620: 56 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20  VdbeChangeP1(v, 
8630: 61 64 64 72 2b 31 2c 20 61 74 6f 69 28 7a 52 69  addr+1, atoi(zRi
8640: 67 68 74 29 29 3b 0a 20 20 20 20 20 20 73 71 6c  ght));.      sql
8650: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 31  ite3VdbeChangeP1
8660: 28 76 2c 20 61 64 64 72 2b 32 2c 20 69 44 62 29  (v, addr+2, iDb)
8670: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
8680: 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c 20 61  dbeChangeP2(v, a
8690: 64 64 72 2b 32 2c 20 69 43 6f 6f 6b 69 65 29 3b  ddr+2, iCookie);
86a0: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
86b0: 20 20 2f 2a 20 52 65 61 64 20 74 68 65 20 73 70    /* Read the sp
86c0: 65 63 69 66 69 65 64 20 63 6f 6f 6b 69 65 20 76  ecified cookie v
86d0: 61 6c 75 65 20 2a 2f 0a 20 20 20 20 20 20 73 74  alue */.      st
86e0: 61 74 69 63 20 63 6f 6e 73 74 20 56 64 62 65 4f  atic const VdbeO
86f0: 70 4c 69 73 74 20 72 65 61 64 43 6f 6f 6b 69 65  pList readCookie
8700: 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 20 20 7b  [] = {.        {
8710: 20 4f 50 5f 52 65 61 64 43 6f 6f 6b 69 65 2c 20   OP_ReadCookie, 
8720: 20 20 20 20 20 30 2c 20 20 30 2c 20 20 30 7d 2c       0,  0,  0},
8730: 20 20 20 20 2f 2a 20 30 20 2a 2f 0a 20 20 20 20      /* 0 */.    
8740: 20 20 20 20 7b 20 4f 50 5f 43 61 6c 6c 62 61 63      { OP_Callbac
8750: 6b 2c 20 20 20 20 20 20 20 20 31 2c 20 20 30 2c  k,        1,  0,
8760: 20 20 30 7d 0a 20 20 20 20 20 20 7d 3b 0a 20 20    0}.      };.  
8770: 20 20 20 20 69 6e 74 20 61 64 64 72 20 3d 20 73      int addr = s
8780: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c  qlite3VdbeAddOpL
8790: 69 73 74 28 76 2c 20 41 72 72 61 79 53 69 7a 65  ist(v, ArraySize
87a0: 28 72 65 61 64 43 6f 6f 6b 69 65 29 2c 20 72 65  (readCookie), re
87b0: 61 64 43 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 20  adCookie);.     
87c0: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
87d0: 67 65 50 31 28 76 2c 20 61 64 64 72 2c 20 69 44  geP1(v, addr, iD
87e0: 62 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  b);.      sqlite
87f0: 33 56 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c  3VdbeChangeP2(v,
8800: 20 61 64 64 72 2c 20 69 43 6f 6f 6b 69 65 29 3b   addr, iCookie);
8810: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
8820: 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20  beSetNumCols(v, 
8830: 31 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  1);.      sqlite
8840: 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28  3VdbeSetColName(
8850: 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41  v, 0, COLNAME_NA
8860: 4d 45 2c 20 7a 4c 65 66 74 2c 20 50 33 5f 54 52  ME, zLeft, P3_TR
8870: 41 4e 53 49 45 4e 54 29 3b 0a 20 20 20 20 7d 0a  ANSIENT);.    }.
8880: 20 20 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51    }.#endif /* SQ
8890: 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48 45 4d 41  LITE_OMIT_SCHEMA
88a0: 5f 56 45 52 53 49 4f 4e 5f 50 52 41 47 4d 41 53  _VERSION_PRAGMAS
88b0: 20 2a 2f 0a 0a 23 69 66 20 64 65 66 69 6e 65 64   */..#if defined
88c0: 28 53 51 4c 49 54 45 5f 44 45 42 55 47 29 20 7c  (SQLITE_DEBUG) |
88d0: 7c 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45  | defined(SQLITE
88e0: 5f 54 45 53 54 29 0a 20 20 2f 2a 0a 20 20 2a 2a  _TEST).  /*.  **
88f0: 20 52 65 70 6f 72 74 20 74 68 65 20 63 75 72 72   Report the curr
8900: 65 6e 74 20 73 74 61 74 65 20 6f 66 20 66 69 6c  ent state of fil
8910: 65 20 6c 6f 67 73 20 66 6f 72 20 61 6c 6c 20 64  e logs for all d
8920: 61 74 61 62 61 73 65 73 0a 20 20 2a 2f 0a 20 20  atabases.  */.  
8930: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
8940: 6d 70 28 7a 4c 65 66 74 2c 20 22 6c 6f 63 6b 5f  mp(zLeft, "lock_
8950: 73 74 61 74 75 73 22 29 3d 3d 30 20 29 7b 0a 20  status")==0 ){. 
8960: 20 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20     static const 
8970: 63 68 61 72 20 2a 63 6f 6e 73 74 20 61 7a 4c 6f  char *const azLo
8980: 63 6b 4e 61 6d 65 5b 5d 20 3d 20 7b 0a 20 20 20  ckName[] = {.   
8990: 20 20 20 22 75 6e 6c 6f 63 6b 65 64 22 2c 20 22     "unlocked", "
89a0: 73 68 61 72 65 64 22 2c 20 22 72 65 73 65 72 76  shared", "reserv
89b0: 65 64 22 2c 20 22 70 65 6e 64 69 6e 67 22 2c 20  ed", "pending", 
89c0: 22 65 78 63 6c 75 73 69 76 65 22 0a 20 20 20 20  "exclusive".    
89d0: 7d 3b 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20 20  };.    int i;.  
89e0: 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71 6c 69    Vdbe *v = sqli
89f0: 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72 73  te3GetVdbe(pPars
8a00: 65 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  e);.    sqlite3V
8a10: 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c  dbeSetNumCols(v,
8a20: 20 32 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33   2);.    sqlite3
8a30: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
8a40: 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 0, COLNAME_NAM
8a50: 45 2c 20 22 64 61 74 61 62 61 73 65 22 2c 20 50  E, "database", P
8a60: 33 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 73  3_STATIC);.    s
8a70: 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c  qlite3VdbeSetCol
8a80: 4e 61 6d 65 28 76 2c 20 31 2c 20 43 4f 4c 4e 41  Name(v, 1, COLNA
8a90: 4d 45 5f 4e 41 4d 45 2c 20 22 73 74 61 74 75 73  ME_NAME, "status
8aa0: 22 2c 20 50 33 5f 53 54 41 54 49 43 29 3b 0a 20  ", P3_STATIC);. 
8ab0: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62     for(i=0; i<db
8ac0: 2d 3e 6e 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20  ->nDb; i++){.   
8ad0: 20 20 20 42 74 72 65 65 20 2a 70 42 74 3b 0a 20     Btree *pBt;. 
8ae0: 20 20 20 20 20 50 61 67 65 72 20 2a 70 50 61 67       Pager *pPag
8af0: 65 72 3b 0a 20 20 20 20 20 20 69 66 28 20 64 62  er;.      if( db
8b00: 2d 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 3d 3d  ->aDb[i].zName==
8b10: 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20  0 ) continue;.  
8b20: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 4f      sqlite3VdbeO
8b30: 70 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38  p3(v, OP_String8
8b40: 2c 20 30 2c 20 30 2c 20 64 62 2d 3e 61 44 62 5b  , 0, 0, db->aDb[
8b50: 69 5d 2e 7a 4e 61 6d 65 2c 20 50 33 5f 53 54 41  i].zName, P3_STA
8b60: 54 49 43 29 3b 0a 20 20 20 20 20 20 70 42 74 20  TIC);.      pBt 
8b70: 3d 20 64 62 2d 3e 61 44 62 5b 69 5d 2e 70 42 74  = db->aDb[i].pBt
8b80: 3b 0a 20 20 20 20 20 20 69 66 28 20 70 42 74 3d  ;.      if( pBt=
8b90: 3d 30 20 7c 7c 20 28 70 50 61 67 65 72 20 3d 20  =0 || (pPager = 
8ba0: 73 71 6c 69 74 65 33 42 74 72 65 65 50 61 67 65  sqlite3BtreePage
8bb0: 72 28 70 42 74 29 29 3d 3d 30 20 29 7b 0a 20 20  r(pBt))==0 ){.  
8bc0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
8bd0: 65 4f 70 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e  eOp3(v, OP_Strin
8be0: 67 38 2c 20 30 2c 20 30 2c 20 22 63 6c 6f 73 65  g8, 0, 0, "close
8bf0: 64 22 2c 20 50 33 5f 53 54 41 54 49 43 29 3b 0a  d", P3_STATIC);.
8c00: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
8c10: 20 20 20 20 20 69 6e 74 20 6a 20 3d 20 73 71 6c       int j = sql
8c20: 69 74 65 33 50 61 67 65 72 4c 6f 63 6b 73 74 61  ite3PagerLocksta
8c30: 74 65 28 70 50 61 67 65 72 29 3b 0a 20 20 20 20  te(pPager);.    
8c40: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 4f      sqlite3VdbeO
8c50: 70 33 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38  p3(v, OP_String8
8c60: 2c 20 30 2c 20 30 2c 20 0a 20 20 20 20 20 20 20  , 0, 0, .       
8c70: 20 20 20 20 20 28 6a 3e 3d 30 20 26 26 20 6a 3c       (j>=0 && j<
8c80: 3d 34 29 20 3f 20 61 7a 4c 6f 63 6b 4e 61 6d 65  =4) ? azLockName
8c90: 5b 6a 5d 20 3a 20 22 75 6e 6b 6e 6f 77 6e 22 2c  [j] : "unknown",
8ca0: 20 50 33 5f 53 54 41 54 49 43 29 3b 0a 20 20 20   P3_STATIC);.   
8cb0: 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74     }.      sqlit
8cc0: 65 33 56 64 62 65 41 64 64 4f 70 28 76 2c 20 4f  e3VdbeAddOp(v, O
8cd0: 50 5f 43 61 6c 6c 62 61 63 6b 2c 20 32 2c 20 30  P_Callback, 2, 0
8ce0: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65  );.    }.  }else
8cf0: 0a 23 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20  .#endif..#ifdef 
8d00: 53 51 4c 49 54 45 5f 53 53 45 0a 20 20 2f 2a 0a  SQLITE_SSE.  /*.
8d10: 20 20 2a 2a 20 43 68 65 63 6b 20 74 6f 20 73 65    ** Check to se
8d20: 65 20 69 66 20 74 68 65 20 73 71 6c 69 74 65 5f  e if the sqlite_
8d30: 73 74 61 74 65 6d 65 6e 74 73 20 74 61 62 6c 65  statements table
8d40: 20 65 78 69 73 74 73 2e 20 20 43 72 65 61 74 65   exists.  Create
8d50: 20 69 74 0a 20 20 2a 2a 20 69 66 20 69 74 20 64   it.  ** if it d
8d60: 6f 65 73 20 6e 6f 74 2e 0a 20 20 2a 2f 0a 20 20  oes not..  */.  
8d70: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
8d80: 6d 70 28 7a 4c 65 66 74 2c 20 22 63 72 65 61 74  mp(zLeft, "creat
8d90: 65 5f 73 71 6c 69 74 65 5f 73 74 61 74 65 6d 65  e_sqlite_stateme
8da0: 6e 74 5f 74 61 62 6c 65 22 29 3d 3d 30 20 29 7b  nt_table")==0 ){
8db0: 0a 20 20 20 20 65 78 74 65 72 6e 20 69 6e 74 20  .    extern int 
8dc0: 73 71 6c 69 74 65 33 43 72 65 61 74 65 53 74 61  sqlite3CreateSta
8dd0: 74 65 6d 65 6e 74 73 54 61 62 6c 65 28 50 61 72  tementsTable(Par
8de0: 73 65 2a 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  se*);.    sqlite
8df0: 33 43 72 65 61 74 65 53 74 61 74 65 6d 65 6e 74  3CreateStatement
8e00: 73 54 61 62 6c 65 28 70 50 61 72 73 65 29 3b 0a  sTable(pParse);.
8e10: 20 20 7d 65 6c 73 65 0a 23 65 6e 64 69 66 0a 0a    }else.#endif..
8e20: 23 69 66 20 53 51 4c 49 54 45 5f 48 41 53 5f 43  #if SQLITE_HAS_C
8e30: 4f 44 45 43 0a 20 20 69 66 28 20 73 71 6c 69 74  ODEC.  if( sqlit
8e40: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
8e50: 20 22 6b 65 79 22 29 3d 3d 30 20 29 7b 0a 20 20   "key")==0 ){.  
8e60: 20 20 73 71 6c 69 74 65 33 5f 6b 65 79 28 64 62    sqlite3_key(db
8e70: 2c 20 7a 52 69 67 68 74 2c 20 73 74 72 6c 65 6e  , zRight, strlen
8e80: 28 7a 52 69 67 68 74 29 29 3b 0a 20 20 7d 65 6c  (zRight));.  }el
8e90: 73 65 0a 23 65 6e 64 69 66 0a 23 69 66 20 53 51  se.#endif.#if SQ
8ea0: 4c 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 20 7c  LITE_HAS_CODEC |
8eb0: 7c 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45  | defined(SQLITE
8ec0: 5f 45 4e 41 42 4c 45 5f 43 45 52 4f 44 29 0a 20  _ENABLE_CEROD). 
8ed0: 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49   if( sqlite3StrI
8ee0: 43 6d 70 28 7a 4c 65 66 74 2c 20 22 61 63 74 69  Cmp(zLeft, "acti
8ef0: 76 61 74 65 5f 65 78 74 65 6e 73 69 6f 6e 73 22  vate_extensions"
8f00: 29 3d 3d 30 20 29 7b 0a 23 69 66 20 53 51 4c 49  )==0 ){.#if SQLI
8f10: 54 45 5f 48 41 53 5f 43 4f 44 45 43 0a 20 20 20  TE_HAS_CODEC.   
8f20: 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 4e   if( sqlite3StrN
8f30: 49 43 6d 70 28 7a 52 69 67 68 74 2c 20 22 73 65  ICmp(zRight, "se
8f40: 65 2d 22 2c 20 34 29 3d 3d 30 20 29 7b 0a 20 20  e-", 4)==0 ){.  
8f50: 20 20 20 20 65 78 74 65 72 6e 20 76 6f 69 64 20      extern void 
8f60: 73 71 6c 69 74 65 33 5f 61 63 74 69 76 61 74 65  sqlite3_activate
8f70: 5f 73 65 65 28 63 6f 6e 73 74 20 63 68 61 72 2a  _see(const char*
8f80: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
8f90: 5f 61 63 74 69 76 61 74 65 5f 73 65 65 28 26 7a  _activate_see(&z
8fa0: 52 69 67 68 74 5b 34 5d 29 3b 0a 20 20 20 20 7d  Right[4]);.    }
8fb0: 0a 23 65 6e 64 69 66 0a 23 69 66 64 65 66 20 53  .#endif.#ifdef S
8fc0: 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 43 45 52  QLITE_ENABLE_CER
8fd0: 4f 44 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74  OD.    if( sqlit
8fe0: 65 33 53 74 72 4e 49 43 6d 70 28 7a 52 69 67 68  e3StrNICmp(zRigh
8ff0: 74 2c 20 22 63 65 72 6f 64 2d 22 2c 20 36 29 3d  t, "cerod-", 6)=
9000: 3d 30 20 29 7b 0a 20 20 20 20 20 20 65 78 74 65  =0 ){.      exte
9010: 72 6e 20 76 6f 69 64 20 73 71 6c 69 74 65 33 5f  rn void sqlite3_
9020: 61 63 74 69 76 61 74 65 5f 63 65 72 6f 64 28 63  activate_cerod(c
9030: 6f 6e 73 74 20 63 68 61 72 2a 29 3b 0a 20 20 20  onst char*);.   
9040: 20 20 20 73 71 6c 69 74 65 33 5f 61 63 74 69 76     sqlite3_activ
9050: 61 74 65 5f 63 65 72 6f 64 28 26 7a 52 69 67 68  ate_cerod(&zRigh
9060: 74 5b 36 5d 29 3b 0a 20 20 20 20 7d 0a 23 65 6e  t[6]);.    }.#en
9070: 64 69 66 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 0a  dif.  }.#endif..
9080: 20 20 7b 7d 0a 0a 20 20 69 66 28 20 76 20 29 7b    {}..  if( v ){
9090: 0a 20 20 20 20 2f 2a 20 43 6f 64 65 20 61 6e 20  .    /* Code an 
90a0: 4f 50 5f 45 78 70 69 72 65 20 61 74 20 74 68 65  OP_Expire at the
90b0: 20 65 6e 64 20 6f 66 20 65 61 63 68 20 50 52 41   end of each PRA
90c0: 47 4d 41 20 70 72 6f 67 72 61 6d 20 74 6f 20 63  GMA program to c
90d0: 61 75 73 65 0a 20 20 20 20 2a 2a 20 74 68 65 20  ause.    ** the 
90e0: 56 44 42 45 20 69 6d 70 6c 65 6d 65 6e 74 69 6e  VDBE implementin
90f0: 67 20 74 68 65 20 70 72 61 67 6d 61 20 74 6f 20  g the pragma to 
9100: 65 78 70 69 72 65 2e 20 4d 6f 73 74 20 28 61 6c  expire. Most (al
9110: 6c 3f 29 20 70 72 61 67 6d 61 73 0a 20 20 20 20  l?) pragmas.    
9120: 2a 2a 20 61 72 65 20 6f 6e 6c 79 20 76 61 6c 69  ** are only vali
9130: 64 20 66 6f 72 20 61 20 73 69 6e 67 6c 65 20 65  d for a single e
9140: 78 65 63 75 74 69 6f 6e 2e 0a 20 20 20 20 2a 2f  xecution..    */
9150: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
9160: 41 64 64 4f 70 28 76 2c 20 4f 50 5f 45 78 70 69  AddOp(v, OP_Expi
9170: 72 65 2c 20 31 2c 20 30 29 3b 0a 0a 20 20 20 20  re, 1, 0);..    
9180: 2f 2a 0a 20 20 20 20 2a 2a 20 52 65 73 65 74 20  /*.    ** Reset 
9190: 74 68 65 20 73 61 66 65 74 79 20 6c 65 76 65 6c  the safety level
91a0: 2c 20 69 6e 20 63 61 73 65 20 74 68 65 20 66 75  , in case the fu
91b0: 6c 6c 66 73 79 6e 63 20 66 6c 61 67 20 6f 72 20  llfsync flag or 
91c0: 73 79 6e 63 68 72 6f 6e 6f 75 73 0a 20 20 20 20  synchronous.    
91d0: 2a 2a 20 73 65 74 74 69 6e 67 20 63 68 61 6e 67  ** setting chang
91e0: 65 64 2e 0a 20 20 20 20 2a 2f 0a 23 69 66 6e 64  ed..    */.#ifnd
91f0: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50  ef SQLITE_OMIT_P
9200: 41 47 45 52 5f 50 52 41 47 4d 41 53 0a 20 20 20  AGER_PRAGMAS.   
9210: 20 69 66 28 20 64 62 2d 3e 61 75 74 6f 43 6f 6d   if( db->autoCom
9220: 6d 69 74 20 29 7b 0a 20 20 20 20 20 20 73 71 6c  mit ){.      sql
9230: 69 74 65 33 42 74 72 65 65 53 65 74 53 61 66 65  ite3BtreeSetSafe
9240: 74 79 4c 65 76 65 6c 28 70 44 62 2d 3e 70 42 74  tyLevel(pDb->pBt
9250: 2c 20 70 44 62 2d 3e 73 61 66 65 74 79 5f 6c 65  , pDb->safety_le
9260: 76 65 6c 2c 0a 20 20 20 20 20 20 20 20 20 20 20  vel,.           
9270: 20 20 20 20 20 20 28 64 62 2d 3e 66 6c 61 67 73        (db->flags
9280: 26 53 51 4c 49 54 45 5f 46 75 6c 6c 46 53 79 6e  &SQLITE_FullFSyn
9290: 63 29 21 3d 30 29 3b 0a 20 20 20 20 7d 0a 23 65  c)!=0);.    }.#e
92a0: 6e 64 69 66 0a 20 20 7d 0a 70 72 61 67 6d 61 5f  ndif.  }.pragma_
92b0: 6f 75 74 3a 0a 20 20 73 71 6c 69 74 65 46 72 65  out:.  sqliteFre
92c0: 65 28 7a 4c 65 66 74 29 3b 0a 20 20 73 71 6c 69  e(zLeft);.  sqli
92d0: 74 65 46 72 65 65 28 7a 52 69 67 68 74 29 3b 0a  teFree(zRight);.
92e0: 7d 0a 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c  }..#endif /* SQL
92f0: 49 54 45 5f 4f 4d 49 54 5f 50 52 41 47 4d 41 20  ITE_OMIT_PRAGMA 
9300: 7c 7c 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50  || SQLITE_OMIT_P
9310: 41 52 53 45 52 20 2a 2f 0a                       ARSER */.