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

Artifact 40f9db60546bef5a3b47858387f158f25b33dca9:


0000: 2f 2a 0a 2a 2a 20 32 30 31 35 2d 30 35 2d 32 35  /*.** 2015-05-25
0010: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68 6f  .**.** The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65 67  lace of.** a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 2a  is a blessing:.*
0080: 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75 20  *.**    May you 
0090: 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20  do good and not 
00a0: 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  evil..**    May 
00b0: 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65  you find forgive
00c0: 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c  ness for yoursel
00d0: 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74  f and forgive ot
00e0: 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  hers..**    May 
00f0: 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c 79  you share freely
0100: 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20 6d  , never taking m
0110: 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69 76  ore than you giv
0120: 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e..**.**********
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 0a  ***************.
0170: 2a 2a 0a 2a 2a 20 54 68 69 73 20 69 73 20 61 20  **.** This is a 
0180: 75 74 69 6c 69 74 79 20 70 72 6f 67 72 61 6d 20  utility program 
0190: 64 65 73 69 67 6e 65 64 20 74 6f 20 61 69 64 20  designed to aid 
01a0: 72 75 6e 6e 69 6e 67 20 72 65 67 72 65 73 73 69  running regressi
01b0: 6f 6e 73 20 74 65 73 74 73 20 6f 6e 0a 2a 2a 20  ons tests on.** 
01c0: 74 68 65 20 53 51 4c 69 74 65 20 6c 69 62 72 61  the SQLite libra
01d0: 72 79 20 75 73 69 6e 67 20 64 61 74 61 20 66 72  ry using data fr
01e0: 6f 6d 20 61 6e 20 65 78 74 65 72 6e 61 6c 20 66  om an external f
01f0: 75 7a 7a 65 72 2c 20 73 75 63 68 20 61 73 20 41  uzzer, such as A
0200: 6d 65 72 69 63 61 6e 0a 2a 2a 20 46 75 7a 7a 79  merican.** Fuzzy
0210: 20 4c 6f 70 20 28 41 46 4c 29 20 28 68 74 74 70   Lop (AFL) (http
0220: 3a 2f 2f 6c 63 61 6d 74 75 66 2e 63 6f 72 65 64  ://lcamtuf.cored
0230: 75 6d 70 2e 63 78 2f 61 66 6c 2f 29 2e 0a 2a 2a  ump.cx/afl/)..**
0240: 0a 2a 2a 20 54 68 69 73 20 70 72 6f 67 72 61 6d  .** This program
0250: 20 72 65 61 64 73 20 63 6f 6e 74 65 6e 74 20 66   reads content f
0260: 72 6f 6d 20 61 6e 20 53 51 4c 69 74 65 20 64 61  rom an SQLite da
0270: 74 61 62 61 73 65 20 66 69 6c 65 20 77 69 74 68  tabase file with
0280: 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 0a 2a   the following.*
0290: 2a 20 73 63 68 65 6d 61 3a 0a 2a 2a 0a 2a 2a 20  * schema:.**.** 
02a0: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
02b0: 20 64 62 28 0a 2a 2a 20 20 20 20 20 20 20 64 62   db(.**       db
02c0: 69 64 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41  id INTEGER PRIMA
02d0: 52 59 20 4b 45 59 2c 20 2d 2d 20 64 61 74 61 62  RY KEY, -- datab
02e0: 61 73 65 20 69 64 0a 2a 2a 20 20 20 20 20 20 20  ase id.**       
02f0: 64 62 63 6f 6e 74 65 6e 74 20 42 4c 4f 42 20 20  dbcontent BLOB  
0300: 20 20 20 20 20 20 20 20 20 20 2d 2d 20 64 61 74            -- dat
0310: 61 62 61 73 65 20 64 69 73 6b 20 66 69 6c 65 20  abase disk file 
0320: 69 6d 61 67 65 0a 2a 2a 20 20 20 20 20 29 3b 0a  image.**     );.
0330: 2a 2a 20 20 20 20 20 43 52 45 41 54 45 20 54 41  **     CREATE TA
0340: 42 4c 45 20 78 73 71 6c 28 0a 2a 2a 20 20 20 20  BLE xsql(.**    
0350: 20 20 20 73 71 6c 69 64 20 49 4e 54 45 47 45 52     sqlid INTEGER
0360: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 20 20   PRIMARY KEY,   
0370: 2d 2d 20 53 51 4c 20 73 63 72 69 70 74 20 69 64  -- SQL script id
0380: 0a 2a 2a 20 20 20 20 20 20 20 73 71 6c 74 65 78  .**       sqltex
0390: 74 20 54 45 58 54 20 20 20 20 20 20 20 20 20 20  t TEXT          
03a0: 20 20 20 20 20 20 20 2d 2d 20 54 65 78 74 20 6f         -- Text o
03b0: 66 20 53 51 4c 20 73 74 61 74 65 6d 65 6e 74 73  f SQL statements
03c0: 20 74 6f 20 72 75 6e 0a 2a 2a 20 20 20 20 20 29   to run.**     )
03d0: 3b 0a 2a 2a 20 20 20 20 20 43 52 45 41 54 45 20  ;.**     CREATE 
03e0: 54 41 42 4c 45 20 49 46 20 4e 4f 54 20 45 58 49  TABLE IF NOT EXI
03f0: 53 54 53 20 72 65 61 64 6d 65 28 0a 2a 2a 20 20  STS readme(.**  
0400: 20 20 20 20 20 6d 73 67 20 54 45 58 54 20 2d 2d       msg TEXT --
0410: 20 48 75 6d 61 6e 2d 72 65 61 64 61 62 6c 65 20   Human-readable 
0420: 64 65 73 63 72 69 70 74 69 6f 6e 20 6f 66 20 74  description of t
0430: 68 69 73 20 74 65 73 74 20 63 6f 6c 6c 65 63 74  his test collect
0440: 69 6f 6e 0a 2a 2a 20 20 20 20 20 29 3b 0a 2a 2a  ion.**     );.**
0450: 0a 2a 2a 20 46 6f 72 20 65 61 63 68 20 64 61 74  .** For each dat
0460: 61 62 61 73 65 20 66 69 6c 65 20 69 6e 20 74 68  abase file in th
0470: 65 20 44 42 20 74 61 62 6c 65 2c 20 74 68 65 20  e DB table, the 
0480: 53 51 4c 20 74 65 78 74 20 69 6e 20 74 68 65 20  SQL text in the 
0490: 58 53 51 4c 20 74 61 62 6c 65 0a 2a 2a 20 69 73  XSQL table.** is
04a0: 20 72 75 6e 20 61 67 61 69 6e 73 74 20 74 68 61   run against tha
04b0: 74 20 64 61 74 61 62 61 73 65 2e 20 20 41 6c 6c  t database.  All
04c0: 20 52 45 41 44 4d 45 2e 4d 53 47 20 76 61 6c 75   README.MSG valu
04d0: 65 73 20 61 72 65 20 70 72 69 6e 74 65 64 20 70  es are printed p
04e0: 72 69 6f 72 0a 2a 2a 20 74 6f 20 74 68 65 20 73  rior.** to the s
04f0: 74 61 72 74 20 6f 66 20 74 68 65 20 74 65 73 74  tart of the test
0500: 20 28 75 6e 6c 65 73 73 20 74 68 65 20 2d 2d 71   (unless the --q
0510: 75 69 65 74 20 6f 70 74 69 6f 6e 20 69 73 20 75  uiet option is u
0520: 73 65 64 29 2e 20 20 49 66 20 74 68 65 0a 2a 2a  sed).  If the.**
0530: 20 44 42 20 74 61 62 6c 65 20 69 73 20 65 6d 70   DB table is emp
0540: 74 79 2c 20 74 68 65 6e 20 61 6c 6c 20 65 6e 74  ty, then all ent
0550: 72 69 65 73 20 69 6e 20 58 53 51 4c 20 61 72 65  ries in XSQL are
0560: 20 72 75 6e 20 61 67 61 69 6e 73 74 20 61 6e 20   run against an 
0570: 65 6d 70 74 79 0a 2a 2a 20 69 6e 2d 6d 65 6d 6f  empty.** in-memo
0580: 72 79 20 64 61 74 61 62 61 73 65 2e 0a 2a 2a 0a  ry database..**.
0590: 2a 2a 20 54 68 69 73 20 70 72 6f 67 72 61 6d 20  ** This program 
05a0: 69 73 20 6c 6f 6f 6b 69 6e 67 20 66 6f 72 20 63  is looking for c
05b0: 72 61 73 68 65 73 2c 20 61 73 73 65 72 74 69 6f  rashes, assertio
05c0: 6e 20 66 61 75 6c 74 73 2c 20 61 6e 64 2f 6f 72  n faults, and/or
05d0: 20 6d 65 6d 6f 72 79 20 6c 65 61 6b 73 2e 0a 2a   memory leaks..*
05e0: 2a 20 4e 6f 20 61 74 74 65 6d 70 74 20 69 73 20  * No attempt is 
05f0: 6d 61 64 65 20 74 6f 20 76 65 72 69 66 79 20 74  made to verify t
0600: 68 65 20 6f 75 74 70 75 74 2e 20 20 54 68 65 20  he output.  The 
0610: 61 73 73 75 6d 70 74 69 6f 6e 20 69 73 20 74 68  assumption is th
0620: 61 74 20 65 69 74 68 65 72 20 61 6c 6c 0a 2a 2a  at either all.**
0630: 20 6f 66 20 74 68 65 20 64 61 74 61 62 61 73 65   of the database
0640: 20 66 69 6c 65 73 20 6f 72 20 61 6c 6c 20 6f 66   files or all of
0650: 20 74 68 65 20 53 51 4c 20 73 74 61 74 65 6d 65   the SQL stateme
0660: 6e 74 73 20 61 72 65 20 6d 61 6c 66 6f 72 6d 65  nts are malforme
0670: 64 20 69 6e 70 75 74 73 2c 0a 2a 2a 20 67 65 6e  d inputs,.** gen
0680: 65 72 61 74 65 64 20 62 79 20 61 20 66 75 7a 7a  erated by a fuzz
0690: 65 72 2c 20 74 68 61 74 20 6e 65 65 64 20 74 6f  er, that need to
06a0: 20 62 65 20 63 68 65 63 6b 65 64 20 74 6f 20 6d   be checked to m
06b0: 61 6b 65 20 73 75 72 65 20 74 68 65 79 20 64 6f  ake sure they do
06c0: 20 6e 6f 74 0a 2a 2a 20 70 72 65 73 65 6e 74 20   not.** present 
06d0: 61 20 73 65 63 75 72 69 74 79 20 72 69 73 6b 2e  a security risk.
06e0: 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 70 72 6f 67  .**.** This prog
06f0: 72 61 6d 20 61 6c 73 6f 20 69 6e 63 6c 75 64 65  ram also include
0700: 73 20 73 6f 6d 65 20 63 6f 6d 6d 61 6e 64 2d 6c  s some command-l
0710: 69 6e 65 20 6f 70 74 69 6f 6e 73 20 74 6f 20 68  ine options to h
0720: 65 6c 70 20 77 69 74 68 20 0a 2a 2a 20 63 72 65  elp with .** cre
0730: 61 74 69 6f 6e 20 61 6e 64 20 6d 61 69 6e 74 65  ation and mainte
0740: 6e 61 6e 63 65 20 6f 66 20 74 68 65 20 73 6f 75  nance of the sou
0750: 72 63 65 20 63 6f 6e 74 65 6e 74 20 64 61 74 61  rce content data
0760: 62 61 73 65 2e 20 20 54 68 65 20 63 6f 6d 6d 61  base.  The comma
0770: 6e 64 0a 2a 2a 0a 2a 2a 20 20 20 20 20 2e 2f 66  nd.**.**     ./f
0780: 75 7a 7a 63 68 65 63 6b 20 64 61 74 61 62 61 73  uzzcheck databas
0790: 65 2e 64 62 20 2d 2d 6c 6f 61 64 2d 73 71 6c 20  e.db --load-sql 
07a0: 46 49 4c 45 2e 2e 2e 0a 2a 2a 0a 2a 2a 20 4c 6f  FILE....**.** Lo
07b0: 61 64 73 20 61 6c 6c 20 46 49 4c 45 2e 2e 2e 20  ads all FILE... 
07c0: 61 72 67 75 6d 65 6e 74 73 20 69 6e 74 6f 20 74  arguments into t
07d0: 68 65 20 58 53 51 4c 20 74 61 62 6c 65 2e 20 20  he XSQL table.  
07e0: 54 68 65 20 2d 2d 6c 6f 61 64 2d 64 62 20 6f 70  The --load-db op
07f0: 74 69 6f 6e 0a 2a 2a 20 77 6f 72 6b 73 20 74 68  tion.** works th
0800: 65 20 73 61 6d 65 20 62 75 74 20 6c 6f 61 64 73  e same but loads
0810: 20 74 68 65 20 66 69 6c 65 73 20 69 6e 74 6f 20   the files into 
0820: 74 68 65 20 44 42 20 74 61 62 6c 65 2e 20 20 54  the DB table.  T
0830: 68 65 20 2d 6d 20 6f 70 74 69 6f 6e 20 63 61 6e  he -m option can
0840: 0a 2a 2a 20 62 65 20 75 73 65 64 20 74 6f 20 69  .** be used to i
0850: 6e 69 74 69 61 6c 69 7a 65 20 74 68 65 20 52 45  nitialize the RE
0860: 41 44 4d 45 20 74 61 62 6c 65 2e 20 20 54 68 65  ADME table.  The
0870: 20 22 64 61 74 61 62 61 73 65 2e 64 62 22 20 66   "database.db" f
0880: 69 6c 65 20 69 73 20 63 72 65 61 74 65 64 0a 2a  ile is created.*
0890: 2a 20 69 66 20 69 74 20 64 6f 65 73 20 6e 6f 74  * if it does not
08a0: 20 70 72 65 76 69 6f 75 73 6c 79 20 65 78 69 73   previously exis
08b0: 74 2e 20 20 45 78 61 6d 70 6c 65 3a 0a 2a 2a 0a  t.  Example:.**.
08c0: 2a 2a 20 20 20 20 20 2e 2f 66 75 7a 7a 63 68 65  **     ./fuzzche
08d0: 63 6b 20 6e 65 77 2e 64 62 20 2d 2d 6c 6f 61 64  ck new.db --load
08e0: 2d 73 71 6c 20 2a 2e 73 71 6c 0a 2a 2a 20 20 20  -sql *.sql.**   
08f0: 20 20 2e 2f 66 75 7a 7a 63 68 65 63 6b 20 6e 65    ./fuzzcheck ne
0900: 77 2e 64 62 20 2d 2d 6c 6f 61 64 2d 64 62 20 2a  w.db --load-db *
0910: 2e 64 62 0a 2a 2a 20 20 20 20 20 2e 2f 66 75 7a  .db.**     ./fuz
0920: 7a 63 68 65 63 6b 20 6e 65 77 2e 64 62 20 2d 6d  zcheck new.db -m
0930: 20 27 4e 65 77 20 74 65 73 74 20 63 61 73 65 73   'New test cases
0940: 27 0a 2a 2a 0a 2a 2a 20 54 68 65 20 74 68 72 65  '.**.** The thre
0950: 65 20 63 6f 6d 6d 61 6e 64 73 20 61 62 6f 76 65  e commands above
0960: 20 77 69 6c 6c 20 63 72 65 61 74 65 20 74 68 65   will create the
0970: 20 22 6e 65 77 2e 64 62 22 20 66 69 6c 65 20 61   "new.db" file a
0980: 6e 64 20 69 6e 69 74 69 61 6c 69 7a 65 20 61 6c  nd initialize al
0990: 6c 0a 2a 2a 20 74 61 62 6c 65 73 2e 20 20 54 68  l.** tables.  Th
09a0: 65 6e 20 64 6f 20 22 2e 2f 66 75 7a 7a 63 68 65  en do "./fuzzche
09b0: 63 6b 20 6e 65 77 2e 64 62 22 20 74 6f 20 72 75  ck new.db" to ru
09c0: 6e 20 74 68 65 20 74 65 73 74 73 2e 0a 2a 2a 0a  n the tests..**.
09d0: 2a 2a 20 44 45 42 55 47 47 49 4e 47 20 48 49 4e  ** DEBUGGING HIN
09e0: 54 53 3a 0a 2a 2a 0a 2a 2a 20 49 66 20 66 75 7a  TS:.**.** If fuz
09f0: 7a 63 68 65 63 6b 20 64 6f 65 73 20 63 72 61 73  zcheck does cras
0a00: 68 2c 20 69 74 20 63 61 6e 20 62 65 20 72 75 6e  h, it can be run
0a10: 20 69 6e 20 74 68 65 20 64 65 62 75 67 67 65 72   in the debugger
0a20: 20 61 6e 64 20 74 68 65 20 63 6f 6e 74 65 6e 74   and the content
0a30: 0a 2a 2a 20 6f 66 20 74 68 65 20 67 6c 6f 62 61  .** of the globa
0a40: 6c 20 76 61 72 69 61 62 6c 65 20 67 2e 7a 54 65  l variable g.zTe
0a50: 78 74 4e 61 6d 65 5b 5d 20 77 69 6c 6c 20 69 64  xtName[] will id
0a60: 65 6e 74 69 66 79 20 74 68 65 20 73 70 65 63 69  entify the speci
0a70: 66 69 63 20 58 53 51 4c 20 61 6e 64 0a 2a 2a 20  fic XSQL and.** 
0a80: 44 42 20 76 61 6c 75 65 73 20 74 68 61 74 20 77  DB values that w
0a90: 65 72 65 20 72 75 6e 6e 69 6e 67 20 77 68 65 6e  ere running when
0aa0: 20 74 68 65 20 63 72 61 73 68 20 6f 63 63 75 72   the crash occur
0ab0: 72 65 64 2e 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65  red..*/.#include
0ac0: 20 3c 73 74 64 69 6f 2e 68 3e 0a 23 69 6e 63 6c   <stdio.h>.#incl
0ad0: 75 64 65 20 3c 73 74 64 6c 69 62 2e 68 3e 0a 23  ude <stdlib.h>.#
0ae0: 69 6e 63 6c 75 64 65 20 3c 73 74 72 69 6e 67 2e  include <string.
0af0: 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 64  h>.#include <std
0b00: 61 72 67 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20  arg.h>.#include 
0b10: 3c 63 74 79 70 65 2e 68 3e 0a 23 69 6e 63 6c 75  <ctype.h>.#inclu
0b20: 64 65 20 22 73 71 6c 69 74 65 33 2e 68 22 0a 0a  de "sqlite3.h"..
0b30: 2f 2a 0a 2a 2a 20 46 69 6c 65 73 20 69 6e 20 74  /*.** Files in t
0b40: 68 65 20 76 69 72 74 75 61 6c 20 66 69 6c 65 20  he virtual file 
0b50: 73 79 73 74 65 6d 2e 0a 2a 2f 0a 74 79 70 65 64  system..*/.typed
0b60: 65 66 20 73 74 72 75 63 74 20 56 46 69 6c 65 20  ef struct VFile 
0b70: 56 46 69 6c 65 3b 0a 73 74 72 75 63 74 20 56 46  VFile;.struct VF
0b80: 69 6c 65 20 7b 0a 20 20 63 68 61 72 20 2a 7a 46  ile {.  char *zF
0b90: 69 6c 65 6e 61 6d 65 3b 20 20 20 20 20 20 20 20  ilename;        
0ba0: 2f 2a 20 46 69 6c 65 6e 61 6d 65 2e 20 20 4e 55  /* Filename.  NU
0bb0: 4c 4c 20 66 6f 72 20 64 65 6c 65 74 65 2d 6f 6e  LL for delete-on
0bc0: 2d 63 6c 6f 73 65 2e 20 46 72 6f 6d 20 6d 61 6c  -close. From mal
0bd0: 6c 6f 63 28 29 20 2a 2f 0a 20 20 69 6e 74 20 73  loc() */.  int s
0be0: 7a 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  z;              
0bf0: 20 20 20 2f 2a 20 53 69 7a 65 20 6f 66 20 74 68     /* Size of th
0c00: 65 20 66 69 6c 65 20 69 6e 20 62 79 74 65 73 20  e file in bytes 
0c10: 2a 2f 0a 20 20 69 6e 74 20 6e 52 65 66 3b 20 20  */.  int nRef;  
0c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
0c30: 4e 75 6d 62 65 72 20 6f 66 20 72 65 66 65 72 65  Number of refere
0c40: 6e 63 65 73 20 74 6f 20 74 68 69 73 20 66 69 6c  nces to this fil
0c50: 65 20 2a 2f 0a 20 20 75 6e 73 69 67 6e 65 64 20  e */.  unsigned 
0c60: 63 68 61 72 20 2a 61 3b 20 20 20 20 20 20 20 2f  char *a;       /
0c70: 2a 20 43 6f 6e 74 65 6e 74 20 6f 66 20 74 68 65  * Content of the
0c80: 20 66 69 6c 65 2e 20 20 46 72 6f 6d 20 6d 61 6c   file.  From mal
0c90: 6c 6f 63 28 29 20 2a 2f 0a 7d 3b 0a 74 79 70 65  loc() */.};.type
0ca0: 64 65 66 20 73 74 72 75 63 74 20 56 48 61 6e 64  def struct VHand
0cb0: 6c 65 20 56 48 61 6e 64 6c 65 3b 0a 73 74 72 75  le VHandle;.stru
0cc0: 63 74 20 56 48 61 6e 64 6c 65 20 7b 0a 20 20 73  ct VHandle {.  s
0cd0: 71 6c 69 74 65 33 5f 66 69 6c 65 20 62 61 73 65  qlite3_file base
0ce0: 3b 20 20 20 20 20 20 2f 2a 20 42 61 73 65 20 63  ;      /* Base c
0cf0: 6c 61 73 73 2e 20 20 4d 75 73 74 20 62 65 20 66  lass.  Must be f
0d00: 69 72 73 74 20 2a 2f 0a 20 20 56 46 69 6c 65 20  irst */.  VFile 
0d10: 2a 70 56 46 69 6c 65 3b 20 20 20 20 20 20 20 20  *pVFile;        
0d20: 20 20 2f 2a 20 54 68 65 20 75 6e 64 65 72 6c 79    /* The underly
0d30: 69 6e 67 20 66 69 6c 65 20 2a 2f 0a 7d 3b 0a 0a  ing file */.};..
0d40: 2f 2a 0a 2a 2a 20 54 68 65 20 76 61 6c 75 65 20  /*.** The value 
0d50: 6f 66 20 61 20 64 61 74 61 62 61 73 65 20 66 69  of a database fi
0d60: 6c 65 20 74 65 6d 70 6c 61 74 65 2c 20 6f 72 20  le template, or 
0d70: 6f 66 20 61 6e 20 53 51 4c 20 73 63 72 69 70 74  of an SQL script
0d80: 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75  .*/.typedef stru
0d90: 63 74 20 42 6c 6f 62 20 42 6c 6f 62 3b 0a 73 74  ct Blob Blob;.st
0da0: 72 75 63 74 20 42 6c 6f 62 20 7b 0a 20 20 42 6c  ruct Blob {.  Bl
0db0: 6f 62 20 2a 70 4e 65 78 74 3b 20 20 20 20 20 20  ob *pNext;      
0dc0: 20 20 20 20 20 20 2f 2a 20 4e 65 78 74 20 69 6e        /* Next in
0dd0: 20 61 20 6c 69 73 74 20 2a 2f 0a 20 20 69 6e 74   a list */.  int
0de0: 20 69 64 3b 20 20 20 20 20 20 20 20 20 20 20 20   id;            
0df0: 20 20 20 20 20 2f 2a 20 49 64 20 6f 66 20 74 68       /* Id of th
0e00: 69 73 20 42 6c 6f 62 20 2a 2f 0a 20 20 69 6e 74  is Blob */.  int
0e10: 20 73 65 71 3b 20 20 20 20 20 20 20 20 20 20 20   seq;           
0e20: 20 20 20 20 20 2f 2a 20 53 65 71 75 65 6e 63 65       /* Sequence
0e30: 20 6e 75 6d 62 65 72 20 2a 2f 0a 20 20 69 6e 74   number */.  int
0e40: 20 73 7a 3b 20 20 20 20 20 20 20 20 20 20 20 20   sz;            
0e50: 20 20 20 20 20 2f 2a 20 53 69 7a 65 20 6f 66 20       /* Size of 
0e60: 74 68 69 73 20 42 6c 6f 62 20 69 6e 20 62 79 74  this Blob in byt
0e70: 65 73 20 2a 2f 0a 20 20 75 6e 73 69 67 6e 65 64  es */.  unsigned
0e80: 20 63 68 61 72 20 61 5b 31 5d 3b 20 20 20 20 20   char a[1];     
0e90: 2f 2a 20 42 6c 6f 62 20 63 6f 6e 74 65 6e 74 2e  /* Blob content.
0ea0: 20 20 45 78 74 72 61 20 73 70 61 63 65 20 61 6c    Extra space al
0eb0: 6c 6f 63 61 74 65 64 20 61 73 20 6e 65 65 64 65  located as neede
0ec0: 64 2e 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  d. */.};../*.** 
0ed0: 4d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f  Maximum number o
0ee0: 66 20 66 69 6c 65 73 20 69 6e 20 74 68 65 20 69  f files in the i
0ef0: 6e 2d 6d 65 6d 6f 72 79 20 76 69 72 74 75 61 6c  n-memory virtual
0f00: 20 66 69 6c 65 73 79 73 74 65 6d 2e 0a 2a 2f 0a   filesystem..*/.
0f10: 23 64 65 66 69 6e 65 20 4d 58 5f 46 49 4c 45 20  #define MX_FILE 
0f20: 20 31 30 0a 0a 2f 2a 0a 2a 2a 20 4d 61 78 69 6d   10../*.** Maxim
0f30: 75 6d 20 61 6c 6c 6f 77 65 64 20 66 69 6c 65 20  um allowed file 
0f40: 73 69 7a 65 0a 2a 2f 0a 23 64 65 66 69 6e 65 20  size.*/.#define 
0f50: 4d 58 5f 46 49 4c 45 5f 53 5a 20 31 30 30 30 30  MX_FILE_SZ 10000
0f60: 30 30 30 0a 0a 2f 2a 0a 2a 2a 20 41 6c 6c 20 67  000../*.** All g
0f70: 6c 6f 62 61 6c 20 76 61 72 69 61 62 6c 65 73 20  lobal variables 
0f80: 61 72 65 20 67 61 74 68 65 72 65 64 20 69 6e 74  are gathered int
0f90: 6f 20 74 68 65 20 22 67 22 20 73 69 6e 67 6c 65  o the "g" single
0fa0: 74 6f 6e 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 73  ton..*/.static s
0fb0: 74 72 75 63 74 20 47 6c 6f 62 61 6c 56 61 72 73  truct GlobalVars
0fc0: 20 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20   {.  const char 
0fd0: 2a 7a 41 72 67 76 30 3b 20 20 20 20 20 20 20 20  *zArgv0;        
0fe0: 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66        /* Name of
0ff0: 20 70 72 6f 67 72 61 6d 20 2a 2f 0a 20 20 56 46   program */.  VF
1000: 69 6c 65 20 61 46 69 6c 65 5b 4d 58 5f 46 49 4c  ile aFile[MX_FIL
1010: 45 5d 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f  E];            /
1020: 2a 20 54 68 65 20 76 69 72 74 75 61 6c 20 66 69  * The virtual fi
1030: 6c 65 73 79 73 74 65 6d 20 2a 2f 0a 20 20 69 6e  lesystem */.  in
1040: 74 20 6e 44 62 3b 20 20 20 20 20 20 20 20 20 20  t nDb;          
1050: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
1060: 2a 20 4e 75 6d 62 65 72 20 6f 66 20 74 65 6d 70  * Number of temp
1070: 6c 61 74 65 20 64 61 74 61 62 61 73 65 73 20 2a  late databases *
1080: 2f 0a 20 20 42 6c 6f 62 20 2a 70 46 69 72 73 74  /.  Blob *pFirst
1090: 44 62 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  Db;             
10a0: 20 20 20 20 20 2f 2a 20 43 6f 6e 74 65 6e 74 20       /* Content 
10b0: 6f 66 20 66 69 72 73 74 20 74 65 6d 70 6c 61 74  of first templat
10c0: 65 20 64 61 74 61 62 61 73 65 20 2a 2f 0a 20 20  e database */.  
10d0: 69 6e 74 20 6e 53 71 6c 3b 20 20 20 20 20 20 20  int nSql;       
10e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
10f0: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 53 51   /* Number of SQ
1100: 4c 20 73 63 72 69 70 74 73 20 2a 2f 0a 20 20 42  L scripts */.  B
1110: 6c 6f 62 20 2a 70 46 69 72 73 74 53 71 6c 3b 20  lob *pFirstSql; 
1120: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1130: 2f 2a 20 46 69 72 73 74 20 53 51 4c 20 73 63 72  /* First SQL scr
1140: 69 70 74 20 2a 2f 0a 20 20 63 68 61 72 20 7a 54  ipt */.  char zT
1150: 65 73 74 4e 61 6d 65 5b 31 30 30 5d 3b 20 20 20  estName[100];   
1160: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d            /* Nam
1170: 65 20 6f 66 20 63 75 72 72 65 6e 74 20 74 65 73  e of current tes
1180: 74 20 2a 2f 0a 7d 20 67 3b 0a 0a 2f 2a 0a 2a 2a  t */.} g;../*.**
1190: 20 50 72 69 6e 74 20 61 6e 20 65 72 72 6f 72 20   Print an error 
11a0: 6d 65 73 73 61 67 65 20 61 6e 64 20 71 75 69 74  message and quit
11b0: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  ..*/.static void
11c0: 20 66 61 74 61 6c 45 72 72 6f 72 28 63 6f 6e 73   fatalError(cons
11d0: 74 20 63 68 61 72 20 2a 7a 46 6f 72 6d 61 74 2c  t char *zFormat,
11e0: 20 2e 2e 2e 29 7b 0a 20 20 76 61 5f 6c 69 73 74   ...){.  va_list
11f0: 20 61 70 3b 0a 20 20 69 66 28 20 67 2e 7a 54 65   ap;.  if( g.zTe
1200: 73 74 4e 61 6d 65 5b 30 5d 20 29 7b 0a 20 20 20  stName[0] ){.   
1210: 20 66 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c   fprintf(stderr,
1220: 20 22 25 73 20 28 25 73 29 3a 20 22 2c 20 67 2e   "%s (%s): ", g.
1230: 7a 41 72 67 76 30 2c 20 67 2e 7a 54 65 73 74 4e  zArgv0, g.zTestN
1240: 61 6d 65 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20  ame);.  }else{. 
1250: 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72     fprintf(stder
1260: 72 2c 20 22 25 73 3a 20 22 2c 20 67 2e 7a 41 72  r, "%s: ", g.zAr
1270: 67 76 30 29 3b 0a 20 20 7d 0a 20 20 76 61 5f 73  gv0);.  }.  va_s
1280: 74 61 72 74 28 61 70 2c 20 7a 46 6f 72 6d 61 74  tart(ap, zFormat
1290: 29 3b 0a 20 20 76 66 70 72 69 6e 74 66 28 73 74  );.  vfprintf(st
12a0: 64 65 72 72 2c 20 7a 46 6f 72 6d 61 74 2c 20 61  derr, zFormat, a
12b0: 70 29 3b 0a 20 20 76 61 5f 65 6e 64 28 61 70 29  p);.  va_end(ap)
12c0: 3b 0a 20 20 66 70 72 69 6e 74 66 28 73 74 64 65  ;.  fprintf(stde
12d0: 72 72 2c 20 22 5c 6e 22 29 3b 0a 20 20 65 78 69  rr, "\n");.  exi
12e0: 74 28 31 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52  t(1);.}../*.** R
12f0: 65 61 6c 6c 6f 63 61 74 65 20 6d 65 6d 6f 72 79  eallocate memory
1300: 2e 20 20 53 68 6f 77 20 61 6e 64 20 65 72 72 6f  .  Show and erro
1310: 72 20 61 6e 64 20 71 75 69 74 20 69 66 20 75 6e  r and quit if un
1320: 61 62 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  able..*/.static 
1330: 76 6f 69 64 20 2a 73 61 66 65 5f 72 65 61 6c 6c  void *safe_reall
1340: 6f 63 28 76 6f 69 64 20 2a 70 4f 6c 64 2c 20 69  oc(void *pOld, i
1350: 6e 74 20 73 7a 4e 65 77 29 7b 0a 20 20 76 6f 69  nt szNew){.  voi
1360: 64 20 2a 70 4e 65 77 20 3d 20 72 65 61 6c 6c 6f  d *pNew = reallo
1370: 63 28 70 4f 6c 64 2c 20 73 7a 4e 65 77 29 3b 0a  c(pOld, szNew);.
1380: 20 20 69 66 28 20 70 4e 65 77 3d 3d 30 20 29 20    if( pNew==0 ) 
1390: 66 61 74 61 6c 45 72 72 6f 72 28 22 75 6e 61 62  fatalError("unab
13a0: 6c 65 20 74 6f 20 72 65 61 6c 6c 6f 63 20 66 6f  le to realloc fo
13b0: 72 20 25 64 20 62 79 74 65 73 22 2c 20 73 7a 4e  r %d bytes", szN
13c0: 65 77 29 3b 0a 20 20 72 65 74 75 72 6e 20 70 4e  ew);.  return pN
13d0: 65 77 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 69  ew;.}../*.** Ini
13e0: 74 69 61 6c 69 7a 65 20 74 68 65 20 76 69 72 74  tialize the virt
13f0: 75 61 6c 20 66 69 6c 65 20 73 79 73 74 65 6d 2e  ual file system.
1400: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
1410: 66 6f 72 6d 61 74 56 66 73 28 76 6f 69 64 29 7b  formatVfs(void){
1420: 0a 20 20 69 6e 74 20 69 3b 0a 20 20 66 6f 72 28  .  int i;.  for(
1430: 69 3d 30 3b 20 69 3c 4d 58 5f 46 49 4c 45 3b 20  i=0; i<MX_FILE; 
1440: 69 2b 2b 29 7b 0a 20 20 20 20 67 2e 61 46 69 6c  i++){.    g.aFil
1450: 65 5b 69 5d 2e 73 7a 20 3d 20 2d 31 3b 0a 20 20  e[i].sz = -1;.  
1460: 20 20 67 2e 61 46 69 6c 65 5b 69 5d 2e 7a 46 69    g.aFile[i].zFi
1470: 6c 65 6e 61 6d 65 20 3d 20 30 3b 0a 20 20 20 20  lename = 0;.    
1480: 67 2e 61 46 69 6c 65 5b 69 5d 2e 61 20 3d 20 30  g.aFile[i].a = 0
1490: 3b 0a 20 20 20 20 67 2e 61 46 69 6c 65 5b 69 5d  ;.    g.aFile[i]
14a0: 2e 6e 52 65 66 20 3d 20 30 3b 0a 20 20 7d 0a 7d  .nRef = 0;.  }.}
14b0: 0a 0a 0a 2f 2a 0a 2a 2a 20 45 72 61 73 65 20 61  .../*.** Erase a
14c0: 6c 6c 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 69  ll information i
14d0: 6e 20 74 68 65 20 76 69 72 74 75 61 6c 20 66 69  n the virtual fi
14e0: 6c 65 20 73 79 73 74 65 6d 2e 0a 2a 2f 0a 73 74  le system..*/.st
14f0: 61 74 69 63 20 76 6f 69 64 20 72 65 66 6f 72 6d  atic void reform
1500: 61 74 56 66 73 28 76 6f 69 64 29 7b 0a 20 20 69  atVfs(void){.  i
1510: 6e 74 20 69 3b 0a 20 20 66 6f 72 28 69 3d 30 3b  nt i;.  for(i=0;
1520: 20 69 3c 4d 58 5f 46 49 4c 45 3b 20 69 2b 2b 29   i<MX_FILE; i++)
1530: 7b 0a 20 20 20 20 69 66 28 20 67 2e 61 46 69 6c  {.    if( g.aFil
1540: 65 5b 69 5d 2e 73 7a 3c 30 20 29 20 63 6f 6e 74  e[i].sz<0 ) cont
1550: 69 6e 75 65 3b 0a 20 20 20 20 69 66 28 20 67 2e  inue;.    if( g.
1560: 61 46 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65 6e 61  aFile[i].zFilena
1570: 6d 65 20 29 7b 0a 20 20 20 20 20 20 66 72 65 65  me ){.      free
1580: 28 67 2e 61 46 69 6c 65 5b 69 5d 2e 7a 46 69 6c  (g.aFile[i].zFil
1590: 65 6e 61 6d 65 29 3b 0a 20 20 20 20 20 20 67 2e  ename);.      g.
15a0: 61 46 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65 6e 61  aFile[i].zFilena
15b0: 6d 65 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 20 20  me = 0;.    }.  
15c0: 20 20 69 66 28 20 67 2e 61 46 69 6c 65 5b 69 5d    if( g.aFile[i]
15d0: 2e 6e 52 65 66 3e 30 20 29 7b 0a 20 20 20 20 20  .nRef>0 ){.     
15e0: 20 66 61 74 61 6c 45 72 72 6f 72 28 22 66 69 6c   fatalError("fil
15f0: 65 20 25 64 20 73 74 69 6c 6c 20 6f 70 65 6e 2e  e %d still open.
1600: 20 20 6e 52 65 66 3d 25 64 22 2c 20 69 2c 20 67    nRef=%d", i, g
1610: 2e 61 46 69 6c 65 5b 69 5d 2e 6e 52 65 66 29 3b  .aFile[i].nRef);
1620: 0a 20 20 20 20 7d 0a 20 20 20 20 67 2e 61 46 69  .    }.    g.aFi
1630: 6c 65 5b 69 5d 2e 73 7a 20 3d 20 2d 31 3b 0a 20  le[i].sz = -1;. 
1640: 20 20 20 66 72 65 65 28 67 2e 61 46 69 6c 65 5b     free(g.aFile[
1650: 69 5d 2e 61 29 3b 0a 20 20 20 20 67 2e 61 46 69  i].a);.    g.aFi
1660: 6c 65 5b 69 5d 2e 61 20 3d 20 30 3b 0a 20 20 20  le[i].a = 0;.   
1670: 20 67 2e 61 46 69 6c 65 5b 69 5d 2e 6e 52 65 66   g.aFile[i].nRef
1680: 20 3d 20 30 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a   = 0;.  }.}../*.
1690: 2a 2a 20 46 69 6e 64 20 61 20 56 46 69 6c 65 20  ** Find a VFile 
16a0: 62 79 20 6e 61 6d 65 0a 2a 2f 0a 73 74 61 74 69  by name.*/.stati
16b0: 63 20 56 46 69 6c 65 20 2a 66 69 6e 64 56 46 69  c VFile *findVFi
16c0: 6c 65 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  le(const char *z
16d0: 4e 61 6d 65 29 7b 0a 20 20 69 6e 74 20 69 3b 0a  Name){.  int i;.
16e0: 20 20 69 66 28 20 7a 4e 61 6d 65 3d 3d 30 20 29    if( zName==0 )
16f0: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 66 6f 72   return 0;.  for
1700: 28 69 3d 30 3b 20 69 3c 4d 58 5f 46 49 4c 45 3b  (i=0; i<MX_FILE;
1710: 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 67   i++){.    if( g
1720: 2e 61 46 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65 6e  .aFile[i].zFilen
1730: 61 6d 65 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75  ame==0 ) continu
1740: 65 3b 20 20 20 0a 20 20 20 20 69 66 28 20 73 74  e;   .    if( st
1750: 72 63 6d 70 28 67 2e 61 46 69 6c 65 5b 69 5d 2e  rcmp(g.aFile[i].
1760: 7a 46 69 6c 65 6e 61 6d 65 2c 20 7a 4e 61 6d 65  zFilename, zName
1770: 29 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 26 67  )==0 ) return &g
1780: 2e 61 46 69 6c 65 5b 69 5d 3b 0a 20 20 7d 0a 20  .aFile[i];.  }. 
1790: 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a   return 0;.}../*
17a0: 0a 2a 2a 20 46 69 6e 64 20 61 20 56 46 69 6c 65  .** Find a VFile
17b0: 20 62 79 20 6e 61 6d 65 2e 20 20 43 72 65 61 74   by name.  Creat
17c0: 65 20 69 74 20 69 66 20 69 74 20 64 6f 65 73 20  e it if it does 
17d0: 6e 6f 74 20 61 6c 72 65 61 64 79 20 65 78 69 73  not already exis
17e0: 74 20 61 6e 64 0a 2a 2a 20 69 6e 69 74 69 61 6c  t and.** initial
17f0: 69 7a 65 20 69 74 20 74 6f 20 74 68 65 20 73 69  ize it to the si
1800: 7a 65 20 61 6e 64 20 63 6f 6e 74 65 6e 74 20 67  ze and content g
1810: 69 76 65 6e 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75  iven..**.** Retu
1820: 72 6e 20 4e 55 4c 4c 20 6f 6e 6c 79 20 69 66 20  rn NULL only if 
1830: 74 68 65 20 66 69 6c 65 73 79 73 74 65 6d 20 69  the filesystem i
1840: 73 20 66 75 6c 6c 2e 0a 2a 2f 0a 73 74 61 74 69  s full..*/.stati
1850: 63 20 56 46 69 6c 65 20 2a 63 72 65 61 74 65 56  c VFile *createV
1860: 46 69 6c 65 28 63 6f 6e 73 74 20 63 68 61 72 20  File(const char 
1870: 2a 7a 4e 61 6d 65 2c 20 69 6e 74 20 73 7a 2c 20  *zName, int sz, 
1880: 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a 70  unsigned char *p
1890: 44 61 74 61 29 7b 0a 20 20 56 46 69 6c 65 20 2a  Data){.  VFile *
18a0: 70 4e 65 77 20 3d 20 66 69 6e 64 56 46 69 6c 65  pNew = findVFile
18b0: 28 7a 4e 61 6d 65 29 3b 0a 20 20 69 6e 74 20 69  (zName);.  int i
18c0: 3b 0a 20 20 69 66 28 20 70 4e 65 77 20 29 20 72  ;.  if( pNew ) r
18d0: 65 74 75 72 6e 20 70 4e 65 77 3b 0a 20 20 66 6f  eturn pNew;.  fo
18e0: 72 28 69 3d 30 3b 20 69 3c 4d 58 5f 46 49 4c 45  r(i=0; i<MX_FILE
18f0: 20 26 26 20 67 2e 61 46 69 6c 65 5b 69 5d 2e 73   && g.aFile[i].s
1900: 7a 3e 3d 30 3b 20 69 2b 2b 29 7b 7d 0a 20 20 69  z>=0; i++){}.  i
1910: 66 28 20 69 3e 3d 4d 58 5f 46 49 4c 45 20 29 20  f( i>=MX_FILE ) 
1920: 72 65 74 75 72 6e 20 30 3b 0a 20 20 70 4e 65 77  return 0;.  pNew
1930: 20 3d 20 26 67 2e 61 46 69 6c 65 5b 69 5d 3b 0a   = &g.aFile[i];.
1940: 20 20 69 66 28 20 7a 4e 61 6d 65 20 29 7b 0a 20    if( zName ){. 
1950: 20 20 20 70 4e 65 77 2d 3e 7a 46 69 6c 65 6e 61     pNew->zFilena
1960: 6d 65 20 3d 20 73 61 66 65 5f 72 65 61 6c 6c 6f  me = safe_reallo
1970: 63 28 30 2c 20 73 74 72 6c 65 6e 28 7a 4e 61 6d  c(0, strlen(zNam
1980: 65 29 2b 31 29 3b 0a 20 20 20 20 6d 65 6d 63 70  e)+1);.    memcp
1990: 79 28 70 4e 65 77 2d 3e 7a 46 69 6c 65 6e 61 6d  y(pNew->zFilenam
19a0: 65 2c 20 7a 4e 61 6d 65 2c 20 73 74 72 6c 65 6e  e, zName, strlen
19b0: 28 7a 4e 61 6d 65 29 2b 31 29 3b 0a 20 20 7d 65  (zName)+1);.  }e
19c0: 6c 73 65 7b 0a 20 20 20 20 70 4e 65 77 2d 3e 7a  lse{.    pNew->z
19d0: 46 69 6c 65 6e 61 6d 65 20 3d 20 30 3b 0a 20 20  Filename = 0;.  
19e0: 7d 0a 20 20 70 4e 65 77 2d 3e 6e 52 65 66 20 3d  }.  pNew->nRef =
19f0: 20 30 3b 0a 20 20 70 4e 65 77 2d 3e 73 7a 20 3d   0;.  pNew->sz =
1a00: 20 73 7a 3b 0a 20 20 70 4e 65 77 2d 3e 61 20 3d   sz;.  pNew->a =
1a10: 20 73 61 66 65 5f 72 65 61 6c 6c 6f 63 28 30 2c   safe_realloc(0,
1a20: 20 73 7a 29 3b 0a 20 20 69 66 28 20 73 7a 3e 30   sz);.  if( sz>0
1a30: 20 29 20 6d 65 6d 63 70 79 28 70 4e 65 77 2d 3e   ) memcpy(pNew->
1a40: 61 2c 20 70 44 61 74 61 2c 20 73 7a 29 3b 0a 20  a, pData, sz);. 
1a50: 20 72 65 74 75 72 6e 20 70 4e 65 77 3b 0a 7d 0a   return pNew;.}.
1a60: 0a 0a 2f 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e  ../*.** Implemen
1a70: 74 61 74 69 6f 6e 20 6f 66 20 74 68 65 20 22 72  tation of the "r
1a80: 65 61 64 66 69 6c 65 28 58 29 22 20 53 51 4c 20  eadfile(X)" SQL 
1a90: 66 75 6e 63 74 69 6f 6e 2e 20 20 54 68 65 20 65  function.  The e
1aa0: 6e 74 69 72 65 20 63 6f 6e 74 65 6e 74 0a 2a 2a  ntire content.**
1ab0: 20 6f 66 20 74 68 65 20 66 69 6c 65 20 6e 61 6d   of the file nam
1ac0: 65 64 20 58 20 69 73 20 72 65 61 64 20 61 6e 64  ed X is read and
1ad0: 20 72 65 74 75 72 6e 65 64 20 61 73 20 61 20 42   returned as a B
1ae0: 4c 4f 42 2e 20 20 4e 55 4c 4c 20 69 73 20 72 65  LOB.  NULL is re
1af0: 74 75 72 6e 65 64 0a 2a 2a 20 69 66 20 74 68 65  turned.** if the
1b00: 20 66 69 6c 65 20 64 6f 65 73 20 6e 6f 74 20 65   file does not e
1b10: 78 69 73 74 20 6f 72 20 69 73 20 75 6e 72 65 61  xist or is unrea
1b20: 64 61 62 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  dable..*/.static
1b30: 20 76 6f 69 64 20 72 65 61 64 66 69 6c 65 46 75   void readfileFu
1b40: 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  nc(.  sqlite3_co
1b50: 6e 74 65 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a  ntext *context,.
1b60: 20 20 69 6e 74 20 61 72 67 63 2c 0a 20 20 73 71    int argc,.  sq
1b70: 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72  lite3_value **ar
1b80: 67 76 0a 29 7b 0a 20 20 63 6f 6e 73 74 20 63 68  gv.){.  const ch
1b90: 61 72 20 2a 7a 4e 61 6d 65 3b 0a 20 20 46 49 4c  ar *zName;.  FIL
1ba0: 45 20 2a 69 6e 3b 0a 20 20 6c 6f 6e 67 20 6e 49  E *in;.  long nI
1bb0: 6e 3b 0a 20 20 76 6f 69 64 20 2a 70 42 75 66 3b  n;.  void *pBuf;
1bc0: 0a 0a 20 20 7a 4e 61 6d 65 20 3d 20 28 63 6f 6e  ..  zName = (con
1bd0: 73 74 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33  st char*)sqlite3
1be0: 5f 76 61 6c 75 65 5f 74 65 78 74 28 61 72 67 76  _value_text(argv
1bf0: 5b 30 5d 29 3b 0a 20 20 69 66 28 20 7a 4e 61 6d  [0]);.  if( zNam
1c00: 65 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 20  e==0 ) return;. 
1c10: 20 69 6e 20 3d 20 66 6f 70 65 6e 28 7a 4e 61 6d   in = fopen(zNam
1c20: 65 2c 20 22 72 62 22 29 3b 0a 20 20 69 66 28 20  e, "rb");.  if( 
1c30: 69 6e 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a  in==0 ) return;.
1c40: 20 20 66 73 65 65 6b 28 69 6e 2c 20 30 2c 20 53    fseek(in, 0, S
1c50: 45 45 4b 5f 45 4e 44 29 3b 0a 20 20 6e 49 6e 20  EEK_END);.  nIn 
1c60: 3d 20 66 74 65 6c 6c 28 69 6e 29 3b 0a 20 20 72  = ftell(in);.  r
1c70: 65 77 69 6e 64 28 69 6e 29 3b 0a 20 20 70 42 75  ewind(in);.  pBu
1c80: 66 20 3d 20 73 71 6c 69 74 65 33 5f 6d 61 6c 6c  f = sqlite3_mall
1c90: 6f 63 36 34 28 20 6e 49 6e 20 29 3b 0a 20 20 69  oc64( nIn );.  i
1ca0: 66 28 20 70 42 75 66 20 26 26 20 31 3d 3d 66 72  f( pBuf && 1==fr
1cb0: 65 61 64 28 70 42 75 66 2c 20 6e 49 6e 2c 20 31  ead(pBuf, nIn, 1
1cc0: 2c 20 69 6e 29 20 29 7b 0a 20 20 20 20 73 71 6c  , in) ){.    sql
1cd0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 62 6c 6f 62  ite3_result_blob
1ce0: 28 63 6f 6e 74 65 78 74 2c 20 70 42 75 66 2c 20  (context, pBuf, 
1cf0: 6e 49 6e 2c 20 73 71 6c 69 74 65 33 5f 66 72 65  nIn, sqlite3_fre
1d00: 65 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  e);.  }else{.   
1d10: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70 42   sqlite3_free(pB
1d20: 75 66 29 3b 0a 20 20 7d 0a 20 20 66 63 6c 6f 73  uf);.  }.  fclos
1d30: 65 28 69 6e 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  e(in);.}../*.** 
1d40: 4c 6f 61 64 20 61 20 6c 69 73 74 20 6f 66 20 42  Load a list of B
1d50: 6c 6f 62 20 6f 62 6a 65 63 74 73 20 66 72 6f 6d  lob objects from
1d60: 20 74 68 65 20 64 61 74 61 62 61 73 65 0a 2a 2f   the database.*/
1d70: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 62 6c 6f  .static void blo
1d80: 62 4c 69 73 74 4c 6f 61 64 46 72 6f 6d 44 62 28  bListLoadFromDb(
1d90: 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 2c 20  .  sqlite3 *db, 
1da0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 52              /* R
1db0: 65 61 64 20 66 72 6f 6d 20 74 68 69 73 20 64 61  ead from this da
1dc0: 74 61 62 61 73 65 20 2a 2f 0a 20 20 63 6f 6e 73  tabase */.  cons
1dd0: 74 20 63 68 61 72 20 2a 7a 53 71 6c 2c 20 20 20  t char *zSql,   
1de0: 20 20 20 20 20 2f 2a 20 51 75 65 72 79 20 75 73       /* Query us
1df0: 65 64 20 74 6f 20 65 78 74 72 61 63 74 20 74 68  ed to extract th
1e00: 65 20 62 6c 6f 62 73 20 2a 2f 0a 20 20 69 6e 74  e blobs */.  int
1e10: 20 6f 6e 6c 79 49 64 2c 20 20 20 20 20 20 20 20   onlyId,        
1e20: 20 20 20 20 20 20 2f 2a 20 4f 6e 6c 79 20 6c 6f        /* Only lo
1e30: 61 64 20 77 68 65 72 65 20 69 64 20 69 73 20 74  ad where id is t
1e40: 68 69 73 20 76 61 6c 75 65 20 2a 2f 0a 20 20 69  his value */.  i
1e50: 6e 74 20 2a 70 4e 2c 20 20 20 20 20 20 20 20 20  nt *pN,         
1e60: 20 20 20 20 20 20 20 20 2f 2a 20 4f 55 54 3a 20          /* OUT: 
1e70: 57 72 69 74 65 20 6e 75 6d 62 65 72 20 6f 66 20  Write number of 
1e80: 62 6c 6f 62 73 20 6c 6f 61 64 65 64 20 68 65 72  blobs loaded her
1e90: 65 20 2a 2f 0a 20 20 42 6c 6f 62 20 2a 2a 70 70  e */.  Blob **pp
1ea0: 4c 69 73 74 20 20 20 20 20 20 20 20 20 20 20 20  List            
1eb0: 2f 2a 20 4f 55 54 3a 20 57 72 69 74 65 20 74 68  /* OUT: Write th
1ec0: 65 20 68 65 61 64 20 6f 66 20 74 68 65 20 62 6c  e head of the bl
1ed0: 6f 62 20 6c 69 73 74 20 68 65 72 65 20 2a 2f 0a  ob list here */.
1ee0: 29 7b 0a 20 20 42 6c 6f 62 20 68 65 61 64 3b 0a  ){.  Blob head;.
1ef0: 20 20 42 6c 6f 62 20 2a 70 3b 0a 20 20 73 71 6c    Blob *p;.  sql
1f00: 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74  ite3_stmt *pStmt
1f10: 3b 0a 20 20 69 6e 74 20 6e 20 3d 20 30 3b 0a 20  ;.  int n = 0;. 
1f20: 20 69 6e 74 20 72 63 3b 0a 20 20 63 68 61 72 20   int rc;.  char 
1f30: 2a 7a 32 3b 0a 0a 20 20 69 66 28 20 6f 6e 6c 79  *z2;..  if( only
1f40: 49 64 3e 30 20 29 7b 0a 20 20 20 20 7a 32 20 3d  Id>0 ){.    z2 =
1f50: 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66   sqlite3_mprintf
1f60: 28 22 25 73 20 57 48 45 52 45 20 72 6f 77 69 64  ("%s WHERE rowid
1f70: 3d 25 64 22 2c 20 7a 53 71 6c 2c 20 6f 6e 6c 79  =%d", zSql, only
1f80: 49 64 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  Id);.  }else{.  
1f90: 20 20 7a 32 20 3d 20 73 71 6c 69 74 65 33 5f 6d    z2 = sqlite3_m
1fa0: 70 72 69 6e 74 66 28 22 25 73 22 2c 20 7a 53 71  printf("%s", zSq
1fb0: 6c 29 3b 0a 20 20 7d 0a 20 20 72 63 20 3d 20 73  l);.  }.  rc = s
1fc0: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
1fd0: 32 28 64 62 2c 20 7a 32 2c 20 2d 31 2c 20 26 70  2(db, z2, -1, &p
1fe0: 53 74 6d 74 2c 20 30 29 3b 0a 20 20 73 71 6c 69  Stmt, 0);.  sqli
1ff0: 74 65 33 5f 66 72 65 65 28 7a 32 29 3b 0a 20 20  te3_free(z2);.  
2000: 69 66 28 20 72 63 20 29 20 66 61 74 61 6c 45 72  if( rc ) fatalEr
2010: 72 6f 72 28 22 25 73 22 2c 20 73 71 6c 69 74 65  ror("%s", sqlite
2020: 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20  3_errmsg(db));. 
2030: 20 68 65 61 64 2e 70 4e 65 78 74 20 3d 20 30 3b   head.pNext = 0;
2040: 0a 20 20 70 20 3d 20 26 68 65 61 64 3b 0a 20 20  .  p = &head;.  
2050: 77 68 69 6c 65 28 20 53 51 4c 49 54 45 5f 52 4f  while( SQLITE_RO
2060: 57 3d 3d 73 71 6c 69 74 65 33 5f 73 74 65 70 28  W==sqlite3_step(
2070: 70 53 74 6d 74 29 20 29 7b 0a 20 20 20 20 69 6e  pStmt) ){.    in
2080: 74 20 73 7a 20 3d 20 73 71 6c 69 74 65 33 5f 63  t sz = sqlite3_c
2090: 6f 6c 75 6d 6e 5f 62 79 74 65 73 28 70 53 74 6d  olumn_bytes(pStm
20a0: 74 2c 20 31 29 3b 0a 20 20 20 20 42 6c 6f 62 20  t, 1);.    Blob 
20b0: 2a 70 4e 65 77 20 3d 20 73 61 66 65 5f 72 65 61  *pNew = safe_rea
20c0: 6c 6c 6f 63 28 30 2c 20 73 69 7a 65 6f 66 28 2a  lloc(0, sizeof(*
20d0: 70 4e 65 77 29 2b 73 7a 20 29 3b 0a 20 20 20 20  pNew)+sz );.    
20e0: 70 4e 65 77 2d 3e 69 64 20 3d 20 73 71 6c 69 74  pNew->id = sqlit
20f0: 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 28 70 53  e3_column_int(pS
2100: 74 6d 74 2c 20 30 29 3b 0a 20 20 20 20 70 4e 65  tmt, 0);.    pNe
2110: 77 2d 3e 73 7a 20 3d 20 73 7a 3b 0a 20 20 20 20  w->sz = sz;.    
2120: 70 4e 65 77 2d 3e 73 65 71 20 3d 20 6e 2b 2b 3b  pNew->seq = n++;
2130: 0a 20 20 20 20 70 4e 65 77 2d 3e 70 4e 65 78 74  .    pNew->pNext
2140: 20 3d 20 30 3b 0a 20 20 20 20 6d 65 6d 63 70 79   = 0;.    memcpy
2150: 28 70 4e 65 77 2d 3e 61 2c 20 73 71 6c 69 74 65  (pNew->a, sqlite
2160: 33 5f 63 6f 6c 75 6d 6e 5f 62 6c 6f 62 28 70 53  3_column_blob(pS
2170: 74 6d 74 2c 31 29 2c 20 73 7a 29 3b 0a 20 20 20  tmt,1), sz);.   
2180: 20 70 4e 65 77 2d 3e 61 5b 73 7a 5d 20 3d 20 30   pNew->a[sz] = 0
2190: 3b 0a 20 20 20 20 70 2d 3e 70 4e 65 78 74 20 3d  ;.    p->pNext =
21a0: 20 70 4e 65 77 3b 0a 20 20 20 20 70 20 3d 20 70   pNew;.    p = p
21b0: 4e 65 77 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74  New;.  }.  sqlit
21c0: 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53 74 6d  e3_finalize(pStm
21d0: 74 29 3b 0a 20 20 2a 70 4e 20 3d 20 6e 3b 0a 20  t);.  *pN = n;. 
21e0: 20 2a 70 70 4c 69 73 74 20 3d 20 68 65 61 64 2e   *ppList = head.
21f0: 70 4e 65 78 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  pNext;.}../*.** 
2200: 46 72 65 65 20 61 20 6c 69 73 74 20 6f 66 20 42  Free a list of B
2210: 6c 6f 62 20 6f 62 6a 65 63 74 73 0a 2a 2f 0a 73  lob objects.*/.s
2220: 74 61 74 69 63 20 76 6f 69 64 20 62 6c 6f 62 4c  tatic void blobL
2230: 69 73 74 46 72 65 65 28 42 6c 6f 62 20 2a 70 29  istFree(Blob *p)
2240: 7b 0a 20 20 42 6c 6f 62 20 2a 70 4e 65 78 74 3b  {.  Blob *pNext;
2250: 0a 20 20 77 68 69 6c 65 28 20 70 20 29 7b 0a 20  .  while( p ){. 
2260: 20 20 20 70 4e 65 78 74 20 3d 20 70 2d 3e 70 4e     pNext = p->pN
2270: 65 78 74 3b 0a 20 20 20 20 66 72 65 65 28 70 29  ext;.    free(p)
2280: 3b 0a 20 20 20 20 70 20 3d 20 70 4e 65 78 74 3b  ;.    p = pNext;
2290: 0a 20 20 7d 0a 7d 0a 0a 0a 2f 2a 20 52 65 74 75  .  }.}.../* Retu
22a0: 72 6e 20 74 68 65 20 63 75 72 72 65 6e 74 20 77  rn the current w
22b0: 61 6c 6c 2d 63 6c 6f 63 6b 20 74 69 6d 65 20 2a  all-clock time *
22c0: 2f 0a 73 74 61 74 69 63 20 73 71 6c 69 74 65 33  /.static sqlite3
22d0: 5f 69 6e 74 36 34 20 74 69 6d 65 4f 66 44 61 79  _int64 timeOfDay
22e0: 28 76 6f 69 64 29 7b 0a 20 20 73 74 61 74 69 63  (void){.  static
22f0: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 63 6c   sqlite3_vfs *cl
2300: 6f 63 6b 56 66 73 20 3d 20 30 3b 0a 20 20 73 71  ockVfs = 0;.  sq
2310: 6c 69 74 65 33 5f 69 6e 74 36 34 20 74 3b 0a 20  lite3_int64 t;. 
2320: 20 69 66 28 20 63 6c 6f 63 6b 56 66 73 3d 3d 30   if( clockVfs==0
2330: 20 29 20 63 6c 6f 63 6b 56 66 73 20 3d 20 73 71   ) clockVfs = sq
2340: 6c 69 74 65 33 5f 76 66 73 5f 66 69 6e 64 28 30  lite3_vfs_find(0
2350: 29 3b 0a 20 20 69 66 28 20 63 6c 6f 63 6b 56 66  );.  if( clockVf
2360: 73 2d 3e 69 56 65 72 73 69 6f 6e 3e 3d 31 20 26  s->iVersion>=1 &
2370: 26 20 63 6c 6f 63 6b 56 66 73 2d 3e 78 43 75 72  & clockVfs->xCur
2380: 72 65 6e 74 54 69 6d 65 49 6e 74 36 34 21 3d 30  rentTimeInt64!=0
2390: 20 29 7b 0a 20 20 20 20 63 6c 6f 63 6b 56 66 73   ){.    clockVfs
23a0: 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d 65 49 6e  ->xCurrentTimeIn
23b0: 74 36 34 28 63 6c 6f 63 6b 56 66 73 2c 20 26 74  t64(clockVfs, &t
23c0: 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  );.  }else{.    
23d0: 64 6f 75 62 6c 65 20 72 3b 0a 20 20 20 20 63 6c  double r;.    cl
23e0: 6f 63 6b 56 66 73 2d 3e 78 43 75 72 72 65 6e 74  ockVfs->xCurrent
23f0: 54 69 6d 65 28 63 6c 6f 63 6b 56 66 73 2c 20 26  Time(clockVfs, &
2400: 72 29 3b 0a 20 20 20 20 74 20 3d 20 28 73 71 6c  r);.    t = (sql
2410: 69 74 65 33 5f 69 6e 74 36 34 29 28 72 2a 38 36  ite3_int64)(r*86
2420: 34 30 30 30 30 30 2e 30 29 3b 0a 20 20 7d 0a 20  400000.0);.  }. 
2430: 20 72 65 74 75 72 6e 20 74 3b 0a 7d 0a 0a 2f 2a   return t;.}../*
2440: 20 4d 65 74 68 6f 64 73 20 66 6f 72 20 74 68 65   Methods for the
2450: 20 56 48 61 6e 64 6c 65 20 6f 62 6a 65 63 74 0a   VHandle object.
2460: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 69 6e  */.static int in
2470: 6d 65 6d 43 6c 6f 73 65 28 73 71 6c 69 74 65 33  memClose(sqlite3
2480: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 29 7b 0a 20  _file *pFile){. 
2490: 20 56 48 61 6e 64 6c 65 20 2a 70 20 3d 20 28 56   VHandle *p = (V
24a0: 48 61 6e 64 6c 65 2a 29 70 46 69 6c 65 3b 0a 20  Handle*)pFile;. 
24b0: 20 56 46 69 6c 65 20 2a 70 56 46 69 6c 65 20 3d   VFile *pVFile =
24c0: 20 70 2d 3e 70 56 46 69 6c 65 3b 0a 20 20 70 56   p->pVFile;.  pV
24d0: 46 69 6c 65 2d 3e 6e 52 65 66 2d 2d 3b 0a 20 20  File->nRef--;.  
24e0: 69 66 28 20 70 56 46 69 6c 65 2d 3e 6e 52 65 66  if( pVFile->nRef
24f0: 3d 3d 30 20 26 26 20 70 56 46 69 6c 65 2d 3e 7a  ==0 && pVFile->z
2500: 46 69 6c 65 6e 61 6d 65 3d 3d 30 20 29 7b 0a 20  Filename==0 ){. 
2510: 20 20 20 70 56 46 69 6c 65 2d 3e 73 7a 20 3d 20     pVFile->sz = 
2520: 2d 31 3b 0a 20 20 20 20 66 72 65 65 28 70 56 46  -1;.    free(pVF
2530: 69 6c 65 2d 3e 61 29 3b 0a 20 20 20 20 70 56 46  ile->a);.    pVF
2540: 69 6c 65 2d 3e 61 20 3d 20 30 3b 0a 20 20 7d 0a  ile->a = 0;.  }.
2550: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
2560: 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e 74  OK;.}.static int
2570: 20 69 6e 6d 65 6d 52 65 61 64 28 0a 20 20 73 71   inmemRead(.  sq
2580: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c  lite3_file *pFil
2590: 65 2c 20 20 20 2f 2a 20 52 65 61 64 20 66 72 6f  e,   /* Read fro
25a0: 6d 20 74 68 69 73 20 6f 70 65 6e 20 66 69 6c 65  m this open file
25b0: 20 2a 2f 0a 20 20 76 6f 69 64 20 2a 70 44 61 74   */.  void *pDat
25c0: 61 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  a,           /* 
25d0: 53 74 6f 72 65 20 63 6f 6e 74 65 6e 74 20 69 6e  Store content in
25e0: 20 74 68 69 73 20 62 75 66 66 65 72 20 2a 2f 0a   this buffer */.
25f0: 20 20 69 6e 74 20 69 41 6d 74 2c 20 20 20 20 20    int iAmt,     
2600: 20 20 20 20 20 20 20 20 20 2f 2a 20 42 79 74 65           /* Byte
2610: 73 20 6f 66 20 63 6f 6e 74 65 6e 74 20 2a 2f 0a  s of content */.
2620: 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20    sqlite3_int64 
2630: 69 4f 66 73 74 20 20 20 20 2f 2a 20 53 74 61 72  iOfst    /* Star
2640: 74 20 72 65 61 64 69 6e 67 20 68 65 72 65 20 2a  t reading here *
2650: 2f 0a 29 7b 0a 20 20 56 48 61 6e 64 6c 65 20 2a  /.){.  VHandle *
2660: 70 48 61 6e 64 6c 65 20 3d 20 28 56 48 61 6e 64  pHandle = (VHand
2670: 6c 65 2a 29 70 46 69 6c 65 3b 0a 20 20 56 46 69  le*)pFile;.  VFi
2680: 6c 65 20 2a 70 56 46 69 6c 65 20 3d 20 70 48 61  le *pVFile = pHa
2690: 6e 64 6c 65 2d 3e 70 56 46 69 6c 65 3b 0a 20 20  ndle->pVFile;.  
26a0: 69 66 28 20 69 4f 66 73 74 3c 30 20 7c 7c 20 69  if( iOfst<0 || i
26b0: 4f 66 73 74 3e 3d 70 56 46 69 6c 65 2d 3e 73 7a  Ofst>=pVFile->sz
26c0: 20 29 7b 0a 20 20 20 20 6d 65 6d 73 65 74 28 70   ){.    memset(p
26d0: 44 61 74 61 2c 20 30 2c 20 69 41 6d 74 29 3b 0a  Data, 0, iAmt);.
26e0: 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54      return SQLIT
26f0: 45 5f 49 4f 45 52 52 5f 53 48 4f 52 54 5f 52 45  E_IOERR_SHORT_RE
2700: 41 44 3b 0a 20 20 7d 0a 20 20 69 66 28 20 69 4f  AD;.  }.  if( iO
2710: 66 73 74 2b 69 41 6d 74 3e 70 56 46 69 6c 65 2d  fst+iAmt>pVFile-
2720: 3e 73 7a 20 29 7b 0a 20 20 20 20 6d 65 6d 73 65  >sz ){.    memse
2730: 74 28 70 44 61 74 61 2c 20 30 2c 20 69 41 6d 74  t(pData, 0, iAmt
2740: 29 3b 0a 20 20 20 20 69 41 6d 74 20 3d 20 28 69  );.    iAmt = (i
2750: 6e 74 29 28 70 56 46 69 6c 65 2d 3e 73 7a 20 2d  nt)(pVFile->sz -
2760: 20 69 4f 66 73 74 29 3b 0a 20 20 20 20 6d 65 6d   iOfst);.    mem
2770: 63 70 79 28 70 44 61 74 61 2c 20 70 56 46 69 6c  cpy(pData, pVFil
2780: 65 2d 3e 61 2c 20 69 41 6d 74 29 3b 0a 20 20 20  e->a, iAmt);.   
2790: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 49   return SQLITE_I
27a0: 4f 45 52 52 5f 53 48 4f 52 54 5f 52 45 41 44 3b  OERR_SHORT_READ;
27b0: 0a 20 20 7d 0a 20 20 6d 65 6d 63 70 79 28 70 44  .  }.  memcpy(pD
27c0: 61 74 61 2c 20 70 56 46 69 6c 65 2d 3e 61 20 2b  ata, pVFile->a +
27d0: 20 69 4f 66 73 74 2c 20 69 41 6d 74 29 3b 0a 20   iOfst, iAmt);. 
27e0: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f   return SQLITE_O
27f0: 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e 74 20  K;.}.static int 
2800: 69 6e 6d 65 6d 57 72 69 74 65 28 0a 20 20 73 71  inmemWrite(.  sq
2810: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c  lite3_file *pFil
2820: 65 2c 20 20 20 2f 2a 20 57 72 69 74 65 20 74 6f  e,   /* Write to
2830: 20 74 68 69 73 20 66 69 6c 65 20 2a 2f 0a 20 20   this file */.  
2840: 63 6f 6e 73 74 20 76 6f 69 64 20 2a 70 44 61 74  const void *pDat
2850: 61 2c 20 20 20 20 20 2f 2a 20 43 6f 6e 74 65 6e  a,     /* Conten
2860: 74 20 74 6f 20 77 72 69 74 65 20 2a 2f 0a 20 20  t to write */.  
2870: 69 6e 74 20 69 41 6d 74 2c 20 20 20 20 20 20 20  int iAmt,       
2880: 20 20 20 20 20 20 20 2f 2a 20 62 79 74 65 73 20         /* bytes 
2890: 74 6f 20 77 72 69 74 65 20 2a 2f 0a 20 20 73 71  to write */.  sq
28a0: 6c 69 74 65 33 5f 69 6e 74 36 34 20 69 4f 66 73  lite3_int64 iOfs
28b0: 74 20 20 20 20 2f 2a 20 53 74 61 72 74 20 77 72  t    /* Start wr
28c0: 69 74 69 6e 67 20 68 65 72 65 20 2a 2f 0a 29 7b  iting here */.){
28d0: 0a 20 20 56 48 61 6e 64 6c 65 20 2a 70 48 61 6e  .  VHandle *pHan
28e0: 64 6c 65 20 3d 20 28 56 48 61 6e 64 6c 65 2a 29  dle = (VHandle*)
28f0: 70 46 69 6c 65 3b 0a 20 20 56 46 69 6c 65 20 2a  pFile;.  VFile *
2900: 70 56 46 69 6c 65 20 3d 20 70 48 61 6e 64 6c 65  pVFile = pHandle
2910: 2d 3e 70 56 46 69 6c 65 3b 0a 20 20 69 66 28 20  ->pVFile;.  if( 
2920: 69 4f 66 73 74 2b 69 41 6d 74 20 3e 20 70 56 46  iOfst+iAmt > pVF
2930: 69 6c 65 2d 3e 73 7a 20 29 7b 0a 20 20 20 20 69  ile->sz ){.    i
2940: 66 28 20 69 4f 66 73 74 2b 69 41 6d 74 20 3e 3d  f( iOfst+iAmt >=
2950: 20 4d 58 5f 46 49 4c 45 5f 53 5a 20 29 7b 0a 20   MX_FILE_SZ ){. 
2960: 20 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49       return SQLI
2970: 54 45 5f 46 55 4c 4c 3b 0a 20 20 20 20 7d 0a 20  TE_FULL;.    }. 
2980: 20 20 20 70 56 46 69 6c 65 2d 3e 61 20 3d 20 73     pVFile->a = s
2990: 61 66 65 5f 72 65 61 6c 6c 6f 63 28 70 56 46 69  afe_realloc(pVFi
29a0: 6c 65 2d 3e 61 2c 20 28 69 6e 74 29 28 69 4f 66  le->a, (int)(iOf
29b0: 73 74 2b 69 41 6d 74 29 29 3b 0a 20 20 20 20 69  st+iAmt));.    i
29c0: 66 28 20 69 4f 66 73 74 20 3e 20 70 56 46 69 6c  f( iOfst > pVFil
29d0: 65 2d 3e 73 7a 20 29 7b 0a 20 20 20 20 20 20 6d  e->sz ){.      m
29e0: 65 6d 73 65 74 28 70 56 46 69 6c 65 2d 3e 61 20  emset(pVFile->a 
29f0: 2b 20 70 56 46 69 6c 65 2d 3e 73 7a 2c 20 30 2c  + pVFile->sz, 0,
2a00: 20 28 69 6e 74 29 28 69 4f 66 73 74 20 2d 20 70   (int)(iOfst - p
2a10: 56 46 69 6c 65 2d 3e 73 7a 29 29 3b 0a 20 20 20  VFile->sz));.   
2a20: 20 7d 0a 20 20 20 20 70 56 46 69 6c 65 2d 3e 73   }.    pVFile->s
2a30: 7a 20 3d 20 28 69 6e 74 29 28 69 4f 66 73 74 20  z = (int)(iOfst 
2a40: 2b 20 69 41 6d 74 29 3b 0a 20 20 7d 0a 20 20 6d  + iAmt);.  }.  m
2a50: 65 6d 63 70 79 28 70 56 46 69 6c 65 2d 3e 61 20  emcpy(pVFile->a 
2a60: 2b 20 69 4f 66 73 74 2c 20 70 44 61 74 61 2c 20  + iOfst, pData, 
2a70: 69 41 6d 74 29 3b 0a 20 20 72 65 74 75 72 6e 20  iAmt);.  return 
2a80: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 73 74 61  SQLITE_OK;.}.sta
2a90: 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d 54 72 75  tic int inmemTru
2aa0: 6e 63 61 74 65 28 73 71 6c 69 74 65 33 5f 66 69  ncate(sqlite3_fi
2ab0: 6c 65 20 2a 70 46 69 6c 65 2c 20 73 71 6c 69 74  le *pFile, sqlit
2ac0: 65 33 5f 69 6e 74 36 34 20 69 53 69 7a 65 29 7b  e3_int64 iSize){
2ad0: 0a 20 20 56 48 61 6e 64 6c 65 20 2a 70 48 61 6e  .  VHandle *pHan
2ae0: 64 6c 65 20 3d 20 28 56 48 61 6e 64 6c 65 2a 29  dle = (VHandle*)
2af0: 70 46 69 6c 65 3b 0a 20 20 56 46 69 6c 65 20 2a  pFile;.  VFile *
2b00: 70 56 46 69 6c 65 20 3d 20 70 48 61 6e 64 6c 65  pVFile = pHandle
2b10: 2d 3e 70 56 46 69 6c 65 3b 0a 20 20 69 66 28 20  ->pVFile;.  if( 
2b20: 70 56 46 69 6c 65 2d 3e 73 7a 3e 69 53 69 7a 65  pVFile->sz>iSize
2b30: 20 26 26 20 69 53 69 7a 65 3e 3d 30 20 29 20 70   && iSize>=0 ) p
2b40: 56 46 69 6c 65 2d 3e 73 7a 20 3d 20 28 69 6e 74  VFile->sz = (int
2b50: 29 69 53 69 7a 65 3b 0a 20 20 72 65 74 75 72 6e  )iSize;.  return
2b60: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 73 74   SQLITE_OK;.}.st
2b70: 61 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d 53 79  atic int inmemSy
2b80: 6e 63 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20  nc(sqlite3_file 
2b90: 2a 70 46 69 6c 65 2c 20 69 6e 74 20 66 6c 61 67  *pFile, int flag
2ba0: 73 29 7b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c  s){.  return SQL
2bb0: 49 54 45 5f 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63  ITE_OK;.}.static
2bc0: 20 69 6e 74 20 69 6e 6d 65 6d 46 69 6c 65 53 69   int inmemFileSi
2bd0: 7a 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20  ze(sqlite3_file 
2be0: 2a 70 46 69 6c 65 2c 20 73 71 6c 69 74 65 33 5f  *pFile, sqlite3_
2bf0: 69 6e 74 36 34 20 2a 70 53 69 7a 65 29 7b 0a 20  int64 *pSize){. 
2c00: 20 2a 70 53 69 7a 65 20 3d 20 28 28 56 48 61 6e   *pSize = ((VHan
2c10: 64 6c 65 2a 29 70 46 69 6c 65 29 2d 3e 70 56 46  dle*)pFile)->pVF
2c20: 69 6c 65 2d 3e 73 7a 3b 0a 20 20 72 65 74 75 72  ile->sz;.  retur
2c30: 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 73  n SQLITE_OK;.}.s
2c40: 74 61 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d 4c  tatic int inmemL
2c50: 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c 65  ock(sqlite3_file
2c60: 20 2a 70 46 69 6c 65 2c 20 69 6e 74 20 74 79 70   *pFile, int typ
2c70: 65 29 7b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c  e){.  return SQL
2c80: 49 54 45 5f 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63  ITE_OK;.}.static
2c90: 20 69 6e 74 20 69 6e 6d 65 6d 55 6e 6c 6f 63 6b   int inmemUnlock
2ca0: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70  (sqlite3_file *p
2cb0: 46 69 6c 65 2c 20 69 6e 74 20 74 79 70 65 29 7b  File, int type){
2cc0: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
2cd0: 5f 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e  _OK;.}.static in
2ce0: 74 20 69 6e 6d 65 6d 43 68 65 63 6b 52 65 73 65  t inmemCheckRese
2cf0: 72 76 65 64 4c 6f 63 6b 28 73 71 6c 69 74 65 33  rvedLock(sqlite3
2d00: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 6e  _file *pFile, in
2d10: 74 20 2a 70 4f 75 74 29 7b 0a 20 20 2a 70 4f 75  t *pOut){.  *pOu
2d20: 74 20 3d 20 30 3b 0a 20 20 72 65 74 75 72 6e 20  t = 0;.  return 
2d30: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 73 74 61  SQLITE_OK;.}.sta
2d40: 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d 46 69 6c  tic int inmemFil
2d50: 65 43 6f 6e 74 72 6f 6c 28 73 71 6c 69 74 65 33  eControl(sqlite3
2d60: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 6e  _file *pFile, in
2d70: 74 20 6f 70 2c 20 76 6f 69 64 20 2a 70 41 72 67  t op, void *pArg
2d80: 29 7b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49  ){.  return SQLI
2d90: 54 45 5f 4e 4f 54 46 4f 55 4e 44 3b 0a 7d 0a 73  TE_NOTFOUND;.}.s
2da0: 74 61 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d 53  tatic int inmemS
2db0: 65 63 74 6f 72 53 69 7a 65 28 73 71 6c 69 74 65  ectorSize(sqlite
2dc0: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 29 7b 0a  3_file *pFile){.
2dd0: 20 20 72 65 74 75 72 6e 20 35 31 32 3b 0a 7d 0a    return 512;.}.
2de0: 73 74 61 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d  static int inmem
2df0: 44 65 76 69 63 65 43 68 61 72 61 63 74 65 72 69  DeviceCharacteri
2e00: 73 74 69 63 73 28 73 71 6c 69 74 65 33 5f 66 69  stics(sqlite3_fi
2e10: 6c 65 20 2a 70 46 69 6c 65 29 7b 0a 20 20 72 65  le *pFile){.  re
2e20: 74 75 72 6e 0a 20 20 20 20 20 20 53 51 4c 49 54  turn.      SQLIT
2e30: 45 5f 49 4f 43 41 50 5f 53 41 46 45 5f 41 50 50  E_IOCAP_SAFE_APP
2e40: 45 4e 44 20 7c 0a 20 20 20 20 20 20 53 51 4c 49  END |.      SQLI
2e50: 54 45 5f 49 4f 43 41 50 5f 55 4e 44 45 4c 45 54  TE_IOCAP_UNDELET
2e60: 41 42 4c 45 5f 57 48 45 4e 5f 4f 50 45 4e 20 7c  ABLE_WHEN_OPEN |
2e70: 0a 20 20 20 20 20 20 53 51 4c 49 54 45 5f 49 4f  .      SQLITE_IO
2e80: 43 41 50 5f 50 4f 57 45 52 53 41 46 45 5f 4f 56  CAP_POWERSAFE_OV
2e90: 45 52 57 52 49 54 45 3b 0a 7d 0a 0a 0a 2f 2a 20  ERWRITE;.}.../* 
2ea0: 4d 65 74 68 6f 64 20 74 61 62 6c 65 20 66 6f 72  Method table for
2eb0: 20 56 48 61 6e 64 6c 65 0a 2a 2f 0a 73 74 61 74   VHandle.*/.stat
2ec0: 69 63 20 73 71 6c 69 74 65 33 5f 69 6f 5f 6d 65  ic sqlite3_io_me
2ed0: 74 68 6f 64 73 20 56 48 61 6e 64 6c 65 4d 65 74  thods VHandleMet
2ee0: 68 6f 64 73 20 3d 20 7b 0a 20 20 2f 2a 20 69 56  hods = {.  /* iV
2ef0: 65 72 73 69 6f 6e 20 20 2a 2f 20 20 20 20 31 2c  ersion  */    1,
2f00: 0a 20 20 2f 2a 20 78 43 6c 6f 73 65 20 20 20 20  .  /* xClose    
2f10: 2a 2f 20 20 20 20 69 6e 6d 65 6d 43 6c 6f 73 65  */    inmemClose
2f20: 2c 0a 20 20 2f 2a 20 78 52 65 61 64 20 20 20 20  ,.  /* xRead    
2f30: 20 2a 2f 20 20 20 20 69 6e 6d 65 6d 52 65 61 64   */    inmemRead
2f40: 2c 0a 20 20 2f 2a 20 78 57 72 69 74 65 20 20 20  ,.  /* xWrite   
2f50: 20 2a 2f 20 20 20 20 69 6e 6d 65 6d 57 72 69 74   */    inmemWrit
2f60: 65 2c 0a 20 20 2f 2a 20 78 54 72 75 6e 63 61 74  e,.  /* xTruncat
2f70: 65 20 2a 2f 20 20 20 20 69 6e 6d 65 6d 54 72 75  e */    inmemTru
2f80: 6e 63 61 74 65 2c 0a 20 20 2f 2a 20 78 53 79 6e  ncate,.  /* xSyn
2f90: 63 20 20 20 20 20 2a 2f 20 20 20 20 69 6e 6d 65  c     */    inme
2fa0: 6d 53 79 6e 63 2c 0a 20 20 2f 2a 20 78 46 69 6c  mSync,.  /* xFil
2fb0: 65 53 69 7a 65 20 2a 2f 20 20 20 20 69 6e 6d 65  eSize */    inme
2fc0: 6d 46 69 6c 65 53 69 7a 65 2c 0a 20 20 2f 2a 20  mFileSize,.  /* 
2fd0: 78 4c 6f 63 6b 20 20 20 20 20 2a 2f 20 20 20 20  xLock     */    
2fe0: 69 6e 6d 65 6d 4c 6f 63 6b 2c 0a 20 20 2f 2a 20  inmemLock,.  /* 
2ff0: 78 55 6e 6c 6f 63 6b 20 20 20 2a 2f 20 20 20 20  xUnlock   */    
3000: 69 6e 6d 65 6d 55 6e 6c 6f 63 6b 2c 0a 20 20 2f  inmemUnlock,.  /
3010: 2a 20 78 43 68 65 63 6b 2e 2e 2e 20 2a 2f 20 20  * xCheck... */  
3020: 20 20 69 6e 6d 65 6d 43 68 65 63 6b 52 65 73 65    inmemCheckRese
3030: 72 76 65 64 4c 6f 63 6b 2c 0a 20 20 2f 2a 20 78  rvedLock,.  /* x
3040: 46 69 6c 65 43 74 72 6c 20 2a 2f 20 20 20 20 69  FileCtrl */    i
3050: 6e 6d 65 6d 46 69 6c 65 43 6f 6e 74 72 6f 6c 2c  nmemFileControl,
3060: 0a 20 20 2f 2a 20 78 53 65 63 74 6f 72 53 7a 20  .  /* xSectorSz 
3070: 2a 2f 20 20 20 20 69 6e 6d 65 6d 53 65 63 74 6f  */    inmemSecto
3080: 72 53 69 7a 65 2c 0a 20 20 2f 2a 20 78 44 65 76  rSize,.  /* xDev
3090: 63 68 61 72 20 20 2a 2f 20 20 20 20 69 6e 6d 65  char  */    inme
30a0: 6d 44 65 76 69 63 65 43 68 61 72 61 63 74 65 72  mDeviceCharacter
30b0: 69 73 74 69 63 73 2c 0a 20 20 2f 2a 20 78 53 68  istics,.  /* xSh
30c0: 6d 4d 61 70 20 20 20 2a 2f 20 20 20 20 30 2c 0a  mMap   */    0,.
30d0: 20 20 2f 2a 20 78 53 68 6d 4c 6f 63 6b 20 20 2a    /* xShmLock  *
30e0: 2f 20 20 20 20 30 2c 0a 20 20 2f 2a 20 78 53 68  /    0,.  /* xSh
30f0: 6d 42 61 72 72 69 65 72 20 2a 2f 20 20 30 2c 0a  mBarrier */  0,.
3100: 20 20 2f 2a 20 78 53 68 6d 55 6e 6d 61 70 20 2a    /* xShmUnmap *
3110: 2f 20 20 20 20 30 2c 0a 20 20 2f 2a 20 78 46 65  /    0,.  /* xFe
3120: 74 63 68 20 20 20 20 2a 2f 20 20 20 20 30 2c 0a  tch    */    0,.
3130: 20 20 2f 2a 20 78 55 6e 66 65 74 63 68 20 20 2a    /* xUnfetch  *
3140: 2f 20 20 20 20 30 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a  /    0.};../*.**
3150: 20 4f 70 65 6e 20 61 20 6e 65 77 20 66 69 6c 65   Open a new file
3160: 20 69 6e 20 74 68 65 20 69 6e 6d 65 6d 20 56 46   in the inmem VF
3170: 53 2e 20 20 41 6c 6c 20 66 69 6c 65 73 20 61 72  S.  All files ar
3180: 65 20 61 6e 6f 6e 79 6d 6f 75 73 20 61 6e 64 20  e anonymous and 
3190: 61 72 65 0a 2a 2a 20 64 65 6c 65 74 65 2d 6f 6e  are.** delete-on
31a0: 2d 63 6c 6f 73 65 2e 0a 2a 2f 0a 73 74 61 74 69  -close..*/.stati
31b0: 63 20 69 6e 74 20 69 6e 6d 65 6d 4f 70 65 6e 28  c int inmemOpen(
31c0: 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  .  sqlite3_vfs *
31d0: 70 56 66 73 2c 0a 20 20 63 6f 6e 73 74 20 63 68  pVfs,.  const ch
31e0: 61 72 20 2a 7a 46 69 6c 65 6e 61 6d 65 2c 0a 20  ar *zFilename,. 
31f0: 20 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70   sqlite3_file *p
3200: 46 69 6c 65 2c 0a 20 20 69 6e 74 20 6f 70 65 6e  File,.  int open
3210: 46 6c 61 67 73 2c 0a 20 20 69 6e 74 20 2a 70 4f  Flags,.  int *pO
3220: 75 74 46 6c 61 67 73 0a 29 7b 0a 20 20 56 46 69  utFlags.){.  VFi
3230: 6c 65 20 2a 70 56 46 69 6c 65 20 3d 20 63 72 65  le *pVFile = cre
3240: 61 74 65 56 46 69 6c 65 28 7a 46 69 6c 65 6e 61  ateVFile(zFilena
3250: 6d 65 2c 20 30 2c 20 28 75 6e 73 69 67 6e 65 64  me, 0, (unsigned
3260: 20 63 68 61 72 2a 29 22 22 29 3b 0a 20 20 56 48   char*)"");.  VH
3270: 61 6e 64 6c 65 20 2a 70 48 61 6e 64 6c 65 20 3d  andle *pHandle =
3280: 20 28 56 48 61 6e 64 6c 65 2a 29 70 46 69 6c 65   (VHandle*)pFile
3290: 3b 0a 20 20 69 66 28 20 70 56 46 69 6c 65 3d 3d  ;.  if( pVFile==
32a0: 30 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20  0 ){.    return 
32b0: 53 51 4c 49 54 45 5f 46 55 4c 4c 3b 0a 20 20 7d  SQLITE_FULL;.  }
32c0: 0a 20 20 70 48 61 6e 64 6c 65 2d 3e 70 56 46 69  .  pHandle->pVFi
32d0: 6c 65 20 3d 20 70 56 46 69 6c 65 3b 0a 20 20 70  le = pVFile;.  p
32e0: 56 46 69 6c 65 2d 3e 6e 52 65 66 2b 2b 3b 0a 20  VFile->nRef++;. 
32f0: 20 70 46 69 6c 65 2d 3e 70 4d 65 74 68 6f 64 73   pFile->pMethods
3300: 20 3d 20 26 56 48 61 6e 64 6c 65 4d 65 74 68 6f   = &VHandleMetho
3310: 64 73 3b 0a 20 20 69 66 28 20 70 4f 75 74 46 6c  ds;.  if( pOutFl
3320: 61 67 73 20 29 20 2a 70 4f 75 74 46 6c 61 67 73  ags ) *pOutFlags
3330: 20 3d 20 6f 70 65 6e 46 6c 61 67 73 3b 0a 20 20   = openFlags;.  
3340: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
3350: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 44 65 6c 65 74  ;.}../*.** Delet
3360: 65 20 61 20 66 69 6c 65 20 62 79 20 6e 61 6d 65  e a file by name
3370: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 69  .*/.static int i
3380: 6e 6d 65 6d 44 65 6c 65 74 65 28 0a 20 20 73 71  nmemDelete(.  sq
3390: 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c  lite3_vfs *pVfs,
33a0: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
33b0: 46 69 6c 65 6e 61 6d 65 2c 0a 20 20 69 6e 74 20  Filename,.  int 
33c0: 73 79 6e 63 64 69 72 0a 29 7b 0a 20 20 56 46 69  syncdir.){.  VFi
33d0: 6c 65 20 2a 70 56 46 69 6c 65 20 3d 20 66 69 6e  le *pVFile = fin
33e0: 64 56 46 69 6c 65 28 7a 46 69 6c 65 6e 61 6d 65  dVFile(zFilename
33f0: 29 3b 0a 20 20 69 66 28 20 70 56 46 69 6c 65 3d  );.  if( pVFile=
3400: 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49  =0 ) return SQLI
3410: 54 45 5f 4f 4b 3b 0a 20 20 69 66 28 20 70 56 46  TE_OK;.  if( pVF
3420: 69 6c 65 2d 3e 6e 52 65 66 3d 3d 30 20 29 7b 0a  ile->nRef==0 ){.
3430: 20 20 20 20 66 72 65 65 28 70 56 46 69 6c 65 2d      free(pVFile-
3440: 3e 7a 46 69 6c 65 6e 61 6d 65 29 3b 0a 20 20 20  >zFilename);.   
3450: 20 70 56 46 69 6c 65 2d 3e 7a 46 69 6c 65 6e 61   pVFile->zFilena
3460: 6d 65 20 3d 20 30 3b 0a 20 20 20 20 70 56 46 69  me = 0;.    pVFi
3470: 6c 65 2d 3e 73 7a 20 3d 20 2d 31 3b 0a 20 20 20  le->sz = -1;.   
3480: 20 66 72 65 65 28 70 56 46 69 6c 65 2d 3e 61 29   free(pVFile->a)
3490: 3b 0a 20 20 20 20 70 56 46 69 6c 65 2d 3e 61 20  ;.    pVFile->a 
34a0: 3d 20 30 3b 0a 20 20 20 20 72 65 74 75 72 6e 20  = 0;.    return 
34b0: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 7d 0a 20  SQLITE_OK;.  }. 
34c0: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 49   return SQLITE_I
34d0: 4f 45 52 52 5f 44 45 4c 45 54 45 3b 0a 7d 0a 0a  OERR_DELETE;.}..
34e0: 2f 2a 20 43 68 65 63 6b 20 66 6f 72 20 74 68 65  /* Check for the
34f0: 20 65 78 69 73 74 61 6e 63 65 20 6f 66 20 61 20   existance of a 
3500: 66 69 6c 65 0a 2a 2f 0a 73 74 61 74 69 63 20 69  file.*/.static i
3510: 6e 74 20 69 6e 6d 65 6d 41 63 63 65 73 73 28 0a  nt inmemAccess(.
3520: 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70    sqlite3_vfs *p
3530: 56 66 73 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61  Vfs,.  const cha
3540: 72 20 2a 7a 46 69 6c 65 6e 61 6d 65 2c 0a 20 20  r *zFilename,.  
3550: 69 6e 74 20 66 6c 61 67 73 2c 0a 20 20 69 6e 74  int flags,.  int
3560: 20 2a 70 52 65 73 4f 75 74 0a 29 7b 0a 20 20 56   *pResOut.){.  V
3570: 46 69 6c 65 20 2a 70 56 46 69 6c 65 20 3d 20 66  File *pVFile = f
3580: 69 6e 64 56 46 69 6c 65 28 7a 46 69 6c 65 6e 61  indVFile(zFilena
3590: 6d 65 29 3b 0a 20 20 2a 70 52 65 73 4f 75 74 20  me);.  *pResOut 
35a0: 3d 20 20 70 56 46 69 6c 65 21 3d 30 3b 0a 20 20  =  pVFile!=0;.  
35b0: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
35c0: 3b 0a 7d 0a 0a 2f 2a 20 47 65 74 20 74 68 65 20  ;.}../* Get the 
35d0: 63 61 6e 6f 6e 69 63 61 6c 20 70 61 74 68 6e 61  canonical pathna
35e0: 6d 65 20 66 6f 72 20 61 20 66 69 6c 65 0a 2a 2f  me for a file.*/
35f0: 0a 73 74 61 74 69 63 20 69 6e 74 20 69 6e 6d 65  .static int inme
3600: 6d 46 75 6c 6c 50 61 74 68 6e 61 6d 65 28 0a 20  mFullPathname(. 
3610: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56   sqlite3_vfs *pV
3620: 66 73 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61 72  fs,.  const char
3630: 20 2a 7a 46 69 6c 65 6e 61 6d 65 2c 0a 20 20 69   *zFilename,.  i
3640: 6e 74 20 6e 4f 75 74 2c 0a 20 20 63 68 61 72 20  nt nOut,.  char 
3650: 2a 7a 4f 75 74 0a 29 7b 0a 20 20 73 71 6c 69 74  *zOut.){.  sqlit
3660: 65 33 5f 73 6e 70 72 69 6e 74 66 28 6e 4f 75 74  e3_snprintf(nOut
3670: 2c 20 7a 4f 75 74 2c 20 22 25 73 22 2c 20 7a 46  , zOut, "%s", zF
3680: 69 6c 65 6e 61 6d 65 29 3b 0a 20 20 72 65 74 75  ilename);.  retu
3690: 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a  rn SQLITE_OK;.}.
36a0: 0a 2f 2a 20 47 65 74 4c 61 73 74 45 72 72 6f 72  ./* GetLastError
36b0: 28 29 20 69 73 20 6e 65 76 65 72 20 75 73 65 64  () is never used
36c0: 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 69   */.static int i
36d0: 6e 6d 65 6d 47 65 74 4c 61 73 74 45 72 72 6f 72  nmemGetLastError
36e0: 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56  (sqlite3_vfs *pV
36f0: 66 73 2c 20 69 6e 74 20 6e 2c 20 63 68 61 72 20  fs, int n, char 
3700: 2a 7a 29 7b 0a 20 20 72 65 74 75 72 6e 20 53 51  *z){.  return SQ
3710: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a  LITE_OK;.}../*.*
3720: 2a 20 52 65 67 69 73 74 65 72 20 74 68 65 20 56  * Register the V
3730: 46 53 20 74 68 61 74 20 72 65 61 64 73 20 66 72  FS that reads fr
3740: 6f 6d 20 74 68 65 20 67 2e 61 46 69 6c 65 5b 5d  om the g.aFile[]
3750: 20 73 65 74 20 6f 66 20 66 69 6c 65 73 2e 0a 2a   set of files..*
3760: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 69 6e  /.static void in
3770: 6d 65 6d 56 66 73 52 65 67 69 73 74 65 72 28 76  memVfsRegister(v
3780: 6f 69 64 29 7b 0a 20 20 73 74 61 74 69 63 20 73  oid){.  static s
3790: 71 6c 69 74 65 33 5f 76 66 73 20 69 6e 6d 65 6d  qlite3_vfs inmem
37a0: 56 66 73 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76  Vfs;.  sqlite3_v
37b0: 66 73 20 2a 70 44 65 66 61 75 6c 74 20 3d 20 73  fs *pDefault = s
37c0: 71 6c 69 74 65 33 5f 76 66 73 5f 66 69 6e 64 28  qlite3_vfs_find(
37d0: 30 29 3b 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 69  0);.  inmemVfs.i
37e0: 56 65 72 73 69 6f 6e 20 3d 20 31 3b 0a 20 20 69  Version = 1;.  i
37f0: 6e 6d 65 6d 56 66 73 2e 73 7a 4f 73 46 69 6c 65  nmemVfs.szOsFile
3800: 20 3d 20 73 69 7a 65 6f 66 28 56 48 61 6e 64 6c   = sizeof(VHandl
3810: 65 29 3b 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 6d  e);.  inmemVfs.m
3820: 78 50 61 74 68 6e 61 6d 65 20 3d 20 32 30 30 3b  xPathname = 200;
3830: 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 7a 4e 61 6d  .  inmemVfs.zNam
3840: 65 20 3d 20 22 69 6e 6d 65 6d 22 3b 0a 20 20 69  e = "inmem";.  i
3850: 6e 6d 65 6d 56 66 73 2e 78 4f 70 65 6e 20 3d 20  nmemVfs.xOpen = 
3860: 69 6e 6d 65 6d 4f 70 65 6e 3b 0a 20 20 69 6e 6d  inmemOpen;.  inm
3870: 65 6d 56 66 73 2e 78 44 65 6c 65 74 65 20 3d 20  emVfs.xDelete = 
3880: 69 6e 6d 65 6d 44 65 6c 65 74 65 3b 0a 20 20 69  inmemDelete;.  i
3890: 6e 6d 65 6d 56 66 73 2e 78 41 63 63 65 73 73 20  nmemVfs.xAccess 
38a0: 3d 20 69 6e 6d 65 6d 41 63 63 65 73 73 3b 0a 20  = inmemAccess;. 
38b0: 20 69 6e 6d 65 6d 56 66 73 2e 78 46 75 6c 6c 50   inmemVfs.xFullP
38c0: 61 74 68 6e 61 6d 65 20 3d 20 69 6e 6d 65 6d 46  athname = inmemF
38d0: 75 6c 6c 50 61 74 68 6e 61 6d 65 3b 0a 20 20 69  ullPathname;.  i
38e0: 6e 6d 65 6d 56 66 73 2e 78 52 61 6e 64 6f 6d 6e  nmemVfs.xRandomn
38f0: 65 73 73 20 3d 20 70 44 65 66 61 75 6c 74 2d 3e  ess = pDefault->
3900: 78 52 61 6e 64 6f 6d 6e 65 73 73 3b 0a 20 20 69  xRandomness;.  i
3910: 6e 6d 65 6d 56 66 73 2e 78 53 6c 65 65 70 20 3d  nmemVfs.xSleep =
3920: 20 70 44 65 66 61 75 6c 74 2d 3e 78 53 6c 65 65   pDefault->xSlee
3930: 70 3b 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 78 43  p;.  inmemVfs.xC
3940: 75 72 72 65 6e 74 54 69 6d 65 20 3d 20 70 44 65  urrentTime = pDe
3950: 66 61 75 6c 74 2d 3e 78 43 75 72 72 65 6e 74 54  fault->xCurrentT
3960: 69 6d 65 3b 0a 20 20 69 6e 6d 65 6d 56 66 73 2e  ime;.  inmemVfs.
3970: 78 47 65 74 4c 61 73 74 45 72 72 6f 72 20 3d 20  xGetLastError = 
3980: 69 6e 6d 65 6d 47 65 74 4c 61 73 74 45 72 72 6f  inmemGetLastErro
3990: 72 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  r;.  sqlite3_vfs
39a0: 5f 72 65 67 69 73 74 65 72 28 26 69 6e 6d 65 6d  _register(&inmem
39b0: 56 66 73 2c 20 30 29 3b 0a 7d 3b 0a 0a 2f 2a 0a  Vfs, 0);.};../*.
39c0: 2a 2a 20 41 6c 6c 6f 77 65 64 20 76 61 6c 75 65  ** Allowed value
39d0: 73 20 66 6f 72 20 74 68 65 20 72 75 6e 46 6c 61  s for the runFla
39e0: 67 73 20 70 61 72 61 6d 65 74 65 72 20 74 6f 20  gs parameter to 
39f0: 72 75 6e 53 71 6c 28 29 0a 2a 2f 0a 23 64 65 66  runSql().*/.#def
3a00: 69 6e 65 20 53 51 4c 5f 54 52 41 43 45 20 20 30  ine SQL_TRACE  0
3a10: 78 30 30 30 31 20 20 20 20 20 2f 2a 20 50 72 69  x0001     /* Pri
3a20: 6e 74 20 65 61 63 68 20 53 51 4c 20 73 74 61 74  nt each SQL stat
3a30: 65 6d 65 6e 74 20 61 73 20 69 74 20 69 73 20 70  ement as it is p
3a40: 72 65 70 61 72 65 64 20 2a 2f 0a 23 64 65 66 69  repared */.#defi
3a50: 6e 65 20 53 51 4c 5f 4f 55 54 50 55 54 20 30 78  ne SQL_OUTPUT 0x
3a60: 30 30 30 32 20 20 20 20 20 2f 2a 20 53 68 6f 77  0002     /* Show
3a70: 20 74 68 65 20 53 51 4c 20 6f 75 74 70 75 74 20   the SQL output 
3a80: 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 75 6e 20 6d 75  */../*.** Run mu
3a90: 6c 74 69 70 6c 65 20 63 6f 6d 6d 61 6e 64 73 20  ltiple commands 
3aa0: 6f 66 20 53 51 4c 2e 20 20 53 69 6d 69 6c 61 72  of SQL.  Similar
3ab0: 20 74 6f 20 73 71 6c 69 74 65 33 5f 65 78 65 63   to sqlite3_exec
3ac0: 28 29 2c 20 62 75 74 20 64 6f 65 73 20 6e 6f 74  (), but does not
3ad0: 0a 2a 2a 20 73 74 6f 70 20 69 66 20 61 6e 20 65  .** stop if an e
3ae0: 72 72 6f 72 20 69 73 20 65 6e 63 6f 75 6e 74 65  rror is encounte
3af0: 72 65 64 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76  red..*/.static v
3b00: 6f 69 64 20 72 75 6e 53 71 6c 28 73 71 6c 69 74  oid runSql(sqlit
3b10: 65 33 20 2a 64 62 2c 20 63 6f 6e 73 74 20 63 68  e3 *db, const ch
3b20: 61 72 20 2a 7a 53 71 6c 2c 20 75 6e 73 69 67 6e  ar *zSql, unsign
3b30: 65 64 20 20 72 75 6e 46 6c 61 67 73 29 7b 0a 20  ed  runFlags){. 
3b40: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4d 6f   const char *zMo
3b50: 72 65 3b 0a 20 20 73 71 6c 69 74 65 33 5f 73 74  re;.  sqlite3_st
3b60: 6d 74 20 2a 70 53 74 6d 74 3b 0a 0a 20 20 77 68  mt *pStmt;..  wh
3b70: 69 6c 65 28 20 7a 53 71 6c 20 26 26 20 7a 53 71  ile( zSql && zSq
3b80: 6c 5b 30 5d 20 29 7b 0a 20 20 20 20 7a 4d 6f 72  l[0] ){.    zMor
3b90: 65 20 3d 20 30 3b 0a 20 20 20 20 70 53 74 6d 74  e = 0;.    pStmt
3ba0: 20 3d 20 30 3b 0a 20 20 20 20 73 71 6c 69 74 65   = 0;.    sqlite
3bb0: 33 5f 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c  3_prepare_v2(db,
3bc0: 20 7a 53 71 6c 2c 20 2d 31 2c 20 26 70 53 74 6d   zSql, -1, &pStm
3bd0: 74 2c 20 26 7a 4d 6f 72 65 29 3b 0a 20 20 20 20  t, &zMore);.    
3be0: 69 66 28 20 7a 4d 6f 72 65 3d 3d 7a 53 71 6c 20  if( zMore==zSql 
3bf0: 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 69 66 28  ) break;.    if(
3c00: 20 72 75 6e 46 6c 61 67 73 20 26 20 53 51 4c 5f   runFlags & SQL_
3c10: 54 52 41 43 45 20 29 7b 0a 20 20 20 20 20 20 63  TRACE ){.      c
3c20: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 20 3d 20 7a  onst char *z = z
3c30: 53 71 6c 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e  Sql;.      int n
3c40: 3b 0a 20 20 20 20 20 20 77 68 69 6c 65 28 20 7a  ;.      while( z
3c50: 3c 7a 4d 6f 72 65 20 26 26 20 69 73 73 70 61 63  <zMore && isspac
3c60: 65 28 7a 5b 30 5d 29 20 29 20 7a 2b 2b 3b 0a 20  e(z[0]) ) z++;. 
3c70: 20 20 20 20 20 6e 20 3d 20 28 69 6e 74 29 28 7a       n = (int)(z
3c80: 4d 6f 72 65 20 2d 20 7a 29 3b 0a 20 20 20 20 20  More - z);.     
3c90: 20 77 68 69 6c 65 28 20 6e 3e 30 20 26 26 20 69   while( n>0 && i
3ca0: 73 73 70 61 63 65 28 7a 5b 6e 2d 31 5d 29 20 29  sspace(z[n-1]) )
3cb0: 20 6e 2d 2d 3b 0a 20 20 20 20 20 20 69 66 28 20   n--;.      if( 
3cc0: 6e 3d 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20 20  n==0 ) break;.  
3cd0: 20 20 20 20 69 66 28 20 70 53 74 6d 74 3d 3d 30      if( pStmt==0
3ce0: 20 29 7b 0a 20 20 20 20 20 20 20 20 70 72 69 6e   ){.        prin
3cf0: 74 66 28 22 54 52 41 43 45 3a 20 25 2e 2a 73 20  tf("TRACE: %.*s 
3d00: 28 65 72 72 6f 72 3a 20 25 73 29 5c 6e 22 2c 20  (error: %s)\n", 
3d10: 6e 2c 20 7a 2c 20 73 71 6c 69 74 65 33 5f 65 72  n, z, sqlite3_er
3d20: 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 20  rmsg(db));.     
3d30: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
3d40: 70 72 69 6e 74 66 28 22 54 52 41 43 45 3a 20 25  printf("TRACE: %
3d50: 2e 2a 73 5c 6e 22 2c 20 6e 2c 20 7a 29 3b 0a 20  .*s\n", n, z);. 
3d60: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20       }.    }.   
3d70: 20 7a 53 71 6c 20 3d 20 7a 4d 6f 72 65 3b 0a 20   zSql = zMore;. 
3d80: 20 20 20 69 66 28 20 70 53 74 6d 74 20 29 7b 0a     if( pStmt ){.
3d90: 20 20 20 20 20 20 69 66 28 20 28 72 75 6e 46 6c        if( (runFl
3da0: 61 67 73 20 26 20 53 51 4c 5f 4f 55 54 50 55 54  ags & SQL_OUTPUT
3db0: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  )==0 ){.        
3dc0: 77 68 69 6c 65 28 20 53 51 4c 49 54 45 5f 52 4f  while( SQLITE_RO
3dd0: 57 3d 3d 73 71 6c 69 74 65 33 5f 73 74 65 70 28  W==sqlite3_step(
3de0: 70 53 74 6d 74 29 20 29 7b 7d 0a 20 20 20 20 20  pStmt) ){}.     
3df0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
3e00: 69 6e 74 20 6e 43 6f 6c 20 3d 20 2d 31 3b 0a 20  int nCol = -1;. 
3e10: 20 20 20 20 20 20 20 77 68 69 6c 65 28 20 53 51         while( SQ
3e20: 4c 49 54 45 5f 52 4f 57 3d 3d 73 71 6c 69 74 65  LITE_ROW==sqlite
3e30: 33 5f 73 74 65 70 28 70 53 74 6d 74 29 20 29 7b  3_step(pStmt) ){
3e40: 0a 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 69  .          int i
3e50: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  ;.          if( 
3e60: 6e 43 6f 6c 3c 30 20 29 7b 0a 20 20 20 20 20 20  nCol<0 ){.      
3e70: 20 20 20 20 20 20 6e 43 6f 6c 20 3d 20 73 71 6c        nCol = sql
3e80: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 63 6f 75 6e  ite3_column_coun
3e90: 74 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 20 20  t(pStmt);.      
3ea0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 6e 43      }else if( nC
3eb0: 6f 6c 3e 30 20 29 7b 0a 20 20 20 20 20 20 20 20  ol>0 ){.        
3ec0: 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 2d 2d      printf("----
3ed0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3ee0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3ef0: 2d 2d 2d 2d 2d 2d 2d 2d 5c 6e 22 29 3b 0a 20 20  --------\n");.  
3f00: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3f10: 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e      for(i=0; i<n
3f20: 43 6f 6c 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20  Col; i++){.     
3f30: 20 20 20 20 20 20 20 69 6e 74 20 65 54 79 70 65         int eType
3f40: 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d   = sqlite3_colum
3f50: 6e 5f 74 79 70 65 28 70 53 74 6d 74 2c 69 29 3b  n_type(pStmt,i);
3f60: 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 72 69  .            pri
3f70: 6e 74 66 28 22 25 73 20 3d 20 22 2c 20 73 71 6c  ntf("%s = ", sql
3f80: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65  ite3_column_name
3f90: 28 70 53 74 6d 74 2c 69 29 29 3b 0a 20 20 20 20  (pStmt,i));.    
3fa0: 20 20 20 20 20 20 20 20 73 77 69 74 63 68 28 20          switch( 
3fb0: 65 54 79 70 65 20 29 7b 0a 20 20 20 20 20 20 20  eType ){.       
3fc0: 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 49         case SQLI
3fd0: 54 45 5f 4e 55 4c 4c 3a 20 7b 0a 20 20 20 20 20  TE_NULL: {.     
3fe0: 20 20 20 20 20 20 20 20 20 20 20 70 72 69 6e 74             print
3ff0: 66 28 22 4e 55 4c 4c 5c 6e 22 29 3b 0a 20 20 20  f("NULL\n");.   
4000: 20 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65               bre
4010: 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ak;.            
4020: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
4030: 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4e    case SQLITE_IN
4040: 54 45 47 45 52 3a 20 7b 0a 20 20 20 20 20 20 20  TEGER: {.       
4050: 20 20 20 20 20 20 20 20 20 70 72 69 6e 74 66 28           printf(
4060: 22 49 4e 54 20 25 73 5c 6e 22 2c 20 73 71 6c 69  "INT %s\n", sqli
4070: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28  te3_column_text(
4080: 70 53 74 6d 74 2c 69 29 29 3b 0a 20 20 20 20 20  pStmt,i));.     
4090: 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b             break
40a0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
40b0: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }.              
40c0: 63 61 73 65 20 53 51 4c 49 54 45 5f 46 4c 4f 41  case SQLITE_FLOA
40d0: 54 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20  T: {.           
40e0: 20 20 20 20 20 70 72 69 6e 74 66 28 22 46 4c 4f       printf("FLO
40f0: 41 54 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65  AT %s\n", sqlite
4100: 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70 53  3_column_text(pS
4110: 74 6d 74 2c 69 29 29 3b 0a 20 20 20 20 20 20 20  tmt,i));.       
4120: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a           break;.
4130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a                }.
4140: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 61                ca
4150: 73 65 20 53 51 4c 49 54 45 5f 54 45 58 54 3a 20  se SQLITE_TEXT: 
4160: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
4170: 20 20 70 72 69 6e 74 66 28 22 54 45 58 54 20 5b    printf("TEXT [
4180: 25 73 5d 5c 6e 22 2c 20 73 71 6c 69 74 65 33 5f  %s]\n", sqlite3_
4190: 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70 53 74 6d  column_text(pStm
41a0: 74 2c 69 29 29 3b 0a 20 20 20 20 20 20 20 20 20  t,i));.         
41b0: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
41c0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
41d0: 20 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65              case
41e0: 20 53 51 4c 49 54 45 5f 42 4c 4f 42 3a 20 7b 0a   SQLITE_BLOB: {.
41f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4200: 70 72 69 6e 74 66 28 22 42 4c 4f 42 20 28 25 64  printf("BLOB (%d
4210: 20 62 79 74 65 73 29 5c 6e 22 2c 20 73 71 6c 69   bytes)\n", sqli
4220: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65 73  te3_column_bytes
4230: 28 70 53 74 6d 74 2c 69 29 29 3b 0a 20 20 20 20  (pStmt,i));.    
4240: 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61              brea
4250: 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  k;.             
4260: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d   }.            }
4270: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
4280: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 20 20       }.      }  
4290: 20 20 20 20 20 20 20 0a 20 20 20 20 20 20 73 71         .      sq
42a0: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70  lite3_finalize(p
42b0: 53 74 6d 74 29 3b 0a 20 20 20 20 7d 0a 20 20 7d  Stmt);.    }.  }
42c0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 62 75 69 6c  .}../*.** Rebuil
42d0: 64 20 74 68 65 20 64 61 74 61 62 61 73 65 20 66  d the database f
42e0: 69 6c 65 2e 0a 2a 2a 0a 2a 2a 20 20 20 20 28 31  ile..**.**    (1
42f0: 29 20 20 52 65 6d 6f 76 65 20 64 75 70 6c 69 63  )  Remove duplic
4300: 61 74 65 20 65 6e 74 72 69 65 73 0a 2a 2a 20 20  ate entries.**  
4310: 20 20 28 32 29 20 20 50 75 74 20 61 6c 6c 20 65    (2)  Put all e
4320: 6e 74 72 69 65 73 20 69 6e 20 6f 72 64 65 72 0a  ntries in order.
4330: 2a 2a 20 20 20 20 28 33 29 20 20 56 61 63 75 75  **    (3)  Vacuu
4340: 6d 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  m.*/.static void
4350: 20 72 65 62 75 69 6c 64 5f 64 61 74 61 62 61 73   rebuild_databas
4360: 65 28 73 71 6c 69 74 65 33 20 2a 64 62 29 7b 0a  e(sqlite3 *db){.
4370: 20 20 69 6e 74 20 72 63 3b 0a 20 20 72 63 20 3d    int rc;.  rc =
4380: 20 73 71 6c 69 74 65 33 5f 65 78 65 63 28 64 62   sqlite3_exec(db
4390: 2c 20 0a 20 20 20 20 20 22 42 45 47 49 4e 3b 5c  , .     "BEGIN;\
43a0: 6e 22 0a 20 20 20 20 20 22 43 52 45 41 54 45 20  n".     "CREATE 
43b0: 54 45 4d 50 20 54 41 42 4c 45 20 64 62 78 20 41  TEMP TABLE dbx A
43c0: 53 20 53 45 4c 45 43 54 20 44 49 53 54 49 4e 43  S SELECT DISTINC
43d0: 54 20 64 62 63 6f 6e 74 65 6e 74 20 46 52 4f 4d  T dbcontent FROM
43e0: 20 64 62 3b 5c 6e 22 0a 20 20 20 20 20 22 44 45   db;\n".     "DE
43f0: 4c 45 54 45 20 46 52 4f 4d 20 64 62 3b 5c 6e 22  LETE FROM db;\n"
4400: 0a 20 20 20 20 20 22 49 4e 53 45 52 54 20 49 4e  .     "INSERT IN
4410: 54 4f 20 64 62 28 64 62 69 64 2c 20 64 62 63 6f  TO db(dbid, dbco
4420: 6e 74 65 6e 74 29 20 53 45 4c 45 43 54 20 4e 55  ntent) SELECT NU
4430: 4c 4c 2c 20 64 62 63 6f 6e 74 65 6e 74 20 46 52  LL, dbcontent FR
4440: 4f 4d 20 64 62 78 20 4f 52 44 45 52 20 42 59 20  OM dbx ORDER BY 
4450: 32 3b 5c 6e 22 0a 20 20 20 20 20 22 44 52 4f 50  2;\n".     "DROP
4460: 20 54 41 42 4c 45 20 64 62 78 3b 5c 6e 22 0a 20   TABLE dbx;\n". 
4470: 20 20 20 20 22 43 52 45 41 54 45 20 54 45 4d 50      "CREATE TEMP
4480: 20 54 41 42 4c 45 20 73 78 20 41 53 20 53 45 4c   TABLE sx AS SEL
4490: 45 43 54 20 44 49 53 54 49 4e 43 54 20 73 71 6c  ECT DISTINCT sql
44a0: 74 65 78 74 20 46 52 4f 4d 20 78 73 71 6c 3b 5c  text FROM xsql;\
44b0: 6e 22 0a 20 20 20 20 20 22 44 45 4c 45 54 45 20  n".     "DELETE 
44c0: 46 52 4f 4d 20 78 73 71 6c 3b 5c 6e 22 0a 20 20  FROM xsql;\n".  
44d0: 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20     "INSERT INTO 
44e0: 78 73 71 6c 28 73 71 6c 69 64 2c 73 71 6c 74 65  xsql(sqlid,sqlte
44f0: 78 74 29 20 53 45 4c 45 43 54 20 4e 55 4c 4c 2c  xt) SELECT NULL,
4500: 20 73 71 6c 74 65 78 74 20 46 52 4f 4d 20 73 78   sqltext FROM sx
4510: 20 4f 52 44 45 52 20 42 59 20 32 3b 5c 6e 22 0a   ORDER BY 2;\n".
4520: 20 20 20 20 20 22 44 52 4f 50 20 54 41 42 4c 45       "DROP TABLE
4530: 20 73 78 3b 5c 6e 22 0a 20 20 20 20 20 22 43 4f   sx;\n".     "CO
4540: 4d 4d 49 54 3b 5c 6e 22 0a 20 20 20 20 20 22 50  MMIT;\n".     "P
4550: 52 41 47 4d 41 20 70 61 67 65 5f 73 69 7a 65 3d  RAGMA page_size=
4560: 31 30 32 34 3b 5c 6e 22 0a 20 20 20 20 20 22 56  1024;\n".     "V
4570: 41 43 55 55 4d 3b 5c 6e 22 2c 20 30 2c 20 30 2c  ACUUM;\n", 0, 0,
4580: 20 30 29 3b 0a 20 20 69 66 28 20 72 63 20 29 20   0);.  if( rc ) 
4590: 66 61 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e  fatalError("cann
45a0: 6f 74 20 72 65 62 75 69 6c 64 3a 20 25 73 22 2c  ot rebuild: %s",
45b0: 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28   sqlite3_errmsg(
45c0: 64 62 29 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 50  db));.}../*.** P
45d0: 72 69 6e 74 20 73 6b 65 74 63 68 79 20 64 6f 63  rint sketchy doc
45e0: 75 6d 65 6e 74 61 74 69 6f 6e 20 66 6f 72 20 74  umentation for t
45f0: 68 69 73 20 75 74 69 6c 69 74 79 20 70 72 6f 67  his utility prog
4600: 72 61 6d 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  ram.*/.static vo
4610: 69 64 20 73 68 6f 77 48 65 6c 70 28 76 6f 69 64  id showHelp(void
4620: 29 7b 0a 20 20 70 72 69 6e 74 66 28 22 55 73 61  ){.  printf("Usa
4630: 67 65 3a 20 25 73 20 5b 6f 70 74 69 6f 6e 73 5d  ge: %s [options]
4640: 20 53 4f 55 52 43 45 2d 44 42 20 3f 41 52 47 53   SOURCE-DB ?ARGS
4650: 2e 2e 2e 3f 5c 6e 22 2c 20 67 2e 7a 41 72 67 76  ...?\n", g.zArgv
4660: 30 29 3b 0a 20 20 70 72 69 6e 74 66 28 0a 22 52  0);.  printf(."R
4670: 65 61 64 20 64 61 74 61 62 61 73 65 73 20 61 6e  ead databases an
4680: 64 20 53 51 4c 20 73 63 72 69 70 74 73 20 66 72  d SQL scripts fr
4690: 6f 6d 20 53 4f 55 52 43 45 2d 44 42 20 61 6e 64  om SOURCE-DB and
46a0: 20 65 78 65 63 75 74 65 20 65 61 63 68 20 73 63   execute each sc
46b0: 72 69 70 74 20 61 67 61 69 6e 73 74 5c 6e 22 0a  ript against\n".
46c0: 22 65 61 63 68 20 64 61 74 61 62 61 73 65 2c 20  "each database, 
46d0: 63 68 65 63 6b 69 6e 67 20 66 6f 72 20 63 72 61  checking for cra
46e0: 73 68 65 73 20 61 6e 64 20 6d 65 6d 6f 72 79 20  shes and memory 
46f0: 6c 65 61 6b 73 2e 5c 6e 22 0a 22 4f 70 74 69 6f  leaks.\n"."Optio
4700: 6e 73 3a 5c 6e 22 0a 22 20 20 2d 2d 63 65 6c 6c  ns:\n"."  --cell
4710: 2d 73 69 7a 65 2d 63 68 65 63 6b 20 20 20 20 20  -size-check     
4720: 53 65 74 20 74 68 65 20 50 52 41 47 4d 41 20 63  Set the PRAGMA c
4730: 65 6c 6c 5f 73 69 7a 65 5f 63 68 65 63 6b 3d 4f  ell_size_check=O
4740: 4e 5c 6e 22 0a 22 20 20 2d 2d 64 62 69 64 20 4e  N\n"."  --dbid N
4750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 55 73                Us
4760: 65 20 6f 6e 6c 79 20 74 68 65 20 64 61 74 61 62  e only the datab
4770: 61 73 65 20 77 68 65 72 65 20 64 62 69 64 3d 4e  ase where dbid=N
4780: 5c 6e 22 0a 22 20 20 2d 2d 68 65 6c 70 20 20 20  \n"."  --help   
4790: 20 20 20 20 20 20 20 20 20 20 20 20 20 53 68 6f               Sho
47a0: 77 20 74 68 69 73 20 68 65 6c 70 20 74 65 78 74  w this help text
47b0: 5c 6e 22 20 20 20 20 0a 22 20 20 2d 71 20 20 20  \n"    ."  -q   
47c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
47d0: 20 52 65 64 75 63 65 64 20 6f 75 74 70 75 74 5c   Reduced output\
47e0: 6e 22 0a 22 20 20 2d 2d 71 75 69 65 74 20 20 20  n"."  --quiet   
47f0: 20 20 20 20 20 20 20 20 20 20 20 20 52 65 64 75              Redu
4800: 63 65 64 20 6f 75 74 70 75 74 5c 6e 22 0a 22 20  ced output\n"." 
4810: 20 2d 2d 6c 6f 61 64 2d 73 71 6c 20 41 52 47 53   --load-sql ARGS
4820: 2e 2e 2e 20 20 20 20 4c 6f 61 64 20 53 51 4c 20  ...    Load SQL 
4830: 73 63 72 69 70 74 73 20 66 72 6f 20 66 69 6c 65  scripts fro file
4840: 73 20 69 6e 74 6f 20 53 4f 55 52 43 45 2d 44 42  s into SOURCE-DB
4850: 5c 6e 22 0a 22 20 20 2d 2d 6c 6f 61 64 2d 64 62  \n"."  --load-db
4860: 20 41 52 47 53 2e 2e 2e 20 20 20 20 20 4c 6f 61   ARGS...     Loa
4870: 64 20 74 65 6d 70 6c 61 74 65 20 64 61 74 61 62  d template datab
4880: 61 73 65 73 20 66 72 6f 6d 20 66 69 6c 65 73 20  ases from files 
4890: 69 6e 74 6f 20 53 4f 55 52 43 45 5f 44 42 5c 6e  into SOURCE_DB\n
48a0: 22 0a 22 20 20 2d 6d 20 54 45 58 54 20 20 20 20  "."  -m TEXT    
48b0: 20 20 20 20 20 20 20 20 20 20 20 41 64 64 20 61             Add a
48c0: 20 64 65 73 63 72 69 70 74 69 6f 6e 20 74 6f 20   description to 
48d0: 74 68 65 20 64 61 74 61 62 61 73 65 5c 6e 22 0a  the database\n".
48e0: 22 20 20 2d 2d 6e 61 74 69 76 65 2d 76 66 73 20  "  --native-vfs 
48f0: 20 20 20 20 20 20 20 20 20 55 73 65 20 74 68 65           Use the
4900: 20 6e 61 74 69 76 65 20 56 46 53 20 66 6f 72 20   native VFS for 
4910: 69 6e 69 74 69 61 6c 6c 79 20 65 6d 70 74 79 20  initially empty 
4920: 64 61 74 61 62 61 73 65 20 66 69 6c 65 73 5c 6e  database files\n
4930: 22 0a 22 20 20 2d 2d 72 65 62 75 69 6c 64 20 20  "."  --rebuild  
4940: 20 20 20 20 20 20 20 20 20 20 20 52 65 62 75 69             Rebui
4950: 6c 64 20 61 6e 64 20 76 61 63 75 75 6d 20 74 68  ld and vacuum th
4960: 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 5c  e database file\
4970: 6e 22 0a 22 20 20 2d 2d 72 65 73 75 6c 74 2d 74  n"."  --result-t
4980: 72 61 63 65 20 20 20 20 20 20 20 20 53 68 6f 77  race        Show
4990: 20 74 68 65 20 72 65 73 75 6c 74 73 20 6f 66 20   the results of 
49a0: 65 61 63 68 20 53 51 4c 20 63 6f 6d 6d 61 6e 64  each SQL command
49b0: 5c 6e 22 0a 22 20 20 2d 2d 73 71 6c 69 64 20 4e  \n"."  --sqlid N
49c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 55 73 65               Use
49d0: 20 6f 6e 6c 79 20 53 51 4c 20 77 68 65 72 65 20   only SQL where 
49e0: 73 71 6c 69 64 3d 4e 5c 6e 22 0a 22 20 20 2d 76  sqlid=N\n"."  -v
49f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4a00: 20 20 20 20 49 6e 63 72 65 61 73 65 64 20 6f 75      Increased ou
4a10: 74 70 75 74 5c 6e 22 0a 22 20 20 2d 2d 76 65 72  tput\n"."  --ver
4a20: 62 6f 73 65 20 20 20 20 20 20 20 20 20 20 20 20  bose            
4a30: 20 49 6e 63 72 65 61 73 65 64 20 6f 75 74 70 75   Increased outpu
4a40: 74 5c 6e 22 0a 20 20 29 3b 0a 7d 0a 0a 69 6e 74  t\n".  );.}..int
4a50: 20 6d 61 69 6e 28 69 6e 74 20 61 72 67 63 2c 20   main(int argc, 
4a60: 63 68 61 72 20 2a 2a 61 72 67 76 29 7b 0a 20 20  char **argv){.  
4a70: 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 69 42  sqlite3_int64 iB
4a80: 65 67 69 6e 3b 20 20 20 20 20 20 20 20 2f 2a 20  egin;        /* 
4a90: 53 74 61 72 74 20 74 69 6d 65 20 6f 66 20 74 68  Start time of th
4aa0: 69 73 20 70 72 6f 67 72 61 6d 20 2a 2f 0a 20 20  is program */.  
4ab0: 69 6e 74 20 71 75 69 65 74 46 6c 61 67 20 3d 20  int quietFlag = 
4ac0: 30 3b 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  0;           /* 
4ad0: 54 72 75 65 20 69 66 20 2d 2d 71 75 69 65 74 20  True if --quiet 
4ae0: 6f 72 20 2d 71 20 2a 2f 0a 20 20 69 6e 74 20 76  or -q */.  int v
4af0: 65 72 62 6f 73 65 46 6c 61 67 20 3d 20 30 3b 20  erboseFlag = 0; 
4b00: 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20          /* True 
4b10: 69 66 20 2d 2d 76 65 72 62 6f 73 65 20 6f 72 20  if --verbose or 
4b20: 2d 76 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 49  -v */.  char *zI
4b30: 6e 73 53 71 6c 20 3d 20 30 3b 20 20 20 20 20 20  nsSql = 0;      
4b40: 20 20 20 20 20 2f 2a 20 53 51 4c 20 73 74 61 74       /* SQL stat
4b50: 65 6d 65 6e 74 20 66 6f 72 20 2d 2d 6c 6f 61 64  ement for --load
4b60: 2d 64 62 20 6f 72 20 2d 2d 6c 6f 61 64 2d 73 71  -db or --load-sq
4b70: 6c 20 2a 2f 0a 20 20 69 6e 74 20 69 46 69 72 73  l */.  int iFirs
4b80: 74 49 6e 73 41 72 67 20 3d 20 30 3b 20 20 20 20  tInsArg = 0;    
4b90: 20 20 20 20 2f 2a 20 46 69 72 73 74 20 61 72 67      /* First arg
4ba0: 76 5b 5d 20 74 6f 20 75 73 65 20 66 6f 72 20 2d  v[] to use for -
4bb0: 2d 6c 6f 61 64 2d 64 62 20 6f 72 20 2d 2d 6c 6f  -load-db or --lo
4bc0: 61 64 2d 73 71 6c 20 2a 2f 0a 20 20 73 71 6c 69  ad-sql */.  sqli
4bd0: 74 65 33 20 2a 64 62 20 3d 20 30 3b 20 20 20 20  te3 *db = 0;    
4be0: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20           /* The 
4bf0: 6f 70 65 6e 20 64 61 74 61 62 61 73 65 20 63 6f  open database co
4c00: 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a 20 20 73 71  nnection */.  sq
4c10: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d  lite3_stmt *pStm
4c20: 74 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 41 20  t;         /* A 
4c30: 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d 65  prepared stateme
4c40: 6e 74 20 2a 2f 0a 20 20 69 6e 74 20 72 63 3b 20  nt */.  int rc; 
4c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4c60: 20 20 20 20 20 2f 2a 20 52 65 73 75 6c 74 20 63       /* Result c
4c70: 6f 64 65 20 66 72 6f 6d 20 53 51 4c 69 74 65 20  ode from SQLite 
4c80: 69 6e 74 65 72 66 61 63 65 20 63 61 6c 6c 73 20  interface calls 
4c90: 2a 2f 0a 20 20 42 6c 6f 62 20 2a 70 53 71 6c 3b  */.  Blob *pSql;
4ca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4cb0: 20 20 2f 2a 20 46 6f 72 20 6c 6f 6f 70 69 6e 67    /* For looping
4cc0: 20 6f 76 65 72 20 53 51 4c 20 73 63 72 69 70 74   over SQL script
4cd0: 73 20 2a 2f 0a 20 20 42 6c 6f 62 20 2a 70 44 62  s */.  Blob *pDb
4ce0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
4cf0: 20 20 20 20 2f 2a 20 46 6f 72 20 6c 6f 6f 70 69      /* For loopi
4d00: 6e 67 20 6f 76 65 72 20 74 65 6d 70 6c 61 74 65  ng over template
4d10: 20 64 61 74 61 62 61 73 65 73 20 2a 2f 0a 20 20   databases */.  
4d20: 69 6e 74 20 69 3b 20 20 20 20 20 20 20 20 20 20  int i;          
4d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
4d40: 4c 6f 6f 70 20 69 6e 64 65 78 20 66 6f 72 20 74  Loop index for t
4d50: 68 65 20 61 72 67 76 5b 5d 20 6c 6f 6f 70 20 2a  he argv[] loop *
4d60: 2f 0a 20 20 69 6e 74 20 6f 6e 6c 79 53 71 6c 69  /.  int onlySqli
4d70: 64 20 3d 20 2d 31 3b 20 20 20 20 20 20 20 20 20  d = -1;         
4d80: 20 2f 2a 20 2d 2d 73 71 6c 69 64 20 2a 2f 0a 20   /* --sqlid */. 
4d90: 20 69 6e 74 20 6f 6e 6c 79 44 62 69 64 20 3d 20   int onlyDbid = 
4da0: 2d 31 3b 20 20 20 20 20 20 20 20 20 20 20 2f 2a  -1;           /*
4db0: 20 2d 2d 64 62 69 64 20 2a 2f 0a 20 20 69 6e 74   --dbid */.  int
4dc0: 20 6e 61 74 69 76 65 46 6c 61 67 20 3d 20 30 3b   nativeFlag = 0;
4dd0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 2d 2d 6e            /* --n
4de0: 61 74 69 76 65 2d 76 66 73 20 2a 2f 0a 20 20 69  ative-vfs */.  i
4df0: 6e 74 20 72 65 62 75 69 6c 64 46 6c 61 67 20 3d  nt rebuildFlag =
4e00: 20 30 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 2d   0;         /* -
4e10: 2d 72 65 62 75 69 6c 64 20 2a 2f 0a 20 20 69 6e  -rebuild */.  in
4e20: 74 20 72 75 6e 46 6c 61 67 73 20 3d 20 30 3b 20  t runFlags = 0; 
4e30: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 46 6c             /* Fl
4e40: 61 67 73 20 73 65 6e 74 20 74 6f 20 72 75 6e 53  ags sent to runS
4e50: 71 6c 28 29 20 2a 2f 0a 20 20 63 68 61 72 20 2a  ql() */.  char *
4e60: 7a 4d 73 67 20 3d 20 30 3b 20 20 20 20 20 20 20  zMsg = 0;       
4e70: 20 20 20 20 20 20 20 2f 2a 20 41 64 64 20 74 68         /* Add th
4e80: 69 73 20 6d 65 73 73 61 67 65 20 2a 2f 0a 20 20  is message */.  
4e90: 69 6e 74 20 6e 53 72 63 44 62 20 3d 20 30 3b 20  int nSrcDb = 0; 
4ea0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
4eb0: 4e 75 6d 62 65 72 20 6f 66 20 73 6f 75 72 63 65  Number of source
4ec0: 20 64 61 74 61 62 61 73 65 73 20 2a 2f 0a 20 20   databases */.  
4ed0: 63 68 61 72 20 2a 2a 61 7a 53 72 63 44 62 20 3d  char **azSrcDb =
4ee0: 20 30 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20   0;          /* 
4ef0: 41 72 72 61 79 20 6f 66 20 73 6f 75 72 63 65 20  Array of source 
4f00: 64 61 74 61 62 61 73 65 20 6e 61 6d 65 73 20 2a  database names *
4f10: 2f 0a 20 20 69 6e 74 20 69 53 72 63 44 62 3b 20  /.  int iSrcDb; 
4f20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4f30: 20 2f 2a 20 4c 6f 6f 70 20 6f 76 65 72 20 61 6c   /* Loop over al
4f40: 6c 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73  l source databas
4f50: 65 73 20 2a 2f 0a 20 20 69 6e 74 20 6e 54 65 73  es */.  int nTes
4f60: 74 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  t = 0;          
4f70: 20 20 20 20 20 2f 2a 20 54 6f 74 61 6c 20 6e 75       /* Total nu
4f80: 6d 62 65 72 20 6f 66 20 74 65 73 74 73 20 70 65  mber of tests pe
4f90: 72 66 6f 72 6d 65 64 20 2a 2f 0a 20 20 63 68 61  rformed */.  cha
4fa0: 72 20 2a 7a 44 62 4e 61 6d 65 20 3d 20 22 22 3b  r *zDbName = "";
4fb0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 70 70            /* App
4fc0: 72 65 76 69 61 74 65 64 20 6e 61 6d 65 20 6f 66  reviated name of
4fd0: 20 61 20 73 6f 75 72 63 65 20 64 61 74 61 62 61   a source databa
4fe0: 73 65 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68  se */.  const ch
4ff0: 61 72 20 2a 7a 46 61 69 6c 43 6f 64 65 20 3d 20  ar *zFailCode = 
5000: 30 3b 20 20 20 2f 2a 20 56 61 6c 75 65 20 6f 66  0;   /* Value of
5010: 20 74 68 65 20 54 45 53 54 5f 46 41 49 4c 55 52   the TEST_FAILUR
5020: 45 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 76 61  E environment va
5030: 72 69 61 62 6c 65 20 2a 2f 0a 20 20 69 6e 74 20  riable */.  int 
5040: 63 65 6c 6c 53 7a 43 6b 46 6c 61 67 20 3d 20 30  cellSzCkFlag = 0
5050: 3b 20 20 20 20 20 20 20 20 2f 2a 20 2d 2d 63 65  ;        /* --ce
5060: 6c 6c 2d 73 69 7a 65 2d 63 68 65 63 6b 20 2a 2f  ll-size-check */
5070: 0a 0a 20 20 69 42 65 67 69 6e 20 3d 20 74 69 6d  ..  iBegin = tim
5080: 65 4f 66 44 61 79 28 29 3b 0a 20 20 67 2e 7a 41  eOfDay();.  g.zA
5090: 72 67 76 30 20 3d 20 61 72 67 76 5b 30 5d 3b 0a  rgv0 = argv[0];.
50a0: 20 20 7a 46 61 69 6c 43 6f 64 65 20 3d 20 67 65    zFailCode = ge
50b0: 74 65 6e 76 28 22 54 45 53 54 5f 46 41 49 4c 55  tenv("TEST_FAILU
50c0: 52 45 22 29 3b 0a 20 20 66 6f 72 28 69 3d 31 3b  RE");.  for(i=1;
50d0: 20 69 3c 61 72 67 63 3b 20 69 2b 2b 29 7b 0a 20   i<argc; i++){. 
50e0: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a     const char *z
50f0: 20 3d 20 61 72 67 76 5b 69 5d 3b 0a 20 20 20 20   = argv[i];.    
5100: 69 66 28 20 7a 5b 30 5d 3d 3d 27 2d 27 20 29 7b  if( z[0]=='-' ){
5110: 0a 20 20 20 20 20 20 7a 2b 2b 3b 0a 20 20 20 20  .      z++;.    
5120: 20 20 69 66 28 20 7a 5b 30 5d 3d 3d 27 2d 27 20    if( z[0]=='-' 
5130: 29 20 7a 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28  ) z++;.      if(
5140: 20 73 74 72 63 6d 70 28 7a 2c 22 63 65 6c 6c 2d   strcmp(z,"cell-
5150: 73 69 7a 65 2d 63 68 65 63 6b 22 29 3d 3d 30 20  size-check")==0 
5160: 29 7b 0a 20 20 20 20 20 20 20 20 63 65 6c 6c 53  ){.        cellS
5170: 7a 43 6b 46 6c 61 67 20 3d 20 31 3b 0a 20 20 20  zCkFlag = 1;.   
5180: 20 20 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 69     }else.      i
5190: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 64 62 69  f( strcmp(z,"dbi
51a0: 64 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  d")==0 ){.      
51b0: 20 20 69 66 28 20 69 3e 3d 61 72 67 63 2d 31 20    if( i>=argc-1 
51c0: 29 20 66 61 74 61 6c 45 72 72 6f 72 28 22 6d 69  ) fatalError("mi
51d0: 73 73 69 6e 67 20 61 72 67 75 6d 65 6e 74 73 20  ssing arguments 
51e0: 6f 6e 20 25 73 22 2c 20 61 72 67 76 5b 69 5d 29  on %s", argv[i])
51f0: 3b 0a 20 20 20 20 20 20 20 20 6f 6e 6c 79 44 62  ;.        onlyDb
5200: 69 64 20 3d 20 61 74 6f 69 28 61 72 67 76 5b 2b  id = atoi(argv[+
5210: 2b 69 5d 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73  +i]);.      }els
5220: 65 0a 20 20 20 20 20 20 69 66 28 20 73 74 72 63  e.      if( strc
5230: 6d 70 28 7a 2c 22 68 65 6c 70 22 29 3d 3d 30 20  mp(z,"help")==0 
5240: 29 7b 0a 20 20 20 20 20 20 20 20 73 68 6f 77 48  ){.        showH
5250: 65 6c 70 28 29 3b 0a 20 20 20 20 20 20 20 20 72  elp();.        r
5260: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20 20 7d  eturn 0;.      }
5270: 65 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73  else.      if( s
5280: 74 72 63 6d 70 28 7a 2c 22 6c 6f 61 64 2d 73 71  trcmp(z,"load-sq
5290: 6c 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  l")==0 ){.      
52a0: 20 20 7a 49 6e 73 53 71 6c 20 3d 20 22 49 4e 53    zInsSql = "INS
52b0: 45 52 54 20 49 4e 54 4f 20 78 73 71 6c 28 73 71  ERT INTO xsql(sq
52c0: 6c 74 65 78 74 29 20 56 41 4c 55 45 53 28 43 41  ltext) VALUES(CA
52d0: 53 54 28 72 65 61 64 66 69 6c 65 28 3f 31 29 20  ST(readfile(?1) 
52e0: 41 53 20 74 65 78 74 29 29 22 3b 0a 20 20 20 20  AS text))";.    
52f0: 20 20 20 20 69 46 69 72 73 74 49 6e 73 41 72 67      iFirstInsArg
5300: 20 3d 20 69 2b 31 3b 0a 20 20 20 20 20 20 20 20   = i+1;.        
5310: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d 65 6c  break;.      }el
5320: 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74 72  se.      if( str
5330: 63 6d 70 28 7a 2c 22 6c 6f 61 64 2d 64 62 22 29  cmp(z,"load-db")
5340: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 7a  ==0 ){.        z
5350: 49 6e 73 53 71 6c 20 3d 20 22 49 4e 53 45 52 54  InsSql = "INSERT
5360: 20 49 4e 54 4f 20 64 62 28 64 62 63 6f 6e 74 65   INTO db(dbconte
5370: 6e 74 29 20 56 41 4c 55 45 53 28 72 65 61 64 66  nt) VALUES(readf
5380: 69 6c 65 28 3f 31 29 29 22 3b 0a 20 20 20 20 20  ile(?1))";.     
5390: 20 20 20 69 46 69 72 73 74 49 6e 73 41 72 67 20     iFirstInsArg 
53a0: 3d 20 69 2b 31 3b 0a 20 20 20 20 20 20 20 20 62  = i+1;.        b
53b0: 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d 65 6c 73  reak;.      }els
53c0: 65 0a 20 20 20 20 20 20 69 66 28 20 73 74 72 63  e.      if( strc
53d0: 6d 70 28 7a 2c 22 6d 22 29 3d 3d 30 20 29 7b 0a  mp(z,"m")==0 ){.
53e0: 20 20 20 20 20 20 20 20 69 66 28 20 69 3e 3d 61          if( i>=a
53f0: 72 67 63 2d 31 20 29 20 66 61 74 61 6c 45 72 72  rgc-1 ) fatalErr
5400: 6f 72 28 22 6d 69 73 73 69 6e 67 20 61 72 67 75  or("missing argu
5410: 6d 65 6e 74 73 20 6f 6e 20 25 73 22 2c 20 61 72  ments on %s", ar
5420: 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20 20 20 20  gv[i]);.        
5430: 7a 4d 73 67 20 3d 20 61 72 67 76 5b 2b 2b 69 5d  zMsg = argv[++i]
5440: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 0a 20 20  ;.      }else.  
5450: 20 20 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a      if( strcmp(z
5460: 2c 22 6e 61 74 69 76 65 2d 76 66 73 22 29 3d 3d  ,"native-vfs")==
5470: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 6e 61 74  0 ){.        nat
5480: 69 76 65 46 6c 61 67 20 3d 20 31 3b 0a 20 20 20  iveFlag = 1;.   
5490: 20 20 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 69     }else.      i
54a0: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 71 75 69  f( strcmp(z,"qui
54b0: 65 74 22 29 3d 3d 30 20 7c 7c 20 73 74 72 63 6d  et")==0 || strcm
54c0: 70 28 7a 2c 22 71 22 29 3d 3d 30 20 29 7b 0a 20  p(z,"q")==0 ){. 
54d0: 20 20 20 20 20 20 20 71 75 69 65 74 46 6c 61 67         quietFlag
54e0: 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 76 65   = 1;.        ve
54f0: 72 62 6f 73 65 46 6c 61 67 20 3d 20 30 3b 0a 20  rboseFlag = 0;. 
5500: 20 20 20 20 20 7d 65 6c 73 65 0a 20 20 20 20 20       }else.     
5510: 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 72   if( strcmp(z,"r
5520: 65 62 75 69 6c 64 22 29 3d 3d 30 20 29 7b 0a 20  ebuild")==0 ){. 
5530: 20 20 20 20 20 20 20 72 65 62 75 69 6c 64 46 6c         rebuildFl
5540: 61 67 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 65  ag = 1;.      }e
5550: 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74  lse.      if( st
5560: 72 63 6d 70 28 7a 2c 22 72 65 73 75 6c 74 2d 74  rcmp(z,"result-t
5570: 72 61 63 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20  race")==0 ){.   
5580: 20 20 20 20 20 72 75 6e 46 6c 61 67 73 20 7c 3d       runFlags |=
5590: 20 53 51 4c 5f 4f 55 54 50 55 54 3b 0a 20 20 20   SQL_OUTPUT;.   
55a0: 20 20 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 69     }else.      i
55b0: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 73 71 6c  f( strcmp(z,"sql
55c0: 69 64 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  id")==0 ){.     
55d0: 20 20 20 69 66 28 20 69 3e 3d 61 72 67 63 2d 31     if( i>=argc-1
55e0: 20 29 20 66 61 74 61 6c 45 72 72 6f 72 28 22 6d   ) fatalError("m
55f0: 69 73 73 69 6e 67 20 61 72 67 75 6d 65 6e 74 73  issing arguments
5600: 20 6f 6e 20 25 73 22 2c 20 61 72 67 76 5b 69 5d   on %s", argv[i]
5610: 29 3b 0a 20 20 20 20 20 20 20 20 6f 6e 6c 79 53  );.        onlyS
5620: 71 6c 69 64 20 3d 20 61 74 6f 69 28 61 72 67 76  qlid = atoi(argv
5630: 5b 2b 2b 69 5d 29 3b 0a 20 20 20 20 20 20 7d 65  [++i]);.      }e
5640: 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74  lse.      if( st
5650: 72 63 6d 70 28 7a 2c 22 76 65 72 62 6f 73 65 22  rcmp(z,"verbose"
5660: 29 3d 3d 30 20 7c 7c 20 73 74 72 63 6d 70 28 7a  )==0 || strcmp(z
5670: 2c 22 76 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ,"v")==0 ){.    
5680: 20 20 20 20 71 75 69 65 74 46 6c 61 67 20 3d 20      quietFlag = 
5690: 30 3b 0a 20 20 20 20 20 20 20 20 76 65 72 62 6f  0;.        verbo
56a0: 73 65 46 6c 61 67 20 3d 20 31 3b 0a 20 20 20 20  seFlag = 1;.    
56b0: 20 20 20 20 72 75 6e 46 6c 61 67 73 20 7c 3d 20      runFlags |= 
56c0: 53 51 4c 5f 54 52 41 43 45 3b 0a 20 20 20 20 20  SQL_TRACE;.     
56d0: 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 7b 0a 20   }else.      {. 
56e0: 20 20 20 20 20 20 20 66 61 74 61 6c 45 72 72 6f         fatalErro
56f0: 72 28 22 75 6e 6b 6e 6f 77 6e 20 6f 70 74 69 6f  r("unknown optio
5700: 6e 3a 20 25 73 22 2c 20 61 72 67 76 5b 69 5d 29  n: %s", argv[i])
5710: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 65  ;.      }.    }e
5720: 6c 73 65 7b 0a 20 20 20 20 20 20 6e 53 72 63 44  lse{.      nSrcD
5730: 62 2b 2b 3b 0a 20 20 20 20 20 20 61 7a 53 72 63  b++;.      azSrc
5740: 44 62 20 3d 20 73 61 66 65 5f 72 65 61 6c 6c 6f  Db = safe_reallo
5750: 63 28 61 7a 53 72 63 44 62 2c 20 6e 53 72 63 44  c(azSrcDb, nSrcD
5760: 62 2a 73 69 7a 65 6f 66 28 61 7a 53 72 63 44 62  b*sizeof(azSrcDb
5770: 5b 30 5d 29 29 3b 0a 20 20 20 20 20 20 61 7a 53  [0]));.      azS
5780: 72 63 44 62 5b 6e 53 72 63 44 62 2d 31 5d 20 3d  rcDb[nSrcDb-1] =
5790: 20 61 72 67 76 5b 69 5d 3b 0a 20 20 20 20 7d 0a   argv[i];.    }.
57a0: 20 20 7d 0a 20 20 69 66 28 20 6e 53 72 63 44 62    }.  if( nSrcDb
57b0: 3d 3d 30 20 29 20 66 61 74 61 6c 45 72 72 6f 72  ==0 ) fatalError
57c0: 28 22 6e 6f 20 73 6f 75 72 63 65 20 64 61 74 61  ("no source data
57d0: 62 61 73 65 20 73 70 65 63 69 66 69 65 64 22 29  base specified")
57e0: 3b 0a 20 20 69 66 28 20 6e 53 72 63 44 62 3e 31  ;.  if( nSrcDb>1
57f0: 20 29 7b 0a 20 20 20 20 69 66 28 20 7a 4d 73 67   ){.    if( zMsg
5800: 20 29 7b 0a 20 20 20 20 20 20 66 61 74 61 6c 45   ){.      fatalE
5810: 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20 63 68 61  rror("cannot cha
5820: 6e 67 65 20 74 68 65 20 64 65 73 63 72 69 70 74  nge the descript
5830: 69 6f 6e 20 6f 66 20 6d 6f 72 65 20 74 68 61 6e  ion of more than
5840: 20 6f 6e 65 20 64 61 74 61 62 61 73 65 22 29 3b   one database");
5850: 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 7a  .    }.    if( z
5860: 49 6e 73 53 71 6c 20 29 7b 0a 20 20 20 20 20 20  InsSql ){.      
5870: 66 61 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e  fatalError("cann
5880: 6f 74 20 69 6d 70 6f 72 74 20 69 6e 74 6f 20 6d  ot import into m
5890: 6f 72 65 20 74 68 61 6e 20 6f 6e 65 20 64 61 74  ore than one dat
58a0: 61 62 61 73 65 22 29 3b 0a 20 20 20 20 7d 0a 20  abase");.    }. 
58b0: 20 7d 0a 0a 20 20 2f 2a 20 50 72 6f 63 65 73 73   }..  /* Process
58c0: 20 65 61 63 68 20 73 6f 75 72 63 65 20 64 61 74   each source dat
58d0: 61 62 61 73 65 20 73 65 70 61 72 61 74 65 6c 79  abase separately
58e0: 20 2a 2f 0a 20 20 66 6f 72 28 69 53 72 63 44 62   */.  for(iSrcDb
58f0: 3d 30 3b 20 69 53 72 63 44 62 3c 6e 53 72 63 44  =0; iSrcDb<nSrcD
5900: 62 3b 20 69 53 72 63 44 62 2b 2b 29 7b 0a 20 20  b; iSrcDb++){.  
5910: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 6f    rc = sqlite3_o
5920: 70 65 6e 28 61 7a 53 72 63 44 62 5b 69 53 72 63  pen(azSrcDb[iSrc
5930: 44 62 5d 2c 20 26 64 62 29 3b 0a 20 20 20 20 69  Db], &db);.    i
5940: 66 28 20 72 63 20 29 7b 0a 20 20 20 20 20 20 66  f( rc ){.      f
5950: 61 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e 6f  atalError("canno
5960: 74 20 6f 70 65 6e 20 73 6f 75 72 63 65 20 64 61  t open source da
5970: 74 61 62 61 73 65 20 25 73 20 2d 20 25 73 22 2c  tabase %s - %s",
5980: 0a 20 20 20 20 20 20 61 7a 53 72 63 44 62 5b 69  .      azSrcDb[i
5990: 53 72 63 44 62 5d 2c 20 73 71 6c 69 74 65 33 5f  SrcDb], sqlite3_
59a0: 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20  errmsg(db));.   
59b0: 20 7d 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69   }.    rc = sqli
59c0: 74 65 33 5f 65 78 65 63 28 64 62 2c 0a 20 20 20  te3_exec(db,.   
59d0: 20 20 20 20 22 43 52 45 41 54 45 20 54 41 42 4c      "CREATE TABL
59e0: 45 20 49 46 20 4e 4f 54 20 45 58 49 53 54 53 20  E IF NOT EXISTS 
59f0: 64 62 28 5c 6e 22 0a 20 20 20 20 20 20 20 22 20  db(\n".       " 
5a00: 20 64 62 69 64 20 49 4e 54 45 47 45 52 20 50 52   dbid INTEGER PR
5a10: 49 4d 41 52 59 20 4b 45 59 2c 20 2d 2d 20 64 61  IMARY KEY, -- da
5a20: 74 61 62 61 73 65 20 69 64 5c 6e 22 0a 20 20 20  tabase id\n".   
5a30: 20 20 20 20 22 20 20 64 62 63 6f 6e 74 65 6e 74      "  dbcontent
5a40: 20 42 4c 4f 42 20 20 20 20 20 20 20 20 20 20 20   BLOB           
5a50: 20 2d 2d 20 64 61 74 61 62 61 73 65 20 64 69 73   -- database dis
5a60: 6b 20 66 69 6c 65 20 69 6d 61 67 65 5c 6e 22 0a  k file image\n".
5a70: 20 20 20 20 20 20 20 22 29 3b 5c 6e 22 0a 20 20         ");\n".  
5a80: 20 20 20 20 20 22 43 52 45 41 54 45 20 54 41 42       "CREATE TAB
5a90: 4c 45 20 49 46 20 4e 4f 54 20 45 58 49 53 54 53  LE IF NOT EXISTS
5aa0: 20 78 73 71 6c 28 5c 6e 22 0a 20 20 20 20 20 20   xsql(\n".      
5ab0: 20 22 20 20 73 71 6c 69 64 20 49 4e 54 45 47 45   "  sqlid INTEGE
5ac0: 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 20  R PRIMARY KEY,  
5ad0: 20 2d 2d 20 53 51 4c 20 73 63 72 69 70 74 20 69   -- SQL script i
5ae0: 64 5c 6e 22 0a 20 20 20 20 20 20 20 22 20 20 73  d\n".       "  s
5af0: 71 6c 74 65 78 74 20 54 45 58 54 20 20 20 20 20  qltext TEXT     
5b00: 20 20 20 20 20 20 20 20 20 20 20 20 2d 2d 20 54              -- T
5b10: 65 78 74 20 6f 66 20 53 51 4c 20 73 74 61 74 65  ext of SQL state
5b20: 6d 65 6e 74 73 20 74 6f 20 72 75 6e 5c 6e 22 0a  ments to run\n".
5b30: 20 20 20 20 20 20 20 22 29 3b 22 0a 20 20 20 20         ");".    
5b40: 20 20 20 22 43 52 45 41 54 45 20 54 41 42 4c 45     "CREATE TABLE
5b50: 20 49 46 20 4e 4f 54 20 45 58 49 53 54 53 20 72   IF NOT EXISTS r
5b60: 65 61 64 6d 65 28 5c 6e 22 0a 20 20 20 20 20 20  eadme(\n".      
5b70: 20 22 20 20 6d 73 67 20 54 45 58 54 20 2d 2d 20   "  msg TEXT -- 
5b80: 48 75 6d 61 6e 2d 72 65 61 64 61 62 6c 65 20 64  Human-readable d
5b90: 65 73 63 72 69 70 74 69 6f 6e 20 6f 66 20 74 68  escription of th
5ba0: 69 73 20 66 69 6c 65 5c 6e 22 0a 20 20 20 20 20  is file\n".     
5bb0: 20 20 22 29 3b 22 2c 20 30 2c 20 30 2c 20 30 29    ");", 0, 0, 0)
5bc0: 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29 20 66  ;.    if( rc ) f
5bd0: 61 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e 6f  atalError("canno
5be0: 74 20 63 72 65 61 74 65 20 73 63 68 65 6d 61 3a  t create schema:
5bf0: 20 25 73 22 2c 20 73 71 6c 69 74 65 33 5f 65 72   %s", sqlite3_er
5c00: 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 69  rmsg(db));.    i
5c10: 66 28 20 7a 4d 73 67 20 29 7b 0a 20 20 20 20 20  f( zMsg ){.     
5c20: 20 63 68 61 72 20 2a 7a 53 71 6c 3b 0a 20 20 20   char *zSql;.   
5c30: 20 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65     zSql = sqlite
5c40: 33 5f 6d 70 72 69 6e 74 66 28 0a 20 20 20 20 20  3_mprintf(.     
5c50: 20 20 20 20 20 20 20 20 20 20 22 44 45 4c 45 54            "DELET
5c60: 45 20 46 52 4f 4d 20 72 65 61 64 6d 65 3b 20 49  E FROM readme; I
5c70: 4e 53 45 52 54 20 49 4e 54 4f 20 72 65 61 64 6d  NSERT INTO readm
5c80: 65 28 6d 73 67 29 20 56 41 4c 55 45 53 28 25 51  e(msg) VALUES(%Q
5c90: 29 22 2c 20 7a 4d 73 67 29 3b 0a 20 20 20 20 20  )", zMsg);.     
5ca0: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 65 78   rc = sqlite3_ex
5cb0: 65 63 28 64 62 2c 20 7a 53 71 6c 2c 20 30 2c 20  ec(db, zSql, 0, 
5cc0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c  0, 0);.      sql
5cd0: 69 74 65 33 5f 66 72 65 65 28 7a 53 71 6c 29 3b  ite3_free(zSql);
5ce0: 0a 20 20 20 20 20 20 69 66 28 20 72 63 20 29 20  .      if( rc ) 
5cf0: 66 61 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e  fatalError("cann
5d00: 6f 74 20 63 68 61 6e 67 65 20 64 65 73 63 72 69  ot change descri
5d10: 70 74 69 6f 6e 3a 20 25 73 22 2c 20 73 71 6c 69  ption: %s", sqli
5d20: 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b  te3_errmsg(db));
5d30: 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 7a  .    }.    if( z
5d40: 49 6e 73 53 71 6c 20 29 7b 0a 20 20 20 20 20 20  InsSql ){.      
5d50: 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 66  sqlite3_create_f
5d60: 75 6e 63 74 69 6f 6e 28 64 62 2c 20 22 72 65 61  unction(db, "rea
5d70: 64 66 69 6c 65 22 2c 20 31 2c 20 53 51 4c 49 54  dfile", 1, SQLIT
5d80: 45 5f 55 54 46 38 2c 20 30 2c 0a 20 20 20 20 20  E_UTF8, 0,.     
5d90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5da0: 20 20 20 20 20 20 20 20 20 72 65 61 64 66 69 6c           readfil
5db0: 65 46 75 6e 63 2c 20 30 2c 20 30 29 3b 0a 20 20  eFunc, 0, 0);.  
5dc0: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
5dd0: 5f 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 20  _prepare_v2(db, 
5de0: 7a 49 6e 73 53 71 6c 2c 20 2d 31 2c 20 26 70 53  zInsSql, -1, &pS
5df0: 74 6d 74 2c 20 30 29 3b 0a 20 20 20 20 20 20 69  tmt, 0);.      i
5e00: 66 28 20 72 63 20 29 20 66 61 74 61 6c 45 72 72  f( rc ) fatalErr
5e10: 6f 72 28 22 63 61 6e 6e 6f 74 20 70 72 65 70 61  or("cannot prepa
5e20: 72 65 20 73 74 61 74 65 6d 65 6e 74 20 5b 25 73  re statement [%s
5e30: 5d 3a 20 25 73 22 2c 0a 20 20 20 20 20 20 20 20  ]: %s",.        
5e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e50: 20 20 7a 49 6e 73 53 71 6c 2c 20 73 71 6c 69 74    zInsSql, sqlit
5e60: 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a  e3_errmsg(db));.
5e70: 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74        rc = sqlit
5e80: 65 33 5f 65 78 65 63 28 64 62 2c 20 22 42 45 47  e3_exec(db, "BEG
5e90: 49 4e 22 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20  IN", 0, 0, 0);. 
5ea0: 20 20 20 20 20 69 66 28 20 72 63 20 29 20 66 61       if( rc ) fa
5eb0: 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e 6f 74  talError("cannot
5ec0: 20 73 74 61 72 74 20 61 20 74 72 61 6e 73 61 63   start a transac
5ed0: 74 69 6f 6e 22 29 3b 0a 20 20 20 20 20 20 66 6f  tion");.      fo
5ee0: 72 28 69 3d 69 46 69 72 73 74 49 6e 73 41 72 67  r(i=iFirstInsArg
5ef0: 3b 20 69 3c 61 72 67 63 3b 20 69 2b 2b 29 7b 0a  ; i<argc; i++){.
5f00: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
5f10: 62 69 6e 64 5f 74 65 78 74 28 70 53 74 6d 74 2c  bind_text(pStmt,
5f20: 20 31 2c 20 61 72 67 76 5b 69 5d 2c 20 2d 31 2c   1, argv[i], -1,
5f30: 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b   SQLITE_STATIC);
5f40: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
5f50: 5f 73 74 65 70 28 70 53 74 6d 74 29 3b 0a 20 20  _step(pStmt);.  
5f60: 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74        rc = sqlit
5f70: 65 33 5f 72 65 73 65 74 28 70 53 74 6d 74 29 3b  e3_reset(pStmt);
5f80: 0a 20 20 20 20 20 20 20 20 69 66 28 20 72 63 20  .        if( rc 
5f90: 29 20 66 61 74 61 6c 45 72 72 6f 72 28 22 69 6e  ) fatalError("in
5fa0: 73 65 72 74 20 66 61 69 6c 65 64 20 66 6f 72 20  sert failed for 
5fb0: 25 73 22 2c 20 61 72 67 76 5b 69 5d 29 3b 0a 20  %s", argv[i]);. 
5fc0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c       }.      sql
5fd0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53  ite3_finalize(pS
5fe0: 74 6d 74 29 3b 0a 20 20 20 20 20 20 72 63 20 3d  tmt);.      rc =
5ff0: 20 73 71 6c 69 74 65 33 5f 65 78 65 63 28 64 62   sqlite3_exec(db
6000: 2c 20 22 43 4f 4d 4d 49 54 22 2c 20 30 2c 20 30  , "COMMIT", 0, 0
6010: 2c 20 30 29 3b 0a 20 20 20 20 20 20 69 66 28 20  , 0);.      if( 
6020: 72 63 20 29 20 66 61 74 61 6c 45 72 72 6f 72 28  rc ) fatalError(
6030: 22 63 61 6e 6e 6f 74 20 63 6f 6d 6d 69 74 20 74  "cannot commit t
6040: 68 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 3a 20  he transaction: 
6050: 25 73 22 2c 20 73 71 6c 69 74 65 33 5f 65 72 72  %s", sqlite3_err
6060: 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 20 20  msg(db));.      
6070: 72 65 62 75 69 6c 64 5f 64 61 74 61 62 61 73 65  rebuild_database
6080: 28 64 62 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  (db);.      sqli
6090: 74 65 33 5f 63 6c 6f 73 65 28 64 62 29 3b 0a 20  te3_close(db);. 
60a0: 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20       return 0;. 
60b0: 20 20 20 7d 0a 20 20 0a 20 20 20 20 2f 2a 20 4c     }.  .    /* L
60c0: 6f 61 64 20 61 6c 6c 20 53 51 4c 20 73 63 72 69  oad all SQL scri
60d0: 70 74 20 63 6f 6e 74 65 6e 74 20 61 6e 64 20 61  pt content and a
60e0: 6c 6c 20 69 6e 69 74 69 61 6c 20 64 61 74 61 62  ll initial datab
60f0: 61 73 65 20 69 6d 61 67 65 73 20 66 72 6f 6d 20  ase images from 
6100: 74 68 65 0a 20 20 20 20 2a 2a 20 73 6f 75 72 63  the.    ** sourc
6110: 65 20 64 62 0a 20 20 20 20 2a 2f 0a 20 20 20 20  e db.    */.    
6120: 62 6c 6f 62 4c 69 73 74 4c 6f 61 64 46 72 6f 6d  blobListLoadFrom
6130: 44 62 28 64 62 2c 20 22 53 45 4c 45 43 54 20 73  Db(db, "SELECT s
6140: 71 6c 69 64 2c 20 73 71 6c 74 65 78 74 20 46 52  qlid, sqltext FR
6150: 4f 4d 20 78 73 71 6c 22 2c 20 6f 6e 6c 79 53 71  OM xsql", onlySq
6160: 6c 69 64 2c 0a 20 20 20 20 20 20 20 20 20 20 20  lid,.           
6170: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6180: 26 67 2e 6e 53 71 6c 2c 20 26 67 2e 70 46 69 72  &g.nSql, &g.pFir
6190: 73 74 53 71 6c 29 3b 0a 20 20 20 20 69 66 28 20  stSql);.    if( 
61a0: 67 2e 6e 53 71 6c 3d 3d 30 20 29 20 66 61 74 61  g.nSql==0 ) fata
61b0: 6c 45 72 72 6f 72 28 22 6e 65 65 64 20 61 74 20  lError("need at 
61c0: 6c 65 61 73 74 20 6f 6e 65 20 53 51 4c 20 73 63  least one SQL sc
61d0: 72 69 70 74 22 29 3b 0a 20 20 20 20 62 6c 6f 62  ript");.    blob
61e0: 4c 69 73 74 4c 6f 61 64 46 72 6f 6d 44 62 28 64  ListLoadFromDb(d
61f0: 62 2c 20 22 53 45 4c 45 43 54 20 64 62 69 64 2c  b, "SELECT dbid,
6200: 20 64 62 63 6f 6e 74 65 6e 74 20 46 52 4f 4d 20   dbcontent FROM 
6210: 64 62 22 2c 20 6f 6e 6c 79 44 62 69 64 2c 0a 20  db", onlyDbid,. 
6220: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6230: 20 20 20 20 20 20 26 67 2e 6e 44 62 2c 20 26 67        &g.nDb, &g
6240: 2e 70 46 69 72 73 74 44 62 29 3b 0a 20 20 20 20  .pFirstDb);.    
6250: 69 66 28 20 67 2e 6e 44 62 3d 3d 30 20 29 7b 0a  if( g.nDb==0 ){.
6260: 20 20 20 20 20 20 67 2e 70 46 69 72 73 74 44 62        g.pFirstDb
6270: 20 3d 20 73 61 66 65 5f 72 65 61 6c 6c 6f 63 28   = safe_realloc(
6280: 30 2c 20 73 69 7a 65 6f 66 28 42 6c 6f 62 29 29  0, sizeof(Blob))
6290: 3b 0a 20 20 20 20 20 20 6d 65 6d 73 65 74 28 67  ;.      memset(g
62a0: 2e 70 46 69 72 73 74 44 62 2c 20 30 2c 20 73 69  .pFirstDb, 0, si
62b0: 7a 65 6f 66 28 42 6c 6f 62 29 29 3b 0a 20 20 20  zeof(Blob));.   
62c0: 20 20 20 67 2e 70 46 69 72 73 74 44 62 2d 3e 69     g.pFirstDb->i
62d0: 64 20 3d 20 31 3b 0a 20 20 20 20 20 20 67 2e 70  d = 1;.      g.p
62e0: 46 69 72 73 74 44 62 2d 3e 73 65 71 20 3d 20 30  FirstDb->seq = 0
62f0: 3b 0a 20 20 20 20 20 20 67 2e 6e 44 62 20 3d 20  ;.      g.nDb = 
6300: 31 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20  1;.    }.  .    
6310: 2f 2a 20 50 72 69 6e 74 20 74 68 65 20 64 65 73  /* Print the des
6320: 63 72 69 70 74 69 6f 6e 2c 20 69 66 20 74 68 65  cription, if the
6330: 72 65 20 69 73 20 6f 6e 65 20 2a 2f 0a 20 20 20  re is one */.   
6340: 20 69 66 28 20 21 71 75 69 65 74 46 6c 61 67 20   if( !quietFlag 
6350: 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a  ){.      int i;.
6360: 20 20 20 20 20 20 7a 44 62 4e 61 6d 65 20 3d 20        zDbName = 
6370: 61 7a 53 72 63 44 62 5b 69 53 72 63 44 62 5d 3b  azSrcDb[iSrcDb];
6380: 0a 20 20 20 20 20 20 69 20 3d 20 73 74 72 6c 65  .      i = strle
6390: 6e 28 7a 44 62 4e 61 6d 65 29 20 2d 20 31 3b 0a  n(zDbName) - 1;.
63a0: 20 20 20 20 20 20 77 68 69 6c 65 28 20 69 3e 30        while( i>0
63b0: 20 26 26 20 7a 44 62 4e 61 6d 65 5b 69 2d 31 5d   && zDbName[i-1]
63c0: 21 3d 27 2f 27 20 26 26 20 7a 44 62 4e 61 6d 65  !='/' && zDbName
63d0: 5b 69 2d 31 5d 21 3d 27 5c 5c 27 20 29 7b 20 69  [i-1]!='\\' ){ i
63e0: 2d 2d 3b 20 7d 0a 20 20 20 20 20 20 7a 44 62 4e  --; }.      zDbN
63f0: 61 6d 65 20 2b 3d 20 69 3b 0a 20 20 20 20 20 20  ame += i;.      
6400: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
6410: 76 32 28 64 62 2c 20 22 53 45 4c 45 43 54 20 6d  v2(db, "SELECT m
6420: 73 67 20 46 52 4f 4d 20 72 65 61 64 6d 65 22 2c  sg FROM readme",
6430: 20 2d 31 2c 20 26 70 53 74 6d 74 2c 20 30 29 3b   -1, &pStmt, 0);
6440: 0a 20 20 20 20 20 20 69 66 28 20 70 53 74 6d 74  .      if( pStmt
6450: 20 26 26 20 73 71 6c 69 74 65 33 5f 73 74 65 70   && sqlite3_step
6460: 28 70 53 74 6d 74 29 3d 3d 53 51 4c 49 54 45 5f  (pStmt)==SQLITE_
6470: 52 4f 57 20 29 7b 0a 20 20 20 20 20 20 20 20 70  ROW ){.        p
6480: 72 69 6e 74 66 28 22 25 73 3a 20 25 73 5c 6e 22  rintf("%s: %s\n"
6490: 2c 20 7a 44 62 4e 61 6d 65 2c 20 73 71 6c 69 74  , zDbName, sqlit
64a0: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70  e3_column_text(p
64b0: 53 74 6d 74 2c 30 29 29 3b 0a 20 20 20 20 20 20  Stmt,0));.      
64c0: 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  }.      sqlite3_
64d0: 66 69 6e 61 6c 69 7a 65 28 70 53 74 6d 74 29 3b  finalize(pStmt);
64e0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 52  .    }..    /* R
64f0: 65 62 75 69 6c 64 20 74 68 65 20 64 61 74 61 62  ebuild the datab
6500: 61 73 65 2c 20 69 66 20 72 65 71 75 65 73 74 65  ase, if requeste
6510: 64 20 2a 2f 0a 20 20 20 20 69 66 28 20 72 65 62  d */.    if( reb
6520: 75 69 6c 64 46 6c 61 67 20 29 7b 0a 20 20 20 20  uildFlag ){.    
6530: 20 20 69 66 28 20 21 71 75 69 65 74 46 6c 61 67    if( !quietFlag
6540: 20 29 7b 0a 20 20 20 20 20 20 20 20 70 72 69 6e   ){.        prin
6550: 74 66 28 22 25 73 3a 20 72 65 62 75 69 6c 64 69  tf("%s: rebuildi
6560: 6e 67 2e 2e 2e 20 22 2c 20 7a 44 62 4e 61 6d 65  ng... ", zDbName
6570: 29 3b 0a 20 20 20 20 20 20 20 20 66 66 6c 75 73  );.        fflus
6580: 68 28 73 74 64 6f 75 74 29 3b 0a 20 20 20 20 20  h(stdout);.     
6590: 20 7d 0a 20 20 20 20 20 20 72 65 62 75 69 6c 64   }.      rebuild
65a0: 5f 64 61 74 61 62 61 73 65 28 64 62 29 3b 0a 20  _database(db);. 
65b0: 20 20 20 20 20 69 66 28 20 21 71 75 69 65 74 46       if( !quietF
65c0: 6c 61 67 20 29 20 70 72 69 6e 74 66 28 22 64 6f  lag ) printf("do
65d0: 6e 65 5c 6e 22 29 3b 0a 20 20 20 20 7d 0a 20 20  ne\n");.    }.  
65e0: 0a 20 20 20 20 2f 2a 20 43 6c 6f 73 65 20 74 68  .    /* Close th
65f0: 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73  e source databas
6600: 65 2e 20 20 56 65 72 69 66 79 20 74 68 61 74 20  e.  Verify that 
6610: 6e 6f 20 53 51 4c 69 74 65 20 6d 65 6d 6f 72 79  no SQLite memory
6620: 20 61 6c 6c 6f 63 61 74 69 6f 6e 73 20 61 72 65   allocations are
6630: 0a 20 20 20 20 2a 2a 20 6f 75 74 73 74 61 6e 64  .    ** outstand
6640: 69 6e 67 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20  ing..    */.    
6650: 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 28 64 62  sqlite3_close(db
6660: 29 3b 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74  );.    if( sqlit
6670: 65 33 5f 6d 65 6d 6f 72 79 5f 75 73 65 64 28 29  e3_memory_used()
6680: 3e 30 20 29 7b 0a 20 20 20 20 20 20 66 61 74 61  >0 ){.      fata
6690: 6c 45 72 72 6f 72 28 22 53 51 4c 69 74 65 20 68  lError("SQLite h
66a0: 61 73 20 6d 65 6d 6f 72 79 20 69 6e 20 75 73 65  as memory in use
66b0: 20 62 65 66 6f 72 65 20 74 68 65 20 73 74 61 72   before the star
66c0: 74 20 6f 66 20 74 65 73 74 69 6e 67 22 29 3b 0a  t of testing");.
66d0: 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 2f 2a 20      }.  .    /* 
66e0: 52 65 67 69 73 74 65 72 20 74 68 65 20 69 6e 2d  Register the in-
66f0: 6d 65 6d 6f 72 79 20 76 69 72 74 75 61 6c 20 66  memory virtual f
6700: 69 6c 65 73 79 73 74 65 6d 0a 20 20 20 20 2a 2f  ilesystem.    */
6710: 0a 20 20 20 20 66 6f 72 6d 61 74 56 66 73 28 29  .    formatVfs()
6720: 3b 0a 20 20 20 20 69 6e 6d 65 6d 56 66 73 52 65  ;.    inmemVfsRe
6730: 67 69 73 74 65 72 28 29 3b 0a 20 20 20 20 0a 20  gister();.    . 
6740: 20 20 20 2f 2a 20 52 75 6e 20 61 20 74 65 73 74     /* Run a test
6750: 20 75 73 69 6e 67 20 65 61 63 68 20 53 51 4c 20   using each SQL 
6760: 73 63 72 69 70 74 20 61 67 61 69 6e 73 74 20 65  script against e
6770: 61 63 68 20 64 61 74 61 62 61 73 65 2e 0a 20 20  ach database..  
6780: 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 21 76 65    */.    if( !ve
6790: 72 62 6f 73 65 46 6c 61 67 20 26 26 20 21 71 75  rboseFlag && !qu
67a0: 69 65 74 46 6c 61 67 20 29 20 70 72 69 6e 74 66  ietFlag ) printf
67b0: 28 22 25 73 3a 22 2c 20 7a 44 62 4e 61 6d 65 29  ("%s:", zDbName)
67c0: 3b 0a 20 20 20 20 66 6f 72 28 70 53 71 6c 3d 67  ;.    for(pSql=g
67d0: 2e 70 46 69 72 73 74 53 71 6c 3b 20 70 53 71 6c  .pFirstSql; pSql
67e0: 3b 20 70 53 71 6c 3d 70 53 71 6c 2d 3e 70 4e 65  ; pSql=pSql->pNe
67f0: 78 74 29 7b 0a 20 20 20 20 20 20 66 6f 72 28 70  xt){.      for(p
6800: 44 62 3d 67 2e 70 46 69 72 73 74 44 62 3b 20 70  Db=g.pFirstDb; p
6810: 44 62 3b 20 70 44 62 3d 70 44 62 2d 3e 70 4e 65  Db; pDb=pDb->pNe
6820: 78 74 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74  xt){.        int
6830: 20 6f 70 65 6e 46 6c 61 67 73 3b 0a 20 20 20 20   openFlags;.    
6840: 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a      const char *
6850: 7a 56 66 73 20 3d 20 22 69 6e 6d 65 6d 22 3b 0a  zVfs = "inmem";.
6860: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
6870: 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66 28  snprintf(sizeof(
6880: 67 2e 7a 54 65 73 74 4e 61 6d 65 29 2c 20 67 2e  g.zTestName), g.
6890: 7a 54 65 73 74 4e 61 6d 65 2c 20 22 73 71 6c 69  zTestName, "sqli
68a0: 64 3d 25 64 2c 64 62 69 64 3d 25 64 22 2c 0a 20  d=%d,dbid=%d",. 
68b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
68c0: 20 20 20 20 20 20 20 20 70 53 71 6c 2d 3e 69 64          pSql->id
68d0: 2c 20 70 44 62 2d 3e 69 64 29 3b 0a 20 20 20 20  , pDb->id);.    
68e0: 20 20 20 20 69 66 28 20 76 65 72 62 6f 73 65 46      if( verboseF
68f0: 6c 61 67 20 29 7b 0a 20 20 20 20 20 20 20 20 20  lag ){.         
6900: 20 70 72 69 6e 74 66 28 22 25 73 5c 6e 22 2c 20   printf("%s\n", 
6910: 67 2e 7a 54 65 73 74 4e 61 6d 65 29 3b 0a 20 20  g.zTestName);.  
6920: 20 20 20 20 20 20 20 20 66 66 6c 75 73 68 28 73          fflush(s
6930: 74 64 6f 75 74 29 3b 0a 20 20 20 20 20 20 20 20  tdout);.        
6940: 7d 65 6c 73 65 20 69 66 28 20 21 71 75 69 65 74  }else if( !quiet
6950: 46 6c 61 67 20 29 7b 0a 20 20 20 20 20 20 20 20  Flag ){.        
6960: 20 20 73 74 61 74 69 63 20 69 6e 74 20 70 72 65    static int pre
6970: 76 41 6d 74 20 3d 20 2d 31 3b 0a 20 20 20 20 20  vAmt = -1;.     
6980: 20 20 20 20 20 69 6e 74 20 69 64 78 20 3d 20 70       int idx = p
6990: 53 71 6c 2d 3e 73 65 71 2a 67 2e 6e 44 62 20 2b  Sql->seq*g.nDb +
69a0: 20 70 44 62 2d 3e 69 64 20 2d 20 31 3b 0a 20 20   pDb->id - 1;.  
69b0: 20 20 20 20 20 20 20 20 69 6e 74 20 61 6d 74 20          int amt 
69c0: 3d 20 69 64 78 2a 31 30 2f 28 67 2e 6e 44 62 2a  = idx*10/(g.nDb*
69d0: 67 2e 6e 53 71 6c 29 3b 0a 20 20 20 20 20 20 20  g.nSql);.       
69e0: 20 20 20 69 66 28 20 61 6d 74 21 3d 70 72 65 76     if( amt!=prev
69f0: 41 6d 74 20 29 7b 0a 20 20 20 20 20 20 20 20 20  Amt ){.         
6a00: 20 20 20 70 72 69 6e 74 66 28 22 20 25 64 25 25     printf(" %d%%
6a10: 22 2c 20 61 6d 74 2a 31 30 29 3b 0a 20 20 20 20  ", amt*10);.    
6a20: 20 20 20 20 20 20 20 20 66 66 6c 75 73 68 28 73          fflush(s
6a30: 74 64 6f 75 74 29 3b 0a 20 20 20 20 20 20 20 20  tdout);.        
6a40: 20 20 20 20 70 72 65 76 41 6d 74 20 3d 20 61 6d      prevAmt = am
6a50: 74 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  t;.          }. 
6a60: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
6a70: 20 63 72 65 61 74 65 56 46 69 6c 65 28 22 6d 61   createVFile("ma
6a80: 69 6e 2e 64 62 22 2c 20 70 44 62 2d 3e 73 7a 2c  in.db", pDb->sz,
6a90: 20 70 44 62 2d 3e 61 29 3b 0a 20 20 20 20 20 20   pDb->a);.      
6aa0: 20 20 6f 70 65 6e 46 6c 61 67 73 20 3d 20 53 51    openFlags = SQ
6ab0: 4c 49 54 45 5f 4f 50 45 4e 5f 43 52 45 41 54 45  LITE_OPEN_CREATE
6ac0: 20 7c 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 52   | SQLITE_OPEN_R
6ad0: 45 41 44 57 52 49 54 45 3b 0a 20 20 20 20 20 20  EADWRITE;.      
6ae0: 20 20 69 66 28 20 6e 61 74 69 76 65 46 6c 61 67    if( nativeFlag
6af0: 20 26 26 20 70 44 62 2d 3e 73 7a 3d 3d 30 20 29   && pDb->sz==0 )
6b00: 7b 0a 20 20 20 20 20 20 20 20 20 20 6f 70 65 6e  {.          open
6b10: 46 6c 61 67 73 20 7c 3d 20 53 51 4c 49 54 45 5f  Flags |= SQLITE_
6b20: 4f 50 45 4e 5f 4d 45 4d 4f 52 59 3b 0a 20 20 20  OPEN_MEMORY;.   
6b30: 20 20 20 20 20 20 20 7a 56 66 73 20 3d 20 30 3b         zVfs = 0;
6b40: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
6b50: 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f     rc = sqlite3_
6b60: 6f 70 65 6e 5f 76 32 28 22 6d 61 69 6e 2e 64 62  open_v2("main.db
6b70: 22 2c 20 26 64 62 2c 20 6f 70 65 6e 46 6c 61 67  ", &db, openFlag
6b80: 73 2c 20 7a 56 66 73 29 3b 0a 20 20 20 20 20 20  s, zVfs);.      
6b90: 20 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c    if( rc ) fatal
6ba0: 45 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20 6f 70  Error("cannot op
6bb0: 65 6e 20 69 6e 6d 65 6d 20 64 61 74 61 62 61 73  en inmem databas
6bc0: 65 22 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28  e");.        if(
6bd0: 20 63 65 6c 6c 53 7a 43 6b 46 6c 61 67 20 29 20   cellSzCkFlag ) 
6be0: 72 75 6e 53 71 6c 28 64 62 2c 20 22 50 52 41 47  runSql(db, "PRAG
6bf0: 4d 41 20 63 65 6c 6c 5f 73 69 7a 65 5f 63 68 65  MA cell_size_che
6c00: 63 6b 3d 4f 4e 22 2c 20 72 75 6e 46 6c 61 67 73  ck=ON", runFlags
6c10: 29 3b 0a 20 20 20 20 20 20 20 20 72 75 6e 53 71  );.        runSq
6c20: 6c 28 64 62 2c 20 28 63 68 61 72 2a 29 70 53 71  l(db, (char*)pSq
6c30: 6c 2d 3e 61 2c 20 72 75 6e 46 6c 61 67 73 29 3b  l->a, runFlags);
6c40: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
6c50: 5f 63 6c 6f 73 65 28 64 62 29 3b 0a 20 20 20 20  _close(db);.    
6c60: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f      if( sqlite3_
6c70: 6d 65 6d 6f 72 79 5f 75 73 65 64 28 29 3e 30 20  memory_used()>0 
6c80: 29 20 66 61 74 61 6c 45 72 72 6f 72 28 22 6d 65  ) fatalError("me
6c90: 6d 6f 72 79 20 6c 65 61 6b 22 29 3b 0a 20 20 20  mory leak");.   
6ca0: 20 20 20 20 20 72 65 66 6f 72 6d 61 74 56 66 73       reformatVfs
6cb0: 28 29 3b 0a 20 20 20 20 20 20 20 20 6e 54 65 73  ();.        nTes
6cc0: 74 2b 2b 3b 0a 20 20 20 20 20 20 20 20 67 2e 7a  t++;.        g.z
6cd0: 54 65 73 74 4e 61 6d 65 5b 30 5d 20 3d 20 30 3b  TestName[0] = 0;
6ce0: 0a 0a 20 20 20 20 20 20 20 20 2f 2a 20 53 69 6d  ..        /* Sim
6cf0: 75 6c 61 74 65 20 61 6e 20 65 72 72 6f 72 20 69  ulate an error i
6d00: 66 20 74 68 65 20 54 45 53 54 5f 46 41 49 4c 55  f the TEST_FAILU
6d10: 52 45 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 76  RE environment v
6d20: 61 72 69 61 62 6c 65 20 69 73 20 22 35 22 2e 0a  ariable is "5"..
6d30: 20 20 20 20 20 20 20 20 2a 2a 20 54 68 69 73 20          ** This 
6d40: 69 73 20 75 73 65 64 20 74 6f 20 76 65 72 69 66  is used to verif
6d50: 79 20 74 68 61 74 20 61 75 74 6f 6d 61 74 65 64  y that automated
6d60: 20 74 65 73 74 20 73 63 72 69 70 74 20 72 65 61   test script rea
6d70: 6c 6c 79 20 64 6f 20 73 70 6f 74 0a 20 20 20 20  lly do spot.    
6d80: 20 20 20 20 2a 2a 20 65 72 72 6f 72 73 20 74 68      ** errors th
6d90: 61 74 20 6f 63 63 75 72 20 69 6e 20 74 68 69 73  at occur in this
6da0: 20 74 65 73 74 20 70 72 6f 67 72 61 6d 2e 0a 20   test program.. 
6db0: 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20         */.      
6dc0: 20 20 69 66 28 20 7a 46 61 69 6c 43 6f 64 65 20    if( zFailCode 
6dd0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  ){.          if(
6de0: 20 7a 46 61 69 6c 43 6f 64 65 5b 30 5d 3d 3d 27   zFailCode[0]=='
6df0: 35 27 20 26 26 20 7a 46 61 69 6c 43 6f 64 65 5b  5' && zFailCode[
6e00: 31 5d 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  1]==0 ){.       
6e10: 20 20 20 20 20 66 61 74 61 6c 45 72 72 6f 72 28       fatalError(
6e20: 22 73 69 6d 75 6c 61 74 65 64 20 66 61 69 6c 75  "simulated failu
6e30: 72 65 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20  re");.          
6e40: 7d 65 6c 73 65 20 69 66 28 20 7a 46 61 69 6c 43  }else if( zFailC
6e50: 6f 64 65 5b 30 5d 21 3d 30 20 29 7b 0a 20 20 20  ode[0]!=0 ){.   
6e60: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 66 20 54           /* If T
6e70: 45 53 54 5f 46 41 49 4c 55 52 45 20 69 73 20 73  EST_FAILURE is s
6e80: 6f 6d 65 74 68 69 6e 67 20 6f 74 68 65 72 20 74  omething other t
6e90: 68 61 6e 20 35 2c 20 6a 75 73 74 20 65 78 69 74  han 5, just exit
6ea0: 20 74 68 65 20 74 65 73 74 0a 20 20 20 20 20 20   the test.      
6eb0: 20 20 20 20 20 20 2a 2a 20 65 61 72 6c 79 20 2a        ** early *
6ec0: 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 72  /.            pr
6ed0: 69 6e 74 66 28 22 5c 6e 45 78 69 74 20 65 61 72  intf("\nExit ear
6ee0: 6c 79 20 64 75 65 20 74 6f 20 54 45 53 54 5f 46  ly due to TEST_F
6ef0: 41 49 4c 55 52 45 20 62 65 69 6e 67 20 73 65 74  AILURE being set
6f00: 5c 6e 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20  \n");.          
6f10: 20 20 69 53 72 63 44 62 20 3d 20 6e 53 72 63 44    iSrcDb = nSrcD
6f20: 62 2d 31 3b 0a 20 20 20 20 20 20 20 20 20 20 20  b-1;.           
6f30: 20 67 6f 74 6f 20 73 6f 75 72 63 65 64 62 5f 63   goto sourcedb_c
6f40: 6c 65 61 6e 75 70 3b 0a 20 20 20 20 20 20 20 20  leanup;.        
6f50: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
6f60: 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20      }.    }.    
6f70: 69 66 28 20 21 71 75 69 65 74 46 6c 61 67 20 26  if( !quietFlag &
6f80: 26 20 21 76 65 72 62 6f 73 65 46 6c 61 67 20 29  & !verboseFlag )
6f90: 7b 0a 20 20 20 20 20 20 70 72 69 6e 74 66 28 22  {.      printf("
6fa0: 20 31 30 30 25 25 20 2d 20 25 64 20 74 65 73 74   100%% - %d test
6fb0: 73 5c 6e 22 2c 20 67 2e 6e 44 62 2a 67 2e 6e 53  s\n", g.nDb*g.nS
6fc0: 71 6c 29 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20  ql);.    }.  .  
6fd0: 20 20 2f 2a 20 43 6c 65 61 6e 20 75 70 20 61 74    /* Clean up at
6fe0: 20 74 68 65 20 65 6e 64 20 6f 66 20 70 72 6f 63   the end of proc
6ff0: 65 73 73 69 6e 67 20 61 20 73 69 6e 67 6c 65 20  essing a single 
7000: 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 0a  source database.
7010: 20 20 20 20 2a 2f 0a 20 20 73 6f 75 72 63 65 64      */.  sourced
7020: 62 5f 63 6c 65 61 6e 75 70 3a 0a 20 20 20 20 62  b_cleanup:.    b
7030: 6c 6f 62 4c 69 73 74 46 72 65 65 28 67 2e 70 46  lobListFree(g.pF
7040: 69 72 73 74 53 71 6c 29 3b 0a 20 20 20 20 62 6c  irstSql);.    bl
7050: 6f 62 4c 69 73 74 46 72 65 65 28 67 2e 70 46 69  obListFree(g.pFi
7060: 72 73 74 44 62 29 3b 0a 20 20 20 20 72 65 66 6f  rstDb);.    refo
7070: 72 6d 61 74 56 66 73 28 29 3b 0a 20 0a 20 20 7d  rmatVfs();. .  }
7080: 20 2f 2a 20 45 6e 64 20 6c 6f 6f 70 20 6f 76 65   /* End loop ove
7090: 72 20 61 6c 6c 20 73 6f 75 72 63 65 20 64 61 74  r all source dat
70a0: 61 62 61 73 65 73 20 2a 2f 0a 0a 20 20 69 66 28  abases */..  if(
70b0: 20 21 71 75 69 65 74 46 6c 61 67 20 29 7b 0a 20   !quietFlag ){. 
70c0: 20 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34     sqlite3_int64
70d0: 20 69 45 6c 61 70 73 65 20 3d 20 74 69 6d 65 4f   iElapse = timeO
70e0: 66 44 61 79 28 29 20 2d 20 69 42 65 67 69 6e 3b  fDay() - iBegin;
70f0: 0a 20 20 20 20 70 72 69 6e 74 66 28 22 66 75 7a  .    printf("fuz
7100: 7a 63 68 65 63 6b 3a 20 30 20 65 72 72 6f 72 73  zcheck: 0 errors
7110: 20 6f 75 74 20 6f 66 20 25 64 20 74 65 73 74 73   out of %d tests
7120: 20 69 6e 20 25 64 2e 25 30 33 64 20 73 65 63 6f   in %d.%03d seco
7130: 6e 64 73 5c 6e 22 0a 20 20 20 20 20 20 20 20 20  nds\n".         
7140: 20 20 22 53 51 4c 69 74 65 20 25 73 20 25 73 5c    "SQLite %s %s\
7150: 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 6e  n",.           n
7160: 54 65 73 74 2c 20 28 69 6e 74 29 28 69 45 6c 61  Test, (int)(iEla
7170: 70 73 65 2f 31 30 30 30 29 2c 20 28 69 6e 74 29  pse/1000), (int)
7180: 28 69 45 6c 61 70 73 65 25 31 30 30 30 29 2c 0a  (iElapse%1000),.
7190: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
71a0: 65 33 5f 6c 69 62 76 65 72 73 69 6f 6e 28 29 2c  e3_libversion(),
71b0: 20 73 71 6c 69 74 65 33 5f 73 6f 75 72 63 65 69   sqlite3_sourcei
71c0: 64 28 29 29 3b 0a 20 20 7d 0a 20 20 66 72 65 65  d());.  }.  free
71d0: 28 61 7a 53 72 63 44 62 29 3b 0a 20 20 72 65 74  (azSrcDb);.  ret
71e0: 75 72 6e 20 30 3b 0a 7d 0a                       urn 0;.}.