/ Hex Artifact Content
Login

Artifact d0e76671ea5c3a766768b65d69f7d755aa614a98c17b84fa4496f4cd2e2fa515:


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 3c 61 73 73 65 72 74 2e 68 3e 0a 23 69  de <assert.h>.#i
0b30: 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65 33 2e  nclude "sqlite3.
0b40: 68 22 0a 23 64 65 66 69 6e 65 20 49 53 53 50 41  h".#define ISSPA
0b50: 43 45 28 58 29 20 69 73 73 70 61 63 65 28 28 75  CE(X) isspace((u
0b60: 6e 73 69 67 6e 65 64 20 63 68 61 72 29 28 58 29  nsigned char)(X)
0b70: 29 0a 23 64 65 66 69 6e 65 20 49 53 44 49 47 49  ).#define ISDIGI
0b80: 54 28 58 29 20 69 73 64 69 67 69 74 28 28 75 6e  T(X) isdigit((un
0b90: 73 69 67 6e 65 64 20 63 68 61 72 29 28 58 29 29  signed char)(X))
0ba0: 0a 0a 0a 23 69 66 64 65 66 20 5f 5f 75 6e 69 78  ...#ifdef __unix
0bb0: 5f 5f 0a 23 20 69 6e 63 6c 75 64 65 20 3c 73 69  __.# include <si
0bc0: 67 6e 61 6c 2e 68 3e 0a 23 20 69 6e 63 6c 75 64  gnal.h>.# includ
0bd0: 65 20 3c 75 6e 69 73 74 64 2e 68 3e 0a 23 65 6e  e <unistd.h>.#en
0be0: 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51 4c 49  dif..#ifdef SQLI
0bf0: 54 45 5f 4f 53 53 5f 46 55 5a 5a 0a 23 20 69 6e  TE_OSS_FUZZ.# in
0c00: 63 6c 75 64 65 20 3c 73 74 64 64 65 66 2e 68 3e  clude <stddef.h>
0c10: 0a 23 20 69 66 20 21 64 65 66 69 6e 65 64 28 5f  .# if !defined(_
0c20: 4d 53 43 5f 56 45 52 29 0a 23 20 20 69 6e 63 6c  MSC_VER).#  incl
0c30: 75 64 65 20 3c 73 74 64 69 6e 74 2e 68 3e 0a 23  ude <stdint.h>.#
0c40: 20 65 6e 64 69 66 0a 23 65 6e 64 69 66 0a 0a 23   endif.#endif..#
0c50: 69 66 20 64 65 66 69 6e 65 64 28 5f 4d 53 43 5f  if defined(_MSC_
0c60: 56 45 52 29 0a 74 79 70 65 64 65 66 20 75 6e 73  VER).typedef uns
0c70: 69 67 6e 65 64 20 63 68 61 72 20 75 69 6e 74 38  igned char uint8
0c80: 5f 74 3b 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a  _t;.#endif../*.*
0c90: 2a 20 46 69 6c 65 73 20 69 6e 20 74 68 65 20 76  * Files in the v
0ca0: 69 72 74 75 61 6c 20 66 69 6c 65 20 73 79 73 74  irtual file syst
0cb0: 65 6d 2e 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73  em..*/.typedef s
0cc0: 74 72 75 63 74 20 56 46 69 6c 65 20 56 46 69 6c  truct VFile VFil
0cd0: 65 3b 0a 73 74 72 75 63 74 20 56 46 69 6c 65 20  e;.struct VFile 
0ce0: 7b 0a 20 20 63 68 61 72 20 2a 7a 46 69 6c 65 6e  {.  char *zFilen
0cf0: 61 6d 65 3b 20 20 20 20 20 20 20 20 2f 2a 20 46  ame;        /* F
0d00: 69 6c 65 6e 61 6d 65 2e 20 20 4e 55 4c 4c 20 66  ilename.  NULL f
0d10: 6f 72 20 64 65 6c 65 74 65 2d 6f 6e 2d 63 6c 6f  or delete-on-clo
0d20: 73 65 2e 20 46 72 6f 6d 20 6d 61 6c 6c 6f 63 28  se. From malloc(
0d30: 29 20 2a 2f 0a 20 20 69 6e 74 20 73 7a 3b 20 20  ) */.  int sz;  
0d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
0d50: 2a 20 53 69 7a 65 20 6f 66 20 74 68 65 20 66 69  * Size of the fi
0d60: 6c 65 20 69 6e 20 62 79 74 65 73 20 2a 2f 0a 20  le in bytes */. 
0d70: 20 69 6e 74 20 6e 52 65 66 3b 20 20 20 20 20 20   int nRef;      
0d80: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62           /* Numb
0d90: 65 72 20 6f 66 20 72 65 66 65 72 65 6e 63 65 73  er of references
0da0: 20 74 6f 20 74 68 69 73 20 66 69 6c 65 20 2a 2f   to this file */
0db0: 0a 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72  .  unsigned char
0dc0: 20 2a 61 3b 20 20 20 20 20 20 20 2f 2a 20 43 6f   *a;       /* Co
0dd0: 6e 74 65 6e 74 20 6f 66 20 74 68 65 20 66 69 6c  ntent of the fil
0de0: 65 2e 20 20 46 72 6f 6d 20 6d 61 6c 6c 6f 63 28  e.  From malloc(
0df0: 29 20 2a 2f 0a 7d 3b 0a 74 79 70 65 64 65 66 20  ) */.};.typedef 
0e00: 73 74 72 75 63 74 20 56 48 61 6e 64 6c 65 20 56  struct VHandle V
0e10: 48 61 6e 64 6c 65 3b 0a 73 74 72 75 63 74 20 56  Handle;.struct V
0e20: 48 61 6e 64 6c 65 20 7b 0a 20 20 73 71 6c 69 74  Handle {.  sqlit
0e30: 65 33 5f 66 69 6c 65 20 62 61 73 65 3b 20 20 20  e3_file base;   
0e40: 20 20 20 2f 2a 20 42 61 73 65 20 63 6c 61 73 73     /* Base class
0e50: 2e 20 20 4d 75 73 74 20 62 65 20 66 69 72 73 74  .  Must be first
0e60: 20 2a 2f 0a 20 20 56 46 69 6c 65 20 2a 70 56 46   */.  VFile *pVF
0e70: 69 6c 65 3b 20 20 20 20 20 20 20 20 20 20 2f 2a  ile;          /*
0e80: 20 54 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20   The underlying 
0e90: 66 69 6c 65 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a  file */.};../*.*
0ea0: 2a 20 54 68 65 20 76 61 6c 75 65 20 6f 66 20 61  * The value of a
0eb0: 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 20 74   database file t
0ec0: 65 6d 70 6c 61 74 65 2c 20 6f 72 20 6f 66 20 61  emplate, or of a
0ed0: 6e 20 53 51 4c 20 73 63 72 69 70 74 0a 2a 2f 0a  n SQL script.*/.
0ee0: 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20 42  typedef struct B
0ef0: 6c 6f 62 20 42 6c 6f 62 3b 0a 73 74 72 75 63 74  lob Blob;.struct
0f00: 20 42 6c 6f 62 20 7b 0a 20 20 42 6c 6f 62 20 2a   Blob {.  Blob *
0f10: 70 4e 65 78 74 3b 20 20 20 20 20 20 20 20 20 20  pNext;          
0f20: 20 20 2f 2a 20 4e 65 78 74 20 69 6e 20 61 20 6c    /* Next in a l
0f30: 69 73 74 20 2a 2f 0a 20 20 69 6e 74 20 69 64 3b  ist */.  int id;
0f40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0f50: 20 2f 2a 20 49 64 20 6f 66 20 74 68 69 73 20 42   /* Id of this B
0f60: 6c 6f 62 20 2a 2f 0a 20 20 69 6e 74 20 73 65 71  lob */.  int seq
0f70: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
0f80: 20 2f 2a 20 53 65 71 75 65 6e 63 65 20 6e 75 6d   /* Sequence num
0f90: 62 65 72 20 2a 2f 0a 20 20 69 6e 74 20 73 7a 3b  ber */.  int sz;
0fa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0fb0: 20 2f 2a 20 53 69 7a 65 20 6f 66 20 74 68 69 73   /* Size of this
0fc0: 20 42 6c 6f 62 20 69 6e 20 62 79 74 65 73 20 2a   Blob in bytes *
0fd0: 2f 0a 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61  /.  unsigned cha
0fe0: 72 20 61 5b 31 5d 3b 20 20 20 20 20 2f 2a 20 42  r a[1];     /* B
0ff0: 6c 6f 62 20 63 6f 6e 74 65 6e 74 2e 20 20 45 78  lob content.  Ex
1000: 74 72 61 20 73 70 61 63 65 20 61 6c 6c 6f 63 61  tra space alloca
1010: 74 65 64 20 61 73 20 6e 65 65 64 65 64 2e 20 2a  ted as needed. *
1020: 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 4d 61 78 69  /.};../*.** Maxi
1030: 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20 66 69  mum number of fi
1040: 6c 65 73 20 69 6e 20 74 68 65 20 69 6e 2d 6d 65  les in the in-me
1050: 6d 6f 72 79 20 76 69 72 74 75 61 6c 20 66 69 6c  mory virtual fil
1060: 65 73 79 73 74 65 6d 2e 0a 2a 2f 0a 23 64 65 66  esystem..*/.#def
1070: 69 6e 65 20 4d 58 5f 46 49 4c 45 20 20 31 30 0a  ine MX_FILE  10.
1080: 0a 2f 2a 0a 2a 2a 20 4d 61 78 69 6d 75 6d 20 61  ./*.** Maximum a
1090: 6c 6c 6f 77 65 64 20 66 69 6c 65 20 73 69 7a 65  llowed file size
10a0: 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 58 5f 46  .*/.#define MX_F
10b0: 49 4c 45 5f 53 5a 20 31 30 30 30 30 30 30 30 0a  ILE_SZ 10000000.
10c0: 0a 2f 2a 0a 2a 2a 20 41 6c 6c 20 67 6c 6f 62 61  ./*.** All globa
10d0: 6c 20 76 61 72 69 61 62 6c 65 73 20 61 72 65 20  l variables are 
10e0: 67 61 74 68 65 72 65 64 20 69 6e 74 6f 20 74 68  gathered into th
10f0: 65 20 22 67 22 20 73 69 6e 67 6c 65 74 6f 6e 2e  e "g" singleton.
1100: 0a 2a 2f 0a 73 74 61 74 69 63 20 73 74 72 75 63  .*/.static struc
1110: 74 20 47 6c 6f 62 61 6c 56 61 72 73 20 7b 0a 20  t GlobalVars {. 
1120: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 41 72   const char *zAr
1130: 67 76 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  gv0;            
1140: 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 70 72 6f    /* Name of pro
1150: 67 72 61 6d 20 2a 2f 0a 20 20 56 46 69 6c 65 20  gram */.  VFile 
1160: 61 46 69 6c 65 5b 4d 58 5f 46 49 4c 45 5d 3b 20  aFile[MX_FILE]; 
1170: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68             /* Th
1180: 65 20 76 69 72 74 75 61 6c 20 66 69 6c 65 73 79  e virtual filesy
1190: 73 74 65 6d 20 2a 2f 0a 20 20 69 6e 74 20 6e 44  stem */.  int nD
11a0: 62 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b;              
11b0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75             /* Nu
11c0: 6d 62 65 72 20 6f 66 20 74 65 6d 70 6c 61 74 65  mber of template
11d0: 20 64 61 74 61 62 61 73 65 73 20 2a 2f 0a 20 20   databases */.  
11e0: 42 6c 6f 62 20 2a 70 46 69 72 73 74 44 62 3b 20  Blob *pFirstDb; 
11f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1200: 20 2f 2a 20 43 6f 6e 74 65 6e 74 20 6f 66 20 66   /* Content of f
1210: 69 72 73 74 20 74 65 6d 70 6c 61 74 65 20 64 61  irst template da
1220: 74 61 62 61 73 65 20 2a 2f 0a 20 20 69 6e 74 20  tabase */.  int 
1230: 6e 53 71 6c 3b 20 20 20 20 20 20 20 20 20 20 20  nSql;           
1240: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1250: 4e 75 6d 62 65 72 20 6f 66 20 53 51 4c 20 73 63  Number of SQL sc
1260: 72 69 70 74 73 20 2a 2f 0a 20 20 42 6c 6f 62 20  ripts */.  Blob 
1270: 2a 70 46 69 72 73 74 53 71 6c 3b 20 20 20 20 20  *pFirstSql;     
1280: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 46              /* F
1290: 69 72 73 74 20 53 51 4c 20 73 63 72 69 70 74 20  irst SQL script 
12a0: 2a 2f 0a 20 20 75 6e 73 69 67 6e 65 64 20 69 6e  */.  unsigned in
12b0: 74 20 75 52 61 6e 64 6f 6d 3b 20 20 20 20 20 20  t uRandom;      
12c0: 20 20 20 20 20 20 2f 2a 20 53 65 65 64 20 66 6f        /* Seed fo
12d0: 72 20 74 68 65 20 53 51 4c 69 74 65 20 50 52 4e  r the SQLite PRN
12e0: 47 20 2a 2f 0a 20 20 63 68 61 72 20 7a 54 65 73  G */.  char zTes
12f0: 74 4e 61 6d 65 5b 31 30 30 5d 3b 20 20 20 20 20  tName[100];     
1300: 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20          /* Name 
1310: 6f 66 20 63 75 72 72 65 6e 74 20 74 65 73 74 20  of current test 
1320: 2a 2f 0a 7d 20 67 3b 0a 0a 2f 2a 0a 2a 2a 20 50  */.} g;../*.** P
1330: 72 69 6e 74 20 61 6e 20 65 72 72 6f 72 20 6d 65  rint an error me
1340: 73 73 61 67 65 20 61 6e 64 20 71 75 69 74 2e 0a  ssage and quit..
1350: 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 66  */.static void f
1360: 61 74 61 6c 45 72 72 6f 72 28 63 6f 6e 73 74 20  atalError(const 
1370: 63 68 61 72 20 2a 7a 46 6f 72 6d 61 74 2c 20 2e  char *zFormat, .
1380: 2e 2e 29 7b 0a 20 20 76 61 5f 6c 69 73 74 20 61  ..){.  va_list a
1390: 70 3b 0a 20 20 69 66 28 20 67 2e 7a 54 65 73 74  p;.  if( g.zTest
13a0: 4e 61 6d 65 5b 30 5d 20 29 7b 0a 20 20 20 20 66  Name[0] ){.    f
13b0: 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 20 22  printf(stderr, "
13c0: 25 73 20 28 25 73 29 3a 20 22 2c 20 67 2e 7a 41  %s (%s): ", g.zA
13d0: 72 67 76 30 2c 20 67 2e 7a 54 65 73 74 4e 61 6d  rgv0, g.zTestNam
13e0: 65 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  e);.  }else{.   
13f0: 20 66 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c   fprintf(stderr,
1400: 20 22 25 73 3a 20 22 2c 20 67 2e 7a 41 72 67 76   "%s: ", g.zArgv
1410: 30 29 3b 0a 20 20 7d 0a 20 20 76 61 5f 73 74 61  0);.  }.  va_sta
1420: 72 74 28 61 70 2c 20 7a 46 6f 72 6d 61 74 29 3b  rt(ap, zFormat);
1430: 0a 20 20 76 66 70 72 69 6e 74 66 28 73 74 64 65  .  vfprintf(stde
1440: 72 72 2c 20 7a 46 6f 72 6d 61 74 2c 20 61 70 29  rr, zFormat, ap)
1450: 3b 0a 20 20 76 61 5f 65 6e 64 28 61 70 29 3b 0a  ;.  va_end(ap);.
1460: 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72 72    fprintf(stderr
1470: 2c 20 22 5c 6e 22 29 3b 0a 20 20 65 78 69 74 28  , "\n");.  exit(
1480: 31 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 69 6d  1);.}../*.** Tim
1490: 65 6f 75 74 20 68 61 6e 64 6c 65 72 0a 2a 2f 0a  eout handler.*/.
14a0: 23 69 66 64 65 66 20 5f 5f 75 6e 69 78 5f 5f 0a  #ifdef __unix__.
14b0: 73 74 61 74 69 63 20 76 6f 69 64 20 74 69 6d 65  static void time
14c0: 6f 75 74 48 61 6e 64 6c 65 72 28 69 6e 74 20 4e  outHandler(int N
14d0: 6f 74 55 73 65 64 29 7b 0a 20 20 28 76 6f 69 64  otUsed){.  (void
14e0: 29 4e 6f 74 55 73 65 64 3b 0a 20 20 66 61 74 61  )NotUsed;.  fata
14f0: 6c 45 72 72 6f 72 28 22 74 69 6d 65 6f 75 74 5c  lError("timeout\
1500: 6e 22 29 3b 0a 7d 0a 23 65 6e 64 69 66 0a 0a 2f  n");.}.#endif../
1510: 2a 0a 2a 2a 20 53 65 74 20 74 68 65 20 61 6e 20  *.** Set the an 
1520: 61 6c 61 72 6d 20 74 6f 20 67 6f 20 6f 66 66 20  alarm to go off 
1530: 61 66 74 65 72 20 4e 20 73 65 63 6f 6e 64 73 2e  after N seconds.
1540: 20 20 44 69 73 61 62 6c 65 20 74 68 65 20 61 6c    Disable the al
1550: 61 72 6d 0a 2a 2a 20 69 66 20 4e 3d 3d 30 0a 2a  arm.** if N==0.*
1560: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 73 65  /.static void se
1570: 74 41 6c 61 72 6d 28 69 6e 74 20 4e 29 7b 0a 23  tAlarm(int N){.#
1580: 69 66 64 65 66 20 5f 5f 75 6e 69 78 5f 5f 0a 20  ifdef __unix__. 
1590: 20 61 6c 61 72 6d 28 4e 29 3b 0a 23 65 6c 73 65   alarm(N);.#else
15a0: 0a 20 20 28 76 6f 69 64 29 4e 3b 0a 23 65 6e 64  .  (void)N;.#end
15b0: 69 66 0a 7d 0a 0a 23 69 66 6e 64 65 66 20 53 51  if.}..#ifndef SQ
15c0: 4c 49 54 45 5f 4f 4d 49 54 5f 50 52 4f 47 52 45  LITE_OMIT_PROGRE
15d0: 53 53 5f 43 41 4c 4c 42 41 43 4b 0a 2f 2a 0a 2a  SS_CALLBACK./*.*
15e0: 2a 20 54 68 69 73 20 61 6e 20 53 51 4c 20 70 72  * This an SQL pr
15f0: 6f 67 72 65 73 73 20 68 61 6e 64 6c 65 72 2e 20  ogress handler. 
1600: 20 41 66 74 65 72 20 61 6e 20 53 51 4c 20 73 74   After an SQL st
1610: 61 74 65 6d 65 6e 74 20 68 61 73 20 72 75 6e 20  atement has run 
1620: 66 6f 72 0a 2a 2a 20 6d 61 6e 79 20 73 74 65 70  for.** many step
1630: 73 2c 20 77 65 20 77 61 6e 74 20 74 6f 20 69 6e  s, we want to in
1640: 74 65 72 72 75 70 74 20 69 74 2e 20 20 54 68 69  terrupt it.  Thi
1650: 73 20 67 75 61 72 64 73 20 61 67 61 69 6e 73 74  s guards against
1660: 20 69 6e 66 69 6e 69 74 65 0a 2a 2a 20 6c 6f 6f   infinite.** loo
1670: 70 73 20 66 72 6f 6d 20 72 65 63 75 72 73 69 76  ps from recursiv
1680: 65 20 63 6f 6d 6d 6f 6e 20 74 61 62 6c 65 20 65  e common table e
1690: 78 70 72 65 73 73 69 6f 6e 73 2e 0a 2a 2a 0a 2a  xpressions..**.*
16a0: 2a 20 2a 70 56 64 62 65 4c 69 6d 69 74 46 6c 61  * *pVdbeLimitFla
16b0: 67 20 69 73 20 74 72 75 65 20 69 66 20 74 68 65  g is true if the
16c0: 20 2d 2d 6c 69 6d 69 74 2d 76 64 62 65 20 63 6f   --limit-vdbe co
16d0: 6d 6d 61 6e 64 2d 6c 69 6e 65 20 6f 70 74 69 6f  mmand-line optio
16e0: 6e 20 69 73 20 75 73 65 64 2e 0a 2a 2a 20 49 6e  n is used..** In
16f0: 20 74 68 61 74 20 63 61 73 65 2c 20 68 69 74 74   that case, hitt
1700: 69 6e 67 20 74 68 65 20 70 72 6f 67 72 65 73 73  ing the progress
1710: 20 68 61 6e 64 6c 65 72 20 69 73 20 61 20 66 61   handler is a fa
1720: 74 61 6c 20 65 72 72 6f 72 2e 0a 2a 2f 0a 73 74  tal error..*/.st
1730: 61 74 69 63 20 69 6e 74 20 70 72 6f 67 72 65 73  atic int progres
1740: 73 48 61 6e 64 6c 65 72 28 76 6f 69 64 20 2a 70  sHandler(void *p
1750: 56 64 62 65 4c 69 6d 69 74 46 6c 61 67 29 7b 0a  VdbeLimitFlag){.
1760: 20 20 69 66 28 20 2a 28 69 6e 74 2a 29 70 56 64    if( *(int*)pVd
1770: 62 65 4c 69 6d 69 74 46 6c 61 67 20 29 20 66 61  beLimitFlag ) fa
1780: 74 61 6c 45 72 72 6f 72 28 22 74 6f 6f 20 6d 61  talError("too ma
1790: 6e 79 20 56 44 42 45 20 63 79 63 6c 65 73 22 29  ny VDBE cycles")
17a0: 3b 0a 20 20 72 65 74 75 72 6e 20 31 3b 0a 7d 0a  ;.  return 1;.}.
17b0: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 52 65  #endif../*.** Re
17c0: 61 6c 6c 6f 63 61 74 65 20 6d 65 6d 6f 72 79 2e  allocate memory.
17d0: 20 20 53 68 6f 77 20 61 6e 64 20 65 72 72 6f 72    Show and error
17e0: 20 61 6e 64 20 71 75 69 74 20 69 66 20 75 6e 61   and quit if una
17f0: 62 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76  ble..*/.static v
1800: 6f 69 64 20 2a 73 61 66 65 5f 72 65 61 6c 6c 6f  oid *safe_reallo
1810: 63 28 76 6f 69 64 20 2a 70 4f 6c 64 2c 20 69 6e  c(void *pOld, in
1820: 74 20 73 7a 4e 65 77 29 7b 0a 20 20 76 6f 69 64  t szNew){.  void
1830: 20 2a 70 4e 65 77 20 3d 20 72 65 61 6c 6c 6f 63   *pNew = realloc
1840: 28 70 4f 6c 64 2c 20 73 7a 4e 65 77 3c 3d 30 20  (pOld, szNew<=0 
1850: 3f 20 31 20 3a 20 73 7a 4e 65 77 29 3b 0a 20 20  ? 1 : szNew);.  
1860: 69 66 28 20 70 4e 65 77 3d 3d 30 20 29 20 66 61  if( pNew==0 ) fa
1870: 74 61 6c 45 72 72 6f 72 28 22 75 6e 61 62 6c 65  talError("unable
1880: 20 74 6f 20 72 65 61 6c 6c 6f 63 20 66 6f 72 20   to realloc for 
1890: 25 64 20 62 79 74 65 73 22 2c 20 73 7a 4e 65 77  %d bytes", szNew
18a0: 29 3b 0a 20 20 72 65 74 75 72 6e 20 70 4e 65 77  );.  return pNew
18b0: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 69 74 69  ;.}../*.** Initi
18c0: 61 6c 69 7a 65 20 74 68 65 20 76 69 72 74 75 61  alize the virtua
18d0: 6c 20 66 69 6c 65 20 73 79 73 74 65 6d 2e 0a 2a  l file system..*
18e0: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 66 6f  /.static void fo
18f0: 72 6d 61 74 56 66 73 28 76 6f 69 64 29 7b 0a 20  rmatVfs(void){. 
1900: 20 69 6e 74 20 69 3b 0a 20 20 66 6f 72 28 69 3d   int i;.  for(i=
1910: 30 3b 20 69 3c 4d 58 5f 46 49 4c 45 3b 20 69 2b  0; i<MX_FILE; i+
1920: 2b 29 7b 0a 20 20 20 20 67 2e 61 46 69 6c 65 5b  +){.    g.aFile[
1930: 69 5d 2e 73 7a 20 3d 20 2d 31 3b 0a 20 20 20 20  i].sz = -1;.    
1940: 67 2e 61 46 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65  g.aFile[i].zFile
1950: 6e 61 6d 65 20 3d 20 30 3b 0a 20 20 20 20 67 2e  name = 0;.    g.
1960: 61 46 69 6c 65 5b 69 5d 2e 61 20 3d 20 30 3b 0a  aFile[i].a = 0;.
1970: 20 20 20 20 67 2e 61 46 69 6c 65 5b 69 5d 2e 6e      g.aFile[i].n
1980: 52 65 66 20 3d 20 30 3b 0a 20 20 7d 0a 7d 0a 0a  Ref = 0;.  }.}..
1990: 0a 2f 2a 0a 2a 2a 20 45 72 61 73 65 20 61 6c 6c  ./*.** Erase all
19a0: 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 69 6e 20   information in 
19b0: 74 68 65 20 76 69 72 74 75 61 6c 20 66 69 6c 65  the virtual file
19c0: 20 73 79 73 74 65 6d 2e 0a 2a 2f 0a 73 74 61 74   system..*/.stat
19d0: 69 63 20 76 6f 69 64 20 72 65 66 6f 72 6d 61 74  ic void reformat
19e0: 56 66 73 28 76 6f 69 64 29 7b 0a 20 20 69 6e 74  Vfs(void){.  int
19f0: 20 69 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69   i;.  for(i=0; i
1a00: 3c 4d 58 5f 46 49 4c 45 3b 20 69 2b 2b 29 7b 0a  <MX_FILE; i++){.
1a10: 20 20 20 20 69 66 28 20 67 2e 61 46 69 6c 65 5b      if( g.aFile[
1a20: 69 5d 2e 73 7a 3c 30 20 29 20 63 6f 6e 74 69 6e  i].sz<0 ) contin
1a30: 75 65 3b 0a 20 20 20 20 69 66 28 20 67 2e 61 46  ue;.    if( g.aF
1a40: 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65 6e 61 6d 65  ile[i].zFilename
1a50: 20 29 7b 0a 20 20 20 20 20 20 66 72 65 65 28 67   ){.      free(g
1a60: 2e 61 46 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65 6e  .aFile[i].zFilen
1a70: 61 6d 65 29 3b 0a 20 20 20 20 20 20 67 2e 61 46  ame);.      g.aF
1a80: 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65 6e 61 6d 65  ile[i].zFilename
1a90: 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 20 20 20 20   = 0;.    }.    
1aa0: 69 66 28 20 67 2e 61 46 69 6c 65 5b 69 5d 2e 6e  if( g.aFile[i].n
1ab0: 52 65 66 3e 30 20 29 7b 0a 20 20 20 20 20 20 66  Ref>0 ){.      f
1ac0: 61 74 61 6c 45 72 72 6f 72 28 22 66 69 6c 65 20  atalError("file 
1ad0: 25 64 20 73 74 69 6c 6c 20 6f 70 65 6e 2e 20 20  %d still open.  
1ae0: 6e 52 65 66 3d 25 64 22 2c 20 69 2c 20 67 2e 61  nRef=%d", i, g.a
1af0: 46 69 6c 65 5b 69 5d 2e 6e 52 65 66 29 3b 0a 20  File[i].nRef);. 
1b00: 20 20 20 7d 0a 20 20 20 20 67 2e 61 46 69 6c 65     }.    g.aFile
1b10: 5b 69 5d 2e 73 7a 20 3d 20 2d 31 3b 0a 20 20 20  [i].sz = -1;.   
1b20: 20 66 72 65 65 28 67 2e 61 46 69 6c 65 5b 69 5d   free(g.aFile[i]
1b30: 2e 61 29 3b 0a 20 20 20 20 67 2e 61 46 69 6c 65  .a);.    g.aFile
1b40: 5b 69 5d 2e 61 20 3d 20 30 3b 0a 20 20 20 20 67  [i].a = 0;.    g
1b50: 2e 61 46 69 6c 65 5b 69 5d 2e 6e 52 65 66 20 3d  .aFile[i].nRef =
1b60: 20 30 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a   0;.  }.}../*.**
1b70: 20 46 69 6e 64 20 61 20 56 46 69 6c 65 20 62 79   Find a VFile by
1b80: 20 6e 61 6d 65 0a 2a 2f 0a 73 74 61 74 69 63 20   name.*/.static 
1b90: 56 46 69 6c 65 20 2a 66 69 6e 64 56 46 69 6c 65  VFile *findVFile
1ba0: 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4e 61  (const char *zNa
1bb0: 6d 65 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20  me){.  int i;.  
1bc0: 69 66 28 20 7a 4e 61 6d 65 3d 3d 30 20 29 20 72  if( zName==0 ) r
1bd0: 65 74 75 72 6e 20 30 3b 0a 20 20 66 6f 72 28 69  eturn 0;.  for(i
1be0: 3d 30 3b 20 69 3c 4d 58 5f 46 49 4c 45 3b 20 69  =0; i<MX_FILE; i
1bf0: 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 67 2e 61  ++){.    if( g.a
1c00: 46 69 6c 65 5b 69 5d 2e 7a 46 69 6c 65 6e 61 6d  File[i].zFilenam
1c10: 65 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b  e==0 ) continue;
1c20: 20 20 20 0a 20 20 20 20 69 66 28 20 73 74 72 63     .    if( strc
1c30: 6d 70 28 67 2e 61 46 69 6c 65 5b 69 5d 2e 7a 46  mp(g.aFile[i].zF
1c40: 69 6c 65 6e 61 6d 65 2c 20 7a 4e 61 6d 65 29 3d  ilename, zName)=
1c50: 3d 30 20 29 20 72 65 74 75 72 6e 20 26 67 2e 61  =0 ) return &g.a
1c60: 46 69 6c 65 5b 69 5d 3b 0a 20 20 7d 0a 20 20 72  File[i];.  }.  r
1c70: 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a  eturn 0;.}../*.*
1c80: 2a 20 46 69 6e 64 20 61 20 56 46 69 6c 65 20 62  * Find a VFile b
1c90: 79 20 6e 61 6d 65 2e 20 20 43 72 65 61 74 65 20  y name.  Create 
1ca0: 69 74 20 69 66 20 69 74 20 64 6f 65 73 20 6e 6f  it if it does no
1cb0: 74 20 61 6c 72 65 61 64 79 20 65 78 69 73 74 20  t already exist 
1cc0: 61 6e 64 0a 2a 2a 20 69 6e 69 74 69 61 6c 69 7a  and.** initializ
1cd0: 65 20 69 74 20 74 6f 20 74 68 65 20 73 69 7a 65  e it to the size
1ce0: 20 61 6e 64 20 63 6f 6e 74 65 6e 74 20 67 69 76   and content giv
1cf0: 65 6e 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72 6e  en..**.** Return
1d00: 20 4e 55 4c 4c 20 6f 6e 6c 79 20 69 66 20 74 68   NULL only if th
1d10: 65 20 66 69 6c 65 73 79 73 74 65 6d 20 69 73 20  e filesystem is 
1d20: 66 75 6c 6c 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  full..*/.static 
1d30: 56 46 69 6c 65 20 2a 63 72 65 61 74 65 56 46 69  VFile *createVFi
1d40: 6c 65 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  le(const char *z
1d50: 4e 61 6d 65 2c 20 69 6e 74 20 73 7a 2c 20 75 6e  Name, int sz, un
1d60: 73 69 67 6e 65 64 20 63 68 61 72 20 2a 70 44 61  signed char *pDa
1d70: 74 61 29 7b 0a 20 20 56 46 69 6c 65 20 2a 70 4e  ta){.  VFile *pN
1d80: 65 77 20 3d 20 66 69 6e 64 56 46 69 6c 65 28 7a  ew = findVFile(z
1d90: 4e 61 6d 65 29 3b 0a 20 20 69 6e 74 20 69 3b 0a  Name);.  int i;.
1da0: 20 20 69 66 28 20 70 4e 65 77 20 29 20 72 65 74    if( pNew ) ret
1db0: 75 72 6e 20 70 4e 65 77 3b 0a 20 20 66 6f 72 28  urn pNew;.  for(
1dc0: 69 3d 30 3b 20 69 3c 4d 58 5f 46 49 4c 45 20 26  i=0; i<MX_FILE &
1dd0: 26 20 67 2e 61 46 69 6c 65 5b 69 5d 2e 73 7a 3e  & g.aFile[i].sz>
1de0: 3d 30 3b 20 69 2b 2b 29 7b 7d 0a 20 20 69 66 28  =0; i++){}.  if(
1df0: 20 69 3e 3d 4d 58 5f 46 49 4c 45 20 29 20 72 65   i>=MX_FILE ) re
1e00: 74 75 72 6e 20 30 3b 0a 20 20 70 4e 65 77 20 3d  turn 0;.  pNew =
1e10: 20 26 67 2e 61 46 69 6c 65 5b 69 5d 3b 0a 20 20   &g.aFile[i];.  
1e20: 69 66 28 20 7a 4e 61 6d 65 20 29 7b 0a 20 20 20  if( zName ){.   
1e30: 20 69 6e 74 20 6e 4e 61 6d 65 20 3d 20 28 69 6e   int nName = (in
1e40: 74 29 73 74 72 6c 65 6e 28 7a 4e 61 6d 65 29 2b  t)strlen(zName)+
1e50: 31 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 7a 46 69  1;.    pNew->zFi
1e60: 6c 65 6e 61 6d 65 20 3d 20 73 61 66 65 5f 72 65  lename = safe_re
1e70: 61 6c 6c 6f 63 28 30 2c 20 6e 4e 61 6d 65 29 3b  alloc(0, nName);
1e80: 0a 20 20 20 20 6d 65 6d 63 70 79 28 70 4e 65 77  .    memcpy(pNew
1e90: 2d 3e 7a 46 69 6c 65 6e 61 6d 65 2c 20 7a 4e 61  ->zFilename, zNa
1ea0: 6d 65 2c 20 6e 4e 61 6d 65 29 3b 0a 20 20 7d 65  me, nName);.  }e
1eb0: 6c 73 65 7b 0a 20 20 20 20 70 4e 65 77 2d 3e 7a  lse{.    pNew->z
1ec0: 46 69 6c 65 6e 61 6d 65 20 3d 20 30 3b 0a 20 20  Filename = 0;.  
1ed0: 7d 0a 20 20 70 4e 65 77 2d 3e 6e 52 65 66 20 3d  }.  pNew->nRef =
1ee0: 20 30 3b 0a 20 20 70 4e 65 77 2d 3e 73 7a 20 3d   0;.  pNew->sz =
1ef0: 20 73 7a 3b 0a 20 20 70 4e 65 77 2d 3e 61 20 3d   sz;.  pNew->a =
1f00: 20 73 61 66 65 5f 72 65 61 6c 6c 6f 63 28 30 2c   safe_realloc(0,
1f10: 20 73 7a 29 3b 0a 20 20 69 66 28 20 73 7a 3e 30   sz);.  if( sz>0
1f20: 20 29 20 6d 65 6d 63 70 79 28 70 4e 65 77 2d 3e   ) memcpy(pNew->
1f30: 61 2c 20 70 44 61 74 61 2c 20 73 7a 29 3b 0a 20  a, pData, sz);. 
1f40: 20 72 65 74 75 72 6e 20 70 4e 65 77 3b 0a 7d 0a   return pNew;.}.
1f50: 0a 0a 2f 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e  ../*.** Implemen
1f60: 74 61 74 69 6f 6e 20 6f 66 20 74 68 65 20 22 72  tation of the "r
1f70: 65 61 64 66 69 6c 65 28 58 29 22 20 53 51 4c 20  eadfile(X)" SQL 
1f80: 66 75 6e 63 74 69 6f 6e 2e 20 20 54 68 65 20 65  function.  The e
1f90: 6e 74 69 72 65 20 63 6f 6e 74 65 6e 74 0a 2a 2a  ntire content.**
1fa0: 20 6f 66 20 74 68 65 20 66 69 6c 65 20 6e 61 6d   of the file nam
1fb0: 65 64 20 58 20 69 73 20 72 65 61 64 20 61 6e 64  ed X is read and
1fc0: 20 72 65 74 75 72 6e 65 64 20 61 73 20 61 20 42   returned as a B
1fd0: 4c 4f 42 2e 20 20 4e 55 4c 4c 20 69 73 20 72 65  LOB.  NULL is re
1fe0: 74 75 72 6e 65 64 0a 2a 2a 20 69 66 20 74 68 65  turned.** if the
1ff0: 20 66 69 6c 65 20 64 6f 65 73 20 6e 6f 74 20 65   file does not e
2000: 78 69 73 74 20 6f 72 20 69 73 20 75 6e 72 65 61  xist or is unrea
2010: 64 61 62 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  dable..*/.static
2020: 20 76 6f 69 64 20 72 65 61 64 66 69 6c 65 46 75   void readfileFu
2030: 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  nc(.  sqlite3_co
2040: 6e 74 65 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a  ntext *context,.
2050: 20 20 69 6e 74 20 61 72 67 63 2c 0a 20 20 73 71    int argc,.  sq
2060: 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72  lite3_value **ar
2070: 67 76 0a 29 7b 0a 20 20 63 6f 6e 73 74 20 63 68  gv.){.  const ch
2080: 61 72 20 2a 7a 4e 61 6d 65 3b 0a 20 20 46 49 4c  ar *zName;.  FIL
2090: 45 20 2a 69 6e 3b 0a 20 20 6c 6f 6e 67 20 6e 49  E *in;.  long nI
20a0: 6e 3b 0a 20 20 76 6f 69 64 20 2a 70 42 75 66 3b  n;.  void *pBuf;
20b0: 0a 0a 20 20 7a 4e 61 6d 65 20 3d 20 28 63 6f 6e  ..  zName = (con
20c0: 73 74 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33  st char*)sqlite3
20d0: 5f 76 61 6c 75 65 5f 74 65 78 74 28 61 72 67 76  _value_text(argv
20e0: 5b 30 5d 29 3b 0a 20 20 69 66 28 20 7a 4e 61 6d  [0]);.  if( zNam
20f0: 65 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 20  e==0 ) return;. 
2100: 20 69 6e 20 3d 20 66 6f 70 65 6e 28 7a 4e 61 6d   in = fopen(zNam
2110: 65 2c 20 22 72 62 22 29 3b 0a 20 20 69 66 28 20  e, "rb");.  if( 
2120: 69 6e 3d 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a  in==0 ) return;.
2130: 20 20 66 73 65 65 6b 28 69 6e 2c 20 30 2c 20 53    fseek(in, 0, S
2140: 45 45 4b 5f 45 4e 44 29 3b 0a 20 20 6e 49 6e 20  EEK_END);.  nIn 
2150: 3d 20 66 74 65 6c 6c 28 69 6e 29 3b 0a 20 20 72  = ftell(in);.  r
2160: 65 77 69 6e 64 28 69 6e 29 3b 0a 20 20 70 42 75  ewind(in);.  pBu
2170: 66 20 3d 20 73 71 6c 69 74 65 33 5f 6d 61 6c 6c  f = sqlite3_mall
2180: 6f 63 36 34 28 20 6e 49 6e 20 29 3b 0a 20 20 69  oc64( nIn );.  i
2190: 66 28 20 70 42 75 66 20 26 26 20 31 3d 3d 66 72  f( pBuf && 1==fr
21a0: 65 61 64 28 70 42 75 66 2c 20 6e 49 6e 2c 20 31  ead(pBuf, nIn, 1
21b0: 2c 20 69 6e 29 20 29 7b 0a 20 20 20 20 73 71 6c  , in) ){.    sql
21c0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 62 6c 6f 62  ite3_result_blob
21d0: 28 63 6f 6e 74 65 78 74 2c 20 70 42 75 66 2c 20  (context, pBuf, 
21e0: 6e 49 6e 2c 20 73 71 6c 69 74 65 33 5f 66 72 65  nIn, sqlite3_fre
21f0: 65 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  e);.  }else{.   
2200: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70 42   sqlite3_free(pB
2210: 75 66 29 3b 0a 20 20 7d 0a 20 20 66 63 6c 6f 73  uf);.  }.  fclos
2220: 65 28 69 6e 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  e(in);.}../*.** 
2230: 49 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f  Implementation o
2240: 66 20 74 68 65 20 22 77 72 69 74 65 66 69 6c 65  f the "writefile
2250: 28 58 2c 59 29 22 20 53 51 4c 20 66 75 6e 63 74  (X,Y)" SQL funct
2260: 69 6f 6e 2e 20 20 54 68 65 20 61 72 67 75 6d 65  ion.  The argume
2270: 6e 74 20 59 0a 2a 2a 20 69 73 20 77 72 69 74 74  nt Y.** is writt
2280: 65 6e 20 69 6e 74 6f 20 66 69 6c 65 20 58 2e 20  en into file X. 
2290: 20 54 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 62   The number of b
22a0: 79 74 65 73 20 77 72 69 74 74 65 6e 20 69 73 20  ytes written is 
22b0: 72 65 74 75 72 6e 65 64 2e 20 20 4f 72 0a 2a 2a  returned.  Or.**
22c0: 20 4e 55 4c 4c 20 69 73 20 72 65 74 75 72 6e 65   NULL is returne
22d0: 64 20 69 66 20 73 6f 6d 65 74 68 69 6e 67 20 67  d if something g
22e0: 6f 65 73 20 77 72 6f 6e 67 2c 20 73 75 63 68 20  oes wrong, such 
22f0: 61 73 20 62 65 69 6e 67 20 75 6e 61 62 6c 65 20  as being unable 
2300: 74 6f 20 6f 70 65 6e 0a 2a 2a 20 66 69 6c 65 20  to open.** file 
2310: 58 20 66 6f 72 20 77 72 69 74 69 6e 67 2e 0a 2a  X for writing..*
2320: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 77 72  /.static void wr
2330: 69 74 65 66 69 6c 65 46 75 6e 63 28 0a 20 20 73  itefileFunc(.  s
2340: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
2350: 63 6f 6e 74 65 78 74 2c 0a 20 20 69 6e 74 20 61  context,.  int a
2360: 72 67 63 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76  rgc,.  sqlite3_v
2370: 61 6c 75 65 20 2a 2a 61 72 67 76 0a 29 7b 0a 20  alue **argv.){. 
2380: 20 46 49 4c 45 20 2a 6f 75 74 3b 0a 20 20 63 6f   FILE *out;.  co
2390: 6e 73 74 20 63 68 61 72 20 2a 7a 3b 0a 20 20 73  nst char *z;.  s
23a0: 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 72 63 3b  qlite3_int64 rc;
23b0: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
23c0: 46 69 6c 65 3b 0a 0a 20 20 28 76 6f 69 64 29 61  File;..  (void)a
23d0: 72 67 63 3b 0a 20 20 7a 46 69 6c 65 20 3d 20 28  rgc;.  zFile = (
23e0: 63 6f 6e 73 74 20 63 68 61 72 2a 29 73 71 6c 69  const char*)sqli
23f0: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 28 61  te3_value_text(a
2400: 72 67 76 5b 30 5d 29 3b 0a 20 20 69 66 28 20 7a  rgv[0]);.  if( z
2410: 46 69 6c 65 3d 3d 30 20 29 20 72 65 74 75 72 6e  File==0 ) return
2420: 3b 0a 20 20 6f 75 74 20 3d 20 66 6f 70 65 6e 28  ;.  out = fopen(
2430: 7a 46 69 6c 65 2c 20 22 77 62 22 29 3b 0a 20 20  zFile, "wb");.  
2440: 69 66 28 20 6f 75 74 3d 3d 30 20 29 20 72 65 74  if( out==0 ) ret
2450: 75 72 6e 3b 0a 20 20 7a 20 3d 20 28 63 6f 6e 73  urn;.  z = (cons
2460: 74 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33 5f  t char*)sqlite3_
2470: 76 61 6c 75 65 5f 62 6c 6f 62 28 61 72 67 76 5b  value_blob(argv[
2480: 31 5d 29 3b 0a 20 20 69 66 28 20 7a 3d 3d 30 20  1]);.  if( z==0 
2490: 29 7b 0a 20 20 20 20 72 63 20 3d 20 30 3b 0a 20  ){.    rc = 0;. 
24a0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 72 63 20 3d   }else{.    rc =
24b0: 20 66 77 72 69 74 65 28 7a 2c 20 31 2c 20 73 71   fwrite(z, 1, sq
24c0: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 79 74 65  lite3_value_byte
24d0: 73 28 61 72 67 76 5b 31 5d 29 2c 20 6f 75 74 29  s(argv[1]), out)
24e0: 3b 0a 20 20 7d 0a 20 20 66 63 6c 6f 73 65 28 6f  ;.  }.  fclose(o
24f0: 75 74 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 72  ut);.  sqlite3_r
2500: 65 73 75 6c 74 5f 69 6e 74 36 34 28 63 6f 6e 74  esult_int64(cont
2510: 65 78 74 2c 20 72 63 29 3b 0a 7d 0a 0a 0a 2f 2a  ext, rc);.}.../*
2520: 0a 2a 2a 20 4c 6f 61 64 20 61 20 6c 69 73 74 20  .** Load a list 
2530: 6f 66 20 42 6c 6f 62 20 6f 62 6a 65 63 74 73 20  of Blob objects 
2540: 66 72 6f 6d 20 74 68 65 20 64 61 74 61 62 61 73  from the databas
2550: 65 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  e.*/.static void
2560: 20 62 6c 6f 62 4c 69 73 74 4c 6f 61 64 46 72 6f   blobListLoadFro
2570: 6d 44 62 28 0a 20 20 73 71 6c 69 74 65 33 20 2a  mDb(.  sqlite3 *
2580: 64 62 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  db,             
2590: 2f 2a 20 52 65 61 64 20 66 72 6f 6d 20 74 68 69  /* Read from thi
25a0: 73 20 64 61 74 61 62 61 73 65 20 2a 2f 0a 20 20  s database */.  
25b0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53 71 6c  const char *zSql
25c0: 2c 20 20 20 20 20 20 20 20 2f 2a 20 51 75 65 72  ,        /* Quer
25d0: 79 20 75 73 65 64 20 74 6f 20 65 78 74 72 61 63  y used to extrac
25e0: 74 20 74 68 65 20 62 6c 6f 62 73 20 2a 2f 0a 20  t the blobs */. 
25f0: 20 69 6e 74 20 6f 6e 6c 79 49 64 2c 20 20 20 20   int onlyId,    
2600: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 6e 6c            /* Onl
2610: 79 20 6c 6f 61 64 20 77 68 65 72 65 20 69 64 20  y load where id 
2620: 69 73 20 74 68 69 73 20 76 61 6c 75 65 20 2a 2f  is this value */
2630: 0a 20 20 69 6e 74 20 2a 70 4e 2c 20 20 20 20 20  .  int *pN,     
2640: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4f              /* O
2650: 55 54 3a 20 57 72 69 74 65 20 6e 75 6d 62 65 72  UT: Write number
2660: 20 6f 66 20 62 6c 6f 62 73 20 6c 6f 61 64 65 64   of blobs loaded
2670: 20 68 65 72 65 20 2a 2f 0a 20 20 42 6c 6f 62 20   here */.  Blob 
2680: 2a 2a 70 70 4c 69 73 74 20 20 20 20 20 20 20 20  **ppList        
2690: 20 20 20 20 2f 2a 20 4f 55 54 3a 20 57 72 69 74      /* OUT: Writ
26a0: 65 20 74 68 65 20 68 65 61 64 20 6f 66 20 74 68  e the head of th
26b0: 65 20 62 6c 6f 62 20 6c 69 73 74 20 68 65 72 65  e blob list here
26c0: 20 2a 2f 0a 29 7b 0a 20 20 42 6c 6f 62 20 68 65   */.){.  Blob he
26d0: 61 64 3b 0a 20 20 42 6c 6f 62 20 2a 70 3b 0a 20  ad;.  Blob *p;. 
26e0: 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70   sqlite3_stmt *p
26f0: 53 74 6d 74 3b 0a 20 20 69 6e 74 20 6e 20 3d 20  Stmt;.  int n = 
2700: 30 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 63  0;.  int rc;.  c
2710: 68 61 72 20 2a 7a 32 3b 0a 0a 20 20 69 66 28 20  har *z2;..  if( 
2720: 6f 6e 6c 79 49 64 3e 30 20 29 7b 0a 20 20 20 20  onlyId>0 ){.    
2730: 7a 32 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72  z2 = sqlite3_mpr
2740: 69 6e 74 66 28 22 25 73 20 57 48 45 52 45 20 72  intf("%s WHERE r
2750: 6f 77 69 64 3d 25 64 22 2c 20 7a 53 71 6c 2c 20  owid=%d", zSql, 
2760: 6f 6e 6c 79 49 64 29 3b 0a 20 20 7d 65 6c 73 65  onlyId);.  }else
2770: 7b 0a 20 20 20 20 7a 32 20 3d 20 73 71 6c 69 74  {.    z2 = sqlit
2780: 65 33 5f 6d 70 72 69 6e 74 66 28 22 25 73 22 2c  e3_mprintf("%s",
2790: 20 7a 53 71 6c 29 3b 0a 20 20 7d 0a 20 20 72 63   zSql);.  }.  rc
27a0: 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61   = sqlite3_prepa
27b0: 72 65 5f 76 32 28 64 62 2c 20 7a 32 2c 20 2d 31  re_v2(db, z2, -1
27c0: 2c 20 26 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20  , &pStmt, 0);.  
27d0: 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a 32 29  sqlite3_free(z2)
27e0: 3b 0a 20 20 69 66 28 20 72 63 20 29 20 66 61 74  ;.  if( rc ) fat
27f0: 61 6c 45 72 72 6f 72 28 22 25 73 22 2c 20 73 71  alError("%s", sq
2800: 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29  lite3_errmsg(db)
2810: 29 3b 0a 20 20 68 65 61 64 2e 70 4e 65 78 74 20  );.  head.pNext 
2820: 3d 20 30 3b 0a 20 20 70 20 3d 20 26 68 65 61 64  = 0;.  p = &head
2830: 3b 0a 20 20 77 68 69 6c 65 28 20 53 51 4c 49 54  ;.  while( SQLIT
2840: 45 5f 52 4f 57 3d 3d 73 71 6c 69 74 65 33 5f 73  E_ROW==sqlite3_s
2850: 74 65 70 28 70 53 74 6d 74 29 20 29 7b 0a 20 20  tep(pStmt) ){.  
2860: 20 20 69 6e 74 20 73 7a 20 3d 20 73 71 6c 69 74    int sz = sqlit
2870: 65 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 28  e3_column_bytes(
2880: 70 53 74 6d 74 2c 20 31 29 3b 0a 20 20 20 20 42  pStmt, 1);.    B
2890: 6c 6f 62 20 2a 70 4e 65 77 20 3d 20 73 61 66 65  lob *pNew = safe
28a0: 5f 72 65 61 6c 6c 6f 63 28 30 2c 20 73 69 7a 65  _realloc(0, size
28b0: 6f 66 28 2a 70 4e 65 77 29 2b 73 7a 20 29 3b 0a  of(*pNew)+sz );.
28c0: 20 20 20 20 70 4e 65 77 2d 3e 69 64 20 3d 20 73      pNew->id = s
28d0: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e  qlite3_column_in
28e0: 74 28 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20 20  t(pStmt, 0);.   
28f0: 20 70 4e 65 77 2d 3e 73 7a 20 3d 20 73 7a 3b 0a   pNew->sz = sz;.
2900: 20 20 20 20 70 4e 65 77 2d 3e 73 65 71 20 3d 20      pNew->seq = 
2910: 6e 2b 2b 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 70  n++;.    pNew->p
2920: 4e 65 78 74 20 3d 20 30 3b 0a 20 20 20 20 6d 65  Next = 0;.    me
2930: 6d 63 70 79 28 70 4e 65 77 2d 3e 61 2c 20 73 71  mcpy(pNew->a, sq
2940: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 6c 6f  lite3_column_blo
2950: 62 28 70 53 74 6d 74 2c 31 29 2c 20 73 7a 29 3b  b(pStmt,1), sz);
2960: 0a 20 20 20 20 70 4e 65 77 2d 3e 61 5b 73 7a 5d  .    pNew->a[sz]
2970: 20 3d 20 30 3b 0a 20 20 20 20 70 2d 3e 70 4e 65   = 0;.    p->pNe
2980: 78 74 20 3d 20 70 4e 65 77 3b 0a 20 20 20 20 70  xt = pNew;.    p
2990: 20 3d 20 70 4e 65 77 3b 0a 20 20 7d 0a 20 20 73   = pNew;.  }.  s
29a0: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28  qlite3_finalize(
29b0: 70 53 74 6d 74 29 3b 0a 20 20 2a 70 4e 20 3d 20  pStmt);.  *pN = 
29c0: 6e 3b 0a 20 20 2a 70 70 4c 69 73 74 20 3d 20 68  n;.  *ppList = h
29d0: 65 61 64 2e 70 4e 65 78 74 3b 0a 7d 0a 0a 2f 2a  ead.pNext;.}../*
29e0: 0a 2a 2a 20 46 72 65 65 20 61 20 6c 69 73 74 20  .** Free a list 
29f0: 6f 66 20 42 6c 6f 62 20 6f 62 6a 65 63 74 73 0a  of Blob objects.
2a00: 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 62  */.static void b
2a10: 6c 6f 62 4c 69 73 74 46 72 65 65 28 42 6c 6f 62  lobListFree(Blob
2a20: 20 2a 70 29 7b 0a 20 20 42 6c 6f 62 20 2a 70 4e   *p){.  Blob *pN
2a30: 65 78 74 3b 0a 20 20 77 68 69 6c 65 28 20 70 20  ext;.  while( p 
2a40: 29 7b 0a 20 20 20 20 70 4e 65 78 74 20 3d 20 70  ){.    pNext = p
2a50: 2d 3e 70 4e 65 78 74 3b 0a 20 20 20 20 66 72 65  ->pNext;.    fre
2a60: 65 28 70 29 3b 0a 20 20 20 20 70 20 3d 20 70 4e  e(p);.    p = pN
2a70: 65 78 74 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 20 52  ext;.  }.}../* R
2a80: 65 74 75 72 6e 20 74 68 65 20 63 75 72 72 65 6e  eturn the curren
2a90: 74 20 77 61 6c 6c 2d 63 6c 6f 63 6b 20 74 69 6d  t wall-clock tim
2aa0: 65 20 2a 2f 0a 73 74 61 74 69 63 20 73 71 6c 69  e */.static sqli
2ab0: 74 65 33 5f 69 6e 74 36 34 20 74 69 6d 65 4f 66  te3_int64 timeOf
2ac0: 44 61 79 28 76 6f 69 64 29 7b 0a 20 20 73 74 61  Day(void){.  sta
2ad0: 74 69 63 20 73 71 6c 69 74 65 33 5f 76 66 73 20  tic sqlite3_vfs 
2ae0: 2a 63 6c 6f 63 6b 56 66 73 20 3d 20 30 3b 0a 20  *clockVfs = 0;. 
2af0: 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 74   sqlite3_int64 t
2b00: 3b 0a 20 20 69 66 28 20 63 6c 6f 63 6b 56 66 73  ;.  if( clockVfs
2b10: 3d 3d 30 20 29 7b 0a 20 20 20 20 63 6c 6f 63 6b  ==0 ){.    clock
2b20: 56 66 73 20 3d 20 73 71 6c 69 74 65 33 5f 76 66  Vfs = sqlite3_vf
2b30: 73 5f 66 69 6e 64 28 30 29 3b 0a 20 20 20 20 69  s_find(0);.    i
2b40: 66 28 20 63 6c 6f 63 6b 56 66 73 3d 3d 30 20 29  f( clockVfs==0 )
2b50: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20   return 0;.  }. 
2b60: 20 69 66 28 20 63 6c 6f 63 6b 56 66 73 2d 3e 69   if( clockVfs->i
2b70: 56 65 72 73 69 6f 6e 3e 3d 31 20 26 26 20 63 6c  Version>=1 && cl
2b80: 6f 63 6b 56 66 73 2d 3e 78 43 75 72 72 65 6e 74  ockVfs->xCurrent
2b90: 54 69 6d 65 49 6e 74 36 34 21 3d 30 20 29 7b 0a  TimeInt64!=0 ){.
2ba0: 20 20 20 20 63 6c 6f 63 6b 56 66 73 2d 3e 78 43      clockVfs->xC
2bb0: 75 72 72 65 6e 74 54 69 6d 65 49 6e 74 36 34 28  urrentTimeInt64(
2bc0: 63 6c 6f 63 6b 56 66 73 2c 20 26 74 29 3b 0a 20  clockVfs, &t);. 
2bd0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 64 6f 75 62   }else{.    doub
2be0: 6c 65 20 72 3b 0a 20 20 20 20 63 6c 6f 63 6b 56  le r;.    clockV
2bf0: 66 73 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d 65  fs->xCurrentTime
2c00: 28 63 6c 6f 63 6b 56 66 73 2c 20 26 72 29 3b 0a  (clockVfs, &r);.
2c10: 20 20 20 20 74 20 3d 20 28 73 71 6c 69 74 65 33      t = (sqlite3
2c20: 5f 69 6e 74 36 34 29 28 72 2a 38 36 34 30 30 30  _int64)(r*864000
2c30: 30 30 2e 30 29 3b 0a 20 20 7d 0a 20 20 72 65 74  00.0);.  }.  ret
2c40: 75 72 6e 20 74 3b 0a 7d 0a 0a 2f 2a 2a 2a 2a 2a  urn t;.}../*****
2c50: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
2c60: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
2c70: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
2c80: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
2c90: 2a 2a 2a 2a 2a 2a 0a 2a 2a 20 43 6f 64 65 20 74  ******.** Code t
2ca0: 6f 20 70 72 6f 63 65 73 73 20 63 6f 6d 62 69 6e  o process combin
2cb0: 65 64 20 64 61 74 61 62 61 73 65 2b 53 51 4c 20  ed database+SQL 
2cc0: 73 63 72 69 70 74 73 20 67 65 6e 65 72 61 74 65  scripts generate
2cd0: 64 20 62 79 20 74 68 65 0a 2a 2a 20 64 62 73 71  d by the.** dbsq
2ce0: 6c 66 75 7a 7a 20 66 75 7a 7a 65 72 2e 0a 2a 2f  lfuzz fuzzer..*/
2cf0: 0a 0a 2f 2a 20 41 6e 20 69 6e 73 74 61 6e 63 65  ../* An instance
2d00: 20 6f 66 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e   of the followin
2d10: 67 20 6f 62 6a 65 63 74 20 69 73 20 70 61 73 73  g object is pass
2d20: 65 64 20 62 79 20 70 6f 69 6e 74 65 72 20 61 73  ed by pointer as
2d30: 20 74 68 65 0a 2a 2a 20 63 6c 69 65 6e 74 20 64   the.** client d
2d40: 61 74 61 20 74 6f 20 76 61 72 69 6f 75 73 20 63  ata to various c
2d50: 61 6c 6c 62 61 63 6b 73 2e 0a 2a 2f 0a 74 79 70  allbacks..*/.typ
2d60: 65 64 65 66 20 73 74 72 75 63 74 20 46 75 7a 7a  edef struct Fuzz
2d70: 43 74 78 20 7b 0a 20 20 73 71 6c 69 74 65 33 20  Ctx {.  sqlite3 
2d80: 2a 64 62 3b 20 20 20 20 20 20 20 20 20 20 20 20  *db;            
2d90: 20 20 20 2f 2a 20 54 68 65 20 64 61 74 61 62 61     /* The databa
2da0: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f  se connection */
2db0: 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34  .  sqlite3_int64
2dc0: 20 69 43 75 74 6f 66 66 54 69 6d 65 3b 20 2f 2a   iCutoffTime; /*
2dd0: 20 53 74 6f 70 20 70 72 6f 63 65 73 73 69 6e 67   Stop processing
2de0: 20 61 74 20 74 68 69 73 20 74 69 6d 65 2e 20 2a   at this time. *
2df0: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36  /.  sqlite3_int6
2e00: 34 20 69 4c 61 73 74 43 62 3b 20 20 20 20 20 2f  4 iLastCb;     /
2e10: 2a 20 54 69 6d 65 20 72 65 63 6f 72 64 65 64 20  * Time recorded 
2e20: 66 6f 72 20 70 72 65 76 69 6f 75 73 20 70 72 6f  for previous pro
2e30: 67 72 65 73 73 20 63 61 6c 6c 62 61 63 6b 20 2a  gress callback *
2e40: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36  /.  sqlite3_int6
2e50: 34 20 6d 78 49 6e 74 65 72 76 61 6c 3b 20 20 2f  4 mxInterval;  /
2e60: 2a 20 4c 6f 6e 67 65 73 74 20 69 6e 74 65 72 76  * Longest interv
2e70: 61 6c 20 62 65 74 77 65 65 6e 20 74 77 6f 20 70  al between two p
2e80: 72 6f 67 72 65 73 73 20 63 61 6c 6c 73 20 2a 2f  rogress calls */
2e90: 0a 20 20 75 6e 73 69 67 6e 65 64 20 6e 43 62 3b  .  unsigned nCb;
2ea0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
2eb0: 20 4e 75 6d 62 65 72 20 6f 66 20 70 72 6f 67 72   Number of progr
2ec0: 65 73 73 20 63 61 6c 6c 62 61 63 6b 73 20 2a 2f  ess callbacks */
2ed0: 0a 20 20 75 6e 73 69 67 6e 65 64 20 6d 78 43 62  .  unsigned mxCb
2ee0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ;             /*
2ef0: 20 4d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72 20   Maximum number 
2f00: 6f 66 20 70 72 6f 67 72 65 73 73 20 63 61 6c 6c  of progress call
2f10: 62 61 63 6b 73 20 61 6c 6c 6f 77 65 64 20 2a 2f  backs allowed */
2f20: 0a 20 20 75 6e 73 69 67 6e 65 64 20 65 78 65 63  .  unsigned exec
2f30: 43 6e 74 3b 20 20 20 20 20 20 20 20 20 20 2f 2a  Cnt;          /*
2f40: 20 4e 75 6d 62 65 72 20 6f 66 20 63 61 6c 6c 73   Number of calls
2f50: 20 74 6f 20 74 68 65 20 73 71 6c 69 74 65 33 5f   to the sqlite3_
2f60: 65 78 65 63 20 63 61 6c 6c 62 61 63 6b 20 2a 2f  exec callback */
2f70: 0a 20 20 69 6e 74 20 74 69 6d 65 6f 75 74 48 69  .  int timeoutHi
2f80: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  t;            /*
2f90: 20 54 72 75 65 20 77 68 65 6e 20 72 65 61 63 68   True when reach
2fa0: 69 6e 67 20 61 20 74 69 6d 65 6f 75 74 20 2a 2f  ing a timeout */
2fb0: 0a 7d 20 46 75 7a 7a 43 74 78 3b 0a 0a 2f 2a 20  .} FuzzCtx;../* 
2fc0: 56 65 72 62 6f 73 69 74 79 20 6c 65 76 65 6c 20  Verbosity level 
2fd0: 66 6f 72 20 74 68 65 20 64 62 73 71 6c 66 75 7a  for the dbsqlfuz
2fe0: 7a 20 74 65 73 74 20 72 75 6e 6e 65 72 20 2a 2f  z test runner */
2ff0: 0a 73 74 61 74 69 63 20 69 6e 74 20 65 56 65 72  .static int eVer
3000: 62 6f 73 69 74 79 20 3d 20 30 3b 0a 0a 2f 2a 20  bosity = 0;../* 
3010: 54 72 75 65 20 74 6f 20 61 63 74 69 76 61 74 65  True to activate
3020: 20 50 52 41 47 4d 41 20 76 64 62 65 5f 64 65 62   PRAGMA vdbe_deb
3030: 75 67 3d 6f 6e 20 2a 2f 0a 73 74 61 74 69 63 20  ug=on */.static 
3040: 69 6e 74 20 62 56 64 62 65 44 65 62 75 67 20 3d  int bVdbeDebug =
3050: 20 30 3b 0a 0a 2f 2a 20 54 69 6d 65 6f 75 74 20   0;../* Timeout 
3060: 66 6f 72 20 65 61 63 68 20 66 75 7a 7a 69 6e 67  for each fuzzing
3070: 20 61 74 74 65 6d 70 74 2c 20 69 6e 20 6d 69 6c   attempt, in mil
3080: 6c 69 73 65 63 6f 6e 64 73 20 2a 2f 0a 73 74 61  liseconds */.sta
3090: 74 69 63 20 69 6e 74 20 67 69 54 69 6d 65 6f 75  tic int giTimeou
30a0: 74 20 3d 20 31 30 30 30 30 3b 20 20 20 2f 2a 20  t = 10000;   /* 
30b0: 44 65 66 61 75 6c 74 73 20 74 6f 20 31 30 20 73  Defaults to 10 s
30c0: 65 63 6f 6e 64 73 20 2a 2f 0a 0a 2f 2a 20 4d 61  econds */../* Ma
30d0: 78 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20  ximum number of 
30e0: 70 72 6f 67 72 65 73 73 20 68 61 6e 64 6c 65 72  progress handler
30f0: 20 63 61 6c 6c 62 61 63 6b 73 20 2a 2f 0a 73 74   callbacks */.st
3100: 61 74 69 63 20 75 6e 73 69 67 6e 65 64 20 69 6e  atic unsigned in
3110: 74 20 6d 78 50 72 6f 67 72 65 73 73 43 62 20 3d  t mxProgressCb =
3120: 20 32 30 30 30 3b 0a 0a 2f 2a 20 4d 61 78 69 6d   2000;../* Maxim
3130: 75 6d 20 73 74 72 69 6e 67 20 6c 65 6e 67 74 68  um string length
3140: 20 69 6e 20 53 51 4c 69 74 65 20 2a 2f 0a 73 74   in SQLite */.st
3150: 61 74 69 63 20 69 6e 74 20 6c 65 6e 67 74 68 4c  atic int lengthL
3160: 69 6d 69 74 20 3d 20 31 30 30 30 30 30 30 3b 0a  imit = 1000000;.
3170: 0a 2f 2a 20 4d 61 78 69 6d 75 6d 20 62 79 74 65  ./* Maximum byte
3180: 2d 63 6f 64 65 20 70 72 6f 67 72 61 6d 20 6c 65  -code program le
3190: 6e 67 74 68 20 69 6e 20 53 51 4c 69 74 65 20 2a  ngth in SQLite *
31a0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76 64 62  /.static int vdb
31b0: 65 4f 70 4c 69 6d 69 74 20 3d 20 32 35 30 30 30  eOpLimit = 25000
31c0: 3b 0a 0a 2f 2a 20 4d 61 78 69 6d 75 6d 20 73 69  ;../* Maximum si
31d0: 7a 65 20 6f 66 20 74 68 65 20 69 6e 2d 6d 65 6d  ze of the in-mem
31e0: 6f 72 79 20 64 61 74 61 62 61 73 65 20 2a 2f 0a  ory database */.
31f0: 73 74 61 74 69 63 20 73 71 6c 69 74 65 33 5f 69  static sqlite3_i
3200: 6e 74 36 34 20 6d 61 78 44 62 53 69 7a 65 20 3d  nt64 maxDbSize =
3210: 20 31 30 34 38 35 37 36 30 30 3b 0a 0a 2f 2a 0a   104857600;../*.
3220: 2a 2a 20 54 72 61 6e 73 6c 61 74 65 20 61 20 73  ** Translate a s
3230: 69 6e 67 6c 65 20 62 79 74 65 20 6f 66 20 48 65  ingle byte of He
3240: 78 20 69 6e 74 6f 20 61 6e 20 69 6e 74 65 67 65  x into an intege
3250: 72 2e 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69  r..** This routi
3260: 6e 65 20 6f 6e 6c 79 20 77 6f 72 6b 73 20 69 66  ne only works if
3270: 20 68 20 72 65 61 6c 6c 79 20 69 73 20 61 20 76   h really is a v
3280: 61 6c 69 64 20 68 65 78 61 64 65 63 69 6d 61 6c  alid hexadecimal
3290: 0a 2a 2a 20 63 68 61 72 61 63 74 65 72 3a 20 20  .** character:  
32a0: 30 2e 2e 39 61 2e 2e 66 41 2e 2e 46 0a 2a 2f 0a  0..9a..fA..F.*/.
32b0: 73 74 61 74 69 63 20 75 6e 73 69 67 6e 65 64 20  static unsigned 
32c0: 63 68 61 72 20 68 65 78 54 6f 49 6e 74 28 75 6e  char hexToInt(un
32d0: 73 69 67 6e 65 64 20 69 6e 74 20 68 29 7b 0a 23  signed int h){.#
32e0: 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45 42 43  ifdef SQLITE_EBC
32f0: 44 49 43 0a 20 20 68 20 2b 3d 20 39 2a 28 31 26  DIC.  h += 9*(1&
3300: 7e 28 68 3e 3e 34 29 29 3b 20 20 20 2f 2a 20 45  ~(h>>4));   /* E
3310: 42 43 44 49 43 20 2a 2f 0a 23 65 6c 73 65 0a 20  BCDIC */.#else. 
3320: 20 68 20 2b 3d 20 39 2a 28 31 26 28 68 3e 3e 36   h += 9*(1&(h>>6
3330: 29 29 3b 20 20 20 20 2f 2a 20 41 53 43 49 49 20  ));    /* ASCII 
3340: 2a 2f 0a 23 65 6e 64 69 66 0a 20 20 72 65 74 75  */.#endif.  retu
3350: 72 6e 20 68 20 26 20 30 78 66 3b 0a 7d 0a 0a 2f  rn h & 0xf;.}../
3360: 2a 0a 2a 2a 20 54 68 65 20 66 69 72 73 74 20 63  *.** The first c
3370: 68 61 72 61 63 74 65 72 20 6f 66 20 62 75 66 66  haracter of buff
3380: 65 72 20 7a 49 6e 5b 30 2e 2e 6e 49 6e 2d 31 5d  er zIn[0..nIn-1]
3390: 20 69 73 20 61 20 27 5b 27 2e 20 20 54 68 69 73   is a '['.  This
33a0: 20 72 6f 75 74 69 6e 65 0a 2a 2a 20 63 68 65 63   routine.** chec
33b0: 6b 65 64 20 74 6f 20 73 65 65 20 69 66 20 74 68  ked to see if th
33c0: 65 20 62 75 66 66 65 72 20 68 6f 6c 64 73 20 22  e buffer holds "
33d0: 5b 4e 4e 4e 4e 5d 22 20 6f 72 20 22 5b 2b 4e 4e  [NNNN]" or "[+NN
33e0: 4e 4e 5d 22 20 61 6e 64 20 69 66 20 69 74 0a 2a  NN]" and if it.*
33f0: 2a 20 64 6f 65 73 20 69 74 20 6d 61 6b 65 73 20  * does it makes 
3400: 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 63 68  corresponding ch
3410: 61 6e 67 65 73 20 74 6f 20 74 68 65 20 2a 70 4b  anges to the *pK
3420: 20 76 61 6c 75 65 20 61 6e 64 20 2a 70 49 20 76   value and *pI v
3430: 61 6c 75 65 0a 2a 2a 20 61 6e 64 20 72 65 74 75  alue.** and retu
3440: 72 6e 73 20 74 72 75 65 2e 20 20 49 66 20 74 68  rns true.  If th
3450: 65 20 69 6e 70 75 74 20 62 75 66 66 65 72 20 64  e input buffer d
3460: 6f 65 73 20 6e 6f 74 20 6d 61 74 63 68 20 74 68  oes not match th
3470: 65 20 70 61 74 74 65 72 6e 73 2c 0a 2a 2a 20 6e  e patterns,.** n
3480: 6f 20 63 68 61 6e 67 65 73 20 61 72 65 20 6d 61  o changes are ma
3490: 64 65 20 74 6f 20 65 69 74 68 65 72 20 2a 70 4b  de to either *pK
34a0: 20 6f 72 20 2a 70 49 20 61 6e 64 20 74 68 69 73   or *pI and this
34b0: 20 72 6f 75 74 69 6e 65 20 72 65 74 75 72 6e 73   routine returns
34c0: 20 66 61 6c 73 65 2e 0a 2a 2f 0a 73 74 61 74 69   false..*/.stati
34d0: 63 20 69 6e 74 20 69 73 4f 66 66 73 65 74 28 0a  c int isOffset(.
34e0: 20 20 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64    const unsigned
34f0: 20 63 68 61 72 20 2a 7a 49 6e 2c 20 20 2f 2a 20   char *zIn,  /* 
3500: 54 65 78 74 20 69 6e 70 75 74 20 2a 2f 0a 20 20  Text input */.  
3510: 69 6e 74 20 6e 49 6e 2c 20 20 20 20 20 20 20 20  int nIn,        
3520: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 42 79             /* By
3530: 74 65 73 20 6f 66 20 69 6e 70 75 74 20 2a 2f 0a  tes of input */.
3540: 20 20 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 2a    unsigned int *
3550: 70 4b 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20  pK,          /* 
3560: 68 61 6c 66 2d 62 79 74 65 20 63 75 72 73 6f 72  half-byte cursor
3570: 20 74 6f 20 61 64 6a 75 73 74 20 2a 2f 0a 20 20   to adjust */.  
3580: 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 2a 70 49  unsigned int *pI
3590: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 6e             /* In
35a0: 70 75 74 20 69 6e 64 65 78 20 74 6f 20 61 64 6a  put index to adj
35b0: 75 73 74 20 2a 2f 0a 29 7b 0a 20 20 69 6e 74 20  ust */.){.  int 
35c0: 69 3b 0a 20 20 75 6e 73 69 67 6e 65 64 20 69 6e  i;.  unsigned in
35d0: 74 20 6b 20 3d 20 30 3b 0a 20 20 75 6e 73 69 67  t k = 0;.  unsig
35e0: 6e 65 64 20 63 68 61 72 20 63 3b 0a 20 20 66 6f  ned char c;.  fo
35f0: 72 28 69 3d 31 3b 20 69 3c 6e 49 6e 20 26 26 20  r(i=1; i<nIn && 
3600: 28 63 20 3d 20 7a 49 6e 5b 69 5d 29 21 3d 27 5d  (c = zIn[i])!=']
3610: 27 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28  '; i++){.    if(
3620: 20 21 69 73 78 64 69 67 69 74 28 63 29 20 29 20   !isxdigit(c) ) 
3630: 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 6b 20  return 0;.    k 
3640: 3d 20 6b 2a 31 36 20 2b 20 68 65 78 54 6f 49 6e  = k*16 + hexToIn
3650: 74 28 63 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20  t(c);.  }.  if( 
3660: 69 3d 3d 6e 49 6e 20 29 20 72 65 74 75 72 6e 20  i==nIn ) return 
3670: 30 3b 0a 20 20 2a 70 4b 20 3d 20 32 2a 6b 3b 0a  0;.  *pK = 2*k;.
3680: 20 20 2a 70 49 20 2b 3d 20 69 3b 0a 20 20 72 65    *pI += i;.  re
3690: 74 75 72 6e 20 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  turn 1;.}../*.**
36a0: 20 44 65 63 6f 64 65 20 74 68 65 20 74 65 78 74   Decode the text
36b0: 20 73 74 61 72 74 69 6e 67 20 61 74 20 7a 49 6e   starting at zIn
36c0: 20 69 6e 74 6f 20 61 20 62 69 6e 61 72 79 20 64   into a binary d
36d0: 61 74 61 62 61 73 65 20 66 69 6c 65 2e 0a 2a 2a  atabase file..**
36e0: 20 54 68 65 20 6d 61 78 69 6d 75 6d 20 6c 65 6e   The maximum len
36f0: 67 74 68 20 6f 66 20 7a 49 6e 20 69 73 20 6e 49  gth of zIn is nI
3700: 6e 20 62 79 74 65 73 2e 20 20 43 6f 6d 70 75 74  n bytes.  Comput
3710: 65 20 74 68 65 20 62 69 6e 61 72 79 20 64 61 74  e the binary dat
3720: 61 62 61 73 65 0a 2a 2a 20 66 69 6c 65 20 63 6f  abase.** file co
3730: 6e 74 61 69 6e 20 69 6e 20 73 70 61 63 65 20 6f  ntain in space o
3740: 62 74 61 69 6e 65 64 20 66 72 6f 6d 20 73 71 6c  btained from sql
3750: 69 74 65 33 5f 6d 61 6c 6c 6f 63 28 29 2e 0a 2a  ite3_malloc()..*
3760: 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20  *.** Return the 
3770: 6e 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20  number of bytes 
3780: 6f 66 20 7a 49 6e 20 63 6f 6e 73 75 6d 65 64 2e  of zIn consumed.
3790: 20 20 4f 72 20 72 65 74 75 72 6e 20 2d 31 20 69    Or return -1 i
37a0: 66 20 74 68 65 72 65 0a 2a 2a 20 69 73 20 61 6e  f there.** is an
37b0: 20 65 72 72 6f 72 2e 20 20 4f 6e 65 20 70 6f 74   error.  One pot
37c0: 65 6e 74 69 61 6c 20 65 72 72 6f 72 20 69 73 20  ential error is 
37d0: 74 68 61 74 20 74 68 65 20 72 65 63 69 70 65 20  that the recipe 
37e0: 73 70 65 63 69 66 69 65 73 20 61 0a 2a 2a 20 64  specifies a.** d
37f0: 61 74 61 62 61 73 65 20 66 69 6c 65 20 6c 61 72  atabase file lar
3800: 67 65 72 20 74 68 61 6e 20 4d 58 5f 46 49 4c 45  ger than MX_FILE
3810: 5f 53 5a 20 62 79 74 65 73 2e 0a 2a 2a 0a 2a 2a  _SZ bytes..**.**
3820: 20 41 62 6f 72 74 20 6f 6e 20 61 6e 20 4f 4f 4d   Abort on an OOM
3830: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
3840: 64 65 63 6f 64 65 44 61 74 61 62 61 73 65 28 0a  decodeDatabase(.
3850: 20 20 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64    const unsigned
3860: 20 63 68 61 72 20 2a 7a 49 6e 2c 20 20 20 20 20   char *zIn,     
3870: 20 2f 2a 20 49 6e 70 75 74 20 74 65 78 74 20 74   /* Input text t
3880: 6f 20 62 65 20 64 65 63 6f 64 65 64 20 2a 2f 0a  o be decoded */.
3890: 20 20 69 6e 74 20 6e 49 6e 2c 20 20 20 20 20 20    int nIn,      
38a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
38b0: 20 2f 2a 20 42 79 74 65 73 20 6f 66 20 69 6e 70   /* Bytes of inp
38c0: 75 74 20 74 65 78 74 20 2a 2f 0a 20 20 75 6e 73  ut text */.  uns
38d0: 69 67 6e 65 64 20 63 68 61 72 20 2a 2a 70 61 44  igned char **paD
38e0: 65 63 6f 64 65 2c 20 20 20 20 20 20 2f 2a 20 4f  ecode,      /* O
38f0: 55 54 3a 20 64 65 63 6f 64 65 64 20 64 61 74 61  UT: decoded data
3900: 62 61 73 65 20 66 69 6c 65 20 2a 2f 0a 20 20 69  base file */.  i
3910: 6e 74 20 2a 70 6e 44 65 63 6f 64 65 20 20 20 20  nt *pnDecode    
3920: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
3930: 20 4f 55 54 3a 20 53 69 7a 65 20 6f 66 20 64 65   OUT: Size of de
3940: 63 6f 64 65 64 20 64 61 74 61 62 61 73 65 20 2a  coded database *
3950: 2f 0a 29 7b 0a 20 20 75 6e 73 69 67 6e 65 64 20  /.){.  unsigned 
3960: 63 68 61 72 20 2a 61 3b 20 20 20 20 20 20 20 20  char *a;        
3970: 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62 61 73        /* Databas
3980: 65 20 75 6e 64 65 72 20 63 6f 6e 73 74 72 75 63  e under construc
3990: 74 69 6f 6e 20 2a 2f 0a 20 20 69 6e 74 20 6d 78  tion */.  int mx
39a0: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
39b0: 20 20 20 20 20 20 20 20 20 2f 2a 20 43 75 72 72           /* Curr
39c0: 65 6e 74 20 73 69 7a 65 20 6f 66 20 74 68 65 20  ent size of the 
39d0: 64 61 74 61 62 61 73 65 20 2a 2f 0a 20 20 73 71  database */.  sq
39e0: 6c 69 74 65 33 5f 75 69 6e 74 36 34 20 6e 41 6c  lite3_uint64 nAl
39f0: 6c 6f 63 20 3d 20 34 30 39 36 3b 20 20 2f 2a 20  loc = 4096;  /* 
3a00: 53 70 61 63 65 20 61 6c 6c 6f 63 61 74 65 64 20  Space allocated 
3a10: 69 6e 20 61 5b 5d 20 2a 2f 0a 20 20 75 6e 73 69  in a[] */.  unsi
3a20: 67 6e 65 64 20 69 6e 74 20 69 3b 20 20 20 20 20  gned int i;     
3a30: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 65             /* Ne
3a40: 78 74 20 62 79 74 65 20 6f 66 20 7a 49 6e 5b 5d  xt byte of zIn[]
3a50: 20 74 6f 20 72 65 61 64 20 2a 2f 0a 20 20 75 6e   to read */.  un
3a60: 73 69 67 6e 65 64 20 69 6e 74 20 6a 3b 20 20 20  signed int j;   
3a70: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
3a80: 54 65 6d 70 6f 72 61 72 79 20 69 6e 74 65 67 65  Temporary intege
3a90: 72 20 2a 2f 0a 20 20 75 6e 73 69 67 6e 65 64 20  r */.  unsigned 
3aa0: 69 6e 74 20 6b 3b 20 20 20 20 20 20 20 20 20 20  int k;          
3ab0: 20 20 20 20 20 20 2f 2a 20 68 61 6c 66 2d 62 79        /* half-by
3ac0: 74 65 20 63 75 72 73 6f 72 20 69 6e 64 65 78 20  te cursor index 
3ad0: 66 6f 72 20 6f 75 74 70 75 74 20 2a 2f 0a 20 20  for output */.  
3ae0: 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 6e 3b 20  unsigned int n; 
3af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
3b00: 2a 20 4e 75 6d 62 65 72 20 6f 66 20 62 79 74 65  * Number of byte
3b10: 73 20 6f 66 20 69 6e 70 75 74 20 2a 2f 0a 20 20  s of input */.  
3b20: 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20 62 20  unsigned char b 
3b30: 3d 20 30 3b 0a 20 20 69 66 28 20 6e 49 6e 3c 34  = 0;.  if( nIn<4
3b40: 20 29 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20   ) return -1;.  
3b50: 6e 20 3d 20 28 75 6e 73 69 67 6e 65 64 20 69 6e  n = (unsigned in
3b60: 74 29 6e 49 6e 3b 0a 20 20 61 20 3d 20 73 71 6c  t)nIn;.  a = sql
3b70: 69 74 65 33 5f 6d 61 6c 6c 6f 63 36 34 28 20 6e  ite3_malloc64( n
3b80: 41 6c 6c 6f 63 20 29 3b 0a 20 20 69 66 28 20 61  Alloc );.  if( a
3b90: 3d 3d 30 20 29 7b 0a 20 20 20 20 66 70 72 69 6e  ==0 ){.    fprin
3ba0: 74 66 28 73 74 64 65 72 72 2c 20 22 4f 75 74 20  tf(stderr, "Out 
3bb0: 6f 66 20 6d 65 6d 6f 72 79 21 5c 6e 22 29 3b 0a  of memory!\n");.
3bc0: 20 20 20 20 65 78 69 74 28 31 29 3b 0a 20 20 7d      exit(1);.  }
3bd0: 0a 20 20 6d 65 6d 73 65 74 28 61 2c 20 30 2c 20  .  memset(a, 0, 
3be0: 28 73 69 7a 65 5f 74 29 6e 41 6c 6c 6f 63 29 3b  (size_t)nAlloc);
3bf0: 0a 20 20 66 6f 72 28 69 3d 6b 3d 30 3b 20 69 3c  .  for(i=k=0; i<
3c00: 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 75 6e 73  n; i++){.    uns
3c10: 69 67 6e 65 64 20 63 68 61 72 20 63 20 3d 20 28  igned char c = (
3c20: 75 6e 73 69 67 6e 65 64 20 63 68 61 72 29 7a 49  unsigned char)zI
3c30: 6e 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20 69 73  n[i];.    if( is
3c40: 78 64 69 67 69 74 28 63 29 20 29 7b 0a 20 20 20  xdigit(c) ){.   
3c50: 20 20 20 6b 2b 2b 3b 0a 20 20 20 20 20 20 69 66     k++;.      if
3c60: 28 20 6b 20 26 20 31 20 29 7b 0a 20 20 20 20 20  ( k & 1 ){.     
3c70: 20 20 20 62 20 3d 20 68 65 78 54 6f 49 6e 74 28     b = hexToInt(
3c80: 63 29 2a 31 36 3b 0a 20 20 20 20 20 20 7d 65 6c  c)*16;.      }el
3c90: 73 65 7b 0a 20 20 20 20 20 20 20 20 62 20 2b 3d  se{.        b +=
3ca0: 20 68 65 78 54 6f 49 6e 74 28 63 29 3b 0a 20 20   hexToInt(c);.  
3cb0: 20 20 20 20 20 20 6a 20 3d 20 6b 2f 32 20 2d 20        j = k/2 - 
3cc0: 31 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 6a  1;.        if( j
3cd0: 3e 3d 6e 41 6c 6c 6f 63 20 29 7b 0a 20 20 20 20  >=nAlloc ){.    
3ce0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 75 69        sqlite3_ui
3cf0: 6e 74 36 34 20 6e 65 77 53 69 7a 65 3b 0a 20 20  nt64 newSize;.  
3d00: 20 20 20 20 20 20 20 20 69 66 28 20 6e 41 6c 6c          if( nAll
3d10: 6f 63 3d 3d 4d 58 5f 46 49 4c 45 5f 53 5a 20 7c  oc==MX_FILE_SZ |
3d20: 7c 20 6a 3e 3d 4d 58 5f 46 49 4c 45 5f 53 5a 20  | j>=MX_FILE_SZ 
3d30: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  ){.            i
3d40: 66 28 20 65 56 65 72 62 6f 73 69 74 79 20 29 7b  f( eVerbosity ){
3d50: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66  .              f
3d60: 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 20 22  printf(stderr, "
3d70: 49 6e 70 75 74 20 64 61 74 61 62 61 73 65 20 74  Input database t
3d80: 6f 6f 20 62 69 67 3a 20 6d 61 78 20 25 64 20 62  oo big: max %d b
3d90: 79 74 65 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20  ytes\n",.       
3da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 4d                 M
3db0: 58 5f 46 49 4c 45 5f 53 5a 29 3b 0a 20 20 20 20  X_FILE_SZ);.    
3dc0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3dd0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72        sqlite3_fr
3de0: 65 65 28 61 29 3b 0a 20 20 20 20 20 20 20 20 20  ee(a);.         
3df0: 20 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20     return -1;.  
3e00: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3e10: 20 20 20 20 6e 65 77 53 69 7a 65 20 3d 20 6e 41      newSize = nA
3e20: 6c 6c 6f 63 2a 32 3b 0a 20 20 20 20 20 20 20 20  lloc*2;.        
3e30: 20 20 69 66 28 20 6e 65 77 53 69 7a 65 3c 3d 6a    if( newSize<=j
3e40: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
3e50: 6e 65 77 53 69 7a 65 20 3d 20 28 6a 2b 34 30 39  newSize = (j+409
3e60: 36 29 26 7e 34 30 39 35 3b 0a 20 20 20 20 20 20  6)&~4095;.      
3e70: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
3e80: 69 66 28 20 6e 65 77 53 69 7a 65 3e 4d 58 5f 46  if( newSize>MX_F
3e90: 49 4c 45 5f 53 5a 20 29 7b 0a 20 20 20 20 20 20  ILE_SZ ){.      
3ea0: 20 20 20 20 20 20 69 66 28 20 6a 3e 3d 4d 58 5f        if( j>=MX_
3eb0: 46 49 4c 45 5f 53 5a 20 29 7b 0a 20 20 20 20 20  FILE_SZ ){.     
3ec0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
3ed0: 5f 66 72 65 65 28 61 29 3b 0a 20 20 20 20 20 20  _free(a);.      
3ee0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 2d          return -
3ef0: 31 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  1;.            }
3f00: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77  .            new
3f10: 53 69 7a 65 20 3d 20 4d 58 5f 46 49 4c 45 5f 53  Size = MX_FILE_S
3f20: 5a 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  Z;.          }. 
3f30: 20 20 20 20 20 20 20 20 20 61 20 3d 20 73 71 6c           a = sql
3f40: 69 74 65 33 5f 72 65 61 6c 6c 6f 63 36 34 28 20  ite3_realloc64( 
3f50: 61 2c 20 6e 65 77 53 69 7a 65 20 29 3b 0a 20 20  a, newSize );.  
3f60: 20 20 20 20 20 20 20 20 69 66 28 20 61 3d 3d 30          if( a==0
3f70: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
3f80: 66 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 20  fprintf(stderr, 
3f90: 22 4f 75 74 20 6f 66 20 6d 65 6d 6f 72 79 21 5c  "Out of memory!\
3fa0: 6e 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  n");.           
3fb0: 20 65 78 69 74 28 31 29 3b 0a 20 20 20 20 20 20   exit(1);.      
3fc0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
3fd0: 61 73 73 65 72 74 28 20 6e 65 77 53 69 7a 65 20  assert( newSize 
3fe0: 3e 20 6e 41 6c 6c 6f 63 20 29 3b 0a 20 20 20 20  > nAlloc );.    
3ff0: 20 20 20 20 20 20 6d 65 6d 73 65 74 28 61 2b 6e        memset(a+n
4000: 41 6c 6c 6f 63 2c 20 30 2c 20 28 73 69 7a 65 5f  Alloc, 0, (size_
4010: 74 29 28 6e 65 77 53 69 7a 65 20 2d 20 6e 41 6c  t)(newSize - nAl
4020: 6c 6f 63 29 29 3b 0a 20 20 20 20 20 20 20 20 20  loc));.         
4030: 20 6e 41 6c 6c 6f 63 20 3d 20 6e 65 77 53 69 7a   nAlloc = newSiz
4040: 65 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  e;.        }.   
4050: 20 20 20 20 20 69 66 28 20 6a 3e 3d 28 75 6e 73       if( j>=(uns
4060: 69 67 6e 65 64 29 6d 78 20 29 7b 0a 20 20 20 20  igned)mx ){.    
4070: 20 20 20 20 20 20 6d 78 20 3d 20 28 6a 20 2b 20        mx = (j + 
4080: 34 30 39 35 29 26 7e 34 30 39 35 3b 0a 20 20 20  4095)&~4095;.   
4090: 20 20 20 20 20 20 20 69 66 28 20 6d 78 3e 4d 58         if( mx>MX
40a0: 5f 46 49 4c 45 5f 53 5a 20 29 20 6d 78 20 3d 20  _FILE_SZ ) mx = 
40b0: 4d 58 5f 46 49 4c 45 5f 53 5a 3b 0a 20 20 20 20  MX_FILE_SZ;.    
40c0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 61 73      }.        as
40d0: 73 65 72 74 28 20 6a 3c 6e 41 6c 6c 6f 63 20 29  sert( j<nAlloc )
40e0: 3b 0a 20 20 20 20 20 20 20 20 61 5b 6a 5d 20 3d  ;.        a[j] =
40f0: 20 62 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20   b;.      }.    
4100: 7d 65 6c 73 65 20 69 66 28 20 7a 49 6e 5b 69 5d  }else if( zIn[i]
4110: 3d 3d 27 5b 27 20 26 26 20 69 3c 6e 2d 33 20 26  =='[' && i<n-3 &
4120: 26 20 69 73 4f 66 66 73 65 74 28 7a 49 6e 2b 69  & isOffset(zIn+i
4130: 2c 20 6e 49 6e 2d 69 2c 20 26 6b 2c 20 26 69 29  , nIn-i, &k, &i)
4140: 20 29 7b 0a 20 20 20 20 20 20 63 6f 6e 74 69 6e   ){.      contin
4150: 75 65 3b 0a 20 20 20 7d 65 6c 73 65 20 69 66 28  ue;.   }else if(
4160: 20 7a 49 6e 5b 69 5d 3d 3d 27 5c 6e 27 20 26 26   zIn[i]=='\n' &&
4170: 20 69 3c 6e 2d 34 20 26 26 20 6d 65 6d 63 6d 70   i<n-4 && memcmp
4180: 28 7a 49 6e 2b 69 2c 22 5c 6e 2d 2d 5c 6e 22 2c  (zIn+i,"\n--\n",
4190: 34 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 69  4)==0 ){.      i
41a0: 20 2b 3d 20 34 3b 0a 20 20 20 20 20 20 62 72 65   += 4;.      bre
41b0: 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  ak;.    }.  }.  
41c0: 2a 70 6e 44 65 63 6f 64 65 20 3d 20 6d 78 3b 0a  *pnDecode = mx;.
41d0: 20 20 2a 70 61 44 65 63 6f 64 65 20 3d 20 61 3b    *paDecode = a;
41e0: 0a 20 20 72 65 74 75 72 6e 20 69 3b 0a 7d 0a 0a  .  return i;.}..
41f0: 2f 2a 0a 2a 2a 20 50 72 6f 67 72 65 73 73 20 68  /*.** Progress h
4200: 61 6e 64 6c 65 72 20 63 61 6c 6c 62 61 63 6b 2e  andler callback.
4210: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 72 67 75 6d  .**.** The argum
4220: 65 6e 74 20 69 73 20 74 68 65 20 63 75 74 6f 66  ent is the cutof
4230: 66 2d 74 69 6d 65 20 61 66 74 65 72 20 77 68 69  f-time after whi
4240: 63 68 20 61 6c 6c 20 70 72 6f 63 65 73 73 69 6e  ch all processin
4250: 67 20 73 68 6f 75 6c 64 0a 2a 2a 20 73 74 6f 70  g should.** stop
4260: 2e 20 20 53 6f 20 72 65 74 75 72 6e 20 6e 6f 6e  .  So return non
4270: 2d 7a 65 72 6f 20 69 66 20 74 68 65 20 63 75 74  -zero if the cut
4280: 2d 6f 66 66 20 74 69 6d 65 20 69 73 20 65 78 63  -off time is exc
4290: 65 65 64 65 64 2e 0a 2a 2f 0a 73 74 61 74 69 63  eeded..*/.static
42a0: 20 69 6e 74 20 70 72 6f 67 72 65 73 73 5f 68 61   int progress_ha
42b0: 6e 64 6c 65 72 28 76 6f 69 64 20 2a 70 43 6c 69  ndler(void *pCli
42c0: 65 6e 74 44 61 74 61 29 20 7b 0a 20 20 46 75 7a  entData) {.  Fuz
42d0: 7a 43 74 78 20 2a 70 20 3d 20 28 46 75 7a 7a 43  zCtx *p = (FuzzC
42e0: 74 78 2a 29 70 43 6c 69 65 6e 74 44 61 74 61 3b  tx*)pClientData;
42f0: 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34  .  sqlite3_int64
4300: 20 69 4e 6f 77 20 3d 20 74 69 6d 65 4f 66 44 61   iNow = timeOfDa
4310: 79 28 29 3b 0a 20 20 69 6e 74 20 72 63 20 3d 20  y();.  int rc = 
4320: 69 4e 6f 77 3e 3d 70 2d 3e 69 43 75 74 6f 66 66  iNow>=p->iCutoff
4330: 54 69 6d 65 3b 0a 20 20 73 71 6c 69 74 65 33 5f  Time;.  sqlite3_
4340: 69 6e 74 36 34 20 69 44 69 66 66 20 3d 20 69 4e  int64 iDiff = iN
4350: 6f 77 20 2d 20 70 2d 3e 69 4c 61 73 74 43 62 3b  ow - p->iLastCb;
4360: 0a 20 20 69 66 28 20 69 44 69 66 66 20 3e 20 70  .  if( iDiff > p
4370: 2d 3e 6d 78 49 6e 74 65 72 76 61 6c 20 29 20 70  ->mxInterval ) p
4380: 2d 3e 6d 78 49 6e 74 65 72 76 61 6c 20 3d 20 69  ->mxInterval = i
4390: 44 69 66 66 3b 0a 20 20 70 2d 3e 6e 43 62 2b 2b  Diff;.  p->nCb++
43a0: 3b 0a 20 20 69 66 28 20 72 63 3d 3d 30 20 26 26  ;.  if( rc==0 &&
43b0: 20 70 2d 3e 6d 78 43 62 3e 30 20 26 26 20 70 2d   p->mxCb>0 && p-
43c0: 3e 6d 78 43 62 3c 3d 70 2d 3e 6e 43 62 20 29 20  >mxCb<=p->nCb ) 
43d0: 72 63 20 3d 20 31 3b 0a 20 20 69 66 28 20 72 63  rc = 1;.  if( rc
43e0: 20 26 26 20 21 70 2d 3e 74 69 6d 65 6f 75 74 48   && !p->timeoutH
43f0: 69 74 20 26 26 20 65 56 65 72 62 6f 73 69 74 79  it && eVerbosity
4400: 3e 3d 32 20 29 7b 0a 20 20 20 20 70 72 69 6e 74  >=2 ){.    print
4410: 66 28 22 54 69 6d 65 6f 75 74 20 6f 6e 20 70 72  f("Timeout on pr
4420: 6f 67 72 65 73 73 20 63 61 6c 6c 62 61 63 6b 20  ogress callback 
4430: 25 64 5c 6e 22 2c 20 70 2d 3e 6e 43 62 29 3b 0a  %d\n", p->nCb);.
4440: 20 20 20 20 66 66 6c 75 73 68 28 73 74 64 6f 75      fflush(stdou
4450: 74 29 3b 0a 20 20 20 20 70 2d 3e 74 69 6d 65 6f  t);.    p->timeo
4460: 75 74 48 69 74 20 3d 20 31 3b 0a 20 20 7d 0a 20  utHit = 1;.  }. 
4470: 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f   return rc;.}../
4480: 2a 0a 2a 2a 20 44 69 73 61 6c 6c 6f 77 20 64 65  *.** Disallow de
4490: 62 75 67 67 69 6e 67 20 70 72 61 67 6d 61 73 20  bugging pragmas 
44a0: 73 75 63 68 20 61 73 20 22 50 52 41 47 4d 41 20  such as "PRAGMA 
44b0: 76 64 62 65 5f 64 65 62 75 67 22 20 61 6e 64 0a  vdbe_debug" and.
44c0: 2a 2a 20 22 50 52 41 47 4d 41 20 70 61 72 73 65  ** "PRAGMA parse
44d0: 72 5f 74 72 61 63 65 22 20 73 69 6e 63 65 20 74  r_trace" since t
44e0: 68 65 79 20 63 61 6e 20 64 72 61 6d 61 74 69 63  hey can dramatic
44f0: 61 6c 6c 79 20 69 6e 63 72 65 61 73 65 20 74 68  ally increase th
4500: 65 0a 2a 2a 20 61 6d 6f 75 6e 74 20 6f 66 20 6f  e.** amount of o
4510: 75 74 70 75 74 20 77 69 74 68 6f 75 74 20 61 63  utput without ac
4520: 74 75 61 6c 6c 79 20 74 65 73 74 69 6e 67 20 61  tually testing a
4530: 6e 79 74 68 69 6e 67 20 75 73 65 66 75 6c 2e 0a  nything useful..
4540: 2a 2a 0a 2a 2a 20 41 6c 73 6f 20 62 6c 6f 63 6b  **.** Also block
4550: 20 41 54 54 41 43 48 20 61 6e 64 20 44 45 54 41   ATTACH and DETA
4560: 43 48 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  CH.*/.static int
4570: 20 62 6c 6f 63 6b 5f 74 72 6f 75 62 6c 65 73 6f   block_troubleso
4580: 6d 65 5f 73 71 6c 28 0a 20 20 76 6f 69 64 20 2a  me_sql(.  void *
4590: 4e 6f 74 75 73 65 64 2c 0a 20 20 69 6e 74 20 65  Notused,.  int e
45a0: 43 6f 64 65 2c 0a 20 20 63 6f 6e 73 74 20 63 68  Code,.  const ch
45b0: 61 72 20 2a 7a 41 72 67 31 2c 0a 20 20 63 6f 6e  ar *zArg1,.  con
45c0: 73 74 20 63 68 61 72 20 2a 7a 41 72 67 32 2c 0a  st char *zArg2,.
45d0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 41    const char *zA
45e0: 72 67 33 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61  rg3,.  const cha
45f0: 72 20 2a 7a 41 72 67 34 0a 29 7b 0a 20 20 28 76  r *zArg4.){.  (v
4600: 6f 69 64 29 4e 6f 74 75 73 65 64 3b 0a 20 20 28  oid)Notused;.  (
4610: 76 6f 69 64 29 7a 41 72 67 32 3b 0a 20 20 28 76  void)zArg2;.  (v
4620: 6f 69 64 29 7a 41 72 67 33 3b 0a 20 20 28 76 6f  oid)zArg3;.  (vo
4630: 69 64 29 7a 41 72 67 34 3b 0a 20 20 69 66 28 20  id)zArg4;.  if( 
4640: 65 43 6f 64 65 3d 3d 53 51 4c 49 54 45 5f 50 52  eCode==SQLITE_PR
4650: 41 47 4d 41 20 29 7b 0a 20 20 20 20 69 66 28 20  AGMA ){.    if( 
4660: 73 71 6c 69 74 65 33 5f 73 74 72 6e 69 63 6d 70  sqlite3_strnicmp
4670: 28 22 76 64 62 65 5f 22 2c 20 7a 41 72 67 31 2c  ("vdbe_", zArg1,
4680: 20 35 29 3d 3d 30 0a 20 20 20 20 20 7c 7c 20 73   5)==0.     || s
4690: 71 6c 69 74 65 33 5f 73 74 72 69 63 6d 70 28 22  qlite3_stricmp("
46a0: 70 61 72 73 65 72 5f 74 72 61 63 65 22 2c 20 7a  parser_trace", z
46b0: 41 72 67 31 29 3d 3d 30 0a 20 20 20 20 20 7c 7c  Arg1)==0.     ||
46c0: 20 73 71 6c 69 74 65 33 5f 73 74 72 69 63 6d 70   sqlite3_stricmp
46d0: 28 22 74 65 6d 70 5f 73 74 6f 72 65 5f 64 69 72  ("temp_store_dir
46e0: 65 63 74 6f 72 79 22 2c 20 7a 41 72 67 31 29 3d  ectory", zArg1)=
46f0: 3d 30 0a 20 20 20 20 29 7b 0a 20 20 20 20 20 20  =0.    ){.      
4700: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 44 45  return SQLITE_DE
4710: 4e 59 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73  NY;.    }.  }els
4720: 65 20 69 66 28 20 28 65 43 6f 64 65 3d 3d 53 51  e if( (eCode==SQ
4730: 4c 49 54 45 5f 41 54 54 41 43 48 20 7c 7c 20 65  LITE_ATTACH || e
4740: 43 6f 64 65 3d 3d 53 51 4c 49 54 45 5f 44 45 54  Code==SQLITE_DET
4750: 41 43 48 29 0a 20 20 20 20 20 20 20 20 20 20 20  ACH).           
4760: 20 26 26 20 7a 41 72 67 31 20 26 26 20 7a 41 72   && zArg1 && zAr
4770: 67 31 5b 30 5d 20 29 7b 0a 20 20 20 20 72 65 74  g1[0] ){.    ret
4780: 75 72 6e 20 53 51 4c 49 54 45 5f 44 45 4e 59 3b  urn SQLITE_DENY;
4790: 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 53 51  .  }.  return SQ
47a0: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a  LITE_OK;.}../*.*
47b0: 2a 20 52 75 6e 20 74 68 65 20 53 51 4c 20 74 65  * Run the SQL te
47c0: 78 74 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  xt.*/.static int
47d0: 20 72 75 6e 44 62 53 71 6c 28 73 71 6c 69 74 65   runDbSql(sqlite
47e0: 33 20 2a 64 62 2c 20 63 6f 6e 73 74 20 63 68 61  3 *db, const cha
47f0: 72 20 2a 7a 53 71 6c 29 7b 0a 20 20 69 6e 74 20  r *zSql){.  int 
4800: 72 63 3b 0a 20 20 73 71 6c 69 74 65 33 5f 73 74  rc;.  sqlite3_st
4810: 6d 74 20 2a 70 53 74 6d 74 3b 0a 20 20 77 68 69  mt *pStmt;.  whi
4820: 6c 65 28 20 69 73 73 70 61 63 65 28 7a 53 71 6c  le( isspace(zSql
4830: 5b 30 5d 26 30 78 37 66 29 20 29 20 7a 53 71 6c  [0]&0x7f) ) zSql
4840: 2b 2b 3b 0a 20 20 69 66 28 20 7a 53 71 6c 5b 30  ++;.  if( zSql[0
4850: 5d 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51  ]==0 ) return SQ
4860: 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 66 28 20 65  LITE_OK;.  if( e
4870: 56 65 72 62 6f 73 69 74 79 3e 3d 34 20 29 7b 0a  Verbosity>=4 ){.
4880: 20 20 20 20 70 72 69 6e 74 66 28 22 52 55 4e 4e      printf("RUNN
4890: 49 4e 47 2d 53 51 4c 3a 20 5b 25 73 5d 5c 6e 22  ING-SQL: [%s]\n"
48a0: 2c 20 7a 53 71 6c 29 3b 0a 20 20 20 20 66 66 6c  , zSql);.    ffl
48b0: 75 73 68 28 73 74 64 6f 75 74 29 3b 0a 20 20 7d  ush(stdout);.  }
48c0: 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f  .  rc = sqlite3_
48d0: 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 20 7a  prepare_v2(db, z
48e0: 53 71 6c 2c 20 2d 31 2c 20 26 70 53 74 6d 74 2c  Sql, -1, &pStmt,
48f0: 20 30 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53   0);.  if( rc==S
4900: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
4910: 77 68 69 6c 65 28 20 28 72 63 20 3d 20 73 71 6c  while( (rc = sql
4920: 69 74 65 33 5f 73 74 65 70 28 70 53 74 6d 74 29  ite3_step(pStmt)
4930: 29 3d 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b  )==SQLITE_ROW ){
4940: 0a 20 20 20 20 20 20 69 66 28 20 65 56 65 72 62  .      if( eVerb
4950: 6f 73 69 74 79 3e 3d 35 20 29 7b 0a 20 20 20 20  osity>=5 ){.    
4960: 20 20 20 20 69 6e 74 20 6a 3b 0a 20 20 20 20 20      int j;.     
4970: 20 20 20 66 6f 72 28 6a 3d 30 3b 20 6a 3c 73 71     for(j=0; j<sq
4980: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 63 6f 75  lite3_column_cou
4990: 6e 74 28 70 53 74 6d 74 29 3b 20 6a 2b 2b 29 7b  nt(pStmt); j++){
49a0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20 6a  .          if( j
49b0: 20 29 20 70 72 69 6e 74 66 28 22 2c 22 29 3b 0a   ) printf(",");.
49c0: 20 20 20 20 20 20 20 20 20 20 73 77 69 74 63 68            switch
49d0: 28 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  ( sqlite3_column
49e0: 5f 74 79 70 65 28 70 53 74 6d 74 2c 20 6a 29 20  _type(pStmt, j) 
49f0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 63  ){.            c
4a00: 61 73 65 20 53 51 4c 49 54 45 5f 4e 55 4c 4c 3a  ase SQLITE_NULL:
4a10: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
4a20: 20 70 72 69 6e 74 66 28 22 4e 55 4c 4c 22 29 3b   printf("NULL");
4a30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62  .              b
4a40: 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20  reak;.          
4a50: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
4a60: 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4e 54 45  case SQLITE_INTE
4a70: 47 45 52 3a 0a 20 20 20 20 20 20 20 20 20 20 20  GER:.           
4a80: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 46 4c 4f   case SQLITE_FLO
4a90: 41 54 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20  AT: {.          
4aa0: 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 22 2c      printf("%s",
4ab0: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
4ac0: 74 65 78 74 28 70 53 74 6d 74 2c 20 6a 29 29 3b  text(pStmt, j));
4ad0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62  .              b
4ae0: 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20  reak;.          
4af0: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
4b00: 63 61 73 65 20 53 51 4c 49 54 45 5f 42 4c 4f 42  case SQLITE_BLOB
4b10: 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20  : {.            
4b20: 20 20 69 6e 74 20 6e 20 3d 20 73 71 6c 69 74 65    int n = sqlite
4b30: 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 28 70  3_column_bytes(p
4b40: 53 74 6d 74 2c 20 6a 29 3b 0a 20 20 20 20 20 20  Stmt, j);.      
4b50: 20 20 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20          int i;. 
4b60: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e               con
4b70: 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72  st unsigned char
4b80: 20 2a 61 3b 0a 20 20 20 20 20 20 20 20 20 20 20   *a;.           
4b90: 20 20 20 61 20 3d 20 28 63 6f 6e 73 74 20 75 6e     a = (const un
4ba0: 73 69 67 6e 65 64 20 63 68 61 72 2a 29 73 71 6c  signed char*)sql
4bb0: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 6c 6f 62  ite3_column_blob
4bc0: 28 70 53 74 6d 74 2c 20 6a 29 3b 0a 20 20 20 20  (pStmt, j);.    
4bd0: 20 20 20 20 20 20 20 20 20 20 70 72 69 6e 74 66            printf
4be0: 28 22 78 27 22 29 3b 0a 20 20 20 20 20 20 20 20  ("x'");.        
4bf0: 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69        for(i=0; i
4c00: 3c 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  <n; i++){.      
4c10: 20 20 20 20 20 20 20 20 20 20 70 72 69 6e 74 66            printf
4c20: 28 22 25 30 32 78 22 2c 20 61 5b 69 5d 29 3b 0a  ("%02x", a[i]);.
4c30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a                }.
4c40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70 72                pr
4c50: 69 6e 74 66 28 22 27 22 29 3b 0a 20 20 20 20 20  intf("'");.     
4c60: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a           break;.
4c70: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
4c80: 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20 53            case S
4c90: 51 4c 49 54 45 5f 54 45 58 54 3a 20 7b 0a 20 20  QLITE_TEXT: {.  
4ca0: 20 20 20 20 20 20 20 20 20 20 20 20 69 6e 74 20              int 
4cb0: 6e 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  n = sqlite3_colu
4cc0: 6d 6e 5f 62 79 74 65 73 28 70 53 74 6d 74 2c 20  mn_bytes(pStmt, 
4cd0: 6a 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  j);.            
4ce0: 20 20 69 6e 74 20 69 3b 0a 20 20 20 20 20 20 20    int i;.       
4cf0: 20 20 20 20 20 20 20 63 6f 6e 73 74 20 75 6e 73         const uns
4d00: 69 67 6e 65 64 20 63 68 61 72 20 2a 61 3b 0a 20  igned char *a;. 
4d10: 20 20 20 20 20 20 20 20 20 20 20 20 20 61 20 3d               a =
4d20: 20 28 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64   (const unsigned
4d30: 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33 5f 63   char*)sqlite3_c
4d40: 6f 6c 75 6d 6e 5f 62 6c 6f 62 28 70 53 74 6d 74  olumn_blob(pStmt
4d50: 2c 20 6a 29 3b 0a 20 20 20 20 20 20 20 20 20 20  , j);.          
4d60: 20 20 20 20 70 72 69 6e 74 66 28 22 27 22 29 3b      printf("'");
4d70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66  .              f
4d80: 6f 72 28 69 3d 30 3b 20 69 3c 6e 3b 20 69 2b 2b  or(i=0; i<n; i++
4d90: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ){.             
4da0: 20 20 20 69 66 28 20 61 5b 69 5d 3d 3d 27 5c 27     if( a[i]=='\'
4db0: 27 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  ' ){.           
4dc0: 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22 27         printf("'
4dd0: 27 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  '");.           
4de0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
4df0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70 75                pu
4e00: 74 63 68 61 72 28 61 5b 69 5d 29 3b 0a 20 20 20  tchar(a[i]);.   
4e10: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20               }. 
4e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20               }. 
4e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 70 72 69               pri
4e40: 6e 74 66 28 22 27 22 29 3b 0a 20 20 20 20 20 20  ntf("'");.      
4e50: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
4e60: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
4e70: 20 20 20 20 20 20 20 7d 20 2f 2a 20 45 6e 64 20         } /* End 
4e80: 73 77 69 74 63 68 28 29 20 2a 2f 0a 20 20 20 20  switch() */.    
4e90: 20 20 20 20 7d 20 2f 2a 20 45 6e 64 20 66 6f 72      } /* End for
4ea0: 28 29 20 2a 2f 0a 20 20 20 20 20 20 20 20 70 72  () */.        pr
4eb0: 69 6e 74 66 28 22 5c 6e 22 29 3b 0a 20 20 20 20  intf("\n");.    
4ec0: 20 20 20 20 66 66 6c 75 73 68 28 73 74 64 6f 75      fflush(stdou
4ed0: 74 29 3b 0a 20 20 20 20 20 20 7d 20 2f 2a 20 45  t);.      } /* E
4ee0: 6e 64 20 69 66 28 20 65 56 65 72 62 6f 73 69 74  nd if( eVerbosit
4ef0: 79 3e 3d 35 20 29 20 2a 2f 0a 20 20 20 20 7d 20  y>=5 ) */.    } 
4f00: 2f 2a 20 45 6e 64 20 77 68 69 6c 65 28 20 53 51  /* End while( SQ
4f10: 4c 49 54 45 5f 52 4f 57 20 2a 2f 0a 20 20 20 20  LITE_ROW */.    
4f20: 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 44  if( rc!=SQLITE_D
4f30: 4f 4e 45 20 26 26 20 65 56 65 72 62 6f 73 69 74  ONE && eVerbosit
4f40: 79 3e 3d 34 20 29 7b 0a 20 20 20 20 20 20 70 72  y>=4 ){.      pr
4f50: 69 6e 74 66 28 22 53 51 4c 2d 45 52 52 4f 52 3a  intf("SQL-ERROR:
4f60: 20 28 25 64 29 20 25 73 5c 6e 22 2c 20 72 63 2c   (%d) %s\n", rc,
4f70: 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28   sqlite3_errmsg(
4f80: 64 62 29 29 3b 0a 20 20 20 20 20 20 66 66 6c 75  db));.      fflu
4f90: 73 68 28 73 74 64 6f 75 74 29 3b 0a 20 20 20 20  sh(stdout);.    
4fa0: 7d 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 65 56  }.  }else if( eV
4fb0: 65 72 62 6f 73 69 74 79 3e 3d 34 20 29 7b 0a 20  erbosity>=4 ){. 
4fc0: 20 20 20 70 72 69 6e 74 66 28 22 53 51 4c 2d 45     printf("SQL-E
4fd0: 52 52 4f 52 20 28 25 64 29 3a 20 25 73 5c 6e 22  RROR (%d): %s\n"
4fe0: 2c 20 72 63 2c 20 73 71 6c 69 74 65 33 5f 65 72  , rc, sqlite3_er
4ff0: 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 66  rmsg(db));.    f
5000: 66 6c 75 73 68 28 73 74 64 6f 75 74 29 3b 20 20  flush(stdout);  
5010: 20 20 0a 20 20 7d 20 2f 2a 20 45 6e 64 20 69 66    .  } /* End if
5020: 28 20 53 51 4c 49 54 45 5f 4f 4b 20 29 20 2a 2f  ( SQLITE_OK ) */
5030: 0a 20 20 72 65 74 75 72 6e 20 73 71 6c 69 74 65  .  return sqlite
5040: 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53 74 6d 74  3_finalize(pStmt
5050: 29 3b 0a 7d 0a 0a 2f 2a 20 49 6e 76 6f 6b 65 20  );.}../* Invoke 
5060: 74 68 69 73 20 72 6f 75 74 69 6e 65 20 74 6f 20  this routine to 
5070: 72 75 6e 20 61 20 73 69 6e 67 6c 65 20 74 65 73  run a single tes
5080: 74 20 63 61 73 65 20 2a 2f 0a 69 6e 74 20 72 75  t case */.int ru
5090: 6e 43 6f 6d 62 69 6e 65 64 44 62 53 71 6c 49 6e  nCombinedDbSqlIn
50a0: 70 75 74 28 63 6f 6e 73 74 20 75 69 6e 74 38 5f  put(const uint8_
50b0: 74 20 2a 61 44 61 74 61 2c 20 73 69 7a 65 5f 74  t *aData, size_t
50c0: 20 6e 42 79 74 65 29 7b 0a 20 20 69 6e 74 20 72   nByte){.  int r
50d0: 63 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c;              
50e0: 20 20 20 20 20 20 2f 2a 20 53 51 4c 69 74 65 20        /* SQLite 
50f0: 41 50 49 20 72 65 74 75 72 6e 20 76 61 6c 75 65  API return value
5100: 20 2a 2f 0a 20 20 69 6e 74 20 69 53 71 6c 3b 20   */.  int iSql; 
5110: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5120: 20 2f 2a 20 49 6e 64 65 78 20 69 6e 20 61 44 61   /* Index in aDa
5130: 74 61 5b 5d 20 6f 66 20 73 74 61 72 74 20 6f 66  ta[] of start of
5140: 20 53 51 4c 20 2a 2f 0a 20 20 75 6e 73 69 67 6e   SQL */.  unsign
5150: 65 64 20 63 68 61 72 20 2a 61 44 62 20 3d 20 30  ed char *aDb = 0
5160: 3b 20 20 20 20 2f 2a 20 44 65 63 6f 64 65 64 20  ;    /* Decoded 
5170: 64 61 74 61 62 61 73 65 20 63 6f 6e 74 65 6e 74  database content
5180: 20 2a 2f 0a 20 20 69 6e 74 20 6e 44 62 20 3d 20   */.  int nDb = 
5190: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  0;              
51a0: 20 2f 2a 20 53 69 7a 65 20 6f 66 20 74 68 65 20   /* Size of the 
51b0: 64 65 63 6f 64 65 64 20 64 61 74 61 62 61 73 65  decoded database
51c0: 20 2a 2f 0a 20 20 69 6e 74 20 69 3b 20 20 20 20   */.  int i;    
51d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
51e0: 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74 65 72   /* Loop counter
51f0: 20 2a 2f 0a 20 20 69 6e 74 20 6a 3b 20 20 20 20   */.  int j;    
5200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5210: 20 2f 2a 20 53 74 61 72 74 20 6f 66 20 63 75 72   /* Start of cur
5220: 72 65 6e 74 20 53 51 4c 20 73 74 61 74 65 6d 65  rent SQL stateme
5230: 6e 74 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 53  nt */.  char *zS
5240: 71 6c 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20  ql = 0;         
5250: 20 20 20 2f 2a 20 53 51 4c 20 74 65 78 74 20 74     /* SQL text t
5260: 6f 20 72 75 6e 20 2a 2f 0a 20 20 69 6e 74 20 6e  o run */.  int n
5270: 53 71 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20  Sql;            
5280: 20 20 20 20 20 20 2f 2a 20 42 79 74 65 73 20 6f        /* Bytes o
5290: 66 20 53 51 4c 20 74 65 78 74 20 2a 2f 0a 20 20  f SQL text */.  
52a0: 46 75 7a 7a 43 74 78 20 63 78 3b 20 20 20 20 20  FuzzCtx cx;     
52b0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 46 75             /* Fu
52c0: 7a 7a 69 6e 67 20 63 6f 6e 74 65 78 74 20 2a 2f  zzing context */
52d0: 0a 0a 20 20 69 66 28 20 6e 42 79 74 65 3c 31 30  ..  if( nByte<10
52e0: 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 69   ) return 0;.  i
52f0: 66 28 20 73 71 6c 69 74 65 33 5f 69 6e 69 74 69  f( sqlite3_initi
5300: 61 6c 69 7a 65 28 29 20 29 20 72 65 74 75 72 6e  alize() ) return
5310: 20 30 3b 0a 20 20 69 66 28 20 73 71 6c 69 74 65   0;.  if( sqlite
5320: 33 5f 6d 65 6d 6f 72 79 5f 75 73 65 64 28 29 21  3_memory_used()!
5330: 3d 30 20 29 7b 0a 20 20 20 20 69 6e 74 20 6e 41  =0 ){.    int nA
5340: 6c 6c 6f 63 20 3d 20 30 3b 0a 20 20 20 20 69 6e  lloc = 0;.    in
5350: 74 20 6e 4e 6f 74 55 73 65 64 20 3d 20 30 3b 0a  t nNotUsed = 0;.
5360: 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74 61 74      sqlite3_stat
5370: 75 73 28 53 51 4c 49 54 45 5f 53 54 41 54 55 53  us(SQLITE_STATUS
5380: 5f 4d 41 4c 4c 4f 43 5f 43 4f 55 4e 54 2c 20 26  _MALLOC_COUNT, &
5390: 6e 41 6c 6c 6f 63 2c 20 26 6e 4e 6f 74 55 73 65  nAlloc, &nNotUse
53a0: 64 2c 20 30 29 3b 0a 20 20 20 20 66 70 72 69 6e  d, 0);.    fprin
53b0: 74 66 28 73 74 64 65 72 72 2c 22 4d 65 6d 6f 72  tf(stderr,"Memor
53c0: 79 20 6c 65 61 6b 20 69 6e 20 6d 75 74 61 74 6f  y leak in mutato
53d0: 72 3a 20 25 6c 6c 64 20 62 79 74 65 73 20 69 6e  r: %lld bytes in
53e0: 20 25 64 20 61 6c 6c 6f 63 61 74 69 6f 6e 73 5c   %d allocations\
53f0: 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  n",.            
5400: 73 71 6c 69 74 65 33 5f 6d 65 6d 6f 72 79 5f 75  sqlite3_memory_u
5410: 73 65 64 28 29 2c 20 6e 41 6c 6c 6f 63 29 3b 0a  sed(), nAlloc);.
5420: 20 20 20 20 65 78 69 74 28 31 29 3b 0a 20 20 7d      exit(1);.  }
5430: 0a 20 20 6d 65 6d 73 65 74 28 26 63 78 2c 20 30  .  memset(&cx, 0
5440: 2c 20 73 69 7a 65 6f 66 28 63 78 29 29 3b 0a 20  , sizeof(cx));. 
5450: 20 69 53 71 6c 20 3d 20 64 65 63 6f 64 65 44 61   iSql = decodeDa
5460: 74 61 62 61 73 65 28 28 75 6e 73 69 67 6e 65 64  tabase((unsigned
5470: 20 63 68 61 72 2a 29 61 44 61 74 61 2c 20 28 69   char*)aData, (i
5480: 6e 74 29 6e 42 79 74 65 2c 20 26 61 44 62 2c 20  nt)nByte, &aDb, 
5490: 26 6e 44 62 29 3b 0a 20 20 69 66 28 20 69 53 71  &nDb);.  if( iSq
54a0: 6c 3c 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a  l<0 ) return 0;.
54b0: 20 20 6e 53 71 6c 20 3d 20 28 69 6e 74 29 28 6e    nSql = (int)(n
54c0: 42 79 74 65 20 2d 20 69 53 71 6c 29 3b 0a 20 20  Byte - iSql);.  
54d0: 69 66 28 20 65 56 65 72 62 6f 73 69 74 79 3e 3d  if( eVerbosity>=
54e0: 33 20 29 7b 0a 20 20 20 20 70 72 69 6e 74 66 28  3 ){.    printf(
54f0: 0a 20 20 20 20 20 20 22 2a 2a 2a 2a 2a 2a 20 25  .      "****** %
5500: 64 2d 62 79 74 65 20 69 6e 70 75 74 2c 20 25 64  d-byte input, %d
5510: 2d 62 79 74 65 20 64 61 74 61 62 61 73 65 2c 20  -byte database, 
5520: 25 64 2d 62 79 74 65 20 73 63 72 69 70 74 20 22  %d-byte script "
5530: 0a 20 20 20 20 20 20 22 2a 2a 2a 2a 2a 2a 5c 6e  .      "******\n
5540: 22 2c 20 28 69 6e 74 29 6e 42 79 74 65 2c 20 6e  ", (int)nByte, n
5550: 44 62 2c 20 6e 53 71 6c 29 3b 0a 20 20 20 20 66  Db, nSql);.    f
5560: 66 6c 75 73 68 28 73 74 64 6f 75 74 29 3b 0a 20  flush(stdout);. 
5570: 20 7d 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65   }.  rc = sqlite
5580: 33 5f 6f 70 65 6e 28 30 2c 20 26 63 78 2e 64 62  3_open(0, &cx.db
5590: 29 3b 0a 20 20 69 66 28 20 72 63 20 29 20 72 65  );.  if( rc ) re
55a0: 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20 62 56  turn 1;.  if( bV
55b0: 64 62 65 44 65 62 75 67 20 29 7b 0a 20 20 20 20  dbeDebug ){.    
55c0: 73 71 6c 69 74 65 33 5f 65 78 65 63 28 63 78 2e  sqlite3_exec(cx.
55d0: 64 62 2c 20 22 50 52 41 47 4d 41 20 76 64 62 65  db, "PRAGMA vdbe
55e0: 5f 64 65 62 75 67 3d 4f 4e 22 2c 20 30 2c 20 30  _debug=ON", 0, 0
55f0: 2c 20 30 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20  , 0);.  }..  /* 
5600: 49 6e 76 6f 6b 65 20 74 68 65 20 70 72 6f 67 72  Invoke the progr
5610: 65 73 73 20 68 61 6e 64 6c 65 72 20 66 72 65 71  ess handler freq
5620: 75 65 6e 74 6c 79 20 74 6f 20 63 68 65 63 6b 20  uently to check 
5630: 74 6f 20 73 65 65 20 69 66 20 77 65 0a 20 20 2a  to see if we.  *
5640: 2a 20 61 72 65 20 74 61 6b 69 6e 67 20 74 6f 6f  * are taking too
5650: 20 6c 6f 6e 67 2e 20 20 54 68 65 20 70 72 6f 67   long.  The prog
5660: 72 65 73 73 20 68 61 6e 64 6c 65 72 20 77 69 6c  ress handler wil
5670: 6c 20 72 65 74 75 72 6e 20 74 72 75 65 0a 20 20  l return true.  
5680: 2a 2a 20 28 77 68 69 63 68 20 77 69 6c 6c 20 62  ** (which will b
5690: 6c 6f 63 6b 20 66 75 72 74 68 65 72 20 70 72 6f  lock further pro
56a0: 63 65 73 73 69 6e 67 29 20 69 66 20 6d 6f 72 65  cessing) if more
56b0: 20 74 68 61 6e 20 67 69 54 69 6d 65 6f 75 74 20   than giTimeout 
56c0: 73 65 63 6f 6e 64 73 20 68 61 76 65 0a 20 20 2a  seconds have.  *
56d0: 2a 20 65 6c 61 70 73 65 64 20 73 69 6e 63 65 20  * elapsed since 
56e0: 74 68 65 20 73 74 61 72 74 20 6f 66 20 74 68 65  the start of the
56f0: 20 74 65 73 74 2e 0a 20 20 2a 2f 0a 20 20 63 78   test..  */.  cx
5700: 2e 69 4c 61 73 74 43 62 20 3d 20 74 69 6d 65 4f  .iLastCb = timeO
5710: 66 44 61 79 28 29 3b 0a 20 20 63 78 2e 69 43 75  fDay();.  cx.iCu
5720: 74 6f 66 66 54 69 6d 65 20 3d 20 63 78 2e 69 4c  toffTime = cx.iL
5730: 61 73 74 43 62 20 2b 20 67 69 54 69 6d 65 6f 75  astCb + giTimeou
5740: 74 3b 20 20 2f 2a 20 4e 6f 77 20 2b 20 67 69 54  t;  /* Now + giT
5750: 69 6d 65 6f 75 74 20 73 65 63 6f 6e 64 73 20 2a  imeout seconds *
5760: 2f 0a 20 20 63 78 2e 6d 78 43 62 20 3d 20 6d 78  /.  cx.mxCb = mx
5770: 50 72 6f 67 72 65 73 73 43 62 3b 0a 23 69 66 6e  ProgressCb;.#ifn
5780: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
5790: 50 52 4f 47 52 45 53 53 5f 43 41 4c 4c 42 41 43  PROGRESS_CALLBAC
57a0: 4b 0a 20 20 73 71 6c 69 74 65 33 5f 70 72 6f 67  K.  sqlite3_prog
57b0: 72 65 73 73 5f 68 61 6e 64 6c 65 72 28 63 78 2e  ress_handler(cx.
57c0: 64 62 2c 20 31 30 2c 20 70 72 6f 67 72 65 73 73  db, 10, progress
57d0: 5f 68 61 6e 64 6c 65 72 2c 20 28 76 6f 69 64 2a  _handler, (void*
57e0: 29 26 63 78 29 3b 0a 23 65 6e 64 69 66 0a 0a 20  )&cx);.#endif.. 
57f0: 20 2f 2a 20 53 65 74 20 61 20 6c 69 6d 69 74 20   /* Set a limit 
5800: 6f 6e 20 74 68 65 20 6d 61 78 69 6d 75 6d 20 73  on the maximum s
5810: 69 7a 65 20 6f 66 20 61 20 70 72 65 70 61 72 65  ize of a prepare
5820: 64 20 73 74 61 74 65 6d 65 6e 74 2c 20 61 6e 64  d statement, and
5830: 20 74 68 65 0a 20 20 2a 2a 20 6d 61 78 69 6d 75   the.  ** maximu
5840: 6d 20 6c 65 6e 67 74 68 20 6f 66 20 61 20 73 74  m length of a st
5850: 72 69 6e 67 20 6f 72 20 62 6c 6f 62 20 2a 2f 0a  ring or blob */.
5860: 20 20 69 66 28 20 76 64 62 65 4f 70 4c 69 6d 69    if( vdbeOpLimi
5870: 74 3e 30 20 29 7b 0a 20 20 20 20 73 71 6c 69 74  t>0 ){.    sqlit
5880: 65 33 5f 6c 69 6d 69 74 28 63 78 2e 64 62 2c 20  e3_limit(cx.db, 
5890: 53 51 4c 49 54 45 5f 4c 49 4d 49 54 5f 56 44 42  SQLITE_LIMIT_VDB
58a0: 45 5f 4f 50 2c 20 76 64 62 65 4f 70 4c 69 6d 69  E_OP, vdbeOpLimi
58b0: 74 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 6c 65  t);.  }.  if( le
58c0: 6e 67 74 68 4c 69 6d 69 74 3e 30 20 29 7b 0a 20  ngthLimit>0 ){. 
58d0: 20 20 20 73 71 6c 69 74 65 33 5f 6c 69 6d 69 74     sqlite3_limit
58e0: 28 63 78 2e 64 62 2c 20 53 51 4c 49 54 45 5f 4c  (cx.db, SQLITE_L
58f0: 49 4d 49 54 5f 4c 45 4e 47 54 48 2c 20 6c 65 6e  IMIT_LENGTH, len
5900: 67 74 68 4c 69 6d 69 74 29 3b 0a 20 20 7d 0a 0a  gthLimit);.  }..
5910: 20 20 69 66 28 20 6e 44 62 3e 3d 32 30 20 26 26    if( nDb>=20 &&
5920: 20 61 44 62 5b 31 38 5d 3d 3d 32 20 26 26 20 61   aDb[18]==2 && a
5930: 44 62 5b 31 39 5d 3d 3d 32 20 29 7b 0a 20 20 20  Db[19]==2 ){.   
5940: 20 61 44 62 5b 31 38 5d 20 3d 20 61 44 62 5b 31   aDb[18] = aDb[1
5950: 39 5d 20 3d 20 31 3b 0a 20 20 7d 0a 20 20 72 63  9] = 1;.  }.  rc
5960: 20 3d 20 73 71 6c 69 74 65 33 5f 64 65 73 65 72   = sqlite3_deser
5970: 69 61 6c 69 7a 65 28 63 78 2e 64 62 2c 20 22 6d  ialize(cx.db, "m
5980: 61 69 6e 22 2c 20 61 44 62 2c 20 6e 44 62 2c 20  ain", aDb, nDb, 
5990: 6e 44 62 2c 0a 20 20 20 20 20 20 20 20 20 20 53  nDb,.          S
59a0: 51 4c 49 54 45 5f 44 45 53 45 52 49 41 4c 49 5a  QLITE_DESERIALIZ
59b0: 45 5f 52 45 53 49 5a 45 41 42 4c 45 20 7c 0a 20  E_RESIZEABLE |. 
59c0: 20 20 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f           SQLITE_
59d0: 44 45 53 45 52 49 41 4c 49 5a 45 5f 46 52 45 45  DESERIALIZE_FREE
59e0: 4f 4e 43 4c 4f 53 45 29 3b 0a 20 20 69 66 28 20  ONCLOSE);.  if( 
59f0: 72 63 20 29 7b 0a 20 20 20 20 66 70 72 69 6e 74  rc ){.    fprint
5a00: 66 28 73 74 64 65 72 72 2c 20 22 73 71 6c 69 74  f(stderr, "sqlit
5a10: 65 33 5f 64 65 73 65 72 69 61 6c 69 7a 65 28 29  e3_deserialize()
5a20: 20 66 61 69 6c 65 64 20 77 69 74 68 20 25 64 5c   failed with %d\
5a30: 6e 22 2c 20 72 63 29 3b 0a 20 20 20 20 67 6f 74  n", rc);.    got
5a40: 6f 20 74 65 73 74 72 75 6e 5f 66 69 6e 69 73 68  o testrun_finish
5a50: 65 64 3b 0a 20 20 7d 0a 20 20 69 66 28 20 6d 61  ed;.  }.  if( ma
5a60: 78 44 62 53 69 7a 65 3e 30 20 29 7b 0a 20 20 20  xDbSize>0 ){.   
5a70: 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 78   sqlite3_int64 x
5a80: 20 3d 20 6d 61 78 44 62 53 69 7a 65 3b 0a 20 20   = maxDbSize;.  
5a90: 20 20 73 71 6c 69 74 65 33 5f 66 69 6c 65 5f 63    sqlite3_file_c
5aa0: 6f 6e 74 72 6f 6c 28 63 78 2e 64 62 2c 20 22 6d  ontrol(cx.db, "m
5ab0: 61 69 6e 22 2c 20 53 51 4c 49 54 45 5f 46 43 4e  ain", SQLITE_FCN
5ac0: 54 4c 5f 53 49 5a 45 5f 4c 49 4d 49 54 2c 20 26  TL_SIZE_LIMIT, &
5ad0: 78 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 46 6f  x);.  }..  /* Fo
5ae0: 72 20 68 69 67 68 20 64 65 62 75 67 67 69 6e 67  r high debugging
5af0: 20 6c 65 76 65 6c 73 2c 20 74 75 72 6e 20 6f 6e   levels, turn on
5b00: 20 64 65 62 75 67 20 6d 6f 64 65 20 2a 2f 0a 20   debug mode */. 
5b10: 20 69 66 28 20 65 56 65 72 62 6f 73 69 74 79 3e   if( eVerbosity>
5b20: 3d 35 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65  =5 ){.    sqlite
5b30: 33 5f 65 78 65 63 28 63 78 2e 64 62 2c 20 22 50  3_exec(cx.db, "P
5b40: 52 41 47 4d 41 20 76 64 62 65 5f 64 65 62 75 67  RAGMA vdbe_debug
5b50: 3d 4f 4e 3b 22 2c 20 30 2c 20 30 2c 20 30 29 3b  =ON;", 0, 0, 0);
5b60: 0a 20 20 7d 0a 0a 20 20 2f 2a 20 42 6c 6f 63 6b  .  }..  /* Block
5b70: 20 64 65 62 75 67 20 70 72 61 67 6d 61 73 20 61   debug pragmas a
5b80: 6e 64 20 41 54 54 41 43 48 2f 44 45 54 41 43 48  nd ATTACH/DETACH
5b90: 2e 20 20 42 75 74 20 77 61 69 74 20 75 6e 74 69  .  But wait unti
5ba0: 6c 20 61 66 74 65 72 0a 20 20 2a 2a 20 64 65 73  l after.  ** des
5bb0: 65 72 69 61 6c 69 7a 65 20 74 6f 20 64 6f 20 74  erialize to do t
5bc0: 68 69 73 20 62 65 63 61 75 73 65 20 64 65 73 65  his because dese
5bd0: 72 69 61 6c 69 7a 65 20 64 65 70 65 6e 64 73 20  rialize depends 
5be0: 6f 6e 20 41 54 54 41 43 48 20 2a 2f 0a 20 20 73  on ATTACH */.  s
5bf0: 71 6c 69 74 65 33 5f 73 65 74 5f 61 75 74 68 6f  qlite3_set_autho
5c00: 72 69 7a 65 72 28 63 78 2e 64 62 2c 20 62 6c 6f  rizer(cx.db, blo
5c10: 63 6b 5f 74 72 6f 75 62 6c 65 73 6f 6d 65 5f 73  ck_troublesome_s
5c20: 71 6c 2c 20 30 29 3b 0a 0a 20 20 2f 2a 20 43 6f  ql, 0);..  /* Co
5c30: 6e 73 69 73 74 65 6e 74 20 50 52 4e 47 20 73 65  nsistent PRNG se
5c40: 65 64 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f  ed */.  sqlite3_
5c50: 72 61 6e 64 6f 6d 6e 65 73 73 28 30 2c 30 29 3b  randomness(0,0);
5c60: 0a 0a 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74  ..  zSql = sqlit
5c70: 65 33 5f 6d 61 6c 6c 6f 63 28 20 6e 53 71 6c 20  e3_malloc( nSql 
5c80: 2b 20 31 20 29 3b 0a 20 20 69 66 28 20 7a 53 71  + 1 );.  if( zSq
5c90: 6c 3d 3d 30 20 29 7b 0a 20 20 20 20 66 70 72 69  l==0 ){.    fpri
5ca0: 6e 74 66 28 73 74 64 65 72 72 2c 20 22 4f 75 74  ntf(stderr, "Out
5cb0: 20 6f 66 20 6d 65 6d 6f 72 79 21 5c 6e 22 29 3b   of memory!\n");
5cc0: 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 6d 65  .  }else{.    me
5cd0: 6d 63 70 79 28 7a 53 71 6c 2c 20 61 44 61 74 61  mcpy(zSql, aData
5ce0: 2b 69 53 71 6c 2c 20 6e 53 71 6c 29 3b 0a 20 20  +iSql, nSql);.  
5cf0: 20 20 7a 53 71 6c 5b 6e 53 71 6c 5d 20 3d 20 30    zSql[nSql] = 0
5d00: 3b 0a 20 20 20 20 66 6f 72 28 69 3d 6a 3d 30 3b  ;.    for(i=j=0;
5d10: 20 7a 53 71 6c 5b 69 5d 3b 20 69 2b 2b 29 7b 0a   zSql[i]; i++){.
5d20: 20 20 20 20 20 20 69 66 28 20 7a 53 71 6c 5b 69        if( zSql[i
5d30: 5d 3d 3d 27 3b 27 20 29 7b 0a 20 20 20 20 20 20  ]==';' ){.      
5d40: 20 20 63 68 61 72 20 63 53 61 76 65 64 20 3d 20    char cSaved = 
5d50: 7a 53 71 6c 5b 69 2b 31 5d 3b 0a 20 20 20 20 20  zSql[i+1];.     
5d60: 20 20 20 7a 53 71 6c 5b 69 2b 31 5d 20 3d 20 30     zSql[i+1] = 0
5d70: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 73 71  ;.        if( sq
5d80: 6c 69 74 65 33 5f 63 6f 6d 70 6c 65 74 65 28 7a  lite3_complete(z
5d90: 53 71 6c 2b 6a 29 20 29 7b 0a 20 20 20 20 20 20  Sql+j) ){.      
5da0: 20 20 20 20 72 63 20 3d 20 72 75 6e 44 62 53 71      rc = runDbSq
5db0: 6c 28 63 78 2e 64 62 2c 20 7a 53 71 6c 2b 6a 29  l(cx.db, zSql+j)
5dc0: 3b 0a 20 20 20 20 20 20 20 20 20 20 6a 20 3d 20  ;.          j = 
5dd0: 69 2b 31 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  i+1;.        }. 
5de0: 20 20 20 20 20 20 20 7a 53 71 6c 5b 69 2b 31 5d         zSql[i+1]
5df0: 20 3d 20 63 53 61 76 65 64 3b 0a 20 20 20 20 20   = cSaved;.     
5e00: 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54     if( rc==SQLIT
5e10: 45 5f 49 4e 54 45 52 52 55 50 54 20 7c 7c 20 70  E_INTERRUPT || p
5e20: 72 6f 67 72 65 73 73 5f 68 61 6e 64 6c 65 72 28  rogress_handler(
5e30: 26 63 78 29 20 29 7b 0a 20 20 20 20 20 20 20 20  &cx) ){.        
5e40: 20 20 67 6f 74 6f 20 74 65 73 74 72 75 6e 5f 66    goto testrun_f
5e50: 69 6e 69 73 68 65 64 3b 0a 20 20 20 20 20 20 20  inished;.       
5e60: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d   }.      }.    }
5e70: 0a 20 20 20 20 69 66 28 20 6a 3c 69 20 29 7b 0a  .    if( j<i ){.
5e80: 20 20 20 20 20 20 72 75 6e 44 62 53 71 6c 28 63        runDbSql(c
5e90: 78 2e 64 62 2c 20 7a 53 71 6c 2b 6a 29 3b 0a 20  x.db, zSql+j);. 
5ea0: 20 20 20 7d 0a 20 20 7d 0a 74 65 73 74 72 75 6e     }.  }.testrun
5eb0: 5f 66 69 6e 69 73 68 65 64 3a 0a 20 20 73 71 6c  _finished:.  sql
5ec0: 69 74 65 33 5f 66 72 65 65 28 7a 53 71 6c 29 3b  ite3_free(zSql);
5ed0: 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f  .  rc = sqlite3_
5ee0: 63 6c 6f 73 65 28 63 78 2e 64 62 29 3b 0a 20 20  close(cx.db);.  
5ef0: 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f  if( rc!=SQLITE_O
5f00: 4b 20 29 7b 0a 20 20 20 20 66 70 72 69 6e 74 66  K ){.    fprintf
5f10: 28 73 74 64 6f 75 74 2c 20 22 73 71 6c 69 74 65  (stdout, "sqlite
5f20: 33 5f 63 6c 6f 73 65 28 29 20 72 65 74 75 72 6e  3_close() return
5f30: 73 20 25 64 5c 6e 22 2c 20 72 63 29 3b 0a 20 20  s %d\n", rc);.  
5f40: 7d 0a 20 20 69 66 28 20 65 56 65 72 62 6f 73 69  }.  if( eVerbosi
5f50: 74 79 3e 3d 32 20 29 7b 0a 20 20 20 20 66 70 72  ty>=2 ){.    fpr
5f60: 69 6e 74 66 28 73 74 64 6f 75 74 2c 20 22 50 65  intf(stdout, "Pe
5f70: 61 6b 20 6d 65 6d 6f 72 79 20 75 73 61 67 65 73  ak memory usages
5f80: 3a 20 25 66 20 4d 42 5c 6e 22 2c 0a 20 20 20 20  : %f MB\n",.    
5f90: 20 20 20 73 71 6c 69 74 65 33 5f 6d 65 6d 6f 72     sqlite3_memor
5fa0: 79 5f 68 69 67 68 77 61 74 65 72 28 31 29 20 2f  y_highwater(1) /
5fb0: 20 31 30 30 30 30 30 30 2e 30 29 3b 0a 20 20 7d   1000000.0);.  }
5fc0: 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f 6d  .  if( sqlite3_m
5fd0: 65 6d 6f 72 79 5f 75 73 65 64 28 29 21 3d 30 20  emory_used()!=0 
5fe0: 29 7b 0a 20 20 20 20 69 6e 74 20 6e 41 6c 6c 6f  ){.    int nAllo
5ff0: 63 20 3d 20 30 3b 0a 20 20 20 20 69 6e 74 20 6e  c = 0;.    int n
6000: 4e 6f 74 55 73 65 64 20 3d 20 30 3b 0a 20 20 20  NotUsed = 0;.   
6010: 20 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28   sqlite3_status(
6020: 53 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 4d 41  SQLITE_STATUS_MA
6030: 4c 4c 4f 43 5f 43 4f 55 4e 54 2c 20 26 6e 41 6c  LLOC_COUNT, &nAl
6040: 6c 6f 63 2c 20 26 6e 4e 6f 74 55 73 65 64 2c 20  loc, &nNotUsed, 
6050: 30 29 3b 0a 20 20 20 20 66 70 72 69 6e 74 66 28  0);.    fprintf(
6060: 73 74 64 65 72 72 2c 22 4d 65 6d 6f 72 79 20 6c  stderr,"Memory l
6070: 65 61 6b 3a 20 25 6c 6c 64 20 62 79 74 65 73 20  eak: %lld bytes 
6080: 69 6e 20 25 64 20 61 6c 6c 6f 63 61 74 69 6f 6e  in %d allocation
6090: 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20  s\n",.          
60a0: 20 20 73 71 6c 69 74 65 33 5f 6d 65 6d 6f 72 79    sqlite3_memory
60b0: 5f 75 73 65 64 28 29 2c 20 6e 41 6c 6c 6f 63 29  _used(), nAlloc)
60c0: 3b 0a 20 20 20 20 65 78 69 74 28 31 29 3b 0a 20  ;.    exit(1);. 
60d0: 20 7d 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d   }.  return 0;.}
60e0: 0a 0a 2f 2a 0a 2a 2a 20 45 4e 44 20 6f 66 20 74  ../*.** END of t
60f0: 68 65 20 64 62 73 71 6c 66 75 7a 7a 20 63 6f 64  he dbsqlfuzz cod
6100: 65 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e.**************
6110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 0a  *************/..
6150: 2f 2a 20 4c 6f 6f 6b 20 61 74 20 61 20 53 51 4c  /* Look at a SQL
6160: 20 74 65 78 74 20 61 6e 64 20 74 72 79 20 74 6f   text and try to
6170: 20 64 65 74 65 72 6d 69 6e 65 20 69 66 20 69 74   determine if it
6180: 20 62 65 67 69 6e 73 20 77 69 74 68 20 61 20 64   begins with a d
6190: 61 74 61 62 61 73 65 0a 2a 2a 20 64 65 73 63 72  atabase.** descr
61a0: 69 70 74 69 6f 6e 2c 20 73 75 63 68 20 61 73 20  iption, such as 
61b0: 77 6f 75 6c 64 20 62 65 20 66 6f 75 6e 64 20 69  would be found i
61c0: 6e 20 61 20 64 62 73 71 6c 66 75 7a 7a 20 74 65  n a dbsqlfuzz te
61d0: 73 74 20 63 61 73 65 2e 20 20 52 65 74 75 72 6e  st case.  Return
61e0: 0a 2a 2a 20 74 72 75 65 20 69 66 20 74 68 69 73  .** true if this
61f0: 20 64 6f 65 73 20 61 70 70 65 61 72 20 74 6f 20   does appear to 
6200: 62 65 20 61 20 64 62 73 71 6c 66 75 7a 7a 20 74  be a dbsqlfuzz t
6210: 65 73 74 20 63 61 73 65 20 61 6e 64 20 66 61 6c  est case and fal
6220: 73 65 20 6f 74 68 65 72 77 69 73 65 2e 0a 2a 2f  se otherwise..*/
6230: 0a 73 74 61 74 69 63 20 69 6e 74 20 69 73 44 62  .static int isDb
6240: 53 71 6c 28 75 6e 73 69 67 6e 65 64 20 63 68 61  Sql(unsigned cha
6250: 72 20 2a 61 2c 20 69 6e 74 20 6e 29 7b 0a 20 20  r *a, int n){.  
6260: 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20 62 75  unsigned char bu
6270: 66 5b 31 32 5d 3b 0a 20 20 69 6e 74 20 69 3b 0a  f[12];.  int i;.
6280: 20 20 69 66 28 20 6e 3e 34 20 26 26 20 6d 65 6d    if( n>4 && mem
6290: 63 6d 70 28 61 2c 22 5c 6e 2d 2d 5c 6e 22 2c 34  cmp(a,"\n--\n",4
62a0: 29 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 31 3b  )==0 ) return 1;
62b0: 0a 20 20 77 68 69 6c 65 28 20 6e 3e 30 20 26 26  .  while( n>0 &&
62c0: 20 69 73 73 70 61 63 65 28 61 5b 30 5d 29 20 29   isspace(a[0]) )
62d0: 7b 20 61 2b 2b 3b 20 6e 2d 2d 3b 20 7d 0a 20 20  { a++; n--; }.  
62e0: 66 6f 72 28 69 3d 30 3b 20 6e 3e 30 20 26 26 20  for(i=0; n>0 && 
62f0: 69 3c 38 3b 20 6e 2d 2d 2c 20 61 2b 2b 29 7b 0a  i<8; n--, a++){.
6300: 20 20 20 20 69 66 28 20 69 73 78 64 69 67 69 74      if( isxdigit
6310: 28 61 5b 30 5d 29 20 29 20 62 75 66 5b 69 2b 2b  (a[0]) ) buf[i++
6320: 5d 20 3d 20 61 5b 30 5d 3b 0a 20 20 7d 0a 20 20  ] = a[0];.  }.  
6330: 69 66 28 20 69 3d 3d 38 20 26 26 20 6d 65 6d 63  if( i==8 && memc
6340: 6d 70 28 62 75 66 2c 22 35 33 35 31 34 63 36 39  mp(buf,"53514c69
6350: 22 2c 38 29 3d 3d 30 20 29 20 72 65 74 75 72 6e  ",8)==0 ) return
6360: 20 31 3b 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a   1;.  return 0;.
6370: 7d 0a 0a 2f 2a 20 49 6d 70 6c 65 6d 65 6e 74 61  }../* Implementa
6380: 74 69 6f 6e 20 6f 66 20 74 68 65 20 69 73 64 62  tion of the isdb
6390: 73 71 6c 28 54 45 58 54 29 20 53 51 4c 20 66 75  sql(TEXT) SQL fu
63a0: 6e 63 74 69 6f 6e 2e 0a 2a 2f 0a 73 74 61 74 69  nction..*/.stati
63b0: 63 20 76 6f 69 64 20 69 73 44 62 53 71 6c 46 75  c void isDbSqlFu
63c0: 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  nc(.  sqlite3_co
63d0: 6e 74 65 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a  ntext *context,.
63e0: 20 20 69 6e 74 20 61 72 67 63 2c 0a 20 20 73 71    int argc,.  sq
63f0: 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72  lite3_value **ar
6400: 67 76 0a 29 7b 0a 20 20 69 6e 74 20 6e 20 3d 20  gv.){.  int n = 
6410: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 79  sqlite3_value_by
6420: 74 65 73 28 61 72 67 76 5b 30 5d 29 3b 0a 20 20  tes(argv[0]);.  
6430: 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a 61  unsigned char *a
6440: 20 3d 20 28 75 6e 73 69 67 6e 65 64 20 63 68 61   = (unsigned cha
6450: 72 2a 29 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  r*)sqlite3_value
6460: 5f 62 6c 6f 62 28 61 72 67 76 5b 30 5d 29 3b 0a  _blob(argv[0]);.
6470: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
6480: 5f 69 6e 74 28 63 6f 6e 74 65 78 74 2c 20 61 21  _int(context, a!
6490: 3d 30 20 26 26 20 6e 3e 30 20 26 26 20 69 73 44  =0 && n>0 && isD
64a0: 62 53 71 6c 28 61 2c 6e 29 29 3b 0a 7d 0a 0a 2f  bSql(a,n));.}../
64b0: 2a 20 4d 65 74 68 6f 64 73 20 66 6f 72 20 74 68  * Methods for th
64c0: 65 20 56 48 61 6e 64 6c 65 20 6f 62 6a 65 63 74  e VHandle object
64d0: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 69  .*/.static int i
64e0: 6e 6d 65 6d 43 6c 6f 73 65 28 73 71 6c 69 74 65  nmemClose(sqlite
64f0: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 29 7b 0a  3_file *pFile){.
6500: 20 20 56 48 61 6e 64 6c 65 20 2a 70 20 3d 20 28    VHandle *p = (
6510: 56 48 61 6e 64 6c 65 2a 29 70 46 69 6c 65 3b 0a  VHandle*)pFile;.
6520: 20 20 56 46 69 6c 65 20 2a 70 56 46 69 6c 65 20    VFile *pVFile 
6530: 3d 20 70 2d 3e 70 56 46 69 6c 65 3b 0a 20 20 70  = p->pVFile;.  p
6540: 56 46 69 6c 65 2d 3e 6e 52 65 66 2d 2d 3b 0a 20  VFile->nRef--;. 
6550: 20 69 66 28 20 70 56 46 69 6c 65 2d 3e 6e 52 65   if( pVFile->nRe
6560: 66 3d 3d 30 20 26 26 20 70 56 46 69 6c 65 2d 3e  f==0 && pVFile->
6570: 7a 46 69 6c 65 6e 61 6d 65 3d 3d 30 20 29 7b 0a  zFilename==0 ){.
6580: 20 20 20 20 70 56 46 69 6c 65 2d 3e 73 7a 20 3d      pVFile->sz =
6590: 20 2d 31 3b 0a 20 20 20 20 66 72 65 65 28 70 56   -1;.    free(pV
65a0: 46 69 6c 65 2d 3e 61 29 3b 0a 20 20 20 20 70 56  File->a);.    pV
65b0: 46 69 6c 65 2d 3e 61 20 3d 20 30 3b 0a 20 20 7d  File->a = 0;.  }
65c0: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
65d0: 5f 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e  _OK;.}.static in
65e0: 74 20 69 6e 6d 65 6d 52 65 61 64 28 0a 20 20 73  t inmemRead(.  s
65f0: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69  qlite3_file *pFi
6600: 6c 65 2c 20 20 20 2f 2a 20 52 65 61 64 20 66 72  le,   /* Read fr
6610: 6f 6d 20 74 68 69 73 20 6f 70 65 6e 20 66 69 6c  om this open fil
6620: 65 20 2a 2f 0a 20 20 76 6f 69 64 20 2a 70 44 61  e */.  void *pDa
6630: 74 61 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ta,           /*
6640: 20 53 74 6f 72 65 20 63 6f 6e 74 65 6e 74 20 69   Store content i
6650: 6e 20 74 68 69 73 20 62 75 66 66 65 72 20 2a 2f  n this buffer */
6660: 0a 20 20 69 6e 74 20 69 41 6d 74 2c 20 20 20 20  .  int iAmt,    
6670: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 42 79 74            /* Byt
6680: 65 73 20 6f 66 20 63 6f 6e 74 65 6e 74 20 2a 2f  es of content */
6690: 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34  .  sqlite3_int64
66a0: 20 69 4f 66 73 74 20 20 20 20 2f 2a 20 53 74 61   iOfst    /* Sta
66b0: 72 74 20 72 65 61 64 69 6e 67 20 68 65 72 65 20  rt reading here 
66c0: 2a 2f 0a 29 7b 0a 20 20 56 48 61 6e 64 6c 65 20  */.){.  VHandle 
66d0: 2a 70 48 61 6e 64 6c 65 20 3d 20 28 56 48 61 6e  *pHandle = (VHan
66e0: 64 6c 65 2a 29 70 46 69 6c 65 3b 0a 20 20 56 46  dle*)pFile;.  VF
66f0: 69 6c 65 20 2a 70 56 46 69 6c 65 20 3d 20 70 48  ile *pVFile = pH
6700: 61 6e 64 6c 65 2d 3e 70 56 46 69 6c 65 3b 0a 20  andle->pVFile;. 
6710: 20 69 66 28 20 69 4f 66 73 74 3c 30 20 7c 7c 20   if( iOfst<0 || 
6720: 69 4f 66 73 74 3e 3d 70 56 46 69 6c 65 2d 3e 73  iOfst>=pVFile->s
6730: 7a 20 29 7b 0a 20 20 20 20 6d 65 6d 73 65 74 28  z ){.    memset(
6740: 70 44 61 74 61 2c 20 30 2c 20 69 41 6d 74 29 3b  pData, 0, iAmt);
6750: 0a 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49  .    return SQLI
6760: 54 45 5f 49 4f 45 52 52 5f 53 48 4f 52 54 5f 52  TE_IOERR_SHORT_R
6770: 45 41 44 3b 0a 20 20 7d 0a 20 20 69 66 28 20 69  EAD;.  }.  if( i
6780: 4f 66 73 74 2b 69 41 6d 74 3e 70 56 46 69 6c 65  Ofst+iAmt>pVFile
6790: 2d 3e 73 7a 20 29 7b 0a 20 20 20 20 6d 65 6d 73  ->sz ){.    mems
67a0: 65 74 28 70 44 61 74 61 2c 20 30 2c 20 69 41 6d  et(pData, 0, iAm
67b0: 74 29 3b 0a 20 20 20 20 69 41 6d 74 20 3d 20 28  t);.    iAmt = (
67c0: 69 6e 74 29 28 70 56 46 69 6c 65 2d 3e 73 7a 20  int)(pVFile->sz 
67d0: 2d 20 69 4f 66 73 74 29 3b 0a 20 20 20 20 6d 65  - iOfst);.    me
67e0: 6d 63 70 79 28 70 44 61 74 61 2c 20 70 56 46 69  mcpy(pData, pVFi
67f0: 6c 65 2d 3e 61 20 2b 20 69 4f 66 73 74 2c 20 69  le->a + iOfst, i
6800: 41 6d 74 29 3b 0a 20 20 20 20 72 65 74 75 72 6e  Amt);.    return
6810: 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 53 48   SQLITE_IOERR_SH
6820: 4f 52 54 5f 52 45 41 44 3b 0a 20 20 7d 0a 20 20  ORT_READ;.  }.  
6830: 6d 65 6d 63 70 79 28 70 44 61 74 61 2c 20 70 56  memcpy(pData, pV
6840: 46 69 6c 65 2d 3e 61 20 2b 20 69 4f 66 73 74 2c  File->a + iOfst,
6850: 20 69 41 6d 74 29 3b 0a 20 20 72 65 74 75 72 6e   iAmt);.  return
6860: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 73 74   SQLITE_OK;.}.st
6870: 61 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d 57 72  atic int inmemWr
6880: 69 74 65 28 0a 20 20 73 71 6c 69 74 65 33 5f 66  ite(.  sqlite3_f
6890: 69 6c 65 20 2a 70 46 69 6c 65 2c 20 20 20 2f 2a  ile *pFile,   /*
68a0: 20 57 72 69 74 65 20 74 6f 20 74 68 69 73 20 66   Write to this f
68b0: 69 6c 65 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 76  ile */.  const v
68c0: 6f 69 64 20 2a 70 44 61 74 61 2c 20 20 20 20 20  oid *pData,     
68d0: 2f 2a 20 43 6f 6e 74 65 6e 74 20 74 6f 20 77 72  /* Content to wr
68e0: 69 74 65 20 2a 2f 0a 20 20 69 6e 74 20 69 41 6d  ite */.  int iAm
68f0: 74 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t,              
6900: 2f 2a 20 62 79 74 65 73 20 74 6f 20 77 72 69 74  /* bytes to writ
6910: 65 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 69  e */.  sqlite3_i
6920: 6e 74 36 34 20 69 4f 66 73 74 20 20 20 20 2f 2a  nt64 iOfst    /*
6930: 20 53 74 61 72 74 20 77 72 69 74 69 6e 67 20 68   Start writing h
6940: 65 72 65 20 2a 2f 0a 29 7b 0a 20 20 56 48 61 6e  ere */.){.  VHan
6950: 64 6c 65 20 2a 70 48 61 6e 64 6c 65 20 3d 20 28  dle *pHandle = (
6960: 56 48 61 6e 64 6c 65 2a 29 70 46 69 6c 65 3b 0a  VHandle*)pFile;.
6970: 20 20 56 46 69 6c 65 20 2a 70 56 46 69 6c 65 20    VFile *pVFile 
6980: 3d 20 70 48 61 6e 64 6c 65 2d 3e 70 56 46 69 6c  = pHandle->pVFil
6990: 65 3b 0a 20 20 69 66 28 20 69 4f 66 73 74 2b 69  e;.  if( iOfst+i
69a0: 41 6d 74 20 3e 20 70 56 46 69 6c 65 2d 3e 73 7a  Amt > pVFile->sz
69b0: 20 29 7b 0a 20 20 20 20 69 66 28 20 69 4f 66 73   ){.    if( iOfs
69c0: 74 2b 69 41 6d 74 20 3e 3d 20 4d 58 5f 46 49 4c  t+iAmt >= MX_FIL
69d0: 45 5f 53 5a 20 29 7b 0a 20 20 20 20 20 20 72 65  E_SZ ){.      re
69e0: 74 75 72 6e 20 53 51 4c 49 54 45 5f 46 55 4c 4c  turn SQLITE_FULL
69f0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 70 56 46 69  ;.    }.    pVFi
6a00: 6c 65 2d 3e 61 20 3d 20 73 61 66 65 5f 72 65 61  le->a = safe_rea
6a10: 6c 6c 6f 63 28 70 56 46 69 6c 65 2d 3e 61 2c 20  lloc(pVFile->a, 
6a20: 28 69 6e 74 29 28 69 4f 66 73 74 2b 69 41 6d 74  (int)(iOfst+iAmt
6a30: 29 29 3b 0a 20 20 20 20 69 66 28 20 69 4f 66 73  ));.    if( iOfs
6a40: 74 20 3e 20 70 56 46 69 6c 65 2d 3e 73 7a 20 29  t > pVFile->sz )
6a50: 7b 0a 20 20 20 20 20 20 6d 65 6d 73 65 74 28 70  {.      memset(p
6a60: 56 46 69 6c 65 2d 3e 61 20 2b 20 70 56 46 69 6c  VFile->a + pVFil
6a70: 65 2d 3e 73 7a 2c 20 30 2c 20 28 69 6e 74 29 28  e->sz, 0, (int)(
6a80: 69 4f 66 73 74 20 2d 20 70 56 46 69 6c 65 2d 3e  iOfst - pVFile->
6a90: 73 7a 29 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  sz));.    }.    
6aa0: 70 56 46 69 6c 65 2d 3e 73 7a 20 3d 20 28 69 6e  pVFile->sz = (in
6ab0: 74 29 28 69 4f 66 73 74 20 2b 20 69 41 6d 74 29  t)(iOfst + iAmt)
6ac0: 3b 0a 20 20 7d 0a 20 20 6d 65 6d 63 70 79 28 70  ;.  }.  memcpy(p
6ad0: 56 46 69 6c 65 2d 3e 61 20 2b 20 69 4f 66 73 74  VFile->a + iOfst
6ae0: 2c 20 70 44 61 74 61 2c 20 69 41 6d 74 29 3b 0a  , pData, iAmt);.
6af0: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
6b00: 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e 74  OK;.}.static int
6b10: 20 69 6e 6d 65 6d 54 72 75 6e 63 61 74 65 28 73   inmemTruncate(s
6b20: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69  qlite3_file *pFi
6b30: 6c 65 2c 20 73 71 6c 69 74 65 33 5f 69 6e 74 36  le, sqlite3_int6
6b40: 34 20 69 53 69 7a 65 29 7b 0a 20 20 56 48 61 6e  4 iSize){.  VHan
6b50: 64 6c 65 20 2a 70 48 61 6e 64 6c 65 20 3d 20 28  dle *pHandle = (
6b60: 56 48 61 6e 64 6c 65 2a 29 70 46 69 6c 65 3b 0a  VHandle*)pFile;.
6b70: 20 20 56 46 69 6c 65 20 2a 70 56 46 69 6c 65 20    VFile *pVFile 
6b80: 3d 20 70 48 61 6e 64 6c 65 2d 3e 70 56 46 69 6c  = pHandle->pVFil
6b90: 65 3b 0a 20 20 69 66 28 20 70 56 46 69 6c 65 2d  e;.  if( pVFile-
6ba0: 3e 73 7a 3e 69 53 69 7a 65 20 26 26 20 69 53 69  >sz>iSize && iSi
6bb0: 7a 65 3e 3d 30 20 29 20 70 56 46 69 6c 65 2d 3e  ze>=0 ) pVFile->
6bc0: 73 7a 20 3d 20 28 69 6e 74 29 69 53 69 7a 65 3b  sz = (int)iSize;
6bd0: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
6be0: 5f 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e  _OK;.}.static in
6bf0: 74 20 69 6e 6d 65 6d 53 79 6e 63 28 73 71 6c 69  t inmemSync(sqli
6c00: 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c  te3_file *pFile,
6c10: 20 69 6e 74 20 66 6c 61 67 73 29 7b 0a 20 20 72   int flags){.  r
6c20: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b  eturn SQLITE_OK;
6c30: 0a 7d 0a 73 74 61 74 69 63 20 69 6e 74 20 69 6e  .}.static int in
6c40: 6d 65 6d 46 69 6c 65 53 69 7a 65 28 73 71 6c 69  memFileSize(sqli
6c50: 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c  te3_file *pFile,
6c60: 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 2a   sqlite3_int64 *
6c70: 70 53 69 7a 65 29 7b 0a 20 20 2a 70 53 69 7a 65  pSize){.  *pSize
6c80: 20 3d 20 28 28 56 48 61 6e 64 6c 65 2a 29 70 46   = ((VHandle*)pF
6c90: 69 6c 65 29 2d 3e 70 56 46 69 6c 65 2d 3e 73 7a  ile)->pVFile->sz
6ca0: 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54  ;.  return SQLIT
6cb0: 45 5f 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69  E_OK;.}.static i
6cc0: 6e 74 20 69 6e 6d 65 6d 4c 6f 63 6b 28 73 71 6c  nt inmemLock(sql
6cd0: 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65  ite3_file *pFile
6ce0: 2c 20 69 6e 74 20 74 79 70 65 29 7b 0a 20 20 72  , int type){.  r
6cf0: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b  eturn SQLITE_OK;
6d00: 0a 7d 0a 73 74 61 74 69 63 20 69 6e 74 20 69 6e  .}.static int in
6d10: 6d 65 6d 55 6e 6c 6f 63 6b 28 73 71 6c 69 74 65  memUnlock(sqlite
6d20: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69  3_file *pFile, i
6d30: 6e 74 20 74 79 70 65 29 7b 0a 20 20 72 65 74 75  nt type){.  retu
6d40: 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a  rn SQLITE_OK;.}.
6d50: 73 74 61 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d  static int inmem
6d60: 43 68 65 63 6b 52 65 73 65 72 76 65 64 4c 6f 63  CheckReservedLoc
6d70: 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  k(sqlite3_file *
6d80: 70 46 69 6c 65 2c 20 69 6e 74 20 2a 70 4f 75 74  pFile, int *pOut
6d90: 29 7b 0a 20 20 2a 70 4f 75 74 20 3d 20 30 3b 0a  ){.  *pOut = 0;.
6da0: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
6db0: 4f 4b 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e 74  OK;.}.static int
6dc0: 20 69 6e 6d 65 6d 46 69 6c 65 43 6f 6e 74 72 6f   inmemFileContro
6dd0: 6c 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  l(sqlite3_file *
6de0: 70 46 69 6c 65 2c 20 69 6e 74 20 6f 70 2c 20 76  pFile, int op, v
6df0: 6f 69 64 20 2a 70 41 72 67 29 7b 0a 20 20 72 65  oid *pArg){.  re
6e00: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 54 46  turn SQLITE_NOTF
6e10: 4f 55 4e 44 3b 0a 7d 0a 73 74 61 74 69 63 20 69  OUND;.}.static i
6e20: 6e 74 20 69 6e 6d 65 6d 53 65 63 74 6f 72 53 69  nt inmemSectorSi
6e30: 7a 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20  ze(sqlite3_file 
6e40: 2a 70 46 69 6c 65 29 7b 0a 20 20 72 65 74 75 72  *pFile){.  retur
6e50: 6e 20 35 31 32 3b 0a 7d 0a 73 74 61 74 69 63 20  n 512;.}.static 
6e60: 69 6e 74 20 69 6e 6d 65 6d 44 65 76 69 63 65 43  int inmemDeviceC
6e70: 68 61 72 61 63 74 65 72 69 73 74 69 63 73 28 73  haracteristics(s
6e80: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69  qlite3_file *pFi
6e90: 6c 65 29 7b 0a 20 20 72 65 74 75 72 6e 0a 20 20  le){.  return.  
6ea0: 20 20 20 20 53 51 4c 49 54 45 5f 49 4f 43 41 50      SQLITE_IOCAP
6eb0: 5f 53 41 46 45 5f 41 50 50 45 4e 44 20 7c 0a 20  _SAFE_APPEND |. 
6ec0: 20 20 20 20 20 53 51 4c 49 54 45 5f 49 4f 43 41       SQLITE_IOCA
6ed0: 50 5f 55 4e 44 45 4c 45 54 41 42 4c 45 5f 57 48  P_UNDELETABLE_WH
6ee0: 45 4e 5f 4f 50 45 4e 20 7c 0a 20 20 20 20 20 20  EN_OPEN |.      
6ef0: 53 51 4c 49 54 45 5f 49 4f 43 41 50 5f 50 4f 57  SQLITE_IOCAP_POW
6f00: 45 52 53 41 46 45 5f 4f 56 45 52 57 52 49 54 45  ERSAFE_OVERWRITE
6f10: 3b 0a 7d 0a 0a 0a 2f 2a 20 4d 65 74 68 6f 64 20  ;.}.../* Method 
6f20: 74 61 62 6c 65 20 66 6f 72 20 56 48 61 6e 64 6c  table for VHandl
6f30: 65 0a 2a 2f 0a 73 74 61 74 69 63 20 73 71 6c 69  e.*/.static sqli
6f40: 74 65 33 5f 69 6f 5f 6d 65 74 68 6f 64 73 20 56  te3_io_methods V
6f50: 48 61 6e 64 6c 65 4d 65 74 68 6f 64 73 20 3d 20  HandleMethods = 
6f60: 7b 0a 20 20 2f 2a 20 69 56 65 72 73 69 6f 6e 20  {.  /* iVersion 
6f70: 20 2a 2f 20 20 20 20 31 2c 0a 20 20 2f 2a 20 78   */    1,.  /* x
6f80: 43 6c 6f 73 65 20 20 20 20 2a 2f 20 20 20 20 69  Close    */    i
6f90: 6e 6d 65 6d 43 6c 6f 73 65 2c 0a 20 20 2f 2a 20  nmemClose,.  /* 
6fa0: 78 52 65 61 64 20 20 20 20 20 2a 2f 20 20 20 20  xRead     */    
6fb0: 69 6e 6d 65 6d 52 65 61 64 2c 0a 20 20 2f 2a 20  inmemRead,.  /* 
6fc0: 78 57 72 69 74 65 20 20 20 20 2a 2f 20 20 20 20  xWrite    */    
6fd0: 69 6e 6d 65 6d 57 72 69 74 65 2c 0a 20 20 2f 2a  inmemWrite,.  /*
6fe0: 20 78 54 72 75 6e 63 61 74 65 20 2a 2f 20 20 20   xTruncate */   
6ff0: 20 69 6e 6d 65 6d 54 72 75 6e 63 61 74 65 2c 0a   inmemTruncate,.
7000: 20 20 2f 2a 20 78 53 79 6e 63 20 20 20 20 20 2a    /* xSync     *
7010: 2f 20 20 20 20 69 6e 6d 65 6d 53 79 6e 63 2c 0a  /    inmemSync,.
7020: 20 20 2f 2a 20 78 46 69 6c 65 53 69 7a 65 20 2a    /* xFileSize *
7030: 2f 20 20 20 20 69 6e 6d 65 6d 46 69 6c 65 53 69  /    inmemFileSi
7040: 7a 65 2c 0a 20 20 2f 2a 20 78 4c 6f 63 6b 20 20  ze,.  /* xLock  
7050: 20 20 20 2a 2f 20 20 20 20 69 6e 6d 65 6d 4c 6f     */    inmemLo
7060: 63 6b 2c 0a 20 20 2f 2a 20 78 55 6e 6c 6f 63 6b  ck,.  /* xUnlock
7070: 20 20 20 2a 2f 20 20 20 20 69 6e 6d 65 6d 55 6e     */    inmemUn
7080: 6c 6f 63 6b 2c 0a 20 20 2f 2a 20 78 43 68 65 63  lock,.  /* xChec
7090: 6b 2e 2e 2e 20 2a 2f 20 20 20 20 69 6e 6d 65 6d  k... */    inmem
70a0: 43 68 65 63 6b 52 65 73 65 72 76 65 64 4c 6f 63  CheckReservedLoc
70b0: 6b 2c 0a 20 20 2f 2a 20 78 46 69 6c 65 43 74 72  k,.  /* xFileCtr
70c0: 6c 20 2a 2f 20 20 20 20 69 6e 6d 65 6d 46 69 6c  l */    inmemFil
70d0: 65 43 6f 6e 74 72 6f 6c 2c 0a 20 20 2f 2a 20 78  eControl,.  /* x
70e0: 53 65 63 74 6f 72 53 7a 20 2a 2f 20 20 20 20 69  SectorSz */    i
70f0: 6e 6d 65 6d 53 65 63 74 6f 72 53 69 7a 65 2c 0a  nmemSectorSize,.
7100: 20 20 2f 2a 20 78 44 65 76 63 68 61 72 20 20 2a    /* xDevchar  *
7110: 2f 20 20 20 20 69 6e 6d 65 6d 44 65 76 69 63 65  /    inmemDevice
7120: 43 68 61 72 61 63 74 65 72 69 73 74 69 63 73 2c  Characteristics,
7130: 0a 20 20 2f 2a 20 78 53 68 6d 4d 61 70 20 20 20  .  /* xShmMap   
7140: 2a 2f 20 20 20 20 30 2c 0a 20 20 2f 2a 20 78 53  */    0,.  /* xS
7150: 68 6d 4c 6f 63 6b 20 20 2a 2f 20 20 20 20 30 2c  hmLock  */    0,
7160: 0a 20 20 2f 2a 20 78 53 68 6d 42 61 72 72 69 65  .  /* xShmBarrie
7170: 72 20 2a 2f 20 20 30 2c 0a 20 20 2f 2a 20 78 53  r */  0,.  /* xS
7180: 68 6d 55 6e 6d 61 70 20 2a 2f 20 20 20 20 30 2c  hmUnmap */    0,
7190: 0a 20 20 2f 2a 20 78 46 65 74 63 68 20 20 20 20  .  /* xFetch    
71a0: 2a 2f 20 20 20 20 30 2c 0a 20 20 2f 2a 20 78 55  */    0,.  /* xU
71b0: 6e 66 65 74 63 68 20 20 2a 2f 20 20 20 20 30 0a  nfetch  */    0.
71c0: 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 4f 70 65 6e 20 61  };../*.** Open a
71d0: 20 6e 65 77 20 66 69 6c 65 20 69 6e 20 74 68 65   new file in the
71e0: 20 69 6e 6d 65 6d 20 56 46 53 2e 20 20 41 6c 6c   inmem VFS.  All
71f0: 20 66 69 6c 65 73 20 61 72 65 20 61 6e 6f 6e 79   files are anony
7200: 6d 6f 75 73 20 61 6e 64 20 61 72 65 0a 2a 2a 20  mous and are.** 
7210: 64 65 6c 65 74 65 2d 6f 6e 2d 63 6c 6f 73 65 2e  delete-on-close.
7220: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 69  .*/.static int i
7230: 6e 6d 65 6d 4f 70 65 6e 28 0a 20 20 73 71 6c 69  nmemOpen(.  sqli
7240: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 0a 20  te3_vfs *pVfs,. 
7250: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 69   const char *zFi
7260: 6c 65 6e 61 6d 65 2c 0a 20 20 73 71 6c 69 74 65  lename,.  sqlite
7270: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 0a 20  3_file *pFile,. 
7280: 20 69 6e 74 20 6f 70 65 6e 46 6c 61 67 73 2c 0a   int openFlags,.
7290: 20 20 69 6e 74 20 2a 70 4f 75 74 46 6c 61 67 73    int *pOutFlags
72a0: 0a 29 7b 0a 20 20 56 46 69 6c 65 20 2a 70 56 46  .){.  VFile *pVF
72b0: 69 6c 65 20 3d 20 63 72 65 61 74 65 56 46 69 6c  ile = createVFil
72c0: 65 28 7a 46 69 6c 65 6e 61 6d 65 2c 20 30 2c 20  e(zFilename, 0, 
72d0: 28 75 6e 73 69 67 6e 65 64 20 63 68 61 72 2a 29  (unsigned char*)
72e0: 22 22 29 3b 0a 20 20 56 48 61 6e 64 6c 65 20 2a  "");.  VHandle *
72f0: 70 48 61 6e 64 6c 65 20 3d 20 28 56 48 61 6e 64  pHandle = (VHand
7300: 6c 65 2a 29 70 46 69 6c 65 3b 0a 20 20 69 66 28  le*)pFile;.  if(
7310: 20 70 56 46 69 6c 65 3d 3d 30 20 29 7b 0a 20 20   pVFile==0 ){.  
7320: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
7330: 46 55 4c 4c 3b 0a 20 20 7d 0a 20 20 70 48 61 6e  FULL;.  }.  pHan
7340: 64 6c 65 2d 3e 70 56 46 69 6c 65 20 3d 20 70 56  dle->pVFile = pV
7350: 46 69 6c 65 3b 0a 20 20 70 56 46 69 6c 65 2d 3e  File;.  pVFile->
7360: 6e 52 65 66 2b 2b 3b 0a 20 20 70 46 69 6c 65 2d  nRef++;.  pFile-
7370: 3e 70 4d 65 74 68 6f 64 73 20 3d 20 26 56 48 61  >pMethods = &VHa
7380: 6e 64 6c 65 4d 65 74 68 6f 64 73 3b 0a 20 20 69  ndleMethods;.  i
7390: 66 28 20 70 4f 75 74 46 6c 61 67 73 20 29 20 2a  f( pOutFlags ) *
73a0: 70 4f 75 74 46 6c 61 67 73 20 3d 20 6f 70 65 6e  pOutFlags = open
73b0: 46 6c 61 67 73 3b 0a 20 20 72 65 74 75 72 6e 20  Flags;.  return 
73c0: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a  SQLITE_OK;.}../*
73d0: 0a 2a 2a 20 44 65 6c 65 74 65 20 61 20 66 69 6c  .** Delete a fil
73e0: 65 20 62 79 20 6e 61 6d 65 0a 2a 2f 0a 73 74 61  e by name.*/.sta
73f0: 74 69 63 20 69 6e 74 20 69 6e 6d 65 6d 44 65 6c  tic int inmemDel
7400: 65 74 65 28 0a 20 20 73 71 6c 69 74 65 33 5f 76  ete(.  sqlite3_v
7410: 66 73 20 2a 70 56 66 73 2c 0a 20 20 63 6f 6e 73  fs *pVfs,.  cons
7420: 74 20 63 68 61 72 20 2a 7a 46 69 6c 65 6e 61 6d  t char *zFilenam
7430: 65 2c 0a 20 20 69 6e 74 20 73 79 6e 63 64 69 72  e,.  int syncdir
7440: 0a 29 7b 0a 20 20 56 46 69 6c 65 20 2a 70 56 46  .){.  VFile *pVF
7450: 69 6c 65 20 3d 20 66 69 6e 64 56 46 69 6c 65 28  ile = findVFile(
7460: 7a 46 69 6c 65 6e 61 6d 65 29 3b 0a 20 20 69 66  zFilename);.  if
7470: 28 20 70 56 46 69 6c 65 3d 3d 30 20 29 20 72 65  ( pVFile==0 ) re
7480: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  turn SQLITE_OK;.
7490: 20 20 69 66 28 20 70 56 46 69 6c 65 2d 3e 6e 52    if( pVFile->nR
74a0: 65 66 3d 3d 30 20 29 7b 0a 20 20 20 20 66 72 65  ef==0 ){.    fre
74b0: 65 28 70 56 46 69 6c 65 2d 3e 7a 46 69 6c 65 6e  e(pVFile->zFilen
74c0: 61 6d 65 29 3b 0a 20 20 20 20 70 56 46 69 6c 65  ame);.    pVFile
74d0: 2d 3e 7a 46 69 6c 65 6e 61 6d 65 20 3d 20 30 3b  ->zFilename = 0;
74e0: 0a 20 20 20 20 70 56 46 69 6c 65 2d 3e 73 7a 20  .    pVFile->sz 
74f0: 3d 20 2d 31 3b 0a 20 20 20 20 66 72 65 65 28 70  = -1;.    free(p
7500: 56 46 69 6c 65 2d 3e 61 29 3b 0a 20 20 20 20 70  VFile->a);.    p
7510: 56 46 69 6c 65 2d 3e 61 20 3d 20 30 3b 0a 20 20  VFile->a = 0;.  
7520: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
7530: 4f 4b 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e  OK;.  }.  return
7540: 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 44 45   SQLITE_IOERR_DE
7550: 4c 45 54 45 3b 0a 7d 0a 0a 2f 2a 20 43 68 65 63  LETE;.}../* Chec
7560: 6b 20 66 6f 72 20 74 68 65 20 65 78 69 73 74 61  k for the exista
7570: 6e 63 65 20 6f 66 20 61 20 66 69 6c 65 0a 2a 2f  nce of a file.*/
7580: 0a 73 74 61 74 69 63 20 69 6e 74 20 69 6e 6d 65  .static int inme
7590: 6d 41 63 63 65 73 73 28 0a 20 20 73 71 6c 69 74  mAccess(.  sqlit
75a0: 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 0a 20 20  e3_vfs *pVfs,.  
75b0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 69 6c  const char *zFil
75c0: 65 6e 61 6d 65 2c 0a 20 20 69 6e 74 20 66 6c 61  ename,.  int fla
75d0: 67 73 2c 0a 20 20 69 6e 74 20 2a 70 52 65 73 4f  gs,.  int *pResO
75e0: 75 74 0a 29 7b 0a 20 20 56 46 69 6c 65 20 2a 70  ut.){.  VFile *p
75f0: 56 46 69 6c 65 20 3d 20 66 69 6e 64 56 46 69 6c  VFile = findVFil
7600: 65 28 7a 46 69 6c 65 6e 61 6d 65 29 3b 0a 20 20  e(zFilename);.  
7610: 2a 70 52 65 73 4f 75 74 20 3d 20 20 70 56 46 69  *pResOut =  pVFi
7620: 6c 65 21 3d 30 3b 0a 20 20 72 65 74 75 72 6e 20  le!=0;.  return 
7630: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a  SQLITE_OK;.}../*
7640: 20 47 65 74 20 74 68 65 20 63 61 6e 6f 6e 69 63   Get the canonic
7650: 61 6c 20 70 61 74 68 6e 61 6d 65 20 66 6f 72 20  al pathname for 
7660: 61 20 66 69 6c 65 0a 2a 2f 0a 73 74 61 74 69 63  a file.*/.static
7670: 20 69 6e 74 20 69 6e 6d 65 6d 46 75 6c 6c 50 61   int inmemFullPa
7680: 74 68 6e 61 6d 65 28 0a 20 20 73 71 6c 69 74 65  thname(.  sqlite
7690: 33 5f 76 66 73 20 2a 70 56 66 73 2c 0a 20 20 63  3_vfs *pVfs,.  c
76a0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 69 6c 65  onst char *zFile
76b0: 6e 61 6d 65 2c 0a 20 20 69 6e 74 20 6e 4f 75 74  name,.  int nOut
76c0: 2c 0a 20 20 63 68 61 72 20 2a 7a 4f 75 74 0a 29  ,.  char *zOut.)
76d0: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 73 6e 70 72  {.  sqlite3_snpr
76e0: 69 6e 74 66 28 6e 4f 75 74 2c 20 7a 4f 75 74 2c  intf(nOut, zOut,
76f0: 20 22 25 73 22 2c 20 7a 46 69 6c 65 6e 61 6d 65   "%s", zFilename
7700: 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49  );.  return SQLI
7710: 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 20 41 6c 77  TE_OK;.}../* Alw
7720: 61 79 73 20 75 73 65 20 74 68 65 20 73 61 6d 65  ays use the same
7730: 20 72 61 6e 64 6f 6d 20 73 65 65 2c 20 66 6f 72   random see, for
7740: 20 72 65 70 65 61 74 61 62 69 6c 69 74 79 2e 0a   repeatability..
7750: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 69 6e  */.static int in
7760: 6d 65 6d 52 61 6e 64 6f 6d 6e 65 73 73 28 73 71  memRandomness(sq
7770: 6c 69 74 65 33 5f 76 66 73 20 2a 4e 6f 74 55 73  lite3_vfs *NotUs
7780: 65 64 2c 20 69 6e 74 20 6e 42 75 66 2c 20 63 68  ed, int nBuf, ch
7790: 61 72 20 2a 7a 42 75 66 29 7b 0a 20 20 6d 65 6d  ar *zBuf){.  mem
77a0: 73 65 74 28 7a 42 75 66 2c 20 30 2c 20 6e 42 75  set(zBuf, 0, nBu
77b0: 66 29 3b 0a 20 20 6d 65 6d 63 70 79 28 7a 42 75  f);.  memcpy(zBu
77c0: 66 2c 20 26 67 2e 75 52 61 6e 64 6f 6d 2c 20 6e  f, &g.uRandom, n
77d0: 42 75 66 3c 73 69 7a 65 6f 66 28 67 2e 75 52 61  Buf<sizeof(g.uRa
77e0: 6e 64 6f 6d 29 20 3f 20 6e 42 75 66 20 3a 20 73  ndom) ? nBuf : s
77f0: 69 7a 65 6f 66 28 67 2e 75 52 61 6e 64 6f 6d 29  izeof(g.uRandom)
7800: 29 3b 0a 20 20 72 65 74 75 72 6e 20 6e 42 75 66  );.  return nBuf
7810: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73  ;.}../*.** Regis
7820: 74 65 72 20 74 68 65 20 56 46 53 20 74 68 61 74  ter the VFS that
7830: 20 72 65 61 64 73 20 66 72 6f 6d 20 74 68 65 20   reads from the 
7840: 67 2e 61 46 69 6c 65 5b 5d 20 73 65 74 20 6f 66  g.aFile[] set of
7850: 20 66 69 6c 65 73 2e 0a 2a 2f 0a 73 74 61 74 69   files..*/.stati
7860: 63 20 76 6f 69 64 20 69 6e 6d 65 6d 56 66 73 52  c void inmemVfsR
7870: 65 67 69 73 74 65 72 28 69 6e 74 20 6d 61 6b 65  egister(int make
7880: 44 65 66 61 75 6c 74 29 7b 0a 20 20 73 74 61 74  Default){.  stat
7890: 69 63 20 73 71 6c 69 74 65 33 5f 76 66 73 20 69  ic sqlite3_vfs i
78a0: 6e 6d 65 6d 56 66 73 3b 0a 20 20 73 71 6c 69 74  nmemVfs;.  sqlit
78b0: 65 33 5f 76 66 73 20 2a 70 44 65 66 61 75 6c 74  e3_vfs *pDefault
78c0: 20 3d 20 73 71 6c 69 74 65 33 5f 76 66 73 5f 66   = sqlite3_vfs_f
78d0: 69 6e 64 28 30 29 3b 0a 20 20 69 6e 6d 65 6d 56  ind(0);.  inmemV
78e0: 66 73 2e 69 56 65 72 73 69 6f 6e 20 3d 20 33 3b  fs.iVersion = 3;
78f0: 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 73 7a 4f 73  .  inmemVfs.szOs
7900: 46 69 6c 65 20 3d 20 73 69 7a 65 6f 66 28 56 48  File = sizeof(VH
7910: 61 6e 64 6c 65 29 3b 0a 20 20 69 6e 6d 65 6d 56  andle);.  inmemV
7920: 66 73 2e 6d 78 50 61 74 68 6e 61 6d 65 20 3d 20  fs.mxPathname = 
7930: 32 30 30 3b 0a 20 20 69 6e 6d 65 6d 56 66 73 2e  200;.  inmemVfs.
7940: 7a 4e 61 6d 65 20 3d 20 22 69 6e 6d 65 6d 22 3b  zName = "inmem";
7950: 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 78 4f 70 65  .  inmemVfs.xOpe
7960: 6e 20 3d 20 69 6e 6d 65 6d 4f 70 65 6e 3b 0a 20  n = inmemOpen;. 
7970: 20 69 6e 6d 65 6d 56 66 73 2e 78 44 65 6c 65 74   inmemVfs.xDelet
7980: 65 20 3d 20 69 6e 6d 65 6d 44 65 6c 65 74 65 3b  e = inmemDelete;
7990: 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 78 41 63 63  .  inmemVfs.xAcc
79a0: 65 73 73 20 3d 20 69 6e 6d 65 6d 41 63 63 65 73  ess = inmemAcces
79b0: 73 3b 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 78 46  s;.  inmemVfs.xF
79c0: 75 6c 6c 50 61 74 68 6e 61 6d 65 20 3d 20 69 6e  ullPathname = in
79d0: 6d 65 6d 46 75 6c 6c 50 61 74 68 6e 61 6d 65 3b  memFullPathname;
79e0: 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 78 52 61 6e  .  inmemVfs.xRan
79f0: 64 6f 6d 6e 65 73 73 20 3d 20 69 6e 6d 65 6d 52  domness = inmemR
7a00: 61 6e 64 6f 6d 6e 65 73 73 3b 0a 20 20 69 6e 6d  andomness;.  inm
7a10: 65 6d 56 66 73 2e 78 53 6c 65 65 70 20 3d 20 70  emVfs.xSleep = p
7a20: 44 65 66 61 75 6c 74 2d 3e 78 53 6c 65 65 70 3b  Default->xSleep;
7a30: 0a 20 20 69 6e 6d 65 6d 56 66 73 2e 78 43 75 72  .  inmemVfs.xCur
7a40: 72 65 6e 74 54 69 6d 65 49 6e 74 36 34 20 3d 20  rentTimeInt64 = 
7a50: 70 44 65 66 61 75 6c 74 2d 3e 78 43 75 72 72 65  pDefault->xCurre
7a60: 6e 74 54 69 6d 65 49 6e 74 36 34 3b 0a 20 20 73  ntTimeInt64;.  s
7a70: 71 6c 69 74 65 33 5f 76 66 73 5f 72 65 67 69 73  qlite3_vfs_regis
7a80: 74 65 72 28 26 69 6e 6d 65 6d 56 66 73 2c 20 6d  ter(&inmemVfs, m
7a90: 61 6b 65 44 65 66 61 75 6c 74 29 3b 0a 7d 3b 0a  akeDefault);.};.
7aa0: 0a 2f 2a 0a 2a 2a 20 41 6c 6c 6f 77 65 64 20 76  ./*.** Allowed v
7ab0: 61 6c 75 65 73 20 66 6f 72 20 74 68 65 20 72 75  alues for the ru
7ac0: 6e 46 6c 61 67 73 20 70 61 72 61 6d 65 74 65 72  nFlags parameter
7ad0: 20 74 6f 20 72 75 6e 53 71 6c 28 29 0a 2a 2f 0a   to runSql().*/.
7ae0: 23 64 65 66 69 6e 65 20 53 51 4c 5f 54 52 41 43  #define SQL_TRAC
7af0: 45 20 20 30 78 30 30 30 31 20 20 20 20 20 2f 2a  E  0x0001     /*
7b00: 20 50 72 69 6e 74 20 65 61 63 68 20 53 51 4c 20   Print each SQL 
7b10: 73 74 61 74 65 6d 65 6e 74 20 61 73 20 69 74 20  statement as it 
7b20: 69 73 20 70 72 65 70 61 72 65 64 20 2a 2f 0a 23  is prepared */.#
7b30: 64 65 66 69 6e 65 20 53 51 4c 5f 4f 55 54 50 55  define SQL_OUTPU
7b40: 54 20 30 78 30 30 30 32 20 20 20 20 20 2f 2a 20  T 0x0002     /* 
7b50: 53 68 6f 77 20 74 68 65 20 53 51 4c 20 6f 75 74  Show the SQL out
7b60: 70 75 74 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 75  put */../*.** Ru
7b70: 6e 20 6d 75 6c 74 69 70 6c 65 20 63 6f 6d 6d 61  n multiple comma
7b80: 6e 64 73 20 6f 66 20 53 51 4c 2e 20 20 53 69 6d  nds of SQL.  Sim
7b90: 69 6c 61 72 20 74 6f 20 73 71 6c 69 74 65 33 5f  ilar to sqlite3_
7ba0: 65 78 65 63 28 29 2c 20 62 75 74 20 64 6f 65 73  exec(), but does
7bb0: 20 6e 6f 74 0a 2a 2a 20 73 74 6f 70 20 69 66 20   not.** stop if 
7bc0: 61 6e 20 65 72 72 6f 72 20 69 73 20 65 6e 63 6f  an error is enco
7bd0: 75 6e 74 65 72 65 64 2e 0a 2a 2f 0a 73 74 61 74  untered..*/.stat
7be0: 69 63 20 76 6f 69 64 20 72 75 6e 53 71 6c 28 73  ic void runSql(s
7bf0: 71 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f 6e 73  qlite3 *db, cons
7c00: 74 20 63 68 61 72 20 2a 7a 53 71 6c 2c 20 75 6e  t char *zSql, un
7c10: 73 69 67 6e 65 64 20 20 72 75 6e 46 6c 61 67 73  signed  runFlags
7c20: 29 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  ){.  const char 
7c30: 2a 7a 4d 6f 72 65 3b 0a 20 20 73 71 6c 69 74 65  *zMore;.  sqlite
7c40: 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 3b 0a 0a  3_stmt *pStmt;..
7c50: 20 20 77 68 69 6c 65 28 20 7a 53 71 6c 20 26 26    while( zSql &&
7c60: 20 7a 53 71 6c 5b 30 5d 20 29 7b 0a 20 20 20 20   zSql[0] ){.    
7c70: 7a 4d 6f 72 65 20 3d 20 30 3b 0a 20 20 20 20 70  zMore = 0;.    p
7c80: 53 74 6d 74 20 3d 20 30 3b 0a 20 20 20 20 73 71  Stmt = 0;.    sq
7c90: 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32  lite3_prepare_v2
7ca0: 28 64 62 2c 20 7a 53 71 6c 2c 20 2d 31 2c 20 26  (db, zSql, -1, &
7cb0: 70 53 74 6d 74 2c 20 26 7a 4d 6f 72 65 29 3b 0a  pStmt, &zMore);.
7cc0: 20 20 20 20 69 66 28 20 7a 4d 6f 72 65 3d 3d 7a      if( zMore==z
7cd0: 53 71 6c 20 29 20 62 72 65 61 6b 3b 0a 20 20 20  Sql ) break;.   
7ce0: 20 69 66 28 20 72 75 6e 46 6c 61 67 73 20 26 20   if( runFlags & 
7cf0: 53 51 4c 5f 54 52 41 43 45 20 29 7b 0a 20 20 20  SQL_TRACE ){.   
7d00: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a     const char *z
7d10: 20 3d 20 7a 53 71 6c 3b 0a 20 20 20 20 20 20 69   = zSql;.      i
7d20: 6e 74 20 6e 3b 0a 20 20 20 20 20 20 77 68 69 6c  nt n;.      whil
7d30: 65 28 20 7a 3c 7a 4d 6f 72 65 20 26 26 20 49 53  e( z<zMore && IS
7d40: 53 50 41 43 45 28 7a 5b 30 5d 29 20 29 20 7a 2b  SPACE(z[0]) ) z+
7d50: 2b 3b 0a 20 20 20 20 20 20 6e 20 3d 20 28 69 6e  +;.      n = (in
7d60: 74 29 28 7a 4d 6f 72 65 20 2d 20 7a 29 3b 0a 20  t)(zMore - z);. 
7d70: 20 20 20 20 20 77 68 69 6c 65 28 20 6e 3e 30 20       while( n>0 
7d80: 26 26 20 49 53 53 50 41 43 45 28 7a 5b 6e 2d 31  && ISSPACE(z[n-1
7d90: 5d 29 20 29 20 6e 2d 2d 3b 0a 20 20 20 20 20 20  ]) ) n--;.      
7da0: 69 66 28 20 6e 3d 3d 30 20 29 20 62 72 65 61 6b  if( n==0 ) break
7db0: 3b 0a 20 20 20 20 20 20 69 66 28 20 70 53 74 6d  ;.      if( pStm
7dc0: 74 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  t==0 ){.        
7dd0: 70 72 69 6e 74 66 28 22 54 52 41 43 45 3a 20 25  printf("TRACE: %
7de0: 2e 2a 73 20 28 65 72 72 6f 72 3a 20 25 73 29 5c  .*s (error: %s)\
7df0: 6e 22 2c 20 6e 2c 20 7a 2c 20 73 71 6c 69 74 65  n", n, z, sqlite
7e00: 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20  3_errmsg(db));. 
7e10: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
7e20: 20 20 20 20 70 72 69 6e 74 66 28 22 54 52 41 43      printf("TRAC
7e30: 45 3a 20 25 2e 2a 73 5c 6e 22 2c 20 6e 2c 20 7a  E: %.*s\n", n, z
7e40: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
7e50: 0a 20 20 20 20 7a 53 71 6c 20 3d 20 7a 4d 6f 72  .    zSql = zMor
7e60: 65 3b 0a 20 20 20 20 69 66 28 20 70 53 74 6d 74  e;.    if( pStmt
7e70: 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20 28 72   ){.      if( (r
7e80: 75 6e 46 6c 61 67 73 20 26 20 53 51 4c 5f 4f 55  unFlags & SQL_OU
7e90: 54 50 55 54 29 3d 3d 30 20 29 7b 0a 20 20 20 20  TPUT)==0 ){.    
7ea0: 20 20 20 20 77 68 69 6c 65 28 20 53 51 4c 49 54      while( SQLIT
7eb0: 45 5f 52 4f 57 3d 3d 73 71 6c 69 74 65 33 5f 73  E_ROW==sqlite3_s
7ec0: 74 65 70 28 70 53 74 6d 74 29 20 29 7b 7d 0a 20  tep(pStmt) ){}. 
7ed0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
7ee0: 20 20 20 20 69 6e 74 20 6e 43 6f 6c 20 3d 20 2d      int nCol = -
7ef0: 31 3b 0a 20 20 20 20 20 20 20 20 77 68 69 6c 65  1;.        while
7f00: 28 20 53 51 4c 49 54 45 5f 52 4f 57 3d 3d 73 71  ( SQLITE_ROW==sq
7f10: 6c 69 74 65 33 5f 73 74 65 70 28 70 53 74 6d 74  lite3_step(pStmt
7f20: 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69  ) ){.          i
7f30: 6e 74 20 69 3b 0a 20 20 20 20 20 20 20 20 20 20  nt i;.          
7f40: 69 66 28 20 6e 43 6f 6c 3c 30 20 29 7b 0a 20 20  if( nCol<0 ){.  
7f50: 20 20 20 20 20 20 20 20 20 20 6e 43 6f 6c 20 3d            nCol =
7f60: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
7f70: 63 6f 75 6e 74 28 70 53 74 6d 74 29 3b 0a 20 20  count(pStmt);.  
7f80: 20 20 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66          }else if
7f90: 28 20 6e 43 6f 6c 3e 30 20 29 7b 0a 20 20 20 20  ( nCol>0 ){.    
7fa0: 20 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22          printf("
7fb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
7fc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
7fd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 5c 6e 22 29  ------------\n")
7fe0: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20  ;.          }.  
7ff0: 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b          for(i=0;
8000: 20 69 3c 6e 43 6f 6c 3b 20 69 2b 2b 29 7b 0a 20   i<nCol; i++){. 
8010: 20 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 65             int e
8020: 54 79 70 65 20 3d 20 73 71 6c 69 74 65 33 5f 63  Type = sqlite3_c
8030: 6f 6c 75 6d 6e 5f 74 79 70 65 28 70 53 74 6d 74  olumn_type(pStmt
8040: 2c 69 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  ,i);.           
8050: 20 70 72 69 6e 74 66 28 22 25 73 20 3d 20 22 2c   printf("%s = ",
8060: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
8070: 6e 61 6d 65 28 70 53 74 6d 74 2c 69 29 29 3b 0a  name(pStmt,i));.
8080: 20 20 20 20 20 20 20 20 20 20 20 20 73 77 69 74              swit
8090: 63 68 28 20 65 54 79 70 65 20 29 7b 0a 20 20 20  ch( eType ){.   
80a0: 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20             case 
80b0: 53 51 4c 49 54 45 5f 4e 55 4c 4c 3a 20 7b 0a 20  SQLITE_NULL: {. 
80c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70                 p
80d0: 72 69 6e 74 66 28 22 4e 55 4c 4c 5c 6e 22 29 3b  rintf("NULL\n");
80e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
80f0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20   break;.        
8100: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
8110: 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 49 54        case SQLIT
8120: 45 5f 49 4e 54 45 47 45 52 3a 20 7b 0a 20 20 20  E_INTEGER: {.   
8130: 20 20 20 20 20 20 20 20 20 20 20 20 20 70 72 69               pri
8140: 6e 74 66 28 22 49 4e 54 20 25 73 5c 6e 22 2c 20  ntf("INT %s\n", 
8150: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74  sqlite3_column_t
8160: 65 78 74 28 70 53 74 6d 74 2c 69 29 29 3b 0a 20  ext(pStmt,i));. 
8170: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62                 b
8180: 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20  reak;.          
8190: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
81a0: 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f      case SQLITE_
81b0: 46 4c 4f 41 54 3a 20 7b 0a 20 20 20 20 20 20 20  FLOAT: {.       
81c0: 20 20 20 20 20 20 20 20 20 70 72 69 6e 74 66 28           printf(
81d0: 22 46 4c 4f 41 54 20 25 73 5c 6e 22 2c 20 73 71  "FLOAT %s\n", sq
81e0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78  lite3_column_tex
81f0: 74 28 70 53 74 6d 74 2c 69 29 29 3b 0a 20 20 20  t(pStmt,i));.   
8200: 20 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65               bre
8210: 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ak;.            
8220: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
8230: 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 54 45    case SQLITE_TE
8240: 58 54 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20  XT: {.          
8250: 20 20 20 20 20 20 70 72 69 6e 74 66 28 22 54 45        printf("TE
8260: 58 54 20 5b 25 73 5d 5c 6e 22 2c 20 73 71 6c 69  XT [%s]\n", sqli
8270: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28  te3_column_text(
8280: 70 53 74 6d 74 2c 69 29 29 3b 0a 20 20 20 20 20  pStmt,i));.     
8290: 20 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b             break
82a0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
82b0: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }.              
82c0: 63 61 73 65 20 53 51 4c 49 54 45 5f 42 4c 4f 42  case SQLITE_BLOB
82d0: 3a 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20  : {.            
82e0: 20 20 20 20 70 72 69 6e 74 66 28 22 42 4c 4f 42      printf("BLOB
82f0: 20 28 25 64 20 62 79 74 65 73 29 5c 6e 22 2c 20   (%d bytes)\n", 
8300: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62  sqlite3_column_b
8310: 79 74 65 73 28 70 53 74 6d 74 2c 69 29 29 3b 0a  ytes(pStmt,i));.
8320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8330: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20  break;.         
8340: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
8350: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 7d     }.          }
8360: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
8370: 20 7d 20 20 20 20 20 20 20 20 20 0a 20 20 20 20   }         .    
8380: 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69    sqlite3_finali
8390: 7a 65 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 7d  ze(pStmt);.    }
83a0: 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65  .  }.}../*.** Re
83b0: 62 75 69 6c 64 20 74 68 65 20 64 61 74 61 62 61  build the databa
83c0: 73 65 20 66 69 6c 65 2e 0a 2a 2a 0a 2a 2a 20 20  se file..**.**  
83d0: 20 20 28 31 29 20 20 52 65 6d 6f 76 65 20 64 75    (1)  Remove du
83e0: 70 6c 69 63 61 74 65 20 65 6e 74 72 69 65 73 0a  plicate entries.
83f0: 2a 2a 20 20 20 20 28 32 29 20 20 50 75 74 20 61  **    (2)  Put a
8400: 6c 6c 20 65 6e 74 72 69 65 73 20 69 6e 20 6f 72  ll entries in or
8410: 64 65 72 0a 2a 2a 20 20 20 20 28 33 29 20 20 56  der.**    (3)  V
8420: 61 63 75 75 6d 0a 2a 2f 0a 73 74 61 74 69 63 20  acuum.*/.static 
8430: 76 6f 69 64 20 72 65 62 75 69 6c 64 5f 64 61 74  void rebuild_dat
8440: 61 62 61 73 65 28 73 71 6c 69 74 65 33 20 2a 64  abase(sqlite3 *d
8450: 62 2c 20 69 6e 74 20 64 62 53 71 6c 4f 6e 6c 79  b, int dbSqlOnly
8460: 29 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 63  ){.  int rc;.  c
8470: 68 61 72 20 2a 7a 53 71 6c 3b 0a 20 20 7a 53 71  har *zSql;.  zSq
8480: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69  l = sqlite3_mpri
8490: 6e 74 66 28 0a 20 20 20 20 20 22 42 45 47 49 4e  ntf(.     "BEGIN
84a0: 3b 5c 6e 22 0a 20 20 20 20 20 22 43 52 45 41 54  ;\n".     "CREAT
84b0: 45 20 54 45 4d 50 20 54 41 42 4c 45 20 64 62 78  E TEMP TABLE dbx
84c0: 20 41 53 20 53 45 4c 45 43 54 20 44 49 53 54 49   AS SELECT DISTI
84d0: 4e 43 54 20 64 62 63 6f 6e 74 65 6e 74 20 46 52  NCT dbcontent FR
84e0: 4f 4d 20 64 62 3b 5c 6e 22 0a 20 20 20 20 20 22  OM db;\n".     "
84f0: 44 45 4c 45 54 45 20 46 52 4f 4d 20 64 62 3b 5c  DELETE FROM db;\
8500: 6e 22 0a 20 20 20 20 20 22 49 4e 53 45 52 54 20  n".     "INSERT 
8510: 49 4e 54 4f 20 64 62 28 64 62 69 64 2c 20 64 62  INTO db(dbid, db
8520: 63 6f 6e 74 65 6e 74 29 20 22 0a 20 20 20 20 20  content) ".     
8530: 20 20 20 22 20 53 45 4c 45 43 54 20 4e 55 4c 4c     " SELECT NULL
8540: 2c 20 64 62 63 6f 6e 74 65 6e 74 20 46 52 4f 4d  , dbcontent FROM
8550: 20 64 62 78 20 4f 52 44 45 52 20 42 59 20 32 3b   dbx ORDER BY 2;
8560: 5c 6e 22 0a 20 20 20 20 20 22 44 52 4f 50 20 54  \n".     "DROP T
8570: 41 42 4c 45 20 64 62 78 3b 5c 6e 22 0a 20 20 20  ABLE dbx;\n".   
8580: 20 20 22 43 52 45 41 54 45 20 54 45 4d 50 20 54    "CREATE TEMP T
8590: 41 42 4c 45 20 73 78 20 41 53 20 53 45 4c 45 43  ABLE sx AS SELEC
85a0: 54 20 44 49 53 54 49 4e 43 54 20 73 71 6c 74 65  T DISTINCT sqlte
85b0: 78 74 20 46 52 4f 4d 20 78 73 71 6c 20 25 73 3b  xt FROM xsql %s;
85c0: 5c 6e 22 0a 20 20 20 20 20 22 44 45 4c 45 54 45  \n".     "DELETE
85d0: 20 46 52 4f 4d 20 78 73 71 6c 3b 5c 6e 22 0a 20   FROM xsql;\n". 
85e0: 20 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 4f      "INSERT INTO
85f0: 20 78 73 71 6c 28 73 71 6c 69 64 2c 73 71 6c 74   xsql(sqlid,sqlt
8600: 65 78 74 29 20 22 0a 20 20 20 20 20 20 20 20 22  ext) ".        "
8610: 20 53 45 4c 45 43 54 20 4e 55 4c 4c 2c 20 73 71   SELECT NULL, sq
8620: 6c 74 65 78 74 20 46 52 4f 4d 20 73 78 20 4f 52  ltext FROM sx OR
8630: 44 45 52 20 42 59 20 32 3b 5c 6e 22 0a 20 20 20  DER BY 2;\n".   
8640: 20 20 22 44 52 4f 50 20 54 41 42 4c 45 20 73 78    "DROP TABLE sx
8650: 3b 5c 6e 22 0a 20 20 20 20 20 22 43 4f 4d 4d 49  ;\n".     "COMMI
8660: 54 3b 5c 6e 22 0a 20 20 20 20 20 22 50 52 41 47  T;\n".     "PRAG
8670: 4d 41 20 70 61 67 65 5f 73 69 7a 65 3d 31 30 32  MA page_size=102
8680: 34 3b 5c 6e 22 0a 20 20 20 20 20 22 56 41 43 55  4;\n".     "VACU
8690: 55 4d 3b 5c 6e 22 2c 0a 20 20 20 20 20 64 62 53  UM;\n",.     dbS
86a0: 71 6c 4f 6e 6c 79 20 3f 20 22 20 57 48 45 52 45  qlOnly ? " WHERE
86b0: 20 69 73 64 62 73 71 6c 28 73 71 6c 74 65 78 74   isdbsql(sqltext
86c0: 29 22 20 3a 20 22 22 0a 20 20 29 3b 0a 20 20 72  )" : "".  );.  r
86d0: 63 20 3d 20 73 71 6c 69 74 65 33 5f 65 78 65 63  c = sqlite3_exec
86e0: 28 64 62 2c 20 7a 53 71 6c 2c 20 30 2c 20 30 2c  (db, zSql, 0, 0,
86f0: 20 30 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66   0);.  sqlite3_f
8700: 72 65 65 28 7a 53 71 6c 29 3b 0a 20 20 69 66 28  ree(zSql);.  if(
8710: 20 72 63 20 29 20 66 61 74 61 6c 45 72 72 6f 72   rc ) fatalError
8720: 28 22 63 61 6e 6e 6f 74 20 72 65 62 75 69 6c 64  ("cannot rebuild
8730: 3a 20 25 73 22 2c 20 73 71 6c 69 74 65 33 5f 65  : %s", sqlite3_e
8740: 72 72 6d 73 67 28 64 62 29 29 3b 0a 7d 0a 0a 2f  rrmsg(db));.}../
8750: 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20  *.** Return the 
8760: 76 61 6c 75 65 20 6f 66 20 61 20 68 65 78 61 64  value of a hexad
8770: 65 63 69 6d 61 6c 20 64 69 67 69 74 2e 20 20 52  ecimal digit.  R
8780: 65 74 75 72 6e 20 2d 31 20 69 66 20 74 68 65 20  eturn -1 if the 
8790: 69 6e 70 75 74 0a 2a 2a 20 69 73 20 6e 6f 74 20  input.** is not 
87a0: 61 20 68 65 78 20 64 69 67 69 74 2e 0a 2a 2f 0a  a hex digit..*/.
87b0: 73 74 61 74 69 63 20 69 6e 74 20 68 65 78 44 69  static int hexDi
87c0: 67 69 74 56 61 6c 75 65 28 63 68 61 72 20 63 29  gitValue(char c)
87d0: 7b 0a 20 20 69 66 28 20 63 3e 3d 27 30 27 20 26  {.  if( c>='0' &
87e0: 26 20 63 3c 3d 27 39 27 20 29 20 72 65 74 75 72  & c<='9' ) retur
87f0: 6e 20 63 20 2d 20 27 30 27 3b 0a 20 20 69 66 28  n c - '0';.  if(
8800: 20 63 3e 3d 27 61 27 20 26 26 20 63 3c 3d 27 66   c>='a' && c<='f
8810: 27 20 29 20 72 65 74 75 72 6e 20 63 20 2d 20 27  ' ) return c - '
8820: 61 27 20 2b 20 31 30 3b 0a 20 20 69 66 28 20 63  a' + 10;.  if( c
8830: 3e 3d 27 41 27 20 26 26 20 63 3c 3d 27 46 27 20  >='A' && c<='F' 
8840: 29 20 72 65 74 75 72 6e 20 63 20 2d 20 27 41 27  ) return c - 'A'
8850: 20 2b 20 31 30 3b 0a 20 20 72 65 74 75 72 6e 20   + 10;.  return 
8860: 2d 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74  -1;.}../*.** Int
8870: 65 72 70 72 65 74 20 7a 41 72 67 20 61 73 20 61  erpret zArg as a
8880: 6e 20 69 6e 74 65 67 65 72 20 76 61 6c 75 65 2c  n integer value,
8890: 20 70 6f 73 73 69 62 6c 79 20 77 69 74 68 20 73   possibly with s
88a0: 75 66 66 69 78 65 73 2e 0a 2a 2f 0a 73 74 61 74  uffixes..*/.stat
88b0: 69 63 20 69 6e 74 20 69 6e 74 65 67 65 72 56 61  ic int integerVa
88c0: 6c 75 65 28 63 6f 6e 73 74 20 63 68 61 72 20 2a  lue(const char *
88d0: 7a 41 72 67 29 7b 0a 20 20 73 71 6c 69 74 65 33  zArg){.  sqlite3
88e0: 5f 69 6e 74 36 34 20 76 20 3d 20 30 3b 0a 20 20  _int64 v = 0;.  
88f0: 73 74 61 74 69 63 20 63 6f 6e 73 74 20 73 74 72  static const str
8900: 75 63 74 20 7b 20 63 68 61 72 20 2a 7a 53 75 66  uct { char *zSuf
8910: 66 69 78 3b 20 69 6e 74 20 69 4d 75 6c 74 3b 20  fix; int iMult; 
8920: 7d 20 61 4d 75 6c 74 5b 5d 20 3d 20 7b 0a 20 20  } aMult[] = {.  
8930: 20 20 7b 20 22 4b 69 42 22 2c 20 31 30 32 34 20    { "KiB", 1024 
8940: 7d 2c 0a 20 20 20 20 7b 20 22 4d 69 42 22 2c 20  },.    { "MiB", 
8950: 31 30 32 34 2a 31 30 32 34 20 7d 2c 0a 20 20 20  1024*1024 },.   
8960: 20 7b 20 22 47 69 42 22 2c 20 31 30 32 34 2a 31   { "GiB", 1024*1
8970: 30 32 34 2a 31 30 32 34 20 7d 2c 0a 20 20 20 20  024*1024 },.    
8980: 7b 20 22 4b 42 22 2c 20 20 31 30 30 30 20 7d 2c  { "KB",  1000 },
8990: 0a 20 20 20 20 7b 20 22 4d 42 22 2c 20 20 31 30  .    { "MB",  10
89a0: 30 30 30 30 30 20 7d 2c 0a 20 20 20 20 7b 20 22  00000 },.    { "
89b0: 47 42 22 2c 20 20 31 30 30 30 30 30 30 30 30 30  GB",  1000000000
89c0: 20 7d 2c 0a 20 20 20 20 7b 20 22 4b 22 2c 20 20   },.    { "K",  
89d0: 20 31 30 30 30 20 7d 2c 0a 20 20 20 20 7b 20 22   1000 },.    { "
89e0: 4d 22 2c 20 20 20 31 30 30 30 30 30 30 20 7d 2c  M",   1000000 },
89f0: 0a 20 20 20 20 7b 20 22 47 22 2c 20 20 20 31 30  .    { "G",   10
8a00: 30 30 30 30 30 30 30 30 20 7d 2c 0a 20 20 7d 3b  00000000 },.  };
8a10: 0a 20 20 69 6e 74 20 69 3b 0a 20 20 69 6e 74 20  .  int i;.  int 
8a20: 69 73 4e 65 67 20 3d 20 30 3b 0a 20 20 69 66 28  isNeg = 0;.  if(
8a30: 20 7a 41 72 67 5b 30 5d 3d 3d 27 2d 27 20 29 7b   zArg[0]=='-' ){
8a40: 0a 20 20 20 20 69 73 4e 65 67 20 3d 20 31 3b 0a  .    isNeg = 1;.
8a50: 20 20 20 20 7a 41 72 67 2b 2b 3b 0a 20 20 7d 65      zArg++;.  }e
8a60: 6c 73 65 20 69 66 28 20 7a 41 72 67 5b 30 5d 3d  lse if( zArg[0]=
8a70: 3d 27 2b 27 20 29 7b 0a 20 20 20 20 7a 41 72 67  ='+' ){.    zArg
8a80: 2b 2b 3b 0a 20 20 7d 0a 20 20 69 66 28 20 7a 41  ++;.  }.  if( zA
8a90: 72 67 5b 30 5d 3d 3d 27 30 27 20 26 26 20 7a 41  rg[0]=='0' && zA
8aa0: 72 67 5b 31 5d 3d 3d 27 78 27 20 29 7b 0a 20 20  rg[1]=='x' ){.  
8ab0: 20 20 69 6e 74 20 78 3b 0a 20 20 20 20 7a 41 72    int x;.    zAr
8ac0: 67 20 2b 3d 20 32 3b 0a 20 20 20 20 77 68 69 6c  g += 2;.    whil
8ad0: 65 28 20 28 78 20 3d 20 68 65 78 44 69 67 69 74  e( (x = hexDigit
8ae0: 56 61 6c 75 65 28 7a 41 72 67 5b 30 5d 29 29 3e  Value(zArg[0]))>
8af0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 76 20 3d 20  =0 ){.      v = 
8b00: 28 76 3c 3c 34 29 20 2b 20 78 3b 0a 20 20 20 20  (v<<4) + x;.    
8b10: 20 20 7a 41 72 67 2b 2b 3b 0a 20 20 20 20 7d 0a    zArg++;.    }.
8b20: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 77 68 69    }else{.    whi
8b30: 6c 65 28 20 49 53 44 49 47 49 54 28 7a 41 72 67  le( ISDIGIT(zArg
8b40: 5b 30 5d 29 20 29 7b 0a 20 20 20 20 20 20 76 20  [0]) ){.      v 
8b50: 3d 20 76 2a 31 30 20 2b 20 7a 41 72 67 5b 30 5d  = v*10 + zArg[0]
8b60: 20 2d 20 27 30 27 3b 0a 20 20 20 20 20 20 7a 41   - '0';.      zA
8b70: 72 67 2b 2b 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  rg++;.    }.  }.
8b80: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 73 69 7a    for(i=0; i<siz
8b90: 65 6f 66 28 61 4d 75 6c 74 29 2f 73 69 7a 65 6f  eof(aMult)/sizeo
8ba0: 66 28 61 4d 75 6c 74 5b 30 5d 29 3b 20 69 2b 2b  f(aMult[0]); i++
8bb0: 29 7b 0a 20 20 20 20 69 66 28 20 73 71 6c 69 74  ){.    if( sqlit
8bc0: 65 33 5f 73 74 72 69 63 6d 70 28 61 4d 75 6c 74  e3_stricmp(aMult
8bd0: 5b 69 5d 2e 7a 53 75 66 66 69 78 2c 20 7a 41 72  [i].zSuffix, zAr
8be0: 67 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 76  g)==0 ){.      v
8bf0: 20 2a 3d 20 61 4d 75 6c 74 5b 69 5d 2e 69 4d 75   *= aMult[i].iMu
8c00: 6c 74 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  lt;.      break;
8c10: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 69 66 28  .    }.  }.  if(
8c20: 20 76 3e 30 78 37 66 66 66 66 66 66 66 20 29 20   v>0x7fffffff ) 
8c30: 66 61 74 61 6c 45 72 72 6f 72 28 22 70 61 72 61  fatalError("para
8c40: 6d 65 74 65 72 20 74 6f 6f 20 6c 61 72 67 65 20  meter too large 
8c50: 2d 20 6d 61 78 20 32 31 34 37 34 38 33 36 34 38  - max 2147483648
8c60: 22 29 3b 0a 20 20 72 65 74 75 72 6e 20 28 69 6e  ");.  return (in
8c70: 74 29 28 69 73 4e 65 67 3f 20 2d 76 20 3a 20 76  t)(isNeg? -v : v
8c80: 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  );.}../*.** Retu
8c90: 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  rn the number of
8ca0: 20 22 76 22 20 63 68 61 72 61 63 74 65 72 73 20   "v" characters 
8cb0: 69 6e 20 61 20 73 74 72 69 6e 67 2e 20 20 52 65  in a string.  Re
8cc0: 74 75 72 6e 20 30 20 69 66 20 74 68 65 72 65 0a  turn 0 if there.
8cd0: 2a 2a 20 61 72 65 20 61 6e 79 20 63 68 61 72 61  ** are any chara
8ce0: 63 74 65 72 73 20 69 6e 20 74 68 65 20 73 74 72  cters in the str
8cf0: 69 6e 67 20 6f 74 68 65 72 20 74 68 61 6e 20 22  ing other than "
8d00: 76 22 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  v"..*/.static in
8d10: 74 20 6e 75 6d 62 65 72 4f 66 56 43 68 61 72 28  t numberOfVChar(
8d20: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 29 7b 0a  const char *z){.
8d30: 20 20 69 6e 74 20 4e 20 3d 20 30 3b 0a 20 20 77    int N = 0;.  w
8d40: 68 69 6c 65 28 20 7a 5b 30 5d 20 26 26 20 7a 5b  hile( z[0] && z[
8d50: 30 5d 3d 3d 27 76 27 20 29 7b 0a 20 20 20 20 7a  0]=='v' ){.    z
8d60: 2b 2b 3b 0a 20 20 20 20 4e 2b 2b 3b 0a 20 20 7d  ++;.    N++;.  }
8d70: 0a 20 20 72 65 74 75 72 6e 20 7a 5b 30 5d 3d 3d  .  return z[0]==
8d80: 30 20 3f 20 4e 20 3a 20 30 3b 0a 7d 0a 0a 2f 2a  0 ? N : 0;.}../*
8d90: 0a 2a 2a 20 50 72 69 6e 74 20 73 6b 65 74 63 68  .** Print sketch
8da0: 79 20 64 6f 63 75 6d 65 6e 74 61 74 69 6f 6e 20  y documentation 
8db0: 66 6f 72 20 74 68 69 73 20 75 74 69 6c 69 74 79  for this utility
8dc0: 20 70 72 6f 67 72 61 6d 0a 2a 2f 0a 73 74 61 74   program.*/.stat
8dd0: 69 63 20 76 6f 69 64 20 73 68 6f 77 48 65 6c 70  ic void showHelp
8de0: 28 76 6f 69 64 29 7b 0a 20 20 70 72 69 6e 74 66  (void){.  printf
8df0: 28 22 55 73 61 67 65 3a 20 25 73 20 5b 6f 70 74  ("Usage: %s [opt
8e00: 69 6f 6e 73 5d 20 53 4f 55 52 43 45 2d 44 42 20  ions] SOURCE-DB 
8e10: 3f 41 52 47 53 2e 2e 2e 3f 5c 6e 22 2c 20 67 2e  ?ARGS...?\n", g.
8e20: 7a 41 72 67 76 30 29 3b 0a 20 20 70 72 69 6e 74  zArgv0);.  print
8e30: 66 28 0a 22 52 65 61 64 20 64 61 74 61 62 61 73  f(."Read databas
8e40: 65 73 20 61 6e 64 20 53 51 4c 20 73 63 72 69 70  es and SQL scrip
8e50: 74 73 20 66 72 6f 6d 20 53 4f 55 52 43 45 2d 44  ts from SOURCE-D
8e60: 42 20 61 6e 64 20 65 78 65 63 75 74 65 20 65 61  B and execute ea
8e70: 63 68 20 73 63 72 69 70 74 20 61 67 61 69 6e 73  ch script agains
8e80: 74 5c 6e 22 0a 22 65 61 63 68 20 64 61 74 61 62  t\n"."each datab
8e90: 61 73 65 2c 20 63 68 65 63 6b 69 6e 67 20 66 6f  ase, checking fo
8ea0: 72 20 63 72 61 73 68 65 73 20 61 6e 64 20 6d 65  r crashes and me
8eb0: 6d 6f 72 79 20 6c 65 61 6b 73 2e 5c 6e 22 0a 22  mory leaks.\n"."
8ec0: 4f 70 74 69 6f 6e 73 3a 5c 6e 22 0a 22 20 20 2d  Options:\n"."  -
8ed0: 2d 63 65 6c 6c 2d 73 69 7a 65 2d 63 68 65 63 6b  -cell-size-check
8ee0: 20 20 20 20 53 65 74 20 74 68 65 20 50 52 41 47      Set the PRAG
8ef0: 4d 41 20 63 65 6c 6c 5f 73 69 7a 65 5f 63 68 65  MA cell_size_che
8f00: 63 6b 3d 4f 4e 5c 6e 22 0a 22 20 20 2d 2d 64 62  ck=ON\n"."  --db
8f10: 69 64 20 4e 20 20 20 20 20 20 20 20 20 20 20 20  id N            
8f20: 20 55 73 65 20 6f 6e 6c 79 20 74 68 65 20 64 61   Use only the da
8f30: 74 61 62 61 73 65 20 77 68 65 72 65 20 64 62 69  tabase where dbi
8f40: 64 3d 4e 5c 6e 22 0a 22 20 20 2d 2d 65 78 70 6f  d=N\n"."  --expo
8f50: 72 74 2d 64 62 20 44 49 52 20 20 20 20 20 20 57  rt-db DIR      W
8f60: 72 69 74 65 20 64 61 74 61 62 61 73 65 73 20 74  rite databases t
8f70: 6f 20 66 69 6c 65 73 28 73 29 20 69 6e 20 44 49  o files(s) in DI
8f80: 52 2e 20 57 6f 72 6b 73 20 77 69 74 68 20 2d 2d  R. Works with --
8f90: 64 62 69 64 5c 6e 22 0a 22 20 20 2d 2d 65 78 70  dbid\n"."  --exp
8fa0: 6f 72 74 2d 73 71 6c 20 44 49 52 20 20 20 20 20  ort-sql DIR     
8fb0: 57 72 69 74 65 20 53 51 4c 20 74 6f 20 66 69 6c  Write SQL to fil
8fc0: 65 28 73 29 20 69 6e 20 44 49 52 2e 20 41 6c 73  e(s) in DIR. Als
8fd0: 6f 20 77 6f 72 6b 73 20 77 69 74 68 20 2d 2d 73  o works with --s
8fe0: 71 6c 69 64 5c 6e 22 0a 22 20 20 2d 2d 68 65 6c  qlid\n"."  --hel
8ff0: 70 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  p               
9000: 53 68 6f 77 20 74 68 69 73 20 68 65 6c 70 20 74  Show this help t
9010: 65 78 74 5c 6e 22 0a 22 20 20 2d 2d 69 6e 66 6f  ext\n"."  --info
9020: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53                 S
9030: 68 6f 77 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20  how information 
9040: 61 62 6f 75 74 20 53 4f 55 52 43 45 2d 44 42 20  about SOURCE-DB 
9050: 77 2f 6f 20 72 75 6e 6e 69 6e 67 20 74 65 73 74  w/o running test
9060: 73 5c 6e 22 0a 22 20 20 2d 2d 6c 69 6d 69 74 2d  s\n"."  --limit-
9070: 6d 65 6d 20 4e 20 20 20 20 20 20 20 20 4c 69 6d  mem N        Lim
9080: 69 74 20 6d 65 6d 6f 72 79 20 75 73 65 64 20 62  it memory used b
9090: 79 20 74 65 73 74 20 53 51 4c 69 74 65 20 69 6e  y test SQLite in
90a0: 73 74 61 6e 63 65 20 74 6f 20 4e 20 62 79 74 65  stance to N byte
90b0: 73 5c 6e 22 0a 22 20 20 2d 2d 6c 69 6d 69 74 2d  s\n"."  --limit-
90c0: 76 64 62 65 20 20 20 20 20 20 20 20 20 50 61 6e  vdbe         Pan
90d0: 69 63 20 69 66 20 61 6e 79 20 74 65 73 74 20 72  ic if any test r
90e0: 75 6e 73 20 66 6f 72 20 6d 6f 72 65 20 74 68 61  uns for more tha
90f0: 6e 20 31 30 30 2c 30 30 30 20 63 79 63 6c 65 73  n 100,000 cycles
9100: 5c 6e 22 0a 22 20 20 2d 2d 6c 6f 61 64 2d 73 71  \n"."  --load-sq
9110: 6c 20 41 52 47 53 2e 2e 2e 20 20 20 4c 6f 61 64  l ARGS...   Load
9120: 20 53 51 4c 20 73 63 72 69 70 74 73 20 66 72 6f   SQL scripts fro
9130: 6e 20 66 69 6c 65 73 20 69 6e 74 6f 20 53 4f 55  n files into SOU
9140: 52 43 45 2d 44 42 5c 6e 22 0a 22 20 20 2d 2d 6c  RCE-DB\n"."  --l
9150: 6f 61 64 2d 64 62 20 41 52 47 53 2e 2e 2e 20 20  oad-db ARGS...  
9160: 20 20 4c 6f 61 64 20 74 65 6d 70 6c 61 74 65 20    Load template 
9170: 64 61 74 61 62 61 73 65 73 20 66 72 6f 6d 20 66  databases from f
9180: 69 6c 65 73 20 69 6e 74 6f 20 53 4f 55 52 43 45  iles into SOURCE
9190: 5f 44 42 5c 6e 22 0a 22 20 20 2d 2d 6c 6f 61 64  _DB\n"."  --load
91a0: 2d 64 62 73 71 6c 20 41 52 47 53 2e 2e 20 20 4c  -dbsql ARGS..  L
91b0: 6f 61 64 20 64 62 73 71 6c 66 75 7a 7a 20 6f 75  oad dbsqlfuzz ou
91c0: 74 70 75 74 73 20 69 6e 74 6f 20 74 68 65 20 78  tputs into the x
91d0: 73 71 6c 20 74 61 62 6c 65 5c 6e 22 0a 22 20 20  sql table\n"."  
91e0: 2d 6d 20 54 45 58 54 20 20 20 20 20 20 20 20 20  -m TEXT         
91f0: 20 20 20 20 20 41 64 64 20 61 20 64 65 73 63 72       Add a descr
9200: 69 70 74 69 6f 6e 20 74 6f 20 74 68 65 20 64 61  iption to the da
9210: 74 61 62 61 73 65 5c 6e 22 0a 22 20 20 2d 2d 6e  tabase\n"."  --n
9220: 61 74 69 76 65 2d 76 66 73 20 20 20 20 20 20 20  ative-vfs       
9230: 20 20 55 73 65 20 74 68 65 20 6e 61 74 69 76 65    Use the native
9240: 20 56 46 53 20 66 6f 72 20 69 6e 69 74 69 61 6c   VFS for initial
9250: 6c 79 20 65 6d 70 74 79 20 64 61 74 61 62 61 73  ly empty databas
9260: 65 20 66 69 6c 65 73 5c 6e 22 0a 22 20 20 2d 2d  e files\n"."  --
9270: 6e 61 74 69 76 65 2d 6d 61 6c 6c 6f 63 20 20 20  native-malloc   
9280: 20 20 20 54 75 72 6e 20 6f 66 66 20 4d 45 4d 53     Turn off MEMS
9290: 59 53 33 2f 35 20 61 6e 64 20 4c 6f 6f 6b 61 73  YS3/5 and Lookas
92a0: 69 64 65 5c 6e 22 0a 22 20 20 2d 2d 6f 73 73 2d  ide\n"."  --oss-
92b0: 66 75 7a 7a 20 20 20 20 20 20 20 20 20 20 20 45  fuzz           E
92c0: 6e 61 62 6c 65 20 4f 53 53 2d 46 55 5a 5a 20 74  nable OSS-FUZZ t
92d0: 65 73 74 69 6e 67 5c 6e 22 0a 22 20 20 2d 2d 70  esting\n"."  --p
92e0: 72 6e 67 2d 73 65 65 64 20 4e 20 20 20 20 20 20  rng-seed N      
92f0: 20 20 53 65 65 64 20 76 61 6c 75 65 20 66 6f 72    Seed value for
9300: 20 74 68 65 20 50 52 47 4e 20 69 6e 73 69 64 65   the PRGN inside
9310: 20 6f 66 20 53 51 4c 69 74 65 5c 6e 22 0a 22 20   of SQLite\n"." 
9320: 20 2d 71 7c 2d 2d 71 75 69 65 74 20 20 20 20 20   -q|--quiet     
9330: 20 20 20 20 20 20 52 65 64 75 63 65 64 20 6f 75        Reduced ou
9340: 74 70 75 74 5c 6e 22 0a 22 20 20 2d 2d 72 65 62  tput\n"."  --reb
9350: 75 69 6c 64 20 20 20 20 20 20 20 20 20 20 20 20  uild            
9360: 52 65 62 75 69 6c 64 20 61 6e 64 20 76 61 63 75  Rebuild and vacu
9370: 75 6d 20 74 68 65 20 64 61 74 61 62 61 73 65 20  um the database 
9380: 66 69 6c 65 5c 6e 22 0a 22 20 20 2d 2d 72 65 73  file\n"."  --res
9390: 75 6c 74 2d 74 72 61 63 65 20 20 20 20 20 20 20  ult-trace       
93a0: 53 68 6f 77 20 74 68 65 20 72 65 73 75 6c 74 73  Show the results
93b0: 20 6f 66 20 65 61 63 68 20 53 51 4c 20 63 6f 6d   of each SQL com
93c0: 6d 61 6e 64 5c 6e 22 0a 22 20 20 2d 2d 73 71 6c  mand\n"."  --sql
93d0: 69 64 20 4e 20 20 20 20 20 20 20 20 20 20 20 20  id N            
93e0: 55 73 65 20 6f 6e 6c 79 20 53 51 4c 20 77 68 65  Use only SQL whe
93f0: 72 65 20 73 71 6c 69 64 3d 4e 5c 6e 22 0a 22 20  re sqlid=N\n"." 
9400: 20 2d 2d 74 69 6d 65 6f 75 74 20 4e 20 20 20 20   --timeout N    
9410: 20 20 20 20 20 20 41 62 6f 72 74 20 69 66 20 61        Abort if a
9420: 6e 79 20 73 69 6e 67 6c 65 20 74 65 73 74 20 6e  ny single test n
9430: 65 65 64 73 20 6d 6f 72 65 20 74 68 61 6e 20 4e  eeds more than N
9440: 20 73 65 63 6f 6e 64 73 5c 6e 22 0a 22 20 20 2d   seconds\n"."  -
9450: 76 7c 2d 2d 76 65 72 62 6f 73 65 20 20 20 20 20  v|--verbose     
9460: 20 20 20 20 49 6e 63 72 65 61 73 65 64 20 6f 75      Increased ou
9470: 74 70 75 74 2e 20 20 52 65 70 65 61 74 20 66 6f  tput.  Repeat fo
9480: 72 20 6d 6f 72 65 20 6f 75 74 70 75 74 2e 5c 6e  r more output.\n
9490: 22 0a 20 20 29 3b 0a 7d 0a 0a 69 6e 74 20 6d 61  ".  );.}..int ma
94a0: 69 6e 28 69 6e 74 20 61 72 67 63 2c 20 63 68 61  in(int argc, cha
94b0: 72 20 2a 2a 61 72 67 76 29 7b 0a 20 20 73 71 6c  r **argv){.  sql
94c0: 69 74 65 33 5f 69 6e 74 36 34 20 69 42 65 67 69  ite3_int64 iBegi
94d0: 6e 3b 20 20 20 20 20 20 20 20 2f 2a 20 53 74 61  n;        /* Sta
94e0: 72 74 20 74 69 6d 65 20 6f 66 20 74 68 69 73 20  rt time of this 
94f0: 70 72 6f 67 72 61 6d 20 2a 2f 0a 20 20 69 6e 74  program */.  int
9500: 20 71 75 69 65 74 46 6c 61 67 20 3d 20 30 3b 20   quietFlag = 0; 
9510: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75            /* Tru
9520: 65 20 69 66 20 2d 2d 71 75 69 65 74 20 6f 72 20  e if --quiet or 
9530: 2d 71 20 2a 2f 0a 20 20 69 6e 74 20 76 65 72 62  -q */.  int verb
9540: 6f 73 65 46 6c 61 67 20 3d 20 30 3b 20 20 20 20  oseFlag = 0;    
9550: 20 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20       /* True if 
9560: 2d 2d 76 65 72 62 6f 73 65 20 6f 72 20 2d 76 20  --verbose or -v 
9570: 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 49 6e 73 53  */.  char *zInsS
9580: 71 6c 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20  ql = 0;         
9590: 20 20 2f 2a 20 53 51 4c 20 73 74 61 74 65 6d 65    /* SQL stateme
95a0: 6e 74 20 66 6f 72 20 2d 2d 6c 6f 61 64 2d 64 62  nt for --load-db
95b0: 20 6f 72 20 2d 2d 6c 6f 61 64 2d 73 71 6c 20 2a   or --load-sql *
95c0: 2f 0a 20 20 69 6e 74 20 69 46 69 72 73 74 49 6e  /.  int iFirstIn
95d0: 73 41 72 67 20 3d 20 30 3b 20 20 20 20 20 20 20  sArg = 0;       
95e0: 20 2f 2a 20 46 69 72 73 74 20 61 72 67 76 5b 5d   /* First argv[]
95f0: 20 66 6f 72 20 2d 2d 6c 6f 61 64 2d 64 62 20 6f   for --load-db o
9600: 72 20 2d 2d 6c 6f 61 64 2d 73 71 6c 20 2a 2f 0a  r --load-sql */.
9610: 20 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20    sqlite3 *db = 
9620: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  0;             /
9630: 2a 20 54 68 65 20 6f 70 65 6e 20 64 61 74 61 62  * The open datab
9640: 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a  ase connection *
9650: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74  /.  sqlite3_stmt
9660: 20 2a 70 53 74 6d 74 3b 20 20 20 20 20 20 20 20   *pStmt;        
9670: 20 2f 2a 20 41 20 70 72 65 70 61 72 65 64 20 73   /* A prepared s
9680: 74 61 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 69 6e  tatement */.  in
9690: 74 20 72 63 3b 20 20 20 20 20 20 20 20 20 20 20  t rc;           
96a0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 52 65             /* Re
96b0: 73 75 6c 74 20 63 6f 64 65 20 66 72 6f 6d 20 53  sult code from S
96c0: 51 4c 69 74 65 20 69 6e 74 65 72 66 61 63 65 20  QLite interface 
96d0: 63 61 6c 6c 73 20 2a 2f 0a 20 20 42 6c 6f 62 20  calls */.  Blob 
96e0: 2a 70 53 71 6c 3b 20 20 20 20 20 20 20 20 20 20  *pSql;          
96f0: 20 20 20 20 20 20 20 20 2f 2a 20 46 6f 72 20 6c          /* For l
9700: 6f 6f 70 69 6e 67 20 6f 76 65 72 20 53 51 4c 20  ooping over SQL 
9710: 73 63 72 69 70 74 73 20 2a 2f 0a 20 20 42 6c 6f  scripts */.  Blo
9720: 62 20 2a 70 44 62 3b 20 20 20 20 20 20 20 20 20  b *pDb;         
9730: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 46 6f 72            /* For
9740: 20 6c 6f 6f 70 69 6e 67 20 6f 76 65 72 20 74 65   looping over te
9750: 6d 70 6c 61 74 65 20 64 61 74 61 62 61 73 65 73  mplate databases
9760: 20 2a 2f 0a 20 20 69 6e 74 20 69 3b 20 20 20 20   */.  int i;    
9770: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9780: 20 20 20 2f 2a 20 4c 6f 6f 70 20 69 6e 64 65 78     /* Loop index
9790: 20 66 6f 72 20 74 68 65 20 61 72 67 76 5b 5d 20   for the argv[] 
97a0: 6c 6f 6f 70 20 2a 2f 0a 20 20 69 6e 74 20 64 62  loop */.  int db
97b0: 53 71 6c 4f 6e 6c 79 20 3d 20 30 3b 20 20 20 20  SqlOnly = 0;    
97c0: 20 20 20 20 20 20 20 2f 2a 20 4f 6e 6c 79 20 75         /* Only u
97d0: 73 65 20 73 63 72 69 70 74 73 20 74 68 61 74 20  se scripts that 
97e0: 61 72 65 20 64 62 73 71 6c 66 75 7a 7a 20 2a 2f  are dbsqlfuzz */
97f0: 0a 20 20 69 6e 74 20 6f 6e 6c 79 53 71 6c 69 64  .  int onlySqlid
9800: 20 3d 20 2d 31 3b 20 20 20 20 20 20 20 20 20 20   = -1;          
9810: 2f 2a 20 2d 2d 73 71 6c 69 64 20 2a 2f 0a 20 20  /* --sqlid */.  
9820: 69 6e 74 20 6f 6e 6c 79 44 62 69 64 20 3d 20 2d  int onlyDbid = -
9830: 31 3b 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  1;           /* 
9840: 2d 2d 64 62 69 64 20 2a 2f 0a 20 20 69 6e 74 20  --dbid */.  int 
9850: 6e 61 74 69 76 65 46 6c 61 67 20 3d 20 30 3b 20  nativeFlag = 0; 
9860: 20 20 20 20 20 20 20 20 20 2f 2a 20 2d 2d 6e 61           /* --na
9870: 74 69 76 65 2d 76 66 73 20 2a 2f 0a 20 20 69 6e  tive-vfs */.  in
9880: 74 20 72 65 62 75 69 6c 64 46 6c 61 67 20 3d 20  t rebuildFlag = 
9890: 30 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 2d 2d  0;         /* --
98a0: 72 65 62 75 69 6c 64 20 2a 2f 0a 20 20 69 6e 74  rebuild */.  int
98b0: 20 76 64 62 65 4c 69 6d 69 74 46 6c 61 67 20 3d   vdbeLimitFlag =
98c0: 20 30 3b 20 20 20 20 20 20 20 2f 2a 20 2d 2d 6c   0;       /* --l
98d0: 69 6d 69 74 2d 76 64 62 65 20 2a 2f 0a 20 20 69  imit-vdbe */.  i
98e0: 6e 74 20 69 6e 66 6f 46 6c 61 67 20 3d 20 30 3b  nt infoFlag = 0;
98f0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 2d              /* -
9900: 2d 69 6e 66 6f 20 2a 2f 0a 20 20 69 6e 74 20 74  -info */.  int t
9910: 69 6d 65 6f 75 74 54 65 73 74 20 3d 20 30 3b 20  imeoutTest = 0; 
9920: 20 20 20 20 20 20 20 20 2f 2a 20 75 6e 64 6f 63          /* undoc
9930: 75 6d 65 6e 74 65 64 20 2d 2d 74 69 6d 65 6f 75  umented --timeou
9940: 74 2d 74 65 73 74 20 66 6c 61 67 20 2a 2f 0a 20  t-test flag */. 
9950: 20 69 6e 74 20 72 75 6e 46 6c 61 67 73 20 3d 20   int runFlags = 
9960: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  0;            /*
9970: 20 46 6c 61 67 73 20 73 65 6e 74 20 74 6f 20 72   Flags sent to r
9980: 75 6e 53 71 6c 28 29 20 2a 2f 0a 20 20 63 68 61  unSql() */.  cha
9990: 72 20 2a 7a 4d 73 67 20 3d 20 30 3b 20 20 20 20  r *zMsg = 0;    
99a0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 64 64            /* Add
99b0: 20 74 68 69 73 20 6d 65 73 73 61 67 65 20 2a 2f   this message */
99c0: 0a 20 20 69 6e 74 20 6e 53 72 63 44 62 20 3d 20  .  int nSrcDb = 
99d0: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  0;              
99e0: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 73 6f 75  /* Number of sou
99f0: 72 63 65 20 64 61 74 61 62 61 73 65 73 20 2a 2f  rce databases */
9a00: 0a 20 20 63 68 61 72 20 2a 2a 61 7a 53 72 63 44  .  char **azSrcD
9a10: 62 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  b = 0;          
9a20: 2f 2a 20 41 72 72 61 79 20 6f 66 20 73 6f 75 72  /* Array of sour
9a30: 63 65 20 64 61 74 61 62 61 73 65 20 6e 61 6d 65  ce database name
9a40: 73 20 2a 2f 0a 20 20 69 6e 74 20 69 53 72 63 44  s */.  int iSrcD
9a50: 62 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b;              
9a60: 20 20 20 20 2f 2a 20 4c 6f 6f 70 20 6f 76 65 72      /* Loop over
9a70: 20 61 6c 6c 20 73 6f 75 72 63 65 20 64 61 74 61   all source data
9a80: 62 61 73 65 73 20 2a 2f 0a 20 20 69 6e 74 20 6e  bases */.  int n
9a90: 54 65 73 74 20 3d 20 30 3b 20 20 20 20 20 20 20  Test = 0;       
9aa0: 20 20 20 20 20 20 20 20 2f 2a 20 54 6f 74 61 6c          /* Total
9ab0: 20 6e 75 6d 62 65 72 20 6f 66 20 74 65 73 74 73   number of tests
9ac0: 20 70 65 72 66 6f 72 6d 65 64 20 2a 2f 0a 20 20   performed */.  
9ad0: 63 68 61 72 20 2a 7a 44 62 4e 61 6d 65 20 3d 20  char *zDbName = 
9ae0: 22 22 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20  "";          /* 
9af0: 41 70 70 72 65 76 69 61 74 65 64 20 6e 61 6d 65  Appreviated name
9b00: 20 6f 66 20 61 20 73 6f 75 72 63 65 20 64 61 74   of a source dat
9b10: 61 62 61 73 65 20 2a 2f 0a 20 20 63 6f 6e 73 74  abase */.  const
9b20: 20 63 68 61 72 20 2a 7a 46 61 69 6c 43 6f 64 65   char *zFailCode
9b30: 20 3d 20 30 3b 20 20 20 2f 2a 20 56 61 6c 75 65   = 0;   /* Value
9b40: 20 6f 66 20 74 68 65 20 54 45 53 54 5f 46 41 49   of the TEST_FAI
9b50: 4c 55 52 45 20 65 6e 76 20 76 61 72 69 61 62 6c  LURE env variabl
9b60: 65 20 2a 2f 0a 20 20 69 6e 74 20 63 65 6c 6c 53  e */.  int cellS
9b70: 7a 43 6b 46 6c 61 67 20 3d 20 30 3b 20 20 20 20  zCkFlag = 0;    
9b80: 20 20 20 20 2f 2a 20 2d 2d 63 65 6c 6c 2d 73 69      /* --cell-si
9b90: 7a 65 2d 63 68 65 63 6b 20 2a 2f 0a 20 20 69 6e  ze-check */.  in
9ba0: 74 20 73 71 6c 46 75 7a 7a 20 3d 20 30 3b 20 20  t sqlFuzz = 0;  
9bb0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72             /* Tr
9bc0: 75 65 20 66 6f 72 20 53 51 4c 20 66 75 7a 7a 2e  ue for SQL fuzz.
9bd0: 20 46 61 6c 73 65 20 66 6f 72 20 44 42 20 66 75   False for DB fu
9be0: 7a 7a 20 2a 2f 0a 20 20 69 6e 74 20 69 54 69 6d  zz */.  int iTim
9bf0: 65 6f 75 74 20 3d 20 31 32 30 3b 20 20 20 20 20  eout = 120;     
9c00: 20 20 20 20 20 2f 2a 20 44 65 66 61 75 6c 74 20       /* Default 
9c10: 31 32 30 2d 73 65 63 6f 6e 64 20 74 69 6d 65 6f  120-second timeo
9c20: 75 74 20 2a 2f 0a 20 20 69 6e 74 20 6e 4d 65 6d  ut */.  int nMem
9c30: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
9c40: 20 20 20 20 20 2f 2a 20 4d 65 6d 6f 72 79 20 6c       /* Memory l
9c50: 69 6d 69 74 20 2a 2f 0a 20 20 69 6e 74 20 6e 4d  imit */.  int nM
9c60: 65 6d 54 68 69 73 44 62 20 3d 20 30 3b 20 20 20  emThisDb = 0;   
9c70: 20 20 20 20 20 20 20 2f 2a 20 4d 65 6d 6f 72 79         /* Memory
9c80: 20 6c 69 6d 69 74 20 73 65 74 20 62 79 20 74 68   limit set by th
9c90: 65 20 43 4f 4e 46 49 47 20 74 61 62 6c 65 20 2a  e CONFIG table *
9ca0: 2f 0a 20 20 63 68 61 72 20 2a 7a 45 78 70 44 62  /.  char *zExpDb
9cb0: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
9cc0: 20 2f 2a 20 57 72 69 74 65 20 44 61 74 61 62 61   /* Write Databa
9cd0: 73 65 73 20 74 6f 20 66 69 6c 65 73 20 69 6e 20  ses to files in 
9ce0: 74 68 69 73 20 64 69 72 65 63 74 6f 72 79 20 2a  this directory *
9cf0: 2f 0a 20 20 63 68 61 72 20 2a 7a 45 78 70 53 71  /.  char *zExpSq
9d00: 6c 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  l = 0;          
9d10: 20 2f 2a 20 57 72 69 74 65 20 53 51 4c 20 74 6f   /* Write SQL to
9d20: 20 66 69 6c 65 73 20 69 6e 20 74 68 69 73 20 64   files in this d
9d30: 69 72 65 63 74 6f 72 79 20 2a 2f 0a 20 20 76 6f  irectory */.  vo
9d40: 69 64 20 2a 70 48 65 61 70 20 3d 20 30 3b 20 20  id *pHeap = 0;  
9d50: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 48 65             /* He
9d60: 61 70 20 66 6f 72 20 75 73 65 20 62 79 20 53 51  ap for use by SQ
9d70: 4c 69 74 65 20 2a 2f 0a 20 20 69 6e 74 20 6f 73  Lite */.  int os
9d80: 73 46 75 7a 7a 20 3d 20 30 3b 20 20 20 20 20 20  sFuzz = 0;      
9d90: 20 20 20 20 20 20 20 2f 2a 20 65 6e 61 62 6c 65         /* enable
9da0: 20 4f 53 53 2d 46 55 5a 5a 20 74 65 73 74 69 6e   OSS-FUZZ testin
9db0: 67 20 2a 2f 0a 20 20 69 6e 74 20 6f 73 73 46 75  g */.  int ossFu
9dc0: 7a 7a 54 68 69 73 44 62 20 3d 20 30 3b 20 20 20  zzThisDb = 0;   
9dd0: 20 20 20 20 2f 2a 20 6f 73 73 46 75 7a 7a 20 76      /* ossFuzz v
9de0: 61 6c 75 65 20 66 6f 72 20 74 68 69 73 20 70 61  alue for this pa
9df0: 72 74 69 63 75 6c 61 72 20 64 61 74 61 62 61 73  rticular databas
9e00: 65 20 2a 2f 0a 20 20 69 6e 74 20 6e 61 74 69 76  e */.  int nativ
9e10: 65 4d 61 6c 6c 6f 63 20 3d 20 30 3b 20 20 20 20  eMalloc = 0;    
9e20: 20 20 20 20 2f 2a 20 54 75 72 6e 20 6f 66 66 20      /* Turn off 
9e30: 4d 45 4d 53 59 53 33 2f 35 20 61 6e 64 20 6c 6f  MEMSYS3/5 and lo
9e40: 6f 6b 61 73 69 64 65 20 69 66 20 74 72 75 65 20  okaside if true 
9e50: 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  */.  sqlite3_vfs
9e60: 20 2a 70 44 66 6c 74 56 66 73 3b 20 20 20 20 20   *pDfltVfs;     
9e70: 20 20 2f 2a 20 54 68 65 20 64 65 66 61 75 6c 74    /* The default
9e80: 20 56 46 53 20 2a 2f 0a 20 20 69 6e 74 20 6f 70   VFS */.  int op
9e90: 65 6e 46 6c 61 67 73 34 44 61 74 61 3b 20 20 20  enFlags4Data;   
9ea0: 20 20 20 20 20 20 20 2f 2a 20 46 6c 61 67 73 20         /* Flags 
9eb0: 66 6f 72 20 73 71 6c 69 74 65 33 5f 6f 70 65 6e  for sqlite3_open
9ec0: 5f 76 32 28 29 20 2a 2f 0a 20 20 69 6e 74 20 6e  _v2() */.  int n
9ed0: 56 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  V;              
9ee0: 20 20 20 20 20 20 20 20 2f 2a 20 48 6f 77 20 6d          /* How m
9ef0: 75 63 68 20 74 6f 20 69 6e 63 72 65 61 73 65 20  uch to increase 
9f00: 76 65 72 62 6f 73 69 74 79 20 77 69 74 68 20 2d  verbosity with -
9f10: 76 76 76 76 20 2a 2f 0a 0a 20 20 73 71 6c 69 74  vvvv */..  sqlit
9f20: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 28 29 3b  e3_initialize();
9f30: 0a 20 20 69 42 65 67 69 6e 20 3d 20 74 69 6d 65  .  iBegin = time
9f40: 4f 66 44 61 79 28 29 3b 0a 23 69 66 64 65 66 20  OfDay();.#ifdef 
9f50: 5f 5f 75 6e 69 78 5f 5f 0a 20 20 73 69 67 6e 61  __unix__.  signa
9f60: 6c 28 53 49 47 41 4c 52 4d 2c 20 74 69 6d 65 6f  l(SIGALRM, timeo
9f70: 75 74 48 61 6e 64 6c 65 72 29 3b 0a 23 65 6e 64  utHandler);.#end
9f80: 69 66 0a 20 20 67 2e 7a 41 72 67 76 30 20 3d 20  if.  g.zArgv0 = 
9f90: 61 72 67 76 5b 30 5d 3b 0a 20 20 6f 70 65 6e 46  argv[0];.  openF
9fa0: 6c 61 67 73 34 44 61 74 61 20 3d 20 53 51 4c 49  lags4Data = SQLI
9fb0: 54 45 5f 4f 50 45 4e 5f 52 45 41 44 4f 4e 4c 59  TE_OPEN_READONLY
9fc0: 3b 0a 20 20 7a 46 61 69 6c 43 6f 64 65 20 3d 20  ;.  zFailCode = 
9fd0: 67 65 74 65 6e 76 28 22 54 45 53 54 5f 46 41 49  getenv("TEST_FAI
9fe0: 4c 55 52 45 22 29 3b 0a 20 20 70 44 66 6c 74 56  LURE");.  pDfltV
9ff0: 66 73 20 3d 20 73 71 6c 69 74 65 33 5f 76 66 73  fs = sqlite3_vfs
a000: 5f 66 69 6e 64 28 30 29 3b 0a 20 20 69 6e 6d 65  _find(0);.  inme
a010: 6d 56 66 73 52 65 67 69 73 74 65 72 28 31 29 3b  mVfsRegister(1);
a020: 0a 20 20 66 6f 72 28 69 3d 31 3b 20 69 3c 61 72  .  for(i=1; i<ar
a030: 67 63 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 63 6f  gc; i++){.    co
a040: 6e 73 74 20 63 68 61 72 20 2a 7a 20 3d 20 61 72  nst char *z = ar
a050: 67 76 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20 7a  gv[i];.    if( z
a060: 5b 30 5d 3d 3d 27 2d 27 20 29 7b 0a 20 20 20 20  [0]=='-' ){.    
a070: 20 20 7a 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28    z++;.      if(
a080: 20 7a 5b 30 5d 3d 3d 27 2d 27 20 29 20 7a 2b 2b   z[0]=='-' ) z++
a090: 3b 0a 20 20 20 20 20 20 69 66 28 20 73 74 72 63  ;.      if( strc
a0a0: 6d 70 28 7a 2c 22 63 65 6c 6c 2d 73 69 7a 65 2d  mp(z,"cell-size-
a0b0: 63 68 65 63 6b 22 29 3d 3d 30 20 29 7b 0a 20 20  check")==0 ){.  
a0c0: 20 20 20 20 20 20 63 65 6c 6c 53 7a 43 6b 46 6c        cellSzCkFl
a0d0: 61 67 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 65  ag = 1;.      }e
a0e0: 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74  lse.      if( st
a0f0: 72 63 6d 70 28 7a 2c 22 64 62 69 64 22 29 3d 3d  rcmp(z,"dbid")==
a100: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28  0 ){.        if(
a110: 20 69 3e 3d 61 72 67 63 2d 31 20 29 20 66 61 74   i>=argc-1 ) fat
a120: 61 6c 45 72 72 6f 72 28 22 6d 69 73 73 69 6e 67  alError("missing
a130: 20 61 72 67 75 6d 65 6e 74 73 20 6f 6e 20 25 73   arguments on %s
a140: 22 2c 20 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20  ", argv[i]);.   
a150: 20 20 20 20 20 6f 6e 6c 79 44 62 69 64 20 3d 20       onlyDbid = 
a160: 69 6e 74 65 67 65 72 56 61 6c 75 65 28 61 72 67  integerValue(arg
a170: 76 5b 2b 2b 69 5d 29 3b 0a 20 20 20 20 20 20 7d  v[++i]);.      }
a180: 65 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73  else.      if( s
a190: 74 72 63 6d 70 28 7a 2c 22 65 78 70 6f 72 74 2d  trcmp(z,"export-
a1a0: 64 62 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  db")==0 ){.     
a1b0: 20 20 20 69 66 28 20 69 3e 3d 61 72 67 63 2d 31     if( i>=argc-1
a1c0: 20 29 20 66 61 74 61 6c 45 72 72 6f 72 28 22 6d   ) fatalError("m
a1d0: 69 73 73 69 6e 67 20 61 72 67 75 6d 65 6e 74 73  issing arguments
a1e0: 20 6f 6e 20 25 73 22 2c 20 61 72 67 76 5b 69 5d   on %s", argv[i]
a1f0: 29 3b 0a 20 20 20 20 20 20 20 20 7a 45 78 70 44  );.        zExpD
a200: 62 20 3d 20 61 72 67 76 5b 2b 2b 69 5d 3b 0a 20  b = argv[++i];. 
a210: 20 20 20 20 20 7d 65 6c 73 65 0a 20 20 20 20 20       }else.     
a220: 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 65   if( strcmp(z,"e
a230: 78 70 6f 72 74 2d 73 71 6c 22 29 3d 3d 30 20 7c  xport-sql")==0 |
a240: 7c 20 73 74 72 63 6d 70 28 7a 2c 22 65 78 70 6f  | strcmp(z,"expo
a250: 72 74 2d 64 62 73 71 6c 22 29 3d 3d 30 20 29 7b  rt-dbsql")==0 ){
a260: 0a 20 20 20 20 20 20 20 20 69 66 28 20 69 3e 3d  .        if( i>=
a270: 61 72 67 63 2d 31 20 29 20 66 61 74 61 6c 45 72  argc-1 ) fatalEr
a280: 72 6f 72 28 22 6d 69 73 73 69 6e 67 20 61 72 67  ror("missing arg
a290: 75 6d 65 6e 74 73 20 6f 6e 20 25 73 22 2c 20 61  uments on %s", a
a2a0: 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20 20 20  rgv[i]);.       
a2b0: 20 7a 45 78 70 53 71 6c 20 3d 20 61 72 67 76 5b   zExpSql = argv[
a2c0: 2b 2b 69 5d 3b 0a 20 20 20 20 20 20 7d 65 6c 73  ++i];.      }els
a2d0: 65 0a 20 20 20 20 20 20 69 66 28 20 73 74 72 63  e.      if( strc
a2e0: 6d 70 28 7a 2c 22 68 65 6c 70 22 29 3d 3d 30 20  mp(z,"help")==0 
a2f0: 29 7b 0a 20 20 20 20 20 20 20 20 73 68 6f 77 48  ){.        showH
a300: 65 6c 70 28 29 3b 0a 20 20 20 20 20 20 20 20 72  elp();.        r
a310: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20 20 7d  eturn 0;.      }
a320: 65 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73  else.      if( s
a330: 74 72 63 6d 70 28 7a 2c 22 69 6e 66 6f 22 29 3d  trcmp(z,"info")=
a340: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e  =0 ){.        in
a350: 66 6f 46 6c 61 67 20 3d 20 31 3b 0a 20 20 20 20  foFlag = 1;.    
a360: 20 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 69 66    }else.      if
a370: 28 20 73 74 72 63 6d 70 28 7a 2c 22 6c 69 6d 69  ( strcmp(z,"limi
a380: 74 2d 6d 65 6d 22 29 3d 3d 30 20 29 7b 0a 23 69  t-mem")==0 ){.#i
a390: 66 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54  f !defined(SQLIT
a3a0: 45 5f 45 4e 41 42 4c 45 5f 4d 45 4d 53 59 53 33  E_ENABLE_MEMSYS3
a3b0: 29 20 26 26 20 21 64 65 66 69 6e 65 64 28 53 51  ) && !defined(SQ
a3c0: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 4d 45 4d 53  LITE_ENABLE_MEMS
a3d0: 59 53 35 29 0a 20 20 20 20 20 20 20 20 66 61 74  YS5).        fat
a3e0: 61 6c 45 72 72 6f 72 28 22 74 68 65 20 25 73 20  alError("the %s 
a3f0: 6f 70 74 69 6f 6e 20 72 65 71 75 69 72 65 73 20  option requires 
a400: 2d 44 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f  -DSQLITE_ENABLE_
a410: 4d 45 4d 53 59 53 35 20 6f 72 20 5f 4d 45 4d 53  MEMSYS5 or _MEMS
a420: 59 53 33 22 2c 0a 20 20 20 20 20 20 20 20 20 20  YS3",.          
a430: 20 20 20 20 20 20 20 20 20 61 72 67 76 5b 69 5d           argv[i]
a440: 29 3b 0a 23 65 6c 73 65 0a 20 20 20 20 20 20 20  );.#else.       
a450: 20 69 66 28 20 69 3e 3d 61 72 67 63 2d 31 20 29   if( i>=argc-1 )
a460: 20 66 61 74 61 6c 45 72 72 6f 72 28 22 6d 69 73   fatalError("mis
a470: 73 69 6e 67 20 61 72 67 75 6d 65 6e 74 73 20 6f  sing arguments o
a480: 6e 20 25 73 22 2c 20 61 72 67 76 5b 69 5d 29 3b  n %s", argv[i]);
a490: 0a 20 20 20 20 20 20 20 20 6e 4d 65 6d 20 3d 20  .        nMem = 
a4a0: 69 6e 74 65 67 65 72 56 61 6c 75 65 28 61 72 67  integerValue(arg
a4b0: 76 5b 2b 2b 69 5d 29 3b 0a 23 65 6e 64 69 66 0a  v[++i]);.#endif.
a4c0: 20 20 20 20 20 20 7d 65 6c 73 65 0a 20 20 20 20        }else.    
a4d0: 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22    if( strcmp(z,"
a4e0: 6c 69 6d 69 74 2d 76 64 62 65 22 29 3d 3d 30 20  limit-vdbe")==0 
a4f0: 29 7b 0a 20 20 20 20 20 20 20 20 76 64 62 65 4c  ){.        vdbeL
a500: 69 6d 69 74 46 6c 61 67 20 3d 20 31 3b 0a 20 20  imitFlag = 1;.  
a510: 20 20 20 20 7d 65 6c 73 65 0a 20 20 20 20 20 20      }else.      
a520: 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 6c 6f  if( strcmp(z,"lo
a530: 61 64 2d 73 71 6c 22 29 3d 3d 30 20 29 7b 0a 20  ad-sql")==0 ){. 
a540: 20 20 20 20 20 20 20 7a 49 6e 73 53 71 6c 20 3d         zInsSql =
a550: 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 78 73   "INSERT INTO xs
a560: 71 6c 28 73 71 6c 74 65 78 74 29 56 41 4c 55 45  ql(sqltext)VALUE
a570: 53 28 43 41 53 54 28 72 65 61 64 66 69 6c 65 28  S(CAST(readfile(
a580: 3f 31 29 20 41 53 20 74 65 78 74 29 29 22 3b 0a  ?1) AS text))";.
a590: 20 20 20 20 20 20 20 20 69 46 69 72 73 74 49 6e          iFirstIn
a5a0: 73 41 72 67 20 3d 20 69 2b 31 3b 0a 20 20 20 20  sArg = i+1;.    
a5b0: 20 20 20 20 6f 70 65 6e 46 6c 61 67 73 34 44 61      openFlags4Da
a5c0: 74 61 20 3d 20 53 51 4c 49 54 45 5f 4f 50 45 4e  ta = SQLITE_OPEN
a5d0: 5f 52 45 41 44 57 52 49 54 45 7c 53 51 4c 49 54  _READWRITE|SQLIT
a5e0: 45 5f 4f 50 45 4e 5f 43 52 45 41 54 45 3b 0a 20  E_OPEN_CREATE;. 
a5f0: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
a600: 20 20 20 20 7d 65 6c 73 65 0a 20 20 20 20 20 20      }else.      
a610: 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 6c 6f  if( strcmp(z,"lo
a620: 61 64 2d 64 62 22 29 3d 3d 30 20 29 7b 0a 20 20  ad-db")==0 ){.  
a630: 20 20 20 20 20 20 7a 49 6e 73 53 71 6c 20 3d 20        zInsSql = 
a640: 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 64 62 28  "INSERT INTO db(
a650: 64 62 63 6f 6e 74 65 6e 74 29 20 56 41 4c 55 45  dbcontent) VALUE
a660: 53 28 72 65 61 64 66 69 6c 65 28 3f 31 29 29 22  S(readfile(?1))"
a670: 3b 0a 20 20 20 20 20 20 20 20 69 46 69 72 73 74  ;.        iFirst
a680: 49 6e 73 41 72 67 20 3d 20 69 2b 31 3b 0a 20 20  InsArg = i+1;.  
a690: 20 20 20 20 20 20 6f 70 65 6e 46 6c 61 67 73 34        openFlags4
a6a0: 44 61 74 61 20 3d 20 53 51 4c 49 54 45 5f 4f 50  Data = SQLITE_OP
a6b0: 45 4e 5f 52 45 41 44 57 52 49 54 45 7c 53 51 4c  EN_READWRITE|SQL
a6c0: 49 54 45 5f 4f 50 45 4e 5f 43 52 45 41 54 45 3b  ITE_OPEN_CREATE;
a6d0: 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  .        break;.
a6e0: 20 20 20 20 20 20 7d 65 6c 73 65 0a 20 20 20 20        }else.    
a6f0: 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22    if( strcmp(z,"
a700: 6c 6f 61 64 2d 64 62 73 71 6c 22 29 3d 3d 30 20  load-dbsql")==0 
a710: 29 7b 0a 20 20 20 20 20 20 20 20 7a 49 6e 73 53  ){.        zInsS
a720: 71 6c 20 3d 20 22 49 4e 53 45 52 54 20 49 4e 54  ql = "INSERT INT
a730: 4f 20 78 73 71 6c 28 73 71 6c 74 65 78 74 29 56  O xsql(sqltext)V
a740: 41 4c 55 45 53 28 43 41 53 54 28 72 65 61 64 66  ALUES(CAST(readf
a750: 69 6c 65 28 3f 31 29 20 41 53 20 74 65 78 74 29  ile(?1) AS text)
a760: 29 22 3b 0a 20 20 20 20 20 20 20 20 69 46 69 72  )";.        iFir
a770: 73 74 49 6e 73 41 72 67 20 3d 20 69 2b 31 3b 0a  stInsArg = i+1;.
a780: 20 20 20 20 20 20 20 20 6f 70 65 6e 46 6c 61 67          openFlag
a790: 73 34 44 61 74 61 20 3d 20 53 51 4c 49 54 45 5f  s4Data = SQLITE_
a7a0: 4f 50 45 4e 5f 52 45 41 44 57 52 49 54 45 7c 53  OPEN_READWRITE|S
a7b0: 51 4c 49 54 45 5f 4f 50 45 4e 5f 43 52 45 41 54  QLITE_OPEN_CREAT
a7c0: 45 3b 0a 20 20 20 20 20 20 20 20 64 62 53 71 6c  E;.        dbSql
a7d0: 4f 6e 6c 79 20 3d 20 31 3b 0a 20 20 20 20 20 20  Only = 1;.      
a7e0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d    break;.      }
a7f0: 65 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73  else.      if( s
a800: 74 72 63 6d 70 28 7a 2c 22 6d 22 29 3d 3d 30 20  trcmp(z,"m")==0 
a810: 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 69  ){.        if( i
a820: 3e 3d 61 72 67 63 2d 31 20 29 20 66 61 74 61 6c  >=argc-1 ) fatal
a830: 45 72 72 6f 72 28 22 6d 69 73 73 69 6e 67 20 61  Error("missing a
a840: 72 67 75 6d 65 6e 74 73 20 6f 6e 20 25 73 22 2c  rguments on %s",
a850: 20 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20   argv[i]);.     
a860: 20 20 20 7a 4d 73 67 20 3d 20 61 72 67 76 5b 2b     zMsg = argv[+
a870: 2b 69 5d 3b 0a 20 20 20 20 20 20 20 20 6f 70 65  +i];.        ope
a880: 6e 46 6c 61 67 73 34 44 61 74 61 20 3d 20 53 51  nFlags4Data = SQ
a890: 4c 49 54 45 5f 4f 50 45 4e 5f 52 45 41 44 57 52  LITE_OPEN_READWR
a8a0: 49 54 45 7c 53 51 4c 49 54 45 5f 4f 50 45 4e 5f  ITE|SQLITE_OPEN_
a8b0: 43 52 45 41 54 45 3b 0a 20 20 20 20 20 20 7d 65  CREATE;.      }e
a8c0: 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74  lse.      if( st
a8d0: 72 63 6d 70 28 7a 2c 22 6e 61 74 69 76 65 2d 6d  rcmp(z,"native-m
a8e0: 61 6c 6c 6f 63 22 29 3d 3d 30 20 29 7b 0a 20 20  alloc")==0 ){.  
a8f0: 20 20 20 20 20 20 6e 61 74 69 76 65 4d 61 6c 6c        nativeMall
a900: 6f 63 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 65  oc = 1;.      }e
a910: 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74  lse.      if( st
a920: 72 63 6d 70 28 7a 2c 22 6e 61 74 69 76 65 2d 76  rcmp(z,"native-v
a930: 66 73 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  fs")==0 ){.     
a940: 20 20 20 6e 61 74 69 76 65 46 6c 61 67 20 3d 20     nativeFlag = 
a950: 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 0a 20  1;.      }else. 
a960: 20 20 20 20 20 69 66 28 20 73 74 72 63 6d 70 28       if( strcmp(
a970: 7a 2c 22 6f 73 73 2d 66 75 7a 7a 22 29 3d 3d 30  z,"oss-fuzz")==0
a980: 20 29 7b 0a 20 20 20 20 20 20 20 20 6f 73 73 46   ){.        ossF
a990: 75 7a 7a 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d  uzz = 1;.      }
a9a0: 65 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73  else.      if( s
a9b0: 74 72 63 6d 70 28 7a 2c 22 70 72 6e 67 2d 73 65  trcmp(z,"prng-se
a9c0: 65 64 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  ed")==0 ){.     
a9d0: 20 20 20 69 66 28 20 69 3e 3d 61 72 67 63 2d 31     if( i>=argc-1
a9e0: 20 29 20 66 61 74 61 6c 45 72 72 6f 72 28 22 6d   ) fatalError("m
a9f0: 69 73 73 69 6e 67 20 61 72 67 75 6d 65 6e 74 73  issing arguments
aa00: 20 6f 6e 20 25 73 22 2c 20 61 72 67 76 5b 69 5d   on %s", argv[i]
aa10: 29 3b 0a 20 20 20 20 20 20 20 20 67 2e 75 52 61  );.        g.uRa
aa20: 6e 64 6f 6d 20 3d 20 61 74 6f 69 28 61 72 67 76  ndom = atoi(argv
aa30: 5b 2b 2b 69 5d 29 3b 0a 20 20 20 20 20 20 7d 65  [++i]);.      }e
aa40: 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74  lse.      if( st
aa50: 72 63 6d 70 28 7a 2c 22 71 75 69 65 74 22 29 3d  rcmp(z,"quiet")=
aa60: 3d 30 20 7c 7c 20 73 74 72 63 6d 70 28 7a 2c 22  =0 || strcmp(z,"
aa70: 71 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  q")==0 ){.      
aa80: 20 20 71 75 69 65 74 46 6c 61 67 20 3d 20 31 3b    quietFlag = 1;
aa90: 0a 20 20 20 20 20 20 20 20 76 65 72 62 6f 73 65  .        verbose
aaa0: 46 6c 61 67 20 3d 20 30 3b 0a 20 20 20 20 20 20  Flag = 0;.      
aab0: 20 20 65 56 65 72 62 6f 73 69 74 79 20 3d 20 30    eVerbosity = 0
aac0: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 0a 20 20  ;.      }else.  
aad0: 20 20 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a      if( strcmp(z
aae0: 2c 22 72 65 62 75 69 6c 64 22 29 3d 3d 30 20 29  ,"rebuild")==0 )
aaf0: 7b 0a 20 20 20 20 20 20 20 20 72 65 62 75 69 6c  {.        rebuil
ab00: 64 46 6c 61 67 20 3d 20 31 3b 0a 20 20 20 20 20  dFlag = 1;.     
ab10: 20 20 20 6f 70 65 6e 46 6c 61 67 73 34 44 61 74     openFlags4Dat
ab20: 61 20 3d 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f  a = SQLITE_OPEN_
ab30: 52 45 41 44 57 52 49 54 45 3b 0a 20 20 20 20 20  READWRITE;.     
ab40: 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 69 66 28   }else.      if(
ab50: 20 73 74 72 63 6d 70 28 7a 2c 22 72 65 73 75 6c   strcmp(z,"resul
ab60: 74 2d 74 72 61 63 65 22 29 3d 3d 30 20 29 7b 0a  t-trace")==0 ){.
ab70: 20 20 20 20 20 20 20 20 72 75 6e 46 6c 61 67 73          runFlags
ab80: 20 7c 3d 20 53 51 4c 5f 4f 55 54 50 55 54 3b 0a   |= SQL_OUTPUT;.
ab90: 20 20 20 20 20 20 7d 65 6c 73 65 0a 20 20 20 20        }else.    
aba0: 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22    if( strcmp(z,"
abb0: 73 71 6c 69 64 22 29 3d 3d 30 20 29 7b 0a 20 20  sqlid")==0 ){.  
abc0: 20 20 20 20 20 20 69 66 28 20 69 3e 3d 61 72 67        if( i>=arg
abd0: 63 2d 31 20 29 20 66 61 74 61 6c 45 72 72 6f 72  c-1 ) fatalError
abe0: 28 22 6d 69 73 73 69 6e 67 20 61 72 67 75 6d 65  ("missing argume
abf0: 6e 74 73 20 6f 6e 20 25 73 22 2c 20 61 72 67 76  nts on %s", argv
ac00: 5b 69 5d 29 3b 0a 20 20 20 20 20 20 20 20 6f 6e  [i]);.        on
ac10: 6c 79 53 71 6c 69 64 20 3d 20 69 6e 74 65 67 65  lySqlid = intege
ac20: 72 56 61 6c 75 65 28 61 72 67 76 5b 2b 2b 69 5d  rValue(argv[++i]
ac30: 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 0a 20  );.      }else. 
ac40: 20 20 20 20 20 69 66 28 20 73 74 72 63 6d 70 28       if( strcmp(
ac50: 7a 2c 22 74 69 6d 65 6f 75 74 22 29 3d 3d 30 20  z,"timeout")==0 
ac60: 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 69  ){.        if( i
ac70: 3e 3d 61 72 67 63 2d 31 20 29 20 66 61 74 61 6c  >=argc-1 ) fatal
ac80: 45 72 72 6f 72 28 22 6d 69 73 73 69 6e 67 20 61  Error("missing a
ac90: 72 67 75 6d 65 6e 74 73 20 6f 6e 20 25 73 22 2c  rguments on %s",
aca0: 20 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20   argv[i]);.     
acb0: 20 20 20 69 54 69 6d 65 6f 75 74 20 3d 20 69 6e     iTimeout = in
acc0: 74 65 67 65 72 56 61 6c 75 65 28 61 72 67 76 5b  tegerValue(argv[
acd0: 2b 2b 69 5d 29 3b 0a 20 20 20 20 20 20 7d 65 6c  ++i]);.      }el
ace0: 73 65 0a 20 20 20 20 20 20 69 66 28 20 73 74 72  se.      if( str
acf0: 63 6d 70 28 7a 2c 22 74 69 6d 65 6f 75 74 2d 74  cmp(z,"timeout-t
ad00: 65 73 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  est")==0 ){.    
ad10: 20 20 20 20 74 69 6d 65 6f 75 74 54 65 73 74 20      timeoutTest 
ad20: 3d 20 31 3b 0a 23 69 66 6e 64 65 66 20 5f 5f 75  = 1;.#ifndef __u
ad30: 6e 69 78 5f 5f 0a 20 20 20 20 20 20 20 20 66 61  nix__.        fa
ad40: 74 61 6c 45 72 72 6f 72 28 22 74 69 6d 65 6f 75  talError("timeou
ad50: 74 20 69 73 20 6e 6f 74 20 61 76 61 69 6c 61 62  t is not availab
ad60: 6c 65 20 6f 6e 20 6e 6f 6e 2d 75 6e 69 78 20 73  le on non-unix s
ad70: 79 73 74 65 6d 73 22 29 3b 0a 23 65 6e 64 69 66  ystems");.#endif
ad80: 0a 20 20 20 20 20 20 7d 65 6c 73 65 0a 20 20 20  .      }else.   
ad90: 20 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c     if( strcmp(z,
ada0: 22 76 65 72 62 6f 73 65 22 29 3d 3d 30 20 29 7b  "verbose")==0 ){
adb0: 0a 20 20 20 20 20 20 20 20 71 75 69 65 74 46 6c  .        quietFl
adc0: 61 67 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  ag = 0;.        
add0: 76 65 72 62 6f 73 65 46 6c 61 67 2b 2b 3b 0a 20  verboseFlag++;. 
ade0: 20 20 20 20 20 20 20 65 56 65 72 62 6f 73 69 74         eVerbosit
adf0: 79 2b 2b 3b 0a 20 20 20 20 20 20 20 20 69 66 28  y++;.        if(
ae00: 20 76 65 72 62 6f 73 65 46 6c 61 67 3e 31 20 29   verboseFlag>1 )
ae10: 20 72 75 6e 46 6c 61 67 73 20 7c 3d 20 53 51 4c   runFlags |= SQL
ae20: 5f 54 52 41 43 45 3b 0a 20 20 20 20 20 20 7d 65  _TRACE;.      }e
ae30: 6c 73 65 0a 20 20 20 20 20 20 69 66 28 20 28 6e  lse.      if( (n
ae40: 56 20 3d 20 6e 75 6d 62 65 72 4f 66 56 43 68 61  V = numberOfVCha
ae50: 72 28 7a 29 29 3e 3d 31 20 29 7b 0a 20 20 20 20  r(z))>=1 ){.    
ae60: 20 20 20 20 71 75 69 65 74 46 6c 61 67 20 3d 20      quietFlag = 
ae70: 30 3b 0a 20 20 20 20 20 20 20 20 76 65 72 62 6f  0;.        verbo
ae80: 73 65 46 6c 61 67 20 2b 3d 20 6e 56 3b 0a 20 20  seFlag += nV;.  
ae90: 20 20 20 20 20 20 65 56 65 72 62 6f 73 69 74 79        eVerbosity
aea0: 20 2b 3d 20 6e 56 3b 0a 20 20 20 20 20 20 20 20   += nV;.        
aeb0: 69 66 28 20 76 65 72 62 6f 73 65 46 6c 61 67 3e  if( verboseFlag>
aec0: 31 20 29 20 72 75 6e 46 6c 61 67 73 20 7c 3d 20  1 ) runFlags |= 
aed0: 53 51 4c 5f 54 52 41 43 45 3b 0a 20 20 20 20 20  SQL_TRACE;.     
aee0: 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 69 66 28   }else.      if(
aef0: 20 73 74 72 63 6d 70 28 7a 2c 22 76 65 72 73 69   strcmp(z,"versi
af00: 6f 6e 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  on")==0 ){.     
af10: 20 20 20 69 6e 74 20 69 69 3b 0a 20 20 20 20 20     int ii;.     
af20: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a     const char *z
af30: 7a 3b 0a 20 20 20 20 20 20 20 20 70 72 69 6e 74  z;.        print
af40: 66 28 22 53 51 4c 69 74 65 20 25 73 20 25 73 5c  f("SQLite %s %s\
af50: 6e 22 2c 20 73 71 6c 69 74 65 33 5f 6c 69 62 76  n", sqlite3_libv
af60: 65 72 73 69 6f 6e 28 29 2c 20 73 71 6c 69 74 65  ersion(), sqlite
af70: 33 5f 73 6f 75 72 63 65 69 64 28 29 29 3b 0a 20  3_sourceid());. 
af80: 20 20 20 20 20 20 20 66 6f 72 28 69 69 3d 30 3b         for(ii=0;
af90: 20 28 7a 7a 20 3d 20 73 71 6c 69 74 65 33 5f 63   (zz = sqlite3_c
afa0: 6f 6d 70 69 6c 65 6f 70 74 69 6f 6e 5f 67 65 74  ompileoption_get
afb0: 28 69 69 29 29 21 3d 30 3b 20 69 69 2b 2b 29 7b  (ii))!=0; ii++){
afc0: 0a 20 20 20 20 20 20 20 20 20 20 70 72 69 6e 74  .          print
afd0: 66 28 22 25 73 5c 6e 22 2c 20 7a 7a 29 3b 0a 20  f("%s\n", zz);. 
afe0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
aff0: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20   return 0;.     
b000: 20 7d 65 6c 73 65 0a 20 20 20 20 20 20 7b 0a 20   }else.      {. 
b010: 20 20 20 20 20 20 20 66 61 74 61 6c 45 72 72 6f         fatalErro
b020: 72 28 22 75 6e 6b 6e 6f 77 6e 20 6f 70 74 69 6f  r("unknown optio
b030: 6e 3a 20 25 73 22 2c 20 61 72 67 76 5b 69 5d 29  n: %s", argv[i])
b040: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 65  ;.      }.    }e
b050: 6c 73 65 7b 0a 20 20 20 20 20 20 6e 53 72 63 44  lse{.      nSrcD
b060: 62 2b 2b 3b 0a 20 20 20 20 20 20 61 7a 53 72 63  b++;.      azSrc
b070: 44 62 20 3d 20 73 61 66 65 5f 72 65 61 6c 6c 6f  Db = safe_reallo
b080: 63 28 61 7a 53 72 63 44 62 2c 20 6e 53 72 63 44  c(azSrcDb, nSrcD
b090: 62 2a 73 69 7a 65 6f 66 28 61 7a 53 72 63 44 62  b*sizeof(azSrcDb
b0a0: 5b 30 5d 29 29 3b 0a 20 20 20 20 20 20 61 7a 53  [0]));.      azS
b0b0: 72 63 44 62 5b 6e 53 72 63 44 62 2d 31 5d 20 3d  rcDb[nSrcDb-1] =
b0c0: 20 61 72 67 76 5b 69 5d 3b 0a 20 20 20 20 7d 0a   argv[i];.    }.
b0d0: 20 20 7d 0a 20 20 69 66 28 20 6e 53 72 63 44 62    }.  if( nSrcDb
b0e0: 3d 3d 30 20 29 20 66 61 74 61 6c 45 72 72 6f 72  ==0 ) fatalError
b0f0: 28 22 6e 6f 20 73 6f 75 72 63 65 20 64 61 74 61  ("no source data
b100: 62 61 73 65 20 73 70 65 63 69 66 69 65 64 22 29  base specified")
b110: 3b 0a 20 20 69 66 28 20 6e 53 72 63 44 62 3e 31  ;.  if( nSrcDb>1
b120: 20 29 7b 0a 20 20 20 20 69 66 28 20 7a 4d 73 67   ){.    if( zMsg
b130: 20 29 7b 0a 20 20 20 20 20 20 66 61 74 61 6c 45   ){.      fatalE
b140: 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20 63 68 61  rror("cannot cha
b150: 6e 67 65 20 74 68 65 20 64 65 73 63 72 69 70 74  nge the descript
b160: 69 6f 6e 20 6f 66 20 6d 6f 72 65 20 74 68 61 6e  ion of more than
b170: 20 6f 6e 65 20 64 61 74 61 62 61 73 65 22 29 3b   one database");
b180: 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 7a  .    }.    if( z
b190: 49 6e 73 53 71 6c 20 29 7b 0a 20 20 20 20 20 20  InsSql ){.      
b1a0: 66 61 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e  fatalError("cann
b1b0: 6f 74 20 69 6d 70 6f 72 74 20 69 6e 74 6f 20 6d  ot import into m
b1c0: 6f 72 65 20 74 68 61 6e 20 6f 6e 65 20 64 61 74  ore than one dat
b1d0: 61 62 61 73 65 22 29 3b 0a 20 20 20 20 7d 0a 20  abase");.    }. 
b1e0: 20 7d 0a 0a 20 20 2f 2a 20 50 72 6f 63 65 73 73   }..  /* Process
b1f0: 20 65 61 63 68 20 73 6f 75 72 63 65 20 64 61 74   each source dat
b200: 61 62 61 73 65 20 73 65 70 61 72 61 74 65 6c 79  abase separately
b210: 20 2a 2f 0a 20 20 66 6f 72 28 69 53 72 63 44 62   */.  for(iSrcDb
b220: 3d 30 3b 20 69 53 72 63 44 62 3c 6e 53 72 63 44  =0; iSrcDb<nSrcD
b230: 62 3b 20 69 53 72 63 44 62 2b 2b 29 7b 0a 20 20  b; iSrcDb++){.  
b240: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 6f    rc = sqlite3_o
b250: 70 65 6e 5f 76 32 28 61 7a 53 72 63 44 62 5b 69  pen_v2(azSrcDb[i
b260: 53 72 63 44 62 5d 2c 20 26 64 62 2c 0a 20 20 20  SrcDb], &db,.   
b270: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
b280: 20 20 20 20 20 20 6f 70 65 6e 46 6c 61 67 73 34        openFlags4
b290: 44 61 74 61 2c 20 70 44 66 6c 74 56 66 73 2d 3e  Data, pDfltVfs->
b2a0: 7a 4e 61 6d 65 29 3b 0a 20 20 20 20 69 66 28 20  zName);.    if( 
b2b0: 72 63 20 29 7b 0a 20 20 20 20 20 20 66 61 74 61  rc ){.      fata
b2c0: 6c 45 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20 6f  lError("cannot o
b2d0: 70 65 6e 20 73 6f 75 72 63 65 20 64 61 74 61 62  pen source datab
b2e0: 61 73 65 20 25 73 20 2d 20 25 73 22 2c 0a 20 20  ase %s - %s",.  
b2f0: 20 20 20 20 61 7a 53 72 63 44 62 5b 69 53 72 63      azSrcDb[iSrc
b300: 44 62 5d 2c 20 73 71 6c 69 74 65 33 5f 65 72 72  Db], sqlite3_err
b310: 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 7d 0a  msg(db));.    }.
b320: 0a 20 20 20 20 2f 2a 20 50 72 69 6e 74 20 74 68  .    /* Print th
b330: 65 20 64 65 73 63 72 69 70 74 69 6f 6e 2c 20 69  e description, i
b340: 66 20 74 68 65 72 65 20 69 73 20 6f 6e 65 20 2a  f there is one *
b350: 2f 0a 20 20 20 20 69 66 28 20 69 6e 66 6f 46 6c  /.    if( infoFl
b360: 61 67 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20  ag ){.      int 
b370: 6e 3b 0a 20 20 20 20 20 20 7a 44 62 4e 61 6d 65  n;.      zDbName
b380: 20 3d 20 61 7a 53 72 63 44 62 5b 69 53 72 63 44   = azSrcDb[iSrcD
b390: 62 5d 3b 0a 20 20 20 20 20 20 69 20 3d 20 28 69  b];.      i = (i
b3a0: 6e 74 29 73 74 72 6c 65 6e 28 7a 44 62 4e 61 6d  nt)strlen(zDbNam
b3b0: 65 29 20 2d 20 31 3b 0a 20 20 20 20 20 20 77 68  e) - 1;.      wh
b3c0: 69 6c 65 28 20 69 3e 30 20 26 26 20 7a 44 62 4e  ile( i>0 && zDbN
b3d0: 61 6d 65 5b 69 2d 31 5d 21 3d 27 2f 27 20 26 26  ame[i-1]!='/' &&
b3e0: 20 7a 44 62 4e 61 6d 65 5b 69 2d 31 5d 21 3d 27   zDbName[i-1]!='
b3f0: 5c 5c 27 20 29 7b 20 69 2d 2d 3b 20 7d 0a 20 20  \\' ){ i--; }.  
b400: 20 20 20 20 7a 44 62 4e 61 6d 65 20 2b 3d 20 69      zDbName += i
b410: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  ;.      sqlite3_
b420: 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 20 22  prepare_v2(db, "
b430: 53 45 4c 45 43 54 20 6d 73 67 20 46 52 4f 4d 20  SELECT msg FROM 
b440: 72 65 61 64 6d 65 22 2c 20 2d 31 2c 20 26 70 53  readme", -1, &pS
b450: 74 6d 74 2c 20 30 29 3b 0a 20 20 20 20 20 20 69  tmt, 0);.      i
b460: 66 28 20 70 53 74 6d 74 20 26 26 20 73 71 6c 69  f( pStmt && sqli
b470: 74 65 33 5f 73 74 65 70 28 70 53 74 6d 74 29 3d  te3_step(pStmt)=
b480: 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20  =SQLITE_ROW ){. 
b490: 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22 25         printf("%
b4a0: 73 3a 20 25 73 22 2c 20 7a 44 62 4e 61 6d 65 2c  s: %s", zDbName,
b4b0: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
b4c0: 74 65 78 74 28 70 53 74 6d 74 2c 30 29 29 3b 0a  text(pStmt,0));.
b4d0: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
b4e0: 20 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 3a       printf("%s:
b4f0: 20 28 65 6d 70 74 79 20 5c 22 72 65 61 64 6d 65   (empty \"readme
b500: 5c 22 29 22 2c 20 7a 44 62 4e 61 6d 65 29 3b 0a  \")", zDbName);.
b510: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71        }.      sq
b520: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70  lite3_finalize(p
b530: 53 74 6d 74 29 3b 0a 20 20 20 20 20 20 73 71 6c  Stmt);.      sql
b540: 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 28  ite3_prepare_v2(
b550: 64 62 2c 20 22 53 45 4c 45 43 54 20 63 6f 75 6e  db, "SELECT coun
b560: 74 28 2a 29 20 46 52 4f 4d 20 64 62 22 2c 20 2d  t(*) FROM db", -
b570: 31 2c 20 26 70 53 74 6d 74 2c 20 30 29 3b 0a 20  1, &pStmt, 0);. 
b580: 20 20 20 20 20 69 66 28 20 70 53 74 6d 74 0a 20       if( pStmt. 
b590: 20 20 20 20 20 20 26 26 20 73 71 6c 69 74 65 33        && sqlite3
b5a0: 5f 73 74 65 70 28 70 53 74 6d 74 29 3d 3d 53 51  _step(pStmt)==SQ
b5b0: 4c 49 54 45 5f 52 4f 57 0a 20 20 20 20 20 20 20  LITE_ROW.       
b5c0: 26 26 20 28 6e 20 3d 20 73 71 6c 69 74 65 33 5f  && (n = sqlite3_
b5d0: 63 6f 6c 75 6d 6e 5f 69 6e 74 28 70 53 74 6d 74  column_int(pStmt
b5e0: 2c 30 29 29 3e 30 0a 20 20 20 20 20 20 29 7b 0a  ,0))>0.      ){.
b5f0: 20 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22          printf("
b600: 20 2d 20 25 64 20 44 42 73 22 2c 20 6e 29 3b 0a   - %d DBs", n);.
b610: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71        }.      sq
b620: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70  lite3_finalize(p
b630: 53 74 6d 74 29 3b 0a 20 20 20 20 20 20 73 71 6c  Stmt);.      sql
b640: 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 28  ite3_prepare_v2(
b650: 64 62 2c 20 22 53 45 4c 45 43 54 20 63 6f 75 6e  db, "SELECT coun
b660: 74 28 2a 29 20 46 52 4f 4d 20 78 73 71 6c 22 2c  t(*) FROM xsql",
b670: 20 2d 31 2c 20 26 70 53 74 6d 74 2c 20 30 29 3b   -1, &pStmt, 0);
b680: 0a 20 20 20 20 20 20 69 66 28 20 70 53 74 6d 74  .      if( pStmt
b690: 0a 20 20 20 20 20 20 20 26 26 20 73 71 6c 69 74  .       && sqlit
b6a0: 65 33 5f 73 74 65 70 28 70 53 74 6d 74 29 3d 3d  e3_step(pStmt)==
b6b0: 53 51 4c 49 54 45 5f 52 4f 57 0a 20 20 20 20 20  SQLITE_ROW.     
b6c0: 20 20 26 26 20 28 6e 20 3d 20 73 71 6c 69 74 65    && (n = sqlite
b6d0: 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 28 70 53 74  3_column_int(pSt
b6e0: 6d 74 2c 30 29 29 3e 30 0a 20 20 20 20 20 20 29  mt,0))>0.      )
b6f0: 7b 0a 20 20 20 20 20 20 20 20 70 72 69 6e 74 66  {.        printf
b700: 28 22 20 2d 20 25 64 20 73 63 72 69 70 74 73 22  (" - %d scripts"
b710: 2c 20 6e 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  , n);.      }.  
b720: 20 20 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61      sqlite3_fina
b730: 6c 69 7a 65 28 70 53 74 6d 74 29 3b 0a 20 20 20  lize(pStmt);.   
b740: 20 20 20 70 72 69 6e 74 66 28 22 5c 6e 22 29 3b     printf("\n");
b750: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63  .      sqlite3_c
b760: 6c 6f 73 65 28 64 62 29 3b 0a 20 20 20 20 20 20  lose(db);.      
b770: 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 7d 0a  continue;.    }.
b780: 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65  .    rc = sqlite
b790: 33 5f 65 78 65 63 28 64 62 2c 0a 20 20 20 20 20  3_exec(db,.     
b7a0: 20 20 22 43 52 45 41 54 45 20 54 41 42 4c 45 20    "CREATE TABLE 
b7b0: 49 46 20 4e 4f 54 20 45 58 49 53 54 53 20 64 62  IF NOT EXISTS db
b7c0: 28 5c 6e 22 0a 20 20 20 20 20 20 20 22 20 20 64  (\n".       "  d
b7d0: 62 69 64 20 49 4e 54 45 47 45 52 20 50 52 49 4d  bid INTEGER PRIM
b7e0: 41 52 59 20 4b 45 59 2c 20 2d 2d 20 64 61 74 61  ARY KEY, -- data
b7f0: 62 61 73 65 20 69 64 5c 6e 22 0a 20 20 20 20 20  base id\n".     
b800: 20 20 22 20 20 64 62 63 6f 6e 74 65 6e 74 20 42    "  dbcontent B
b810: 4c 4f 42 20 20 20 20 20 20 20 20 20 20 20 20 2d  LOB            -
b820: 2d 20 64 61 74 61 62 61 73 65 20 64 69 73 6b 20  - database disk 
b830: 66 69 6c 65 20 69 6d 61 67 65 5c 6e 22 0a 20 20  file image\n".  
b840: 20 20 20 20 20 22 29 3b 5c 6e 22 0a 20 20 20 20       ");\n".    
b850: 20 20 20 22 43 52 45 41 54 45 20 54 41 42 4c 45     "CREATE TABLE
b860: 20 49 46 20 4e 4f 54 20 45 58 49 53 54 53 20 78   IF NOT EXISTS x
b870: 73 71 6c 28 5c 6e 22 0a 20 20 20 20 20 20 20 22  sql(\n".       "
b880: 20 20 73 71 6c 69 64 20 49 4e 54 45 47 45 52 20    sqlid INTEGER 
b890: 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 20 20 2d  PRIMARY KEY,   -
b8a0: 2d 20 53 51 4c 20 73 63 72 69 70 74 20 69 64 5c  - SQL script id\
b8b0: 6e 22 0a 20 20 20 20 20 20 20 22 20 20 73 71 6c  n".       "  sql
b8c0: 74 65 78 74 20 54 45 58 54 20 20 20 20 20 20 20  text TEXT       
b8d0: 20 20 20 20 20 20 20 20 20 20 2d 2d 20 54 65 78            -- Tex
b8e0: 74 20 6f 66 20 53 51 4c 20 73 74 61 74 65 6d 65  t of SQL stateme
b8f0: 6e 74 73 20 74 6f 20 72 75 6e 5c 6e 22 0a 20 20  nts to run\n".  
b900: 20 20 20 20 20 22 29 3b 22 0a 20 20 20 20 20 20       ");".      
b910: 20 22 43 52 45 41 54 45 20 54 41 42 4c 45 20 49   "CREATE TABLE I
b920: 46 20 4e 4f 54 20 45 58 49 53 54 53 20 72 65 61  F NOT EXISTS rea
b930: 64 6d 65 28 5c 6e 22 0a 20 20 20 20 20 20 20 22  dme(\n".       "
b940: 20 20 6d 73 67 20 54 45 58 54 20 2d 2d 20 48 75    msg TEXT -- Hu
b950: 6d 61 6e 2d 72 65 61 64 61 62 6c 65 20 64 65 73  man-readable des
b960: 63 72 69 70 74 69 6f 6e 20 6f 66 20 74 68 69 73  cription of this
b970: 20 66 69 6c 65 5c 6e 22 0a 20 20 20 20 20 20 20   file\n".       
b980: 22 29 3b 22 2c 20 30 2c 20 30 2c 20 30 29 3b 0a  ");", 0, 0, 0);.
b990: 20 20 20 20 69 66 28 20 72 63 20 29 20 66 61 74      if( rc ) fat
b9a0: 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20  alError("cannot 
b9b0: 63 72 65 61 74 65 20 73 63 68 65 6d 61 3a 20 25  create schema: %
b9c0: 73 22 2c 20 73 71 6c 69 74 65 33 5f 65 72 72 6d  s", sqlite3_errm
b9d0: 73 67 28 64 62 29 29 3b 0a 20 20 20 20 69 66 28  sg(db));.    if(
b9e0: 20 7a 4d 73 67 20 29 7b 0a 20 20 20 20 20 20 63   zMsg ){.      c
b9f0: 68 61 72 20 2a 7a 53 71 6c 3b 0a 20 20 20 20 20  har *zSql;.     
ba00: 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33 5f   zSql = sqlite3_
ba10: 6d 70 72 69 6e 74 66 28 0a 20 20 20 20 20 20 20  mprintf(.       
ba20: 20 20 20 20 20 20 20 20 22 44 45 4c 45 54 45 20          "DELETE 
ba30: 46 52 4f 4d 20 72 65 61 64 6d 65 3b 20 49 4e 53  FROM readme; INS
ba40: 45 52 54 20 49 4e 54 4f 20 72 65 61 64 6d 65 28  ERT INTO readme(
ba50: 6d 73 67 29 20 56 41 4c 55 45 53 28 25 51 29 22  msg) VALUES(%Q)"
ba60: 2c 20 7a 4d 73 67 29 3b 0a 20 20 20 20 20 20 72  , zMsg);.      r
ba70: 63 20 3d 20 73 71 6c 69 74 65 33 5f 65 78 65 63  c = sqlite3_exec
ba80: 28 64 62 2c 20 7a 53 71 6c 2c 20 30 2c 20 30 2c  (db, zSql, 0, 0,
ba90: 20 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74   0);.      sqlit
baa0: 65 33 5f 66 72 65 65 28 7a 53 71 6c 29 3b 0a 20  e3_free(zSql);. 
bab0: 20 20 20 20 20 69 66 28 20 72 63 20 29 20 66 61       if( rc ) fa
bac0: 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e 6f 74  talError("cannot
bad0: 20 63 68 61 6e 67 65 20 64 65 73 63 72 69 70 74   change descript
bae0: 69 6f 6e 3a 20 25 73 22 2c 20 73 71 6c 69 74 65  ion: %s", sqlite
baf0: 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20  3_errmsg(db));. 
bb00: 20 20 20 7d 0a 20 20 20 20 6f 73 73 46 75 7a 7a     }.    ossFuzz
bb10: 54 68 69 73 44 62 20 3d 20 6f 73 73 46 75 7a 7a  ThisDb = ossFuzz
bb20: 3b 0a 0a 20 20 20 20 2f 2a 20 49 66 20 74 68 65  ;..    /* If the
bb30: 20 43 4f 4e 46 49 47 28 6e 61 6d 65 2c 76 61 6c   CONFIG(name,val
bb40: 75 65 29 20 74 61 62 6c 65 20 65 78 69 73 74 73  ue) table exists
bb50: 2c 20 72 65 61 64 20 64 62 2d 73 70 65 63 69 66  , read db-specif
bb60: 69 63 20 73 65 74 74 69 6e 67 73 0a 20 20 20 20  ic settings.    
bb70: 2a 2a 20 66 72 6f 6d 20 74 68 61 74 20 74 61 62  ** from that tab
bb80: 6c 65 20 2a 2f 0a 20 20 20 20 69 66 28 20 73 71  le */.    if( sq
bb90: 6c 69 74 65 33 5f 74 61 62 6c 65 5f 63 6f 6c 75  lite3_table_colu
bba0: 6d 6e 5f 6d 65 74 61 64 61 74 61 28 64 62 2c 30  mn_metadata(db,0
bbb0: 2c 22 63 6f 6e 66 69 67 22 2c 30 2c 30 2c 30 2c  ,"config",0,0,0,
bbc0: 30 2c 30 2c 30 29 3d 3d 53 51 4c 49 54 45 5f 4f  0,0,0)==SQLITE_O
bbd0: 4b 20 29 7b 0a 20 20 20 20 20 20 72 63 20 3d 20  K ){.      rc = 
bbe0: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
bbf0: 76 32 28 64 62 2c 20 22 53 45 4c 45 43 54 20 6e  v2(db, "SELECT n
bc00: 61 6d 65 2c 20 76 61 6c 75 65 20 46 52 4f 4d 20  ame, value FROM 
bc10: 63 6f 6e 66 69 67 22 2c 0a 20 20 20 20 20 20 20  config",.       
bc20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bc30: 20 20 20 20 20 20 20 20 20 20 20 2d 31 2c 20 26             -1, &
bc40: 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20 20 20 20  pStmt, 0);.     
bc50: 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c 45   if( rc ) fatalE
bc60: 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20 70 72 65  rror("cannot pre
bc70: 70 61 72 65 20 71 75 65 72 79 20 6f 66 20 43 4f  pare query of CO
bc80: 4e 46 49 47 20 74 61 62 6c 65 3a 20 25 73 22 2c  NFIG table: %s",
bc90: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
bca0: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
bcb0: 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a  e3_errmsg(db));.
bcc0: 20 20 20 20 20 20 77 68 69 6c 65 28 20 53 51 4c        while( SQL
bcd0: 49 54 45 5f 52 4f 57 3d 3d 73 71 6c 69 74 65 33  ITE_ROW==sqlite3
bce0: 5f 73 74 65 70 28 70 53 74 6d 74 29 20 29 7b 0a  _step(pStmt) ){.
bcf0: 20 20 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68          const ch
bd00: 61 72 20 2a 7a 4e 61 6d 65 20 3d 20 28 63 6f 6e  ar *zName = (con
bd10: 73 74 20 63 68 61 72 20 2a 29 73 71 6c 69 74 65  st char *)sqlite
bd20: 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70 53  3_column_text(pS
bd30: 74 6d 74 2c 30 29 3b 0a 20 20 20 20 20 20 20 20  tmt,0);.        
bd40: 69 66 28 20 7a 4e 61 6d 65 3d 3d 30 20 29 20 63  if( zName==0 ) c
bd50: 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 20  ontinue;.       
bd60: 20 69 66 28 20 73 74 72 63 6d 70 28 7a 4e 61 6d   if( strcmp(zNam
bd70: 65 2c 20 22 6f 73 73 2d 66 75 7a 7a 22 29 3d 3d  e, "oss-fuzz")==
bd80: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 6f  0 ){.          o
bd90: 73 73 46 75 7a 7a 54 68 69 73 44 62 20 3d 20 73  ssFuzzThisDb = s
bda0: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e  qlite3_column_in
bdb0: 74 28 70 53 74 6d 74 2c 31 29 3b 0a 20 20 20 20  t(pStmt,1);.    
bdc0: 20 20 20 20 20 20 69 66 28 20 76 65 72 62 6f 73        if( verbos
bdd0: 65 46 6c 61 67 20 29 20 70 72 69 6e 74 66 28 22  eFlag ) printf("
bde0: 43 6f 6e 66 69 67 3a 20 6f 73 73 2d 66 75 7a 7a  Config: oss-fuzz
bdf0: 3d 25 64 5c 6e 22 2c 20 6f 73 73 46 75 7a 7a 54  =%d\n", ossFuzzT
be00: 68 69 73 44 62 29 3b 0a 20 20 20 20 20 20 20 20  hisDb);.        
be10: 7d 0a 20 20 20 20 20 20 20 20 69 66 28 20 73 74  }.        if( st
be20: 72 63 6d 70 28 7a 4e 61 6d 65 2c 20 22 6c 69 6d  rcmp(zName, "lim
be30: 69 74 2d 6d 65 6d 22 29 3d 3d 30 20 26 26 20 21  it-mem")==0 && !
be40: 6e 61 74 69 76 65 4d 61 6c 6c 6f 63 20 29 7b 0a  nativeMalloc ){.
be50: 23 69 66 20 21 64 65 66 69 6e 65 64 28 53 51 4c  #if !defined(SQL
be60: 49 54 45 5f 45 4e 41 42 4c 45 5f 4d 45 4d 53 59  ITE_ENABLE_MEMSY
be70: 53 33 29 20 26 26 20 21 64 65 66 69 6e 65 64 28  S3) && !defined(
be80: 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 4d 45  SQLITE_ENABLE_ME
be90: 4d 53 59 53 35 29 0a 20 20 20 20 20 20 20 20 20  MSYS5).         
bea0: 20 66 61 74 61 6c 45 72 72 6f 72 28 22 74 68 65   fatalError("the
beb0: 20 6c 69 6d 69 74 2d 6d 65 6d 20 6f 70 74 69 6f   limit-mem optio
bec0: 6e 20 72 65 71 75 69 72 65 73 20 2d 44 53 51 4c  n requires -DSQL
bed0: 49 54 45 5f 45 4e 41 42 4c 45 5f 4d 45 4d 53 59  ITE_ENABLE_MEMSY
bee0: 53 35 22 0a 20 20 20 20 20 20 20 20 20 20 20 20  S5".            
bef0: 20 20 20 20 20 20 20 20 20 22 20 6f 72 20 5f 4d           " or _M
bf00: 45 4d 53 59 53 33 22 29 3b 0a 23 65 6c 73 65 0a  EMSYS3");.#else.
bf10: 20 20 20 20 20 20 20 20 20 20 6e 4d 65 6d 54 68            nMemTh
bf20: 69 73 44 62 20 3d 20 73 71 6c 69 74 65 33 5f 63  isDb = sqlite3_c
bf30: 6f 6c 75 6d 6e 5f 69 6e 74 28 70 53 74 6d 74 2c  olumn_int(pStmt,
bf40: 31 29 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66  1);.          if
bf50: 28 20 76 65 72 62 6f 73 65 46 6c 61 67 20 29 20  ( verboseFlag ) 
bf60: 70 72 69 6e 74 66 28 22 43 6f 6e 66 69 67 3a 20  printf("Config: 
bf70: 6c 69 6d 69 74 2d 6d 65 6d 3d 25 64 5c 6e 22 2c  limit-mem=%d\n",
bf80: 20 6e 4d 65 6d 54 68 69 73 44 62 29 3b 0a 23 65   nMemThisDb);.#e
bf90: 6e 64 69 66 0a 20 20 20 20 20 20 20 20 7d 0a 20  ndif.        }. 
bfa0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71 6c       }.      sql
bfb0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53  ite3_finalize(pS
bfc0: 74 6d 74 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  tmt);.    }..   
bfd0: 20 69 66 28 20 7a 49 6e 73 53 71 6c 20 29 7b 0a   if( zInsSql ){.
bfe0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63 72        sqlite3_cr
bff0: 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 28 64 62  eate_function(db
c000: 2c 20 22 72 65 61 64 66 69 6c 65 22 2c 20 31 2c  , "readfile", 1,
c010: 20 53 51 4c 49 54 45 5f 55 54 46 38 2c 20 30 2c   SQLITE_UTF8, 0,
c020: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
c030: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72                 r
c040: 65 61 64 66 69 6c 65 46 75 6e 63 2c 20 30 2c 20  eadfileFunc, 0, 
c050: 30 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  0);.      sqlite
c060: 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f  3_create_functio
c070: 6e 28 64 62 2c 20 22 69 73 64 62 73 71 6c 22 2c  n(db, "isdbsql",
c080: 20 31 2c 20 53 51 4c 49 54 45 5f 55 54 46 38 2c   1, SQLITE_UTF8,
c090: 20 30 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20   0,.            
c0a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
c0b0: 20 20 69 73 44 62 53 71 6c 46 75 6e 63 2c 20 30    isDbSqlFunc, 0
c0c0: 2c 20 30 29 3b 0a 20 20 20 20 20 20 72 63 20 3d  , 0);.      rc =
c0d0: 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65   sqlite3_prepare
c0e0: 5f 76 32 28 64 62 2c 20 7a 49 6e 73 53 71 6c 2c  _v2(db, zInsSql,
c0f0: 20 2d 31 2c 20 26 70 53 74 6d 74 2c 20 30 29 3b   -1, &pStmt, 0);
c100: 0a 20 20 20 20 20 20 69 66 28 20 72 63 20 29 20  .      if( rc ) 
c110: 66 61 74 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e  fatalError("cann
c120: 6f 74 20 70 72 65 70 61 72 65 20 73 74 61 74 65  ot prepare state
c130: 6d 65 6e 74 20 5b 25 73 5d 3a 20 25 73 22 2c 0a  ment [%s]: %s",.
c140: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
c150: 20 20 20 20 20 20 20 20 20 20 7a 49 6e 73 53 71            zInsSq
c160: 6c 2c 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73  l, sqlite3_errms
c170: 67 28 64 62 29 29 3b 0a 20 20 20 20 20 20 72 63  g(db));.      rc
c180: 20 3d 20 73 71 6c 69 74 65 33 5f 65 78 65 63 28   = sqlite3_exec(
c190: 64 62 2c 20 22 42 45 47 49 4e 22 2c 20 30 2c 20  db, "BEGIN", 0, 
c1a0: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 69 66 28  0, 0);.      if(
c1b0: 20 72 63 20 29 20 66 61 74 61 6c 45 72 72 6f 72   rc ) fatalError
c1c0: 28 22 63 61 6e 6e 6f 74 20 73 74 61 72 74 20 61  ("cannot start a
c1d0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 22 29 3b 0a   transaction");.
c1e0: 20 20 20 20 20 20 66 6f 72 28 69 3d 69 46 69 72        for(i=iFir
c1f0: 73 74 49 6e 73 41 72 67 3b 20 69 3c 61 72 67 63  stInsArg; i<argc
c200: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  ; i++){.        
c210: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78  sqlite3_bind_tex
c220: 74 28 70 53 74 6d 74 2c 20 31 2c 20 61 72 67 76  t(pStmt, 1, argv
c230: 5b 69 5d 2c 20 2d 31 2c 20 53 51 4c 49 54 45 5f  [i], -1, SQLITE_
c240: 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20  STATIC);.       
c250: 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53   sqlite3_step(pS
c260: 74 6d 74 29 3b 0a 20 20 20 20 20 20 20 20 72 63  tmt);.        rc
c270: 20 3d 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74   = sqlite3_reset
c280: 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 20 20 20  (pStmt);.       
c290: 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c 45   if( rc ) fatalE
c2a0: 72 72 6f 72 28 22 69 6e 73 65 72 74 20 66 61 69  rror("insert fai
c2b0: 6c 65 64 20 66 6f 72 20 25 73 22 2c 20 61 72 67  led for %s", arg
c2c0: 76 5b 69 5d 29 3b 0a 20 20 20 20 20 20 7d 0a 20  v[i]);.      }. 
c2d0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 66 69 6e       sqlite3_fin
c2e0: 61 6c 69 7a 65 28 70 53 74 6d 74 29 3b 0a 20 20  alize(pStmt);.  
c2f0: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
c300: 5f 65 78 65 63 28 64 62 2c 20 22 43 4f 4d 4d 49  _exec(db, "COMMI
c310: 54 22 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20  T", 0, 0, 0);.  
c320: 20 20 20 20 69 66 28 20 72 63 20 29 20 66 61 74      if( rc ) fat
c330: 61 6c 45 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20  alError("cannot 
c340: 63 6f 6d 6d 69 74 20 74 68 65 20 74 72 61 6e 73  commit the trans
c350: 61 63 74 69 6f 6e 3a 20 25 73 22 2c 0a 20 20 20  action: %s",.   
c360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
c370: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65         sqlite3_e
c380: 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20  rrmsg(db));.    
c390: 20 20 72 65 62 75 69 6c 64 5f 64 61 74 61 62 61    rebuild_databa
c3a0: 73 65 28 64 62 2c 20 64 62 53 71 6c 4f 6e 6c 79  se(db, dbSqlOnly
c3b0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
c3c0: 5f 63 6c 6f 73 65 28 64 62 29 3b 0a 20 20 20 20  _close(db);.    
c3d0: 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20    return 0;.    
c3e0: 7d 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74  }.    rc = sqlit
c3f0: 65 33 5f 65 78 65 63 28 64 62 2c 20 22 50 52 41  e3_exec(db, "PRA
c400: 47 4d 41 20 71 75 65 72 79 5f 6f 6e 6c 79 3d 31  GMA query_only=1
c410: 3b 22 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20  ;", 0, 0, 0);.  
c420: 20 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c    if( rc ) fatal
c430: 45 72 72 6f 72 28 22 63 61 6e 6e 6f 74 20 73 65  Error("cannot se
c440: 74 20 64 61 74 61 62 61 73 65 20 74 6f 20 71 75  t database to qu
c450: 65 72 79 2d 6f 6e 6c 79 22 29 3b 0a 20 20 20 20  ery-only");.    
c460: 69 66 28 20 7a 45 78 70 44 62 21 3d 30 20 7c 7c  if( zExpDb!=0 ||
c470: 20 7a 45 78 70 53 71 6c 21 3d 30 20 29 7b 0a 20   zExpSql!=0 ){. 
c480: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63 72 65       sqlite3_cre
c490: 61 74 65 5f 66 75 6e 63 74 69 6f 6e 28 64 62 2c  ate_function(db,
c4a0: 20 22 77 72 69 74 65 66 69 6c 65 22 2c 20 32 2c   "writefile", 2,
c4b0: 20 53 51 4c 49 54 45 5f 55 54 46 38 2c 20 30 2c   SQLITE_UTF8, 0,
c4c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
c4d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 77                 w
c4e0: 72 69 74 65 66 69 6c 65 46 75 6e 63 2c 20 30 2c  ritefileFunc, 0,
c4f0: 20 30 29 3b 0a 20 20 20 20 20 20 69 66 28 20 7a   0);.      if( z
c500: 45 78 70 44 62 21 3d 30 20 29 7b 0a 20 20 20 20  ExpDb!=0 ){.    
c510: 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a      const char *
c520: 7a 45 78 44 62 20 3d 20 0a 20 20 20 20 20 20 20  zExDb = .       
c530: 20 20 20 22 53 45 4c 45 43 54 20 77 72 69 74 65     "SELECT write
c540: 66 69 6c 65 28 70 72 69 6e 74 66 28 27 25 73 2f  file(printf('%s/
c550: 64 62 25 30 36 64 2e 64 62 27 2c 3f 31 2c 64 62  db%06d.db',?1,db
c560: 69 64 29 2c 64 62 63 6f 6e 74 65 6e 74 29 2c 22  id),dbcontent),"
c570: 0a 20 20 20 20 20 20 20 20 20 20 22 20 20 20 20  .          "    
c580: 20 20 20 64 62 69 64 2c 20 70 72 69 6e 74 66 28     dbid, printf(
c590: 27 25 73 2f 64 62 25 30 36 64 2e 64 62 27 2c 3f  '%s/db%06d.db',?
c5a0: 31 2c 64 62 69 64 29 2c 20 6c 65 6e 67 74 68 28  1,dbid), length(
c5b0: 64 62 63 6f 6e 74 65 6e 74 29 22 0a 20 20 20 20  dbcontent)".    
c5c0: 20 20 20 20 20 20 22 20 20 46 52 4f 4d 20 64 62        "  FROM db
c5d0: 20 57 48 45 52 45 20 3f 32 3c 30 20 4f 52 20 64   WHERE ?2<0 OR d
c5e0: 62 69 64 3d 3f 32 3b 22 3b 0a 20 20 20 20 20 20  bid=?2;";.      
c5f0: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70    rc = sqlite3_p
c600: 72 65 70 61 72 65 5f 76 32 28 64 62 2c 20 7a 45  repare_v2(db, zE
c610: 78 44 62 2c 20 2d 31 2c 20 26 70 53 74 6d 74 2c  xDb, -1, &pStmt,
c620: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28   0);.        if(
c630: 20 72 63 20 29 20 66 61 74 61 6c 45 72 72 6f 72   rc ) fatalError
c640: 28 22 63 61 6e 6e 6f 74 20 70 72 65 70 61 72 65  ("cannot prepare
c650: 20 73 74 61 74 65 6d 65 6e 74 20 5b 25 73 5d 3a   statement [%s]:
c660: 20 25 73 22 2c 0a 20 20 20 20 20 20 20 20 20 20   %s",.          
c670: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
c680: 20 20 7a 45 78 44 62 2c 20 73 71 6c 69 74 65 33    zExDb, sqlite3
c690: 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20  _errmsg(db));.  
c6a0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 62 69        sqlite3_bi
c6b0: 6e 64 5f 74 65 78 74 36 34 28 70 53 74 6d 74 2c  nd_text64(pStmt,
c6c0: 20 31 2c 20 7a 45 78 70 44 62 2c 20 73 74 72 6c   1, zExpDb, strl
c6d0: 65 6e 28 7a 45 78 70 44 62 29 2c 0a 20 20 20 20  en(zExpDb),.    
c6e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
c6f0: 20 20 20 20 20 20 20 20 53 51 4c 49 54 45 5f 53          SQLITE_S
c700: 54 41 54 49 43 2c 20 53 51 4c 49 54 45 5f 55 54  TATIC, SQLITE_UT
c710: 46 38 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c  F8);.        sql
c720: 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 28 70 53  ite3_bind_int(pS
c730: 74 6d 74 2c 20 32 2c 20 6f 6e 6c 79 44 62 69 64  tmt, 2, onlyDbid
c740: 29 3b 0a 20 20 20 20 20 20 20 20 77 68 69 6c 65  );.        while
c750: 28 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70  ( sqlite3_step(p
c760: 53 74 6d 74 29 3d 3d 53 51 4c 49 54 45 5f 52 4f  Stmt)==SQLITE_RO
c770: 57 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 70  W ){.          p
c780: 72 69 6e 74 66 28 22 77 72 69 74 65 20 64 62 2d  rintf("write db-
c790: 25 64 20 28 25 64 20 62 79 74 65 73 29 20 69 6e  %d (%d bytes) in
c7a0: 74 6f 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20  to %s\n",.      
c7b0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63         sqlite3_c
c7c0: 6f 6c 75 6d 6e 5f 69 6e 74 28 70 53 74 6d 74 2c  olumn_int(pStmt,
c7d0: 31 29 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  1),.            
c7e0: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
c7f0: 69 6e 74 28 70 53 74 6d 74 2c 33 29 2c 0a 20 20  int(pStmt,3),.  
c800: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
c810: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70  e3_column_text(p
c820: 53 74 6d 74 2c 32 29 29 3b 0a 20 20 20 20 20 20  Stmt,2));.      
c830: 20 20 7d 0a 20 20 20 20 20 20 20 20 73 71 6c 69    }.        sqli
c840: 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53 74  te3_finalize(pSt
c850: 6d 74 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  mt);.      }.   
c860: 20 20 20 69 66 28 20 7a 45 78 70 53 71 6c 21 3d     if( zExpSql!=
c870: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 63 6f 6e  0 ){.        con
c880: 73 74 20 63 68 61 72 20 2a 7a 45 78 53 71 6c 20  st char *zExSql 
c890: 3d 20 0a 20 20 20 20 20 20 20 20 20 20 22 53 45  = .          "SE
c8a0: 4c 45 43 54 20 77 72 69 74 65 66 69 6c 65 28 70  LECT writefile(p
c8b0: 72 69 6e 74 66 28 27 25 73 2f 73 71 6c 25 30 36  rintf('%s/sql%06
c8c0: 64 2e 74 78 74 27 2c 3f 31 2c 73 71 6c 69 64 29  d.txt',?1,sqlid)
c8d0: 2c 73 71 6c 74 65 78 74 29 2c 22 0a 20 20 20 20  ,sqltext),".    
c8e0: 20 20 20 20 20 20 22 20 20 20 20 20 20 20 73 71        "       sq
c8f0: 6c 69 64 2c 20 70 72 69 6e 74 66 28 27 25 73 2f  lid, printf('%s/
c900: 73 71 6c 25 30 36 64 2e 74 78 74 27 2c 3f 31 2c  sql%06d.txt',?1,
c910: 73 71 6c 69 64 29 2c 20 6c 65 6e 67 74 68 28 73  sqlid), length(s
c920: 71 6c 74 65 78 74 29 22 0a 20 20 20 20 20 20 20  qltext)".       
c930: 20 20 20 22 20 20 46 52 4f 4d 20 78 73 71 6c 20     "  FROM xsql 
c940: 57 48 45 52 45 20 3f 32 3c 30 20 4f 52 20 73 71  WHERE ?2<0 OR sq
c950: 6c 69 64 3d 3f 32 3b 22 3b 0a 20 20 20 20 20 20  lid=?2;";.      
c960: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70    rc = sqlite3_p
c970: 72 65 70 61 72 65 5f 76 32 28 64 62 2c 20 7a 45  repare_v2(db, zE
c980: 78 53 71 6c 2c 20 2d 31 2c 20 26 70 53 74 6d 74  xSql, -1, &pStmt
c990: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 69 66  , 0);.        if
c9a0: 28 20 72 63 20 29 20 66 61 74 61 6c 45 72 72 6f  ( rc ) fatalErro
c9b0: 72 28 22 63 61 6e 6e 6f 74 20 70 72 65 70 61 72  r("cannot prepar
c9c0: 65 20 73 74 61 74 65 6d 65 6e 74 20 5b 25 73 5d  e statement [%s]
c9d0: 3a 20 25 73 22 2c 0a 20 20 20 20 20 20 20 20 20  : %s",.         
c9e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
c9f0: 20 20 20 7a 45 78 53 71 6c 2c 20 73 71 6c 69 74     zExSql, sqlit
ca00: 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a  e3_errmsg(db));.
ca10: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
ca20: 62 69 6e 64 5f 74 65 78 74 36 34 28 70 53 74 6d  bind_text64(pStm
ca30: 74 2c 20 31 2c 20 7a 45 78 70 53 71 6c 2c 20 73  t, 1, zExpSql, s
ca40: 74 72 6c 65 6e 28 7a 45 78 70 53 71 6c 29 2c 0a  trlen(zExpSql),.
ca50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
ca60: 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 49              SQLI
ca70: 54 45 5f 53 54 41 54 49 43 2c 20 53 51 4c 49 54  TE_STATIC, SQLIT
ca80: 45 5f 55 54 46 38 29 3b 0a 20 20 20 20 20 20 20  E_UTF8);.       
ca90: 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e   sqlite3_bind_in
caa0: 74 28 70 53 74 6d 74 2c 20 32 2c 20 6f 6e 6c 79  t(pStmt, 2, only
cab0: 53 71 6c 69 64 29 3b 0a 20 20 20 20 20 20 20 20  Sqlid);.        
cac0: 77 68 69 6c 65 28 20 73 71 6c 69 74 65 33 5f 73  while( sqlite3_s
cad0: 74 65 70 28 70 53 74 6d 74 29 3d 3d 53 51 4c 49  tep(pStmt)==SQLI
cae0: 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20 20  TE_ROW ){.      
caf0: 20 20 20 20 70 72 69 6e 74 66 28 22 77 72 69 74      printf("writ
cb00: 65 20 73 71 6c 2d 25 64 20 28 25 64 20 62 79 74  e sql-%d (%d byt
cb10: 65 73 29 20 69 6e 74 6f 20 25 73 5c 6e 22 2c 0a  es) into %s\n",.
cb20: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c               sql
cb30: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 28  ite3_column_int(
cb40: 70 53 74 6d 74 2c 31 29 2c 0a 20 20 20 20 20 20  pStmt,1),.      
cb50: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63         sqlite3_c
cb60: 6f 6c 75 6d 6e 5f 69 6e 74 28 70 53 74 6d 74 2c  olumn_int(pStmt,
cb70: 33 29 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  3),.            
cb80: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
cb90: 74 65 78 74 28 70 53 74 6d 74 2c 32 29 29 3b 0a  text(pStmt,2));.
cba0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
cbb0: 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69    sqlite3_finali
cbc0: 7a 65 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 20  ze(pStmt);.     
cbd0: 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33   }.      sqlite3
cbe0: 5f 63 6c 6f 73 65 28 64 62 29 3b 0a 20 20 20 20  _close(db);.    
cbf0: 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20    return 0;.    
cc00: 7d 0a 20 20 0a 20 20 20 20 2f 2a 20 4c 6f 61 64  }.  .    /* Load
cc10: 20 61 6c 6c 20 53 51 4c 20 73 63 72 69 70 74 20   all SQL script 
cc20: 63 6f 6e 74 65 6e 74 20 61 6e 64 20 61 6c 6c 20  content and all 
cc30: 69 6e 69 74 69 61 6c 20 64 61 74 61 62 61 73 65  initial database
cc40: 20 69 6d 61 67 65 73 20 66 72 6f 6d 20 74 68 65   images from the
cc50: 0a 20 20 20 20 2a 2a 20 73 6f 75 72 63 65 20 64  .    ** source d
cc60: 62 0a 20 20 20 20 2a 2f 0a 20 20 20 20 62 6c 6f  b.    */.    blo
cc70: 62 4c 69 73 74 4c 6f 61 64 46 72 6f 6d 44 62 28  bListLoadFromDb(
cc80: 64 62 2c 20 22 53 45 4c 45 43 54 20 73 71 6c 69  db, "SELECT sqli
cc90: 64 2c 20 73 71 6c 74 65 78 74 20 46 52 4f 4d 20  d, sqltext FROM 
cca0: 78 73 71 6c 22 2c 20 6f 6e 6c 79 53 71 6c 69 64  xsql", onlySqlid
ccb0: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
ccc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 26 67 2e               &g.
ccd0: 6e 53 71 6c 2c 20 26 67 2e 70 46 69 72 73 74 53  nSql, &g.pFirstS
cce0: 71 6c 29 3b 0a 20 20 20 20 69 66 28 20 67 2e 6e  ql);.    if( g.n
ccf0: 53 71 6c 3d 3d 30 20 29 20 66 61 74 61 6c 45 72  Sql==0 ) fatalEr
cd00: 72 6f 72 28 22 6e 65 65 64 20 61 74 20 6c 65 61  ror("need at lea
cd10: 73 74 20 6f 6e 65 20 53 51 4c 20 73 63 72 69 70  st one SQL scrip
cd20: 74 22 29 3b 0a 20 20 20 20 62 6c 6f 62 4c 69 73  t");.    blobLis
cd30: 74 4c 6f 61 64 46 72 6f 6d 44 62 28 64 62 2c 20  tLoadFromDb(db, 
cd40: 22 53 45 4c 45 43 54 20 64 62 69 64 2c 20 64 62  "SELECT dbid, db
cd50: 63 6f 6e 74 65 6e 74 20 46 52 4f 4d 20 64 62 22  content FROM db"
cd60: 2c 20 6f 6e 6c 79 44 62 69 64 2c 0a 20 20 20 20  , onlyDbid,.    
cd70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
cd80: 20 20 20 26 67 2e 6e 44 62 2c 20 26 67 2e 70 46     &g.nDb, &g.pF
cd90: 69 72 73 74 44 62 29 3b 0a 20 20 20 20 69 66 28  irstDb);.    if(
cda0: 20 67 2e 6e 44 62 3d 3d 30 20 29 7b 0a 20 20 20   g.nDb==0 ){.   
cdb0: 20 20 20 67 2e 70 46 69 72 73 74 44 62 20 3d 20     g.pFirstDb = 
cdc0: 73 61 66 65 5f 72 65 61 6c 6c 6f 63 28 30 2c 20  safe_realloc(0, 
cdd0: 73 69 7a 65 6f 66 28 42 6c 6f 62 29 29 3b 0a 20  sizeof(Blob));. 
cde0: 20 20 20 20 20 6d 65 6d 73 65 74 28 67 2e 70 46       memset(g.pF
cdf0: 69 72 73 74 44 62 2c 20 30 2c 20 73 69 7a 65 6f  irstDb, 0, sizeo
ce00: 66 28 42 6c 6f 62 29 29 3b 0a 20 20 20 20 20 20  f(Blob));.      
ce10: 67 2e 70 46 69 72 73 74 44 62 2d 3e 69 64 20 3d  g.pFirstDb->id =
ce20: 20 31 3b 0a 20 20 20 20 20 20 67 2e 70 46 69 72   1;.      g.pFir
ce30: 73 74 44 62 2d 3e 73 65 71 20 3d 20 30 3b 0a 20  stDb->seq = 0;. 
ce40: 20 20 20 20 20 67 2e 6e 44 62 20 3d 20 31 3b 0a       g.nDb = 1;.
ce50: 20 20 20 20 20 20 73 71 6c 46 75 7a 7a 20 3d 20        sqlFuzz = 
ce60: 31 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20  1;.    }.  .    
ce70: 2f 2a 20 50 72 69 6e 74 20 74 68 65 20 64 65 73  /* Print the des
ce80: 63 72 69 70 74 69 6f 6e 2c 20 69 66 20 74 68 65  cription, if the
ce90: 72 65 20 69 73 20 6f 6e 65 20 2a 2f 0a 20 20 20  re is one */.   
cea0: 20 69 66 28 20 21 71 75 69 65 74 46 6c 61 67 20   if( !quietFlag 
ceb0: 29 7b 0a 20 20 20 20 20 20 7a 44 62 4e 61 6d 65  ){.      zDbName
cec0: 20 3d 20 61 7a 53 72 63 44 62 5b 69 53 72 63 44   = azSrcDb[iSrcD
ced0: 62 5d 3b 0a 20 20 20 20 20 20 69 20 3d 20 28 69  b];.      i = (i
cee0: 6e 74 29 73 74 72 6c 65 6e 28 7a 44 62 4e 61 6d  nt)strlen(zDbNam
cef0: 65 29 20 2d 20 31 3b 0a 20 20 20 20 20 20 77 68  e) - 1;.      wh
cf00: 69 6c 65 28 20 69 3e 30 20 26 26 20 7a 44 62 4e  ile( i>0 && zDbN
cf10: 61 6d 65 5b 69 2d 31 5d 21 3d 27 2f 27 20 26 26  ame[i-1]!='/' &&
cf20: 20 7a 44 62 4e 61 6d 65 5b 69 2d 31 5d 21 3d 27   zDbName[i-1]!='
cf30: 5c 5c 27 20 29 7b 20 69 2d 2d 3b 20 7d 0a 20 20  \\' ){ i--; }.  
cf40: 20 20 20 20 7a 44 62 4e 61 6d 65 20 2b 3d 20 69      zDbName += i
cf50: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  ;.      sqlite3_
cf60: 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 20 22  prepare_v2(db, "
cf70: 53 45 4c 45 43 54 20 6d 73 67 20 46 52 4f 4d 20  SELECT msg FROM 
cf80: 72 65 61 64 6d 65 22 2c 20 2d 31 2c 20 26 70 53  readme", -1, &pS
cf90: 74 6d 74 2c 20 30 29 3b 0a 20 20 20 20 20 20 69  tmt, 0);.      i
cfa0: 66 28 20 70 53 74 6d 74 20 26 26 20 73 71 6c 69  f( pStmt && sqli
cfb0: 74 65 33 5f 73 74 65 70 28 70 53 74 6d 74 29 3d  te3_step(pStmt)=
cfc0: 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20  =SQLITE_ROW ){. 
cfd0: 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22 25         printf("%
cfe0: 73 3a 20 25 73 5c 6e 22 2c 20 7a 44 62 4e 61 6d  s: %s\n", zDbNam
cff0: 65 2c 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  e, sqlite3_colum
d000: 6e 5f 74 65 78 74 28 70 53 74 6d 74 2c 30 29 29  n_text(pStmt,0))
d010: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
d020: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
d030: 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 7d 0a 0a  (pStmt);.    }..
d040: 20 20 20 20 2f 2a 20 52 65 62 75 69 6c 64 20 74      /* Rebuild t
d050: 68 65 20 64 61 74 61 62 61 73 65 2c 20 69 66 20  he database, if 
d060: 72 65 71 75 65 73 74 65 64 20 2a 2f 0a 20 20 20  requested */.   
d070: 20 69 66 28 20 72 65 62 75 69 6c 64 46 6c 61 67   if( rebuildFlag
d080: 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20 21 71   ){.      if( !q
d090: 75 69 65 74 46 6c 61 67 20 29 7b 0a 20 20 20 20  uietFlag ){.    
d0a0: 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 3a 20      printf("%s: 
d0b0: 72 65 62 75 69 6c 64 69 6e 67 2e 2e 2e 20 22 2c  rebuilding... ",
d0c0: 20 7a 44 62 4e 61 6d 65 29 3b 0a 20 20 20 20 20   zDbName);.     
d0d0: 20 20 20 66 66 6c 75 73 68 28 73 74 64 6f 75 74     fflush(stdout
d0e0: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  );.      }.     
d0f0: 20 72 65 62 75 69 6c 64 5f 64 61 74 61 62 61 73   rebuild_databas
d100: 65 28 64 62 2c 20 30 29 3b 0a 20 20 20 20 20 20  e(db, 0);.      
d110: 69 66 28 20 21 71 75 69 65 74 46 6c 61 67 20 29  if( !quietFlag )
d120: 20 70 72 69 6e 74 66 28 22 64 6f 6e 65 5c 6e 22   printf("done\n"
d130: 29 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20  );.    }.  .    
d140: 2f 2a 20 43 6c 6f 73 65 20 74 68 65 20 73 6f 75  /* Close the sou
d150: 72 63 65 20 64 61 74 61 62 61 73 65 2e 20 20 56  rce database.  V
d160: 65 72 69 66 79 20 74 68 61 74 20 6e 6f 20 53 51  erify that no SQ
d170: 4c 69 74 65 20 6d 65 6d 6f 72 79 20 61 6c 6c 6f  Lite memory allo
d180: 63 61 74 69 6f 6e 73 20 61 72 65 0a 20 20 20 20  cations are.    
d190: 2a 2a 20 6f 75 74 73 74 61 6e 64 69 6e 67 2e 0a  ** outstanding..
d1a0: 20 20 20 20 2a 2f 0a 20 20 20 20 73 71 6c 69 74      */.    sqlit
d1b0: 65 33 5f 63 6c 6f 73 65 28 64 62 29 3b 0a 20 20  e3_close(db);.  
d1c0: 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f 6d 65    if( sqlite3_me
d1d0: 6d 6f 72 79 5f 75 73 65 64 28 29 3e 30 20 29 7b  mory_used()>0 ){
d1e0: 0a 20 20 20 20 20 20 66 61 74 61 6c 45 72 72 6f  .      fatalErro
d1f0: 72 28 22 53 51 4c 69 74 65 20 68 61 73 20 6d 65  r("SQLite has me
d200: 6d 6f 72 79 20 69 6e 20 75 73 65 20 62 65 66 6f  mory in use befo
d210: 72 65 20 74 68 65 20 73 74 61 72 74 20 6f 66 20  re the start of 
d220: 74 65 73 74 69 6e 67 22 29 3b 0a 20 20 20 20 7d  testing");.    }
d230: 0a 0a 20 20 20 20 2f 2a 20 4c 69 6d 69 74 20 61  ..    /* Limit a
d240: 76 61 69 6c 61 62 6c 65 20 6d 65 6d 6f 72 79 2c  vailable memory,
d250: 20 69 66 20 72 65 71 75 65 73 74 65 64 20 2a 2f   if requested */
d260: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 68 75  .    sqlite3_shu
d270: 74 64 6f 77 6e 28 29 3b 0a 20 20 20 20 69 66 28  tdown();.    if(
d280: 20 6e 4d 65 6d 54 68 69 73 44 62 3e 30 20 26 26   nMemThisDb>0 &&
d290: 20 21 6e 61 74 69 76 65 4d 61 6c 6c 6f 63 20 29   !nativeMalloc )
d2a0: 7b 0a 20 20 20 20 20 20 70 48 65 61 70 20 3d 20  {.      pHeap = 
d2b0: 72 65 61 6c 6c 6f 63 28 70 48 65 61 70 2c 20 6e  realloc(pHeap, n
d2c0: 4d 65 6d 54 68 69 73 44 62 29 3b 0a 20 20 20 20  MemThisDb);.    
d2d0: 20 20 69 66 28 20 70 48 65 61 70 3d 3d 30 20 29    if( pHeap==0 )
d2e0: 7b 0a 20 20 20 20 20 20 20 20 66 61 74 61 6c 45  {.        fatalE
d2f0: 72 72 6f 72 28 22 66 61 69 6c 65 64 20 74 6f 20  rror("failed to 
d300: 61 6c 6c 6f 63 61 74 65 20 25 64 20 62 79 74 65  allocate %d byte
d310: 73 20 6f 66 20 68 65 61 70 20 6d 65 6d 6f 72 79  s of heap memory
d320: 22 2c 20 6e 4d 65 6d 29 3b 0a 20 20 20 20 20 20  ", nMem);.      
d330: 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  }.      sqlite3_
d340: 63 6f 6e 66 69 67 28 53 51 4c 49 54 45 5f 43 4f  config(SQLITE_CO
d350: 4e 46 49 47 5f 48 45 41 50 2c 20 70 48 65 61 70  NFIG_HEAP, pHeap
d360: 2c 20 6e 4d 65 6d 54 68 69 73 44 62 2c 20 31 32  , nMemThisDb, 12
d370: 38 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f  8);.    }..    /
d380: 2a 20 44 69 73 61 62 6c 65 20 6c 6f 6f 6b 61 73  * Disable lookas
d390: 69 64 65 20 77 69 74 68 20 74 68 65 20 2d 2d 6e  ide with the --n
d3a0: 61 74 69 76 65 2d 6d 61 6c 6c 6f 63 20 6f 70 74  ative-malloc opt
d3b0: 69 6f 6e 20 2a 2f 0a 20 20 20 20 69 66 28 20 6e  ion */.    if( n
d3c0: 61 74 69 76 65 4d 61 6c 6c 6f 63 20 29 7b 0a 20  ativeMalloc ){. 
d3d0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e       sqlite3_con
d3e0: 66 69 67 28 53 51 4c 49 54 45 5f 43 4f 4e 46 49  fig(SQLITE_CONFI
d3f0: 47 5f 4c 4f 4f 4b 41 53 49 44 45 2c 20 30 2c 20  G_LOOKASIDE, 0, 
d400: 30 29 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20  0);.    }.  .   
d410: 20 2f 2a 20 52 65 73 65 74 20 74 68 65 20 69 6e   /* Reset the in
d420: 2d 6d 65 6d 6f 72 79 20 76 69 72 74 75 61 6c 20  -memory virtual 
d430: 66 69 6c 65 73 79 73 74 65 6d 20 2a 2f 0a 20 20  filesystem */.  
d440: 20 20 66 6f 72 6d 61 74 56 66 73 28 29 3b 0a 20    formatVfs();. 
d450: 20 20 20 0a 20 20 20 20 2f 2a 20 52 75 6e 20 61     .    /* Run a
d460: 20 74 65 73 74 20 75 73 69 6e 67 20 65 61 63 68   test using each
d470: 20 53 51 4c 20 73 63 72 69 70 74 20 61 67 61 69   SQL script agai
d480: 6e 73 74 20 65 61 63 68 20 64 61 74 61 62 61 73  nst each databas
d490: 65 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20 69 66  e..    */.    if
d4a0: 28 20 21 76 65 72 62 6f 73 65 46 6c 61 67 20 26  ( !verboseFlag &
d4b0: 26 20 21 71 75 69 65 74 46 6c 61 67 20 29 20 70  & !quietFlag ) p
d4c0: 72 69 6e 74 66 28 22 25 73 3a 22 2c 20 7a 44 62  rintf("%s:", zDb
d4d0: 4e 61 6d 65 29 3b 0a 20 20 20 20 66 6f 72 28 70  Name);.    for(p
d4e0: 53 71 6c 3d 67 2e 70 46 69 72 73 74 53 71 6c 3b  Sql=g.pFirstSql;
d4f0: 20 70 53 71 6c 3b 20 70 53 71 6c 3d 70 53 71 6c   pSql; pSql=pSql
d500: 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 20 20  ->pNext){.      
d510: 69 66 28 20 69 73 44 62 53 71 6c 28 70 53 71 6c  if( isDbSql(pSql
d520: 2d 3e 61 2c 20 70 53 71 6c 2d 3e 73 7a 29 20 29  ->a, pSql->sz) )
d530: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
d540: 33 5f 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f  3_snprintf(sizeo
d550: 66 28 67 2e 7a 54 65 73 74 4e 61 6d 65 29 2c 20  f(g.zTestName), 
d560: 67 2e 7a 54 65 73 74 4e 61 6d 65 2c 20 22 73 71  g.zTestName, "sq
d570: 6c 69 64 3d 25 64 22 2c 70 53 71 6c 2d 3e 69 64  lid=%d",pSql->id
d580: 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 76  );.        if( v
d590: 65 72 62 6f 73 65 46 6c 61 67 20 29 7b 0a 20 20  erboseFlag ){.  
d5a0: 20 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22          printf("
d5b0: 25 73 5c 6e 22 2c 20 67 2e 7a 54 65 73 74 4e 61  %s\n", g.zTestNa
d5c0: 6d 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 66  me);.          f
d5d0: 66 6c 75 73 68 28 73 74 64 6f 75 74 29 3b 0a 20  flush(stdout);. 
d5e0: 20 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28         }else if(
d5f0: 20 21 71 75 69 65 74 46 6c 61 67 20 29 7b 0a 20   !quietFlag ){. 
d600: 20 20 20 20 20 20 20 20 20 73 74 61 74 69 63 20           static 
d610: 69 6e 74 20 70 72 65 76 41 6d 74 20 3d 20 2d 31  int prevAmt = -1
d620: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 6e 74 20  ;.          int 
d630: 69 64 78 20 3d 20 70 53 71 6c 2d 3e 73 65 71 3b  idx = pSql->seq;
d640: 0a 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 61  .          int a
d650: 6d 74 20 3d 20 69 64 78 2a 31 30 2f 28 67 2e 6e  mt = idx*10/(g.n
d660: 53 71 6c 29 3b 0a 20 20 20 20 20 20 20 20 20 20  Sql);.          
d670: 69 66 28 20 61 6d 74 21 3d 70 72 65 76 41 6d 74  if( amt!=prevAmt
d680: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
d690: 70 72 69 6e 74 66 28 22 20 25 64 25 25 22 2c 20  printf(" %d%%", 
d6a0: 61 6d 74 2a 31 30 29 3b 0a 20 20 20 20 20 20 20  amt*10);.       
d6b0: 20 20 20 20 20 66 66 6c 75 73 68 28 73 74 64 6f       fflush(stdo
d6c0: 75 74 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  ut);.           
d6d0: 20 70 72 65 76 41 6d 74 20 3d 20 61 6d 74 3b 0a   prevAmt = amt;.
d6e0: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
d6f0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 72 75      }.        ru
d700: 6e 43 6f 6d 62 69 6e 65 64 44 62 53 71 6c 49 6e  nCombinedDbSqlIn
d710: 70 75 74 28 70 53 71 6c 2d 3e 61 2c 20 70 53 71  put(pSql->a, pSq
d720: 6c 2d 3e 73 7a 29 3b 0a 20 20 20 20 20 20 20 20  l->sz);.        
d730: 6e 54 65 73 74 2b 2b 3b 0a 20 20 20 20 20 20 20  nTest++;.       
d740: 20 67 2e 7a 54 65 73 74 4e 61 6d 65 5b 30 5d 20   g.zTestName[0] 
d750: 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 63 6f 6e  = 0;.        con
d760: 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 7d 0a 20  tinue;.      }. 
d770: 20 20 20 20 20 66 6f 72 28 70 44 62 3d 67 2e 70       for(pDb=g.p
d780: 46 69 72 73 74 44 62 3b 20 70 44 62 3b 20 70 44  FirstDb; pDb; pD
d790: 62 3d 70 44 62 2d 3e 70 4e 65 78 74 29 7b 0a 20  b=pDb->pNext){. 
d7a0: 20 20 20 20 20 20 20 69 6e 74 20 6f 70 65 6e 46         int openF
d7b0: 6c 61 67 73 3b 0a 20 20 20 20 20 20 20 20 63 6f  lags;.        co
d7c0: 6e 73 74 20 63 68 61 72 20 2a 7a 56 66 73 20 3d  nst char *zVfs =
d7d0: 20 22 69 6e 6d 65 6d 22 3b 0a 20 20 20 20 20 20   "inmem";.      
d7e0: 20 20 73 71 6c 69 74 65 33 5f 73 6e 70 72 69 6e    sqlite3_snprin
d7f0: 74 66 28 73 69 7a 65 6f 66 28 67 2e 7a 54 65 73  tf(sizeof(g.zTes
d800: 74 4e 61 6d 65 29 2c 20 67 2e 7a 54 65 73 74 4e  tName), g.zTestN
d810: 61 6d 65 2c 20 22 73 71 6c 69 64 3d 25 64 2c 64  ame, "sqlid=%d,d
d820: 62 69 64 3d 25 64 22 2c 0a 20 20 20 20 20 20 20  bid=%d",.       
d830: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
d840: 20 20 70 53 71 6c 2d 3e 69 64 2c 20 70 44 62 2d    pSql->id, pDb-
d850: 3e 69 64 29 3b 0a 20 20 20 20 20 20 20 20 69 66  >id);.        if
d860: 28 20 76 65 72 62 6f 73 65 46 6c 61 67 20 29 7b  ( verboseFlag ){
d870: 0a 20 20 20 20 20 20 20 20 20 20 70 72 69 6e 74  .          print
d880: 66 28 22 25 73 5c 6e 22 2c 20 67 2e 7a 54 65 73  f("%s\n", g.zTes
d890: 74 4e 61 6d 65 29 3b 0a 20 20 20 20 20 20 20 20  tName);.        
d8a0: 20 20 66 66 6c 75 73 68 28 73 74 64 6f 75 74 29    fflush(stdout)
d8b0: 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 20  ;.        }else 
d8c0: 69 66 28 20 21 71 75 69 65 74 46 6c 61 67 20 29  if( !quietFlag )
d8d0: 7b 0a 20 20 20 20 20 20 20 20 20 20 73 74 61 74  {.          stat
d8e0: 69 63 20 69 6e 74 20 70 72 65 76 41 6d 74 20 3d  ic int prevAmt =
d8f0: 20 2d 31 3b 0a 20 20 20 20 20 20 20 20 20 20 69   -1;.          i
d900: 6e 74 20 69 64 78 20 3d 20 70 53 71 6c 2d 3e 73  nt idx = pSql->s
d910: 65 71 2a 67 2e 6e 44 62 20 2b 20 70 44 62 2d 3e  eq*g.nDb + pDb->
d920: 69 64 20 2d 20 31 3b 0a 20 20 20 20 20 20 20 20  id - 1;.        
d930: 20 20 69 6e 74 20 61 6d 74 20 3d 20 69 64 78 2a    int amt = idx*
d940: 31 30 2f 28 67 2e 6e 44 62 2a 67 2e 6e 53 71 6c  10/(g.nDb*g.nSql
d950: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  );.          if(
d960: 20 61 6d 74 21 3d 70 72 65 76 41 6d 74 20 29 7b   amt!=prevAmt ){
d970: 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 72 69  .            pri
d980: 6e 74 66 28 22 20 25 64 25 25 22 2c 20 61 6d 74  ntf(" %d%%", amt
d990: 2a 31 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20  *10);.          
d9a0: 20 20 66 66 6c 75 73 68 28 73 74 64 6f 75 74 29    fflush(stdout)
d9b0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 72  ;.            pr
d9c0: 65 76 41 6d 74 20 3d 20 61 6d 74 3b 0a 20 20 20  evAmt = amt;.   
d9d0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
d9e0: 20 7d 0a 20 20 20 20 20 20 20 20 63 72 65 61 74   }.        creat
d9f0: 65 56 46 69 6c 65 28 22 6d 61 69 6e 2e 64 62 22  eVFile("main.db"
da00: 2c 20 70 44 62 2d 3e 73 7a 2c 20 70 44 62 2d 3e  , pDb->sz, pDb->
da10: 61 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  a);.        sqli
da20: 74 65 33 5f 72 61 6e 64 6f 6d 6e 65 73 73 28 30  te3_randomness(0
da30: 2c 30 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28  ,0);.        if(
da40: 20 6f 73 73 46 75 7a 7a 54 68 69 73 44 62 20 29   ossFuzzThisDb )
da50: 7b 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  {.#ifndef SQLITE
da60: 5f 4f 53 53 5f 46 55 5a 5a 0a 20 20 20 20 20 20  _OSS_FUZZ.      
da70: 20 20 20 20 66 61 74 61 6c 45 72 72 6f 72 28 22      fatalError("
da80: 2d 2d 6f 73 73 2d 66 75 7a 7a 20 6e 6f 74 20 73  --oss-fuzz not s
da90: 75 70 70 6f 72 74 65 64 3a 20 72 65 63 6f 6d 70  upported: recomp
daa0: 69 6c 65 22 0a 20 20 20 20 20 20 20 20 20 20 20  ile".           
dab0: 20 20 20 20 20 20 20 20 20 20 22 20 77 69 74 68            " with
dac0: 20 2d 44 53 51 4c 49 54 45 5f 4f 53 53 5f 46 55   -DSQLITE_OSS_FU
dad0: 5a 5a 22 29 3b 0a 23 65 6c 73 65 0a 20 20 20 20  ZZ");.#else.    
dae0: 20 20 20 20 20 20 65 78 74 65 72 6e 20 69 6e 74        extern int
daf0: 20 4c 4c 56 4d 46 75 7a 7a 65 72 54 65 73 74 4f   LLVMFuzzerTestO
db00: 6e 65 49 6e 70 75 74 28 63 6f 6e 73 74 20 75 69  neInput(const ui
db10: 6e 74 38 5f 74 2a 2c 20 73 69 7a 65 5f 74 29 3b  nt8_t*, size_t);
db20: 0a 20 20 20 20 20 20 20 20 20 20 4c 4c 56 4d 46  .          LLVMF
db30: 75 7a 7a 65 72 54 65 73 74 4f 6e 65 49 6e 70 75  uzzerTestOneInpu
db40: 74 28 28 63 6f 6e 73 74 20 75 69 6e 74 38 5f 74  t((const uint8_t
db50: 2a 29 70 53 71 6c 2d 3e 61 2c 20 28 73 69 7a 65  *)pSql->a, (size
db60: 5f 74 29 70 53 71 6c 2d 3e 73 7a 29 3b 0a 23 65  _t)pSql->sz);.#e
db70: 6e 64 69 66 0a 20 20 20 20 20 20 20 20 7d 65 6c  ndif.        }el
db80: 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20 6f 70  se{.          op
db90: 65 6e 46 6c 61 67 73 20 3d 20 53 51 4c 49 54 45  enFlags = SQLITE
dba0: 5f 4f 50 45 4e 5f 43 52 45 41 54 45 20 7c 20 53  _OPEN_CREATE | S
dbb0: 51 4c 49 54 45 5f 4f 50 45 4e 5f 52 45 41 44 57  QLITE_OPEN_READW
dbc0: 52 49 54 45 3b 0a 20 20 20 20 20 20 20 20 20 20  RITE;.          
dbd0: 69 66 28 20 6e 61 74 69 76 65 46 6c 61 67 20 26  if( nativeFlag &
dbe0: 26 20 70 44 62 2d 3e 73 7a 3d 3d 30 20 29 7b 0a  & pDb->sz==0 ){.
dbf0: 20 20 20 20 20 20 20 20 20 20 20 20 6f 70 65 6e              open
dc00: 46 6c 61 67 73 20 7c 3d 20 53 51 4c 49 54 45 5f  Flags |= SQLITE_
dc10: 4f 50 45 4e 5f 4d 45 4d 4f 52 59 3b 0a 20 20 20  OPEN_MEMORY;.   
dc20: 20 20 20 20 20 20 20 20 20 7a 56 66 73 20 3d 20           zVfs = 
dc30: 30 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  0;.          }. 
dc40: 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71           rc = sq
dc50: 6c 69 74 65 33 5f 6f 70 65 6e 5f 76 32 28 22 6d  lite3_open_v2("m
dc60: 61 69 6e 2e 64 62 22 2c 20 26 64 62 2c 20 6f 70  ain.db", &db, op
dc70: 65 6e 46 6c 61 67 73 2c 20 7a 56 66 73 29 3b 0a  enFlags, zVfs);.
dc80: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 72 63            if( rc
dc90: 20 29 20 66 61 74 61 6c 45 72 72 6f 72 28 22 63   ) fatalError("c
dca0: 61 6e 6e 6f 74 20 6f 70 65 6e 20 69 6e 6d 65 6d  annot open inmem
dcb0: 20 64 61 74 61 62 61 73 65 22 29 3b 0a 20 20 20   database");.   
dcc0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 6c         sqlite3_l
dcd0: 69 6d 69 74 28 64 62 2c 20 53 51 4c 49 54 45 5f  imit(db, SQLITE_
dce0: 4c 49 4d 49 54 5f 4c 45 4e 47 54 48 2c 20 31 30  LIMIT_LENGTH, 10
dcf0: 30 30 30 30 30 30 30 29 3b 0a 20 20 20 20 20 20  0000000);.      
dd00: 20 20 20 20 73 71 6c 69 74 65 33 5f 6c 69 6d 69      sqlite3_limi
dd10: 74 28 64 62 2c 20 53 51 4c 49 54 45 5f 4c 49 4d  t(db, SQLITE_LIM
dd20: 49 54 5f 4c 49 4b 45 5f 50 41 54 54 45 52 4e 5f  IT_LIKE_PATTERN_
dd30: 4c 45 4e 47 54 48 2c 20 35 30 29 3b 0a 20 20 20  LENGTH, 50);.   
dd40: 20 20 20 20 20 20 20 69 66 28 20 63 65 6c 6c 53         if( cellS
dd50: 7a 43 6b 46 6c 61 67 20 29 20 72 75 6e 53 71 6c  zCkFlag ) runSql
dd60: 28 64 62 2c 20 22 50 52 41 47 4d 41 20 63 65 6c  (db, "PRAGMA cel
dd70: 6c 5f 73 69 7a 65 5f 63 68 65 63 6b 3d 4f 4e 22  l_size_check=ON"
dd80: 2c 20 72 75 6e 46 6c 61 67 73 29 3b 0a 20 20 20  , runFlags);.   
dd90: 20 20 20 20 20 20 20 73 65 74 41 6c 61 72 6d 28         setAlarm(
dda0: 69 54 69 6d 65 6f 75 74 29 3b 0a 23 69 66 6e 64  iTimeout);.#ifnd
ddb0: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50  ef SQLITE_OMIT_P
ddc0: 52 4f 47 52 45 53 53 5f 43 41 4c 4c 42 41 43 4b  ROGRESS_CALLBACK
ddd0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20 73  .          if( s
dde0: 71 6c 46 75 7a 7a 20 7c 7c 20 76 64 62 65 4c 69  qlFuzz || vdbeLi
ddf0: 6d 69 74 46 6c 61 67 20 29 7b 0a 20 20 20 20 20  mitFlag ){.     
de00: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 70         sqlite3_p
de10: 72 6f 67 72 65 73 73 5f 68 61 6e 64 6c 65 72 28  rogress_handler(
de20: 64 62 2c 20 31 30 30 30 30 30 2c 20 70 72 6f 67  db, 100000, prog
de30: 72 65 73 73 48 61 6e 64 6c 65 72 2c 0a 20 20 20  ressHandler,.   
de40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
de50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
de60: 20 20 26 76 64 62 65 4c 69 6d 69 74 46 6c 61 67    &vdbeLimitFlag
de70: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 23  );.          }.#
de80: 65 6e 64 69 66 0a 20 20 20 20 20 20 20 20 20 20  endif.          
de90: 64 6f 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20  do{.            
dea0: 72 75 6e 53 71 6c 28 64 62 2c 20 28 63 68 61 72  runSql(db, (char
deb0: 2a 29 70 53 71 6c 2d 3e 61 2c 20 72 75 6e 46 6c  *)pSql->a, runFl
dec0: 61 67 73 29 3b 0a 20 20 20 20 20 20 20 20 20 20  ags);.          
ded0: 7d 77 68 69 6c 65 28 20 74 69 6d 65 6f 75 74 54  }while( timeoutT
dee0: 65 73 74 20 29 3b 0a 20 20 20 20 20 20 20 20 20  est );.         
def0: 20 73 65 74 41 6c 61 72 6d 28 30 29 3b 0a 20 20   setAlarm(0);.  
df00: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
df10: 65 78 65 63 28 64 62 2c 20 22 50 52 41 47 4d 41  exec(db, "PRAGMA
df20: 20 74 65 6d 70 5f 73 74 6f 72 65 5f 64 69 72 65   temp_store_dire
df30: 63 74 6f 72 79 3d 27 27 22 2c 20 30 2c 20 30 2c  ctory=''", 0, 0,
df40: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73   0);.          s
df50: 71 6c 69 74 65 33 5f 63 6c 6f 73 65 28 64 62 29  qlite3_close(db)
df60: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
df70: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f      if( sqlite3_
df80: 6d 65 6d 6f 72 79 5f 75 73 65 64 28 29 3e 30 20  memory_used()>0 
df90: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 66 61  ){.           fa
dfa0: 74 61 6c 45 72 72 6f 72 28 22 6d 65 6d 6f 72 79  talError("memory
dfb0: 20 6c 65 61 6b 3a 20 25 6c 6c 64 20 62 79 74 65   leak: %lld byte
dfc0: 73 20 6f 75 74 73 74 61 6e 64 69 6e 67 22 2c 0a  s outstanding",.
dfd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
dfe0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 65        sqlite3_me
dff0: 6d 6f 72 79 5f 75 73 65 64 28 29 29 3b 0a 20 20  mory_used());.  
e000: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
e010: 72 65 66 6f 72 6d 61 74 56 66 73 28 29 3b 0a 20  reformatVfs();. 
e020: 20 20 20 20 20 20 20 6e 54 65 73 74 2b 2b 3b 0a         nTest++;.
e030: 20 20 20 20 20 20 20 20 67 2e 7a 54 65 73 74 4e          g.zTestN
e040: 61 6d 65 5b 30 5d 20 3d 20 30 3b 0a 0a 20 20 20  ame[0] = 0;..   
e050: 20 20 20 20 20 2f 2a 20 53 69 6d 75 6c 61 74 65       /* Simulate
e060: 20 61 6e 20 65 72 72 6f 72 20 69 66 20 74 68 65   an error if the
e070: 20 54 45 53 54 5f 46 41 49 4c 55 52 45 20 65 6e   TEST_FAILURE en
e080: 76 69 72 6f 6e 6d 65 6e 74 20 76 61 72 69 61 62  vironment variab
e090: 6c 65 20 69 73 20 22 35 22 2e 0a 20 20 20 20 20  le is "5"..     
e0a0: 20 20 20 2a 2a 20 54 68 69 73 20 69 73 20 75 73     ** This is us
e0b0: 65 64 20 74 6f 20 76 65 72 69 66 79 20 74 68 61  ed to verify tha
e0c0: 74 20 61 75 74 6f 6d 61 74 65 64 20 74 65 73 74  t automated test
e0d0: 20 73 63 72 69 70 74 20 72 65 61 6c 6c 79 20 64   script really d
e0e0: 6f 20 73 70 6f 74 0a 20 20 20 20 20 20 20 20 2a  o spot.        *
e0f0: 2a 20 65 72 72 6f 72 73 20 74 68 61 74 20 6f 63  * errors that oc
e100: 63 75 72 20 69 6e 20 74 68 69 73 20 74 65 73 74  cur in this test
e110: 20 70 72 6f 67 72 61 6d 2e 0a 20 20 20 20 20 20   program..      
e120: 20 20 2a 2f 0a 20 20 20 20 20 20 20 20 69 66 28    */.        if(
e130: 20 7a 46 61 69 6c 43 6f 64 65 20 29 7b 0a 20 20   zFailCode ){.  
e140: 20 20 20 20 20 20 20 20 69 66 28 20 7a 46 61 69          if( zFai
e150: 6c 43 6f 64 65 5b 30 5d 3d 3d 27 35 27 20 26 26  lCode[0]=='5' &&
e160: 20 7a 46 61 69 6c 43 6f 64 65 5b 31 5d 3d 3d 30   zFailCode[1]==0
e170: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
e180: 66 61 74 61 6c 45 72 72 6f 72 28 22 73 69 6d 75  fatalError("simu
e190: 6c 61 74 65 64 20 66 61 69 6c 75 72 65 22 29 3b  lated failure");
e1a0: 0a 20 20 20 20 20 20 20 20 20 20 7d 65 6c 73 65  .          }else
e1b0: 20 69 66 28 20 7a 46 61 69 6c 43 6f 64 65 5b 30   if( zFailCode[0
e1c0: 5d 21 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  ]!=0 ){.        
e1d0: 20 20 20 20 2f 2a 20 49 66 20 54 45 53 54 5f 46      /* If TEST_F
e1e0: 41 49 4c 55 52 45 20 69 73 20 73 6f 6d 65 74 68  AILURE is someth
e1f0: 69 6e 67 20 6f 74 68 65 72 20 74 68 61 6e 20 35  ing other than 5
e200: 2c 20 6a 75 73 74 20 65 78 69 74 20 74 68 65 20  , just exit the 
e210: 74 65 73 74 0a 20 20 20 20 20 20 20 20 20 20 20  test.           
e220: 20 2a 2a 20 65 61 72 6c 79 20 2a 2f 0a 20 20 20   ** early */.   
e230: 20 20 20 20 20 20 20 20 20 70 72 69 6e 74 66 28           printf(
e240: 22 5c 6e 45 78 69 74 20 65 61 72 6c 79 20 64 75  "\nExit early du
e250: 65 20 74 6f 20 54 45 53 54 5f 46 41 49 4c 55 52  e to TEST_FAILUR
e260: 45 20 62 65 69 6e 67 20 73 65 74 5c 6e 22 29 3b  E being set\n");
e270: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 53 72  .            iSr
e280: 63 44 62 20 3d 20 6e 53 72 63 44 62 2d 31 3b 0a  cDb = nSrcDb-1;.
e290: 20 20 20 20 20 20 20 20 20 20 20 20 67 6f 74 6f              goto
e2a0: 20 73 6f 75 72 63 65 64 62 5f 63 6c 65 61 6e 75   sourcedb_cleanu
e2b0: 70 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  p;.          }. 
e2c0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
e2d0: 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 21  .    }.    if( !
e2e0: 71 75 69 65 74 46 6c 61 67 20 26 26 20 21 76 65  quietFlag && !ve
e2f0: 72 62 6f 73 65 46 6c 61 67 20 29 7b 0a 20 20 20  rboseFlag ){.   
e300: 20 20 20 70 72 69 6e 74 66 28 22 20 31 30 30 25     printf(" 100%
e310: 25 20 2d 20 25 64 20 74 65 73 74 73 5c 6e 22 2c  % - %d tests\n",
e320: 20 67 2e 6e 44 62 2a 67 2e 6e 53 71 6c 29 3b 0a   g.nDb*g.nSql);.
e330: 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 2f 2a 20      }.  .    /* 
e340: 43 6c 65 61 6e 20 75 70 20 61 74 20 74 68 65 20  Clean up at the 
e350: 65 6e 64 20 6f 66 20 70 72 6f 63 65 73 73 69 6e  end of processin
e360: 67 20 61 20 73 69 6e 67 6c 65 20 73 6f 75 72 63  g a single sourc
e370: 65 20 64 61 74 61 62 61 73 65 0a 20 20 20 20 2a  e database.    *
e380: 2f 0a 20 20 73 6f 75 72 63 65 64 62 5f 63 6c 65  /.  sourcedb_cle
e390: 61 6e 75 70 3a 0a 20 20 20 20 62 6c 6f 62 4c 69  anup:.    blobLi
e3a0: 73 74 46 72 65 65 28 67 2e 70 46 69 72 73 74 53  stFree(g.pFirstS
e3b0: 71 6c 29 3b 0a 20 20 20 20 62 6c 6f 62 4c 69 73  ql);.    blobLis
e3c0: 74 46 72 65 65 28 67 2e 70 46 69 72 73 74 44 62  tFree(g.pFirstDb
e3d0: 29 3b 0a 20 20 20 20 72 65 66 6f 72 6d 61 74 56  );.    reformatV
e3e0: 66 73 28 29 3b 0a 20 0a 20 20 7d 20 2f 2a 20 45  fs();. .  } /* E
e3f0: 6e 64 20 6c 6f 6f 70 20 6f 76 65 72 20 61 6c 6c  nd loop over all
e400: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65   source database
e410: 73 20 2a 2f 0a 0a 20 20 69 66 28 20 21 71 75 69  s */..  if( !qui
e420: 65 74 46 6c 61 67 20 29 7b 0a 20 20 20 20 73 71  etFlag ){.    sq
e430: 6c 69 74 65 33 5f 69 6e 74 36 34 20 69 45 6c 61  lite3_int64 iEla
e440: 70 73 65 20 3d 20 74 69 6d 65 4f 66 44 61 79 28  pse = timeOfDay(
e450: 29 20 2d 20 69 42 65 67 69 6e 3b 0a 20 20 20 20  ) - iBegin;.    
e460: 70 72 69 6e 74 66 28 22 66 75 7a 7a 63 68 65 63  printf("fuzzchec
e470: 6b 3a 20 30 20 65 72 72 6f 72 73 20 6f 75 74 20  k: 0 errors out 
e480: 6f 66 20 25 64 20 74 65 73 74 73 20 69 6e 20 25  of %d tests in %
e490: 64 2e 25 30 33 64 20 73 65 63 6f 6e 64 73 5c 6e  d.%03d seconds\n
e4a0: 22 0a 20 20 20 20 20 20 20 20 20 20 20 22 53 51  ".           "SQ
e4b0: 4c 69 74 65 20 25 73 20 25 73 5c 6e 22 2c 0a 20  Lite %s %s\n",. 
e4c0: 20 20 20 20 20 20 20 20 20 20 6e 54 65 73 74 2c            nTest,
e4d0: 20 28 69 6e 74 29 28 69 45 6c 61 70 73 65 2f 31   (int)(iElapse/1
e4e0: 30 30 30 29 2c 20 28 69 6e 74 29 28 69 45 6c 61  000), (int)(iEla
e4f0: 70 73 65 25 31 30 30 30 29 2c 0a 20 20 20 20 20  pse%1000),.     
e500: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 6c 69        sqlite3_li
e510: 62 76 65 72 73 69 6f 6e 28 29 2c 20 73 71 6c 69  bversion(), sqli
e520: 74 65 33 5f 73 6f 75 72 63 65 69 64 28 29 29 3b  te3_sourceid());
e530: 0a 20 20 7d 0a 20 20 66 72 65 65 28 61 7a 53 72  .  }.  free(azSr
e540: 63 44 62 29 3b 0a 20 20 66 72 65 65 28 70 48 65  cDb);.  free(pHe
e550: 61 70 29 3b 0a 20 20 72 65 74 75 72 6e 20 30 3b  ap);.  return 0;
e560: 0a 7d 0a                                         .}.