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

Artifact bae3ce82ca6d0ac5d3ca3e46b286856d1f0ddd70:


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 2f 0a 23 69 6e 63 6c 75 64 65 20 22  d..*/.#include "
01c0: 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a 0a 2f 2a  sqliteInt.h"../*
01d0: 20 49 67 6e 6f 72 65 20 74 68 69 73 20 77 68 6f   Ignore this who
01e0: 6c 65 20 66 69 6c 65 20 69 66 20 70 72 61 67 6d  le file if pragm
01f0: 61 73 20 61 72 65 20 64 69 73 61 62 6c 65 64 0a  as are disabled.
0200: 2a 2f 0a 23 69 66 20 21 64 65 66 69 6e 65 64 28  */.#if !defined(
0210: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 52 41 47  SQLITE_OMIT_PRAG
0220: 4d 41 29 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74 65 72  MA)../*.** Inter
0230: 70 72 65 74 20 74 68 65 20 67 69 76 65 6e 20 73  pret the given s
0240: 74 72 69 6e 67 20 61 73 20 61 20 73 61 66 65 74  tring as a safet
0250: 79 20 6c 65 76 65 6c 2e 20 20 52 65 74 75 72 6e  y level.  Return
0260: 20 30 20 66 6f 72 20 4f 46 46 2c 0a 2a 2a 20 31   0 for OFF,.** 1
0270: 20 66 6f 72 20 4f 4e 20 6f 72 20 4e 4f 52 4d 41   for ON or NORMA
0280: 4c 20 61 6e 64 20 32 20 66 6f 72 20 46 55 4c 4c  L and 2 for FULL
0290: 2e 20 20 52 65 74 75 72 6e 20 31 20 66 6f 72 20  .  Return 1 for 
02a0: 61 6e 20 65 6d 70 74 79 20 6f 72 20 0a 2a 2a 20  an empty or .** 
02b0: 75 6e 72 65 63 6f 67 6e 69 7a 65 64 20 73 74 72  unrecognized str
02c0: 69 6e 67 20 61 72 67 75 6d 65 6e 74 2e 0a 2a 2a  ing argument..**
02d0: 0a 2a 2a 20 4e 6f 74 65 20 74 68 61 74 20 74 68  .** Note that th
02e0: 65 20 76 61 6c 75 65 73 20 72 65 74 75 72 6e 65  e values returne
02f0: 64 20 61 72 65 20 6f 6e 65 20 6c 65 73 73 20 74  d are one less t
0300: 68 61 74 20 74 68 65 20 76 61 6c 75 65 73 20 74  hat the values t
0310: 68 61 74 0a 2a 2a 20 73 68 6f 75 6c 64 20 62 65  hat.** should be
0320: 20 70 61 73 73 65 64 20 69 6e 74 6f 20 73 71 6c   passed into sql
0330: 69 74 65 33 42 74 72 65 65 53 65 74 53 61 66 65  ite3BtreeSetSafe
0340: 74 79 4c 65 76 65 6c 28 29 2e 20 20 54 68 65 20  tyLevel().  The 
0350: 69 73 20 64 6f 6e 65 0a 2a 2a 20 74 6f 20 73 75  is done.** to su
0360: 70 70 6f 72 74 20 6c 65 67 61 63 79 20 53 51 4c  pport legacy SQL
0370: 20 63 6f 64 65 2e 20 20 54 68 65 20 73 61 66 65   code.  The safe
0380: 74 79 20 6c 65 76 65 6c 20 75 73 65 64 20 74 6f  ty level used to
0390: 20 62 65 20 62 6f 6f 6c 65 61 6e 0a 2a 2a 20 61   be boolean.** a
03a0: 6e 64 20 6f 6c 64 65 72 20 73 63 72 69 70 74 73  nd older scripts
03b0: 20 6d 61 79 20 68 61 76 65 20 75 73 65 64 20 6e   may have used n
03c0: 75 6d 62 65 72 73 20 30 20 66 6f 72 20 4f 46 46  umbers 0 for OFF
03d0: 20 61 6e 64 20 31 20 66 6f 72 20 4f 4e 2e 0a 2a   and 1 for ON..*
03e0: 2f 0a 73 74 61 74 69 63 20 75 38 20 67 65 74 53  /.static u8 getS
03f0: 61 66 65 74 79 4c 65 76 65 6c 28 63 6f 6e 73 74  afetyLevel(const
0400: 20 63 68 61 72 20 2a 7a 29 7b 0a 20 20 20 20 20   char *z){.     
0410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0420: 20 20 20 20 20 20 20 20 2f 2a 20 31 32 33 34 35          /* 12345
0430: 36 37 38 39 20 31 32 33 34 35 36 37 38 39 20 2a  6789 123456789 *
0440: 2f 0a 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74  /.  static const
0450: 20 63 68 61 72 20 7a 54 65 78 74 5b 5d 20 3d 20   char zText[] = 
0460: 22 6f 6e 6f 66 66 61 6c 73 65 79 65 73 74 72 75  "onoffalseyestru
0470: 65 66 75 6c 6c 22 3b 0a 20 20 73 74 61 74 69 63  efull";.  static
0480: 20 63 6f 6e 73 74 20 75 38 20 69 4f 66 66 73 65   const u8 iOffse
0490: 74 5b 5d 20 3d 20 7b 30 2c 20 31 2c 20 32 2c 20  t[] = {0, 1, 2, 
04a0: 34 2c 20 39 2c 20 31 32 2c 20 31 36 7d 3b 0a 20  4, 9, 12, 16};. 
04b0: 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20 75 38   static const u8
04c0: 20 69 4c 65 6e 67 74 68 5b 5d 20 3d 20 7b 32 2c   iLength[] = {2,
04d0: 20 32 2c 20 33 2c 20 35 2c 20 33 2c 20 34 2c 20   2, 3, 5, 3, 4, 
04e0: 34 7d 3b 0a 20 20 73 74 61 74 69 63 20 63 6f 6e  4};.  static con
04f0: 73 74 20 75 38 20 69 56 61 6c 75 65 5b 5d 20 3d  st u8 iValue[] =
0500: 20 20 7b 31 2c 20 30 2c 20 30 2c 20 30 2c 20 31    {1, 0, 0, 0, 1
0510: 2c 20 31 2c 20 32 7d 3b 0a 20 20 69 6e 74 20 69  , 1, 2};.  int i
0520: 2c 20 6e 3b 0a 20 20 69 66 28 20 73 71 6c 69 74  , n;.  if( sqlit
0530: 65 33 49 73 64 69 67 69 74 28 2a 7a 29 20 29 7b  e3Isdigit(*z) ){
0540: 0a 20 20 20 20 72 65 74 75 72 6e 20 28 75 38 29  .    return (u8)
0550: 61 74 6f 69 28 7a 29 3b 0a 20 20 7d 0a 20 20 6e  atoi(z);.  }.  n
0560: 20 3d 20 73 71 6c 69 74 65 33 53 74 72 6c 65 6e   = sqlite3Strlen
0570: 33 30 28 7a 29 3b 0a 20 20 66 6f 72 28 69 3d 30  30(z);.  for(i=0
0580: 3b 20 69 3c 41 72 72 61 79 53 69 7a 65 28 69 4c  ; i<ArraySize(iL
0590: 65 6e 67 74 68 29 3b 20 69 2b 2b 29 7b 0a 20 20  ength); i++){.  
05a0: 20 20 69 66 28 20 69 4c 65 6e 67 74 68 5b 69 5d    if( iLength[i]
05b0: 3d 3d 6e 20 26 26 20 73 71 6c 69 74 65 33 53 74  ==n && sqlite3St
05c0: 72 4e 49 43 6d 70 28 26 7a 54 65 78 74 5b 69 4f  rNICmp(&zText[iO
05d0: 66 66 73 65 74 5b 69 5d 5d 2c 7a 2c 6e 29 3d 3d  ffset[i]],z,n)==
05e0: 30 20 29 7b 0a 20 20 20 20 20 20 72 65 74 75 72  0 ){.      retur
05f0: 6e 20 69 56 61 6c 75 65 5b 69 5d 3b 0a 20 20 20  n iValue[i];.   
0600: 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20   }.  }.  return 
0610: 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74 65  1;.}../*.** Inte
0620: 72 70 72 65 74 20 74 68 65 20 67 69 76 65 6e 20  rpret the given 
0630: 73 74 72 69 6e 67 20 61 73 20 61 20 62 6f 6f 6c  string as a bool
0640: 65 61 6e 20 76 61 6c 75 65 2e 0a 2a 2f 0a 73 74  ean value..*/.st
0650: 61 74 69 63 20 75 38 20 67 65 74 42 6f 6f 6c 65  atic u8 getBoole
0660: 61 6e 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  an(const char *z
0670: 29 7b 0a 20 20 72 65 74 75 72 6e 20 67 65 74 53  ){.  return getS
0680: 61 66 65 74 79 4c 65 76 65 6c 28 7a 29 26 31 3b  afetyLevel(z)&1;
0690: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74 65 72 70  .}../*.** Interp
06a0: 72 65 74 20 74 68 65 20 67 69 76 65 6e 20 73 74  ret the given st
06b0: 72 69 6e 67 20 61 73 20 61 20 6c 6f 63 6b 69 6e  ring as a lockin
06c0: 67 20 6d 6f 64 65 20 76 61 6c 75 65 2e 0a 2a 2f  g mode value..*/
06d0: 0a 73 74 61 74 69 63 20 69 6e 74 20 67 65 74 4c  .static int getL
06e0: 6f 63 6b 69 6e 67 4d 6f 64 65 28 63 6f 6e 73 74  ockingMode(const
06f0: 20 63 68 61 72 20 2a 7a 29 7b 0a 20 20 69 66 28   char *z){.  if(
0700: 20 7a 20 29 7b 0a 20 20 20 20 69 66 28 20 30 3d   z ){.    if( 0=
0710: 3d 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28  =sqlite3StrICmp(
0720: 7a 2c 20 22 65 78 63 6c 75 73 69 76 65 22 29 20  z, "exclusive") 
0730: 29 20 72 65 74 75 72 6e 20 50 41 47 45 52 5f 4c  ) return PAGER_L
0740: 4f 43 4b 49 4e 47 4d 4f 44 45 5f 45 58 43 4c 55  OCKINGMODE_EXCLU
0750: 53 49 56 45 3b 0a 20 20 20 20 69 66 28 20 30 3d  SIVE;.    if( 0=
0760: 3d 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28  =sqlite3StrICmp(
0770: 7a 2c 20 22 6e 6f 72 6d 61 6c 22 29 20 29 20 72  z, "normal") ) r
0780: 65 74 75 72 6e 20 50 41 47 45 52 5f 4c 4f 43 4b  eturn PAGER_LOCK
0790: 49 4e 47 4d 4f 44 45 5f 4e 4f 52 4d 41 4c 3b 0a  INGMODE_NORMAL;.
07a0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 50 41 47    }.  return PAG
07b0: 45 52 5f 4c 4f 43 4b 49 4e 47 4d 4f 44 45 5f 51  ER_LOCKINGMODE_Q
07c0: 55 45 52 59 3b 0a 7d 0a 0a 23 69 66 6e 64 65 66  UERY;.}..#ifndef
07d0: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54   SQLITE_OMIT_AUT
07e0: 4f 56 41 43 55 55 4d 0a 2f 2a 0a 2a 2a 20 49 6e  OVACUUM./*.** In
07f0: 74 65 72 70 72 65 74 20 74 68 65 20 67 69 76 65  terpret the give
0800: 6e 20 73 74 72 69 6e 67 20 61 73 20 61 6e 20 61  n string as an a
0810: 75 74 6f 2d 76 61 63 75 75 6d 20 6d 6f 64 65 20  uto-vacuum mode 
0820: 76 61 6c 75 65 2e 0a 2a 2a 0a 2a 2a 20 54 68 65  value..**.** The
0830: 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 74 72 69 6e   following strin
0840: 67 73 2c 20 22 6e 6f 6e 65 22 2c 20 22 66 75 6c  gs, "none", "ful
0850: 6c 22 20 61 6e 64 20 22 69 6e 63 72 65 6d 65 6e  l" and "incremen
0860: 74 61 6c 22 20 61 72 65 20 0a 2a 2a 20 61 63 63  tal" are .** acc
0870: 65 70 74 61 62 6c 65 2c 20 61 73 20 61 72 65 20  eptable, as are 
0880: 74 68 65 69 72 20 6e 75 6d 65 72 69 63 20 65 71  their numeric eq
0890: 75 69 76 61 6c 65 6e 74 73 3a 20 30 2c 20 31 20  uivalents: 0, 1 
08a0: 61 6e 64 20 32 20 72 65 73 70 65 63 74 69 76 65  and 2 respective
08b0: 6c 79 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ly..*/.static in
08c0: 74 20 67 65 74 41 75 74 6f 56 61 63 75 75 6d 28  t getAutoVacuum(
08d0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 29 7b 0a  const char *z){.
08e0: 20 20 69 6e 74 20 69 3b 0a 20 20 69 66 28 20 30    int i;.  if( 0
08f0: 3d 3d 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70  ==sqlite3StrICmp
0900: 28 7a 2c 20 22 6e 6f 6e 65 22 29 20 29 20 72 65  (z, "none") ) re
0910: 74 75 72 6e 20 42 54 52 45 45 5f 41 55 54 4f 56  turn BTREE_AUTOV
0920: 41 43 55 55 4d 5f 4e 4f 4e 45 3b 0a 20 20 69 66  ACUUM_NONE;.  if
0930: 28 20 30 3d 3d 73 71 6c 69 74 65 33 53 74 72 49  ( 0==sqlite3StrI
0940: 43 6d 70 28 7a 2c 20 22 66 75 6c 6c 22 29 20 29  Cmp(z, "full") )
0950: 20 72 65 74 75 72 6e 20 42 54 52 45 45 5f 41 55   return BTREE_AU
0960: 54 4f 56 41 43 55 55 4d 5f 46 55 4c 4c 3b 0a 20  TOVACUUM_FULL;. 
0970: 20 69 66 28 20 30 3d 3d 73 71 6c 69 74 65 33 53   if( 0==sqlite3S
0980: 74 72 49 43 6d 70 28 7a 2c 20 22 69 6e 63 72 65  trICmp(z, "incre
0990: 6d 65 6e 74 61 6c 22 29 20 29 20 72 65 74 75 72  mental") ) retur
09a0: 6e 20 42 54 52 45 45 5f 41 55 54 4f 56 41 43 55  n BTREE_AUTOVACU
09b0: 55 4d 5f 49 4e 43 52 3b 0a 20 20 69 20 3d 20 61  UM_INCR;.  i = a
09c0: 74 6f 69 28 7a 29 3b 0a 20 20 72 65 74 75 72 6e  toi(z);.  return
09d0: 20 28 75 38 29 28 28 69 3e 3d 30 26 26 69 3c 3d   (u8)((i>=0&&i<=
09e0: 32 29 3f 69 3a 30 29 3b 0a 7d 0a 23 65 6e 64 69  2)?i:0);.}.#endi
09f0: 66 20 2f 2a 20 69 66 6e 64 65 66 20 53 51 4c 49  f /* ifndef SQLI
0a00: 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 56 41 43 55  TE_OMIT_AUTOVACU
0a10: 55 4d 20 2a 2f 0a 0a 23 69 66 6e 64 65 66 20 53  UM */..#ifndef S
0a20: 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52  QLITE_OMIT_PAGER
0a30: 5f 50 52 41 47 4d 41 53 0a 2f 2a 0a 2a 2a 20 49  _PRAGMAS./*.** I
0a40: 6e 74 65 72 70 72 65 74 20 74 68 65 20 67 69 76  nterpret the giv
0a50: 65 6e 20 73 74 72 69 6e 67 20 61 73 20 61 20 74  en string as a t
0a60: 65 6d 70 20 64 62 20 6c 6f 63 61 74 69 6f 6e 2e  emp db location.
0a70: 20 52 65 74 75 72 6e 20 31 20 66 6f 72 20 66 69   Return 1 for fi
0a80: 6c 65 0a 2a 2a 20 62 61 63 6b 65 64 20 74 65 6d  le.** backed tem
0a90: 70 6f 72 61 72 79 20 64 61 74 61 62 61 73 65 73  porary databases
0aa0: 2c 20 32 20 66 6f 72 20 74 68 65 20 52 65 64 2d  , 2 for the Red-
0ab0: 42 6c 61 63 6b 20 74 72 65 65 20 69 6e 20 6d 65  Black tree in me
0ac0: 6d 6f 72 79 20 64 61 74 61 62 61 73 65 0a 2a 2a  mory database.**
0ad0: 20 61 6e 64 20 30 20 74 6f 20 75 73 65 20 74 68   and 0 to use th
0ae0: 65 20 63 6f 6d 70 69 6c 65 2d 74 69 6d 65 20 64  e compile-time d
0af0: 65 66 61 75 6c 74 2e 0a 2a 2f 0a 73 74 61 74 69  efault..*/.stati
0b00: 63 20 69 6e 74 20 67 65 74 54 65 6d 70 53 74 6f  c int getTempSto
0b10: 72 65 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  re(const char *z
0b20: 29 7b 0a 20 20 69 66 28 20 7a 5b 30 5d 3e 3d 27  ){.  if( z[0]>='
0b30: 30 27 20 26 26 20 7a 5b 30 5d 3c 3d 27 32 27 20  0' && z[0]<='2' 
0b40: 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 7a 5b  ){.    return z[
0b50: 30 5d 20 2d 20 27 30 27 3b 0a 20 20 7d 65 6c 73  0] - '0';.  }els
0b60: 65 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72  e if( sqlite3Str
0b70: 49 43 6d 70 28 7a 2c 20 22 66 69 6c 65 22 29 3d  ICmp(z, "file")=
0b80: 3d 30 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e  =0 ){.    return
0b90: 20 31 3b 0a 20 20 7d 65 6c 73 65 20 69 66 28 20   1;.  }else if( 
0ba0: 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28 7a  sqlite3StrICmp(z
0bb0: 2c 20 22 6d 65 6d 6f 72 79 22 29 3d 3d 30 20 29  , "memory")==0 )
0bc0: 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 32 3b 0a  {.    return 2;.
0bd0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 72 65 74    }else{.    ret
0be0: 75 72 6e 20 30 3b 0a 20 20 7d 0a 7d 0a 23 65 6e  urn 0;.  }.}.#en
0bf0: 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 50 41  dif /* SQLITE_PA
0c00: 47 45 52 5f 50 52 41 47 4d 41 53 20 2a 2f 0a 0a  GER_PRAGMAS */..
0c10: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
0c20: 4d 49 54 5f 50 41 47 45 52 5f 50 52 41 47 4d 41  MIT_PAGER_PRAGMA
0c30: 53 0a 2f 2a 0a 2a 2a 20 49 6e 76 61 6c 69 64 61  S./*.** Invalida
0c40: 74 65 20 74 65 6d 70 20 73 74 6f 72 61 67 65 2c  te temp storage,
0c50: 20 65 69 74 68 65 72 20 77 68 65 6e 20 74 68 65   either when the
0c60: 20 74 65 6d 70 20 73 74 6f 72 61 67 65 20 69 73   temp storage is
0c70: 20 63 68 61 6e 67 65 64 0a 2a 2a 20 66 72 6f 6d   changed.** from
0c80: 20 64 65 66 61 75 6c 74 2c 20 6f 72 20 77 68 65   default, or whe
0c90: 6e 20 27 66 69 6c 65 27 20 61 6e 64 20 74 68 65  n 'file' and the
0ca0: 20 74 65 6d 70 5f 73 74 6f 72 65 5f 64 69 72 65   temp_store_dire
0cb0: 63 74 6f 72 79 20 68 61 73 20 63 68 61 6e 67 65  ctory has change
0cc0: 64 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  d.*/.static int 
0cd0: 69 6e 76 61 6c 69 64 61 74 65 54 65 6d 70 53 74  invalidateTempSt
0ce0: 6f 72 61 67 65 28 50 61 72 73 65 20 2a 70 50 61  orage(Parse *pPa
0cf0: 72 73 65 29 7b 0a 20 20 73 71 6c 69 74 65 33 20  rse){.  sqlite3 
0d00: 2a 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62  *db = pParse->db
0d10: 3b 0a 20 20 69 66 28 20 64 62 2d 3e 61 44 62 5b  ;.  if( db->aDb[
0d20: 31 5d 2e 70 42 74 21 3d 30 20 29 7b 0a 20 20 20  1].pBt!=0 ){.   
0d30: 20 69 66 28 20 21 64 62 2d 3e 61 75 74 6f 43 6f   if( !db->autoCo
0d40: 6d 6d 69 74 20 7c 7c 20 73 71 6c 69 74 65 33 42  mmit || sqlite3B
0d50: 74 72 65 65 49 73 49 6e 52 65 61 64 54 72 61 6e  treeIsInReadTran
0d60: 73 28 64 62 2d 3e 61 44 62 5b 31 5d 2e 70 42 74  s(db->aDb[1].pBt
0d70: 29 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  ) ){.      sqlit
0d80: 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61 72 73  e3ErrorMsg(pPars
0d90: 65 2c 20 22 74 65 6d 70 6f 72 61 72 79 20 73 74  e, "temporary st
0da0: 6f 72 61 67 65 20 63 61 6e 6e 6f 74 20 62 65 20  orage cannot be 
0db0: 63 68 61 6e 67 65 64 20 22 0a 20 20 20 20 20 20  changed ".      
0dc0: 20 20 22 66 72 6f 6d 20 77 69 74 68 69 6e 20 61    "from within a
0dd0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 22 29 3b 0a   transaction");.
0de0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c        return SQL
0df0: 49 54 45 5f 45 52 52 4f 52 3b 0a 20 20 20 20 7d  ITE_ERROR;.    }
0e00: 0a 20 20 20 20 73 71 6c 69 74 65 33 42 74 72 65  .    sqlite3Btre
0e10: 65 43 6c 6f 73 65 28 64 62 2d 3e 61 44 62 5b 31  eClose(db->aDb[1
0e20: 5d 2e 70 42 74 29 3b 0a 20 20 20 20 64 62 2d 3e  ].pBt);.    db->
0e30: 61 44 62 5b 31 5d 2e 70 42 74 20 3d 20 30 3b 0a  aDb[1].pBt = 0;.
0e40: 20 20 20 20 73 71 6c 69 74 65 33 52 65 73 65 74      sqlite3Reset
0e50: 49 6e 74 65 72 6e 61 6c 53 63 68 65 6d 61 28 64  InternalSchema(d
0e60: 62 2c 20 30 29 3b 0a 20 20 7d 0a 20 20 72 65 74  b, 0);.  }.  ret
0e70: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d  urn SQLITE_OK;.}
0e80: 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54  .#endif /* SQLIT
0e90: 45 5f 50 41 47 45 52 5f 50 52 41 47 4d 41 53 20  E_PAGER_PRAGMAS 
0ea0: 2a 2f 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  */..#ifndef SQLI
0eb0: 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52  TE_OMIT_PAGER_PR
0ec0: 41 47 4d 41 53 0a 2f 2a 0a 2a 2a 20 49 66 20 74  AGMAS./*.** If t
0ed0: 68 65 20 54 45 4d 50 20 64 61 74 61 62 61 73 65  he TEMP database
0ee0: 20 69 73 20 6f 70 65 6e 2c 20 63 6c 6f 73 65 20   is open, close 
0ef0: 69 74 20 61 6e 64 20 6d 61 72 6b 20 74 68 65 20  it and mark the 
0f00: 64 61 74 61 62 61 73 65 20 73 63 68 65 6d 61 0a  database schema.
0f10: 2a 2a 20 61 73 20 6e 65 65 64 69 6e 67 20 72 65  ** as needing re
0f20: 6c 6f 61 64 69 6e 67 2e 20 20 54 68 69 73 20 6d  loading.  This m
0f30: 75 73 74 20 62 65 20 64 6f 6e 65 20 77 68 65 6e  ust be done when
0f40: 20 75 73 69 6e 67 20 74 68 65 20 53 51 4c 49 54   using the SQLIT
0f50: 45 5f 54 45 4d 50 5f 53 54 4f 52 45 0a 2a 2a 20  E_TEMP_STORE.** 
0f60: 6f 72 20 44 45 46 41 55 4c 54 5f 54 45 4d 50 5f  or DEFAULT_TEMP_
0f70: 53 54 4f 52 45 20 70 72 61 67 6d 61 73 2e 0a 2a  STORE pragmas..*
0f80: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 63 68 61  /.static int cha
0f90: 6e 67 65 54 65 6d 70 53 74 6f 72 61 67 65 28 50  ngeTempStorage(P
0fa0: 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 63 6f  arse *pParse, co
0fb0: 6e 73 74 20 63 68 61 72 20 2a 7a 53 74 6f 72 61  nst char *zStora
0fc0: 67 65 54 79 70 65 29 7b 0a 20 20 69 6e 74 20 74  geType){.  int t
0fd0: 73 20 3d 20 67 65 74 54 65 6d 70 53 74 6f 72 65  s = getTempStore
0fe0: 28 7a 53 74 6f 72 61 67 65 54 79 70 65 29 3b 0a  (zStorageType);.
0ff0: 20 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20    sqlite3 *db = 
1000: 70 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 69 66  pParse->db;.  if
1010: 28 20 64 62 2d 3e 74 65 6d 70 5f 73 74 6f 72 65  ( db->temp_store
1020: 3d 3d 74 73 20 29 20 72 65 74 75 72 6e 20 53 51  ==ts ) return SQ
1030: 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 66 28 20 69  LITE_OK;.  if( i
1040: 6e 76 61 6c 69 64 61 74 65 54 65 6d 70 53 74 6f  nvalidateTempSto
1050: 72 61 67 65 28 20 70 50 61 72 73 65 20 29 20 21  rage( pParse ) !
1060: 3d 20 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20  = SQLITE_OK ){. 
1070: 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45     return SQLITE
1080: 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 64 62  _ERROR;.  }.  db
1090: 2d 3e 74 65 6d 70 5f 73 74 6f 72 65 20 3d 20 28  ->temp_store = (
10a0: 75 38 29 74 73 3b 0a 20 20 72 65 74 75 72 6e 20  u8)ts;.  return 
10b0: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 23 65 6e  SQLITE_OK;.}.#en
10c0: 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 50 41  dif /* SQLITE_PA
10d0: 47 45 52 5f 50 52 41 47 4d 41 53 20 2a 2f 0a 0a  GER_PRAGMAS */..
10e0: 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20 63  /*.** Generate c
10f0: 6f 64 65 20 74 6f 20 72 65 74 75 72 6e 20 61 20  ode to return a 
1100: 73 69 6e 67 6c 65 20 69 6e 74 65 67 65 72 20 76  single integer v
1110: 61 6c 75 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  alue..*/.static 
1120: 76 6f 69 64 20 72 65 74 75 72 6e 53 69 6e 67 6c  void returnSingl
1130: 65 49 6e 74 28 50 61 72 73 65 20 2a 70 50 61 72  eInt(Parse *pPar
1140: 73 65 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  se, const char *
1150: 7a 4c 61 62 65 6c 2c 20 69 36 34 20 76 61 6c 75  zLabel, i64 valu
1160: 65 29 7b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20  e){.  Vdbe *v = 
1170: 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70  sqlite3GetVdbe(p
1180: 50 61 72 73 65 29 3b 0a 20 20 69 6e 74 20 6d 65  Parse);.  int me
1190: 6d 20 3d 20 2b 2b 70 50 61 72 73 65 2d 3e 6e 4d  m = ++pParse->nM
11a0: 65 6d 3b 0a 20 20 69 36 34 20 2a 70 49 36 34 20  em;.  i64 *pI64 
11b0: 3d 20 73 71 6c 69 74 65 33 44 62 4d 61 6c 6c 6f  = sqlite3DbMallo
11c0: 63 52 61 77 28 70 50 61 72 73 65 2d 3e 64 62 2c  cRaw(pParse->db,
11d0: 20 73 69 7a 65 6f 66 28 76 61 6c 75 65 29 29 3b   sizeof(value));
11e0: 0a 20 20 69 66 28 20 70 49 36 34 20 29 7b 0a 20  .  if( pI64 ){. 
11f0: 20 20 20 6d 65 6d 63 70 79 28 70 49 36 34 2c 20     memcpy(pI64, 
1200: 26 76 61 6c 75 65 2c 20 73 69 7a 65 6f 66 28 76  &value, sizeof(v
1210: 61 6c 75 65 29 29 3b 0a 20 20 7d 0a 20 20 73 71  alue));.  }.  sq
1220: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 34 28  lite3VdbeAddOp4(
1230: 76 2c 20 4f 50 5f 49 6e 74 36 34 2c 20 30 2c 20  v, OP_Int64, 0, 
1240: 6d 65 6d 2c 20 30 2c 20 28 63 68 61 72 2a 29 70  mem, 0, (char*)p
1250: 49 36 34 2c 20 50 34 5f 49 4e 54 36 34 29 3b 0a  I64, P4_INT64);.
1260: 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74    sqlite3VdbeSet
1270: 4e 75 6d 43 6f 6c 73 28 76 2c 20 31 29 3b 0a 20  NumCols(v, 1);. 
1280: 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43   sqlite3VdbeSetC
1290: 6f 6c 4e 61 6d 65 28 76 2c 20 30 2c 20 43 4f 4c  olName(v, 0, COL
12a0: 4e 41 4d 45 5f 4e 41 4d 45 2c 20 7a 4c 61 62 65  NAME_NAME, zLabe
12b0: 6c 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  l, SQLITE_STATIC
12c0: 29 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65  );.  sqlite3Vdbe
12d0: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73  AddOp2(v, OP_Res
12e0: 75 6c 74 52 6f 77 2c 20 6d 65 6d 2c 20 31 29 3b  ultRow, mem, 1);
12f0: 0a 7d 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  .}..#ifndef SQLI
1300: 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41  TE_OMIT_FLAG_PRA
1310: 47 4d 41 53 0a 2f 2a 0a 2a 2a 20 43 68 65 63 6b  GMAS./*.** Check
1320: 20 74 6f 20 73 65 65 20 69 66 20 7a 52 69 67 68   to see if zRigh
1330: 74 20 61 6e 64 20 7a 4c 65 66 74 20 72 65 66 65  t and zLeft refe
1340: 72 20 74 6f 20 61 20 70 72 61 67 6d 61 20 74 68  r to a pragma th
1350: 61 74 20 71 75 65 72 69 65 73 0a 2a 2a 20 6f 72  at queries.** or
1360: 20 63 68 61 6e 67 65 73 20 6f 6e 65 20 6f 66 20   changes one of 
1370: 74 68 65 20 66 6c 61 67 73 20 69 6e 20 64 62 2d  the flags in db-
1380: 3e 66 6c 61 67 73 2e 20 20 52 65 74 75 72 6e 20  >flags.  Return 
1390: 31 20 69 66 20 73 6f 20 61 6e 64 20 30 20 69 66  1 if so and 0 if
13a0: 20 6e 6f 74 2e 0a 2a 2a 20 41 6c 73 6f 2c 20 69   not..** Also, i
13b0: 6d 70 6c 65 6d 65 6e 74 20 74 68 65 20 70 72 61  mplement the pra
13c0: 67 6d 61 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  gma..*/.static i
13d0: 6e 74 20 66 6c 61 67 50 72 61 67 6d 61 28 50 61  nt flagPragma(Pa
13e0: 72 73 65 20 2a 70 50 61 72 73 65 2c 20 63 6f 6e  rse *pParse, con
13f0: 73 74 20 63 68 61 72 20 2a 7a 4c 65 66 74 2c 20  st char *zLeft, 
1400: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 52 69 67  const char *zRig
1410: 68 74 29 7b 0a 20 20 73 74 61 74 69 63 20 63 6f  ht){.  static co
1420: 6e 73 74 20 73 74 72 75 63 74 20 73 50 72 61 67  nst struct sPrag
1430: 6d 61 54 79 70 65 20 7b 0a 20 20 20 20 63 6f 6e  maType {.    con
1440: 73 74 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b 20  st char *zName; 
1450: 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 74 68 65 20   /* Name of the 
1460: 70 72 61 67 6d 61 20 2a 2f 0a 20 20 20 20 69 6e  pragma */.    in
1470: 74 20 6d 61 73 6b 3b 20 20 20 20 20 20 20 20 20  t mask;         
1480: 20 20 2f 2a 20 4d 61 73 6b 20 66 6f 72 20 74 68    /* Mask for th
1490: 65 20 64 62 2d 3e 66 6c 61 67 73 20 76 61 6c 75  e db->flags valu
14a0: 65 20 2a 2f 0a 20 20 7d 20 61 50 72 61 67 6d 61  e */.  } aPragma
14b0: 5b 5d 20 3d 20 7b 0a 20 20 20 20 7b 20 22 66 75  [] = {.    { "fu
14c0: 6c 6c 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 73 22  ll_column_names"
14d0: 2c 20 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f  ,        SQLITE_
14e0: 46 75 6c 6c 43 6f 6c 4e 61 6d 65 73 20 20 7d 2c  FullColNames  },
14f0: 0a 20 20 20 20 7b 20 22 73 68 6f 72 74 5f 63 6f  .    { "short_co
1500: 6c 75 6d 6e 5f 6e 61 6d 65 73 22 2c 20 20 20 20  lumn_names",    
1510: 20 20 20 53 51 4c 49 54 45 5f 53 68 6f 72 74 43     SQLITE_ShortC
1520: 6f 6c 4e 61 6d 65 73 20 7d 2c 0a 20 20 20 20 7b  olNames },.    {
1530: 20 22 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 22   "count_changes"
1540: 2c 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c  ,            SQL
1550: 49 54 45 5f 43 6f 75 6e 74 52 6f 77 73 20 20 20  ITE_CountRows   
1560: 20 20 7d 2c 0a 20 20 20 20 7b 20 22 65 6d 70 74    },.    { "empt
1570: 79 5f 72 65 73 75 6c 74 5f 63 61 6c 6c 62 61 63  y_result_callbac
1580: 6b 73 22 2c 20 20 20 53 51 4c 49 54 45 5f 4e 75  ks",   SQLITE_Nu
1590: 6c 6c 43 61 6c 6c 62 61 63 6b 20 20 7d 2c 0a 20  llCallback  },. 
15a0: 20 20 20 7b 20 22 6c 65 67 61 63 79 5f 66 69 6c     { "legacy_fil
15b0: 65 5f 66 6f 72 6d 61 74 22 2c 20 20 20 20 20 20  e_format",      
15c0: 20 53 51 4c 49 54 45 5f 4c 65 67 61 63 79 46 69   SQLITE_LegacyFi
15d0: 6c 65 46 6d 74 20 7d 2c 0a 20 20 20 20 7b 20 22  leFmt },.    { "
15e0: 66 75 6c 6c 66 73 79 6e 63 22 2c 20 20 20 20 20  fullfsync",     
15f0: 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 49 54             SQLIT
1600: 45 5f 46 75 6c 6c 46 53 79 6e 63 20 20 20 20 20  E_FullFSync     
1610: 7d 2c 0a 20 20 20 20 7b 20 22 72 65 76 65 72 73  },.    { "revers
1620: 65 5f 75 6e 6f 72 64 65 72 65 64 5f 73 65 6c 65  e_unordered_sele
1630: 63 74 73 22 2c 20 53 51 4c 49 54 45 5f 52 65 76  cts", SQLITE_Rev
1640: 65 72 73 65 4f 72 64 65 72 20 20 7d 2c 0a 23 69  erseOrder  },.#i
1650: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
1660: 54 5f 41 55 54 4f 4d 41 54 49 43 5f 49 4e 44 45  T_AUTOMATIC_INDE
1670: 58 0a 20 20 20 20 7b 20 22 61 75 74 6f 6d 61 74  X.    { "automat
1680: 69 63 5f 69 6e 64 65 78 22 2c 20 20 20 20 20 20  ic_index",      
1690: 20 20 20 20 53 51 4c 49 54 45 5f 41 75 74 6f 49      SQLITE_AutoI
16a0: 6e 64 65 78 20 20 20 20 20 7d 2c 0a 23 65 6e 64  ndex     },.#end
16b0: 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  if.#ifdef SQLITE
16c0: 5f 44 45 42 55 47 0a 20 20 20 20 7b 20 22 73 71  _DEBUG.    { "sq
16d0: 6c 5f 74 72 61 63 65 22 2c 20 20 20 20 20 20 20  l_trace",       
16e0: 20 20 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f           SQLITE_
16f0: 53 71 6c 54 72 61 63 65 20 20 20 20 20 20 7d 2c  SqlTrace      },
1700: 0a 20 20 20 20 7b 20 22 76 64 62 65 5f 6c 69 73  .    { "vdbe_lis
1710: 74 69 6e 67 22 2c 20 20 20 20 20 20 20 20 20 20  ting",          
1720: 20 20 20 53 51 4c 49 54 45 5f 56 64 62 65 4c 69     SQLITE_VdbeLi
1730: 73 74 69 6e 67 20 20 20 7d 2c 0a 20 20 20 20 7b  sting   },.    {
1740: 20 22 76 64 62 65 5f 74 72 61 63 65 22 2c 20 20   "vdbe_trace",  
1750: 20 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c               SQL
1760: 49 54 45 5f 56 64 62 65 54 72 61 63 65 20 20 20  ITE_VdbeTrace   
1770: 20 20 7d 2c 0a 23 65 6e 64 69 66 0a 23 69 66 6e    },.#endif.#ifn
1780: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
1790: 43 48 45 43 4b 0a 20 20 20 20 7b 20 22 69 67 6e  CHECK.    { "ign
17a0: 6f 72 65 5f 63 68 65 63 6b 5f 63 6f 6e 73 74 72  ore_check_constr
17b0: 61 69 6e 74 73 22 2c 20 53 51 4c 49 54 45 5f 49  aints", SQLITE_I
17c0: 67 6e 6f 72 65 43 68 65 63 6b 73 20 20 7d 2c 0a  gnoreChecks  },.
17d0: 23 65 6e 64 69 66 0a 20 20 20 20 2f 2a 20 54 68  #endif.    /* Th
17e0: 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 69 73 20 56  e following is V
17f0: 45 52 59 20 65 78 70 65 72 69 6d 65 6e 74 61 6c  ERY experimental
1800: 20 2a 2f 0a 20 20 20 20 7b 20 22 77 72 69 74 61   */.    { "writa
1810: 62 6c 65 5f 73 63 68 65 6d 61 22 2c 20 20 20 20  ble_schema",    
1820: 20 20 20 20 20 20 53 51 4c 49 54 45 5f 57 72 69        SQLITE_Wri
1830: 74 65 53 63 68 65 6d 61 7c 53 51 4c 49 54 45 5f  teSchema|SQLITE_
1840: 52 65 63 6f 76 65 72 79 4d 6f 64 65 20 7d 2c 0a  RecoveryMode },.
1850: 20 20 20 20 7b 20 22 6f 6d 69 74 5f 72 65 61 64      { "omit_read
1860: 6c 6f 63 6b 22 2c 20 20 20 20 20 20 20 20 20 20  lock",          
1870: 20 20 53 51 4c 49 54 45 5f 4e 6f 52 65 61 64 6c    SQLITE_NoReadl
1880: 6f 63 6b 20 20 20 20 7d 2c 0a 0a 20 20 20 20 2f  ock    },..    /
1890: 2a 20 54 4f 44 4f 3a 20 4d 61 79 62 65 20 69 74  * TODO: Maybe it
18a0: 20 73 68 6f 75 6c 64 6e 27 74 20 62 65 20 70 6f   shouldn't be po
18b0: 73 73 69 62 6c 65 20 74 6f 20 63 68 61 6e 67 65  ssible to change
18c0: 20 74 68 65 20 52 65 61 64 55 6e 63 6f 6d 6d 69   the ReadUncommi
18d0: 74 74 65 64 0a 20 20 20 20 2a 2a 20 66 6c 61 67  tted.    ** flag
18e0: 20 69 66 20 74 68 65 72 65 20 61 72 65 20 61 6e   if there are an
18f0: 79 20 61 63 74 69 76 65 20 73 74 61 74 65 6d 65  y active stateme
1900: 6e 74 73 2e 20 2a 2f 0a 20 20 20 20 7b 20 22 72  nts. */.    { "r
1910: 65 61 64 5f 75 6e 63 6f 6d 6d 69 74 74 65 64 22  ead_uncommitted"
1920: 2c 20 20 20 20 20 20 20 20 20 53 51 4c 49 54 45  ,         SQLITE
1930: 5f 52 65 61 64 55 6e 63 6f 6d 6d 69 74 74 65 64  _ReadUncommitted
1940: 20 7d 2c 0a 20 20 20 20 7b 20 22 72 65 63 75 72   },.    { "recur
1950: 73 69 76 65 5f 74 72 69 67 67 65 72 73 22 2c 20  sive_triggers", 
1960: 20 20 20 20 20 20 53 51 4c 49 54 45 5f 52 65 63        SQLITE_Rec
1970: 54 72 69 67 67 65 72 73 20 7d 2c 0a 0a 20 20 20  Triggers },..   
1980: 20 2f 2a 20 54 68 69 73 20 66 6c 61 67 20 6d 61   /* This flag ma
1990: 79 20 6f 6e 6c 79 20 62 65 20 73 65 74 20 69 66  y only be set if
19a0: 20 62 6f 74 68 20 66 6f 72 65 69 67 6e 2d 6b 65   both foreign-ke
19b0: 79 20 61 6e 64 20 74 72 69 67 67 65 72 20 73 75  y and trigger su
19c0: 70 70 6f 72 74 0a 20 20 20 20 2a 2a 20 61 72 65  pport.    ** are
19d0: 20 70 72 65 73 65 6e 74 20 69 6e 20 74 68 65 20   present in the 
19e0: 62 75 69 6c 64 2e 20 20 2a 2f 0a 23 69 66 20 21  build.  */.#if !
19f0: 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f  defined(SQLITE_O
1a00: 4d 49 54 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 29  MIT_FOREIGN_KEY)
1a10: 20 26 26 20 21 64 65 66 69 6e 65 64 28 53 51 4c   && !defined(SQL
1a20: 49 54 45 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52  ITE_OMIT_TRIGGER
1a30: 29 0a 20 20 20 20 7b 20 22 66 6f 72 65 69 67 6e  ).    { "foreign
1a40: 5f 6b 65 79 73 22 2c 20 20 20 20 20 20 20 20 20  _keys",         
1a50: 20 20 20 20 53 51 4c 49 54 45 5f 46 6f 72 65 69      SQLITE_Forei
1a60: 67 6e 4b 65 79 73 20 7d 2c 0a 23 65 6e 64 69 66  gnKeys },.#endif
1a70: 0a 20 20 7d 3b 0a 20 20 69 6e 74 20 69 3b 0a 20  .  };.  int i;. 
1a80: 20 63 6f 6e 73 74 20 73 74 72 75 63 74 20 73 50   const struct sP
1a90: 72 61 67 6d 61 54 79 70 65 20 2a 70 3b 0a 20 20  ragmaType *p;.  
1aa0: 66 6f 72 28 69 3d 30 2c 20 70 3d 61 50 72 61 67  for(i=0, p=aPrag
1ab0: 6d 61 3b 20 69 3c 41 72 72 61 79 53 69 7a 65 28  ma; i<ArraySize(
1ac0: 61 50 72 61 67 6d 61 29 3b 20 69 2b 2b 2c 20 70  aPragma); i++, p
1ad0: 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 73 71 6c  ++){.    if( sql
1ae0: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
1af0: 74 2c 20 70 2d 3e 7a 4e 61 6d 65 29 3d 3d 30 20  t, p->zName)==0 
1b00: 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ){.      sqlite3
1b10: 20 2a 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64   *db = pParse->d
1b20: 62 3b 0a 20 20 20 20 20 20 56 64 62 65 20 2a 76  b;.      Vdbe *v
1b30: 3b 0a 20 20 20 20 20 20 76 20 3d 20 73 71 6c 69  ;.      v = sqli
1b40: 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72 73  te3GetVdbe(pPars
1b50: 65 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74  e);.      assert
1b60: 28 20 76 21 3d 30 20 29 3b 20 20 2f 2a 20 41 6c  ( v!=0 );  /* Al
1b70: 72 65 61 64 79 20 61 6c 6c 6f 63 61 74 65 64 20  ready allocated 
1b80: 62 79 20 73 71 6c 69 74 65 33 50 72 61 67 6d 61  by sqlite3Pragma
1b90: 28 29 20 2a 2f 0a 20 20 20 20 20 20 69 66 28 20  () */.      if( 
1ba0: 41 4c 57 41 59 53 28 76 29 20 29 7b 0a 20 20 20  ALWAYS(v) ){.   
1bb0: 20 20 20 20 20 69 66 28 20 7a 52 69 67 68 74 3d       if( zRight=
1bc0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
1bd0: 72 65 74 75 72 6e 53 69 6e 67 6c 65 49 6e 74 28  returnSingleInt(
1be0: 70 50 61 72 73 65 2c 20 70 2d 3e 7a 4e 61 6d 65  pParse, p->zName
1bf0: 2c 20 28 64 62 2d 3e 66 6c 61 67 73 20 26 20 70  , (db->flags & p
1c00: 2d 3e 6d 61 73 6b 29 21 3d 30 20 29 3b 0a 20 20  ->mask)!=0 );.  
1c10: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
1c20: 20 20 20 20 20 20 20 69 6e 74 20 6d 61 73 6b 20         int mask 
1c30: 3d 20 70 2d 3e 6d 61 73 6b 3b 20 20 20 20 20 20  = p->mask;      
1c40: 20 20 20 20 2f 2a 20 4d 61 73 6b 20 6f 66 20 62      /* Mask of b
1c50: 69 74 73 20 74 6f 20 73 65 74 20 6f 72 20 63 6c  its to set or cl
1c60: 65 61 72 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20  ear. */.        
1c70: 20 20 69 66 28 20 64 62 2d 3e 61 75 74 6f 43 6f    if( db->autoCo
1c80: 6d 6d 69 74 3d 3d 30 20 29 7b 0a 20 20 20 20 20  mmit==0 ){.     
1c90: 20 20 20 20 20 20 20 2f 2a 20 46 6f 72 65 69 67         /* Foreig
1ca0: 6e 20 6b 65 79 20 73 75 70 70 6f 72 74 20 6d 61  n key support ma
1cb0: 79 20 6e 6f 74 20 62 65 20 65 6e 61 62 6c 65 64  y not be enabled
1cc0: 20 6f 72 20 64 69 73 61 62 6c 65 64 20 77 68 69   or disabled whi
1cd0: 6c 65 20 6e 6f 74 0a 20 20 20 20 20 20 20 20 20  le not.         
1ce0: 20 20 20 2a 2a 20 69 6e 20 61 75 74 6f 2d 63 6f     ** in auto-co
1cf0: 6d 6d 69 74 20 6d 6f 64 65 2e 20 20 2a 2f 0a 20  mmit mode.  */. 
1d00: 20 20 20 20 20 20 20 20 20 20 20 6d 61 73 6b 20             mask 
1d10: 26 3d 20 7e 28 53 51 4c 49 54 45 5f 46 6f 72 65  &= ~(SQLITE_Fore
1d20: 69 67 6e 4b 65 79 73 29 3b 0a 20 20 20 20 20 20  ignKeys);.      
1d30: 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 20      }..         
1d40: 20 69 66 28 20 67 65 74 42 6f 6f 6c 65 61 6e 28   if( getBoolean(
1d50: 7a 52 69 67 68 74 29 20 29 7b 0a 20 20 20 20 20  zRight) ){.     
1d60: 20 20 20 20 20 20 20 64 62 2d 3e 66 6c 61 67 73         db->flags
1d70: 20 7c 3d 20 6d 61 73 6b 3b 0a 20 20 20 20 20 20   |= mask;.      
1d80: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
1d90: 20 20 20 20 20 20 20 64 62 2d 3e 66 6c 61 67 73         db->flags
1da0: 20 26 3d 20 7e 6d 61 73 6b 3b 0a 20 20 20 20 20   &= ~mask;.     
1db0: 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20       }..        
1dc0: 20 20 2f 2a 20 4d 61 6e 79 20 6f 66 20 74 68 65    /* Many of the
1dd0: 20 66 6c 61 67 2d 70 72 61 67 6d 61 73 20 6d 6f   flag-pragmas mo
1de0: 64 69 66 79 20 74 68 65 20 63 6f 64 65 20 67 65  dify the code ge
1df0: 6e 65 72 61 74 65 64 20 62 79 20 74 68 65 20 53  nerated by the S
1e00: 51 4c 20 0a 20 20 20 20 20 20 20 20 20 20 2a 2a  QL .          **
1e10: 20 63 6f 6d 70 69 6c 65 72 20 28 65 67 2e 20 63   compiler (eg. c
1e20: 6f 75 6e 74 5f 63 68 61 6e 67 65 73 29 2e 20 53  ount_changes). S
1e30: 6f 20 61 64 64 20 61 6e 20 6f 70 63 6f 64 65 20  o add an opcode 
1e40: 74 6f 20 65 78 70 69 72 65 20 61 6c 6c 0a 20 20  to expire all.  
1e50: 20 20 20 20 20 20 20 20 2a 2a 20 63 6f 6d 70 69          ** compi
1e60: 6c 65 64 20 53 51 4c 20 73 74 61 74 65 6d 65 6e  led SQL statemen
1e70: 74 73 20 61 66 74 65 72 20 6d 6f 64 69 66 79 69  ts after modifyi
1e80: 6e 67 20 61 20 70 72 61 67 6d 61 20 76 61 6c 75  ng a pragma valu
1e90: 65 2e 0a 20 20 20 20 20 20 20 20 20 20 2a 2f 0a  e..          */.
1ea0: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
1eb0: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
1ec0: 50 5f 45 78 70 69 72 65 2c 20 30 2c 20 30 29 3b  P_Expire, 0, 0);
1ed0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
1ee0: 20 7d 0a 0a 20 20 20 20 20 20 72 65 74 75 72 6e   }..      return
1ef0: 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20   1;.    }.  }.  
1f00: 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 23 65 6e 64  return 0;.}.#end
1f10: 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49  if /* SQLITE_OMI
1f20: 54 5f 46 4c 41 47 5f 50 52 41 47 4d 41 53 20 2a  T_FLAG_PRAGMAS *
1f30: 2f 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20  /../*.** Return 
1f40: 61 20 68 75 6d 61 6e 2d 72 65 61 64 61 62 6c 65  a human-readable
1f50: 20 6e 61 6d 65 20 66 6f 72 20 61 20 63 6f 6e 73   name for a cons
1f60: 74 72 61 69 6e 74 20 72 65 73 6f 6c 75 74 69 6f  traint resolutio
1f70: 6e 20 61 63 74 69 6f 6e 2e 0a 2a 2f 0a 23 69 66  n action..*/.#if
1f80: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  ndef SQLITE_OMIT
1f90: 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 0a 73 74 61  _FOREIGN_KEY.sta
1fa0: 74 69 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  tic const char *
1fb0: 61 63 74 69 6f 6e 4e 61 6d 65 28 75 38 20 61 63  actionName(u8 ac
1fc0: 74 69 6f 6e 29 7b 0a 20 20 63 6f 6e 73 74 20 63  tion){.  const c
1fd0: 68 61 72 20 2a 7a 4e 61 6d 65 3b 0a 20 20 73 77  har *zName;.  sw
1fe0: 69 74 63 68 28 20 61 63 74 69 6f 6e 20 29 7b 0a  itch( action ){.
1ff0: 20 20 20 20 63 61 73 65 20 4f 45 5f 53 65 74 4e      case OE_SetN
2000: 75 6c 6c 3a 20 20 7a 4e 61 6d 65 20 3d 20 22 53  ull:  zName = "S
2010: 45 54 20 4e 55 4c 4c 22 3b 20 20 20 20 20 20 20  ET NULL";       
2020: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
2030: 20 4f 45 5f 53 65 74 44 66 6c 74 3a 20 20 7a 4e   OE_SetDflt:  zN
2040: 61 6d 65 20 3d 20 22 53 45 54 20 44 45 46 41 55  ame = "SET DEFAU
2050: 4c 54 22 3b 20 20 20 20 20 62 72 65 61 6b 3b 0a  LT";     break;.
2060: 20 20 20 20 63 61 73 65 20 4f 45 5f 43 61 73 63      case OE_Casc
2070: 61 64 65 3a 20 20 7a 4e 61 6d 65 20 3d 20 22 43  ade:  zName = "C
2080: 41 53 43 41 44 45 22 3b 20 20 20 20 20 20 20 20  ASCADE";        
2090: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
20a0: 20 4f 45 5f 52 65 73 74 72 69 63 74 3a 20 7a 4e   OE_Restrict: zN
20b0: 61 6d 65 20 3d 20 22 52 45 53 54 52 49 43 54 22  ame = "RESTRICT"
20c0: 3b 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  ;        break;.
20d0: 20 20 20 20 64 65 66 61 75 6c 74 3a 20 20 20 20      default:    
20e0: 20 20 20 20 20 20 7a 4e 61 6d 65 20 3d 20 22 4e        zName = "N
20f0: 4f 20 41 43 54 49 4f 4e 22 3b 20 20 0a 20 20 20  O ACTION";  .   
2100: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2110: 20 20 20 61 73 73 65 72 74 28 20 61 63 74 69 6f     assert( actio
2120: 6e 3d 3d 4f 45 5f 4e 6f 6e 65 20 29 3b 20 62 72  n==OE_None ); br
2130: 65 61 6b 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  eak;.  }.  retur
2140: 6e 20 7a 4e 61 6d 65 3b 0a 7d 0a 23 65 6e 64 69  n zName;.}.#endi
2150: 66 0a 0a 0a 2f 2a 0a 2a 2a 20 50 61 72 61 6d 65  f.../*.** Parame
2160: 74 65 72 20 65 4d 6f 64 65 20 6d 75 73 74 20 62  ter eMode must b
2170: 65 20 6f 6e 65 20 6f 66 20 74 68 65 20 50 41 47  e one of the PAG
2180: 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 58  ER_JOURNALMODE_X
2190: 58 58 20 63 6f 6e 73 74 61 6e 74 73 0a 2a 2a 20  XX constants.** 
21a0: 64 65 66 69 6e 65 64 20 69 6e 20 70 61 67 65 72  defined in pager
21b0: 2e 68 2e 20 54 68 69 73 20 66 75 6e 63 74 69 6f  .h. This functio
21c0: 6e 20 72 65 74 75 72 6e 73 20 74 68 65 20 61 73  n returns the as
21d0: 73 6f 63 69 61 74 65 64 20 6c 6f 77 65 72 63 61  sociated lowerca
21e0: 73 65 0a 2a 2a 20 6a 6f 75 72 6e 61 6c 2d 6d 6f  se.** journal-mo
21f0: 64 65 20 6e 61 6d 65 2e 0a 2a 2f 0a 63 6f 6e 73  de name..*/.cons
2200: 74 20 63 68 61 72 20 2a 73 71 6c 69 74 65 33 4a  t char *sqlite3J
2210: 6f 75 72 6e 61 6c 4d 6f 64 65 6e 61 6d 65 28 69  ournalModename(i
2220: 6e 74 20 65 4d 6f 64 65 29 7b 0a 20 20 73 74 61  nt eMode){.  sta
2230: 74 69 63 20 63 68 61 72 20 2a 20 63 6f 6e 73 74  tic char * const
2240: 20 61 7a 4d 6f 64 65 4e 61 6d 65 5b 5d 20 3d 20   azModeName[] = 
2250: 7b 0a 20 20 20 20 22 64 65 6c 65 74 65 22 2c 20  {.    "delete", 
2260: 22 70 65 72 73 69 73 74 22 2c 20 22 6f 66 66 22  "persist", "off"
2270: 2c 20 22 74 72 75 6e 63 61 74 65 22 2c 20 22 6d  , "truncate", "m
2280: 65 6d 6f 72 79 22 2c 20 22 77 61 6c 22 0a 20 20  emory", "wal".  
2290: 7d 3b 0a 20 20 61 73 73 65 72 74 28 20 50 41 47  };.  assert( PAG
22a0: 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 44  ER_JOURNALMODE_D
22b0: 45 4c 45 54 45 3d 3d 30 20 29 3b 0a 20 20 61 73  ELETE==0 );.  as
22c0: 73 65 72 74 28 20 50 41 47 45 52 5f 4a 4f 55 52  sert( PAGER_JOUR
22d0: 4e 41 4c 4d 4f 44 45 5f 50 45 52 53 49 53 54 3d  NALMODE_PERSIST=
22e0: 3d 31 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20  =1 );.  assert( 
22f0: 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44  PAGER_JOURNALMOD
2300: 45 5f 4f 46 46 3d 3d 32 20 29 3b 0a 20 20 61 73  E_OFF==2 );.  as
2310: 73 65 72 74 28 20 50 41 47 45 52 5f 4a 4f 55 52  sert( PAGER_JOUR
2320: 4e 41 4c 4d 4f 44 45 5f 54 52 55 4e 43 41 54 45  NALMODE_TRUNCATE
2330: 3d 3d 33 20 29 3b 0a 20 20 61 73 73 65 72 74 28  ==3 );.  assert(
2340: 20 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f   PAGER_JOURNALMO
2350: 44 45 5f 4d 45 4d 4f 52 59 3d 3d 34 20 29 3b 0a  DE_MEMORY==4 );.
2360: 20 20 61 73 73 65 72 74 28 20 50 41 47 45 52 5f    assert( PAGER_
2370: 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 57 41 4c 3d  JOURNALMODE_WAL=
2380: 3d 35 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20  =5 );.  assert( 
2390: 65 4d 6f 64 65 3e 3d 30 20 26 26 20 65 4d 6f 64  eMode>=0 && eMod
23a0: 65 3c 3d 41 72 72 61 79 53 69 7a 65 28 61 7a 4d  e<=ArraySize(azM
23b0: 6f 64 65 4e 61 6d 65 29 20 29 3b 0a 0a 20 20 69  odeName) );..  i
23c0: 66 28 20 65 4d 6f 64 65 3d 3d 41 72 72 61 79 53  f( eMode==ArrayS
23d0: 69 7a 65 28 61 7a 4d 6f 64 65 4e 61 6d 65 29 20  ize(azModeName) 
23e0: 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 72 65  ) return 0;.  re
23f0: 74 75 72 6e 20 61 7a 4d 6f 64 65 4e 61 6d 65 5b  turn azModeName[
2400: 65 4d 6f 64 65 5d 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  eMode];.}../*.**
2410: 20 50 72 6f 63 65 73 73 20 61 20 70 72 61 67 6d   Process a pragm
2420: 61 20 73 74 61 74 65 6d 65 6e 74 2e 20 20 0a 2a  a statement.  .*
2430: 2a 0a 2a 2a 20 50 72 61 67 6d 61 73 20 61 72 65  *.** Pragmas are
2440: 20 6f 66 20 74 68 69 73 20 66 6f 72 6d 3a 0a 2a   of this form:.*
2450: 2a 0a 2a 2a 20 20 20 20 20 20 50 52 41 47 4d 41  *.**      PRAGMA
2460: 20 5b 64 61 74 61 62 61 73 65 2e 5d 69 64 20 5b   [database.]id [
2470: 3d 20 76 61 6c 75 65 5d 0a 2a 2a 0a 2a 2a 20 54  = value].**.** T
2480: 68 65 20 69 64 65 6e 74 69 66 69 65 72 20 6d 69  he identifier mi
2490: 67 68 74 20 61 6c 73 6f 20 62 65 20 61 20 73 74  ght also be a st
24a0: 72 69 6e 67 2e 20 20 54 68 65 20 76 61 6c 75 65  ring.  The value
24b0: 20 69 73 20 61 20 73 74 72 69 6e 67 2c 20 61 6e   is a string, an
24c0: 64 0a 2a 2a 20 69 64 65 6e 74 69 66 69 65 72 2c  d.** identifier,
24d0: 20 6f 72 20 61 20 6e 75 6d 62 65 72 2e 20 20 49   or a number.  I
24e0: 66 20 6d 69 6e 75 73 46 6c 61 67 20 69 73 20 74  f minusFlag is t
24f0: 72 75 65 2c 20 74 68 65 6e 20 74 68 65 20 76 61  rue, then the va
2500: 6c 75 65 20 69 73 0a 2a 2a 20 61 20 6e 75 6d 62  lue is.** a numb
2510: 65 72 20 74 68 61 74 20 77 61 73 20 70 72 65 63  er that was prec
2520: 65 64 65 64 20 62 79 20 61 20 6d 69 6e 75 73 20  eded by a minus 
2530: 73 69 67 6e 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74  sign..**.** If t
2540: 68 65 20 6c 65 66 74 20 73 69 64 65 20 69 73 20  he left side is 
2550: 22 64 61 74 61 62 61 73 65 2e 69 64 22 20 74 68  "database.id" th
2560: 65 6e 20 70 49 64 31 20 69 73 20 74 68 65 20 64  en pId1 is the d
2570: 61 74 61 62 61 73 65 20 6e 61 6d 65 0a 2a 2a 20  atabase name.** 
2580: 61 6e 64 20 70 49 64 32 20 69 73 20 74 68 65 20  and pId2 is the 
2590: 69 64 2e 20 20 49 66 20 74 68 65 20 6c 65 66 74  id.  If the left
25a0: 20 73 69 64 65 20 69 73 20 6a 75 73 74 20 22 69   side is just "i
25b0: 64 22 20 74 68 65 6e 20 70 49 64 31 20 69 73 20  d" then pId1 is 
25c0: 74 68 65 0a 2a 2a 20 69 64 20 61 6e 64 20 70 49  the.** id and pI
25d0: 64 32 20 69 73 20 61 6e 79 20 65 6d 70 74 79 20  d2 is any empty 
25e0: 73 74 72 69 6e 67 2e 0a 2a 2f 0a 76 6f 69 64 20  string..*/.void 
25f0: 73 71 6c 69 74 65 33 50 72 61 67 6d 61 28 0a 20  sqlite3Pragma(. 
2600: 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20   Parse *pParse, 
2610: 0a 20 20 54 6f 6b 65 6e 20 2a 70 49 64 31 2c 20  .  Token *pId1, 
2620: 20 20 20 20 20 20 20 2f 2a 20 46 69 72 73 74 20         /* First 
2630: 70 61 72 74 20 6f 66 20 5b 64 61 74 61 62 61 73  part of [databas
2640: 65 2e 5d 69 64 20 66 69 65 6c 64 20 2a 2f 0a 20  e.]id field */. 
2650: 20 54 6f 6b 65 6e 20 2a 70 49 64 32 2c 20 20 20   Token *pId2,   
2660: 20 20 20 20 20 2f 2a 20 53 65 63 6f 6e 64 20 70       /* Second p
2670: 61 72 74 20 6f 66 20 5b 64 61 74 61 62 61 73 65  art of [database
2680: 2e 5d 69 64 20 66 69 65 6c 64 2c 20 6f 72 20 4e  .]id field, or N
2690: 55 4c 4c 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a  ULL */.  Token *
26a0: 70 56 61 6c 75 65 2c 20 20 20 20 20 20 2f 2a 20  pValue,      /* 
26b0: 54 6f 6b 65 6e 20 66 6f 72 20 3c 76 61 6c 75 65  Token for <value
26c0: 3e 2c 20 6f 72 20 4e 55 4c 4c 20 2a 2f 0a 20 20  >, or NULL */.  
26d0: 69 6e 74 20 6d 69 6e 75 73 46 6c 61 67 20 20 20  int minusFlag   
26e0: 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20 61      /* True if a
26f0: 20 27 2d 27 20 73 69 67 6e 20 70 72 65 63 65 64   '-' sign preced
2700: 65 64 20 3c 76 61 6c 75 65 3e 20 2a 2f 0a 29 7b  ed <value> */.){
2710: 0a 20 20 63 68 61 72 20 2a 7a 4c 65 66 74 20 3d  .  char *zLeft =
2720: 20 30 3b 20 20 20 20 20 20 20 2f 2a 20 4e 75 6c   0;       /* Nul
2730: 2d 74 65 72 6d 69 6e 61 74 65 64 20 55 54 46 2d  -terminated UTF-
2740: 38 20 73 74 72 69 6e 67 20 3c 69 64 3e 20 2a 2f  8 string <id> */
2750: 0a 20 20 63 68 61 72 20 2a 7a 52 69 67 68 74 20  .  char *zRight 
2760: 3d 20 30 3b 20 20 20 20 20 20 2f 2a 20 4e 75 6c  = 0;      /* Nul
2770: 2d 74 65 72 6d 69 6e 61 74 65 64 20 55 54 46 2d  -terminated UTF-
2780: 38 20 73 74 72 69 6e 67 20 3c 76 61 6c 75 65 3e  8 string <value>
2790: 2c 20 6f 72 20 4e 55 4c 4c 20 2a 2f 0a 20 20 63  , or NULL */.  c
27a0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 20 3d  onst char *zDb =
27b0: 20 30 3b 20 20 20 2f 2a 20 54 68 65 20 64 61 74   0;   /* The dat
27c0: 61 62 61 73 65 20 6e 61 6d 65 20 2a 2f 0a 20 20  abase name */.  
27d0: 54 6f 6b 65 6e 20 2a 70 49 64 3b 20 20 20 20 20  Token *pId;     
27e0: 20 20 20 20 20 20 20 2f 2a 20 50 6f 69 6e 74 65         /* Pointe
27f0: 72 20 74 6f 20 3c 69 64 3e 20 74 6f 6b 65 6e 20  r to <id> token 
2800: 2a 2f 0a 20 20 69 6e 74 20 69 44 62 3b 20 20 20  */.  int iDb;   
2810: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44              /* D
2820: 61 74 61 62 61 73 65 20 69 6e 64 65 78 20 66 6f  atabase index fo
2830: 72 20 3c 64 61 74 61 62 61 73 65 3e 20 2a 2f 0a  r <database> */.
2840: 20 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20    sqlite3 *db = 
2850: 70 50 61 72 73 65 2d 3e 64 62 3b 0a 20 20 44 62  pParse->db;.  Db
2860: 20 2a 70 44 62 3b 0a 20 20 56 64 62 65 20 2a 76   *pDb;.  Vdbe *v
2870: 20 3d 20 70 50 61 72 73 65 2d 3e 70 56 64 62 65   = pParse->pVdbe
2880: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 43 72   = sqlite3VdbeCr
2890: 65 61 74 65 28 64 62 29 3b 0a 20 20 69 66 28 20  eate(db);.  if( 
28a0: 76 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 20  v==0 ) return;. 
28b0: 20 73 71 6c 69 74 65 33 56 64 62 65 52 75 6e 4f   sqlite3VdbeRunO
28c0: 6e 6c 79 4f 6e 63 65 28 76 29 3b 0a 20 20 70 50  nlyOnce(v);.  pP
28d0: 61 72 73 65 2d 3e 6e 4d 65 6d 20 3d 20 32 3b 0a  arse->nMem = 2;.
28e0: 0a 20 20 2f 2a 20 49 6e 74 65 72 70 72 65 74 20  .  /* Interpret 
28f0: 74 68 65 20 5b 64 61 74 61 62 61 73 65 2e 5d 20  the [database.] 
2900: 70 61 72 74 20 6f 66 20 74 68 65 20 70 72 61 67  part of the prag
2910: 6d 61 20 73 74 61 74 65 6d 65 6e 74 2e 20 69 44  ma statement. iD
2920: 62 20 69 73 20 74 68 65 0a 20 20 2a 2a 20 69 6e  b is the.  ** in
2930: 64 65 78 20 6f 66 20 74 68 65 20 64 61 74 61 62  dex of the datab
2940: 61 73 65 20 74 68 69 73 20 70 72 61 67 6d 61 20  ase this pragma 
2950: 69 73 20 62 65 69 6e 67 20 61 70 70 6c 69 65 64  is being applied
2960: 20 74 6f 20 69 6e 20 64 62 2e 61 44 62 5b 5d 2e   to in db.aDb[].
2970: 20 2a 2f 0a 20 20 69 44 62 20 3d 20 73 71 6c 69   */.  iDb = sqli
2980: 74 65 33 54 77 6f 50 61 72 74 4e 61 6d 65 28 70  te3TwoPartName(p
2990: 50 61 72 73 65 2c 20 70 49 64 31 2c 20 70 49 64  Parse, pId1, pId
29a0: 32 2c 20 26 70 49 64 29 3b 0a 20 20 69 66 28 20  2, &pId);.  if( 
29b0: 69 44 62 3c 30 20 29 20 72 65 74 75 72 6e 3b 0a  iDb<0 ) return;.
29c0: 20 20 70 44 62 20 3d 20 26 64 62 2d 3e 61 44 62    pDb = &db->aDb
29d0: 5b 69 44 62 5d 3b 0a 0a 20 20 2f 2a 20 49 66 20  [iDb];..  /* If 
29e0: 74 68 65 20 74 65 6d 70 20 64 61 74 61 62 61 73  the temp databas
29f0: 65 20 68 61 73 20 62 65 65 6e 20 65 78 70 6c 69  e has been expli
2a00: 63 69 74 6c 79 20 6e 61 6d 65 64 20 61 73 20 70  citly named as p
2a10: 61 72 74 20 6f 66 20 74 68 65 20 0a 20 20 2a 2a  art of the .  **
2a20: 20 70 72 61 67 6d 61 2c 20 6d 61 6b 65 20 73 75   pragma, make su
2a30: 72 65 20 69 74 20 69 73 20 6f 70 65 6e 2e 20 0a  re it is open. .
2a40: 20 20 2a 2f 0a 20 20 69 66 28 20 69 44 62 3d 3d    */.  if( iDb==
2a50: 31 20 26 26 20 73 71 6c 69 74 65 33 4f 70 65 6e  1 && sqlite3Open
2a60: 54 65 6d 70 44 61 74 61 62 61 73 65 28 70 50 61  TempDatabase(pPa
2a70: 72 73 65 29 20 29 7b 0a 20 20 20 20 72 65 74 75  rse) ){.    retu
2a80: 72 6e 3b 0a 20 20 7d 0a 0a 20 20 7a 4c 65 66 74  rn;.  }..  zLeft
2a90: 20 3d 20 73 71 6c 69 74 65 33 4e 61 6d 65 46 72   = sqlite3NameFr
2aa0: 6f 6d 54 6f 6b 65 6e 28 64 62 2c 20 70 49 64 29  omToken(db, pId)
2ab0: 3b 0a 20 20 69 66 28 20 21 7a 4c 65 66 74 20 29  ;.  if( !zLeft )
2ac0: 20 72 65 74 75 72 6e 3b 0a 20 20 69 66 28 20 6d   return;.  if( m
2ad0: 69 6e 75 73 46 6c 61 67 20 29 7b 0a 20 20 20 20  inusFlag ){.    
2ae0: 7a 52 69 67 68 74 20 3d 20 73 71 6c 69 74 65 33  zRight = sqlite3
2af0: 4d 50 72 69 6e 74 66 28 64 62 2c 20 22 2d 25 54  MPrintf(db, "-%T
2b00: 22 2c 20 70 56 61 6c 75 65 29 3b 0a 20 20 7d 65  ", pValue);.  }e
2b10: 6c 73 65 7b 0a 20 20 20 20 7a 52 69 67 68 74 20  lse{.    zRight 
2b20: 3d 20 73 71 6c 69 74 65 33 4e 61 6d 65 46 72 6f  = sqlite3NameFro
2b30: 6d 54 6f 6b 65 6e 28 64 62 2c 20 70 56 61 6c 75  mToken(db, pValu
2b40: 65 29 3b 0a 20 20 7d 0a 0a 20 20 61 73 73 65 72  e);.  }..  asser
2b50: 74 28 20 70 49 64 32 20 29 3b 0a 20 20 7a 44 62  t( pId2 );.  zDb
2b60: 20 3d 20 70 49 64 32 2d 3e 6e 3e 30 20 3f 20 70   = pId2->n>0 ? p
2b70: 44 62 2d 3e 7a 4e 61 6d 65 20 3a 20 30 3b 0a 20  Db->zName : 0;. 
2b80: 20 69 66 28 20 73 71 6c 69 74 65 33 41 75 74 68   if( sqlite3Auth
2b90: 43 68 65 63 6b 28 70 50 61 72 73 65 2c 20 53 51  Check(pParse, SQ
2ba0: 4c 49 54 45 5f 50 52 41 47 4d 41 2c 20 7a 4c 65  LITE_PRAGMA, zLe
2bb0: 66 74 2c 20 7a 52 69 67 68 74 2c 20 7a 44 62 29  ft, zRight, zDb)
2bc0: 20 29 7b 0a 20 20 20 20 67 6f 74 6f 20 70 72 61   ){.    goto pra
2bd0: 67 6d 61 5f 6f 75 74 3b 0a 20 20 7d 0a 20 0a 23  gma_out;.  }. .#
2be0: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
2bf0: 49 54 5f 50 41 47 45 52 5f 50 52 41 47 4d 41 53  IT_PAGER_PRAGMAS
2c00: 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 50 52 41 47  .  /*.  **  PRAG
2c10: 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 64 65  MA [database.]de
2c20: 66 61 75 6c 74 5f 63 61 63 68 65 5f 73 69 7a 65  fault_cache_size
2c30: 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64  .  **  PRAGMA [d
2c40: 61 74 61 62 61 73 65 2e 5d 64 65 66 61 75 6c 74  atabase.]default
2c50: 5f 63 61 63 68 65 5f 73 69 7a 65 3d 4e 0a 20 20  _cache_size=N.  
2c60: 2a 2a 0a 20 20 2a 2a 20 54 68 65 20 66 69 72 73  **.  ** The firs
2c70: 74 20 66 6f 72 6d 20 72 65 70 6f 72 74 73 20 74  t form reports t
2c80: 68 65 20 63 75 72 72 65 6e 74 20 70 65 72 73 69  he current persi
2c90: 73 74 65 6e 74 20 73 65 74 74 69 6e 67 20 66 6f  stent setting fo
2ca0: 72 20 74 68 65 0a 20 20 2a 2a 20 70 61 67 65 20  r the.  ** page 
2cb0: 63 61 63 68 65 20 73 69 7a 65 2e 20 20 54 68 65  cache size.  The
2cc0: 20 76 61 6c 75 65 20 72 65 74 75 72 6e 65 64 20   value returned 
2cd0: 69 73 20 74 68 65 20 6d 61 78 69 6d 75 6d 20 6e  is the maximum n
2ce0: 75 6d 62 65 72 20 6f 66 0a 20 20 2a 2a 20 70 61  umber of.  ** pa
2cf0: 67 65 73 20 69 6e 20 74 68 65 20 70 61 67 65 20  ges in the page 
2d00: 63 61 63 68 65 2e 20 20 54 68 65 20 73 65 63 6f  cache.  The seco
2d10: 6e 64 20 66 6f 72 6d 20 73 65 74 73 20 62 6f 74  nd form sets bot
2d20: 68 20 74 68 65 20 63 75 72 72 65 6e 74 0a 20 20  h the current.  
2d30: 2a 2a 20 70 61 67 65 20 63 61 63 68 65 20 73 69  ** page cache si
2d40: 7a 65 20 76 61 6c 75 65 20 61 6e 64 20 74 68 65  ze value and the
2d50: 20 70 65 72 73 69 73 74 65 6e 74 20 70 61 67 65   persistent page
2d60: 20 63 61 63 68 65 20 73 69 7a 65 20 76 61 6c 75   cache size valu
2d70: 65 0a 20 20 2a 2a 20 73 74 6f 72 65 64 20 69 6e  e.  ** stored in
2d80: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 66 69   the database fi
2d90: 6c 65 2e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 68  le..  **.  ** Th
2da0: 65 20 64 65 66 61 75 6c 74 20 63 61 63 68 65 20  e default cache 
2db0: 73 69 7a 65 20 69 73 20 73 74 6f 72 65 64 20 69  size is stored i
2dc0: 6e 20 6d 65 74 61 2d 76 61 6c 75 65 20 32 20 6f  n meta-value 2 o
2dd0: 66 20 70 61 67 65 20 31 20 6f 66 20 74 68 65 0a  f page 1 of the.
2de0: 20 20 2a 2a 20 64 61 74 61 62 61 73 65 20 66 69    ** database fi
2df0: 6c 65 2e 20 20 54 68 65 20 63 61 63 68 65 20 73  le.  The cache s
2e00: 69 7a 65 20 69 73 20 61 63 74 75 61 6c 6c 79 20  ize is actually 
2e10: 74 68 65 20 61 62 73 6f 6c 75 74 65 20 76 61 6c  the absolute val
2e20: 75 65 20 6f 66 0a 20 20 2a 2a 20 74 68 69 73 20  ue of.  ** this 
2e30: 6d 65 6d 6f 72 79 20 6c 6f 63 61 74 69 6f 6e 2e  memory location.
2e40: 20 20 54 68 65 20 73 69 67 6e 20 6f 66 20 6d 65    The sign of me
2e50: 74 61 2d 76 61 6c 75 65 20 32 20 64 65 74 65 72  ta-value 2 deter
2e60: 6d 69 6e 65 73 20 74 68 65 0a 20 20 2a 2a 20 73  mines the.  ** s
2e70: 79 6e 63 68 72 6f 6e 6f 75 73 20 73 65 74 74 69  ynchronous setti
2e80: 6e 67 2e 20 20 41 20 6e 65 67 61 74 69 76 65 20  ng.  A negative 
2e90: 76 61 6c 75 65 20 6d 65 61 6e 73 20 73 79 6e 63  value means sync
2ea0: 68 72 6f 6e 6f 75 73 20 69 73 20 6f 66 66 0a 20  hronous is off. 
2eb0: 20 2a 2a 20 61 6e 64 20 61 20 70 6f 73 69 74 69   ** and a positi
2ec0: 76 65 20 76 61 6c 75 65 20 6d 65 61 6e 73 20 73  ve value means s
2ed0: 79 6e 63 68 72 6f 6e 6f 75 73 20 69 73 20 6f 6e  ynchronous is on
2ee0: 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c  ..  */.  if( sql
2ef0: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
2f00: 74 2c 22 64 65 66 61 75 6c 74 5f 63 61 63 68 65  t,"default_cache
2f10: 5f 73 69 7a 65 22 29 3d 3d 30 20 29 7b 0a 20 20  _size")==0 ){.  
2f20: 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20 56    static const V
2f30: 64 62 65 4f 70 4c 69 73 74 20 67 65 74 43 61 63  dbeOpList getCac
2f40: 68 65 53 69 7a 65 5b 5d 20 3d 20 7b 0a 20 20 20  heSize[] = {.   
2f50: 20 20 20 7b 20 4f 50 5f 54 72 61 6e 73 61 63 74     { OP_Transact
2f60: 69 6f 6e 2c 20 30 2c 20 30 2c 20 20 20 20 20 20  ion, 0, 0,      
2f70: 20 20 30 7d 2c 20 20 20 20 20 20 20 20 20 20 20    0},           
2f80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
2f90: 20 30 20 2a 2f 0a 20 20 20 20 20 20 7b 20 4f 50   0 */.      { OP
2fa0: 5f 52 65 61 64 43 6f 6f 6b 69 65 2c 20 20 30 2c  _ReadCookie,  0,
2fb0: 20 31 2c 20 20 20 20 20 20 20 20 42 54 52 45 45   1,        BTREE
2fc0: 5f 44 45 46 41 55 4c 54 5f 43 41 43 48 45 5f 53  _DEFAULT_CACHE_S
2fd0: 49 5a 45 7d 2c 20 20 2f 2a 20 31 20 2a 2f 0a 20  IZE},  /* 1 */. 
2fe0: 20 20 20 20 20 7b 20 4f 50 5f 49 66 50 6f 73 2c       { OP_IfPos,
2ff0: 20 20 20 20 20 20 20 31 2c 20 37 2c 20 20 20 20         1, 7,    
3000: 20 20 20 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20      0},.      { 
3010: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20 20  OP_Integer,     
3020: 30 2c 20 32 2c 20 20 20 20 20 20 20 20 30 7d 2c  0, 2,        0},
3030: 0a 20 20 20 20 20 20 7b 20 4f 50 5f 53 75 62 74  .      { OP_Subt
3040: 72 61 63 74 2c 20 20 20 20 31 2c 20 32 2c 20 20  ract,    1, 2,  
3050: 20 20 20 20 20 20 31 7d 2c 0a 20 20 20 20 20 20        1},.      
3060: 7b 20 4f 50 5f 49 66 50 6f 73 2c 20 20 20 20 20  { OP_IfPos,     
3070: 20 20 31 2c 20 37 2c 20 20 20 20 20 20 20 20 30    1, 7,        0
3080: 7d 2c 0a 20 20 20 20 20 20 7b 20 4f 50 5f 49 6e  },.      { OP_In
3090: 74 65 67 65 72 2c 20 20 20 20 20 30 2c 20 31 2c  teger,     0, 1,
30a0: 20 20 20 20 20 20 20 20 30 7d 2c 20 20 20 20 20          0},     
30b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30c0: 20 20 20 20 2f 2a 20 36 20 2a 2f 0a 20 20 20 20      /* 6 */.    
30d0: 20 20 7b 20 4f 50 5f 52 65 73 75 6c 74 52 6f 77    { OP_ResultRow
30e0: 2c 20 20 20 31 2c 20 31 2c 20 20 20 20 20 20 20  ,   1, 1,       
30f0: 20 30 7d 2c 0a 20 20 20 20 7d 3b 0a 20 20 20 20   0},.    };.    
3100: 69 6e 74 20 61 64 64 72 3b 0a 20 20 20 20 69 66  int addr;.    if
3110: 28 20 73 71 6c 69 74 65 33 52 65 61 64 53 63 68  ( sqlite3ReadSch
3120: 65 6d 61 28 70 50 61 72 73 65 29 20 29 20 67 6f  ema(pParse) ) go
3130: 74 6f 20 70 72 61 67 6d 61 5f 6f 75 74 3b 0a 20  to pragma_out;. 
3140: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 55 73     sqlite3VdbeUs
3150: 65 73 42 74 72 65 65 28 76 2c 20 69 44 62 29 3b  esBtree(v, iDb);
3160: 0a 20 20 20 20 69 66 28 20 21 7a 52 69 67 68 74  .    if( !zRight
3170: 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   ){.      sqlite
3180: 33 56 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28  3VdbeSetNumCols(
3190: 76 2c 20 31 29 3b 0a 20 20 20 20 20 20 73 71 6c  v, 1);.      sql
31a0: 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61  ite3VdbeSetColNa
31b0: 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45  me(v, 0, COLNAME
31c0: 5f 4e 41 4d 45 2c 20 22 63 61 63 68 65 5f 73 69  _NAME, "cache_si
31d0: 7a 65 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54  ze", SQLITE_STAT
31e0: 49 43 29 3b 0a 20 20 20 20 20 20 70 50 61 72 73  IC);.      pPars
31f0: 65 2d 3e 6e 4d 65 6d 20 2b 3d 20 32 3b 0a 20 20  e->nMem += 2;.  
3200: 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74      addr = sqlit
3210: 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28  e3VdbeAddOpList(
3220: 76 2c 20 41 72 72 61 79 53 69 7a 65 28 67 65 74  v, ArraySize(get
3230: 43 61 63 68 65 53 69 7a 65 29 2c 20 67 65 74 43  CacheSize), getC
3240: 61 63 68 65 53 69 7a 65 29 3b 0a 20 20 20 20 20  acheSize);.     
3250: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
3260: 67 65 50 31 28 76 2c 20 61 64 64 72 2c 20 69 44  geP1(v, addr, iD
3270: 62 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  b);.      sqlite
3280: 33 56 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c  3VdbeChangeP1(v,
3290: 20 61 64 64 72 2b 31 2c 20 69 44 62 29 3b 0a 20   addr+1, iDb);. 
32a0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
32b0: 43 68 61 6e 67 65 50 31 28 76 2c 20 61 64 64 72  ChangeP1(v, addr
32c0: 2b 36 2c 20 53 51 4c 49 54 45 5f 44 45 46 41 55  +6, SQLITE_DEFAU
32d0: 4c 54 5f 43 41 43 48 45 5f 53 49 5a 45 29 3b 0a  LT_CACHE_SIZE);.
32e0: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
32f0: 20 69 6e 74 20 73 69 7a 65 20 3d 20 61 74 6f 69   int size = atoi
3300: 28 7a 52 69 67 68 74 29 3b 0a 20 20 20 20 20 20  (zRight);.      
3310: 69 66 28 20 73 69 7a 65 3c 30 20 29 20 73 69 7a  if( size<0 ) siz
3320: 65 20 3d 20 2d 73 69 7a 65 3b 0a 20 20 20 20 20  e = -size;.     
3330: 20 73 71 6c 69 74 65 33 42 65 67 69 6e 57 72 69   sqlite3BeginWri
3340: 74 65 4f 70 65 72 61 74 69 6f 6e 28 70 50 61 72  teOperation(pPar
3350: 73 65 2c 20 30 2c 20 69 44 62 29 3b 0a 20 20 20  se, 0, iDb);.   
3360: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
3370: 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67  dOp2(v, OP_Integ
3380: 65 72 2c 20 73 69 7a 65 2c 20 31 29 3b 0a 20 20  er, size, 1);.  
3390: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
33a0: 64 64 4f 70 33 28 76 2c 20 4f 50 5f 52 65 61 64  ddOp3(v, OP_Read
33b0: 43 6f 6f 6b 69 65 2c 20 69 44 62 2c 20 32 2c 20  Cookie, iDb, 2, 
33c0: 42 54 52 45 45 5f 44 45 46 41 55 4c 54 5f 43 41  BTREE_DEFAULT_CA
33d0: 43 48 45 5f 53 49 5a 45 29 3b 0a 20 20 20 20 20  CHE_SIZE);.     
33e0: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56   addr = sqlite3V
33f0: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
3400: 49 66 50 6f 73 2c 20 32 2c 20 30 29 3b 0a 20 20  IfPos, 2, 0);.  
3410: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
3420: 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65  ddOp2(v, OP_Inte
3430: 67 65 72 2c 20 2d 73 69 7a 65 2c 20 31 29 3b 0a  ger, -size, 1);.
3440: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
3450: 65 4a 75 6d 70 48 65 72 65 28 76 2c 20 61 64 64  eJumpHere(v, add
3460: 72 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  r);.      sqlite
3470: 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f  3VdbeAddOp3(v, O
3480: 50 5f 53 65 74 43 6f 6f 6b 69 65 2c 20 69 44 62  P_SetCookie, iDb
3490: 2c 20 42 54 52 45 45 5f 44 45 46 41 55 4c 54 5f  , BTREE_DEFAULT_
34a0: 43 41 43 48 45 5f 53 49 5a 45 2c 20 31 29 3b 0a  CACHE_SIZE, 1);.
34b0: 20 20 20 20 20 20 70 44 62 2d 3e 70 53 63 68 65        pDb->pSche
34c0: 6d 61 2d 3e 63 61 63 68 65 5f 73 69 7a 65 20 3d  ma->cache_size =
34d0: 20 73 69 7a 65 3b 0a 20 20 20 20 20 20 73 71 6c   size;.      sql
34e0: 69 74 65 33 42 74 72 65 65 53 65 74 43 61 63 68  ite3BtreeSetCach
34f0: 65 53 69 7a 65 28 70 44 62 2d 3e 70 42 74 2c 20  eSize(pDb->pBt, 
3500: 70 44 62 2d 3e 70 53 63 68 65 6d 61 2d 3e 63 61  pDb->pSchema->ca
3510: 63 68 65 5f 73 69 7a 65 29 3b 0a 20 20 20 20 7d  che_size);.    }
3520: 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20  .  }else..  /*. 
3530: 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64 61 74   **  PRAGMA [dat
3540: 61 62 61 73 65 2e 5d 70 61 67 65 5f 73 69 7a 65  abase.]page_size
3550: 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64  .  **  PRAGMA [d
3560: 61 74 61 62 61 73 65 2e 5d 70 61 67 65 5f 73 69  atabase.]page_si
3570: 7a 65 3d 4e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54  ze=N.  **.  ** T
3580: 68 65 20 66 69 72 73 74 20 66 6f 72 6d 20 72 65  he first form re
3590: 70 6f 72 74 73 20 74 68 65 20 63 75 72 72 65 6e  ports the curren
35a0: 74 20 73 65 74 74 69 6e 67 20 66 6f 72 20 74 68  t setting for th
35b0: 65 0a 20 20 2a 2a 20 64 61 74 61 62 61 73 65 20  e.  ** database 
35c0: 70 61 67 65 20 73 69 7a 65 20 69 6e 20 62 79 74  page size in byt
35d0: 65 73 2e 20 20 54 68 65 20 73 65 63 6f 6e 64 20  es.  The second 
35e0: 66 6f 72 6d 20 73 65 74 73 20 74 68 65 0a 20 20  form sets the.  
35f0: 2a 2a 20 64 61 74 61 62 61 73 65 20 70 61 67 65  ** database page
3600: 20 73 69 7a 65 20 76 61 6c 75 65 2e 20 20 54 68   size value.  Th
3610: 65 20 76 61 6c 75 65 20 63 61 6e 20 6f 6e 6c 79  e value can only
3620: 20 62 65 20 73 65 74 20 69 66 0a 20 20 2a 2a 20   be set if.  ** 
3630: 74 68 65 20 64 61 74 61 62 61 73 65 20 68 61 73  the database has
3640: 20 6e 6f 74 20 79 65 74 20 62 65 65 6e 20 63 72   not yet been cr
3650: 65 61 74 65 64 2e 0a 20 20 2a 2f 0a 20 20 69 66  eated..  */.  if
3660: 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70  ( sqlite3StrICmp
3670: 28 7a 4c 65 66 74 2c 22 70 61 67 65 5f 73 69 7a  (zLeft,"page_siz
3680: 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 42 74  e")==0 ){.    Bt
3690: 72 65 65 20 2a 70 42 74 20 3d 20 70 44 62 2d 3e  ree *pBt = pDb->
36a0: 70 42 74 3b 0a 20 20 20 20 61 73 73 65 72 74 28  pBt;.    assert(
36b0: 20 70 42 74 21 3d 30 20 29 3b 0a 20 20 20 20 69   pBt!=0 );.    i
36c0: 66 28 20 21 7a 52 69 67 68 74 20 29 7b 0a 20 20  f( !zRight ){.  
36d0: 20 20 20 20 69 6e 74 20 73 69 7a 65 20 3d 20 41      int size = A
36e0: 4c 57 41 59 53 28 70 42 74 29 20 3f 20 73 71 6c  LWAYS(pBt) ? sql
36f0: 69 74 65 33 42 74 72 65 65 47 65 74 50 61 67 65  ite3BtreeGetPage
3700: 53 69 7a 65 28 70 42 74 29 20 3a 20 30 3b 0a 20  Size(pBt) : 0;. 
3710: 20 20 20 20 20 72 65 74 75 72 6e 53 69 6e 67 6c       returnSingl
3720: 65 49 6e 74 28 70 50 61 72 73 65 2c 20 22 70 61  eInt(pParse, "pa
3730: 67 65 5f 73 69 7a 65 22 2c 20 73 69 7a 65 29 3b  ge_size", size);
3740: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
3750: 20 20 2f 2a 20 4d 61 6c 6c 6f 63 20 6d 61 79 20    /* Malloc may 
3760: 66 61 69 6c 20 77 68 65 6e 20 73 65 74 74 69 6e  fail when settin
3770: 67 20 74 68 65 20 70 61 67 65 2d 73 69 7a 65 2c  g the page-size,
3780: 20 61 73 20 74 68 65 72 65 20 69 73 20 61 6e 20   as there is an 
3790: 69 6e 74 65 72 6e 61 6c 0a 20 20 20 20 20 20 2a  internal.      *
37a0: 2a 20 62 75 66 66 65 72 20 74 68 61 74 20 74 68  * buffer that th
37b0: 65 20 70 61 67 65 72 20 6d 6f 64 75 6c 65 20 72  e pager module r
37c0: 65 73 69 7a 65 73 20 75 73 69 6e 67 20 73 71 6c  esizes using sql
37d0: 69 74 65 33 5f 72 65 61 6c 6c 6f 63 28 29 2e 0a  ite3_realloc()..
37e0: 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 64        */.      d
37f0: 62 2d 3e 6e 65 78 74 50 61 67 65 73 69 7a 65 20  b->nextPagesize 
3800: 3d 20 61 74 6f 69 28 7a 52 69 67 68 74 29 3b 0a  = atoi(zRight);.
3810: 20 20 20 20 20 20 69 66 28 20 53 51 4c 49 54 45        if( SQLITE
3820: 5f 4e 4f 4d 45 4d 3d 3d 73 71 6c 69 74 65 33 42  _NOMEM==sqlite3B
3830: 74 72 65 65 53 65 74 50 61 67 65 53 69 7a 65 28  treeSetPageSize(
3840: 70 42 74 2c 20 64 62 2d 3e 6e 65 78 74 50 61 67  pBt, db->nextPag
3850: 65 73 69 7a 65 2c 20 2d 31 2c 20 30 29 20 29 7b  esize, -1, 0) ){
3860: 0a 20 20 20 20 20 20 20 20 64 62 2d 3e 6d 61 6c  .        db->mal
3870: 6c 6f 63 46 61 69 6c 65 64 20 3d 20 31 3b 0a 20  locFailed = 1;. 
3880: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d       }.    }.  }
3890: 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20  else..  /*.  ** 
38a0: 20 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73   PRAGMA [databas
38b0: 65 2e 5d 6d 61 78 5f 70 61 67 65 5f 63 6f 75 6e  e.]max_page_coun
38c0: 74 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b  t.  **  PRAGMA [
38d0: 64 61 74 61 62 61 73 65 2e 5d 6d 61 78 5f 70 61  database.]max_pa
38e0: 67 65 5f 63 6f 75 6e 74 3d 4e 0a 20 20 2a 2a 0a  ge_count=N.  **.
38f0: 20 20 2a 2a 20 54 68 65 20 66 69 72 73 74 20 66    ** The first f
3900: 6f 72 6d 20 72 65 70 6f 72 74 73 20 74 68 65 20  orm reports the 
3910: 63 75 72 72 65 6e 74 20 73 65 74 74 69 6e 67 20  current setting 
3920: 66 6f 72 20 74 68 65 0a 20 20 2a 2a 20 6d 61 78  for the.  ** max
3930: 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20 70  imum number of p
3940: 61 67 65 73 20 69 6e 20 74 68 65 20 64 61 74 61  ages in the data
3950: 62 61 73 65 20 66 69 6c 65 2e 20 20 54 68 65 20  base file.  The 
3960: 0a 20 20 2a 2a 20 73 65 63 6f 6e 64 20 66 6f 72  .  ** second for
3970: 6d 20 61 74 74 65 6d 70 74 73 20 74 6f 20 63 68  m attempts to ch
3980: 61 6e 67 65 20 74 68 69 73 20 73 65 74 74 69 6e  ange this settin
3990: 67 2e 20 20 42 6f 74 68 0a 20 20 2a 2a 20 66 6f  g.  Both.  ** fo
39a0: 72 6d 73 20 72 65 74 75 72 6e 20 74 68 65 20 63  rms return the c
39b0: 75 72 72 65 6e 74 20 73 65 74 74 69 6e 67 2e 0a  urrent setting..
39c0: 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74    */.  if( sqlit
39d0: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
39e0: 22 6d 61 78 5f 70 61 67 65 5f 63 6f 75 6e 74 22  "max_page_count"
39f0: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 42 74 72 65  )==0 ){.    Btre
3a00: 65 20 2a 70 42 74 20 3d 20 70 44 62 2d 3e 70 42  e *pBt = pDb->pB
3a10: 74 3b 0a 20 20 20 20 69 6e 74 20 6e 65 77 4d 61  t;.    int newMa
3a20: 78 20 3d 20 30 3b 0a 20 20 20 20 61 73 73 65 72  x = 0;.    asser
3a30: 74 28 20 70 42 74 21 3d 30 20 29 3b 0a 20 20 20  t( pBt!=0 );.   
3a40: 20 69 66 28 20 7a 52 69 67 68 74 20 29 7b 0a 20   if( zRight ){. 
3a50: 20 20 20 20 20 6e 65 77 4d 61 78 20 3d 20 61 74       newMax = at
3a60: 6f 69 28 7a 52 69 67 68 74 29 3b 0a 20 20 20 20  oi(zRight);.    
3a70: 7d 0a 20 20 20 20 69 66 28 20 41 4c 57 41 59 53  }.    if( ALWAYS
3a80: 28 70 42 74 29 20 29 7b 0a 20 20 20 20 20 20 6e  (pBt) ){.      n
3a90: 65 77 4d 61 78 20 3d 20 73 71 6c 69 74 65 33 42  ewMax = sqlite3B
3aa0: 74 72 65 65 4d 61 78 50 61 67 65 43 6f 75 6e 74  treeMaxPageCount
3ab0: 28 70 42 74 2c 20 6e 65 77 4d 61 78 29 3b 0a 20  (pBt, newMax);. 
3ac0: 20 20 20 7d 0a 20 20 20 20 72 65 74 75 72 6e 53     }.    returnS
3ad0: 69 6e 67 6c 65 49 6e 74 28 70 50 61 72 73 65 2c  ingleInt(pParse,
3ae0: 20 22 6d 61 78 5f 70 61 67 65 5f 63 6f 75 6e 74   "max_page_count
3af0: 22 2c 20 6e 65 77 4d 61 78 29 3b 0a 20 20 7d 65  ", newMax);.  }e
3b00: 6c 73 65 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20  lse..  /*.  **  
3b10: 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65  PRAGMA [database
3b20: 2e 5d 73 65 63 75 72 65 5f 64 65 6c 65 74 65 0a  .]secure_delete.
3b30: 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64 61    **  PRAGMA [da
3b40: 74 61 62 61 73 65 2e 5d 73 65 63 75 72 65 5f 64  tabase.]secure_d
3b50: 65 6c 65 74 65 3d 4f 4e 2f 4f 46 46 0a 20 20 2a  elete=ON/OFF.  *
3b60: 2a 0a 20 20 2a 2a 20 54 68 65 20 66 69 72 73 74  *.  ** The first
3b70: 20 66 6f 72 6d 20 72 65 70 6f 72 74 73 20 74 68   form reports th
3b80: 65 20 63 75 72 72 65 6e 74 20 73 65 74 74 69 6e  e current settin
3b90: 67 20 66 6f 72 20 74 68 65 0a 20 20 2a 2a 20 73  g for the.  ** s
3ba0: 65 63 75 72 65 5f 64 65 6c 65 74 65 20 66 6c 61  ecure_delete fla
3bb0: 67 2e 20 20 54 68 65 20 73 65 63 6f 6e 64 20 66  g.  The second f
3bc0: 6f 72 6d 20 63 68 61 6e 67 65 73 20 74 68 65 20  orm changes the 
3bd0: 73 65 63 75 72 65 5f 64 65 6c 65 74 65 0a 20 20  secure_delete.  
3be0: 2a 2a 20 66 6c 61 67 20 73 65 74 74 69 6e 67 20  ** flag setting 
3bf0: 61 6e 64 20 72 65 70 6f 72 74 73 20 74 68 65 6e  and reports then
3c00: 65 77 20 76 61 6c 75 65 2e 0a 20 20 2a 2f 0a 20  ew value..  */. 
3c10: 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49   if( sqlite3StrI
3c20: 43 6d 70 28 7a 4c 65 66 74 2c 22 73 65 63 75 72  Cmp(zLeft,"secur
3c30: 65 5f 64 65 6c 65 74 65 22 29 3d 3d 30 20 29 7b  e_delete")==0 ){
3c40: 0a 20 20 20 20 42 74 72 65 65 20 2a 70 42 74 20  .    Btree *pBt 
3c50: 3d 20 70 44 62 2d 3e 70 42 74 3b 0a 20 20 20 20  = pDb->pBt;.    
3c60: 69 6e 74 20 62 20 3d 20 2d 31 3b 0a 20 20 20 20  int b = -1;.    
3c70: 61 73 73 65 72 74 28 20 70 42 74 21 3d 30 20 29  assert( pBt!=0 )
3c80: 3b 0a 20 20 20 20 69 66 28 20 7a 52 69 67 68 74  ;.    if( zRight
3c90: 20 29 7b 0a 20 20 20 20 20 20 62 20 3d 20 67 65   ){.      b = ge
3ca0: 74 42 6f 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29  tBoolean(zRight)
3cb0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20  ;.    }.    if( 
3cc0: 70 49 64 32 2d 3e 6e 3d 3d 30 20 26 26 20 62 3e  pId2->n==0 && b>
3cd0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20  =0 ){.      int 
3ce0: 69 69 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 69  ii;.      for(ii
3cf0: 3d 30 3b 20 69 69 3c 64 62 2d 3e 6e 44 62 3b 20  =0; ii<db->nDb; 
3d00: 69 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 73  ii++){.        s
3d10: 71 6c 69 74 65 33 42 74 72 65 65 53 65 63 75 72  qlite3BtreeSecur
3d20: 65 44 65 6c 65 74 65 28 64 62 2d 3e 61 44 62 5b  eDelete(db->aDb[
3d30: 69 69 5d 2e 70 42 74 2c 20 62 29 3b 0a 20 20 20  ii].pBt, b);.   
3d40: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 62     }.    }.    b
3d50: 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 53   = sqlite3BtreeS
3d60: 65 63 75 72 65 44 65 6c 65 74 65 28 70 42 74 2c  ecureDelete(pBt,
3d70: 20 62 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 53   b);.    returnS
3d80: 69 6e 67 6c 65 49 6e 74 28 70 50 61 72 73 65 2c  ingleInt(pParse,
3d90: 20 22 73 65 63 75 72 65 5f 64 65 6c 65 74 65 22   "secure_delete"
3da0: 2c 20 62 29 3b 0a 20 20 7d 65 6c 73 65 0a 0a 20  , b);.  }else.. 
3db0: 20 2f 2a 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41   /*.  **  PRAGMA
3dc0: 20 5b 64 61 74 61 62 61 73 65 2e 5d 70 61 67 65   [database.]page
3dd0: 5f 63 6f 75 6e 74 0a 20 20 2a 2a 0a 20 20 2a 2a  _count.  **.  **
3de0: 20 52 65 74 75 72 6e 20 74 68 65 20 6e 75 6d 62   Return the numb
3df0: 65 72 20 6f 66 20 70 61 67 65 73 20 69 6e 20 74  er of pages in t
3e00: 68 65 20 73 70 65 63 69 66 69 65 64 20 64 61 74  he specified dat
3e10: 61 62 61 73 65 2e 0a 20 20 2a 2f 0a 20 20 69 66  abase..  */.  if
3e20: 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70  ( sqlite3StrICmp
3e30: 28 7a 4c 65 66 74 2c 22 70 61 67 65 5f 63 6f 75  (zLeft,"page_cou
3e40: 6e 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 69  nt")==0 ){.    i
3e50: 6e 74 20 69 52 65 67 3b 0a 20 20 20 20 69 66 28  nt iReg;.    if(
3e60: 20 73 71 6c 69 74 65 33 52 65 61 64 53 63 68 65   sqlite3ReadSche
3e70: 6d 61 28 70 50 61 72 73 65 29 20 29 20 67 6f 74  ma(pParse) ) got
3e80: 6f 20 70 72 61 67 6d 61 5f 6f 75 74 3b 0a 20 20  o pragma_out;.  
3e90: 20 20 73 71 6c 69 74 65 33 43 6f 64 65 56 65 72    sqlite3CodeVer
3ea0: 69 66 79 53 63 68 65 6d 61 28 70 50 61 72 73 65  ifySchema(pParse
3eb0: 2c 20 69 44 62 29 3b 0a 20 20 20 20 69 52 65 67  , iDb);.    iReg
3ec0: 20 3d 20 2b 2b 70 50 61 72 73 65 2d 3e 6e 4d 65   = ++pParse->nMe
3ed0: 6d 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  m;.    sqlite3Vd
3ee0: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 50  beAddOp2(v, OP_P
3ef0: 61 67 65 63 6f 75 6e 74 2c 20 69 44 62 2c 20 69  agecount, iDb, i
3f00: 52 65 67 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  Reg);.    sqlite
3f10: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
3f20: 50 5f 52 65 73 75 6c 74 52 6f 77 2c 20 69 52 65  P_ResultRow, iRe
3f30: 67 2c 20 31 29 3b 0a 20 20 20 20 73 71 6c 69 74  g, 1);.    sqlit
3f40: 65 33 56 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73  e3VdbeSetNumCols
3f50: 28 76 2c 20 31 29 3b 0a 20 20 20 20 73 71 6c 69  (v, 1);.    sqli
3f60: 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d  te3VdbeSetColNam
3f70: 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f  e(v, 0, COLNAME_
3f80: 4e 41 4d 45 2c 20 22 70 61 67 65 5f 63 6f 75 6e  NAME, "page_coun
3f90: 74 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49  t", SQLITE_STATI
3fa0: 43 29 3b 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f  C);.  }else..  /
3fb0: 2a 0a 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b  *.  **  PRAGMA [
3fc0: 64 61 74 61 62 61 73 65 2e 5d 6c 6f 63 6b 69 6e  database.]lockin
3fd0: 67 5f 6d 6f 64 65 0a 20 20 2a 2a 20 20 50 52 41  g_mode.  **  PRA
3fe0: 47 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 6c  GMA [database.]l
3ff0: 6f 63 6b 69 6e 67 5f 6d 6f 64 65 20 3d 20 28 6e  ocking_mode = (n
4000: 6f 72 6d 61 6c 7c 65 78 63 6c 75 73 69 76 65 29  ormal|exclusive)
4010: 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69  .  */.  if( sqli
4020: 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74  te3StrICmp(zLeft
4030: 2c 22 6c 6f 63 6b 69 6e 67 5f 6d 6f 64 65 22 29  ,"locking_mode")
4040: 3d 3d 30 20 29 7b 0a 20 20 20 20 63 6f 6e 73 74  ==0 ){.    const
4050: 20 63 68 61 72 20 2a 7a 52 65 74 20 3d 20 22 6e   char *zRet = "n
4060: 6f 72 6d 61 6c 22 3b 0a 20 20 20 20 69 6e 74 20  ormal";.    int 
4070: 65 4d 6f 64 65 20 3d 20 67 65 74 4c 6f 63 6b 69  eMode = getLocki
4080: 6e 67 4d 6f 64 65 28 7a 52 69 67 68 74 29 3b 0a  ngMode(zRight);.
4090: 0a 20 20 20 20 69 66 28 20 70 49 64 32 2d 3e 6e  .    if( pId2->n
40a0: 3d 3d 30 20 26 26 20 65 4d 6f 64 65 3d 3d 50 41  ==0 && eMode==PA
40b0: 47 45 52 5f 4c 4f 43 4b 49 4e 47 4d 4f 44 45 5f  GER_LOCKINGMODE_
40c0: 51 55 45 52 59 20 29 7b 0a 20 20 20 20 20 20 2f  QUERY ){.      /
40d0: 2a 20 53 69 6d 70 6c 65 20 22 50 52 41 47 4d 41  * Simple "PRAGMA
40e0: 20 6c 6f 63 6b 69 6e 67 5f 6d 6f 64 65 3b 22 20   locking_mode;" 
40f0: 73 74 61 74 65 6d 65 6e 74 2e 20 54 68 69 73 20  statement. This 
4100: 69 73 20 61 20 71 75 65 72 79 20 66 6f 72 0a 20  is a query for. 
4110: 20 20 20 20 20 2a 2a 20 74 68 65 20 63 75 72 72       ** the curr
4120: 65 6e 74 20 64 65 66 61 75 6c 74 20 6c 6f 63 6b  ent default lock
4130: 69 6e 67 20 6d 6f 64 65 20 28 77 68 69 63 68 20  ing mode (which 
4140: 6d 61 79 20 62 65 20 64 69 66 66 65 72 65 6e 74  may be different
4150: 20 74 6f 0a 20 20 20 20 20 20 2a 2a 20 74 68 65   to.      ** the
4160: 20 6c 6f 63 6b 69 6e 67 2d 6d 6f 64 65 20 6f 66   locking-mode of
4170: 20 74 68 65 20 6d 61 69 6e 20 64 61 74 61 62 61   the main databa
4180: 73 65 29 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20  se)..      */.  
4190: 20 20 20 20 65 4d 6f 64 65 20 3d 20 64 62 2d 3e      eMode = db->
41a0: 64 66 6c 74 4c 6f 63 6b 4d 6f 64 65 3b 0a 20 20  dfltLockMode;.  
41b0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 50    }else{.      P
41c0: 61 67 65 72 20 2a 70 50 61 67 65 72 3b 0a 20 20  ager *pPager;.  
41d0: 20 20 20 20 69 66 28 20 70 49 64 32 2d 3e 6e 3d      if( pId2->n=
41e0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 2f 2a  =0 ){.        /*
41f0: 20 54 68 69 73 20 69 6e 64 69 63 61 74 65 73 20   This indicates 
4200: 74 68 61 74 20 6e 6f 20 64 61 74 61 62 61 73 65  that no database
4210: 20 6e 61 6d 65 20 77 61 73 20 73 70 65 63 69 66   name was specif
4220: 69 65 64 20 61 73 20 70 61 72 74 0a 20 20 20 20  ied as part.    
4230: 20 20 20 20 2a 2a 20 6f 66 20 74 68 65 20 50 52      ** of the PR
4240: 41 47 4d 41 20 63 6f 6d 6d 61 6e 64 2e 20 49 6e  AGMA command. In
4250: 20 74 68 69 73 20 63 61 73 65 20 74 68 65 20 6c   this case the l
4260: 6f 63 6b 69 6e 67 2d 6d 6f 64 65 20 6d 75 73 74  ocking-mode must
4270: 20 62 65 0a 20 20 20 20 20 20 20 20 2a 2a 20 73   be.        ** s
4280: 65 74 20 6f 6e 20 61 6c 6c 20 61 74 74 61 63 68  et on all attach
4290: 65 64 20 64 61 74 61 62 61 73 65 73 2c 20 61 73  ed databases, as
42a0: 20 77 65 6c 6c 20 61 73 20 74 68 65 20 6d 61 69   well as the mai
42b0: 6e 20 64 62 20 66 69 6c 65 2e 0a 20 20 20 20 20  n db file..     
42c0: 20 20 20 2a 2a 0a 20 20 20 20 20 20 20 20 2a 2a     **.        **
42d0: 20 41 6c 73 6f 2c 20 74 68 65 20 73 71 6c 69 74   Also, the sqlit
42e0: 65 33 2e 64 66 6c 74 4c 6f 63 6b 4d 6f 64 65 20  e3.dfltLockMode 
42f0: 76 61 72 69 61 62 6c 65 20 69 73 20 73 65 74 20  variable is set 
4300: 73 6f 20 74 68 61 74 0a 20 20 20 20 20 20 20 20  so that.        
4310: 2a 2a 20 61 6e 79 20 73 75 62 73 65 71 75 65 6e  ** any subsequen
4320: 74 6c 79 20 61 74 74 61 63 68 65 64 20 64 61 74  tly attached dat
4330: 61 62 61 73 65 73 20 61 6c 73 6f 20 75 73 65 20  abases also use 
4340: 74 68 65 20 73 70 65 63 69 66 69 65 64 0a 20 20  the specified.  
4350: 20 20 20 20 20 20 2a 2a 20 6c 6f 63 6b 69 6e 67        ** locking
4360: 20 6d 6f 64 65 2e 0a 20 20 20 20 20 20 20 20 2a   mode..        *
4370: 2f 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 69  /.        int ii
4380: 3b 0a 20 20 20 20 20 20 20 20 61 73 73 65 72 74  ;.        assert
4390: 28 70 44 62 3d 3d 26 64 62 2d 3e 61 44 62 5b 30  (pDb==&db->aDb[0
43a0: 5d 29 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28  ]);.        for(
43b0: 69 69 3d 32 3b 20 69 69 3c 64 62 2d 3e 6e 44 62  ii=2; ii<db->nDb
43c0: 3b 20 69 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20  ; ii++){.       
43d0: 20 20 20 70 50 61 67 65 72 20 3d 20 73 71 6c 69     pPager = sqli
43e0: 74 65 33 42 74 72 65 65 50 61 67 65 72 28 64 62  te3BtreePager(db
43f0: 2d 3e 61 44 62 5b 69 69 5d 2e 70 42 74 29 3b 0a  ->aDb[ii].pBt);.
4400: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
4410: 33 50 61 67 65 72 4c 6f 63 6b 69 6e 67 4d 6f 64  3PagerLockingMod
4420: 65 28 70 50 61 67 65 72 2c 20 65 4d 6f 64 65 29  e(pPager, eMode)
4430: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
4440: 20 20 20 20 64 62 2d 3e 64 66 6c 74 4c 6f 63 6b      db->dfltLock
4450: 4d 6f 64 65 20 3d 20 28 75 38 29 65 4d 6f 64 65  Mode = (u8)eMode
4460: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
4470: 70 50 61 67 65 72 20 3d 20 73 71 6c 69 74 65 33  pPager = sqlite3
4480: 42 74 72 65 65 50 61 67 65 72 28 70 44 62 2d 3e  BtreePager(pDb->
4490: 70 42 74 29 3b 0a 20 20 20 20 20 20 65 4d 6f 64  pBt);.      eMod
44a0: 65 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72  e = sqlite3Pager
44b0: 4c 6f 63 6b 69 6e 67 4d 6f 64 65 28 70 50 61 67  LockingMode(pPag
44c0: 65 72 2c 20 65 4d 6f 64 65 29 3b 0a 20 20 20 20  er, eMode);.    
44d0: 7d 0a 0a 20 20 20 20 61 73 73 65 72 74 28 65 4d  }..    assert(eM
44e0: 6f 64 65 3d 3d 50 41 47 45 52 5f 4c 4f 43 4b 49  ode==PAGER_LOCKI
44f0: 4e 47 4d 4f 44 45 5f 4e 4f 52 4d 41 4c 7c 7c 65  NGMODE_NORMAL||e
4500: 4d 6f 64 65 3d 3d 50 41 47 45 52 5f 4c 4f 43 4b  Mode==PAGER_LOCK
4510: 49 4e 47 4d 4f 44 45 5f 45 58 43 4c 55 53 49 56  INGMODE_EXCLUSIV
4520: 45 29 3b 0a 20 20 20 20 69 66 28 20 65 4d 6f 64  E);.    if( eMod
4530: 65 3d 3d 50 41 47 45 52 5f 4c 4f 43 4b 49 4e 47  e==PAGER_LOCKING
4540: 4d 4f 44 45 5f 45 58 43 4c 55 53 49 56 45 20 29  MODE_EXCLUSIVE )
4550: 7b 0a 20 20 20 20 20 20 7a 52 65 74 20 3d 20 22  {.      zRet = "
4560: 65 78 63 6c 75 73 69 76 65 22 3b 0a 20 20 20 20  exclusive";.    
4570: 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  }.    sqlite3Vdb
4580: 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20 31  eSetNumCols(v, 1
4590: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
45a0: 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20  beSetColName(v, 
45b0: 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c  0, COLNAME_NAME,
45c0: 20 22 6c 6f 63 6b 69 6e 67 5f 6d 6f 64 65 22 2c   "locking_mode",
45d0: 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b   SQLITE_STATIC);
45e0: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
45f0: 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53 74 72  AddOp4(v, OP_Str
4600: 69 6e 67 38 2c 20 30 2c 20 31 2c 20 30 2c 20 7a  ing8, 0, 1, 0, z
4610: 52 65 74 2c 20 30 29 3b 0a 20 20 20 20 73 71 6c  Ret, 0);.    sql
4620: 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76  ite3VdbeAddOp2(v
4630: 2c 20 4f 50 5f 52 65 73 75 6c 74 52 6f 77 2c 20  , OP_ResultRow, 
4640: 31 2c 20 31 29 3b 0a 20 20 7d 65 6c 73 65 0a 0a  1, 1);.  }else..
4650: 20 20 2f 2a 0a 20 20 2a 2a 20 20 50 52 41 47 4d    /*.  **  PRAGM
4660: 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 6a 6f 75  A [database.]jou
4670: 72 6e 61 6c 5f 6d 6f 64 65 0a 20 20 2a 2a 20 20  rnal_mode.  **  
4680: 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65  PRAGMA [database
4690: 2e 5d 6a 6f 75 72 6e 61 6c 5f 6d 6f 64 65 20 3d  .]journal_mode =
46a0: 20 28 64 65 6c 65 74 65 7c 70 65 72 73 69 73 74   (delete|persist
46b0: 7c 6f 66 66 7c 74 72 75 6e 63 61 74 65 7c 6d 65  |off|truncate|me
46c0: 6d 6f 72 79 29 0a 20 20 2a 2f 0a 20 20 69 66 28  mory).  */.  if(
46d0: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
46e0: 7a 4c 65 66 74 2c 22 6a 6f 75 72 6e 61 6c 5f 6d  zLeft,"journal_m
46f0: 6f 64 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ode")==0 ){.    
4700: 69 6e 74 20 65 4d 6f 64 65 3b 20 20 20 20 20 20  int eMode;      
4710: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
4720: 20 4f 6e 65 20 6f 66 20 74 68 65 20 50 41 47 45   One of the PAGE
4730: 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 58 58  R_JOURNALMODE_XX
4740: 58 20 73 79 6d 62 6f 6c 73 20 2a 2f 0a 0a 20 20  X symbols */..  
4750: 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74    sqlite3VdbeSet
4760: 4e 75 6d 43 6f 6c 73 28 76 2c 20 31 29 3b 0a 20  NumCols(v, 1);. 
4770: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65     sqlite3VdbeSe
4780: 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 30 2c 20 43  tColName(v, 0, C
4790: 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 6a 6f  OLNAME_NAME, "jo
47a0: 75 72 6e 61 6c 5f 6d 6f 64 65 22 2c 20 53 51 4c  urnal_mode", SQL
47b0: 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 0a 20 20  ITE_STATIC);..  
47c0: 20 20 69 66 28 20 7a 52 69 67 68 74 3d 3d 30 20    if( zRight==0 
47d0: 29 7b 0a 20 20 20 20 20 20 65 4d 6f 64 65 20 3d  ){.      eMode =
47e0: 20 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f   PAGER_JOURNALMO
47f0: 44 45 5f 51 55 45 52 59 3b 0a 20 20 20 20 7d 65  DE_QUERY;.    }e
4800: 6c 73 65 7b 0a 20 20 20 20 20 20 63 6f 6e 73 74  lse{.      const
4810: 20 63 68 61 72 20 2a 7a 4d 6f 64 65 3b 0a 20 20   char *zMode;.  
4820: 20 20 20 20 69 6e 74 20 6e 20 3d 20 73 71 6c 69      int n = sqli
4830: 74 65 33 53 74 72 6c 65 6e 33 30 28 7a 52 69 67  te3Strlen30(zRig
4840: 68 74 29 3b 0a 20 20 20 20 20 20 66 6f 72 28 65  ht);.      for(e
4850: 4d 6f 64 65 3d 30 3b 20 28 7a 4d 6f 64 65 20 3d  Mode=0; (zMode =
4860: 20 73 71 6c 69 74 65 33 4a 6f 75 72 6e 61 6c 4d   sqlite3JournalM
4870: 6f 64 65 6e 61 6d 65 28 65 4d 6f 64 65 29 29 3b  odename(eMode));
4880: 20 65 4d 6f 64 65 2b 2b 29 7b 0a 20 20 20 20 20   eMode++){.     
4890: 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 53 74     if( sqlite3St
48a0: 72 4e 49 43 6d 70 28 7a 52 69 67 68 74 2c 20 7a  rNICmp(zRight, z
48b0: 4d 6f 64 65 2c 20 6e 29 3d 3d 30 20 29 20 62 72  Mode, n)==0 ) br
48c0: 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  eak;.      }.   
48d0: 20 20 20 69 66 28 20 21 7a 4d 6f 64 65 20 29 7b     if( !zMode ){
48e0: 0a 20 20 20 20 20 20 20 20 65 4d 6f 64 65 20 3d  .        eMode =
48f0: 20 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f   PAGER_JOURNALMO
4900: 44 45 5f 51 55 45 52 59 3b 0a 20 20 20 20 20 20  DE_QUERY;.      
4910: 7d 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20  }.    }.    if( 
4920: 70 49 64 32 2d 3e 6e 3d 3d 30 20 26 26 20 65 4d  pId2->n==0 && eM
4930: 6f 64 65 3d 3d 50 41 47 45 52 5f 4a 4f 55 52 4e  ode==PAGER_JOURN
4940: 41 4c 4d 4f 44 45 5f 51 55 45 52 59 20 29 7b 0a  ALMODE_QUERY ){.
4950: 20 20 20 20 20 20 2f 2a 20 53 69 6d 70 6c 65 20        /* Simple 
4960: 22 50 52 41 47 4d 41 20 6a 6f 75 72 6e 61 6c 5f  "PRAGMA journal_
4970: 6d 6f 64 65 3b 22 20 73 74 61 74 65 6d 65 6e 74  mode;" statement
4980: 2e 20 54 68 69 73 20 69 73 20 61 20 71 75 65 72  . This is a quer
4990: 79 20 66 6f 72 0a 20 20 20 20 20 20 2a 2a 20 74  y for.      ** t
49a0: 68 65 20 63 75 72 72 65 6e 74 20 64 65 66 61 75  he current defau
49b0: 6c 74 20 6a 6f 75 72 6e 61 6c 20 6d 6f 64 65 20  lt journal mode 
49c0: 28 77 68 69 63 68 20 6d 61 79 20 62 65 20 64 69  (which may be di
49d0: 66 66 65 72 65 6e 74 20 74 6f 0a 20 20 20 20 20  fferent to.     
49e0: 20 2a 2a 20 74 68 65 20 6a 6f 75 72 6e 61 6c 2d   ** the journal-
49f0: 6d 6f 64 65 20 6f 66 20 74 68 65 20 6d 61 69 6e  mode of the main
4a00: 20 64 61 74 61 62 61 73 65 29 2e 0a 20 20 20 20   database)..    
4a10: 20 20 2a 2f 0a 20 20 20 20 20 20 65 4d 6f 64 65    */.      eMode
4a20: 20 3d 20 64 62 2d 3e 64 66 6c 74 4a 6f 75 72 6e   = db->dfltJourn
4a30: 61 6c 4d 6f 64 65 3b 0a 20 20 20 20 20 20 73 71  alMode;.      sq
4a40: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
4a50: 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30  v, OP_String8, 0
4a60: 2c 20 31 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  , 1);.      sqli
4a70: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 34 28  te3VdbeChangeP4(
4a80: 76 2c 20 2d 31 2c 20 73 71 6c 69 74 65 33 4a 6f  v, -1, sqlite3Jo
4a90: 75 72 6e 61 6c 4d 6f 64 65 6e 61 6d 65 28 65 4d  urnalModename(eM
4aa0: 6f 64 65 29 2c 20 50 34 5f 53 54 41 54 49 43 29  ode), P4_STATIC)
4ab0: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
4ac0: 20 20 20 69 6e 74 20 69 69 3b 0a 0a 20 20 20 20     int ii;..    
4ad0: 20 20 69 66 28 20 70 49 64 32 2d 3e 6e 3d 3d 30    if( pId2->n==0
4ae0: 20 26 26 20 65 4d 6f 64 65 21 3d 50 41 47 45 52   && eMode!=PAGER
4af0: 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 57 41 4c  _JOURNALMODE_WAL
4b00: 20 29 7b 0a 20 20 20 20 20 20 20 20 2f 2a 20 54   ){.        /* T
4b10: 68 69 73 20 69 6e 64 69 63 61 74 65 73 20 74 68  his indicates th
4b20: 61 74 20 6e 6f 20 64 61 74 61 62 61 73 65 20 6e  at no database n
4b30: 61 6d 65 20 77 61 73 20 73 70 65 63 69 66 69 65  ame was specifie
4b40: 64 20 61 73 20 70 61 72 74 0a 20 20 20 20 20 20  d as part.      
4b50: 20 20 2a 2a 20 6f 66 20 74 68 65 20 50 52 41 47    ** of the PRAG
4b60: 4d 41 20 63 6f 6d 6d 61 6e 64 2e 20 49 6e 20 74  MA command. In t
4b70: 68 69 73 20 63 61 73 65 20 74 68 65 20 6a 6f 75  his case the jou
4b80: 72 6e 61 6c 2d 6d 6f 64 65 20 6d 75 73 74 20 62  rnal-mode must b
4b90: 65 0a 20 20 20 20 20 20 20 20 2a 2a 20 73 65 74  e.        ** set
4ba0: 20 6f 6e 20 61 6c 6c 20 61 74 74 61 63 68 65 64   on all attached
4bb0: 20 64 61 74 61 62 61 73 65 73 2c 20 61 73 20 77   databases, as w
4bc0: 65 6c 6c 20 61 73 20 74 68 65 20 6d 61 69 6e 20  ell as the main 
4bd0: 64 62 20 66 69 6c 65 2e 0a 20 20 20 20 20 20 20  db file..       
4be0: 20 2a 2a 0a 20 20 20 20 20 20 20 20 2a 2a 20 41   **.        ** A
4bf0: 6c 73 6f 2c 20 74 68 65 20 73 71 6c 69 74 65 33  lso, the sqlite3
4c00: 2e 64 66 6c 74 4a 6f 75 72 6e 61 6c 4d 6f 64 65  .dfltJournalMode
4c10: 20 76 61 72 69 61 62 6c 65 20 69 73 20 73 65 74   variable is set
4c20: 20 73 6f 20 74 68 61 74 0a 20 20 20 20 20 20 20   so that.       
4c30: 20 2a 2a 20 61 6e 79 20 73 75 62 73 65 71 75 65   ** any subseque
4c40: 6e 74 6c 79 20 61 74 74 61 63 68 65 64 20 64 61  ntly attached da
4c50: 74 61 62 61 73 65 73 20 61 6c 73 6f 20 75 73 65  tabases also use
4c60: 20 74 68 65 20 73 70 65 63 69 66 69 65 64 0a 20   the specified. 
4c70: 20 20 20 20 20 20 20 2a 2a 20 6a 6f 75 72 6e 61         ** journa
4c80: 6c 20 6d 6f 64 65 2e 20 45 78 63 65 70 74 2c 20  l mode. Except, 
4c90: 74 68 65 20 64 65 66 61 75 6c 74 20 6a 6f 75 72  the default jour
4ca0: 6e 61 6c 20 6d 6f 64 65 20 69 73 20 6e 65 76 65  nal mode is neve
4cb0: 72 20 73 65 74 0a 20 20 20 20 20 20 20 20 2a 2a  r set.        **
4cc0: 20 74 6f 20 57 41 4c 2e 0a 20 20 20 20 20 20 20   to WAL..       
4cd0: 20 2a 2f 0a 20 20 20 20 20 20 20 20 64 62 2d 3e   */.        db->
4ce0: 64 66 6c 74 4a 6f 75 72 6e 61 6c 4d 6f 64 65 20  dfltJournalMode 
4cf0: 3d 20 28 75 38 29 65 4d 6f 64 65 3b 0a 20 20 20  = (u8)eMode;.   
4d00: 20 20 20 7d 0a 0a 20 20 20 20 20 20 66 6f 72 28     }..      for(
4d10: 69 69 3d 64 62 2d 3e 6e 44 62 2d 31 3b 20 69 69  ii=db->nDb-1; ii
4d20: 3e 3d 30 3b 20 69 69 2d 2d 29 7b 0a 20 20 20 20  >=0; ii--){.    
4d30: 20 20 20 20 69 66 28 20 64 62 2d 3e 61 44 62 5b      if( db->aDb[
4d40: 69 69 5d 2e 70 42 74 20 26 26 20 28 69 69 3d 3d  ii].pBt && (ii==
4d50: 69 44 62 20 7c 7c 20 70 49 64 32 2d 3e 6e 3d 3d  iDb || pId2->n==
4d60: 30 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  0) ){.          
4d70: 73 71 6c 69 74 65 33 56 64 62 65 55 73 65 73 42  sqlite3VdbeUsesB
4d80: 74 72 65 65 28 76 2c 20 69 69 29 3b 0a 20 20 20  tree(v, ii);.   
4d90: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
4da0: 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4a  beAddOp3(v, OP_J
4db0: 6f 75 72 6e 61 6c 4d 6f 64 65 2c 20 69 69 2c 20  ournalMode, ii, 
4dc0: 31 2c 20 65 4d 6f 64 65 29 3b 0a 20 20 20 20 20  1, eMode);.     
4dd0: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
4de0: 20 7d 0a 0a 20 20 20 20 73 71 6c 69 74 65 33 56   }..    sqlite3V
4df0: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
4e00: 52 65 73 75 6c 74 52 6f 77 2c 20 31 2c 20 31 29  ResultRow, 1, 1)
4e10: 3b 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a  ;.  }else..  /*.
4e20: 20 20 2a 2a 20 20 50 52 41 47 4d 41 20 5b 64 61    **  PRAGMA [da
4e30: 74 61 62 61 73 65 2e 5d 6a 6f 75 72 6e 61 6c 5f  tabase.]journal_
4e40: 73 69 7a 65 5f 6c 69 6d 69 74 0a 20 20 2a 2a 20  size_limit.  ** 
4e50: 20 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73   PRAGMA [databas
4e60: 65 2e 5d 6a 6f 75 72 6e 61 6c 5f 73 69 7a 65 5f  e.]journal_size_
4e70: 6c 69 6d 69 74 3d 4e 0a 20 20 2a 2a 0a 20 20 2a  limit=N.  **.  *
4e80: 2a 20 47 65 74 20 6f 72 20 73 65 74 20 74 68 65  * Get or set the
4e90: 20 73 69 7a 65 20 6c 69 6d 69 74 20 6f 6e 20 72   size limit on r
4ea0: 6f 6c 6c 62 61 63 6b 20 6a 6f 75 72 6e 61 6c 20  ollback journal 
4eb0: 66 69 6c 65 73 2e 0a 20 20 2a 2f 0a 20 20 69 66  files..  */.  if
4ec0: 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70  ( sqlite3StrICmp
4ed0: 28 7a 4c 65 66 74 2c 22 6a 6f 75 72 6e 61 6c 5f  (zLeft,"journal_
4ee0: 73 69 7a 65 5f 6c 69 6d 69 74 22 29 3d 3d 30 20  size_limit")==0 
4ef0: 29 7b 0a 20 20 20 20 50 61 67 65 72 20 2a 70 50  ){.    Pager *pP
4f00: 61 67 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74  ager = sqlite3Bt
4f10: 72 65 65 50 61 67 65 72 28 70 44 62 2d 3e 70 42  reePager(pDb->pB
4f20: 74 29 3b 0a 20 20 20 20 69 36 34 20 69 4c 69 6d  t);.    i64 iLim
4f30: 69 74 20 3d 20 2d 32 3b 0a 20 20 20 20 69 66 28  it = -2;.    if(
4f40: 20 7a 52 69 67 68 74 20 29 7b 0a 20 20 20 20 20   zRight ){.     
4f50: 20 73 71 6c 69 74 65 33 41 74 6f 69 36 34 28 7a   sqlite3Atoi64(z
4f60: 52 69 67 68 74 2c 20 26 69 4c 69 6d 69 74 29 3b  Right, &iLimit);
4f70: 0a 20 20 20 20 20 20 69 66 28 20 69 4c 69 6d 69  .      if( iLimi
4f80: 74 3c 2d 31 20 29 20 69 4c 69 6d 69 74 20 3d 20  t<-1 ) iLimit = 
4f90: 2d 31 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 4c  -1;.    }.    iL
4fa0: 69 6d 69 74 20 3d 20 73 71 6c 69 74 65 33 50 61  imit = sqlite3Pa
4fb0: 67 65 72 4a 6f 75 72 6e 61 6c 53 69 7a 65 4c 69  gerJournalSizeLi
4fc0: 6d 69 74 28 70 50 61 67 65 72 2c 20 69 4c 69 6d  mit(pPager, iLim
4fd0: 69 74 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 53  it);.    returnS
4fe0: 69 6e 67 6c 65 49 6e 74 28 70 50 61 72 73 65 2c  ingleInt(pParse,
4ff0: 20 22 6a 6f 75 72 6e 61 6c 5f 73 69 7a 65 5f 6c   "journal_size_l
5000: 69 6d 69 74 22 2c 20 69 4c 69 6d 69 74 29 3b 0a  imit", iLimit);.
5010: 20 20 7d 65 6c 73 65 0a 0a 23 65 6e 64 69 66 20    }else..#endif 
5020: 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50  /* SQLITE_OMIT_P
5030: 41 47 45 52 5f 50 52 41 47 4d 41 53 20 2a 2f 0a  AGER_PRAGMAS */.
5040: 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 50 52 41 47  .  /*.  **  PRAG
5050: 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 61 75  MA [database.]au
5060: 74 6f 5f 76 61 63 75 75 6d 0a 20 20 2a 2a 20 20  to_vacuum.  **  
5070: 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65  PRAGMA [database
5080: 2e 5d 61 75 74 6f 5f 76 61 63 75 75 6d 3d 4e 0a  .]auto_vacuum=N.
5090: 20 20 2a 2a 0a 20 20 2a 2a 20 47 65 74 20 6f 72    **.  ** Get or
50a0: 20 73 65 74 20 74 68 65 20 76 61 6c 75 65 20 6f   set the value o
50b0: 66 20 74 68 65 20 64 61 74 61 62 61 73 65 20 27  f the database '
50c0: 61 75 74 6f 2d 76 61 63 75 75 6d 27 20 70 61 72  auto-vacuum' par
50d0: 61 6d 65 74 65 72 2e 0a 20 20 2a 2a 20 54 68 65  ameter..  ** The
50e0: 20 76 61 6c 75 65 20 69 73 20 6f 6e 65 20 6f 66   value is one of
50f0: 3a 20 20 30 20 4e 4f 4e 45 20 31 20 46 55 4c 4c  :  0 NONE 1 FULL
5100: 20 32 20 49 4e 43 52 45 4d 45 4e 54 41 4c 0a 20   2 INCREMENTAL. 
5110: 20 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49   */.#ifndef SQLI
5120: 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 56 41 43 55  TE_OMIT_AUTOVACU
5130: 55 4d 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33  UM.  if( sqlite3
5140: 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 22 61  StrICmp(zLeft,"a
5150: 75 74 6f 5f 76 61 63 75 75 6d 22 29 3d 3d 30 20  uto_vacuum")==0 
5160: 29 7b 0a 20 20 20 20 42 74 72 65 65 20 2a 70 42  ){.    Btree *pB
5170: 74 20 3d 20 70 44 62 2d 3e 70 42 74 3b 0a 20 20  t = pDb->pBt;.  
5180: 20 20 61 73 73 65 72 74 28 20 70 42 74 21 3d 30    assert( pBt!=0
5190: 20 29 3b 0a 20 20 20 20 69 66 28 20 73 71 6c 69   );.    if( sqli
51a0: 74 65 33 52 65 61 64 53 63 68 65 6d 61 28 70 50  te3ReadSchema(pP
51b0: 61 72 73 65 29 20 29 7b 0a 20 20 20 20 20 20 67  arse) ){.      g
51c0: 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75 74 3b 0a  oto pragma_out;.
51d0: 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 21 7a      }.    if( !z
51e0: 52 69 67 68 74 20 29 7b 0a 20 20 20 20 20 20 69  Right ){.      i
51f0: 6e 74 20 61 75 74 6f 5f 76 61 63 75 75 6d 3b 0a  nt auto_vacuum;.
5200: 20 20 20 20 20 20 69 66 28 20 41 4c 57 41 59 53        if( ALWAYS
5210: 28 70 42 74 29 20 29 7b 0a 20 20 20 20 20 20 20  (pBt) ){.       
5220: 20 20 61 75 74 6f 5f 76 61 63 75 75 6d 20 3d 20    auto_vacuum = 
5230: 73 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 41  sqlite3BtreeGetA
5240: 75 74 6f 56 61 63 75 75 6d 28 70 42 74 29 3b 0a  utoVacuum(pBt);.
5250: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
5260: 20 20 20 20 20 20 61 75 74 6f 5f 76 61 63 75 75        auto_vacuu
5270: 6d 20 3d 20 53 51 4c 49 54 45 5f 44 45 46 41 55  m = SQLITE_DEFAU
5280: 4c 54 5f 41 55 54 4f 56 41 43 55 55 4d 3b 0a 20  LT_AUTOVACUUM;. 
5290: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65 74       }.      ret
52a0: 75 72 6e 53 69 6e 67 6c 65 49 6e 74 28 70 50 61  urnSingleInt(pPa
52b0: 72 73 65 2c 20 22 61 75 74 6f 5f 76 61 63 75 75  rse, "auto_vacuu
52c0: 6d 22 2c 20 61 75 74 6f 5f 76 61 63 75 75 6d 29  m", auto_vacuum)
52d0: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
52e0: 20 20 20 69 6e 74 20 65 41 75 74 6f 20 3d 20 67     int eAuto = g
52f0: 65 74 41 75 74 6f 56 61 63 75 75 6d 28 7a 52 69  etAutoVacuum(zRi
5300: 67 68 74 29 3b 0a 20 20 20 20 20 20 61 73 73 65  ght);.      asse
5310: 72 74 28 20 65 41 75 74 6f 3e 3d 30 20 26 26 20  rt( eAuto>=0 && 
5320: 65 41 75 74 6f 3c 3d 32 20 29 3b 0a 20 20 20 20  eAuto<=2 );.    
5330: 20 20 64 62 2d 3e 6e 65 78 74 41 75 74 6f 76 61    db->nextAutova
5340: 63 20 3d 20 28 75 38 29 65 41 75 74 6f 3b 0a 20  c = (u8)eAuto;. 
5350: 20 20 20 20 20 69 66 28 20 41 4c 57 41 59 53 28       if( ALWAYS(
5360: 65 41 75 74 6f 3e 3d 30 29 20 29 7b 0a 20 20 20  eAuto>=0) ){.   
5370: 20 20 20 20 20 2f 2a 20 43 61 6c 6c 20 53 65 74       /* Call Set
5380: 41 75 74 6f 56 61 63 75 75 6d 28 29 20 74 6f 20  AutoVacuum() to 
5390: 73 65 74 20 69 6e 69 74 69 61 6c 69 7a 65 20 74  set initialize t
53a0: 68 65 20 69 6e 74 65 72 6e 61 6c 20 61 75 74 6f  he internal auto
53b0: 20 61 6e 64 0a 20 20 20 20 20 20 20 20 2a 2a 20   and.        ** 
53c0: 69 6e 63 72 2d 76 61 63 75 75 6d 20 66 6c 61 67  incr-vacuum flag
53d0: 73 2e 20 54 68 69 73 20 69 73 20 72 65 71 75 69  s. This is requi
53e0: 72 65 64 20 69 6e 20 63 61 73 65 20 74 68 69 73  red in case this
53f0: 20 63 6f 6e 6e 65 63 74 69 6f 6e 0a 20 20 20 20   connection.    
5400: 20 20 20 20 2a 2a 20 63 72 65 61 74 65 73 20 74      ** creates t
5410: 68 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65  he database file
5420: 2e 20 49 74 20 69 73 20 69 6d 70 6f 72 74 61 6e  . It is importan
5430: 74 20 74 68 61 74 20 69 74 20 69 73 20 63 72 65  t that it is cre
5440: 61 74 65 64 0a 20 20 20 20 20 20 20 20 2a 2a 20  ated.        ** 
5450: 61 73 20 61 6e 20 61 75 74 6f 2d 76 61 63 75 75  as an auto-vacuu
5460: 6d 20 63 61 70 61 62 6c 65 20 64 62 2e 0a 20 20  m capable db..  
5470: 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 20        */.       
5480: 20 69 6e 74 20 72 63 20 3d 20 73 71 6c 69 74 65   int rc = sqlite
5490: 33 42 74 72 65 65 53 65 74 41 75 74 6f 56 61 63  3BtreeSetAutoVac
54a0: 75 75 6d 28 70 42 74 2c 20 65 41 75 74 6f 29 3b  uum(pBt, eAuto);
54b0: 0a 20 20 20 20 20 20 20 20 69 66 28 20 72 63 3d  .        if( rc=
54c0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 28 65  =SQLITE_OK && (e
54d0: 41 75 74 6f 3d 3d 31 20 7c 7c 20 65 41 75 74 6f  Auto==1 || eAuto
54e0: 3d 3d 32 29 20 29 7b 0a 20 20 20 20 20 20 20 20  ==2) ){.        
54f0: 20 20 2f 2a 20 57 68 65 6e 20 73 65 74 74 69 6e    /* When settin
5500: 67 20 74 68 65 20 61 75 74 6f 5f 76 61 63 75 75  g the auto_vacuu
5510: 6d 20 6d 6f 64 65 20 74 6f 20 65 69 74 68 65 72  m mode to either
5520: 20 22 66 75 6c 6c 22 20 6f 72 20 0a 20 20 20 20   "full" or .    
5530: 20 20 20 20 20 20 2a 2a 20 22 69 6e 63 72 65 6d        ** "increm
5540: 65 6e 74 61 6c 22 2c 20 77 72 69 74 65 20 74 68  ental", write th
5550: 65 20 76 61 6c 75 65 20 6f 66 20 6d 65 74 61 5b  e value of meta[
5560: 36 5d 20 69 6e 20 74 68 65 20 64 61 74 61 62 61  6] in the databa
5570: 73 65 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 20  se.          ** 
5580: 66 69 6c 65 2e 20 42 65 66 6f 72 65 20 77 72 69  file. Before wri
5590: 74 69 6e 67 20 74 6f 20 6d 65 74 61 5b 36 5d 2c  ting to meta[6],
55a0: 20 63 68 65 63 6b 20 74 68 61 74 20 6d 65 74 61   check that meta
55b0: 5b 33 5d 20 69 6e 64 69 63 61 74 65 73 0a 20 20  [3] indicates.  
55c0: 20 20 20 20 20 20 20 20 2a 2a 20 74 68 61 74 20          ** that 
55d0: 74 68 69 73 20 72 65 61 6c 6c 79 20 69 73 20 61  this really is a
55e0: 6e 20 61 75 74 6f 2d 76 61 63 75 75 6d 20 63 61  n auto-vacuum ca
55f0: 70 61 62 6c 65 20 64 61 74 61 62 61 73 65 2e 0a  pable database..
5600: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 20            */.   
5610: 20 20 20 20 20 20 20 73 74 61 74 69 63 20 63 6f         static co
5620: 6e 73 74 20 56 64 62 65 4f 70 4c 69 73 74 20 73  nst VdbeOpList s
5630: 65 74 4d 65 74 61 36 5b 5d 20 3d 20 7b 0a 20 20  etMeta6[] = {.  
5640: 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 54            { OP_T
5650: 72 61 6e 73 61 63 74 69 6f 6e 2c 20 20 20 20 30  ransaction,    0
5660: 2c 20 20 20 20 20 20 20 20 20 31 2c 20 20 20 20  ,         1,    
5670: 20 20 20 20 20 20 20 20 20 20 20 20 20 30 7d 2c               0},
5680: 20 20 20 20 2f 2a 20 30 20 2a 2f 0a 20 20 20 20      /* 0 */.    
5690: 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 52 65 61          { OP_Rea
56a0: 64 43 6f 6f 6b 69 65 2c 20 20 20 20 20 30 2c 20  dCookie,     0, 
56b0: 20 20 20 20 20 20 20 20 31 2c 20 20 20 20 20 20          1,      
56c0: 20 20 20 42 54 52 45 45 5f 4c 41 52 47 45 53 54     BTREE_LARGEST
56d0: 5f 52 4f 4f 54 5f 50 41 47 45 7d 2c 0a 20 20 20  _ROOT_PAGE},.   
56e0: 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 49 66           { OP_If
56f0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 31 2c  ,             1,
5700: 20 20 20 20 20 20 20 20 20 30 2c 20 20 20 20 20           0,     
5710: 20 20 20 20 20 20 20 20 20 20 20 20 30 7d 2c 20              0}, 
5720: 20 20 20 2f 2a 20 32 20 2a 2f 0a 20 20 20 20 20     /* 2 */.     
5730: 20 20 20 20 20 20 20 7b 20 4f 50 5f 48 61 6c 74         { OP_Halt
5740: 2c 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 49  ,           SQLI
5750: 54 45 5f 4f 4b 2c 20 4f 45 5f 41 62 6f 72 74 2c  TE_OK, OE_Abort,
5760: 20 20 20 20 20 20 20 20 20 20 30 7d 2c 20 20 20            0},   
5770: 20 2f 2a 20 33 20 2a 2f 0a 20 20 20 20 20 20 20   /* 3 */.       
5780: 20 20 20 20 20 7b 20 4f 50 5f 49 6e 74 65 67 65       { OP_Intege
5790: 72 2c 20 20 20 20 20 20 20 20 30 2c 20 20 20 20  r,        0,    
57a0: 20 20 20 20 20 31 2c 20 20 20 20 20 20 20 20 20       1,         
57b0: 20 20 20 20 20 20 20 20 30 7d 2c 20 20 20 20 2f          0},    /
57c0: 2a 20 34 20 2a 2f 0a 20 20 20 20 20 20 20 20 20  * 4 */.         
57d0: 20 20 20 7b 20 4f 50 5f 53 65 74 43 6f 6f 6b 69     { OP_SetCooki
57e0: 65 2c 20 20 20 20 20 20 30 2c 20 20 20 20 20 20  e,      0,      
57f0: 20 20 20 42 54 52 45 45 5f 49 4e 43 52 5f 56 41     BTREE_INCR_VA
5800: 43 55 55 4d 2c 20 31 7d 2c 20 20 20 20 2f 2a 20  CUUM, 1},    /* 
5810: 35 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 7d  5 */.          }
5820: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 6e 74 20  ;.          int 
5830: 69 41 64 64 72 3b 0a 20 20 20 20 20 20 20 20 20  iAddr;.         
5840: 20 69 41 64 64 72 20 3d 20 73 71 6c 69 74 65 33   iAddr = sqlite3
5850: 56 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c  VdbeAddOpList(v,
5860: 20 41 72 72 61 79 53 69 7a 65 28 73 65 74 4d 65   ArraySize(setMe
5870: 74 61 36 29 2c 20 73 65 74 4d 65 74 61 36 29 3b  ta6), setMeta6);
5880: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
5890: 65 33 56 64 62 65 43 68 61 6e 67 65 50 31 28 76  e3VdbeChangeP1(v
58a0: 2c 20 69 41 64 64 72 2c 20 69 44 62 29 3b 0a 20  , iAddr, iDb);. 
58b0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
58c0: 56 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20  VdbeChangeP1(v, 
58d0: 69 41 64 64 72 2b 31 2c 20 69 44 62 29 3b 0a 20  iAddr+1, iDb);. 
58e0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
58f0: 56 64 62 65 43 68 61 6e 67 65 50 32 28 76 2c 20  VdbeChangeP2(v, 
5900: 69 41 64 64 72 2b 32 2c 20 69 41 64 64 72 2b 34  iAddr+2, iAddr+4
5910: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  );.          sql
5920: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 31  ite3VdbeChangeP1
5930: 28 76 2c 20 69 41 64 64 72 2b 34 2c 20 65 41 75  (v, iAddr+4, eAu
5940: 74 6f 2d 31 29 3b 0a 20 20 20 20 20 20 20 20 20  to-1);.         
5950: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
5960: 67 65 50 31 28 76 2c 20 69 41 64 64 72 2b 35 2c  geP1(v, iAddr+5,
5970: 20 69 44 62 29 3b 0a 20 20 20 20 20 20 20 20 20   iDb);.         
5980: 20 73 71 6c 69 74 65 33 56 64 62 65 55 73 65 73   sqlite3VdbeUses
5990: 42 74 72 65 65 28 76 2c 20 69 44 62 29 3b 0a 20  Btree(v, iDb);. 
59a0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
59b0: 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 23  .    }.  }else.#
59c0: 65 6e 64 69 66 0a 0a 20 20 2f 2a 0a 20 20 2a 2a  endif..  /*.  **
59d0: 20 20 50 52 41 47 4d 41 20 5b 64 61 74 61 62 61    PRAGMA [databa
59e0: 73 65 2e 5d 69 6e 63 72 65 6d 65 6e 74 61 6c 5f  se.]incremental_
59f0: 76 61 63 75 75 6d 28 4e 29 0a 20 20 2a 2a 0a 20  vacuum(N).  **. 
5a00: 20 2a 2a 20 44 6f 20 4e 20 73 74 65 70 73 20 6f   ** Do N steps o
5a10: 66 20 69 6e 63 72 65 6d 65 6e 74 61 6c 20 76 61  f incremental va
5a20: 63 75 75 6d 69 6e 67 20 6f 6e 20 61 20 64 61 74  cuuming on a dat
5a30: 61 62 61 73 65 2e 0a 20 20 2a 2f 0a 23 69 66 6e  abase..  */.#ifn
5a40: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
5a50: 41 55 54 4f 56 41 43 55 55 4d 0a 20 20 69 66 28  AUTOVACUUM.  if(
5a60: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
5a70: 7a 4c 65 66 74 2c 22 69 6e 63 72 65 6d 65 6e 74  zLeft,"increment
5a80: 61 6c 5f 76 61 63 75 75 6d 22 29 3d 3d 30 20 29  al_vacuum")==0 )
5a90: 7b 0a 20 20 20 20 69 6e 74 20 69 4c 69 6d 69 74  {.    int iLimit
5aa0: 2c 20 61 64 64 72 3b 0a 20 20 20 20 69 66 28 20  , addr;.    if( 
5ab0: 73 71 6c 69 74 65 33 52 65 61 64 53 63 68 65 6d  sqlite3ReadSchem
5ac0: 61 28 70 50 61 72 73 65 29 20 29 7b 0a 20 20 20  a(pParse) ){.   
5ad0: 20 20 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f     goto pragma_o
5ae0: 75 74 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  ut;.    }.    if
5af0: 28 20 7a 52 69 67 68 74 3d 3d 30 20 7c 7c 20 21  ( zRight==0 || !
5b00: 73 71 6c 69 74 65 33 47 65 74 49 6e 74 33 32 28  sqlite3GetInt32(
5b10: 7a 52 69 67 68 74 2c 20 26 69 4c 69 6d 69 74 29  zRight, &iLimit)
5b20: 20 7c 7c 20 69 4c 69 6d 69 74 3c 3d 30 20 29 7b   || iLimit<=0 ){
5b30: 0a 20 20 20 20 20 20 69 4c 69 6d 69 74 20 3d 20  .      iLimit = 
5b40: 30 78 37 66 66 66 66 66 66 66 3b 0a 20 20 20 20  0x7fffffff;.    
5b50: 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 42 65 67  }.    sqlite3Beg
5b60: 69 6e 57 72 69 74 65 4f 70 65 72 61 74 69 6f 6e  inWriteOperation
5b70: 28 70 50 61 72 73 65 2c 20 30 2c 20 69 44 62 29  (pParse, 0, iDb)
5b80: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  ;.    sqlite3Vdb
5b90: 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e  eAddOp2(v, OP_In
5ba0: 74 65 67 65 72 2c 20 69 4c 69 6d 69 74 2c 20 31  teger, iLimit, 1
5bb0: 29 3b 0a 20 20 20 20 61 64 64 72 20 3d 20 73 71  );.    addr = sq
5bc0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 31 28  lite3VdbeAddOp1(
5bd0: 76 2c 20 4f 50 5f 49 6e 63 72 56 61 63 75 75 6d  v, OP_IncrVacuum
5be0: 2c 20 69 44 62 29 3b 0a 20 20 20 20 73 71 6c 69  , iDb);.    sqli
5bf0: 74 65 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c  te3VdbeAddOp1(v,
5c00: 20 4f 50 5f 52 65 73 75 6c 74 52 6f 77 2c 20 31   OP_ResultRow, 1
5c10: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
5c20: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 41  beAddOp2(v, OP_A
5c30: 64 64 49 6d 6d 2c 20 31 2c 20 2d 31 29 3b 0a 20  ddImm, 1, -1);. 
5c40: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
5c50: 64 4f 70 32 28 76 2c 20 4f 50 5f 49 66 50 6f 73  dOp2(v, OP_IfPos
5c60: 2c 20 31 2c 20 61 64 64 72 29 3b 0a 20 20 20 20  , 1, addr);.    
5c70: 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48  sqlite3VdbeJumpH
5c80: 65 72 65 28 76 2c 20 61 64 64 72 29 3b 0a 20 20  ere(v, addr);.  
5c90: 7d 65 6c 73 65 0a 23 65 6e 64 69 66 0a 0a 23 69  }else.#endif..#i
5ca0: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
5cb0: 54 5f 50 41 47 45 52 5f 50 52 41 47 4d 41 53 0a  T_PAGER_PRAGMAS.
5cc0: 20 20 2f 2a 0a 20 20 2a 2a 20 20 50 52 41 47 4d    /*.  **  PRAGM
5cd0: 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 63 61 63  A [database.]cac
5ce0: 68 65 5f 73 69 7a 65 0a 20 20 2a 2a 20 20 50 52  he_size.  **  PR
5cf0: 41 47 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d  AGMA [database.]
5d00: 63 61 63 68 65 5f 73 69 7a 65 3d 4e 0a 20 20 2a  cache_size=N.  *
5d10: 2a 0a 20 20 2a 2a 20 54 68 65 20 66 69 72 73 74  *.  ** The first
5d20: 20 66 6f 72 6d 20 72 65 70 6f 72 74 73 20 74 68   form reports th
5d30: 65 20 63 75 72 72 65 6e 74 20 6c 6f 63 61 6c 20  e current local 
5d40: 73 65 74 74 69 6e 67 20 66 6f 72 20 74 68 65 0a  setting for the.
5d50: 20 20 2a 2a 20 70 61 67 65 20 63 61 63 68 65 20    ** page cache 
5d60: 73 69 7a 65 2e 20 20 54 68 65 20 6c 6f 63 61 6c  size.  The local
5d70: 20 73 65 74 74 69 6e 67 20 63 61 6e 20 62 65 20   setting can be 
5d80: 64 69 66 66 65 72 65 6e 74 20 66 72 6f 6d 0a 20  different from. 
5d90: 20 2a 2a 20 74 68 65 20 70 65 72 73 69 73 74 65   ** the persiste
5da0: 6e 74 20 63 61 63 68 65 20 73 69 7a 65 20 76 61  nt cache size va
5db0: 6c 75 65 20 74 68 61 74 20 69 73 20 73 74 6f 72  lue that is stor
5dc0: 65 64 20 69 6e 20 74 68 65 20 64 61 74 61 62 61  ed in the databa
5dd0: 73 65 0a 20 20 2a 2a 20 66 69 6c 65 20 69 74 73  se.  ** file its
5de0: 65 6c 66 2e 20 20 54 68 65 20 76 61 6c 75 65 20  elf.  The value 
5df0: 72 65 74 75 72 6e 65 64 20 69 73 20 74 68 65 20  returned is the 
5e00: 6d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f  maximum number o
5e10: 66 0a 20 20 2a 2a 20 70 61 67 65 73 20 69 6e 20  f.  ** pages in 
5e20: 74 68 65 20 70 61 67 65 20 63 61 63 68 65 2e 20  the page cache. 
5e30: 20 54 68 65 20 73 65 63 6f 6e 64 20 66 6f 72 6d   The second form
5e40: 20 73 65 74 73 20 74 68 65 20 6c 6f 63 61 6c 0a   sets the local.
5e50: 20 20 2a 2a 20 70 61 67 65 20 63 61 63 68 65 20    ** page cache 
5e60: 73 69 7a 65 20 76 61 6c 75 65 2e 20 20 49 74 20  size value.  It 
5e70: 64 6f 65 73 20 6e 6f 74 20 63 68 61 6e 67 65 20  does not change 
5e80: 74 68 65 20 70 65 72 73 69 73 74 65 6e 74 0a 20  the persistent. 
5e90: 20 2a 2a 20 63 61 63 68 65 20 73 69 7a 65 20 73   ** cache size s
5ea0: 74 6f 72 65 64 20 6f 6e 20 74 68 65 20 64 69 73  tored on the dis
5eb0: 6b 20 73 6f 20 74 68 65 20 63 61 63 68 65 20 73  k so the cache s
5ec0: 69 7a 65 20 77 69 6c 6c 20 72 65 76 65 72 74 0a  ize will revert.
5ed0: 20 20 2a 2a 20 74 6f 20 69 74 73 20 64 65 66 61    ** to its defa
5ee0: 75 6c 74 20 76 61 6c 75 65 20 77 68 65 6e 20 74  ult value when t
5ef0: 68 65 20 64 61 74 61 62 61 73 65 20 69 73 20 63  he database is c
5f00: 6c 6f 73 65 64 20 61 6e 64 20 72 65 6f 70 65 6e  losed and reopen
5f10: 65 64 2e 0a 20 20 2a 2a 20 4e 20 73 68 6f 75 6c  ed..  ** N shoul
5f20: 64 20 62 65 20 61 20 70 6f 73 69 74 69 76 65 20  d be a positive 
5f30: 69 6e 74 65 67 65 72 2e 0a 20 20 2a 2f 0a 20 20  integer..  */.  
5f40: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
5f50: 6d 70 28 7a 4c 65 66 74 2c 22 63 61 63 68 65 5f  mp(zLeft,"cache_
5f60: 73 69 7a 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20  size")==0 ){.   
5f70: 20 69 66 28 20 73 71 6c 69 74 65 33 52 65 61 64   if( sqlite3Read
5f80: 53 63 68 65 6d 61 28 70 50 61 72 73 65 29 20 29  Schema(pParse) )
5f90: 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75 74   goto pragma_out
5fa0: 3b 0a 20 20 20 20 69 66 28 20 21 7a 52 69 67 68  ;.    if( !zRigh
5fb0: 74 20 29 7b 0a 20 20 20 20 20 20 72 65 74 75 72  t ){.      retur
5fc0: 6e 53 69 6e 67 6c 65 49 6e 74 28 70 50 61 72 73  nSingleInt(pPars
5fd0: 65 2c 20 22 63 61 63 68 65 5f 73 69 7a 65 22 2c  e, "cache_size",
5fe0: 20 70 44 62 2d 3e 70 53 63 68 65 6d 61 2d 3e 63   pDb->pSchema->c
5ff0: 61 63 68 65 5f 73 69 7a 65 29 3b 0a 20 20 20 20  ache_size);.    
6000: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74  }else{.      int
6010: 20 73 69 7a 65 20 3d 20 61 74 6f 69 28 7a 52 69   size = atoi(zRi
6020: 67 68 74 29 3b 0a 20 20 20 20 20 20 69 66 28 20  ght);.      if( 
6030: 73 69 7a 65 3c 30 20 29 20 73 69 7a 65 20 3d 20  size<0 ) size = 
6040: 2d 73 69 7a 65 3b 0a 20 20 20 20 20 20 70 44 62  -size;.      pDb
6050: 2d 3e 70 53 63 68 65 6d 61 2d 3e 63 61 63 68 65  ->pSchema->cache
6060: 5f 73 69 7a 65 20 3d 20 73 69 7a 65 3b 0a 20 20  _size = size;.  
6070: 20 20 20 20 73 71 6c 69 74 65 33 42 74 72 65 65      sqlite3Btree
6080: 53 65 74 43 61 63 68 65 53 69 7a 65 28 70 44 62  SetCacheSize(pDb
6090: 2d 3e 70 42 74 2c 20 70 44 62 2d 3e 70 53 63 68  ->pBt, pDb->pSch
60a0: 65 6d 61 2d 3e 63 61 63 68 65 5f 73 69 7a 65 29  ema->cache_size)
60b0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a  ;.    }.  }else.
60c0: 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20 50 52 41  .  /*.  **   PRA
60d0: 47 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 0a 20  GMA temp_store. 
60e0: 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 74 65 6d   **   PRAGMA tem
60f0: 70 5f 73 74 6f 72 65 20 3d 20 22 64 65 66 61 75  p_store = "defau
6100: 6c 74 22 7c 22 6d 65 6d 6f 72 79 22 7c 22 66 69  lt"|"memory"|"fi
6110: 6c 65 22 0a 20 20 2a 2a 0a 20 20 2a 2a 20 52 65  le".  **.  ** Re
6120: 74 75 72 6e 20 6f 72 20 73 65 74 20 74 68 65 20  turn or set the 
6130: 6c 6f 63 61 6c 20 76 61 6c 75 65 20 6f 66 20 74  local value of t
6140: 68 65 20 74 65 6d 70 5f 73 74 6f 72 65 20 66 6c  he temp_store fl
6150: 61 67 2e 20 20 43 68 61 6e 67 69 6e 67 0a 20 20  ag.  Changing.  
6160: 2a 2a 20 74 68 65 20 6c 6f 63 61 6c 20 76 61 6c  ** the local val
6170: 75 65 20 64 6f 65 73 20 6e 6f 74 20 6d 61 6b 65  ue does not make
6180: 20 63 68 61 6e 67 65 73 20 74 6f 20 74 68 65 20   changes to the 
6190: 64 69 73 6b 20 66 69 6c 65 20 61 6e 64 20 74 68  disk file and th
61a0: 65 20 64 65 66 61 75 6c 74 0a 20 20 2a 2a 20 76  e default.  ** v
61b0: 61 6c 75 65 20 77 69 6c 6c 20 62 65 20 72 65 73  alue will be res
61c0: 74 6f 72 65 64 20 74 68 65 20 6e 65 78 74 20 74  tored the next t
61d0: 69 6d 65 20 74 68 65 20 64 61 74 61 62 61 73 65  ime the database
61e0: 20 69 73 20 6f 70 65 6e 65 64 2e 0a 20 20 2a 2a   is opened..  **
61f0: 0a 20 20 2a 2a 20 4e 6f 74 65 20 74 68 61 74 20  .  ** Note that 
6200: 69 74 20 69 73 20 70 6f 73 73 69 62 6c 65 20 66  it is possible f
6210: 6f 72 20 74 68 65 20 6c 69 62 72 61 72 79 20 63  or the library c
6220: 6f 6d 70 69 6c 65 2d 74 69 6d 65 20 6f 70 74 69  ompile-time opti
6230: 6f 6e 73 20 74 6f 0a 20 20 2a 2a 20 6f 76 65 72  ons to.  ** over
6240: 72 69 64 65 20 74 68 69 73 20 73 65 74 74 69 6e  ride this settin
6250: 67 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c  g.  */.  if( sql
6260: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
6270: 74 2c 20 22 74 65 6d 70 5f 73 74 6f 72 65 22 29  t, "temp_store")
6280: 3d 3d 30 20 29 7b 0a 20 20 20 20 69 66 28 20 21  ==0 ){.    if( !
6290: 7a 52 69 67 68 74 20 29 7b 0a 20 20 20 20 20 20  zRight ){.      
62a0: 72 65 74 75 72 6e 53 69 6e 67 6c 65 49 6e 74 28  returnSingleInt(
62b0: 70 50 61 72 73 65 2c 20 22 74 65 6d 70 5f 73 74  pParse, "temp_st
62c0: 6f 72 65 22 2c 20 64 62 2d 3e 74 65 6d 70 5f 73  ore", db->temp_s
62d0: 74 6f 72 65 29 3b 0a 20 20 20 20 7d 65 6c 73 65  tore);.    }else
62e0: 7b 0a 20 20 20 20 20 20 63 68 61 6e 67 65 54 65  {.      changeTe
62f0: 6d 70 53 74 6f 72 61 67 65 28 70 50 61 72 73 65  mpStorage(pParse
6300: 2c 20 7a 52 69 67 68 74 29 3b 0a 20 20 20 20 7d  , zRight);.    }
6310: 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 2f 2a 0a 20  .  }else..  /*. 
6320: 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 74 65 6d   **   PRAGMA tem
6330: 70 5f 73 74 6f 72 65 5f 64 69 72 65 63 74 6f 72  p_store_director
6340: 79 0a 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20  y.  **   PRAGMA 
6350: 74 65 6d 70 5f 73 74 6f 72 65 5f 64 69 72 65 63  temp_store_direc
6360: 74 6f 72 79 20 3d 20 22 22 7c 22 64 69 72 65 63  tory = ""|"direc
6370: 74 6f 72 79 5f 6e 61 6d 65 22 0a 20 20 2a 2a 0a  tory_name".  **.
6380: 20 20 2a 2a 20 52 65 74 75 72 6e 20 6f 72 20 73    ** Return or s
6390: 65 74 20 74 68 65 20 6c 6f 63 61 6c 20 76 61 6c  et the local val
63a0: 75 65 20 6f 66 20 74 68 65 20 74 65 6d 70 5f 73  ue of the temp_s
63b0: 74 6f 72 65 5f 64 69 72 65 63 74 6f 72 79 20 66  tore_directory f
63c0: 6c 61 67 2e 20 20 43 68 61 6e 67 69 6e 67 0a 20  lag.  Changing. 
63d0: 20 2a 2a 20 74 68 65 20 76 61 6c 75 65 20 73 65   ** the value se
63e0: 74 73 20 61 20 73 70 65 63 69 66 69 63 20 64 69  ts a specific di
63f0: 72 65 63 74 6f 72 79 20 74 6f 20 62 65 20 75 73  rectory to be us
6400: 65 64 20 66 6f 72 20 74 65 6d 70 6f 72 61 72 79  ed for temporary
6410: 20 66 69 6c 65 73 2e 0a 20 20 2a 2a 20 53 65 74   files..  ** Set
6420: 74 69 6e 67 20 74 6f 20 61 20 6e 75 6c 6c 20 73  ting to a null s
6430: 74 72 69 6e 67 20 72 65 76 65 72 74 73 20 74 6f  tring reverts to
6440: 20 74 68 65 20 64 65 66 61 75 6c 74 20 74 65 6d   the default tem
6450: 70 6f 72 61 72 79 20 64 69 72 65 63 74 6f 72 79  porary directory
6460: 20 73 65 61 72 63 68 2e 0a 20 20 2a 2a 20 49 66   search..  ** If
6470: 20 74 65 6d 70 6f 72 61 72 79 20 64 69 72 65 63   temporary direc
6480: 74 6f 72 79 20 69 73 20 63 68 61 6e 67 65 64 2c  tory is changed,
6490: 20 74 68 65 6e 20 69 6e 76 61 6c 69 64 61 74 65   then invalidate
64a0: 54 65 6d 70 53 74 6f 72 61 67 65 2e 0a 20 20 2a  TempStorage..  *
64b0: 2a 0a 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c  *.  */.  if( sql
64c0: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
64d0: 74 2c 20 22 74 65 6d 70 5f 73 74 6f 72 65 5f 64  t, "temp_store_d
64e0: 69 72 65 63 74 6f 72 79 22 29 3d 3d 30 20 29 7b  irectory")==0 ){
64f0: 0a 20 20 20 20 69 66 28 20 21 7a 52 69 67 68 74  .    if( !zRight
6500: 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20 73 71   ){.      if( sq
6510: 6c 69 74 65 33 5f 74 65 6d 70 5f 64 69 72 65 63  lite3_temp_direc
6520: 74 6f 72 79 20 29 7b 0a 20 20 20 20 20 20 20 20  tory ){.        
6530: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75  sqlite3VdbeSetNu
6540: 6d 43 6f 6c 73 28 76 2c 20 31 29 3b 0a 20 20 20  mCols(v, 1);.   
6550: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
6560: 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 30 2c  SetColName(v, 0,
6570: 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 0a   COLNAME_NAME, .
6580: 20 20 20 20 20 20 20 20 20 20 20 20 22 74 65 6d              "tem
6590: 70 5f 73 74 6f 72 65 5f 64 69 72 65 63 74 6f 72  p_store_director
65a0: 79 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49  y", SQLITE_STATI
65b0: 43 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  C);.        sqli
65c0: 74 65 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c  te3VdbeAddOp4(v,
65d0: 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20   OP_String8, 0, 
65e0: 31 2c 20 30 2c 20 73 71 6c 69 74 65 33 5f 74 65  1, 0, sqlite3_te
65f0: 6d 70 5f 64 69 72 65 63 74 6f 72 79 2c 20 30 29  mp_directory, 0)
6600: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
6610: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
6620: 50 5f 52 65 73 75 6c 74 52 6f 77 2c 20 31 2c 20  P_ResultRow, 1, 
6630: 31 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  1);.      }.    
6640: 7d 65 6c 73 65 7b 0a 23 69 66 6e 64 65 66 20 53  }else{.#ifndef S
6650: 51 4c 49 54 45 5f 4f 4d 49 54 5f 57 53 44 0a 20  QLITE_OMIT_WSD. 
6660: 20 20 20 20 20 69 66 28 20 7a 52 69 67 68 74 5b       if( zRight[
6670: 30 5d 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e  0] ){.        in
6680: 74 20 72 63 3b 0a 20 20 20 20 20 20 20 20 69 6e  t rc;.        in
6690: 74 20 72 65 73 3b 0a 20 20 20 20 20 20 20 20 72  t res;.        r
66a0: 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 41 63 63  c = sqlite3OsAcc
66b0: 65 73 73 28 64 62 2d 3e 70 56 66 73 2c 20 7a 52  ess(db->pVfs, zR
66c0: 69 67 68 74 2c 20 53 51 4c 49 54 45 5f 41 43 43  ight, SQLITE_ACC
66d0: 45 53 53 5f 52 45 41 44 57 52 49 54 45 2c 20 26  ESS_READWRITE, &
66e0: 72 65 73 29 3b 0a 20 20 20 20 20 20 20 20 69 66  res);.        if
66f0: 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc!=SQLITE_OK 
6700: 7c 7c 20 72 65 73 3d 3d 30 20 29 7b 0a 20 20 20  || res==0 ){.   
6710: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72         sqlite3Er
6720: 72 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22  rorMsg(pParse, "
6730: 6e 6f 74 20 61 20 77 72 69 74 61 62 6c 65 20 64  not a writable d
6740: 69 72 65 63 74 6f 72 79 22 29 3b 0a 20 20 20 20  irectory");.    
6750: 20 20 20 20 20 20 67 6f 74 6f 20 70 72 61 67 6d        goto pragm
6760: 61 5f 6f 75 74 3b 0a 20 20 20 20 20 20 20 20 7d  a_out;.        }
6770: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69  .      }.      i
6780: 66 28 20 53 51 4c 49 54 45 5f 54 45 4d 50 5f 53  f( SQLITE_TEMP_S
6790: 54 4f 52 45 3d 3d 30 0a 20 20 20 20 20 20 20 7c  TORE==0.       |
67a0: 7c 20 28 53 51 4c 49 54 45 5f 54 45 4d 50 5f 53  | (SQLITE_TEMP_S
67b0: 54 4f 52 45 3d 3d 31 20 26 26 20 64 62 2d 3e 74  TORE==1 && db->t
67c0: 65 6d 70 5f 73 74 6f 72 65 3c 3d 31 29 0a 20 20  emp_store<=1).  
67d0: 20 20 20 20 20 7c 7c 20 28 53 51 4c 49 54 45 5f       || (SQLITE_
67e0: 54 45 4d 50 5f 53 54 4f 52 45 3d 3d 32 20 26 26  TEMP_STORE==2 &&
67f0: 20 64 62 2d 3e 74 65 6d 70 5f 73 74 6f 72 65 3d   db->temp_store=
6800: 3d 31 29 0a 20 20 20 20 20 20 29 7b 0a 20 20 20  =1).      ){.   
6810: 20 20 20 20 20 69 6e 76 61 6c 69 64 61 74 65 54       invalidateT
6820: 65 6d 70 53 74 6f 72 61 67 65 28 70 50 61 72 73  empStorage(pPars
6830: 65 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  e);.      }.    
6840: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 73    sqlite3_free(s
6850: 71 6c 69 74 65 33 5f 74 65 6d 70 5f 64 69 72 65  qlite3_temp_dire
6860: 63 74 6f 72 79 29 3b 0a 20 20 20 20 20 20 69 66  ctory);.      if
6870: 28 20 7a 52 69 67 68 74 5b 30 5d 20 29 7b 0a 20  ( zRight[0] ){. 
6880: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 74         sqlite3_t
6890: 65 6d 70 5f 64 69 72 65 63 74 6f 72 79 20 3d 20  emp_directory = 
68a0: 73 71 6c 69 74 65 33 44 62 53 74 72 44 75 70 28  sqlite3DbStrDup(
68b0: 30 2c 20 7a 52 69 67 68 74 29 3b 0a 20 20 20 20  0, zRight);.    
68c0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20    }else{.       
68d0: 20 73 71 6c 69 74 65 33 5f 74 65 6d 70 5f 64 69   sqlite3_temp_di
68e0: 72 65 63 74 6f 72 79 20 3d 20 30 3b 0a 20 20 20  rectory = 0;.   
68f0: 20 20 20 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 53     }.#endif /* S
6900: 51 4c 49 54 45 5f 4f 4d 49 54 5f 57 53 44 20 2a  QLITE_OMIT_WSD *
6910: 2f 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a  /.    }.  }else.
6920: 0a 23 69 66 20 21 64 65 66 69 6e 65 64 28 53 51  .#if !defined(SQ
6930: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 4c 4f 43 4b  LITE_ENABLE_LOCK
6940: 49 4e 47 5f 53 54 59 4c 45 29 0a 23 20 20 69 66  ING_STYLE).#  if
6950: 20 64 65 66 69 6e 65 64 28 5f 5f 41 50 50 4c 45   defined(__APPLE
6960: 5f 5f 29 0a 23 20 20 20 20 64 65 66 69 6e 65 20  __).#    define 
6970: 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 4c 4f  SQLITE_ENABLE_LO
6980: 43 4b 49 4e 47 5f 53 54 59 4c 45 20 31 0a 23 20  CKING_STYLE 1.# 
6990: 20 65 6c 73 65 0a 23 20 20 20 20 64 65 66 69 6e   else.#    defin
69a0: 65 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f  e SQLITE_ENABLE_
69b0: 4c 4f 43 4b 49 4e 47 5f 53 54 59 4c 45 20 30 0a  LOCKING_STYLE 0.
69c0: 23 20 20 65 6e 64 69 66 0a 23 65 6e 64 69 66 0a  #  endif.#endif.
69d0: 23 69 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c  #if SQLITE_ENABL
69e0: 45 5f 4c 4f 43 4b 49 4e 47 5f 53 54 59 4c 45 0a  E_LOCKING_STYLE.
69f0: 20 20 2f 2a 0a 20 20 20 2a 2a 20 20 20 50 52 41    /*.   **   PRA
6a00: 47 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 6c  GMA [database.]l
6a10: 6f 63 6b 5f 70 72 6f 78 79 5f 66 69 6c 65 0a 20  ock_proxy_file. 
6a20: 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 5b 64    **   PRAGMA [d
6a30: 61 74 61 62 61 73 65 2e 5d 6c 6f 63 6b 5f 70 72  atabase.]lock_pr
6a40: 6f 78 79 5f 66 69 6c 65 20 3d 20 22 3a 61 75 74  oxy_file = ":aut
6a50: 6f 3a 22 7c 22 6c 6f 63 6b 5f 66 69 6c 65 5f 70  o:"|"lock_file_p
6a60: 61 74 68 22 0a 20 20 20 2a 2a 0a 20 20 20 2a 2a  ath".   **.   **
6a70: 20 52 65 74 75 72 6e 20 6f 72 20 73 65 74 20 74   Return or set t
6a80: 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20  he value of the 
6a90: 6c 6f 63 6b 5f 70 72 6f 78 79 5f 66 69 6c 65 20  lock_proxy_file 
6aa0: 66 6c 61 67 2e 20 20 43 68 61 6e 67 69 6e 67 0a  flag.  Changing.
6ab0: 20 20 20 2a 2a 20 74 68 65 20 76 61 6c 75 65 20     ** the value 
6ac0: 73 65 74 73 20 61 20 73 70 65 63 69 66 69 63 20  sets a specific 
6ad0: 66 69 6c 65 20 74 6f 20 62 65 20 75 73 65 64 20  file to be used 
6ae0: 66 6f 72 20 64 61 74 61 62 61 73 65 20 61 63 63  for database acc
6af0: 65 73 73 20 6c 6f 63 6b 73 2e 0a 20 20 20 2a 2a  ess locks..   **
6b00: 0a 20 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c  .   */.  if( sql
6b10: 69 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66  ite3StrICmp(zLef
6b20: 74 2c 20 22 6c 6f 63 6b 5f 70 72 6f 78 79 5f 66  t, "lock_proxy_f
6b30: 69 6c 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ile")==0 ){.    
6b40: 69 66 28 20 21 7a 52 69 67 68 74 20 29 7b 0a 20  if( !zRight ){. 
6b50: 20 20 20 20 20 50 61 67 65 72 20 2a 70 50 61 67       Pager *pPag
6b60: 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65  er = sqlite3Btre
6b70: 65 50 61 67 65 72 28 70 44 62 2d 3e 70 42 74 29  ePager(pDb->pBt)
6b80: 3b 0a 20 20 20 20 20 20 63 68 61 72 20 2a 70 72  ;.      char *pr
6b90: 6f 78 79 5f 66 69 6c 65 5f 70 61 74 68 20 3d 20  oxy_file_path = 
6ba0: 4e 55 4c 4c 3b 0a 20 20 20 20 20 20 73 71 6c 69  NULL;.      sqli
6bb0: 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 20  te3_file *pFile 
6bc0: 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 46 69  = sqlite3PagerFi
6bd0: 6c 65 28 70 50 61 67 65 72 29 3b 0a 20 20 20 20  le(pPager);.    
6be0: 20 20 73 71 6c 69 74 65 33 4f 73 46 69 6c 65 43    sqlite3OsFileC
6bf0: 6f 6e 74 72 6f 6c 28 70 46 69 6c 65 2c 20 53 51  ontrol(pFile, SQ
6c00: 4c 49 54 45 5f 47 45 54 5f 4c 4f 43 4b 50 52 4f  LITE_GET_LOCKPRO
6c10: 58 59 46 49 4c 45 2c 20 0a 20 20 20 20 20 20 20  XYFILE, .       
6c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6c30: 20 20 20 20 26 70 72 6f 78 79 5f 66 69 6c 65 5f      &proxy_file_
6c40: 70 61 74 68 29 3b 0a 20 20 20 20 20 20 0a 20 20  path);.      .  
6c50: 20 20 20 20 69 66 28 20 70 72 6f 78 79 5f 66 69      if( proxy_fi
6c60: 6c 65 5f 70 61 74 68 20 29 7b 0a 20 20 20 20 20  le_path ){.     
6c70: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65     sqlite3VdbeSe
6c80: 74 4e 75 6d 43 6f 6c 73 28 76 2c 20 31 29 3b 0a  tNumCols(v, 1);.
6c90: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
6ca0: 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c  dbeSetColName(v,
6cb0: 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45   0, COLNAME_NAME
6cc0: 2c 20 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  , .             
6cd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6ce0: 20 22 6c 6f 63 6b 5f 70 72 6f 78 79 5f 66 69 6c   "lock_proxy_fil
6cf0: 65 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49  e", SQLITE_STATI
6d00: 43 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  C);.        sqli
6d10: 74 65 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c  te3VdbeAddOp4(v,
6d20: 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20   OP_String8, 0, 
6d30: 31 2c 20 30 2c 20 70 72 6f 78 79 5f 66 69 6c 65  1, 0, proxy_file
6d40: 5f 70 61 74 68 2c 20 30 29 3b 0a 20 20 20 20 20  _path, 0);.     
6d50: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
6d60: 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73 75 6c  dOp2(v, OP_Resul
6d70: 74 52 6f 77 2c 20 31 2c 20 31 29 3b 0a 20 20 20  tRow, 1, 1);.   
6d80: 20 20 20 7d 0a 20 20 20 20 7d 65 6c 73 65 7b 0a     }.    }else{.
6d90: 20 20 20 20 20 20 50 61 67 65 72 20 2a 70 50 61        Pager *pPa
6da0: 67 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74 72  ger = sqlite3Btr
6db0: 65 65 50 61 67 65 72 28 70 44 62 2d 3e 70 42 74  eePager(pDb->pBt
6dc0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
6dd0: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 20 3d 20 73  _file *pFile = s
6de0: 71 6c 69 74 65 33 50 61 67 65 72 46 69 6c 65 28  qlite3PagerFile(
6df0: 70 50 61 67 65 72 29 3b 0a 20 20 20 20 20 20 69  pPager);.      i
6e00: 6e 74 20 72 65 73 3b 0a 20 20 20 20 20 20 69 66  nt res;.      if
6e10: 28 20 7a 52 69 67 68 74 5b 30 5d 20 29 7b 0a 20  ( zRight[0] ){. 
6e20: 20 20 20 20 20 20 20 72 65 73 3d 73 71 6c 69 74         res=sqlit
6e30: 65 33 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c 28  e3OsFileControl(
6e40: 70 46 69 6c 65 2c 20 53 51 4c 49 54 45 5f 53 45  pFile, SQLITE_SE
6e50: 54 5f 4c 4f 43 4b 50 52 4f 58 59 46 49 4c 45 2c  T_LOCKPROXYFILE,
6e60: 20 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20   .              
6e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6e80: 20 20 20 20 20 20 20 7a 52 69 67 68 74 29 3b 0a         zRight);.
6e90: 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a 20        } else {. 
6ea0: 20 20 20 20 20 20 20 72 65 73 3d 73 71 6c 69 74         res=sqlit
6eb0: 65 33 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c 28  e3OsFileControl(
6ec0: 70 46 69 6c 65 2c 20 53 51 4c 49 54 45 5f 53 45  pFile, SQLITE_SE
6ed0: 54 5f 4c 4f 43 4b 50 52 4f 58 59 46 49 4c 45 2c  T_LOCKPROXYFILE,
6ee0: 20 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20   .              
6ef0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6f00: 20 20 20 20 20 20 20 4e 55 4c 4c 29 3b 0a 20 20         NULL);.  
6f10: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
6f20: 72 65 73 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29  res!=SQLITE_OK )
6f30: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
6f40: 33 45 72 72 6f 72 4d 73 67 28 70 50 61 72 73 65  3ErrorMsg(pParse
6f50: 2c 20 22 66 61 69 6c 65 64 20 74 6f 20 73 65 74  , "failed to set
6f60: 20 6c 6f 63 6b 20 70 72 6f 78 79 20 66 69 6c 65   lock proxy file
6f70: 22 29 3b 0a 20 20 20 20 20 20 20 20 67 6f 74 6f  ");.        goto
6f80: 20 70 72 61 67 6d 61 5f 6f 75 74 3b 0a 20 20 20   pragma_out;.   
6f90: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 65 6c     }.    }.  }el
6fa0: 73 65 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c  se.#endif /* SQL
6fb0: 49 54 45 5f 45 4e 41 42 4c 45 5f 4c 4f 43 4b 49  ITE_ENABLE_LOCKI
6fc0: 4e 47 5f 53 54 59 4c 45 20 2a 2f 20 20 20 20 20  NG_STYLE */     
6fd0: 20 0a 20 20 20 20 0a 20 20 2f 2a 0a 20 20 2a 2a   .    .  /*.  **
6fe0: 20 20 20 50 52 41 47 4d 41 20 5b 64 61 74 61 62     PRAGMA [datab
6ff0: 61 73 65 2e 5d 73 79 6e 63 68 72 6f 6e 6f 75 73  ase.]synchronous
7000: 0a 20 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 5b  .  **   PRAGMA [
7010: 64 61 74 61 62 61 73 65 2e 5d 73 79 6e 63 68 72  database.]synchr
7020: 6f 6e 6f 75 73 3d 4f 46 46 7c 4f 4e 7c 4e 4f 52  onous=OFF|ON|NOR
7030: 4d 41 4c 7c 46 55 4c 4c 0a 20 20 2a 2a 0a 20 20  MAL|FULL.  **.  
7040: 2a 2a 20 52 65 74 75 72 6e 20 6f 72 20 73 65 74  ** Return or set
7050: 20 74 68 65 20 6c 6f 63 61 6c 20 76 61 6c 75 65   the local value
7060: 20 6f 66 20 74 68 65 20 73 79 6e 63 68 72 6f 6e   of the synchron
7070: 6f 75 73 20 66 6c 61 67 2e 20 20 43 68 61 6e 67  ous flag.  Chang
7080: 69 6e 67 0a 20 20 2a 2a 20 74 68 65 20 6c 6f 63  ing.  ** the loc
7090: 61 6c 20 76 61 6c 75 65 20 64 6f 65 73 20 6e 6f  al value does no
70a0: 74 20 6d 61 6b 65 20 63 68 61 6e 67 65 73 20 74  t make changes t
70b0: 6f 20 74 68 65 20 64 69 73 6b 20 66 69 6c 65 20  o the disk file 
70c0: 61 6e 64 20 74 68 65 0a 20 20 2a 2a 20 64 65 66  and the.  ** def
70d0: 61 75 6c 74 20 76 61 6c 75 65 20 77 69 6c 6c 20  ault value will 
70e0: 62 65 20 72 65 73 74 6f 72 65 64 20 74 68 65 20  be restored the 
70f0: 6e 65 78 74 20 74 69 6d 65 20 74 68 65 20 64 61  next time the da
7100: 74 61 62 61 73 65 20 69 73 0a 20 20 2a 2a 20 6f  tabase is.  ** o
7110: 70 65 6e 65 64 2e 0a 20 20 2a 2f 0a 20 20 69 66  pened..  */.  if
7120: 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70  ( sqlite3StrICmp
7130: 28 7a 4c 65 66 74 2c 22 73 79 6e 63 68 72 6f 6e  (zLeft,"synchron
7140: 6f 75 73 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ous")==0 ){.    
7150: 69 66 28 20 73 71 6c 69 74 65 33 52 65 61 64 53  if( sqlite3ReadS
7160: 63 68 65 6d 61 28 70 50 61 72 73 65 29 20 29 20  chema(pParse) ) 
7170: 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75 74 3b  goto pragma_out;
7180: 0a 20 20 20 20 69 66 28 20 21 7a 52 69 67 68 74  .    if( !zRight
7190: 20 29 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e   ){.      return
71a0: 53 69 6e 67 6c 65 49 6e 74 28 70 50 61 72 73 65  SingleInt(pParse
71b0: 2c 20 22 73 79 6e 63 68 72 6f 6e 6f 75 73 22 2c  , "synchronous",
71c0: 20 70 44 62 2d 3e 73 61 66 65 74 79 5f 6c 65 76   pDb->safety_lev
71d0: 65 6c 2d 31 29 3b 0a 20 20 20 20 7d 65 6c 73 65  el-1);.    }else
71e0: 7b 0a 20 20 20 20 20 20 69 66 28 20 21 64 62 2d  {.      if( !db-
71f0: 3e 61 75 74 6f 43 6f 6d 6d 69 74 20 29 7b 0a 20  >autoCommit ){. 
7200: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72         sqlite3Er
7210: 72 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20 0a  rorMsg(pParse, .
7220: 20 20 20 20 20 20 20 20 20 20 20 20 22 53 61 66              "Saf
7230: 65 74 79 20 6c 65 76 65 6c 20 6d 61 79 20 6e 6f  ety level may no
7240: 74 20 62 65 20 63 68 61 6e 67 65 64 20 69 6e 73  t be changed ins
7250: 69 64 65 20 61 20 74 72 61 6e 73 61 63 74 69 6f  ide a transactio
7260: 6e 22 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  n");.      }else
7270: 7b 0a 20 20 20 20 20 20 20 20 70 44 62 2d 3e 73  {.        pDb->s
7280: 61 66 65 74 79 5f 6c 65 76 65 6c 20 3d 20 67 65  afety_level = ge
7290: 74 53 61 66 65 74 79 4c 65 76 65 6c 28 7a 52 69  tSafetyLevel(zRi
72a0: 67 68 74 29 2b 31 3b 0a 20 20 20 20 20 20 7d 0a  ght)+1;.      }.
72b0: 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 23 65      }.  }else.#e
72c0: 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f  ndif /* SQLITE_O
72d0: 4d 49 54 5f 50 41 47 45 52 5f 50 52 41 47 4d 41  MIT_PAGER_PRAGMA
72e0: 53 20 2a 2f 0a 0a 23 69 66 6e 64 65 66 20 53 51  S */..#ifndef SQ
72f0: 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50  LITE_OMIT_FLAG_P
7300: 52 41 47 4d 41 53 0a 20 20 69 66 28 20 66 6c 61  RAGMAS.  if( fla
7310: 67 50 72 61 67 6d 61 28 70 50 61 72 73 65 2c 20  gPragma(pParse, 
7320: 7a 4c 65 66 74 2c 20 7a 52 69 67 68 74 29 20 29  zLeft, zRight) )
7330: 7b 0a 20 20 20 20 2f 2a 20 54 68 65 20 66 6c 61  {.    /* The fla
7340: 67 50 72 61 67 6d 61 28 29 20 73 75 62 72 6f 75  gPragma() subrou
7350: 74 69 6e 65 20 61 6c 73 6f 20 67 65 6e 65 72 61  tine also genera
7360: 74 65 73 20 61 6e 79 20 6e 65 63 65 73 73 61 72  tes any necessar
7370: 79 20 63 6f 64 65 0a 20 20 20 20 2a 2a 20 74 68  y code.    ** th
7380: 65 72 65 20 69 73 20 6e 6f 74 68 69 6e 67 20 6d  ere is nothing m
7390: 6f 72 65 20 74 6f 20 64 6f 20 68 65 72 65 20 2a  ore to do here *
73a0: 2f 0a 20 20 7d 65 6c 73 65 0a 23 65 6e 64 69 66  /.  }else.#endif
73b0: 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f   /* SQLITE_OMIT_
73c0: 46 4c 41 47 5f 50 52 41 47 4d 41 53 20 2a 2f 0a  FLAG_PRAGMAS */.
73d0: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
73e0: 4f 4d 49 54 5f 53 43 48 45 4d 41 5f 50 52 41 47  OMIT_SCHEMA_PRAG
73f0: 4d 41 53 0a 20 20 2f 2a 0a 20 20 2a 2a 20 20 20  MAS.  /*.  **   
7400: 50 52 41 47 4d 41 20 74 61 62 6c 65 5f 69 6e 66  PRAGMA table_inf
7410: 6f 28 3c 74 61 62 6c 65 3e 29 0a 20 20 2a 2a 0a  o(<table>).  **.
7420: 20 20 2a 2a 20 52 65 74 75 72 6e 20 61 20 73 69    ** Return a si
7430: 6e 67 6c 65 20 72 6f 77 20 66 6f 72 20 65 61 63  ngle row for eac
7440: 68 20 63 6f 6c 75 6d 6e 20 6f 66 20 74 68 65 20  h column of the 
7450: 6e 61 6d 65 64 20 74 61 62 6c 65 2e 20 54 68 65  named table. The
7460: 20 63 6f 6c 75 6d 6e 73 20 6f 66 0a 20 20 2a 2a   columns of.  **
7470: 20 74 68 65 20 72 65 74 75 72 6e 65 64 20 64 61   the returned da
7480: 74 61 20 73 65 74 20 61 72 65 3a 0a 20 20 2a 2a  ta set are:.  **
7490: 0a 20 20 2a 2a 20 63 69 64 3a 20 20 20 20 20 20  .  ** cid:      
74a0: 20 20 43 6f 6c 75 6d 6e 20 69 64 20 28 6e 75 6d    Column id (num
74b0: 62 65 72 65 64 20 66 72 6f 6d 20 6c 65 66 74 20  bered from left 
74c0: 74 6f 20 72 69 67 68 74 2c 20 73 74 61 72 74 69  to right, starti
74d0: 6e 67 20 61 74 20 30 29 0a 20 20 2a 2a 20 6e 61  ng at 0).  ** na
74e0: 6d 65 3a 20 20 20 20 20 20 20 43 6f 6c 75 6d 6e  me:       Column
74f0: 20 6e 61 6d 65 0a 20 20 2a 2a 20 74 79 70 65 3a   name.  ** type:
7500: 20 20 20 20 20 20 20 43 6f 6c 75 6d 6e 20 64 65         Column de
7510: 63 6c 61 72 61 74 69 6f 6e 20 74 79 70 65 2e 0a  claration type..
7520: 20 20 2a 2a 20 6e 6f 74 6e 75 6c 6c 3a 20 20 20    ** notnull:   
7530: 20 54 72 75 65 20 69 66 20 27 4e 4f 54 20 4e 55   True if 'NOT NU
7540: 4c 4c 27 20 69 73 20 70 61 72 74 20 6f 66 20 63  LL' is part of c
7550: 6f 6c 75 6d 6e 20 64 65 63 6c 61 72 61 74 69 6f  olumn declaratio
7560: 6e 0a 20 20 2a 2a 20 64 66 6c 74 5f 76 61 6c 75  n.  ** dflt_valu
7570: 65 3a 20 54 68 65 20 64 65 66 61 75 6c 74 20 76  e: The default v
7580: 61 6c 75 65 20 66 6f 72 20 74 68 65 20 63 6f 6c  alue for the col
7590: 75 6d 6e 2c 20 69 66 20 61 6e 79 2e 0a 20 20 2a  umn, if any..  *
75a0: 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 53  /.  if( sqlite3S
75b0: 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 74  trICmp(zLeft, "t
75c0: 61 62 6c 65 5f 69 6e 66 6f 22 29 3d 3d 30 20 26  able_info")==0 &
75d0: 26 20 7a 52 69 67 68 74 20 29 7b 0a 20 20 20 20  & zRight ){.    
75e0: 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a 20 20 20  Table *pTab;.   
75f0: 20 69 66 28 20 73 71 6c 69 74 65 33 52 65 61 64   if( sqlite3Read
7600: 53 63 68 65 6d 61 28 70 50 61 72 73 65 29 20 29  Schema(pParse) )
7610: 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f 75 74   goto pragma_out
7620: 3b 0a 20 20 20 20 70 54 61 62 20 3d 20 73 71 6c  ;.    pTab = sql
7630: 69 74 65 33 46 69 6e 64 54 61 62 6c 65 28 64 62  ite3FindTable(db
7640: 2c 20 7a 52 69 67 68 74 2c 20 7a 44 62 29 3b 0a  , zRight, zDb);.
7650: 20 20 20 20 69 66 28 20 70 54 61 62 20 29 7b 0a      if( pTab ){.
7660: 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20 20 20        int i;.   
7670: 20 20 20 69 6e 74 20 6e 48 69 64 64 65 6e 20 3d     int nHidden =
7680: 20 30 3b 0a 20 20 20 20 20 20 43 6f 6c 75 6d 6e   0;.      Column
7690: 20 2a 70 43 6f 6c 3b 0a 20 20 20 20 20 20 73 71   *pCol;.      sq
76a0: 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75 6d 43  lite3VdbeSetNumC
76b0: 6f 6c 73 28 76 2c 20 36 29 3b 0a 20 20 20 20 20  ols(v, 6);.     
76c0: 20 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20 3d 20   pParse->nMem = 
76d0: 36 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  6;.      sqlite3
76e0: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
76f0: 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 0, COLNAME_NAM
7700: 45 2c 20 22 63 69 64 22 2c 20 53 51 4c 49 54 45  E, "cid", SQLITE
7710: 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20  _STATIC);.      
7720: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f  sqlite3VdbeSetCo
7730: 6c 4e 61 6d 65 28 76 2c 20 31 2c 20 43 4f 4c 4e  lName(v, 1, COLN
7740: 41 4d 45 5f 4e 41 4d 45 2c 20 22 6e 61 6d 65 22  AME_NAME, "name"
7750: 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29  , SQLITE_STATIC)
7760: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
7770: 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c  dbeSetColName(v,
7780: 20 32 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45   2, COLNAME_NAME
7790: 2c 20 22 74 79 70 65 22 2c 20 53 51 4c 49 54 45  , "type", SQLITE
77a0: 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20  _STATIC);.      
77b0: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f  sqlite3VdbeSetCo
77c0: 6c 4e 61 6d 65 28 76 2c 20 33 2c 20 43 4f 4c 4e  lName(v, 3, COLN
77d0: 41 4d 45 5f 4e 41 4d 45 2c 20 22 6e 6f 74 6e 75  AME_NAME, "notnu
77e0: 6c 6c 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54  ll", SQLITE_STAT
77f0: 49 43 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  IC);.      sqlit
7800: 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65  e3VdbeSetColName
7810: 28 76 2c 20 34 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  (v, 4, COLNAME_N
7820: 41 4d 45 2c 20 22 64 66 6c 74 5f 76 61 6c 75 65  AME, "dflt_value
7830: 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  ", SQLITE_STATIC
7840: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
7850: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
7860: 2c 20 35 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 5, COLNAME_NAM
7870: 45 2c 20 22 70 6b 22 2c 20 53 51 4c 49 54 45 5f  E, "pk", SQLITE_
7880: 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 73  STATIC);.      s
7890: 71 6c 69 74 65 33 56 69 65 77 47 65 74 43 6f 6c  qlite3ViewGetCol
78a0: 75 6d 6e 4e 61 6d 65 73 28 70 50 61 72 73 65 2c  umnNames(pParse,
78b0: 20 70 54 61 62 29 3b 0a 20 20 20 20 20 20 66 6f   pTab);.      fo
78c0: 72 28 69 3d 30 2c 20 70 43 6f 6c 3d 70 54 61 62  r(i=0, pCol=pTab
78d0: 2d 3e 61 43 6f 6c 3b 20 69 3c 70 54 61 62 2d 3e  ->aCol; i<pTab->
78e0: 6e 43 6f 6c 3b 20 69 2b 2b 2c 20 70 43 6f 6c 2b  nCol; i++, pCol+
78f0: 2b 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20  +){.        if( 
7900: 49 73 48 69 64 64 65 6e 43 6f 6c 75 6d 6e 28 70  IsHiddenColumn(p
7910: 43 6f 6c 29 20 29 7b 0a 20 20 20 20 20 20 20 20  Col) ){.        
7920: 20 20 6e 48 69 64 64 65 6e 2b 2b 3b 0a 20 20 20    nHidden++;.   
7930: 20 20 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b         continue;
7940: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
7950: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
7960: 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67  dOp2(v, OP_Integ
7970: 65 72 2c 20 69 2d 6e 48 69 64 64 65 6e 2c 20 31  er, i-nHidden, 1
7980: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
7990: 65 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20  e3VdbeAddOp4(v, 
79a0: 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20 32  OP_String8, 0, 2
79b0: 2c 20 30 2c 20 70 43 6f 6c 2d 3e 7a 4e 61 6d 65  , 0, pCol->zName
79c0: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73 71  , 0);.        sq
79d0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 34 28  lite3VdbeAddOp4(
79e0: 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30  v, OP_String8, 0
79f0: 2c 20 33 2c 20 30 2c 0a 20 20 20 20 20 20 20 20  , 3, 0,.        
7a00: 20 20 20 70 43 6f 6c 2d 3e 7a 54 79 70 65 20 3f     pCol->zType ?
7a10: 20 70 43 6f 6c 2d 3e 7a 54 79 70 65 20 3a 20 22   pCol->zType : "
7a20: 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 73  ", 0);.        s
7a30: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
7a40: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
7a50: 28 70 43 6f 6c 2d 3e 6e 6f 74 4e 75 6c 6c 20 3f  (pCol->notNull ?
7a60: 20 31 20 3a 20 30 29 2c 20 34 29 3b 0a 20 20 20   1 : 0), 4);.   
7a70: 20 20 20 20 20 69 66 28 20 70 43 6f 6c 2d 3e 7a       if( pCol->z
7a80: 44 66 6c 74 20 29 7b 0a 20 20 20 20 20 20 20 20  Dflt ){.        
7a90: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
7aa0: 4f 70 34 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67  Op4(v, OP_String
7ab0: 38 2c 20 30 2c 20 35 2c 20 30 2c 20 28 63 68 61  8, 0, 5, 0, (cha
7ac0: 72 2a 29 70 43 6f 6c 2d 3e 7a 44 66 6c 74 2c 20  r*)pCol->zDflt, 
7ad0: 30 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73  0);.        }els
7ae0: 65 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  e{.          sql
7af0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76  ite3VdbeAddOp2(v
7b00: 2c 20 4f 50 5f 4e 75 6c 6c 2c 20 30 2c 20 35 29  , OP_Null, 0, 5)
7b10: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
7b20: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
7b30: 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65  ddOp2(v, OP_Inte
7b40: 67 65 72 2c 20 70 43 6f 6c 2d 3e 69 73 50 72 69  ger, pCol->isPri
7b50: 6d 4b 65 79 2c 20 36 29 3b 0a 20 20 20 20 20 20  mKey, 6);.      
7b60: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
7b70: 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73 75 6c 74  Op2(v, OP_Result
7b80: 52 6f 77 2c 20 31 2c 20 36 29 3b 0a 20 20 20 20  Row, 1, 6);.    
7b90: 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73    }.    }.  }els
7ba0: 65 0a 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33  e..  if( sqlite3
7bb0: 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22  StrICmp(zLeft, "
7bc0: 69 6e 64 65 78 5f 69 6e 66 6f 22 29 3d 3d 30 20  index_info")==0 
7bd0: 26 26 20 7a 52 69 67 68 74 20 29 7b 0a 20 20 20  && zRight ){.   
7be0: 20 49 6e 64 65 78 20 2a 70 49 64 78 3b 0a 20 20   Index *pIdx;.  
7bf0: 20 20 54 61 62 6c 65 20 2a 70 54 61 62 3b 0a 20    Table *pTab;. 
7c00: 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 52 65     if( sqlite3Re
7c10: 61 64 53 63 68 65 6d 61 28 70 50 61 72 73 65 29  adSchema(pParse)
7c20: 20 29 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f   ) goto pragma_o
7c30: 75 74 3b 0a 20 20 20 20 70 49 64 78 20 3d 20 73  ut;.    pIdx = s
7c40: 71 6c 69 74 65 33 46 69 6e 64 49 6e 64 65 78 28  qlite3FindIndex(
7c50: 64 62 2c 20 7a 52 69 67 68 74 2c 20 7a 44 62 29  db, zRight, zDb)
7c60: 3b 0a 20 20 20 20 69 66 28 20 70 49 64 78 20 29  ;.    if( pIdx )
7c70: 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20  {.      int i;. 
7c80: 20 20 20 20 20 70 54 61 62 20 3d 20 70 49 64 78       pTab = pIdx
7c90: 2d 3e 70 54 61 62 6c 65 3b 0a 20 20 20 20 20 20  ->pTable;.      
7ca0: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75  sqlite3VdbeSetNu
7cb0: 6d 43 6f 6c 73 28 76 2c 20 33 29 3b 0a 20 20 20  mCols(v, 3);.   
7cc0: 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20     pParse->nMem 
7cd0: 3d 20 33 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  = 3;.      sqlit
7ce0: 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65  e3VdbeSetColName
7cf0: 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  (v, 0, COLNAME_N
7d00: 41 4d 45 2c 20 22 73 65 71 6e 6f 22 2c 20 53 51  AME, "seqno", SQ
7d10: 4c 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20  LITE_STATIC);.  
7d20: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
7d30: 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 31 2c 20  etColName(v, 1, 
7d40: 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 63  COLNAME_NAME, "c
7d50: 69 64 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54  id", SQLITE_STAT
7d60: 49 43 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  IC);.      sqlit
7d70: 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65  e3VdbeSetColName
7d80: 28 76 2c 20 32 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  (v, 2, COLNAME_N
7d90: 41 4d 45 2c 20 22 6e 61 6d 65 22 2c 20 53 51 4c  AME, "name", SQL
7da0: 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20  ITE_STATIC);.   
7db0: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 49     for(i=0; i<pI
7dc0: 64 78 2d 3e 6e 43 6f 6c 75 6d 6e 3b 20 69 2b 2b  dx->nColumn; i++
7dd0: 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 63  ){.        int c
7de0: 6e 75 6d 20 3d 20 70 49 64 78 2d 3e 61 69 43 6f  num = pIdx->aiCo
7df0: 6c 75 6d 6e 5b 69 5d 3b 0a 20 20 20 20 20 20 20  lumn[i];.       
7e00: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
7e10: 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72  p2(v, OP_Integer
7e20: 2c 20 69 2c 20 31 29 3b 0a 20 20 20 20 20 20 20  , i, 1);.       
7e30: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
7e40: 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72  p2(v, OP_Integer
7e50: 2c 20 63 6e 75 6d 2c 20 32 29 3b 0a 20 20 20 20  , cnum, 2);.    
7e60: 20 20 20 20 61 73 73 65 72 74 28 20 70 54 61 62      assert( pTab
7e70: 2d 3e 6e 43 6f 6c 3e 63 6e 75 6d 20 29 3b 0a 20  ->nCol>cnum );. 
7e80: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
7e90: 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53  beAddOp4(v, OP_S
7ea0: 74 72 69 6e 67 38 2c 20 30 2c 20 33 2c 20 30 2c  tring8, 0, 3, 0,
7eb0: 20 70 54 61 62 2d 3e 61 43 6f 6c 5b 63 6e 75 6d   pTab->aCol[cnum
7ec0: 5d 2e 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 20  ].zName, 0);.   
7ed0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
7ee0: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73  AddOp2(v, OP_Res
7ef0: 75 6c 74 52 6f 77 2c 20 31 2c 20 33 29 3b 0a 20  ultRow, 1, 3);. 
7f00: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d       }.    }.  }
7f10: 65 6c 73 65 0a 0a 20 20 69 66 28 20 73 71 6c 69  else..  if( sqli
7f20: 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74  te3StrICmp(zLeft
7f30: 2c 20 22 69 6e 64 65 78 5f 6c 69 73 74 22 29 3d  , "index_list")=
7f40: 3d 30 20 26 26 20 7a 52 69 67 68 74 20 29 7b 0a  =0 && zRight ){.
7f50: 20 20 20 20 49 6e 64 65 78 20 2a 70 49 64 78 3b      Index *pIdx;
7f60: 0a 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62  .    Table *pTab
7f70: 3b 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65  ;.    if( sqlite
7f80: 33 52 65 61 64 53 63 68 65 6d 61 28 70 50 61 72  3ReadSchema(pPar
7f90: 73 65 29 20 29 20 67 6f 74 6f 20 70 72 61 67 6d  se) ) goto pragm
7fa0: 61 5f 6f 75 74 3b 0a 20 20 20 20 70 54 61 62 20  a_out;.    pTab 
7fb0: 3d 20 73 71 6c 69 74 65 33 46 69 6e 64 54 61 62  = sqlite3FindTab
7fc0: 6c 65 28 64 62 2c 20 7a 52 69 67 68 74 2c 20 7a  le(db, zRight, z
7fd0: 44 62 29 3b 0a 20 20 20 20 69 66 28 20 70 54 61  Db);.    if( pTa
7fe0: 62 20 29 7b 0a 20 20 20 20 20 20 76 20 3d 20 73  b ){.      v = s
7ff0: 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70 50  qlite3GetVdbe(pP
8000: 61 72 73 65 29 3b 0a 20 20 20 20 20 20 70 49 64  arse);.      pId
8010: 78 20 3d 20 70 54 61 62 2d 3e 70 49 6e 64 65 78  x = pTab->pIndex
8020: 3b 0a 20 20 20 20 20 20 69 66 28 20 70 49 64 78  ;.      if( pIdx
8030: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20   ){.        int 
8040: 69 20 3d 20 30 3b 20 0a 20 20 20 20 20 20 20 20  i = 0; .        
8050: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75  sqlite3VdbeSetNu
8060: 6d 43 6f 6c 73 28 76 2c 20 33 29 3b 0a 20 20 20  mCols(v, 3);.   
8070: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65       pParse->nMe
8080: 6d 20 3d 20 33 3b 0a 20 20 20 20 20 20 20 20 73  m = 3;.        s
8090: 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c  qlite3VdbeSetCol
80a0: 4e 61 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41  Name(v, 0, COLNA
80b0: 4d 45 5f 4e 41 4d 45 2c 20 22 73 65 71 22 2c 20  ME_NAME, "seq", 
80c0: 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b 0a  SQLITE_STATIC);.
80d0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
80e0: 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c  dbeSetColName(v,
80f0: 20 31 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45   1, COLNAME_NAME
8100: 2c 20 22 6e 61 6d 65 22 2c 20 53 51 4c 49 54 45  , "name", SQLITE
8110: 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20  _STATIC);.      
8120: 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74    sqlite3VdbeSet
8130: 43 6f 6c 4e 61 6d 65 28 76 2c 20 32 2c 20 43 4f  ColName(v, 2, CO
8140: 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 75 6e 69  LNAME_NAME, "uni
8150: 71 75 65 22 2c 20 53 51 4c 49 54 45 5f 53 54 41  que", SQLITE_STA
8160: 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 77 68  TIC);.        wh
8170: 69 6c 65 28 70 49 64 78 29 7b 0a 20 20 20 20 20  ile(pIdx){.     
8180: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
8190: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74  AddOp2(v, OP_Int
81a0: 65 67 65 72 2c 20 69 2c 20 31 29 3b 0a 20 20 20  eger, i, 1);.   
81b0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
81c0: 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53  beAddOp4(v, OP_S
81d0: 74 72 69 6e 67 38 2c 20 30 2c 20 32 2c 20 30 2c  tring8, 0, 2, 0,
81e0: 20 70 49 64 78 2d 3e 7a 4e 61 6d 65 2c 20 30 29   pIdx->zName, 0)
81f0: 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  ;.          sqli
8200: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c  te3VdbeAddOp2(v,
8210: 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 70 49 64   OP_Integer, pId
8220: 78 2d 3e 6f 6e 45 72 72 6f 72 21 3d 4f 45 5f 4e  x->onError!=OE_N
8230: 6f 6e 65 2c 20 33 29 3b 0a 20 20 20 20 20 20 20  one, 3);.       
8240: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
8250: 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73 75 6c  dOp2(v, OP_Resul
8260: 74 52 6f 77 2c 20 31 2c 20 33 29 3b 0a 20 20 20  tRow, 1, 3);.   
8270: 20 20 20 20 20 20 20 2b 2b 69 3b 0a 20 20 20 20         ++i;.    
8280: 20 20 20 20 20 20 70 49 64 78 20 3d 20 70 49 64        pIdx = pId
8290: 78 2d 3e 70 4e 65 78 74 3b 0a 20 20 20 20 20 20  x->pNext;.      
82a0: 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20    }.      }.    
82b0: 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 69 66 28  }.  }else..  if(
82c0: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
82d0: 7a 4c 65 66 74 2c 20 22 64 61 74 61 62 61 73 65  zLeft, "database
82e0: 5f 6c 69 73 74 22 29 3d 3d 30 20 29 7b 0a 20 20  _list")==0 ){.  
82f0: 20 20 69 6e 74 20 69 3b 0a 20 20 20 20 69 66 28    int i;.    if(
8300: 20 73 71 6c 69 74 65 33 52 65 61 64 53 63 68 65   sqlite3ReadSche
8310: 6d 61 28 70 50 61 72 73 65 29 20 29 20 67 6f 74  ma(pParse) ) got
8320: 6f 20 70 72 61 67 6d 61 5f 6f 75 74 3b 0a 20 20  o pragma_out;.  
8330: 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74    sqlite3VdbeSet
8340: 4e 75 6d 43 6f 6c 73 28 76 2c 20 33 29 3b 0a 20  NumCols(v, 3);. 
8350: 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20     pParse->nMem 
8360: 3d 20 33 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  = 3;.    sqlite3
8370: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
8380: 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 0, COLNAME_NAM
8390: 45 2c 20 22 73 65 71 22 2c 20 53 51 4c 49 54 45  E, "seq", SQLITE
83a0: 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 73 71  _STATIC);.    sq
83b0: 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e  lite3VdbeSetColN
83c0: 61 6d 65 28 76 2c 20 31 2c 20 43 4f 4c 4e 41 4d  ame(v, 1, COLNAM
83d0: 45 5f 4e 41 4d 45 2c 20 22 6e 61 6d 65 22 2c 20  E_NAME, "name", 
83e0: 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b 0a  SQLITE_STATIC);.
83f0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
8400: 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 32 2c 20  etColName(v, 2, 
8410: 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 66  COLNAME_NAME, "f
8420: 69 6c 65 22 2c 20 53 51 4c 49 54 45 5f 53 54 41  ile", SQLITE_STA
8430: 54 49 43 29 3b 0a 20 20 20 20 66 6f 72 28 69 3d  TIC);.    for(i=
8440: 30 3b 20 69 3c 64 62 2d 3e 6e 44 62 3b 20 69 2b  0; i<db->nDb; i+
8450: 2b 29 7b 0a 20 20 20 20 20 20 69 66 28 20 64 62  +){.      if( db
8460: 2d 3e 61 44 62 5b 69 5d 2e 70 42 74 3d 3d 30 20  ->aDb[i].pBt==0 
8470: 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20  ) continue;.    
8480: 20 20 61 73 73 65 72 74 28 20 64 62 2d 3e 61 44    assert( db->aD
8490: 62 5b 69 5d 2e 7a 4e 61 6d 65 21 3d 30 20 29 3b  b[i].zName!=0 );
84a0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
84b0: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49  beAddOp2(v, OP_I
84c0: 6e 74 65 67 65 72 2c 20 69 2c 20 31 29 3b 0a 20  nteger, i, 1);. 
84d0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
84e0: 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53 74 72  AddOp4(v, OP_Str
84f0: 69 6e 67 38 2c 20 30 2c 20 32 2c 20 30 2c 20 64  ing8, 0, 2, 0, d
8500: 62 2d 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 2c  b->aDb[i].zName,
8510: 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   0);.      sqlit
8520: 65 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20  e3VdbeAddOp4(v, 
8530: 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20 33  OP_String8, 0, 3
8540: 2c 20 30 2c 0a 20 20 20 20 20 20 20 20 20 20 20  , 0,.           
8550: 73 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 46  sqlite3BtreeGetF
8560: 69 6c 65 6e 61 6d 65 28 64 62 2d 3e 61 44 62 5b  ilename(db->aDb[
8570: 69 5d 2e 70 42 74 29 2c 20 30 29 3b 0a 20 20 20  i].pBt), 0);.   
8580: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
8590: 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73 75 6c  dOp2(v, OP_Resul
85a0: 74 52 6f 77 2c 20 31 2c 20 33 29 3b 0a 20 20 20  tRow, 1, 3);.   
85b0: 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 69 66   }.  }else..  if
85c0: 28 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70  ( sqlite3StrICmp
85d0: 28 7a 4c 65 66 74 2c 20 22 63 6f 6c 6c 61 74 69  (zLeft, "collati
85e0: 6f 6e 5f 6c 69 73 74 22 29 3d 3d 30 20 29 7b 0a  on_list")==0 ){.
85f0: 20 20 20 20 69 6e 74 20 69 20 3d 20 30 3b 0a 20      int i = 0;. 
8600: 20 20 20 48 61 73 68 45 6c 65 6d 20 2a 70 3b 0a     HashElem *p;.
8610: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
8620: 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20 32 29 3b  etNumCols(v, 2);
8630: 0a 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65  .    pParse->nMe
8640: 6d 20 3d 20 32 3b 0a 20 20 20 20 73 71 6c 69 74  m = 2;.    sqlit
8650: 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65  e3VdbeSetColName
8660: 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  (v, 0, COLNAME_N
8670: 41 4d 45 2c 20 22 73 65 71 22 2c 20 53 51 4c 49  AME, "seq", SQLI
8680: 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  TE_STATIC);.    
8690: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f  sqlite3VdbeSetCo
86a0: 6c 4e 61 6d 65 28 76 2c 20 31 2c 20 43 4f 4c 4e  lName(v, 1, COLN
86b0: 41 4d 45 5f 4e 41 4d 45 2c 20 22 6e 61 6d 65 22  AME_NAME, "name"
86c0: 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29  , SQLITE_STATIC)
86d0: 3b 0a 20 20 20 20 66 6f 72 28 70 3d 73 71 6c 69  ;.    for(p=sqli
86e0: 74 65 48 61 73 68 46 69 72 73 74 28 26 64 62 2d  teHashFirst(&db-
86f0: 3e 61 43 6f 6c 6c 53 65 71 29 3b 20 70 3b 20 70  >aCollSeq); p; p
8700: 3d 73 71 6c 69 74 65 48 61 73 68 4e 65 78 74 28  =sqliteHashNext(
8710: 70 29 29 7b 0a 20 20 20 20 20 20 43 6f 6c 6c 53  p)){.      CollS
8720: 65 71 20 2a 70 43 6f 6c 6c 20 3d 20 28 43 6f 6c  eq *pColl = (Col
8730: 6c 53 65 71 20 2a 29 73 71 6c 69 74 65 48 61 73  lSeq *)sqliteHas
8740: 68 44 61 74 61 28 70 29 3b 0a 20 20 20 20 20 20  hData(p);.      
8750: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
8760: 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c  2(v, OP_Integer,
8770: 20 69 2b 2b 2c 20 31 29 3b 0a 20 20 20 20 20 20   i++, 1);.      
8780: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
8790: 34 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c  4(v, OP_String8,
87a0: 20 30 2c 20 32 2c 20 30 2c 20 70 43 6f 6c 6c 2d   0, 2, 0, pColl-
87b0: 3e 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 20 20  >zName, 0);.    
87c0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
87d0: 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73 75 6c 74  Op2(v, OP_Result
87e0: 52 6f 77 2c 20 31 2c 20 32 29 3b 0a 20 20 20 20  Row, 1, 2);.    
87f0: 7d 0a 20 20 7d 65 6c 73 65 0a 23 65 6e 64 69 66  }.  }else.#endif
8800: 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f   /* SQLITE_OMIT_
8810: 53 43 48 45 4d 41 5f 50 52 41 47 4d 41 53 20 2a  SCHEMA_PRAGMAS *
8820: 2f 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  /..#ifndef SQLIT
8830: 45 5f 4f 4d 49 54 5f 46 4f 52 45 49 47 4e 5f 4b  E_OMIT_FOREIGN_K
8840: 45 59 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33  EY.  if( sqlite3
8850: 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22  StrICmp(zLeft, "
8860: 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 6c 69 73 74  foreign_key_list
8870: 22 29 3d 3d 30 20 26 26 20 7a 52 69 67 68 74 20  ")==0 && zRight 
8880: 29 7b 0a 20 20 20 20 46 4b 65 79 20 2a 70 46 4b  ){.    FKey *pFK
8890: 3b 0a 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61  ;.    Table *pTa
88a0: 62 3b 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74  b;.    if( sqlit
88b0: 65 33 52 65 61 64 53 63 68 65 6d 61 28 70 50 61  e3ReadSchema(pPa
88c0: 72 73 65 29 20 29 20 67 6f 74 6f 20 70 72 61 67  rse) ) goto prag
88d0: 6d 61 5f 6f 75 74 3b 0a 20 20 20 20 70 54 61 62  ma_out;.    pTab
88e0: 20 3d 20 73 71 6c 69 74 65 33 46 69 6e 64 54 61   = sqlite3FindTa
88f0: 62 6c 65 28 64 62 2c 20 7a 52 69 67 68 74 2c 20  ble(db, zRight, 
8900: 7a 44 62 29 3b 0a 20 20 20 20 69 66 28 20 70 54  zDb);.    if( pT
8910: 61 62 20 29 7b 0a 20 20 20 20 20 20 76 20 3d 20  ab ){.      v = 
8920: 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70  sqlite3GetVdbe(p
8930: 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20 70 46  Parse);.      pF
8940: 4b 20 3d 20 70 54 61 62 2d 3e 70 46 4b 65 79 3b  K = pTab->pFKey;
8950: 0a 20 20 20 20 20 20 69 66 28 20 70 46 4b 20 29  .      if( pFK )
8960: 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 20  {.        int i 
8970: 3d 20 30 3b 20 0a 20 20 20 20 20 20 20 20 73 71  = 0; .        sq
8980: 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75 6d 43  lite3VdbeSetNumC
8990: 6f 6c 73 28 76 2c 20 38 29 3b 0a 20 20 20 20 20  ols(v, 8);.     
89a0: 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20     pParse->nMem 
89b0: 3d 20 38 3b 0a 20 20 20 20 20 20 20 20 73 71 6c  = 8;.        sql
89c0: 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61  ite3VdbeSetColNa
89d0: 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45  me(v, 0, COLNAME
89e0: 5f 4e 41 4d 45 2c 20 22 69 64 22 2c 20 53 51 4c  _NAME, "id", SQL
89f0: 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20  ITE_STATIC);.   
8a00: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
8a10: 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 31 2c  SetColName(v, 1,
8a20: 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22   COLNAME_NAME, "
8a30: 73 65 71 22 2c 20 53 51 4c 49 54 45 5f 53 54 41  seq", SQLITE_STA
8a40: 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 73 71  TIC);.        sq
8a50: 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e  lite3VdbeSetColN
8a60: 61 6d 65 28 76 2c 20 32 2c 20 43 4f 4c 4e 41 4d  ame(v, 2, COLNAM
8a70: 45 5f 4e 41 4d 45 2c 20 22 74 61 62 6c 65 22 2c  E_NAME, "table",
8a80: 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b   SQLITE_STATIC);
8a90: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
8aa0: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
8ab0: 2c 20 33 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 3, COLNAME_NAM
8ac0: 45 2c 20 22 66 72 6f 6d 22 2c 20 53 51 4c 49 54  E, "from", SQLIT
8ad0: 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20  E_STATIC);.     
8ae0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53 65     sqlite3VdbeSe
8af0: 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 34 2c 20 43  tColName(v, 4, C
8b00: 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 22 74 6f  OLNAME_NAME, "to
8b10: 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  ", SQLITE_STATIC
8b20: 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  );.        sqlit
8b30: 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65  e3VdbeSetColName
8b40: 28 76 2c 20 35 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  (v, 5, COLNAME_N
8b50: 41 4d 45 2c 20 22 6f 6e 5f 75 70 64 61 74 65 22  AME, "on_update"
8b60: 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29  , SQLITE_STATIC)
8b70: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
8b80: 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28  3VdbeSetColName(
8b90: 76 2c 20 36 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41  v, 6, COLNAME_NA
8ba0: 4d 45 2c 20 22 6f 6e 5f 64 65 6c 65 74 65 22 2c  ME, "on_delete",
8bb0: 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b   SQLITE_STATIC);
8bc0: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
8bd0: 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76  VdbeSetColName(v
8be0: 2c 20 37 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d  , 7, COLNAME_NAM
8bf0: 45 2c 20 22 6d 61 74 63 68 22 2c 20 53 51 4c 49  E, "match", SQLI
8c00: 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  TE_STATIC);.    
8c10: 20 20 20 20 77 68 69 6c 65 28 70 46 4b 29 7b 0a      while(pFK){.
8c20: 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 6a 3b            int j;
8c30: 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 28 6a  .          for(j
8c40: 3d 30 3b 20 6a 3c 70 46 4b 2d 3e 6e 43 6f 6c 3b  =0; j<pFK->nCol;
8c50: 20 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20   j++){.         
8c60: 20 20 20 63 68 61 72 20 2a 7a 43 6f 6c 20 3d 20     char *zCol = 
8c70: 70 46 4b 2d 3e 61 43 6f 6c 5b 6a 5d 2e 7a 43 6f  pFK->aCol[j].zCo
8c80: 6c 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 63  l;.            c
8c90: 68 61 72 20 2a 7a 4f 6e 44 65 6c 65 74 65 20 3d  har *zOnDelete =
8ca0: 20 28 63 68 61 72 20 2a 29 61 63 74 69 6f 6e 4e   (char *)actionN
8cb0: 61 6d 65 28 70 46 4b 2d 3e 61 41 63 74 69 6f 6e  ame(pFK->aAction
8cc0: 5b 30 5d 29 3b 0a 20 20 20 20 20 20 20 20 20 20  [0]);.          
8cd0: 20 20 63 68 61 72 20 2a 7a 4f 6e 55 70 64 61 74    char *zOnUpdat
8ce0: 65 20 3d 20 28 63 68 61 72 20 2a 29 61 63 74 69  e = (char *)acti
8cf0: 6f 6e 4e 61 6d 65 28 70 46 4b 2d 3e 61 41 63 74  onName(pFK->aAct
8d00: 69 6f 6e 5b 31 5d 29 3b 0a 20 20 20 20 20 20 20  ion[1]);.       
8d10: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
8d20: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74  AddOp2(v, OP_Int
8d30: 65 67 65 72 2c 20 69 2c 20 31 29 3b 0a 20 20 20  eger, i, 1);.   
8d40: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
8d50: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
8d60: 5f 49 6e 74 65 67 65 72 2c 20 6a 2c 20 32 29 3b  _Integer, j, 2);
8d70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c  .            sql
8d80: 69 74 65 33 56 64 62 65 41 64 64 4f 70 34 28 76  ite3VdbeAddOp4(v
8d90: 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c  , OP_String8, 0,
8da0: 20 33 2c 20 30 2c 20 70 46 4b 2d 3e 7a 54 6f 2c   3, 0, pFK->zTo,
8db0: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20   0);.           
8dc0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
8dd0: 70 34 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38  p4(v, OP_String8
8de0: 2c 20 30 2c 20 34 2c 20 30 2c 0a 20 20 20 20 20  , 0, 4, 0,.     
8df0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8e00: 20 20 20 20 20 20 20 20 20 70 54 61 62 2d 3e 61           pTab->a
8e10: 43 6f 6c 5b 70 46 4b 2d 3e 61 43 6f 6c 5b 6a 5d  Col[pFK->aCol[j]
8e20: 2e 69 46 72 6f 6d 5d 2e 7a 4e 61 6d 65 2c 20 30  .iFrom].zName, 0
8e30: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 73  );.            s
8e40: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 34  qlite3VdbeAddOp4
8e50: 28 76 2c 20 7a 43 6f 6c 20 3f 20 4f 50 5f 53 74  (v, zCol ? OP_St
8e60: 72 69 6e 67 38 20 3a 20 4f 50 5f 4e 75 6c 6c 2c  ring8 : OP_Null,
8e70: 20 30 2c 20 35 2c 20 30 2c 20 7a 43 6f 6c 2c 20   0, 5, 0, zCol, 
8e80: 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  0);.            
8e90: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
8ea0: 34 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38 2c  4(v, OP_String8,
8eb0: 20 30 2c 20 36 2c 20 30 2c 20 7a 4f 6e 55 70 64   0, 6, 0, zOnUpd
8ec0: 61 74 65 2c 20 30 29 3b 0a 20 20 20 20 20 20 20  ate, 0);.       
8ed0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
8ee0: 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53 74 72  AddOp4(v, OP_Str
8ef0: 69 6e 67 38 2c 20 30 2c 20 37 2c 20 30 2c 20 7a  ing8, 0, 7, 0, z
8f00: 4f 6e 44 65 6c 65 74 65 2c 20 30 29 3b 0a 20 20  OnDelete, 0);.  
8f10: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
8f20: 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f  3VdbeAddOp4(v, O
8f30: 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20 38 2c  P_String8, 0, 8,
8f40: 20 30 2c 20 22 4e 4f 4e 45 22 2c 20 30 29 3b 0a   0, "NONE", 0);.
8f50: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
8f60: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c  te3VdbeAddOp2(v,
8f70: 20 4f 50 5f 52 65 73 75 6c 74 52 6f 77 2c 20 31   OP_ResultRow, 1
8f80: 2c 20 38 29 3b 0a 20 20 20 20 20 20 20 20 20 20  , 8);.          
8f90: 7d 0a 20 20 20 20 20 20 20 20 20 20 2b 2b 69 3b  }.          ++i;
8fa0: 0a 20 20 20 20 20 20 20 20 20 20 70 46 4b 20 3d  .          pFK =
8fb0: 20 70 46 4b 2d 3e 70 4e 65 78 74 46 72 6f 6d 3b   pFK->pNextFrom;
8fc0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
8fd0: 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65   }.    }.  }else
8fe0: 0a 23 65 6e 64 69 66 20 2f 2a 20 21 64 65 66 69  .#endif /* !defi
8ff0: 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  ned(SQLITE_OMIT_
9000: 46 4f 52 45 49 47 4e 5f 4b 45 59 29 20 2a 2f 0a  FOREIGN_KEY) */.
9010: 0a 23 69 66 6e 64 65 66 20 4e 44 45 42 55 47 0a  .#ifndef NDEBUG.
9020: 20 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72    if( sqlite3Str
9030: 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 70 61 72  ICmp(zLeft, "par
9040: 73 65 72 5f 74 72 61 63 65 22 29 3d 3d 30 20 29  ser_trace")==0 )
9050: 7b 0a 20 20 20 20 69 66 28 20 7a 52 69 67 68 74  {.    if( zRight
9060: 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20 67 65   ){.      if( ge
9070: 74 42 6f 6f 6c 65 61 6e 28 7a 52 69 67 68 74 29  tBoolean(zRight)
9080: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
9090: 74 65 33 50 61 72 73 65 72 54 72 61 63 65 28 73  te3ParserTrace(s
90a0: 74 64 65 72 72 2c 20 22 70 61 72 73 65 72 3a 20  tderr, "parser: 
90b0: 22 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b  ");.      }else{
90c0: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
90d0: 50 61 72 73 65 72 54 72 61 63 65 28 30 2c 20 30  ParserTrace(0, 0
90e0: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
90f0: 0a 20 20 7d 65 6c 73 65 0a 23 65 6e 64 69 66 0a  .  }else.#endif.
9100: 0a 20 20 2f 2a 20 52 65 69 6e 73 74 61 6c 6c 20  .  /* Reinstall 
9110: 74 68 65 20 4c 49 4b 45 20 61 6e 64 20 47 4c 4f  the LIKE and GLO
9120: 42 20 66 75 6e 63 74 69 6f 6e 73 2e 20 20 54 68  B functions.  Th
9130: 65 20 76 61 72 69 61 6e 74 20 6f 66 20 4c 49 4b  e variant of LIK
9140: 45 0a 20 20 2a 2a 20 75 73 65 64 20 77 69 6c 6c  E.  ** used will
9150: 20 62 65 20 63 61 73 65 20 73 65 6e 73 69 74 69   be case sensiti
9160: 76 65 20 6f 72 20 6e 6f 74 20 64 65 70 65 6e 64  ve or not depend
9170: 69 6e 67 20 6f 6e 20 74 68 65 20 52 48 53 2e 0a  ing on the RHS..
9180: 20 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74    */.  if( sqlit
9190: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
91a0: 20 22 63 61 73 65 5f 73 65 6e 73 69 74 69 76 65   "case_sensitive
91b0: 5f 6c 69 6b 65 22 29 3d 3d 30 20 29 7b 0a 20 20  _like")==0 ){.  
91c0: 20 20 69 66 28 20 7a 52 69 67 68 74 20 29 7b 0a    if( zRight ){.
91d0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 52 65 67        sqlite3Reg
91e0: 69 73 74 65 72 4c 69 6b 65 46 75 6e 63 74 69 6f  isterLikeFunctio
91f0: 6e 73 28 64 62 2c 20 67 65 74 42 6f 6f 6c 65 61  ns(db, getBoolea
9200: 6e 28 7a 52 69 67 68 74 29 29 3b 0a 20 20 20 20  n(zRight));.    
9210: 7d 0a 20 20 7d 65 6c 73 65 0a 0a 23 69 66 6e 64  }.  }else..#ifnd
9220: 65 66 20 53 51 4c 49 54 45 5f 49 4e 54 45 47 52  ef SQLITE_INTEGR
9230: 49 54 59 5f 43 48 45 43 4b 5f 45 52 52 4f 52 5f  ITY_CHECK_ERROR_
9240: 4d 41 58 0a 23 20 64 65 66 69 6e 65 20 53 51 4c  MAX.# define SQL
9250: 49 54 45 5f 49 4e 54 45 47 52 49 54 59 5f 43 48  ITE_INTEGRITY_CH
9260: 45 43 4b 5f 45 52 52 4f 52 5f 4d 41 58 20 31 30  ECK_ERROR_MAX 10
9270: 30 0a 23 65 6e 64 69 66 0a 0a 23 69 66 6e 64 65  0.#endif..#ifnde
9280: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 49 4e  f SQLITE_OMIT_IN
9290: 54 45 47 52 49 54 59 5f 43 48 45 43 4b 0a 20 20  TEGRITY_CHECK.  
92a0: 2f 2a 20 50 72 61 67 6d 61 20 22 71 75 69 63 6b  /* Pragma "quick
92b0: 5f 63 68 65 63 6b 22 20 69 73 20 61 6e 20 65 78  _check" is an ex
92c0: 70 65 72 69 6d 65 6e 74 61 6c 20 72 65 64 75 63  perimental reduc
92d0: 65 64 20 76 65 72 73 69 6f 6e 20 6f 66 20 0a 20  ed version of . 
92e0: 20 2a 2a 20 69 6e 74 65 67 72 69 74 79 5f 63 68   ** integrity_ch
92f0: 65 63 6b 20 64 65 73 69 67 6e 65 64 20 74 6f 20  eck designed to 
9300: 64 65 74 65 63 74 20 6d 6f 73 74 20 64 61 74 61  detect most data
9310: 62 61 73 65 20 63 6f 72 72 75 70 74 69 6f 6e 0a  base corruption.
9320: 20 20 2a 2a 20 77 69 74 68 6f 75 74 20 6d 6f 73    ** without mos
9330: 74 20 6f 66 20 74 68 65 20 6f 76 65 72 68 65 61  t of the overhea
9340: 64 20 6f 66 20 61 20 66 75 6c 6c 20 69 6e 74 65  d of a full inte
9350: 67 72 69 74 79 2d 63 68 65 63 6b 2e 0a 20 20 2a  grity-check..  *
9360: 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 53  /.  if( sqlite3S
9370: 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 69  trICmp(zLeft, "i
9380: 6e 74 65 67 72 69 74 79 5f 63 68 65 63 6b 22 29  ntegrity_check")
9390: 3d 3d 30 0a 20 20 20 7c 7c 20 73 71 6c 69 74 65  ==0.   || sqlite
93a0: 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20  3StrICmp(zLeft, 
93b0: 22 71 75 69 63 6b 5f 63 68 65 63 6b 22 29 3d 3d  "quick_check")==
93c0: 30 20 0a 20 20 29 7b 0a 20 20 20 20 69 6e 74 20  0 .  ){.    int 
93d0: 69 2c 20 6a 2c 20 61 64 64 72 2c 20 6d 78 45 72  i, j, addr, mxEr
93e0: 72 3b 0a 0a 20 20 20 20 2f 2a 20 43 6f 64 65 20  r;..    /* Code 
93f0: 74 68 61 74 20 61 70 70 65 61 72 73 20 61 74 20  that appears at 
9400: 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20 69  the end of the i
9410: 6e 74 65 67 72 69 74 79 20 63 68 65 63 6b 2e 20  ntegrity check. 
9420: 20 49 66 20 6e 6f 20 65 72 72 6f 72 0a 20 20 20   If no error.   
9430: 20 2a 2a 20 6d 65 73 73 61 67 65 73 20 68 61 76   ** messages hav
9440: 65 20 62 65 65 6e 20 67 65 6e 65 72 61 74 65 64  e been generated
9450: 2c 20 6f 75 74 70 75 74 20 4f 4b 2e 20 20 4f 74  , output OK.  Ot
9460: 68 65 72 77 69 73 65 20 6f 75 74 70 75 74 20 74  herwise output t
9470: 68 65 0a 20 20 20 20 2a 2a 20 65 72 72 6f 72 20  he.    ** error 
9480: 6d 65 73 73 61 67 65 0a 20 20 20 20 2a 2f 0a 20  message.    */. 
9490: 20 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20     static const 
94a0: 56 64 62 65 4f 70 4c 69 73 74 20 65 6e 64 43 6f  VdbeOpList endCo
94b0: 64 65 5b 5d 20 3d 20 7b 0a 20 20 20 20 20 20 7b  de[] = {.      {
94c0: 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 20 20 20 20   OP_AddImm,     
94d0: 20 31 2c 20 30 2c 20 20 20 20 20 20 20 20 30 7d   1, 0,        0}
94e0: 2c 20 20 20 20 2f 2a 20 30 20 2a 2f 0a 20 20 20  ,    /* 0 */.   
94f0: 20 20 20 7b 20 4f 50 5f 49 66 4e 65 67 2c 20 20     { OP_IfNeg,  
9500: 20 20 20 20 20 31 2c 20 30 2c 20 20 20 20 20 20       1, 0,      
9510: 20 20 30 7d 2c 20 20 20 20 2f 2a 20 31 20 2a 2f    0},    /* 1 */
9520: 0a 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72 69  .      { OP_Stri
9530: 6e 67 38 2c 20 20 20 20 20 30 2c 20 33 2c 20 20  ng8,     0, 3,  
9540: 20 20 20 20 20 20 30 7d 2c 20 20 20 20 2f 2a 20        0},    /* 
9550: 32 20 2a 2f 0a 20 20 20 20 20 20 7b 20 4f 50 5f  2 */.      { OP_
9560: 52 65 73 75 6c 74 52 6f 77 2c 20 20 20 33 2c 20  ResultRow,   3, 
9570: 31 2c 20 20 20 20 20 20 20 20 30 7d 2c 0a 20 20  1,        0},.  
9580: 20 20 7d 3b 0a 0a 20 20 20 20 69 6e 74 20 69 73    };..    int is
9590: 51 75 69 63 6b 20 3d 20 28 7a 4c 65 66 74 5b 30  Quick = (zLeft[0
95a0: 5d 3d 3d 27 71 27 29 3b 0a 0a 20 20 20 20 2f 2a  ]=='q');..    /*
95b0: 20 49 6e 69 74 69 61 6c 69 7a 65 20 74 68 65 20   Initialize the 
95c0: 56 44 42 45 20 70 72 6f 67 72 61 6d 20 2a 2f 0a  VDBE program */.
95d0: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 52      if( sqlite3R
95e0: 65 61 64 53 63 68 65 6d 61 28 70 50 61 72 73 65  eadSchema(pParse
95f0: 29 20 29 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f  ) ) goto pragma_
9600: 6f 75 74 3b 0a 20 20 20 20 70 50 61 72 73 65 2d  out;.    pParse-
9610: 3e 6e 4d 65 6d 20 3d 20 36 3b 0a 20 20 20 20 73  >nMem = 6;.    s
9620: 71 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75 6d  qlite3VdbeSetNum
9630: 43 6f 6c 73 28 76 2c 20 31 29 3b 0a 20 20 20 20  Cols(v, 1);.    
9640: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f  sqlite3VdbeSetCo
9650: 6c 4e 61 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e  lName(v, 0, COLN
9660: 41 4d 45 5f 4e 41 4d 45 2c 20 22 69 6e 74 65 67  AME_NAME, "integ
9670: 72 69 74 79 5f 63 68 65 63 6b 22 2c 20 53 51 4c  rity_check", SQL
9680: 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 0a 20 20  ITE_STATIC);..  
9690: 20 20 2f 2a 20 53 65 74 20 74 68 65 20 6d 61 78    /* Set the max
96a0: 69 6d 75 6d 20 65 72 72 6f 72 20 63 6f 75 6e 74  imum error count
96b0: 20 2a 2f 0a 20 20 20 20 6d 78 45 72 72 20 3d 20   */.    mxErr = 
96c0: 53 51 4c 49 54 45 5f 49 4e 54 45 47 52 49 54 59  SQLITE_INTEGRITY
96d0: 5f 43 48 45 43 4b 5f 45 52 52 4f 52 5f 4d 41 58  _CHECK_ERROR_MAX
96e0: 3b 0a 20 20 20 20 69 66 28 20 7a 52 69 67 68 74  ;.    if( zRight
96f0: 20 29 7b 0a 20 20 20 20 20 20 6d 78 45 72 72 20   ){.      mxErr 
9700: 3d 20 61 74 6f 69 28 7a 52 69 67 68 74 29 3b 0a  = atoi(zRight);.
9710: 20 20 20 20 20 20 69 66 28 20 6d 78 45 72 72 3c        if( mxErr<
9720: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 6d 78  =0 ){.        mx
9730: 45 72 72 20 3d 20 53 51 4c 49 54 45 5f 49 4e 54  Err = SQLITE_INT
9740: 45 47 52 49 54 59 5f 43 48 45 43 4b 5f 45 52 52  EGRITY_CHECK_ERR
9750: 4f 52 5f 4d 41 58 3b 0a 20 20 20 20 20 20 7d 0a  OR_MAX;.      }.
9760: 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65      }.    sqlite
9770: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
9780: 50 5f 49 6e 74 65 67 65 72 2c 20 6d 78 45 72 72  P_Integer, mxErr
9790: 2c 20 31 29 3b 20 20 2f 2a 20 72 65 67 5b 31 5d  , 1);  /* reg[1]
97a0: 20 68 6f 6c 64 73 20 65 72 72 6f 72 73 20 6c 65   holds errors le
97b0: 66 74 20 2a 2f 0a 0a 20 20 20 20 2f 2a 20 44 6f  ft */..    /* Do
97c0: 20 61 6e 20 69 6e 74 65 67 72 69 74 79 20 63 68   an integrity ch
97d0: 65 63 6b 20 6f 6e 20 65 61 63 68 20 64 61 74 61  eck on each data
97e0: 62 61 73 65 20 66 69 6c 65 20 2a 2f 0a 20 20 20  base file */.   
97f0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62 2d 3e   for(i=0; i<db->
9800: 6e 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20  nDb; i++){.     
9810: 20 48 61 73 68 45 6c 65 6d 20 2a 78 3b 0a 20 20   HashElem *x;.  
9820: 20 20 20 20 48 61 73 68 20 2a 70 54 62 6c 73 3b      Hash *pTbls;
9830: 0a 20 20 20 20 20 20 69 6e 74 20 63 6e 74 20 3d  .      int cnt =
9840: 20 30 3b 0a 0a 20 20 20 20 20 20 69 66 28 20 4f   0;..      if( O
9850: 4d 49 54 5f 54 45 4d 50 44 42 20 26 26 20 69 3d  MIT_TEMPDB && i=
9860: 3d 31 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 0a  =1 ) continue;..
9870: 20 20 20 20 20 20 73 71 6c 69 74 65 33 43 6f 64        sqlite3Cod
9880: 65 56 65 72 69 66 79 53 63 68 65 6d 61 28 70 50  eVerifySchema(pP
9890: 61 72 73 65 2c 20 69 29 3b 0a 20 20 20 20 20 20  arse, i);.      
98a0: 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56 64  addr = sqlite3Vd
98b0: 62 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f 49  beAddOp1(v, OP_I
98c0: 66 50 6f 73 2c 20 31 29 3b 20 2f 2a 20 48 61 6c  fPos, 1); /* Hal
98d0: 74 20 69 66 20 6f 75 74 20 6f 66 20 65 72 72 6f  t if out of erro
98e0: 72 73 20 2a 2f 0a 20 20 20 20 20 20 73 71 6c 69  rs */.      sqli
98f0: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c  te3VdbeAddOp2(v,
9900: 20 4f 50 5f 48 61 6c 74 2c 20 30 2c 20 30 29 3b   OP_Halt, 0, 0);
9910: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
9920: 62 65 4a 75 6d 70 48 65 72 65 28 76 2c 20 61 64  beJumpHere(v, ad
9930: 64 72 29 3b 0a 0a 20 20 20 20 20 20 2f 2a 20 44  dr);..      /* D
9940: 6f 20 61 6e 20 69 6e 74 65 67 72 69 74 79 20 63  o an integrity c
9950: 68 65 63 6b 20 6f 66 20 74 68 65 20 42 2d 54 72  heck of the B-Tr
9960: 65 65 0a 20 20 20 20 20 20 2a 2a 0a 20 20 20 20  ee.      **.    
9970: 20 20 2a 2a 20 42 65 67 69 6e 20 62 79 20 66 69    ** Begin by fi
9980: 6c 6c 69 6e 67 20 72 65 67 69 73 74 65 72 73 20  lling registers 
9990: 32 2c 20 33 2c 20 2e 2e 2e 20 77 69 74 68 20 74  2, 3, ... with t
99a0: 68 65 20 72 6f 6f 74 20 70 61 67 65 73 20 6e 75  he root pages nu
99b0: 6d 62 65 72 73 0a 20 20 20 20 20 20 2a 2a 20 66  mbers.      ** f
99c0: 6f 72 20 61 6c 6c 20 74 61 62 6c 65 73 20 61 6e  or all tables an
99d0: 64 20 69 6e 64 69 63 65 73 20 69 6e 20 74 68 65  d indices in the
99e0: 20 64 61 74 61 62 61 73 65 2e 0a 20 20 20 20 20   database..     
99f0: 20 2a 2f 0a 20 20 20 20 20 20 70 54 62 6c 73 20   */.      pTbls 
9a00: 3d 20 26 64 62 2d 3e 61 44 62 5b 69 5d 2e 70 53  = &db->aDb[i].pS
9a10: 63 68 65 6d 61 2d 3e 74 62 6c 48 61 73 68 3b 0a  chema->tblHash;.
9a20: 20 20 20 20 20 20 66 6f 72 28 78 3d 73 71 6c 69        for(x=sqli
9a30: 74 65 48 61 73 68 46 69 72 73 74 28 70 54 62 6c  teHashFirst(pTbl
9a40: 73 29 3b 20 78 3b 20 78 3d 73 71 6c 69 74 65 48  s); x; x=sqliteH
9a50: 61 73 68 4e 65 78 74 28 78 29 29 7b 0a 20 20 20  ashNext(x)){.   
9a60: 20 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62       Table *pTab
9a70: 20 3d 20 73 71 6c 69 74 65 48 61 73 68 44 61 74   = sqliteHashDat
9a80: 61 28 78 29 3b 0a 20 20 20 20 20 20 20 20 49 6e  a(x);.        In
9a90: 64 65 78 20 2a 70 49 64 78 3b 0a 20 20 20 20 20  dex *pIdx;.     
9aa0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
9ab0: 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67  dOp2(v, OP_Integ
9ac0: 65 72 2c 20 70 54 61 62 2d 3e 74 6e 75 6d 2c 20  er, pTab->tnum, 
9ad0: 32 2b 63 6e 74 29 3b 0a 20 20 20 20 20 20 20 20  2+cnt);.        
9ae0: 63 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 20 20 66  cnt++;.        f
9af0: 6f 72 28 70 49 64 78 3d 70 54 61 62 2d 3e 70 49  or(pIdx=pTab->pI
9b00: 6e 64 65 78 3b 20 70 49 64 78 3b 20 70 49 64 78  ndex; pIdx; pIdx
9b10: 3d 70 49 64 78 2d 3e 70 4e 65 78 74 29 7b 0a 20  =pIdx->pNext){. 
9b20: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
9b30: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
9b40: 5f 49 6e 74 65 67 65 72 2c 20 70 49 64 78 2d 3e  _Integer, pIdx->
9b50: 74 6e 75 6d 2c 20 32 2b 63 6e 74 29 3b 0a 20 20  tnum, 2+cnt);.  
9b60: 20 20 20 20 20 20 20 20 63 6e 74 2b 2b 3b 0a 20          cnt++;. 
9b70: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
9b80: 0a 0a 20 20 20 20 20 20 2f 2a 20 4d 61 6b 65 20  ..      /* Make 
9b90: 73 75 72 65 20 73 75 66 66 69 63 69 65 6e 74 20  sure sufficient 
9ba0: 6e 75 6d 62 65 72 20 6f 66 20 72 65 67 69 73 74  number of regist
9bb0: 65 72 73 20 68 61 76 65 20 62 65 65 6e 20 61 6c  ers have been al
9bc0: 6c 6f 63 61 74 65 64 20 2a 2f 0a 20 20 20 20 20  located */.     
9bd0: 20 69 66 28 20 70 50 61 72 73 65 2d 3e 6e 4d 65   if( pParse->nMe
9be0: 6d 20 3c 20 63 6e 74 2b 34 20 29 7b 0a 20 20 20  m < cnt+4 ){.   
9bf0: 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65       pParse->nMe
9c00: 6d 20 3d 20 63 6e 74 2b 34 3b 0a 20 20 20 20 20  m = cnt+4;.     
9c10: 20 7d 0a 0a 20 20 20 20 20 20 2f 2a 20 44 6f 20   }..      /* Do 
9c20: 74 68 65 20 62 2d 74 72 65 65 20 69 6e 74 65 67  the b-tree integ
9c30: 72 69 74 79 20 63 68 65 63 6b 73 20 2a 2f 0a 20  rity checks */. 
9c40: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
9c50: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 49 6e 74  AddOp3(v, OP_Int
9c60: 65 67 72 69 74 79 43 6b 2c 20 32 2c 20 63 6e 74  egrityCk, 2, cnt
9c70: 2c 20 31 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  , 1);.      sqli
9c80: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 35 28  te3VdbeChangeP5(
9c90: 76 2c 20 28 75 38 29 69 29 3b 0a 20 20 20 20 20  v, (u8)i);.     
9ca0: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56   addr = sqlite3V
9cb0: 64 62 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f  dbeAddOp1(v, OP_
9cc0: 49 73 4e 75 6c 6c 2c 20 32 29 3b 0a 20 20 20 20  IsNull, 2);.    
9cd0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
9ce0: 4f 70 34 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67  Op4(v, OP_String
9cf0: 38 2c 20 30 2c 20 33 2c 20 30 2c 0a 20 20 20 20  8, 0, 3, 0,.    
9d00: 20 20 20 20 20 73 71 6c 69 74 65 33 4d 50 72 69       sqlite3MPri
9d10: 6e 74 66 28 64 62 2c 20 22 2a 2a 2a 20 69 6e 20  ntf(db, "*** in 
9d20: 64 61 74 61 62 61 73 65 20 25 73 20 2a 2a 2a 5c  database %s ***\
9d30: 6e 22 2c 20 64 62 2d 3e 61 44 62 5b 69 5d 2e 7a  n", db->aDb[i].z
9d40: 4e 61 6d 65 29 2c 0a 20 20 20 20 20 20 20 20 20  Name),.         
9d50: 50 34 5f 44 59 4e 41 4d 49 43 29 3b 0a 20 20 20  P4_DYNAMIC);.   
9d60: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
9d70: 64 4f 70 33 28 76 2c 20 4f 50 5f 4d 6f 76 65 2c  dOp3(v, OP_Move,
9d80: 20 32 2c 20 34 2c 20 31 29 3b 0a 20 20 20 20 20   2, 4, 1);.     
9d90: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
9da0: 70 33 28 76 2c 20 4f 50 5f 43 6f 6e 63 61 74 2c  p3(v, OP_Concat,
9db0: 20 34 2c 20 33 2c 20 32 29 3b 0a 20 20 20 20 20   4, 3, 2);.     
9dc0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
9dd0: 70 32 28 76 2c 20 4f 50 5f 52 65 73 75 6c 74 52  p2(v, OP_ResultR
9de0: 6f 77 2c 20 32 2c 20 31 29 3b 0a 20 20 20 20 20  ow, 2, 1);.     
9df0: 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70   sqlite3VdbeJump
9e00: 48 65 72 65 28 76 2c 20 61 64 64 72 29 3b 0a 0a  Here(v, addr);..
9e10: 20 20 20 20 20 20 2f 2a 20 4d 61 6b 65 20 73 75        /* Make su
9e20: 72 65 20 61 6c 6c 20 74 68 65 20 69 6e 64 69 63  re all the indic
9e30: 65 73 20 61 72 65 20 63 6f 6e 73 74 72 75 63 74  es are construct
9e40: 65 64 20 63 6f 72 72 65 63 74 6c 79 2e 0a 20 20  ed correctly..  
9e50: 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 66 6f 72      */.      for
9e60: 28 78 3d 73 71 6c 69 74 65 48 61 73 68 46 69 72  (x=sqliteHashFir
9e70: 73 74 28 70 54 62 6c 73 29 3b 20 78 20 26 26 20  st(pTbls); x && 
9e80: 21 69 73 51 75 69 63 6b 3b 20 78 3d 73 71 6c 69  !isQuick; x=sqli
9e90: 74 65 48 61 73 68 4e 65 78 74 28 78 29 29 7b 0a  teHashNext(x)){.
9ea0: 20 20 20 20 20 20 20 20 54 61 62 6c 65 20 2a 70          Table *p
9eb0: 54 61 62 20 3d 20 73 71 6c 69 74 65 48 61 73 68  Tab = sqliteHash
9ec0: 44 61 74 61 28 78 29 3b 0a 20 20 20 20 20 20 20  Data(x);.       
9ed0: 20 49 6e 64 65 78 20 2a 70 49 64 78 3b 0a 20 20   Index *pIdx;.  
9ee0: 20 20 20 20 20 20 69 6e 74 20 6c 6f 6f 70 54 6f        int loopTo
9ef0: 70 3b 0a 0a 20 20 20 20 20 20 20 20 69 66 28 20  p;..        if( 
9f00: 70 54 61 62 2d 3e 70 49 6e 64 65 78 3d 3d 30 20  pTab->pIndex==0 
9f10: 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20  ) continue;.    
9f20: 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74      addr = sqlit
9f30: 65 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c 20  e3VdbeAddOp1(v, 
9f40: 4f 50 5f 49 66 50 6f 73 2c 20 31 29 3b 20 20 2f  OP_IfPos, 1);  /
9f50: 2a 20 53 74 6f 70 20 69 66 20 6f 75 74 20 6f 66  * Stop if out of
9f60: 20 65 72 72 6f 72 73 20 2a 2f 0a 20 20 20 20 20   errors */.     
9f70: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
9f80: 64 4f 70 32 28 76 2c 20 4f 50 5f 48 61 6c 74 2c  dOp2(v, OP_Halt,
9f90: 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20   0, 0);.        
9fa0: 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48  sqlite3VdbeJumpH
9fb0: 65 72 65 28 76 2c 20 61 64 64 72 29 3b 0a 20 20  ere(v, addr);.  
9fc0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 4f 70 65        sqlite3Ope
9fd0: 6e 54 61 62 6c 65 41 6e 64 49 6e 64 69 63 65 73  nTableAndIndices
9fe0: 28 70 50 61 72 73 65 2c 20 70 54 61 62 2c 20 31  (pParse, pTab, 1
9ff0: 2c 20 4f 50 5f 4f 70 65 6e 52 65 61 64 29 3b 0a  , OP_OpenRead);.
a000: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
a010: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
a020: 49 6e 74 65 67 65 72 2c 20 30 2c 20 32 29 3b 20  Integer, 0, 2); 
a030: 20 2f 2a 20 72 65 67 28 32 29 20 77 69 6c 6c 20   /* reg(2) will 
a040: 63 6f 75 6e 74 20 65 6e 74 72 69 65 73 20 2a 2f  count entries */
a050: 0a 20 20 20 20 20 20 20 20 6c 6f 6f 70 54 6f 70  .        loopTop
a060: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64   = sqlite3VdbeAd
a070: 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 77 69 6e  dOp2(v, OP_Rewin
a080: 64 2c 20 31 2c 20 30 29 3b 0a 20 20 20 20 20 20  d, 1, 0);.      
a090: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
a0a0: 4f 70 32 28 76 2c 20 4f 50 5f 41 64 64 49 6d 6d  Op2(v, OP_AddImm
a0b0: 2c 20 32 2c 20 31 29 3b 20 20 20 2f 2a 20 69 6e  , 2, 1);   /* in
a0c0: 63 72 65 6d 65 6e 74 20 65 6e 74 72 79 20 63 6f  crement entry co
a0d0: 75 6e 74 20 2a 2f 0a 20 20 20 20 20 20 20 20 66  unt */.        f
a0e0: 6f 72 28 6a 3d 30 2c 20 70 49 64 78 3d 70 54 61  or(j=0, pIdx=pTa
a0f0: 62 2d 3e 70 49 6e 64 65 78 3b 20 70 49 64 78 3b  b->pIndex; pIdx;
a100: 20 70 49 64 78 3d 70 49 64 78 2d 3e 70 4e 65 78   pIdx=pIdx->pNex
a110: 74 2c 20 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 20  t, j++){.       
a120: 20 20 20 69 6e 74 20 6a 6d 70 32 3b 0a 20 20 20     int jmp2;.   
a130: 20 20 20 20 20 20 20 69 6e 74 20 72 31 3b 0a 20         int r1;. 
a140: 20 20 20 20 20 20 20 20 20 73 74 61 74 69 63 20           static 
a150: 63 6f 6e 73 74 20 56 64 62 65 4f 70 4c 69 73 74  const VdbeOpList
a160: 20 69 64 78 45 72 72 5b 5d 20 3d 20 7b 0a 20 20   idxErr[] = {.  
a170: 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 41            { OP_A
a180: 64 64 49 6d 6d 2c 20 20 20 20 20 20 31 2c 20 2d  ddImm,      1, -
a190: 31 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20  1,  0},.        
a1a0: 20 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67 38      { OP_String8
a1b0: 2c 20 20 20 20 20 30 2c 20 20 33 2c 20 20 30 7d  ,     0,  3,  0}
a1c0: 2c 20 20 20 20 2f 2a 20 31 20 2a 2f 0a 20 20 20  ,    /* 1 */.   
a1d0: 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 52 6f           { OP_Ro
a1e0: 77 69 64 2c 20 20 20 20 20 20 20 31 2c 20 20 34  wid,       1,  4
a1f0: 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20 20  ,  0},.         
a200: 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67 38 2c     { OP_String8,
a210: 20 20 20 20 20 30 2c 20 20 35 2c 20 20 30 7d 2c       0,  5,  0},
a220: 20 20 20 20 2f 2a 20 33 20 2a 2f 0a 20 20 20 20      /* 3 */.    
a230: 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72          { OP_Str
a240: 69 6e 67 38 2c 20 20 20 20 20 30 2c 20 20 36 2c  ing8,     0,  6,
a250: 20 20 30 7d 2c 20 20 20 20 2f 2a 20 34 20 2a 2f    0},    /* 4 */
a260: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f  .            { O
a270: 50 5f 43 6f 6e 63 61 74 2c 20 20 20 20 20 20 34  P_Concat,      4
a280: 2c 20 20 33 2c 20 20 33 7d 2c 0a 20 20 20 20 20  ,  3,  3},.     
a290: 20 20 20 20 20 20 20 7b 20 4f 50 5f 43 6f 6e 63         { OP_Conc
a2a0: 61 74 2c 20 20 20 20 20 20 35 2c 20 20 33 2c 20  at,      5,  3, 
a2b0: 20 33 7d 2c 0a 20 20 20 20 20 20 20 20 20 20 20   3},.           
a2c0: 20 7b 20 4f 50 5f 43 6f 6e 63 61 74 2c 20 20 20   { OP_Concat,   
a2d0: 20 20 20 36 2c 20 20 33 2c 20 20 33 7d 2c 0a 20     6,  3,  3},. 
a2e0: 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f             { OP_
a2f0: 52 65 73 75 6c 74 52 6f 77 2c 20 20 20 33 2c 20  ResultRow,   3, 
a300: 20 31 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20   1,  0},.       
a310: 20 20 20 20 20 7b 20 4f 50 5f 49 66 50 6f 73 2c       { OP_IfPos,
a320: 20 20 20 20 20 20 20 31 2c 20 20 30 2c 20 20 30         1,  0,  0
a330: 7d 2c 20 20 20 20 2f 2a 20 39 20 2a 2f 0a 20 20  },    /* 9 */.  
a340: 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 48            { OP_H
a350: 61 6c 74 2c 20 20 20 20 20 20 20 20 30 2c 20 20  alt,        0,  
a360: 30 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20  0,  0},.        
a370: 20 20 7d 3b 0a 20 20 20 20 20 20 20 20 20 20 72    };.          r
a380: 31 20 3d 20 73 71 6c 69 74 65 33 47 65 6e 65 72  1 = sqlite3Gener
a390: 61 74 65 49 6e 64 65 78 4b 65 79 28 70 50 61 72  ateIndexKey(pPar
a3a0: 73 65 2c 20 70 49 64 78 2c 20 31 2c 20 33 2c 20  se, pIdx, 1, 3, 
a3b0: 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 6a 6d  0);.          jm
a3c0: 70 32 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65  p2 = sqlite3Vdbe
a3d0: 41 64 64 4f 70 34 49 6e 74 28 76 2c 20 4f 50 5f  AddOp4Int(v, OP_
a3e0: 46 6f 75 6e 64 2c 20 6a 2b 32 2c 20 30 2c 20 72  Found, j+2, 0, r
a3f0: 31 2c 20 70 49 64 78 2d 3e 6e 43 6f 6c 75 6d 6e  1, pIdx->nColumn
a400: 2b 31 29 3b 0a 20 20 20 20 20 20 20 20 20 20 61  +1);.          a
a410: 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56 64 62  ddr = sqlite3Vdb
a420: 65 41 64 64 4f 70 4c 69 73 74 28 76 2c 20 41 72  eAddOpList(v, Ar
a430: 72 61 79 53 69 7a 65 28 69 64 78 45 72 72 29 2c  raySize(idxErr),
a440: 20 69 64 78 45 72 72 29 3b 0a 20 20 20 20 20 20   idxErr);.      
a450: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43      sqlite3VdbeC
a460: 68 61 6e 67 65 50 34 28 76 2c 20 61 64 64 72 2b  hangeP4(v, addr+
a470: 31 2c 20 22 72 6f 77 69 64 20 22 2c 20 50 34 5f  1, "rowid ", P4_
a480: 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20  STATIC);.       
a490: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68     sqlite3VdbeCh
a4a0: 61 6e 67 65 50 34 28 76 2c 20 61 64 64 72 2b 33  angeP4(v, addr+3
a4b0: 2c 20 22 20 6d 69 73 73 69 6e 67 20 66 72 6f 6d  , " missing from
a4c0: 20 69 6e 64 65 78 20 22 2c 20 50 34 5f 53 54 41   index ", P4_STA
a4d0: 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 20 20  TIC);.          
a4e0: 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67  sqlite3VdbeChang
a4f0: 65 50 34 28 76 2c 20 61 64 64 72 2b 34 2c 20 70  eP4(v, addr+4, p
a500: 49 64 78 2d 3e 7a 4e 61 6d 65 2c 20 50 34 5f 53  Idx->zName, P4_S
a510: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20  TATIC);.        
a520: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d    sqlite3VdbeJum
a530: 70 48 65 72 65 28 76 2c 20 61 64 64 72 2b 39 29  pHere(v, addr+9)
a540: 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  ;.          sqli
a550: 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65 28  te3VdbeJumpHere(
a560: 76 2c 20 6a 6d 70 32 29 3b 0a 20 20 20 20 20 20  v, jmp2);.      
a570: 20 20 7d 0a 20 20 20 20 20 20 20 20 73 71 6c 69    }.        sqli
a580: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c  te3VdbeAddOp2(v,
a590: 20 4f 50 5f 4e 65 78 74 2c 20 31 2c 20 6c 6f 6f   OP_Next, 1, loo
a5a0: 70 54 6f 70 2b 31 29 3b 0a 20 20 20 20 20 20 20  pTop+1);.       
a5b0: 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70   sqlite3VdbeJump
a5c0: 48 65 72 65 28 76 2c 20 6c 6f 6f 70 54 6f 70 29  Here(v, loopTop)
a5d0: 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 6a 3d  ;.        for(j=
a5e0: 30 2c 20 70 49 64 78 3d 70 54 61 62 2d 3e 70 49  0, pIdx=pTab->pI
a5f0: 6e 64 65 78 3b 20 70 49 64 78 3b 20 70 49 64 78  ndex; pIdx; pIdx
a600: 3d 70 49 64 78 2d 3e 70 4e 65 78 74 2c 20 6a 2b  =pIdx->pNext, j+
a610: 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 73 74  +){.          st
a620: 61 74 69 63 20 63 6f 6e 73 74 20 56 64 62 65 4f  atic const VdbeO
a630: 70 4c 69 73 74 20 63 6e 74 49 64 78 5b 5d 20 3d  pList cntIdx[] =
a640: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
a650: 7b 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20  { OP_Integer,   
a660: 20 20 20 30 2c 20 20 33 2c 20 20 30 7d 2c 0a 20     0,  3,  0},. 
a670: 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f 50              { OP
a680: 5f 52 65 77 69 6e 64 2c 20 20 20 20 20 20 20 30  _Rewind,       0
a690: 2c 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a 20 31  ,  0,  0},  /* 1
a6a0: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20   */.            
a6b0: 20 7b 20 4f 50 5f 41 64 64 49 6d 6d 2c 20 20 20   { OP_AddImm,   
a6c0: 20 20 20 20 33 2c 20 20 31 2c 20 20 30 7d 2c 0a      3,  1,  0},.
a6d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f               { O
a6e0: 50 5f 4e 65 78 74 2c 20 20 20 20 20 20 20 20 20  P_Next,         
a6f0: 30 2c 20 20 30 2c 20 20 30 7d 2c 20 20 2f 2a 20  0,  0,  0},  /* 
a700: 33 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 20  3 */.           
a710: 20 20 7b 20 4f 50 5f 45 71 2c 20 20 20 20 20 20    { OP_Eq,      
a720: 20 20 20 20 20 32 2c 20 20 30 2c 20 20 33 7d 2c       2,  0,  3},
a730: 20 20 2f 2a 20 34 20 2a 2f 0a 20 20 20 20 20 20    /* 4 */.      
a740: 20 20 20 20 20 20 20 7b 20 4f 50 5f 41 64 64 49         { OP_AddI
a750: 6d 6d 2c 20 20 20 20 20 20 20 31 2c 20 2d 31 2c  mm,       1, -1,
a760: 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20 20 20    0},.          
a770: 20 20 20 7b 20 4f 50 5f 53 74 72 69 6e 67 38 2c     { OP_String8,
a780: 20 20 20 20 20 20 30 2c 20 20 32 2c 20 20 30 7d        0,  2,  0}
a790: 2c 20 20 2f 2a 20 36 20 2a 2f 0a 20 20 20 20 20  ,  /* 6 */.     
a7a0: 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 53 74 72          { OP_Str
a7b0: 69 6e 67 38 2c 20 20 20 20 20 20 30 2c 20 20 33  ing8,      0,  3
a7c0: 2c 20 20 30 7d 2c 20 20 2f 2a 20 37 20 2a 2f 0a  ,  0},  /* 7 */.
a7d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 4f               { O
a7e0: 50 5f 43 6f 6e 63 61 74 2c 20 20 20 20 20 20 20  P_Concat,       
a7f0: 33 2c 20 20 32 2c 20 20 32 7d 2c 0a 20 20 20 20  3,  2,  2},.    
a800: 20 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 52 65           { OP_Re
a810: 73 75 6c 74 52 6f 77 2c 20 20 20 20 32 2c 20 20  sultRow,    2,  
a820: 31 2c 20 20 30 7d 2c 0a 20 20 20 20 20 20 20 20  1,  0},.        
a830: 20 20 7d 3b 0a 20 20 20 20 20 20 20 20 20 20 61    };.          a
a840: 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56 64 62  ddr = sqlite3Vdb
a850: 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f 49 66  eAddOp1(v, OP_If
a860: 50 6f 73 2c 20 31 29 3b 0a 20 20 20 20 20 20 20  Pos, 1);.       
a870: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
a880: 64 4f 70 32 28 76 2c 20 4f 50 5f 48 61 6c 74 2c  dOp2(v, OP_Halt,
a890: 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20   0, 0);.        
a8a0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d    sqlite3VdbeJum
a8b0: 70 48 65 72 65 28 76 2c 20 61 64 64 72 29 3b 0a  pHere(v, addr);.
a8c0: 20 20 20 20 20 20 20 20 20 20 61 64 64 72 20 3d            addr =
a8d0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
a8e0: 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53 69  pList(v, ArraySi
a8f0: 7a 65 28 63 6e 74 49 64 78 29 2c 20 63 6e 74 49  ze(cntIdx), cntI
a900: 64 78 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73  dx);.          s
a910: 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65  qlite3VdbeChange
a920: 50 31 28 76 2c 20 61 64 64 72 2b 31 2c 20 6a 2b  P1(v, addr+1, j+
a930: 32 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71  2);.          sq
a940: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
a950: 32 28 76 2c 20 61 64 64 72 2b 31 2c 20 61 64 64  2(v, addr+1, add
a960: 72 2b 34 29 3b 0a 20 20 20 20 20 20 20 20 20 20  r+4);.          
a970: 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67  sqlite3VdbeChang
a980: 65 50 31 28 76 2c 20 61 64 64 72 2b 33 2c 20 6a  eP1(v, addr+3, j
a990: 2b 32 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73  +2);.          s
a9a0: 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65  qlite3VdbeChange
a9b0: 50 32 28 76 2c 20 61 64 64 72 2b 33 2c 20 61 64  P2(v, addr+3, ad
a9c0: 64 72 2b 32 29 3b 0a 20 20 20 20 20 20 20 20 20  dr+2);.         
a9d0: 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70   sqlite3VdbeJump
a9e0: 48 65 72 65 28 76 2c 20 61 64 64 72 2b 34 29 3b  Here(v, addr+4);
a9f0: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
aa00: 65 33 56 64 62 65 43 68 61 6e 67 65 50 34 28 76  e3VdbeChangeP4(v
aa10: 2c 20 61 64 64 72 2b 36 2c 20 0a 20 20 20 20 20  , addr+6, .     
aa20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
aa30: 22 77 72 6f 6e 67 20 23 20 6f 66 20 65 6e 74 72  "wrong # of entr
aa40: 69 65 73 20 69 6e 20 69 6e 64 65 78 20 22 2c 20  ies in index ", 
aa50: 50 34 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  P4_STATIC);.    
aa60: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
aa70: 65 43 68 61 6e 67 65 50 34 28 76 2c 20 61 64 64  eChangeP4(v, add
aa80: 72 2b 37 2c 20 70 49 64 78 2d 3e 7a 4e 61 6d 65  r+7, pIdx->zName
aa90: 2c 20 50 34 5f 53 54 41 54 49 43 29 3b 0a 20 20  , P4_STATIC);.  
aaa0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 20        }.      } 
aab0: 0a 20 20 20 20 7d 0a 20 20 20 20 61 64 64 72 20  .    }.    addr 
aac0: 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64  = sqlite3VdbeAdd
aad0: 4f 70 4c 69 73 74 28 76 2c 20 41 72 72 61 79 53  OpList(v, ArrayS
aae0: 69 7a 65 28 65 6e 64 43 6f 64 65 29 2c 20 65 6e  ize(endCode), en
aaf0: 64 43 6f 64 65 29 3b 0a 20 20 20 20 73 71 6c 69  dCode);.    sqli
ab00: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 32 28  te3VdbeChangeP2(
ab10: 76 2c 20 61 64 64 72 2c 20 2d 6d 78 45 72 72 29  v, addr, -mxErr)
ab20: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  ;.    sqlite3Vdb
ab30: 65 4a 75 6d 70 48 65 72 65 28 76 2c 20 61 64 64  eJumpHere(v, add
ab40: 72 2b 31 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  r+1);.    sqlite
ab50: 33 56 64 62 65 43 68 61 6e 67 65 50 34 28 76 2c  3VdbeChangeP4(v,
ab60: 20 61 64 64 72 2b 32 2c 20 22 6f 6b 22 2c 20 50   addr+2, "ok", P
ab70: 34 5f 53 54 41 54 49 43 29 3b 0a 20 20 7d 65 6c  4_STATIC);.  }el
ab80: 73 65 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c  se.#endif /* SQL
ab90: 49 54 45 5f 4f 4d 49 54 5f 49 4e 54 45 47 52 49  ITE_OMIT_INTEGRI
aba0: 54 59 5f 43 48 45 43 4b 20 2a 2f 0a 0a 23 69 66  TY_CHECK */..#if
abb0: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  ndef SQLITE_OMIT
abc0: 5f 55 54 46 31 36 0a 20 20 2f 2a 0a 20 20 2a 2a  _UTF16.  /*.  **
abd0: 20 20 20 50 52 41 47 4d 41 20 65 6e 63 6f 64 69     PRAGMA encodi
abe0: 6e 67 0a 20 20 2a 2a 20 20 20 50 52 41 47 4d 41  ng.  **   PRAGMA
abf0: 20 65 6e 63 6f 64 69 6e 67 20 3d 20 22 75 74 66   encoding = "utf
ac00: 2d 38 22 7c 22 75 74 66 2d 31 36 22 7c 22 75 74  -8"|"utf-16"|"ut
ac10: 66 2d 31 36 6c 65 22 7c 22 75 74 66 2d 31 36 62  f-16le"|"utf-16b
ac20: 65 22 0a 20 20 2a 2a 0a 20 20 2a 2a 20 49 6e 20  e".  **.  ** In 
ac30: 69 74 73 20 66 69 72 73 74 20 66 6f 72 6d 2c 20  its first form, 
ac40: 74 68 69 73 20 70 72 61 67 6d 61 20 72 65 74 75  this pragma retu
ac50: 72 6e 73 20 74 68 65 20 65 6e 63 6f 64 69 6e 67  rns the encoding
ac60: 20 6f 66 20 74 68 65 20 6d 61 69 6e 0a 20 20 2a   of the main.  *
ac70: 2a 20 64 61 74 61 62 61 73 65 2e 20 49 66 20 74  * database. If t
ac80: 68 65 20 64 61 74 61 62 61 73 65 20 69 73 20 6e  he database is n
ac90: 6f 74 20 69 6e 69 74 69 61 6c 69 7a 65 64 2c 20  ot initialized, 
aca0: 69 74 20 69 73 20 69 6e 69 74 69 61 6c 69 7a 65  it is initialize
acb0: 64 20 6e 6f 77 2e 0a 20 20 2a 2a 0a 20 20 2a 2a  d now..  **.  **
acc0: 20 54 68 65 20 73 65 63 6f 6e 64 20 66 6f 72 6d   The second form
acd0: 20 6f 66 20 74 68 69 73 20 70 72 61 67 6d 61 20   of this pragma 
ace0: 69 73 20 61 20 6e 6f 2d 6f 70 20 69 66 20 74 68  is a no-op if th
acf0: 65 20 6d 61 69 6e 20 64 61 74 61 62 61 73 65 20  e main database 
ad00: 66 69 6c 65 0a 20 20 2a 2a 20 68 61 73 20 6e 6f  file.  ** has no
ad10: 74 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 69  t already been i
ad20: 6e 69 74 69 61 6c 69 7a 65 64 2e 20 49 6e 20 74  nitialized. In t
ad30: 68 69 73 20 63 61 73 65 20 69 74 20 73 65 74 73  his case it sets
ad40: 20 74 68 65 20 64 65 66 61 75 6c 74 0a 20 20 2a   the default.  *
ad50: 2a 20 65 6e 63 6f 64 69 6e 67 20 74 68 61 74 20  * encoding that 
ad60: 77 69 6c 6c 20 62 65 20 75 73 65 64 20 66 6f 72  will be used for
ad70: 20 74 68 65 20 6d 61 69 6e 20 64 61 74 61 62 61   the main databa
ad80: 73 65 20 66 69 6c 65 20 69 66 20 61 20 6e 65 77  se file if a new
ad90: 20 66 69 6c 65 0a 20 20 2a 2a 20 69 73 20 63 72   file.  ** is cr
ada0: 65 61 74 65 64 2e 20 49 66 20 61 6e 20 65 78 69  eated. If an exi
adb0: 73 74 69 6e 67 20 6d 61 69 6e 20 64 61 74 61 62  sting main datab
adc0: 61 73 65 20 66 69 6c 65 20 69 73 20 6f 70 65 6e  ase file is open
add0: 65 64 2c 20 74 68 65 6e 20 74 68 65 0a 20 20 2a  ed, then the.  *
ade0: 2a 20 64 65 66 61 75 6c 74 20 74 65 78 74 20 65  * default text e
adf0: 6e 63 6f 64 69 6e 67 20 66 6f 72 20 74 68 65 20  ncoding for the 
ae00: 65 78 69 73 74 69 6e 67 20 64 61 74 61 62 61 73  existing databas
ae10: 65 20 69 73 20 75 73 65 64 2e 0a 20 20 2a 2a 20  e is used..  ** 
ae20: 0a 20 20 2a 2a 20 49 6e 20 61 6c 6c 20 63 61 73  .  ** In all cas
ae30: 65 73 20 6e 65 77 20 64 61 74 61 62 61 73 65 73  es new databases
ae40: 20 63 72 65 61 74 65 64 20 75 73 69 6e 67 20 74   created using t
ae50: 68 65 20 41 54 54 41 43 48 20 63 6f 6d 6d 61 6e  he ATTACH comman
ae60: 64 20 61 72 65 0a 20 20 2a 2a 20 63 72 65 61 74  d are.  ** creat
ae70: 65 64 20 74 6f 20 75 73 65 20 74 68 65 20 73 61  ed to use the sa
ae80: 6d 65 20 64 65 66 61 75 6c 74 20 74 65 78 74 20  me default text 
ae90: 65 6e 63 6f 64 69 6e 67 20 61 73 20 74 68 65 20  encoding as the 
aea0: 6d 61 69 6e 20 64 61 74 61 62 61 73 65 2e 20 49  main database. I
aeb0: 66 0a 20 20 2a 2a 20 74 68 65 20 6d 61 69 6e 20  f.  ** the main 
aec0: 64 61 74 61 62 61 73 65 20 68 61 73 20 6e 6f 74  database has not
aed0: 20 62 65 65 6e 20 69 6e 69 74 69 61 6c 69 7a 65   been initialize
aee0: 64 20 61 6e 64 2f 6f 72 20 63 72 65 61 74 65 64  d and/or created
aef0: 20 77 68 65 6e 20 41 54 54 41 43 48 0a 20 20 2a   when ATTACH.  *
af00: 2a 20 69 73 20 65 78 65 63 75 74 65 64 2c 20 74  * is executed, t
af10: 68 69 73 20 69 73 20 64 6f 6e 65 20 62 65 66 6f  his is done befo
af20: 72 65 20 74 68 65 20 41 54 54 41 43 48 20 6f 70  re the ATTACH op
af30: 65 72 61 74 69 6f 6e 2e 0a 20 20 2a 2a 0a 20 20  eration..  **.  
af40: 2a 2a 20 49 6e 20 74 68 65 20 73 65 63 6f 6e 64  ** In the second
af50: 20 66 6f 72 6d 20 74 68 69 73 20 70 72 61 67 6d   form this pragm
af60: 61 20 73 65 74 73 20 74 68 65 20 74 65 78 74 20  a sets the text 
af70: 65 6e 63 6f 64 69 6e 67 20 74 6f 20 62 65 20 75  encoding to be u
af80: 73 65 64 20 69 6e 0a 20 20 2a 2a 20 6e 65 77 20  sed in.  ** new 
af90: 64 61 74 61 62 61 73 65 20 66 69 6c 65 73 20 63  database files c
afa0: 72 65 61 74 65 64 20 75 73 69 6e 67 20 74 68 69  reated using thi
afb0: 73 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c  s database handl
afc0: 65 2e 20 49 74 20 69 73 20 6f 6e 6c 79 0a 20 20  e. It is only.  
afd0: 2a 2a 20 75 73 65 66 75 6c 20 69 66 20 69 6e 76  ** useful if inv
afe0: 6f 6b 65 64 20 69 6d 6d 65 64 69 61 74 65 6c 79  oked immediately
aff0: 20 61 66 74 65 72 20 74 68 65 20 6d 61 69 6e 20   after the main 
b000: 64 61 74 61 62 61 73 65 20 69 0a 20 20 2a 2f 0a  database i.  */.
b010: 20 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72    if( sqlite3Str
b020: 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22 65 6e 63  ICmp(zLeft, "enc
b030: 6f 64 69 6e 67 22 29 3d 3d 30 20 29 7b 0a 20 20  oding")==0 ){.  
b040: 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20 73    static const s
b050: 74 72 75 63 74 20 45 6e 63 4e 61 6d 65 20 7b 0a  truct EncName {.
b060: 20 20 20 20 20 20 63 68 61 72 20 2a 7a 4e 61 6d        char *zNam
b070: 65 3b 0a 20 20 20 20 20 20 75 38 20 65 6e 63 3b  e;.      u8 enc;
b080: 0a 20 20 20 20 7d 20 65 6e 63 6e 61 6d 65 73 5b  .    } encnames[
b090: 5d 20 3d 20 7b 0a 20 20 20 20 20 20 7b 20 22 55  ] = {.      { "U
b0a0: 54 46 38 22 2c 20 20 20 20 20 53 51 4c 49 54 45  TF8",     SQLITE
b0b0: 5f 55 54 46 38 20 20 20 20 20 20 20 20 7d 2c 0a  _UTF8        },.
b0c0: 20 20 20 20 20 20 7b 20 22 55 54 46 2d 38 22 2c        { "UTF-8",
b0d0: 20 20 20 20 53 51 4c 49 54 45 5f 55 54 46 38 20      SQLITE_UTF8 
b0e0: 20 20 20 20 20 20 20 7d 2c 20 20 2f 2a 20 4d 75         },  /* Mu
b0f0: 73 74 20 62 65 20 65 6c 65 6d 65 6e 74 20 5b 31  st be element [1
b100: 5d 20 2a 2f 0a 20 20 20 20 20 20 7b 20 22 55 54  ] */.      { "UT
b110: 46 2d 31 36 6c 65 22 2c 20 53 51 4c 49 54 45 5f  F-16le", SQLITE_
b120: 55 54 46 31 36 4c 45 20 20 20 20 20 7d 2c 20 20  UTF16LE     },  
b130: 2f 2a 20 4d 75 73 74 20 62 65 20 65 6c 65 6d 65  /* Must be eleme
b140: 6e 74 20 5b 32 5d 20 2a 2f 0a 20 20 20 20 20 20  nt [2] */.      
b150: 7b 20 22 55 54 46 2d 31 36 62 65 22 2c 20 53 51  { "UTF-16be", SQ
b160: 4c 49 54 45 5f 55 54 46 31 36 42 45 20 20 20 20  LITE_UTF16BE    
b170: 20 7d 2c 20 20 2f 2a 20 4d 75 73 74 20 62 65 20   },  /* Must be 
b180: 65 6c 65 6d 65 6e 74 20 5b 33 5d 20 2a 2f 0a 20  element [3] */. 
b190: 20 20 20 20 20 7b 20 22 55 54 46 31 36 6c 65 22       { "UTF16le"
b1a0: 2c 20 20 53 51 4c 49 54 45 5f 55 54 46 31 36 4c  ,  SQLITE_UTF16L
b1b0: 45 20 20 20 20 20 7d 2c 0a 20 20 20 20 20 20 7b  E     },.      {
b1c0: 20 22 55 54 46 31 36 62 65 22 2c 20 20 53 51 4c   "UTF16be",  SQL
b1d0: 49 54 45 5f 55 54 46 31 36 42 45 20 20 20 20 20  ITE_UTF16BE     
b1e0: 7d 2c 0a 20 20 20 20 20 20 7b 20 22 55 54 46 2d  },.      { "UTF-
b1f0: 31 36 22 2c 20 20 20 30 20 20 20 20 20 20 20 20  16",   0        
b200: 20 20 20 20 20 20 20 20 20 20 7d 2c 20 2f 2a 20            }, /* 
b210: 53 51 4c 49 54 45 5f 55 54 46 31 36 4e 41 54 49  SQLITE_UTF16NATI
b220: 56 45 20 2a 2f 0a 20 20 20 20 20 20 7b 20 22 55  VE */.      { "U
b230: 54 46 31 36 22 2c 20 20 20 20 30 20 20 20 20 20  TF16",    0     
b240: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 20               }, 
b250: 2f 2a 20 53 51 4c 49 54 45 5f 55 54 46 31 36 4e  /* SQLITE_UTF16N
b260: 41 54 49 56 45 20 2a 2f 0a 20 20 20 20 20 20 7b  ATIVE */.      {
b270: 20 30 2c 20 30 20 7d 0a 20 20 20 20 7d 3b 0a 20   0, 0 }.    };. 
b280: 20 20 20 63 6f 6e 73 74 20 73 74 72 75 63 74 20     const struct 
b290: 45 6e 63 4e 61 6d 65 20 2a 70 45 6e 63 3b 0a 20  EncName *pEnc;. 
b2a0: 20 20 20 69 66 28 20 21 7a 52 69 67 68 74 20 29     if( !zRight )
b2b0: 7b 20 20 20 20 2f 2a 20 22 50 52 41 47 4d 41 20  {    /* "PRAGMA 
b2c0: 65 6e 63 6f 64 69 6e 67 22 20 2a 2f 0a 20 20 20  encoding" */.   
b2d0: 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 52 65     if( sqlite3Re
b2e0: 61 64 53 63 68 65 6d 61 28 70 50 61 72 73 65 29  adSchema(pParse)
b2f0: 20 29 20 67 6f 74 6f 20 70 72 61 67 6d 61 5f 6f   ) goto pragma_o
b300: 75 74 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  ut;.      sqlite
b310: 33 56 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28  3VdbeSetNumCols(
b320: 76 2c 20 31 29 3b 0a 20 20 20 20 20 20 73 71 6c  v, 1);.      sql
b330: 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61  ite3VdbeSetColNa
b340: 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d 45  me(v, 0, COLNAME
b350: 5f 4e 41 4d 45 2c 20 22 65 6e 63 6f 64 69 6e 67  _NAME, "encoding
b360: 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  ", SQLITE_STATIC
b370: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
b380: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
b390: 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20 31 29 3b  _String8, 0, 1);
b3a0: 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20 65  .      assert( e
b3b0: 6e 63 6e 61 6d 65 73 5b 53 51 4c 49 54 45 5f 55  ncnames[SQLITE_U
b3c0: 54 46 38 5d 2e 65 6e 63 3d 3d 53 51 4c 49 54 45  TF8].enc==SQLITE
b3d0: 5f 55 54 46 38 20 29 3b 0a 20 20 20 20 20 20 61  _UTF8 );.      a
b3e0: 73 73 65 72 74 28 20 65 6e 63 6e 61 6d 65 73 5b  ssert( encnames[
b3f0: 53 51 4c 49 54 45 5f 55 54 46 31 36 4c 45 5d 2e  SQLITE_UTF16LE].
b400: 65 6e 63 3d 3d 53 51 4c 49 54 45 5f 55 54 46 31  enc==SQLITE_UTF1
b410: 36 4c 45 20 29 3b 0a 20 20 20 20 20 20 61 73 73  6LE );.      ass
b420: 65 72 74 28 20 65 6e 63 6e 61 6d 65 73 5b 53 51  ert( encnames[SQ
b430: 4c 49 54 45 5f 55 54 46 31 36 42 45 5d 2e 65 6e  LITE_UTF16BE].en
b440: 63 3d 3d 53 51 4c 49 54 45 5f 55 54 46 31 36 42  c==SQLITE_UTF16B
b450: 45 20 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  E );.      sqlit
b460: 65 33 56 64 62 65 43 68 61 6e 67 65 50 34 28 76  e3VdbeChangeP4(v
b470: 2c 20 2d 31 2c 20 65 6e 63 6e 61 6d 65 73 5b 45  , -1, encnames[E
b480: 4e 43 28 70 50 61 72 73 65 2d 3e 64 62 29 5d 2e  NC(pParse->db)].
b490: 7a 4e 61 6d 65 2c 20 50 34 5f 53 54 41 54 49 43  zName, P4_STATIC
b4a0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
b4b0: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
b4c0: 5f 52 65 73 75 6c 74 52 6f 77 2c 20 31 2c 20 31  _ResultRow, 1, 1
b4d0: 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 20 20 20  );.    }else{   
b4e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
b4f0: 20 20 20 20 20 2f 2a 20 22 50 52 41 47 4d 41 20       /* "PRAGMA 
b500: 65 6e 63 6f 64 69 6e 67 20 3d 20 58 58 58 22 20  encoding = XXX" 
b510: 2a 2f 0a 20 20 20 20 20 20 2f 2a 20 4f 6e 6c 79  */.      /* Only
b520: 20 63 68 61 6e 67 65 20 74 68 65 20 76 61 6c 75   change the valu
b530: 65 20 6f 66 20 73 71 6c 69 74 65 2e 65 6e 63 20  e of sqlite.enc 
b540: 69 66 20 74 68 65 20 64 61 74 61 62 61 73 65 20  if the database 
b550: 68 61 6e 64 6c 65 20 69 73 20 6e 6f 74 0a 20 20  handle is not.  
b560: 20 20 20 20 2a 2a 20 69 6e 69 74 69 61 6c 69 7a      ** initializ
b570: 65 64 2e 20 49 66 20 74 68 65 20 6d 61 69 6e 20  ed. If the main 
b580: 64 61 74 61 62 61 73 65 20 65 78 69 73 74 73 2c  database exists,
b590: 20 74 68 65 20 6e 65 77 20 73 71 6c 69 74 65 2e   the new sqlite.
b5a0: 65 6e 63 20 76 61 6c 75 65 0a 20 20 20 20 20 20  enc value.      
b5b0: 2a 2a 20 77 69 6c 6c 20 62 65 20 6f 76 65 72 77  ** will be overw
b5c0: 72 69 74 74 65 6e 20 77 68 65 6e 20 74 68 65 20  ritten when the 
b5d0: 73 63 68 65 6d 61 20 69 73 20 6e 65 78 74 20 6c  schema is next l
b5e0: 6f 61 64 65 64 2e 20 49 66 20 69 74 20 64 6f 65  oaded. If it doe
b5f0: 73 20 6e 6f 74 0a 20 20 20 20 20 20 2a 2a 20 61  s not.      ** a
b600: 6c 72 65 61 64 79 20 65 78 69 73 74 73 2c 20 69  lready exists, i
b610: 74 20 77 69 6c 6c 20 62 65 20 63 72 65 61 74 65  t will be create
b620: 64 20 74 6f 20 75 73 65 20 74 68 65 20 6e 65 77  d to use the new
b630: 20 65 6e 63 6f 64 69 6e 67 20 76 61 6c 75 65 2e   encoding value.
b640: 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20  .      */.      
b650: 69 66 28 20 0a 20 20 20 20 20 20 20 20 21 28 44  if( .        !(D
b660: 62 48 61 73 50 72 6f 70 65 72 74 79 28 64 62 2c  bHasProperty(db,
b670: 20 30 2c 20 44 42 5f 53 63 68 65 6d 61 4c 6f 61   0, DB_SchemaLoa
b680: 64 65 64 29 29 20 7c 7c 20 0a 20 20 20 20 20 20  ded)) || .      
b690: 20 20 44 62 48 61 73 50 72 6f 70 65 72 74 79 28    DbHasProperty(
b6a0: 64 62 2c 20 30 2c 20 44 42 5f 45 6d 70 74 79 29  db, 0, DB_Empty)
b6b0: 20 0a 20 20 20 20 20 20 29 7b 0a 20 20 20 20 20   .      ){.     
b6c0: 20 20 20 66 6f 72 28 70 45 6e 63 3d 26 65 6e 63     for(pEnc=&enc
b6d0: 6e 61 6d 65 73 5b 30 5d 3b 20 70 45 6e 63 2d 3e  names[0]; pEnc->
b6e0: 7a 4e 61 6d 65 3b 20 70 45 6e 63 2b 2b 29 7b 0a  zName; pEnc++){.
b6f0: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 30 3d            if( 0=
b700: 3d 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28  =sqlite3StrICmp(
b710: 7a 52 69 67 68 74 2c 20 70 45 6e 63 2d 3e 7a 4e  zRight, pEnc->zN
b720: 61 6d 65 29 20 29 7b 0a 20 20 20 20 20 20 20 20  ame) ){.        
b730: 20 20 20 20 45 4e 43 28 70 50 61 72 73 65 2d 3e      ENC(pParse->
b740: 64 62 29 20 3d 20 70 45 6e 63 2d 3e 65 6e 63 20  db) = pEnc->enc 
b750: 3f 20 70 45 6e 63 2d 3e 65 6e 63 20 3a 20 53 51  ? pEnc->enc : SQ
b760: 4c 49 54 45 5f 55 54 46 31 36 4e 41 54 49 56 45  LITE_UTF16NATIVE
b770: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 62 72  ;.            br
b780: 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  eak;.          }
b790: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
b7a0: 20 20 20 69 66 28 20 21 70 45 6e 63 2d 3e 7a 4e     if( !pEnc->zN
b7b0: 61 6d 65 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ame ){.         
b7c0: 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67   sqlite3ErrorMsg
b7d0: 28 70 50 61 72 73 65 2c 20 22 75 6e 73 75 70 70  (pParse, "unsupp
b7e0: 6f 72 74 65 64 20 65 6e 63 6f 64 69 6e 67 3a 20  orted encoding: 
b7f0: 25 73 22 2c 20 7a 52 69 67 68 74 29 3b 0a 20 20  %s", zRight);.  
b800: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
b810: 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 23 65      }.  }else.#e
b820: 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f  ndif /* SQLITE_O
b830: 4d 49 54 5f 55 54 46 31 36 20 2a 2f 0a 0a 23 69  MIT_UTF16 */..#i
b840: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
b850: 54 5f 53 43 48 45 4d 41 5f 56 45 52 53 49 4f 4e  T_SCHEMA_VERSION
b860: 5f 50 52 41 47 4d 41 53 0a 20 20 2f 2a 0a 20 20  _PRAGMAS.  /*.  
b870: 2a 2a 20 20 20 50 52 41 47 4d 41 20 5b 64 61 74  **   PRAGMA [dat
b880: 61 62 61 73 65 2e 5d 73 63 68 65 6d 61 5f 76 65  abase.]schema_ve
b890: 72 73 69 6f 6e 0a 20 20 2a 2a 20 20 20 50 52 41  rsion.  **   PRA
b8a0: 47 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 73  GMA [database.]s
b8b0: 63 68 65 6d 61 5f 76 65 72 73 69 6f 6e 20 3d 20  chema_version = 
b8c0: 3c 69 6e 74 65 67 65 72 3e 0a 20 20 2a 2a 0a 20  <integer>.  **. 
b8d0: 20 2a 2a 20 20 20 50 52 41 47 4d 41 20 5b 64 61   **   PRAGMA [da
b8e0: 74 61 62 61 73 65 2e 5d 75 73 65 72 5f 76 65 72  tabase.]user_ver
b8f0: 73 69 6f 6e 0a 20 20 2a 2a 20 20 20 50 52 41 47  sion.  **   PRAG
b900: 4d 41 20 5b 64 61 74 61 62 61 73 65 2e 5d 75 73  MA [database.]us
b910: 65 72 5f 76 65 72 73 69 6f 6e 20 3d 20 3c 69 6e  er_version = <in
b920: 74 65 67 65 72 3e 0a 20 20 2a 2a 0a 20 20 2a 2a  teger>.  **.  **
b930: 20 54 68 65 20 70 72 61 67 6d 61 27 73 20 73 63   The pragma's sc
b940: 68 65 6d 61 5f 76 65 72 73 69 6f 6e 20 61 6e 64  hema_version and
b950: 20 75 73 65 72 5f 76 65 72 73 69 6f 6e 20 61 72   user_version ar
b960: 65 20 75 73 65 64 20 74 6f 20 73 65 74 20 6f 72  e used to set or
b970: 20 67 65 74 0a 20 20 2a 2a 20 74 68 65 20 76 61   get.  ** the va
b980: 6c 75 65 20 6f 66 20 74 68 65 20 73 63 68 65 6d  lue of the schem
b990: 61 2d 76 65 72 73 69 6f 6e 20 61 6e 64 20 75 73  a-version and us
b9a0: 65 72 2d 76 65 72 73 69 6f 6e 2c 20 72 65 73 70  er-version, resp
b9b0: 65 63 74 69 76 65 6c 79 2e 20 42 6f 74 68 0a 20  ectively. Both. 
b9c0: 20 2a 2a 20 74 68 65 20 73 63 68 65 6d 61 2d 76   ** the schema-v
b9d0: 65 72 73 69 6f 6e 20 61 6e 64 20 74 68 65 20 75  ersion and the u
b9e0: 73 65 72 2d 76 65 72 73 69 6f 6e 20 61 72 65 20  ser-version are 
b9f0: 33 32 2d 62 69 74 20 73 69 67 6e 65 64 20 69 6e  32-bit signed in
ba00: 74 65 67 65 72 73 0a 20 20 2a 2a 20 73 74 6f 72  tegers.  ** stor
ba10: 65 64 20 69 6e 20 74 68 65 20 64 61 74 61 62 61  ed in the databa
ba20: 73 65 20 68 65 61 64 65 72 2e 0a 20 20 2a 2a 0a  se header..  **.
ba30: 20 20 2a 2a 20 54 68 65 20 73 63 68 65 6d 61 2d    ** The schema-
ba40: 63 6f 6f 6b 69 65 20 69 73 20 75 73 75 61 6c 6c  cookie is usuall
ba50: 79 20 6f 6e 6c 79 20 6d 61 6e 69 70 75 6c 61 74  y only manipulat
ba60: 65 64 20 69 6e 74 65 72 6e 61 6c 6c 79 20 62 79  ed internally by
ba70: 20 53 51 4c 69 74 65 2e 20 49 74 0a 20 20 2a 2a   SQLite. It.  **
ba80: 20 69 73 20 69 6e 63 72 65 6d 65 6e 74 65 64 20   is incremented 
ba90: 62 79 20 53 51 4c 69 74 65 20 77 68 65 6e 65 76  by SQLite whenev
baa0: 65 72 20 74 68 65 20 64 61 74 61 62 61 73 65 20  er the database 
bab0: 73 63 68 65 6d 61 20 69 73 20 6d 6f 64 69 66 69  schema is modifi
bac0: 65 64 20 28 62 79 0a 20 20 2a 2a 20 63 72 65 61  ed (by.  ** crea
bad0: 74 69 6e 67 20 6f 72 20 64 72 6f 70 70 69 6e 67  ting or dropping
bae0: 20 61 20 74 61 62 6c 65 20 6f 72 20 69 6e 64 65   a table or inde
baf0: 78 29 2e 20 54 68 65 20 73 63 68 65 6d 61 20 76  x). The schema v
bb00: 65 72 73 69 6f 6e 20 69 73 20 75 73 65 64 20 62  ersion is used b
bb10: 79 0a 20 20 2a 2a 20 53 51 4c 69 74 65 20 65 61  y.  ** SQLite ea
bb20: 63 68 20 74 69 6d 65 20 61 20 71 75 65 72 79 20  ch time a query 
bb30: 69 73 20 65 78 65 63 75 74 65 64 20 74 6f 20 65  is executed to e
bb40: 6e 73 75 72 65 20 74 68 61 74 20 74 68 65 20 69  nsure that the i
bb50: 6e 74 65 72 6e 61 6c 20 63 61 63 68 65 0a 20 20  nternal cache.  
bb60: 2a 2a 20 6f 66 20 74 68 65 20 73 63 68 65 6d 61  ** of the schema
bb70: 20 75 73 65 64 20 77 68 65 6e 20 63 6f 6d 70 69   used when compi
bb80: 6c 69 6e 67 20 74 68 65 20 53 51 4c 20 71 75 65  ling the SQL que
bb90: 72 79 20 6d 61 74 63 68 65 73 20 74 68 65 20 73  ry matches the s
bba0: 63 68 65 6d 61 20 6f 66 0a 20 20 2a 2a 20 74 68  chema of.  ** th
bbb0: 65 20 64 61 74 61 62 61 73 65 20 61 67 61 69 6e  e database again
bbc0: 73 74 20 77 68 69 63 68 20 74 68 65 20 63 6f 6d  st which the com
bbd0: 70 69 6c 65 64 20 71 75 65 72 79 20 69 73 20 61  piled query is a
bbe0: 63 74 75 61 6c 6c 79 20 65 78 65 63 75 74 65 64  ctually executed
bbf0: 2e 0a 20 20 2a 2a 20 53 75 62 76 65 72 74 69 6e  ..  ** Subvertin
bc00: 67 20 74 68 69 73 20 6d 65 63 68 61 6e 69 73 6d  g this mechanism
bc10: 20 62 79 20 75 73 69 6e 67 20 22 50 52 41 47 4d   by using "PRAGM
bc20: 41 20 73 63 68 65 6d 61 5f 76 65 72 73 69 6f 6e  A schema_version
bc30: 22 20 74 6f 20 6d 6f 64 69 66 79 0a 20 20 2a 2a  " to modify.  **
bc40: 20 74 68 65 20 73 63 68 65 6d 61 2d 76 65 72 73   the schema-vers
bc50: 69 6f 6e 20 69 73 20 70 6f 74 65 6e 74 69 61 6c  ion is potential
bc60: 6c 79 20 64 61 6e 67 65 72 6f 75 73 20 61 6e 64  ly dangerous and
bc70: 20 6d 61 79 20 6c 65 61 64 20 74 6f 20 70 72 6f   may lead to pro
bc80: 67 72 61 6d 0a 20 20 2a 2a 20 63 72 61 73 68 65  gram.  ** crashe
bc90: 73 20 6f 72 20 64 61 74 61 62 61 73 65 20 63 6f  s or database co
bca0: 72 72 75 70 74 69 6f 6e 2e 20 55 73 65 20 77 69  rruption. Use wi
bcb0: 74 68 20 63 61 75 74 69 6f 6e 21 0a 20 20 2a 2a  th caution!.  **
bcc0: 0a 20 20 2a 2a 20 54 68 65 20 75 73 65 72 2d 76  .  ** The user-v
bcd0: 65 72 73 69 6f 6e 20 69 73 20 6e 6f 74 20 75 73  ersion is not us
bce0: 65 64 20 69 6e 74 65 72 6e 61 6c 6c 79 20 62 79  ed internally by
bcf0: 20 53 51 4c 69 74 65 2e 20 49 74 20 6d 61 79 20   SQLite. It may 
bd00: 62 65 20 75 73 65 64 20 62 79 0a 20 20 2a 2a 20  be used by.  ** 
bd10: 61 70 70 6c 69 63 61 74 69 6f 6e 73 20 66 6f 72  applications for
bd20: 20 61 6e 79 20 70 75 72 70 6f 73 65 2e 0a 20 20   any purpose..  
bd30: 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33  */.  if( sqlite3
bd40: 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22  StrICmp(zLeft, "
bd50: 73 63 68 65 6d 61 5f 76 65 72 73 69 6f 6e 22 29  schema_version")
bd60: 3d 3d 30 20 0a 20 20 20 7c 7c 20 73 71 6c 69 74  ==0 .   || sqlit
bd70: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
bd80: 20 22 75 73 65 72 5f 76 65 72 73 69 6f 6e 22 29   "user_version")
bd90: 3d 3d 30 20 0a 20 20 20 7c 7c 20 73 71 6c 69 74  ==0 .   || sqlit
bda0: 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c  e3StrICmp(zLeft,
bdb0: 20 22 66 72 65 65 6c 69 73 74 5f 63 6f 75 6e 74   "freelist_count
bdc0: 22 29 3d 3d 30 20 0a 20 20 29 7b 0a 20 20 20 20  ")==0 .  ){.    
bdd0: 69 6e 74 20 69 43 6f 6f 6b 69 65 3b 20 20 20 2f  int iCookie;   /
bde0: 2a 20 43 6f 6f 6b 69 65 20 69 6e 64 65 78 2e 20  * Cookie index. 
bdf0: 31 20 66 6f 72 20 73 63 68 65 6d 61 2d 63 6f 6f  1 for schema-coo
be00: 6b 69 65 2c 20 36 20 66 6f 72 20 75 73 65 72 2d  kie, 6 for user-
be10: 63 6f 6f 6b 69 65 2e 20 2a 2f 0a 20 20 20 20 73  cookie. */.    s
be20: 71 6c 69 74 65 33 56 64 62 65 55 73 65 73 42 74  qlite3VdbeUsesBt
be30: 72 65 65 28 76 2c 20 69 44 62 29 3b 0a 20 20 20  ree(v, iDb);.   
be40: 20 73 77 69 74 63 68 28 20 7a 4c 65 66 74 5b 30   switch( zLeft[0
be50: 5d 20 29 7b 0a 20 20 20 20 20 20 63 61 73 65 20  ] ){.      case 
be60: 27 66 27 3a 20 63 61 73 65 20 27 46 27 3a 0a 20  'f': case 'F':. 
be70: 20 20 20 20 20 20 20 69 43 6f 6f 6b 69 65 20 3d         iCookie =
be80: 20 42 54 52 45 45 5f 46 52 45 45 5f 50 41 47 45   BTREE_FREE_PAGE
be90: 5f 43 4f 55 4e 54 3b 0a 20 20 20 20 20 20 20 20  _COUNT;.        
bea0: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 63 61 73  break;.      cas
beb0: 65 20 27 73 27 3a 20 63 61 73 65 20 27 53 27 3a  e 's': case 'S':
bec0: 0a 20 20 20 20 20 20 20 20 69 43 6f 6f 6b 69 65  .        iCookie
bed0: 20 3d 20 42 54 52 45 45 5f 53 43 48 45 4d 41 5f   = BTREE_SCHEMA_
bee0: 56 45 52 53 49 4f 4e 3b 0a 20 20 20 20 20 20 20  VERSION;.       
bef0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 64 65   break;.      de
bf00: 66 61 75 6c 74 3a 0a 20 20 20 20 20 20 20 20 69  fault:.        i
bf10: 43 6f 6f 6b 69 65 20 3d 20 42 54 52 45 45 5f 55  Cookie = BTREE_U
bf20: 53 45 52 5f 56 45 52 53 49 4f 4e 3b 0a 20 20 20  SER_VERSION;.   
bf30: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
bf40: 7d 0a 0a 20 20 20 20 69 66 28 20 7a 52 69 67 68  }..    if( zRigh
bf50: 74 20 26 26 20 69 43 6f 6f 6b 69 65 21 3d 42 54  t && iCookie!=BT
bf60: 52 45 45 5f 46 52 45 45 5f 50 41 47 45 5f 43 4f  REE_FREE_PAGE_CO
bf70: 55 4e 54 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20  UNT ){.      /* 
bf80: 57 72 69 74 65 20 74 68 65 20 73 70 65 63 69 66  Write the specif
bf90: 69 65 64 20 63 6f 6f 6b 69 65 20 76 61 6c 75 65  ied cookie value
bfa0: 20 2a 2f 0a 20 20 20 20 20 20 73 74 61 74 69 63   */.      static
bfb0: 20 63 6f 6e 73 74 20 56 64 62 65 4f 70 4c 69 73   const VdbeOpLis
bfc0: 74 20 73 65 74 43 6f 6f 6b 69 65 5b 5d 20 3d 20  t setCookie[] = 
bfd0: 7b 0a 20 20 20 20 20 20 20 20 7b 20 4f 50 5f 54  {.        { OP_T
bfe0: 72 61 6e 73 61 63 74 69 6f 6e 2c 20 20 20 20 30  ransaction,    0
bff0: 2c 20 20 31 2c 20 20 30 7d 2c 20 20 20 20 2f 2a  ,  1,  0},    /*
c000: 20 30 20 2a 2f 0a 20 20 20 20 20 20 20 20 7b 20   0 */.        { 
c010: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 20 20 20 20  OP_Integer,     
c020: 20 20 20 30 2c 20 20 31 2c 20 20 30 7d 2c 20 20     0,  1,  0},  
c030: 20 20 2f 2a 20 31 20 2a 2f 0a 20 20 20 20 20 20    /* 1 */.      
c040: 20 20 7b 20 4f 50 5f 53 65 74 43 6f 6f 6b 69 65    { OP_SetCookie
c050: 2c 20 20 20 20 20 20 30 2c 20 20 30 2c 20 20 31  ,      0,  0,  1
c060: 7d 2c 20 20 20 20 2f 2a 20 32 20 2a 2f 0a 20 20  },    /* 2 */.  
c070: 20 20 20 20 7d 3b 0a 20 20 20 20 20 20 69 6e 74      };.      int
c080: 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65 33 56   addr = sqlite3V
c090: 64 62 65 41 64 64 4f 70 4c 69 73 74 28 76 2c 20  dbeAddOpList(v, 
c0a0: 41 72 72 61 79 53 69 7a 65 28 73 65 74 43 6f 6f  ArraySize(setCoo
c0b0: 6b 69 65 29 2c 20 73 65 74 43 6f 6f 6b 69 65 29  kie), setCookie)
c0c0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
c0d0: 64 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20 61  dbeChangeP1(v, a
c0e0: 64 64 72 2c 20 69 44 62 29 3b 0a 20 20 20 20 20  ddr, iDb);.     
c0f0: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
c100: 67 65 50 31 28 76 2c 20 61 64 64 72 2b 31 2c 20  geP1(v, addr+1, 
c110: 61 74 6f 69 28 7a 52 69 67 68 74 29 29 3b 0a 20  atoi(zRight));. 
c120: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
c130: 43 68 61 6e 67 65 50 31 28 76 2c 20 61 64 64 72  ChangeP1(v, addr
c140: 2b 32 2c 20 69 44 62 29 3b 0a 20 20 20 20 20 20  +2, iDb);.      
c150: 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67  sqlite3VdbeChang
c160: 65 50 32 28 76 2c 20 61 64 64 72 2b 32 2c 20 69  eP2(v, addr+2, i
c170: 43 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 7d 65 6c  Cookie);.    }el
c180: 73 65 7b 0a 20 20 20 20 20 20 2f 2a 20 52 65 61  se{.      /* Rea
c190: 64 20 74 68 65 20 73 70 65 63 69 66 69 65 64 20  d the specified 
c1a0: 63 6f 6f 6b 69 65 20 76 61 6c 75 65 20 2a 2f 0a  cookie value */.
c1b0: 20 20 20 20 20 20 73 74 61 74 69 63 20 63 6f 6e        static con
c1c0: 73 74 20 56 64 62 65 4f 70 4c 69 73 74 20 72 65  st VdbeOpList re
c1d0: 61 64 43 6f 6f 6b 69 65 5b 5d 20 3d 20 7b 0a 20  adCookie[] = {. 
c1e0: 20 20 20 20 20 20 20 7b 20 4f 50 5f 54 72 61 6e         { OP_Tran
c1f0: 73 61 63 74 69 6f 6e 2c 20 20 20 20 20 30 2c 20  saction,     0, 
c200: 20 30 2c 20 20 30 7d 2c 20 20 20 20 2f 2a 20 30   0,  0},    /* 0
c210: 20 2a 2f 0a 20 20 20 20 20 20 20 20 7b 20 4f 50   */.        { OP
c220: 5f 52 65 61 64 43 6f 6f 6b 69 65 2c 20 20 20 20  _ReadCookie,    
c230: 20 20 30 2c 20 20 31 2c 20 20 30 7d 2c 20 20 20    0,  1,  0},   
c240: 20 2f 2a 20 31 20 2a 2f 0a 20 20 20 20 20 20 20   /* 1 */.       
c250: 20 7b 20 4f 50 5f 52 65 73 75 6c 74 52 6f 77 2c   { OP_ResultRow,
c260: 20 20 20 20 20 20 20 31 2c 20 20 31 2c 20 20 30         1,  1,  0
c270: 7d 0a 20 20 20 20 20 20 7d 3b 0a 20 20 20 20 20  }.      };.     
c280: 20 69 6e 74 20 61 64 64 72 20 3d 20 73 71 6c 69   int addr = sqli
c290: 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74  te3VdbeAddOpList
c2a0: 28 76 2c 20 41 72 72 61 79 53 69 7a 65 28 72 65  (v, ArraySize(re
c2b0: 61 64 43 6f 6f 6b 69 65 29 2c 20 72 65 61 64 43  adCookie), readC
c2c0: 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 20 20 73 71  ookie);.      sq
c2d0: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
c2e0: 31 28 76 2c 20 61 64 64 72 2c 20 69 44 62 29 3b  1(v, addr, iDb);
c2f0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
c300: 62 65 43 68 61 6e 67 65 50 31 28 76 2c 20 61 64  beChangeP1(v, ad
c310: 64 72 2b 31 2c 20 69 44 62 29 3b 0a 20 20 20 20  dr+1, iDb);.    
c320: 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61    sqlite3VdbeCha
c330: 6e 67 65 50 33 28 76 2c 20 61 64 64 72 2b 31 2c  ngeP3(v, addr+1,
c340: 20 69 43 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 20   iCookie);.     
c350: 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 4e   sqlite3VdbeSetN
c360: 75 6d 43 6f 6c 73 28 76 2c 20 31 29 3b 0a 20 20  umCols(v, 1);.  
c370: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 53      sqlite3VdbeS
c380: 65 74 43 6f 6c 4e 61 6d 65 28 76 2c 20 30 2c 20  etColName(v, 0, 
c390: 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 2c 20 7a 4c  COLNAME_NAME, zL
c3a0: 65 66 74 2c 20 53 51 4c 49 54 45 5f 54 52 41 4e  eft, SQLITE_TRAN
c3b0: 53 49 45 4e 54 29 3b 0a 20 20 20 20 7d 0a 20 20  SIENT);.    }.  
c3c0: 7d 65 6c 73 65 0a 23 65 6e 64 69 66 20 2f 2a 20  }else.#endif /* 
c3d0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48 45  SQLITE_OMIT_SCHE
c3e0: 4d 41 5f 56 45 52 53 49 4f 4e 5f 50 52 41 47 4d  MA_VERSION_PRAGM
c3f0: 41 53 20 2a 2f 0a 0a 23 69 66 6e 64 65 66 20 53  AS */..#ifndef S
c400: 51 4c 49 54 45 5f 4f 4d 49 54 5f 43 4f 4d 50 49  QLITE_OMIT_COMPI
c410: 4c 45 4f 50 54 49 4f 4e 5f 44 49 41 47 53 0a 20  LEOPTION_DIAGS. 
c420: 20 2f 2a 0a 20 20 2a 2a 20 20 20 50 52 41 47 4d   /*.  **   PRAGM
c430: 41 20 63 6f 6d 70 69 6c 65 5f 6f 70 74 69 6f 6e  A compile_option
c440: 73 0a 20 20 2a 2a 0a 20 20 2a 2a 20 52 65 74 75  s.  **.  ** Retu
c450: 72 6e 20 74 68 65 20 6e 61 6d 65 73 20 6f 66 20  rn the names of 
c460: 61 6c 6c 20 63 6f 6d 70 69 6c 65 2d 74 69 6d 65  all compile-time
c470: 20 6f 70 74 69 6f 6e 73 20 75 73 65 64 20 69 6e   options used in
c480: 20 74 68 69 73 20 62 75 69 6c 64 2c 0a 20 20 2a   this build,.  *
c490: 2a 20 6f 6e 65 20 6f 70 74 69 6f 6e 20 70 65 72  * one option per
c4a0: 20 72 6f 77 2e 0a 20 20 2a 2f 0a 20 20 69 66 28   row..  */.  if(
c4b0: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
c4c0: 7a 4c 65 66 74 2c 20 22 63 6f 6d 70 69 6c 65 5f  zLeft, "compile_
c4d0: 6f 70 74 69 6f 6e 73 22 29 3d 3d 30 20 29 7b 0a  options")==0 ){.
c4e0: 20 20 20 20 69 6e 74 20 69 20 3d 20 30 3b 0a 20      int i = 0;. 
c4f0: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a     const char *z
c500: 4f 70 74 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  Opt;.    sqlite3
c510: 56 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76  VdbeSetNumCols(v
c520: 2c 20 31 29 3b 0a 20 20 20 20 70 50 61 72 73 65  , 1);.    pParse
c530: 2d 3e 6e 4d 65 6d 20 3d 20 31 3b 0a 20 20 20 20  ->nMem = 1;.    
c540: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f  sqlite3VdbeSetCo
c550: 6c 4e 61 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e  lName(v, 0, COLN
c560: 41 4d 45 5f 4e 41 4d 45 2c 20 22 63 6f 6d 70 69  AME_NAME, "compi
c570: 6c 65 5f 6f 70 74 69 6f 6e 22 2c 20 53 51 4c 49  le_option", SQLI
c580: 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  TE_STATIC);.    
c590: 77 68 69 6c 65 28 20 28 7a 4f 70 74 20 3d 20 73  while( (zOpt = s
c5a0: 71 6c 69 74 65 33 5f 63 6f 6d 70 69 6c 65 6f 70  qlite3_compileop
c5b0: 74 69 6f 6e 5f 67 65 74 28 69 2b 2b 29 29 21 3d  tion_get(i++))!=
c5c0: 30 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  0 ){.      sqlit
c5d0: 65 33 56 64 62 65 41 64 64 4f 70 34 28 76 2c 20  e3VdbeAddOp4(v, 
c5e0: 4f 50 5f 53 74 72 69 6e 67 38 2c 20 30 2c 20 31  OP_String8, 0, 1
c5f0: 2c 20 30 2c 20 7a 4f 70 74 2c 20 30 29 3b 0a 20  , 0, zOpt, 0);. 
c600: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
c610: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73  AddOp2(v, OP_Res
c620: 75 6c 74 52 6f 77 2c 20 31 2c 20 31 29 3b 0a 20  ultRow, 1, 1);. 
c630: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 23 65 6e     }.  }else.#en
c640: 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d  dif /* SQLITE_OM
c650: 49 54 5f 43 4f 4d 50 49 4c 45 4f 50 54 49 4f 4e  IT_COMPILEOPTION
c660: 5f 44 49 41 47 53 20 2a 2f 0a 0a 20 20 69 66 28  _DIAGS */..  if(
c670: 20 73 71 6c 69 74 65 33 53 74 72 49 43 6d 70 28   sqlite3StrICmp(
c680: 7a 4c 65 66 74 2c 20 22 63 68 65 63 6b 70 6f 69  zLeft, "checkpoi
c690: 6e 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73  nt")==0 ){.    s
c6a0: 71 6c 69 74 65 33 56 64 62 65 55 73 65 73 42 74  qlite3VdbeUsesBt
c6b0: 72 65 65 28 76 2c 20 69 44 62 29 3b 0a 20 20 20  ree(v, iDb);.   
c6c0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
c6d0: 70 33 28 76 2c 20 4f 50 5f 43 68 65 63 6b 70 6f  p3(v, OP_Checkpo
c6e0: 69 6e 74 2c 20 69 44 62 2c 20 30 2c 20 30 29 3b  int, iDb, 0, 0);
c6f0: 0a 20 20 7d 65 6c 73 65 0a 0a 23 69 66 20 64 65  .  }else..#if de
c700: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 44 45 42  fined(SQLITE_DEB
c710: 55 47 29 20 7c 7c 20 64 65 66 69 6e 65 64 28 53  UG) || defined(S
c720: 51 4c 49 54 45 5f 54 45 53 54 29 0a 20 20 2f 2a  QLITE_TEST).  /*
c730: 0a 20 20 2a 2a 20 52 65 70 6f 72 74 20 74 68 65  .  ** Report the
c740: 20 63 75 72 72 65 6e 74 20 73 74 61 74 65 20 6f   current state o
c750: 66 20 66 69 6c 65 20 6c 6f 67 73 20 66 6f 72 20  f file logs for 
c760: 61 6c 6c 20 64 61 74 61 62 61 73 65 73 0a 20 20  all databases.  
c770: 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33  */.  if( sqlite3
c780: 53 74 72 49 43 6d 70 28 7a 4c 65 66 74 2c 20 22  StrICmp(zLeft, "
c790: 6c 6f 63 6b 5f 73 74 61 74 75 73 22 29 3d 3d 30  lock_status")==0
c7a0: 20 29 7b 0a 20 20 20 20 73 74 61 74 69 63 20 63   ){.    static c
c7b0: 6f 6e 73 74 20 63 68 61 72 20 2a 63 6f 6e 73 74  onst char *const
c7c0: 20 61 7a 4c 6f 63 6b 4e 61 6d 65 5b 5d 20 3d 20   azLockName[] = 
c7d0: 7b 0a 20 20 20 20 20 20 22 75 6e 6c 6f 63 6b 65  {.      "unlocke
c7e0: 64 22 2c 20 22 73 68 61 72 65 64 22 2c 20 22 72  d", "shared", "r
c7f0: 65 73 65 72 76 65 64 22 2c 20 22 70 65 6e 64 69  eserved", "pendi
c800: 6e 67 22 2c 20 22 65 78 63 6c 75 73 69 76 65 22  ng", "exclusive"
c810: 0a 20 20 20 20 7d 3b 0a 20 20 20 20 69 6e 74 20  .    };.    int 
c820: 69 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  i;.    sqlite3Vd
c830: 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 76 2c 20  beSetNumCols(v, 
c840: 32 29 3b 0a 20 20 20 20 70 50 61 72 73 65 2d 3e  2);.    pParse->
c850: 6e 4d 65 6d 20 3d 20 32 3b 0a 20 20 20 20 73 71  nMem = 2;.    sq
c860: 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e  lite3VdbeSetColN
c870: 61 6d 65 28 76 2c 20 30 2c 20 43 4f 4c 4e 41 4d  ame(v, 0, COLNAM
c880: 45 5f 4e 41 4d 45 2c 20 22 64 61 74 61 62 61 73  E_NAME, "databas
c890: 65 22 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49  e", SQLITE_STATI
c8a0: 43 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  C);.    sqlite3V
c8b0: 64 62 65 53 65 74 43 6f 6c 4e 61 6d 65 28 76 2c  dbeSetColName(v,
c8c0: 20 31 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45   1, COLNAME_NAME
c8d0: 2c 20 22 73 74 61 74 75 73 22 2c 20 53 51 4c 49  , "status", SQLI
c8e0: 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  TE_STATIC);.    
c8f0: 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62 2d 3e 6e  for(i=0; i<db->n
c900: 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  Db; i++){.      
c910: 42 74 72 65 65 20 2a 70 42 74 3b 0a 20 20 20 20  Btree *pBt;.    
c920: 20 20 50 61 67 65 72 20 2a 70 50 61 67 65 72 3b    Pager *pPager;
c930: 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68 61  .      const cha
c940: 72 20 2a 7a 53 74 61 74 65 20 3d 20 22 75 6e 6b  r *zState = "unk
c950: 6e 6f 77 6e 22 3b 0a 20 20 20 20 20 20 69 6e 74  nown";.      int
c960: 20 6a 3b 0a 20 20 20 20 20 20 69 66 28 20 64 62   j;.      if( db
c970: 2d 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 3d 3d  ->aDb[i].zName==
c980: 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20  0 ) continue;.  
c990: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
c9a0: 64 64 4f 70 34 28 76 2c 20 4f 50 5f 53 74 72 69  ddOp4(v, OP_Stri
c9b0: 6e 67 38 2c 20 30 2c 20 31 2c 20 30 2c 20 64 62  ng8, 0, 1, 0, db
c9c0: 2d 3e 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 2c 20  ->aDb[i].zName, 
c9d0: 50 34 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  P4_STATIC);.    
c9e0: 20 20 70 42 74 20 3d 20 64 62 2d 3e 61 44 62 5b    pBt = db->aDb[
c9f0: 69 5d 2e 70 42 74 3b 0a 20 20 20 20 20 20 69 66  i].pBt;.      if
ca00: 28 20 70 42 74 3d 3d 30 20 7c 7c 20 28 70 50 61  ( pBt==0 || (pPa
ca10: 67 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74 72  ger = sqlite3Btr
ca20: 65 65 50 61 67 65 72 28 70 42 74 29 29 3d 3d 30  eePager(pBt))==0
ca30: 20 29 7b 0a 20 20 20 20 20 20 20 20 7a 53 74 61   ){.        zSta
ca40: 74 65 20 3d 20 22 63 6c 6f 73 65 64 22 3b 0a 20  te = "closed";. 
ca50: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73       }else if( s
ca60: 71 6c 69 74 65 33 5f 66 69 6c 65 5f 63 6f 6e 74  qlite3_file_cont
ca70: 72 6f 6c 28 64 62 2c 20 69 20 3f 20 64 62 2d 3e  rol(db, i ? db->
ca80: 61 44 62 5b 69 5d 2e 7a 4e 61 6d 65 20 3a 20 30  aDb[i].zName : 0
ca90: 2c 20 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  , .             
caa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
cab0: 20 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f 46          SQLITE_F
cac0: 43 4e 54 4c 5f 4c 4f 43 4b 53 54 41 54 45 2c 20  CNTL_LOCKSTATE, 
cad0: 26 6a 29 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29  &j)==SQLITE_OK )
cae0: 7b 0a 20 20 20 20 20 20 20 20 20 7a 53 74 61 74  {.         zStat
caf0: 65 20 3d 20 61 7a 4c 6f 63 6b 4e 61 6d 65 5b 6a  e = azLockName[j
cb00: 5d 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  ];.      }.     
cb10: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
cb20: 70 34 28 76 2c 20 4f 50 5f 53 74 72 69 6e 67 38  p4(v, OP_String8
cb30: 2c 20 30 2c 20 32 2c 20 30 2c 20 7a 53 74 61 74  , 0, 2, 0, zStat
cb40: 65 2c 20 50 34 5f 53 54 41 54 49 43 29 3b 0a 20  e, P4_STATIC);. 
cb50: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
cb60: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 52 65 73  AddOp2(v, OP_Res
cb70: 75 6c 74 52 6f 77 2c 20 31 2c 20 32 29 3b 0a 20  ultRow, 1, 2);. 
cb80: 20 20 20 7d 0a 0a 20 20 7d 65 6c 73 65 0a 23 65     }..  }else.#e
cb90: 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51 4c  ndif..#ifdef SQL
cba0: 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 0a 20 20  ITE_HAS_CODEC.  
cbb0: 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49 43  if( sqlite3StrIC
cbc0: 6d 70 28 7a 4c 65 66 74 2c 20 22 6b 65 79 22 29  mp(zLeft, "key")
cbd0: 3d 3d 30 20 26 26 20 7a 52 69 67 68 74 20 29 7b  ==0 && zRight ){
cbe0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6b 65 79  .    sqlite3_key
cbf0: 28 64 62 2c 20 7a 52 69 67 68 74 2c 20 73 71 6c  (db, zRight, sql
cc00: 69 74 65 33 53 74 72 6c 65 6e 33 30 28 7a 52 69  ite3Strlen30(zRi
cc10: 67 68 74 29 29 3b 0a 20 20 7d 65 6c 73 65 0a 20  ght));.  }else. 
cc20: 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49   if( sqlite3StrI
cc30: 43 6d 70 28 7a 4c 65 66 74 2c 20 22 72 65 6b 65  Cmp(zLeft, "reke
cc40: 79 22 29 3d 3d 30 20 26 26 20 7a 52 69 67 68 74  y")==0 && zRight
cc50: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f   ){.    sqlite3_
cc60: 72 65 6b 65 79 28 64 62 2c 20 7a 52 69 67 68 74  rekey(db, zRight
cc70: 2c 20 73 71 6c 69 74 65 33 53 74 72 6c 65 6e 33  , sqlite3Strlen3
cc80: 30 28 7a 52 69 67 68 74 29 29 3b 0a 20 20 7d 65  0(zRight));.  }e
cc90: 6c 73 65 0a 20 20 69 66 28 20 7a 52 69 67 68 74  lse.  if( zRight
cca0: 20 26 26 20 28 73 71 6c 69 74 65 33 53 74 72 49   && (sqlite3StrI
ccb0: 43 6d 70 28 7a 4c 65 66 74 2c 20 22 68 65 78 6b  Cmp(zLeft, "hexk
ccc0: 65 79 22 29 3d 3d 30 20 7c 7c 0a 20 20 20 20 20  ey")==0 ||.     
ccd0: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
cce0: 74 65 33 53 74 72 49 43 6d 70 28 7a 4c 65 66 74  te3StrICmp(zLeft
ccf0: 2c 20 22 68 65 78 72 65 6b 65 79 22 29 3d 3d 30  , "hexrekey")==0
cd00: 29 20 29 7b 0a 20 20 20 20 69 6e 74 20 69 2c 20  ) ){.    int i, 
cd10: 68 31 2c 20 68 32 3b 0a 20 20 20 20 63 68 61 72  h1, h2;.    char
cd20: 20 7a 4b 65 79 5b 34 30 5d 3b 0a 20 20 20 20 66   zKey[40];.    f
cd30: 6f 72 28 69 3d 30 3b 20 28 68 31 20 3d 20 7a 52  or(i=0; (h1 = zR
cd40: 69 67 68 74 5b 69 5d 29 21 3d 30 20 26 26 20 28  ight[i])!=0 && (
cd50: 68 32 20 3d 20 7a 52 69 67 68 74 5b 69 2b 31 5d  h2 = zRight[i+1]
cd60: 29 21 3d 30 3b 20 69 2b 3d 32 29 7b 0a 20 20 20  )!=0; i+=2){.   
cd70: 20 20 20 68 31 20 2b 3d 20 39 2a 28 31 26 28 68     h1 += 9*(1&(h
cd80: 31 3e 3e 36 29 29 3b 0a 20 20 20 20 20 20 68 32  1>>6));.      h2
cd90: 20 2b 3d 20 39 2a 28 31 26 28 68 32 3e 3e 36 29   += 9*(1&(h2>>6)
cda0: 29 3b 0a 20 20 20 20 20 20 7a 4b 65 79 5b 69 2f  );.      zKey[i/
cdb0: 32 5d 20 3d 20 28 68 32 20 26 20 30 78 30 66 29  2] = (h2 & 0x0f)
cdc0: 20 7c 20 28 28 68 31 20 26 20 30 78 66 29 3c 3c   | ((h1 & 0xf)<<
cdd0: 34 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  4);.    }.    if
cde0: 28 20 28 7a 4c 65 66 74 5b 33 5d 20 26 20 30 78  ( (zLeft[3] & 0x
cdf0: 66 29 3d 3d 30 78 62 20 29 7b 0a 20 20 20 20 20  f)==0xb ){.     
ce00: 20 73 71 6c 69 74 65 33 5f 6b 65 79 28 64 62 2c   sqlite3_key(db,
ce10: 20 7a 4b 65 79 2c 20 69 2f 32 29 3b 0a 20 20 20   zKey, i/2);.   
ce20: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 71   }else{.      sq
ce30: 6c 69 74 65 33 5f 72 65 6b 65 79 28 64 62 2c 20  lite3_rekey(db, 
ce40: 7a 4b 65 79 2c 20 69 2f 32 29 3b 0a 20 20 20 20  zKey, i/2);.    
ce50: 7d 0a 20 20 7d 65 6c 73 65 0a 23 65 6e 64 69 66  }.  }else.#endif
ce60: 0a 23 69 66 20 64 65 66 69 6e 65 64 28 53 51 4c  .#if defined(SQL
ce70: 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 29 20 7c  ITE_HAS_CODEC) |
ce80: 7c 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45  | defined(SQLITE
ce90: 5f 45 4e 41 42 4c 45 5f 43 45 52 4f 44 29 0a 20  _ENABLE_CEROD). 
cea0: 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72 49   if( sqlite3StrI
ceb0: 43 6d 70 28 7a 4c 65 66 74 2c 20 22 61 63 74 69  Cmp(zLeft, "acti
cec0: 76 61 74 65 5f 65 78 74 65 6e 73 69 6f 6e 73 22  vate_extensions"
ced0: 29 3d 3d 30 20 29 7b 0a 23 69 66 64 65 66 20 53  )==0 ){.#ifdef S
cee0: 51 4c 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 0a  QLITE_HAS_CODEC.
cef0: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 53      if( sqlite3S
cf00: 74 72 4e 49 43 6d 70 28 7a 52 69 67 68 74 2c 20  trNICmp(zRight, 
cf10: 22 73 65 65 2d 22 2c 20 34 29 3d 3d 30 20 29 7b  "see-", 4)==0 ){
cf20: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 61  .      sqlite3_a
cf30: 63 74 69 76 61 74 65 5f 73 65 65 28 26 7a 52 69  ctivate_see(&zRi
cf40: 67 68 74 5b 34 5d 29 3b 0a 20 20 20 20 7d 0a 23  ght[4]);.    }.#
cf50: 65 6e 64 69 66 0a 23 69 66 64 65 66 20 53 51 4c  endif.#ifdef SQL
cf60: 49 54 45 5f 45 4e 41 42 4c 45 5f 43 45 52 4f 44  ITE_ENABLE_CEROD
cf70: 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33  .    if( sqlite3
cf80: 53 74 72 4e 49 43 6d 70 28 7a 52 69 67 68 74 2c  StrNICmp(zRight,
cf90: 20 22 63 65 72 6f 64 2d 22 2c 20 36 29 3d 3d 30   "cerod-", 6)==0
cfa0: 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   ){.      sqlite
cfb0: 33 5f 61 63 74 69 76 61 74 65 5f 63 65 72 6f 64  3_activate_cerod
cfc0: 28 26 7a 52 69 67 68 74 5b 36 5d 29 3b 0a 20 20  (&zRight[6]);.  
cfd0: 20 20 7d 0a 23 65 6e 64 69 66 0a 20 20 7d 65 6c    }.#endif.  }el
cfe0: 73 65 0a 23 65 6e 64 69 66 0a 0a 20 0a 20 20 7b  se.#endif.. .  {
cff0: 2f 2a 20 45 6d 70 74 79 20 45 4c 53 45 20 63 6c  /* Empty ELSE cl
d000: 61 75 73 65 20 2a 2f 7d 0a 0a 20 20 2f 2a 0a 20  ause */}..  /*. 
d010: 20 2a 2a 20 52 65 73 65 74 20 74 68 65 20 73 61   ** Reset the sa
d020: 66 65 74 79 20 6c 65 76 65 6c 2c 20 69 6e 20 63  fety level, in c
d030: 61 73 65 20 74 68 65 20 66 75 6c 6c 66 73 79 6e  ase the fullfsyn
d040: 63 20 66 6c 61 67 20 6f 72 20 73 79 6e 63 68 72  c flag or synchr
d050: 6f 6e 6f 75 73 0a 20 20 2a 2a 20 73 65 74 74 69  onous.  ** setti
d060: 6e 67 20 63 68 61 6e 67 65 64 2e 0a 20 20 2a 2f  ng changed..  */
d070: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
d080: 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52 41 47 4d  OMIT_PAGER_PRAGM
d090: 41 53 0a 20 20 69 66 28 20 64 62 2d 3e 61 75 74  AS.  if( db->aut
d0a0: 6f 43 6f 6d 6d 69 74 20 29 7b 0a 20 20 20 20 73  oCommit ){.    s
d0b0: 71 6c 69 74 65 33 42 74 72 65 65 53 65 74 53 61  qlite3BtreeSetSa
d0c0: 66 65 74 79 4c 65 76 65 6c 28 70 44 62 2d 3e 70  fetyLevel(pDb->p
d0d0: 42 74 2c 20 70 44 62 2d 3e 73 61 66 65 74 79 5f  Bt, pDb->safety_
d0e0: 6c 65 76 65 6c 2c 0a 20 20 20 20 20 20 20 20 20  level,.         
d0f0: 20 20 20 20 20 20 28 64 62 2d 3e 66 6c 61 67 73        (db->flags
d100: 26 53 51 4c 49 54 45 5f 46 75 6c 6c 46 53 79 6e  &SQLITE_FullFSyn
d110: 63 29 21 3d 30 29 3b 0a 20 20 7d 0a 23 65 6e 64  c)!=0);.  }.#end
d120: 69 66 0a 70 72 61 67 6d 61 5f 6f 75 74 3a 0a 20  if.pragma_out:. 
d130: 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 28 64   sqlite3DbFree(d
d140: 62 2c 20 7a 4c 65 66 74 29 3b 0a 20 20 73 71 6c  b, zLeft);.  sql
d150: 69 74 65 33 44 62 46 72 65 65 28 64 62 2c 20 7a  ite3DbFree(db, z
d160: 52 69 67 68 74 29 3b 0a 7d 0a 0a 23 65 6e 64 69  Right);.}..#endi
d170: 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54  f /* SQLITE_OMIT
d180: 5f 50 52 41 47 4d 41 20 2a 2f 0a                 _PRAGMA */.