/ Hex Artifact Content
Login

Artifact a42341b7a01229782b9bd97ff2eeebae830adbea:


0000: 2f 2a 0a 2a 2a 20 54 68 69 73 20 43 20 70 72 6f  /*.** This C pro
0010: 67 72 61 6d 20 65 78 74 72 61 63 74 73 20 61 6c  gram extracts al
0020: 6c 20 22 77 6f 72 64 73 22 20 66 72 6f 6d 20 61  l "words" from a
0030: 6e 20 69 6e 70 75 74 20 64 6f 63 75 6d 65 6e 74  n input document
0040: 20 61 6e 64 20 61 64 64 73 20 74 68 65 6d 0a 2a   and adds them.*
0050: 2a 20 74 6f 20 61 6e 20 53 51 4c 69 74 65 20 64  * to an SQLite d
0060: 61 74 61 62 61 73 65 2e 20 20 41 20 22 77 6f 72  atabase.  A "wor
0070: 64 22 20 69 73 20 61 6e 79 20 63 6f 6e 74 69 67  d" is any contig
0080: 75 6f 75 73 20 73 65 71 75 65 6e 63 65 20 6f 66  uous sequence of
0090: 20 61 6c 70 68 61 62 65 74 69 63 0a 2a 2a 20 63   alphabetic.** c
00a0: 68 61 72 61 63 74 65 72 73 2e 20 20 41 6c 6c 20  haracters.  All 
00b0: 64 69 67 69 74 73 2c 20 70 75 6e 63 74 75 61 74  digits, punctuat
00c0: 69 6f 6e 2c 20 61 6e 64 20 77 68 69 74 65 73 70  ion, and whitesp
00d0: 61 63 65 20 63 68 61 72 61 63 74 65 72 73 20 61  ace characters a
00e0: 72 65 20 0a 2a 2a 20 77 6f 72 64 20 73 65 70 61  re .** word sepa
00f0: 72 61 74 6f 72 73 2e 20 20 54 68 65 20 64 61 74  rators.  The dat
0100: 61 62 61 73 65 20 73 74 6f 72 65 73 20 61 20 73  abase stores a s
0110: 69 6e 67 6c 65 20 65 6e 74 72 79 20 66 6f 72 20  ingle entry for 
0120: 65 61 63 68 20 64 69 73 74 69 6e 63 74 0a 2a 2a  each distinct.**
0130: 20 77 6f 72 64 20 74 6f 67 65 74 68 65 72 20 77   word together w
0140: 69 74 68 20 61 20 63 6f 75 6e 74 20 6f 66 20 74  ith a count of t
0150: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 6f 63 63  he number of occ
0160: 75 72 72 65 6e 63 65 73 20 6f 66 20 74 68 61 74  urrences of that
0170: 20 77 6f 72 64 2e 0a 2a 2a 20 41 20 66 72 65 73   word..** A fres
0180: 68 20 64 61 74 61 62 61 73 65 20 69 73 20 63 72  h database is cr
0190: 65 61 74 65 64 20 61 75 74 6f 6d 61 74 69 63 61  eated automatica
01a0: 6c 6c 79 20 6f 6e 20 65 61 63 68 20 72 75 6e 2e  lly on each run.
01b0: 0a 2a 2a 0a 2a 2a 20 20 20 20 20 77 6f 72 64 63  .**.**     wordc
01c0: 6f 75 6e 74 20 44 41 54 41 42 41 53 45 20 49 4e  ount DATABASE IN
01d0: 50 55 54 46 49 4c 45 0a 2a 2a 0a 2a 2a 20 54 68  PUTFILE.**.** Th
01e0: 65 20 49 4e 50 55 54 46 49 4c 45 20 6e 61 6d 65  e INPUTFILE name
01f0: 20 63 61 6e 20 62 65 20 6f 6d 69 74 74 65 64 2c   can be omitted,
0200: 20 69 6e 20 77 68 69 63 68 20 63 61 73 65 20 69   in which case i
0210: 6e 70 75 74 20 69 74 20 74 61 6b 65 6e 20 66 72  nput it taken fr
0220: 6f 6d 0a 2a 2a 20 73 74 61 6e 64 61 72 64 20 69  om.** standard i
0230: 6e 70 75 74 2e 0a 2a 2a 0a 2a 2a 20 4f 70 74 69  nput..**.** Opti
0240: 6f 6e 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 2d 2d  on:.**.**     --
0250: 77 69 74 68 6f 75 74 2d 72 6f 77 69 64 20 20 20  without-rowid   
0260: 20 20 20 55 73 65 20 61 20 57 49 54 48 4f 55 54     Use a WITHOUT
0270: 20 52 4f 57 49 44 20 74 61 62 6c 65 20 74 6f 20   ROWID table to 
0280: 73 74 6f 72 65 20 74 68 65 20 77 6f 72 64 73 2e  store the words.
0290: 0a 2a 2a 20 20 20 20 20 2d 2d 69 6e 73 65 72 74  .**     --insert
02a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 55 73 65               Use
02b0: 20 49 4e 53 45 52 54 20 6d 6f 64 65 20 28 74 68   INSERT mode (th
02c0: 65 20 64 65 66 61 75 6c 74 29 0a 2a 2a 20 20 20  e default).**   
02d0: 20 20 2d 2d 72 65 70 6c 61 63 65 20 20 20 20 20    --replace     
02e0: 20 20 20 20 20 20 20 55 73 65 20 52 45 50 4c 41         Use REPLA
02f0: 43 45 20 6d 6f 64 65 0a 2a 2a 20 20 20 20 20 2d  CE mode.**     -
0300: 2d 73 65 6c 65 63 74 20 20 20 20 20 20 20 20 20  -select         
0310: 20 20 20 20 55 73 65 20 53 45 4c 45 43 54 20 6d      Use SELECT m
0320: 6f 64 65 0a 2a 2a 20 20 20 20 20 2d 2d 75 70 64  ode.**     --upd
0330: 61 74 65 20 20 20 20 20 20 20 20 20 20 20 20 20  ate             
0340: 55 73 65 20 55 50 44 41 54 45 20 6d 6f 64 65 0a  Use UPDATE mode.
0350: 2a 2a 20 20 20 20 20 2d 2d 64 65 6c 65 74 65 20  **     --delete 
0360: 20 20 20 20 20 20 20 20 20 20 20 20 55 73 65 20              Use 
0370: 44 45 4c 45 54 45 20 6d 6f 64 65 0a 2a 2a 20 20  DELETE mode.**  
0380: 20 20 20 2d 2d 71 75 65 72 79 20 20 20 20 20 20     --query      
0390: 20 20 20 20 20 20 20 20 55 73 65 20 51 55 45 52          Use QUER
03a0: 59 20 6d 6f 64 65 0a 2a 2a 20 20 20 20 20 2d 2d  Y mode.**     --
03b0: 6e 6f 63 61 73 65 20 20 20 20 20 20 20 20 20 20  nocase          
03c0: 20 20 20 41 64 64 20 74 68 65 20 4e 4f 43 41 53     Add the NOCAS
03d0: 45 20 63 6f 6c 6c 61 74 69 6e 67 20 73 65 71 75  E collating sequ
03e0: 65 6e 63 65 20 74 6f 20 74 68 65 20 77 6f 72 64  ence to the word
03f0: 73 2e 0a 2a 2a 20 20 20 20 20 2d 2d 74 72 61 63  s..**     --trac
0400: 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20 45  e              E
0410: 6e 61 62 6c 65 20 73 71 6c 69 74 65 33 5f 74 72  nable sqlite3_tr
0420: 61 63 65 28 29 20 6f 75 74 70 75 74 2e 0a 2a 2a  ace() output..**
0430: 20 20 20 20 20 2d 2d 73 75 6d 6d 61 72 79 20 20       --summary  
0440: 20 20 20 20 20 20 20 20 20 20 53 68 6f 77 20 73            Show s
0450: 75 6d 6d 61 72 79 20 69 6e 66 6f 72 6d 61 74 69  ummary informati
0460: 6f 6e 20 6f 6e 20 74 68 65 20 63 6f 6c 6c 65 63  on on the collec
0470: 74 65 64 20 64 61 74 61 2e 0a 2a 2a 20 20 20 20  ted data..**    
0480: 20 2d 2d 73 74 61 74 73 20 20 20 20 20 20 20 20   --stats        
0490: 20 20 20 20 20 20 53 68 6f 77 20 73 71 6c 69 74        Show sqlit
04a0: 65 33 5f 73 74 61 74 75 73 28 29 20 72 65 73 75  e3_status() resu
04b0: 6c 74 73 20 61 74 20 74 68 65 20 65 6e 64 2e 0a  lts at the end..
04c0: 2a 2a 20 20 20 20 20 2d 2d 70 61 67 65 73 69 7a  **     --pagesiz
04d0: 65 20 4e 4e 4e 20 20 20 20 20 20 20 55 73 65 20  e NNN       Use 
04e0: 61 20 70 61 67 65 20 73 69 7a 65 20 6f 66 20 4e  a page size of N
04f0: 4e 4e 0a 2a 2a 20 20 20 20 20 2d 2d 63 61 63 68  NN.**     --cach
0500: 65 73 69 7a 65 20 4e 4e 4e 20 20 20 20 20 20 55  esize NNN      U
0510: 73 65 20 61 20 63 61 63 68 65 20 73 69 7a 65 20  se a cache size 
0520: 6f 66 20 4e 4e 4e 0a 2a 2a 20 20 20 20 20 2d 2d  of NNN.**     --
0530: 63 6f 6d 6d 69 74 20 4e 4e 4e 20 20 20 20 20 20  commit NNN      
0540: 20 20 20 43 6f 6d 6d 69 74 20 61 66 74 65 72 20     Commit after 
0550: 65 76 65 72 79 20 4e 4e 4e 20 6f 70 65 72 61 74  every NNN operat
0560: 69 6f 6e 73 0a 2a 2a 20 20 20 20 20 2d 2d 6e 6f  ions.**     --no
0570: 73 79 6e 63 20 20 20 20 20 20 20 20 20 20 20 20  sync            
0580: 20 55 73 65 20 50 52 41 47 4d 41 20 73 79 6e 63   Use PRAGMA sync
0590: 68 72 6f 6e 6f 75 73 3d 4f 46 46 0a 2a 2a 20 20  hronous=OFF.**  
05a0: 20 20 20 2d 2d 6a 6f 75 72 6e 61 6c 20 4d 4d 4d     --journal MMM
05b0: 4d 20 20 20 20 20 20 20 55 73 65 20 50 52 41 47  M       Use PRAG
05c0: 4d 41 20 6a 6f 75 72 6e 61 6c 5f 6d 6f 64 65 3d  MA journal_mode=
05d0: 4d 4d 4d 4d 0a 2a 2a 20 20 20 20 20 2d 2d 74 69  MMMM.**     --ti
05e0: 6d 65 72 20 20 20 20 20 20 20 20 20 20 20 20 20  mer             
05f0: 20 54 69 6d 65 20 74 68 65 20 6f 70 65 72 61 74   Time the operat
0600: 69 6f 6e 20 6f 66 20 74 68 69 73 20 70 72 6f 67  ion of this prog
0610: 72 61 6d 0a 2a 2a 0a 2a 2a 20 4d 6f 64 65 73 3a  ram.**.** Modes:
0620: 0a 2a 2a 0a 2a 2a 20 49 6e 73 65 72 74 20 6d 6f  .**.** Insert mo
0630: 64 65 20 6d 65 61 6e 73 3a 0a 2a 2a 20 20 20 20  de means:.**    
0640: 28 31 29 20 49 4e 53 45 52 54 20 4f 52 20 49 47  (1) INSERT OR IG
0650: 4e 4f 52 45 20 49 4e 54 4f 20 77 6f 72 64 63 6f  NORE INTO wordco
0660: 75 6e 74 20 56 41 4c 55 45 53 28 24 6e 65 77 2c  unt VALUES($new,
0670: 31 29 0a 2a 2a 20 20 20 20 28 32 29 20 55 50 44  1).**    (2) UPD
0680: 41 54 45 20 77 6f 72 64 63 6f 75 6e 74 20 53 45  ATE wordcount SE
0690: 54 20 63 6e 74 3d 63 6e 74 2b 31 20 57 48 45 52  T cnt=cnt+1 WHER
06a0: 45 20 77 6f 72 64 3d 24 6e 65 77 20 2d 2d 20 69  E word=$new -- i
06b0: 66 20 28 31 29 20 69 73 20 61 20 6e 6f 6f 70 0a  f (1) is a noop.
06c0: 2a 2a 0a 2a 2a 20 55 70 64 61 74 65 20 6d 6f 64  **.** Update mod
06d0: 65 20 6d 65 61 6e 73 3a 0a 2a 2a 20 20 20 20 28  e means:.**    (
06e0: 31 29 20 49 4e 53 45 52 54 20 4f 52 20 49 47 4e  1) INSERT OR IGN
06f0: 4f 52 45 20 49 4e 54 4f 20 77 6f 72 64 63 6f 75  ORE INTO wordcou
0700: 6e 74 20 56 41 4c 55 45 53 28 24 6e 65 77 2c 30  nt VALUES($new,0
0710: 29 0a 2a 2a 20 20 20 20 28 32 29 20 55 50 44 41  ).**    (2) UPDA
0720: 54 45 20 77 6f 72 64 63 6f 75 6e 74 20 53 45 54  TE wordcount SET
0730: 20 63 6e 74 3d 63 6e 74 2b 31 20 57 48 45 52 45   cnt=cnt+1 WHERE
0740: 20 77 6f 72 64 3d 24 6e 65 77 0a 2a 2a 0a 2a 2a   word=$new.**.**
0750: 20 52 65 70 6c 61 63 65 20 6d 6f 64 65 20 6d 65   Replace mode me
0760: 61 6e 73 3a 0a 2a 2a 20 20 20 20 28 31 29 20 52  ans:.**    (1) R
0770: 45 50 4c 41 43 45 20 49 4e 54 4f 20 77 6f 72 64  EPLACE INTO word
0780: 63 6f 75 6e 74 0a 2a 2a 20 20 20 20 20 20 20 20  count.**        
0790: 56 41 4c 55 45 53 28 24 6e 65 77 2c 69 66 6e 75  VALUES($new,ifnu
07a0: 6c 6c 28 28 53 45 4c 45 43 54 20 63 6e 74 20 46  ll((SELECT cnt F
07b0: 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 20 57 48  ROM wordcount WH
07c0: 45 52 45 20 77 6f 72 64 3d 24 6e 65 77 29 2c 30  ERE word=$new),0
07d0: 29 2b 31 29 3b 0a 2a 2a 0a 2a 2a 20 53 65 6c 65  )+1);.**.** Sele
07e0: 63 74 20 6d 6f 64 65 20 6d 65 61 6e 73 3a 0a 2a  ct mode means:.*
07f0: 2a 20 20 20 20 28 31 29 20 53 45 4c 45 43 54 20  *    (1) SELECT 
0800: 31 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74  1 FROM wordcount
0810: 20 57 48 45 52 45 20 77 6f 72 64 3d 24 6e 65 77   WHERE word=$new
0820: 0a 2a 2a 20 20 20 20 28 32 29 20 49 4e 53 45 52  .**    (2) INSER
0830: 54 20 49 4e 54 4f 20 77 6f 72 64 63 6f 75 6e 74  T INTO wordcount
0840: 20 56 41 4c 55 45 53 28 24 6e 65 77 2c 31 29 20   VALUES($new,1) 
0850: 2d 2d 20 69 66 20 28 31 29 20 72 65 74 75 72 6e  -- if (1) return
0860: 73 20 6e 6f 74 68 69 6e 67 0a 2a 2a 20 20 20 20  s nothing.**    
0870: 28 33 29 20 55 50 44 41 54 45 20 77 6f 72 64 63  (3) UPDATE wordc
0880: 6f 75 6e 74 20 53 45 54 20 63 6e 74 3d 63 6e 74  ount SET cnt=cnt
0890: 2b 31 20 57 48 45 52 45 20 77 6f 72 64 3d 24 6e  +1 WHERE word=$n
08a0: 65 77 20 20 2d 2d 69 66 20 28 31 29 20 72 65 74  ew  --if (1) ret
08b0: 75 72 6e 20 54 52 55 45 0a 2a 2a 0a 2a 2a 20 44  urn TRUE.**.** D
08c0: 65 6c 65 74 65 20 6d 6f 64 65 20 6d 65 61 6e 73  elete mode means
08d0: 3a 0a 2a 2a 20 20 20 20 28 31 29 20 44 45 4c 45  :.**    (1) DELE
08e0: 54 45 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e  TE FROM wordcoun
08f0: 74 20 57 48 45 52 45 20 77 6f 72 64 3d 24 6e 65  t WHERE word=$ne
0900: 77 0a 2a 2a 0a 2a 2a 20 51 75 65 72 79 20 6d 6f  w.**.** Query mo
0910: 64 65 20 6d 65 61 6e 73 3a 0a 2a 2a 20 20 20 20  de means:.**    
0920: 28 31 29 20 53 45 4c 45 43 54 20 63 6e 74 20 46  (1) SELECT cnt F
0930: 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 20 57 48  ROM wordcount WH
0940: 45 52 45 20 77 6f 72 64 3d 24 6e 65 77 0a 2a 2a  ERE word=$new.**
0950: 0a 2a 2a 20 4e 6f 74 65 20 74 68 61 74 20 64 65  .** Note that de
0960: 6c 65 74 65 20 6d 6f 64 65 20 61 6e 64 20 71 75  lete mode and qu
0970: 65 72 79 20 6d 6f 64 65 20 61 72 65 20 6f 6e 6c  ery mode are onl
0980: 79 20 75 73 65 66 75 6c 20 66 6f 72 20 70 72 65  y useful for pre
0990: 65 78 69 73 74 69 6e 67 0a 2a 2a 20 64 61 74 61  existing.** data
09a0: 62 61 73 65 73 2e 20 20 54 68 65 20 77 6f 72 64  bases.  The word
09b0: 63 6f 75 6e 74 20 74 61 62 6c 65 20 69 73 20 63  count table is c
09c0: 72 65 61 74 65 64 20 75 73 69 6e 67 20 49 46 20  reated using IF 
09d0: 4e 4f 54 20 45 58 49 53 54 53 20 73 6f 20 74 68  NOT EXISTS so th
09e0: 69 73 0a 2a 2a 20 75 74 69 6c 69 74 79 20 63 61  is.** utility ca
09f0: 6e 20 62 65 20 72 75 6e 20 6d 75 6c 74 69 70 6c  n be run multipl
0a00: 65 20 74 69 6d 65 73 20 6f 6e 20 74 68 65 20 73  e times on the s
0a10: 61 6d 65 20 64 61 74 61 62 61 73 65 20 66 69 6c  ame database fil
0a20: 65 2e 20 20 54 68 65 0a 2a 2a 20 2d 2d 77 69 74  e.  The.** --wit
0a30: 68 6f 75 74 2d 72 6f 77 69 64 2c 20 2d 2d 6e 6f  hout-rowid, --no
0a40: 63 61 73 65 2c 20 61 6e 64 20 2d 2d 70 61 67 65  case, and --page
0a50: 73 69 7a 65 20 70 61 72 61 6d 65 74 65 72 73 20  size parameters 
0a60: 61 72 65 20 6f 6e 6c 79 20 65 66 66 65 63 74 69  are only effecti
0a70: 76 65 0a 2a 2a 20 77 68 65 6e 20 63 72 65 61 74  ve.** when creat
0a80: 69 6e 67 20 61 20 6e 65 77 20 64 61 74 61 62 61  ing a new databa
0a90: 73 65 20 61 6e 64 20 61 72 65 20 68 61 72 6d 6c  se and are harml
0aa0: 65 73 73 20 6e 6f 2d 6f 70 73 20 6f 6e 20 70 72  ess no-ops on pr
0ab0: 65 65 78 69 73 74 69 6e 67 0a 2a 2a 20 64 61 74  eexisting.** dat
0ac0: 61 62 61 73 65 73 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a  abases..**.*****
0ad0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0ae0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0af0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0b00: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0b10: 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 2a 2a 0a 2a 2a 20  *********.**.** 
0b20: 43 6f 6d 70 69 6c 65 20 61 73 20 66 6f 6c 6c 6f  Compile as follo
0b30: 77 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 67 63 63  ws:.**.**    gcc
0b40: 20 2d 49 2e 20 77 6f 72 64 63 6f 75 6e 74 2e 63   -I. wordcount.c
0b50: 20 73 71 6c 69 74 65 33 2e 63 20 2d 6c 64 6c 20   sqlite3.c -ldl 
0b60: 2d 6c 70 74 68 72 65 61 64 73 0a 2a 2a 0a 2a 2a  -lpthreads.**.**
0b70: 20 4f 72 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 67 63   Or:.**.**    gc
0b80: 63 20 2d 49 2e 20 2d 44 53 51 4c 49 54 45 5f 54  c -I. -DSQLITE_T
0b90: 48 52 45 41 44 53 41 46 45 3d 30 20 2d 44 53 51  HREADSAFE=0 -DSQ
0ba0: 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f 41 44 5f 45  LITE_OMIT_LOAD_E
0bb0: 58 54 45 4e 53 49 4f 4e 20 5c 0a 2a 2a 20 20 20  XTENSION \.**   
0bc0: 20 20 20 20 20 77 6f 72 64 63 6f 75 6e 74 2e 63       wordcount.c
0bd0: 20 73 71 6c 69 74 65 33 2e 63 0a 2a 2f 0a 23 69   sqlite3.c.*/.#i
0be0: 6e 63 6c 75 64 65 20 3c 73 74 64 69 6f 2e 68 3e  nclude <stdio.h>
0bf0: 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 72 69 6e  .#include <strin
0c00: 67 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 63  g.h>.#include <c
0c10: 74 79 70 65 2e 68 3e 0a 23 69 6e 63 6c 75 64 65  type.h>.#include
0c20: 20 3c 73 74 64 6c 69 62 2e 68 3e 0a 23 69 6e 63   <stdlib.h>.#inc
0c30: 6c 75 64 65 20 3c 73 74 64 61 72 67 2e 68 3e 0a  lude <stdarg.h>.
0c40: 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65  #include "sqlite
0c50: 33 2e 68 22 0a 0a 2f 2a 20 52 65 74 75 72 6e 20  3.h"../* Return 
0c60: 74 68 65 20 63 75 72 72 65 6e 74 20 77 61 6c 6c  the current wall
0c70: 2d 63 6c 6f 63 6b 20 74 69 6d 65 20 2a 2f 0a 73  -clock time */.s
0c80: 74 61 74 69 63 20 73 71 6c 69 74 65 33 5f 69 6e  tatic sqlite3_in
0c90: 74 36 34 20 72 65 61 6c 54 69 6d 65 28 76 6f 69  t64 realTime(voi
0ca0: 64 29 7b 0a 20 20 73 74 61 74 69 63 20 73 71 6c  d){.  static sql
0cb0: 69 74 65 33 5f 76 66 73 20 2a 63 6c 6f 63 6b 56  ite3_vfs *clockV
0cc0: 66 73 20 3d 20 30 3b 0a 20 20 73 71 6c 69 74 65  fs = 0;.  sqlite
0cd0: 33 5f 69 6e 74 36 34 20 74 3b 0a 20 20 69 66 28  3_int64 t;.  if(
0ce0: 20 63 6c 6f 63 6b 56 66 73 3d 3d 30 20 29 20 63   clockVfs==0 ) c
0cf0: 6c 6f 63 6b 56 66 73 20 3d 20 73 71 6c 69 74 65  lockVfs = sqlite
0d00: 33 5f 76 66 73 5f 66 69 6e 64 28 30 29 3b 0a 20  3_vfs_find(0);. 
0d10: 20 69 66 28 20 63 6c 6f 63 6b 56 66 73 2d 3e 69   if( clockVfs->i
0d20: 56 65 72 73 69 6f 6e 3e 3d 31 20 26 26 20 63 6c  Version>=1 && cl
0d30: 6f 63 6b 56 66 73 2d 3e 78 43 75 72 72 65 6e 74  ockVfs->xCurrent
0d40: 54 69 6d 65 49 6e 74 36 34 21 3d 30 20 29 7b 0a  TimeInt64!=0 ){.
0d50: 20 20 20 20 63 6c 6f 63 6b 56 66 73 2d 3e 78 43      clockVfs->xC
0d60: 75 72 72 65 6e 74 54 69 6d 65 49 6e 74 36 34 28  urrentTimeInt64(
0d70: 63 6c 6f 63 6b 56 66 73 2c 20 26 74 29 3b 0a 20  clockVfs, &t);. 
0d80: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 64 6f 75 62   }else{.    doub
0d90: 6c 65 20 72 3b 0a 20 20 20 20 63 6c 6f 63 6b 56  le r;.    clockV
0da0: 66 73 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d 65  fs->xCurrentTime
0db0: 28 63 6c 6f 63 6b 56 66 73 2c 20 26 72 29 3b 0a  (clockVfs, &r);.
0dc0: 20 20 20 20 74 20 3d 20 28 73 71 6c 69 74 65 33      t = (sqlite3
0dd0: 5f 69 6e 74 36 34 29 28 72 2a 38 36 34 30 30 30  _int64)(r*864000
0de0: 30 30 2e 30 29 3b 0a 20 20 7d 0a 20 20 72 65 74  00.0);.  }.  ret
0df0: 75 72 6e 20 74 3b 0a 7d 0a 0a 2f 2a 20 50 72 69  urn t;.}../* Pri
0e00: 6e 74 20 61 6e 20 65 72 72 6f 72 20 6d 65 73 73  nt an error mess
0e10: 61 67 65 20 61 6e 64 20 65 78 69 74 20 2a 2f 0a  age and exit */.
0e20: 73 74 61 74 69 63 20 76 6f 69 64 20 66 61 74 61  static void fata
0e30: 6c 5f 65 72 72 6f 72 28 63 6f 6e 73 74 20 63 68  l_error(const ch
0e40: 61 72 20 2a 7a 4d 73 67 2c 20 2e 2e 2e 29 7b 0a  ar *zMsg, ...){.
0e50: 20 20 76 61 5f 6c 69 73 74 20 61 70 3b 0a 20 20    va_list ap;.  
0e60: 76 61 5f 73 74 61 72 74 28 61 70 2c 20 7a 4d 73  va_start(ap, zMs
0e70: 67 29 3b 0a 20 20 76 66 70 72 69 6e 74 66 28 73  g);.  vfprintf(s
0e80: 74 64 65 72 72 2c 20 7a 4d 73 67 2c 20 61 70 29  tderr, zMsg, ap)
0e90: 3b 0a 20 20 76 61 5f 65 6e 64 28 61 70 29 3b 0a  ;.  va_end(ap);.
0ea0: 20 20 65 78 69 74 28 31 29 3b 0a 7d 0a 0a 2f 2a    exit(1);.}../*
0eb0: 20 54 68 65 20 73 71 6c 69 74 65 33 5f 74 72 61   The sqlite3_tra
0ec0: 63 65 28 29 20 63 61 6c 6c 62 61 63 6b 20 66 75  ce() callback fu
0ed0: 6e 63 74 69 6f 6e 20 2a 2f 0a 73 74 61 74 69 63  nction */.static
0ee0: 20 76 6f 69 64 20 74 72 61 63 65 43 61 6c 6c 62   void traceCallb
0ef0: 61 63 6b 28 76 6f 69 64 20 2a 4e 6f 74 55 73 65  ack(void *NotUse
0f00: 64 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  d, const char *z
0f10: 53 71 6c 29 7b 0a 20 20 70 72 69 6e 74 66 28 22  Sql){.  printf("
0f20: 25 73 3b 5c 6e 22 2c 20 7a 53 71 6c 29 3b 0a 7d  %s;\n", zSql);.}
0f30: 0a 0a 2f 2a 20 41 6e 20 73 71 6c 69 74 65 33 5f  ../* An sqlite3_
0f40: 65 78 65 63 28 29 20 63 61 6c 6c 62 61 63 6b 20  exec() callback 
0f50: 74 68 61 74 20 70 72 69 6e 74 73 20 72 65 73 75  that prints resu
0f60: 6c 74 73 20 6f 6e 20 73 74 61 6e 64 61 72 64 20  lts on standard 
0f70: 6f 75 74 70 75 74 2c 0a 2a 2a 20 65 61 63 68 20  output,.** each 
0f80: 63 6f 6c 75 6d 6e 20 73 65 70 61 72 61 74 65 64  column separated
0f90: 20 62 79 20 61 20 73 69 6e 67 6c 65 20 73 70 61   by a single spa
0fa0: 63 65 2e 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ce. */.static in
0fb0: 74 20 70 72 69 6e 74 52 65 73 75 6c 74 28 76 6f  t printResult(vo
0fc0: 69 64 20 2a 4e 6f 74 55 73 65 64 2c 20 69 6e 74  id *NotUsed, int
0fd0: 20 6e 41 72 67 2c 20 63 68 61 72 20 2a 2a 61 7a   nArg, char **az
0fe0: 41 72 67 2c 20 63 68 61 72 20 2a 2a 61 7a 4e 6d  Arg, char **azNm
0ff0: 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 70 72  ){.  int i;.  pr
1000: 69 6e 74 66 28 22 2d 2d 22 29 3b 0a 20 20 66 6f  intf("--");.  fo
1010: 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20 69  r(i=0; i<nArg; i
1020: 2b 2b 29 7b 0a 20 20 20 20 70 72 69 6e 74 66 28  ++){.    printf(
1030: 22 20 25 73 22 2c 20 61 7a 41 72 67 5b 69 5d 29  " %s", azArg[i])
1040: 3b 0a 20 20 7d 0a 20 20 70 72 69 6e 74 66 28 22  ;.  }.  printf("
1050: 5c 6e 22 29 3b 0a 20 20 72 65 74 75 72 6e 20 30  \n");.  return 0
1060: 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 41 64 64 20  ;.}.../*.** Add 
1070: 6f 6e 65 20 63 68 61 72 61 63 74 65 72 20 74 6f  one character to
1080: 20 61 20 68 61 73 68 0a 2a 2f 0a 73 74 61 74 69   a hash.*/.stati
1090: 63 20 76 6f 69 64 20 61 64 64 43 68 61 72 54 6f  c void addCharTo
10a0: 48 61 73 68 28 75 6e 73 69 67 6e 65 64 20 69 6e  Hash(unsigned in
10b0: 74 20 2a 61 2c 20 75 6e 73 69 67 6e 65 64 20 63  t *a, unsigned c
10c0: 68 61 72 20 78 29 7b 0a 20 20 69 66 28 20 61 5b  har x){.  if( a[
10d0: 30 5d 3c 34 20 29 7b 0a 20 20 20 20 61 5b 31 5d  0]<4 ){.    a[1]
10e0: 20 3d 20 28 61 5b 31 5d 3c 3c 38 29 20 7c 20 78   = (a[1]<<8) | x
10f0: 3b 0a 20 20 20 20 61 5b 30 5d 2b 2b 3b 0a 20 20  ;.    a[0]++;.  
1100: 7d 65 6c 73 65 7b 0a 20 20 20 20 61 5b 32 5d 20  }else{.    a[2] 
1110: 3d 20 28 61 5b 32 5d 3c 3c 38 29 20 7c 20 78 3b  = (a[2]<<8) | x;
1120: 0a 20 20 20 20 61 5b 30 5d 2b 2b 3b 0a 20 20 20  .    a[0]++;.   
1130: 20 69 66 28 20 61 5b 30 5d 3d 3d 38 20 29 7b 0a   if( a[0]==8 ){.
1140: 20 20 20 20 20 20 61 5b 33 5d 20 2b 3d 20 61 5b        a[3] += a[
1150: 31 5d 20 2b 20 61 5b 34 5d 3b 0a 20 20 20 20 20  1] + a[4];.     
1160: 20 61 5b 34 5d 20 2b 3d 20 61 5b 32 5d 20 2b 20   a[4] += a[2] + 
1170: 61 5b 33 5d 3b 0a 20 20 20 20 20 20 61 5b 30 5d  a[3];.      a[0]
1180: 20 3d 20 61 5b 31 5d 20 3d 20 61 5b 32 5d 20 3d   = a[1] = a[2] =
1190: 20 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 20 20   0;.    }.  }   
11a0: 20 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6d 70 75   .}../*.** Compu
11b0: 74 65 20 74 68 65 20 66 69 6e 61 6c 20 68 61 73  te the final has
11c0: 68 20 76 61 6c 75 65 2e 0a 2a 2f 0a 73 74 61 74  h value..*/.stat
11d0: 69 63 20 76 6f 69 64 20 66 69 6e 61 6c 48 61 73  ic void finalHas
11e0: 68 28 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 2a  h(unsigned int *
11f0: 61 2c 20 63 68 61 72 20 2a 7a 29 7b 0a 20 20 61  a, char *z){.  a
1200: 5b 33 5d 20 2b 3d 20 61 5b 31 5d 20 2b 20 61 5b  [3] += a[1] + a[
1210: 34 5d 20 2b 20 61 5b 30 5d 3b 0a 20 20 61 5b 34  4] + a[0];.  a[4
1220: 5d 20 2b 3d 20 61 5b 32 5d 20 2b 20 61 5b 33 5d  ] += a[2] + a[3]
1230: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 73 6e 70 72  ;.  sqlite3_snpr
1240: 69 6e 74 66 28 31 37 2c 20 7a 2c 20 22 25 30 38  intf(17, z, "%08
1250: 78 25 30 38 78 22 2c 20 61 5b 33 5d 2c 20 61 5b  x%08x", a[3], a[
1260: 34 5d 29 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 49  4]);.}.../*.** I
1270: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66  mplementation of
1280: 20 61 20 63 68 65 63 6b 73 75 6d 28 29 20 61 67   a checksum() ag
1290: 67 72 65 67 61 74 65 20 53 51 4c 20 66 75 6e 63  gregate SQL func
12a0: 74 69 6f 6e 0a 2a 2f 0a 73 74 61 74 69 63 20 76  tion.*/.static v
12b0: 6f 69 64 20 63 68 65 63 6b 73 75 6d 53 74 65 70  oid checksumStep
12c0: 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  (.  sqlite3_cont
12d0: 65 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a 20 20  ext *context,.  
12e0: 69 6e 74 20 61 72 67 63 2c 0a 20 20 73 71 6c 69  int argc,.  sqli
12f0: 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72 67 76  te3_value **argv
1300: 0a 29 7b 0a 20 20 63 6f 6e 73 74 20 75 6e 73 69  .){.  const unsi
1310: 67 6e 65 64 20 63 68 61 72 20 2a 7a 56 61 6c 3b  gned char *zVal;
1320: 0a 20 20 69 6e 74 20 6e 56 61 6c 2c 20 69 2c 20  .  int nVal, i, 
1330: 6a 3b 0a 20 20 75 6e 73 69 67 6e 65 64 20 69 6e  j;.  unsigned in
1340: 74 20 2a 61 3b 0a 20 20 61 20 3d 20 28 75 6e 73  t *a;.  a = (uns
1350: 69 67 6e 65 64 2a 29 73 71 6c 69 74 65 33 5f 61  igned*)sqlite3_a
1360: 67 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78 74  ggregate_context
1370: 28 63 6f 6e 74 65 78 74 2c 20 73 69 7a 65 6f 66  (context, sizeof
1380: 28 75 6e 73 69 67 6e 65 64 20 69 6e 74 29 2a 35  (unsigned int)*5
1390: 29 3b 0a 0a 20 20 69 66 28 20 61 20 29 7b 0a 20  );..  if( a ){. 
13a0: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 61 72     for(i=0; i<ar
13b0: 67 63 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  gc; i++){.      
13c0: 6e 56 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 76  nVal = sqlite3_v
13d0: 61 6c 75 65 5f 62 79 74 65 73 28 61 72 67 76 5b  alue_bytes(argv[
13e0: 69 5d 29 3b 0a 20 20 20 20 20 20 7a 56 61 6c 20  i]);.      zVal 
13f0: 3d 20 28 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65  = (const unsigne
1400: 64 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33 5f  d char*)sqlite3_
1410: 76 61 6c 75 65 5f 74 65 78 74 28 61 72 67 76 5b  value_text(argv[
1420: 69 5d 29 3b 0a 20 20 20 20 20 20 69 66 28 20 7a  i]);.      if( z
1430: 56 61 6c 20 29 20 66 6f 72 28 6a 3d 30 3b 20 6a  Val ) for(j=0; j
1440: 3c 6e 56 61 6c 3b 20 6a 2b 2b 29 20 61 64 64 43  <nVal; j++) addC
1450: 68 61 72 54 6f 48 61 73 68 28 61 2c 20 7a 56 61  harToHash(a, zVa
1460: 6c 5b 6a 5d 29 3b 0a 20 20 20 20 20 20 61 64 64  l[j]);.      add
1470: 43 68 61 72 54 6f 48 61 73 68 28 61 2c 20 27 7c  CharToHash(a, '|
1480: 27 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 61 64  ');.    }.    ad
1490: 64 43 68 61 72 54 6f 48 61 73 68 28 61 2c 20 27  dCharToHash(a, '
14a0: 5c 6e 27 29 3b 0a 20 20 7d 0a 7d 0a 73 74 61 74  \n');.  }.}.stat
14b0: 69 63 20 76 6f 69 64 20 63 68 65 63 6b 73 75 6d  ic void checksum
14c0: 46 69 6e 61 6c 69 7a 65 28 73 71 6c 69 74 65 33  Finalize(sqlite3
14d0: 5f 63 6f 6e 74 65 78 74 20 2a 63 6f 6e 74 65 78  _context *contex
14e0: 74 29 7b 0a 20 20 75 6e 73 69 67 6e 65 64 20 69  t){.  unsigned i
14f0: 6e 74 20 2a 61 3b 0a 20 20 63 68 61 72 20 7a 52  nt *a;.  char zR
1500: 65 73 75 6c 74 5b 32 34 5d 3b 0a 20 20 61 20 3d  esult[24];.  a =
1510: 20 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67 61   sqlite3_aggrega
1520: 74 65 5f 63 6f 6e 74 65 78 74 28 63 6f 6e 74 65  te_context(conte
1530: 78 74 2c 20 30 29 3b 0a 20 20 69 66 28 20 61 20  xt, 0);.  if( a 
1540: 29 7b 0a 20 20 20 20 66 69 6e 61 6c 48 61 73 68  ){.    finalHash
1550: 28 61 2c 20 7a 52 65 73 75 6c 74 29 3b 0a 20 20  (a, zResult);.  
1560: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
1570: 5f 74 65 78 74 28 63 6f 6e 74 65 78 74 2c 20 7a  _text(context, z
1580: 52 65 73 75 6c 74 2c 20 2d 31 2c 20 53 51 4c 49  Result, -1, SQLI
1590: 54 45 5f 54 52 41 4e 53 49 45 4e 54 29 3b 0a 20  TE_TRANSIENT);. 
15a0: 20 7d 0a 7d 0a 0a 0a 2f 2a 20 44 65 66 69 6e 65   }.}.../* Define
15b0: 20 6f 70 65 72 61 74 69 6e 67 20 6d 6f 64 65 73   operating modes
15c0: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45   */.#define MODE
15d0: 5f 49 4e 53 45 52 54 20 20 20 20 20 30 0a 23 64  _INSERT     0.#d
15e0: 65 66 69 6e 65 20 4d 4f 44 45 5f 52 45 50 4c 41  efine MODE_REPLA
15f0: 43 45 20 20 20 20 31 0a 23 64 65 66 69 6e 65 20  CE    1.#define 
1600: 4d 4f 44 45 5f 53 45 4c 45 43 54 20 20 20 20 20  MODE_SELECT     
1610: 32 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f 55  2.#define MODE_U
1620: 50 44 41 54 45 20 20 20 20 20 33 0a 23 64 65 66  PDATE     3.#def
1630: 69 6e 65 20 4d 4f 44 45 5f 44 45 4c 45 54 45 20  ine MODE_DELETE 
1640: 20 20 20 20 34 0a 23 64 65 66 69 6e 65 20 4d 4f      4.#define MO
1650: 44 45 5f 51 55 45 52 59 20 20 20 20 20 20 35 0a  DE_QUERY      5.
1660: 0a 69 6e 74 20 6d 61 69 6e 28 69 6e 74 20 61 72  .int main(int ar
1670: 67 63 2c 20 63 68 61 72 20 2a 2a 61 72 67 76 29  gc, char **argv)
1680: 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  {.  const char *
1690: 7a 46 69 6c 65 54 6f 52 65 61 64 20 3d 20 30 3b  zFileToRead = 0;
16a0: 20 20 2f 2a 20 49 6e 70 75 74 20 66 69 6c 65 2e    /* Input file.
16b0: 20 20 4e 55 4c 4c 20 66 6f 72 20 73 74 64 69 6e    NULL for stdin
16c0: 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72   */.  const char
16d0: 20 2a 7a 44 62 4e 61 6d 65 20 3d 20 30 3b 20 20   *zDbName = 0;  
16e0: 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 74      /* Name of t
16f0: 68 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65  he database file
1700: 20 74 6f 20 63 72 65 61 74 65 20 2a 2f 0a 20 20   to create */.  
1710: 69 6e 74 20 75 73 65 57 69 74 68 6f 75 74 52 6f  int useWithoutRo
1720: 77 69 64 20 3d 20 30 3b 20 20 20 20 20 20 2f 2a  wid = 0;      /*
1730: 20 54 72 75 65 20 66 6f 72 20 2d 2d 77 69 74 68   True for --with
1740: 6f 75 74 2d 72 6f 77 69 64 20 2a 2f 0a 20 20 69  out-rowid */.  i
1750: 6e 74 20 69 4d 6f 64 65 20 3d 20 4d 4f 44 45 5f  nt iMode = MODE_
1760: 49 4e 53 45 52 54 3b 20 20 20 20 20 20 2f 2a 20  INSERT;      /* 
1770: 4f 6e 65 20 6f 66 20 4d 4f 44 45 5f 78 78 78 78  One of MODE_xxxx
1780: 78 20 2a 2f 0a 20 20 69 6e 74 20 75 73 65 4e 6f  x */.  int useNo
1790: 63 61 73 65 20 3d 20 30 3b 20 20 20 20 20 20 20  case = 0;       
17a0: 20 20 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72       /* True for
17b0: 20 2d 2d 6e 6f 63 61 73 65 20 2a 2f 0a 20 20 69   --nocase */.  i
17c0: 6e 74 20 64 6f 54 72 61 63 65 20 3d 20 30 3b 20  nt doTrace = 0; 
17d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
17e0: 54 72 75 65 20 66 6f 72 20 2d 2d 74 72 61 63 65  True for --trace
17f0: 20 2a 2f 0a 20 20 69 6e 74 20 73 68 6f 77 53 74   */.  int showSt
1800: 61 74 73 20 3d 20 30 3b 20 20 20 20 20 20 20 20  ats = 0;        
1810: 20 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20      /* True for 
1820: 2d 2d 73 74 61 74 73 20 2a 2f 0a 20 20 69 6e 74  --stats */.  int
1830: 20 73 68 6f 77 53 75 6d 6d 61 72 79 20 3d 20 30   showSummary = 0
1840: 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72  ;          /* Tr
1850: 75 65 20 66 6f 72 20 2d 2d 73 75 6d 6d 61 72 79  ue for --summary
1860: 20 2a 2f 0a 20 20 69 6e 74 20 73 68 6f 77 54 69   */.  int showTi
1870: 6d 65 72 20 3d 20 30 3b 20 20 20 20 20 20 20 20  mer = 0;        
1880: 20 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20      /* True for 
1890: 2d 2d 74 69 6d 65 72 20 2a 2f 0a 20 20 69 6e 74  --timer */.  int
18a0: 20 63 61 63 68 65 53 69 7a 65 20 3d 20 30 3b 20   cacheSize = 0; 
18b0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 65             /* De
18c0: 73 69 72 65 64 20 63 61 63 68 65 20 73 69 7a 65  sired cache size
18d0: 2e 20 20 30 20 6d 65 61 6e 73 20 64 65 66 61 75  .  0 means defau
18e0: 6c 74 20 2a 2f 0a 20 20 69 6e 74 20 70 61 67 65  lt */.  int page
18f0: 53 69 7a 65 20 3d 20 30 3b 20 20 20 20 20 20 20  Size = 0;       
1900: 20 20 20 20 20 20 2f 2a 20 44 65 73 69 72 65 64        /* Desired
1910: 20 70 61 67 65 20 73 69 7a 65 2e 20 20 30 20 6d   page size.  0 m
1920: 65 61 6e 73 20 64 65 66 61 75 6c 74 20 2a 2f 0a  eans default */.
1930: 20 20 69 6e 74 20 63 6f 6d 6d 69 74 49 6e 74 65    int commitInte
1940: 72 76 61 6c 20 3d 20 30 3b 20 20 20 20 20 20 20  rval = 0;       
1950: 2f 2a 20 48 6f 77 20 6f 66 74 65 6e 20 74 6f 20  /* How often to 
1960: 63 6f 6d 6d 69 74 2e 20 20 30 20 6d 65 61 6e 73  commit.  0 means
1970: 20 6e 65 76 65 72 20 2a 2f 0a 20 20 69 6e 74 20   never */.  int 
1980: 6e 6f 53 79 6e 63 20 3d 20 30 3b 20 20 20 20 20  noSync = 0;     
1990: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75            /* Tru
19a0: 65 20 66 6f 72 20 2d 2d 6e 6f 73 79 6e 63 20 2a  e for --nosync *
19b0: 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  /.  const char *
19c0: 7a 4a 4d 6f 64 65 20 3d 20 30 3b 20 20 20 20 20  zJMode = 0;     
19d0: 20 20 2f 2a 20 4a 6f 75 72 6e 61 6c 20 6d 6f 64    /* Journal mod
19e0: 65 20 2a 2f 0a 20 20 69 6e 74 20 6e 4f 70 20 3d  e */.  int nOp =
19f0: 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 20   0;             
1a00: 20 20 20 20 20 2f 2a 20 4f 70 65 72 61 74 69 6f       /* Operatio
1a10: 6e 20 63 6f 75 6e 74 65 72 20 2a 2f 0a 20 20 69  n counter */.  i
1a20: 6e 74 20 69 2c 20 6a 3b 20 20 20 20 20 20 20 20  nt i, j;        
1a30: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1a40: 4c 6f 6f 70 20 63 6f 75 6e 74 65 72 73 20 2a 2f  Loop counters */
1a50: 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 3b 20  .  sqlite3 *db; 
1a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a70: 20 2f 2a 20 54 68 65 20 53 51 4c 69 74 65 20 64   /* The SQLite d
1a80: 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69  atabase connecti
1a90: 6f 6e 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 53  on */.  char *zS
1aa0: 71 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  ql;             
1ab0: 20 20 20 20 20 20 2f 2a 20 43 6f 6e 73 74 72 75        /* Constru
1ac0: 63 74 65 64 20 53 51 4c 20 73 74 61 74 65 6d 65  cted SQL stateme
1ad0: 6e 74 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f  nt */.  sqlite3_
1ae0: 73 74 6d 74 20 2a 70 49 6e 73 65 72 74 20 3d 20  stmt *pInsert = 
1af0: 30 3b 20 20 20 20 2f 2a 20 54 68 65 20 49 4e 53  0;    /* The INS
1b00: 45 52 54 20 73 74 61 74 65 6d 65 6e 74 20 2a 2f  ERT statement */
1b10: 0a 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20  .  sqlite3_stmt 
1b20: 2a 70 55 70 64 61 74 65 20 3d 20 30 3b 20 20 20  *pUpdate = 0;   
1b30: 20 2f 2a 20 54 68 65 20 55 50 44 41 54 45 20 73   /* The UPDATE s
1b40: 74 61 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 73 71  tatement */.  sq
1b50: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 65 6c  lite3_stmt *pSel
1b60: 65 63 74 20 3d 20 30 3b 20 20 20 20 2f 2a 20 54  ect = 0;    /* T
1b70: 68 65 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d  he SELECT statem
1b80: 65 6e 74 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  ent */.  sqlite3
1b90: 5f 73 74 6d 74 20 2a 70 44 65 6c 65 74 65 20 3d  _stmt *pDelete =
1ba0: 20 30 3b 20 20 20 20 2f 2a 20 54 68 65 20 44 45   0;    /* The DE
1bb0: 4c 45 54 45 20 73 74 61 74 65 6d 65 6e 74 20 2a  LETE statement *
1bc0: 2f 0a 20 20 46 49 4c 45 20 2a 69 6e 3b 20 20 20  /.  FILE *in;   
1bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1be0: 20 20 2f 2a 20 54 68 65 20 6f 70 65 6e 20 69 6e    /* The open in
1bf0: 70 75 74 20 66 69 6c 65 20 2a 2f 0a 20 20 69 6e  put file */.  in
1c00: 74 20 72 63 3b 20 20 20 20 20 20 20 20 20 20 20  t rc;           
1c10: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 52              /* R
1c20: 65 74 75 72 6e 20 63 6f 64 65 20 66 72 6f 6d 20  eturn code from 
1c30: 61 6e 20 53 51 4c 69 74 65 20 69 6e 74 65 72 66  an SQLite interf
1c40: 61 63 65 20 2a 2f 0a 20 20 69 6e 74 20 69 43 75  ace */.  int iCu
1c50: 72 2c 20 69 48 69 77 74 72 3b 20 20 20 20 20 20  r, iHiwtr;      
1c60: 20 20 20 20 20 20 20 2f 2a 20 53 74 61 74 69 73         /* Statis
1c70: 74 69 63 73 20 76 61 6c 75 65 73 2c 20 63 75 72  tics values, cur
1c80: 72 65 6e 74 20 61 6e 64 20 22 68 69 67 68 77 61  rent and "highwa
1c90: 74 65 72 22 20 2a 2f 0a 20 20 73 71 6c 69 74 65  ter" */.  sqlite
1ca0: 33 5f 69 6e 74 36 34 20 73 75 6d 43 6e 74 20 3d  3_int64 sumCnt =
1cb0: 20 30 3b 20 20 20 20 20 2f 2a 20 53 75 6d 20 69   0;     /* Sum i
1cc0: 6e 20 51 55 45 52 59 20 6d 6f 64 65 20 2a 2f 0a  n QUERY mode */.
1cd0: 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20    sqlite3_int64 
1ce0: 73 74 61 72 74 54 69 6d 65 3b 0a 20 20 63 68 61  startTime;.  cha
1cf0: 72 20 7a 49 6e 70 75 74 5b 32 30 30 30 5d 3b 20  r zInput[2000]; 
1d00: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 20             /* A 
1d10: 73 69 6e 67 6c 65 20 6c 69 6e 65 20 6f 66 20 69  single line of i
1d20: 6e 70 75 74 20 2a 2f 0a 0a 20 20 2f 2a 20 50 72  nput */..  /* Pr
1d30: 6f 63 65 73 73 20 63 6f 6d 6d 61 6e 64 2d 6c 69  ocess command-li
1d40: 6e 65 20 61 72 67 75 6d 65 6e 74 73 20 2a 2f 0a  ne arguments */.
1d50: 20 20 66 6f 72 28 69 3d 31 3b 20 69 3c 61 72 67    for(i=1; i<arg
1d60: 63 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 63 6f 6e  c; i++){.    con
1d70: 73 74 20 63 68 61 72 20 2a 7a 20 3d 20 61 72 67  st char *z = arg
1d80: 76 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20 7a 5b  v[i];.    if( z[
1d90: 30 5d 3d 3d 27 2d 27 20 29 7b 0a 20 20 20 20 20  0]=='-' ){.     
1da0: 20 64 6f 7b 20 7a 2b 2b 3b 20 7d 77 68 69 6c 65   do{ z++; }while
1db0: 28 20 7a 5b 30 5d 3d 3d 27 2d 27 20 29 3b 0a 20  ( z[0]=='-' );. 
1dc0: 20 20 20 20 20 69 66 28 20 73 74 72 63 6d 70 28       if( strcmp(
1dd0: 7a 2c 22 77 69 74 68 6f 75 74 2d 72 6f 77 69 64  z,"without-rowid
1de0: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ")==0 ){.       
1df0: 20 75 73 65 57 69 74 68 6f 75 74 52 6f 77 69 64   useWithoutRowid
1e00: 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73   = 1;.      }els
1e10: 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22  e if( strcmp(z,"
1e20: 72 65 70 6c 61 63 65 22 29 3d 3d 30 20 29 7b 0a  replace")==0 ){.
1e30: 20 20 20 20 20 20 20 20 69 4d 6f 64 65 20 3d 20          iMode = 
1e40: 4d 4f 44 45 5f 52 45 50 4c 41 43 45 3b 0a 20 20  MODE_REPLACE;.  
1e50: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74      }else if( st
1e60: 72 63 6d 70 28 7a 2c 22 73 65 6c 65 63 74 22 29  rcmp(z,"select")
1e70: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 69  ==0 ){.        i
1e80: 4d 6f 64 65 20 3d 20 4d 4f 44 45 5f 53 45 4c 45  Mode = MODE_SELE
1e90: 43 54 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20  CT;.      }else 
1ea0: 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 69 6e  if( strcmp(z,"in
1eb0: 73 65 72 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20  sert")==0 ){.   
1ec0: 20 20 20 20 20 69 4d 6f 64 65 20 3d 20 4d 4f 44       iMode = MOD
1ed0: 45 5f 49 4e 53 45 52 54 3b 0a 20 20 20 20 20 20  E_INSERT;.      
1ee0: 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70  }else if( strcmp
1ef0: 28 7a 2c 22 75 70 64 61 74 65 22 29 3d 3d 30 20  (z,"update")==0 
1f00: 29 7b 0a 20 20 20 20 20 20 20 20 69 4d 6f 64 65  ){.        iMode
1f10: 20 3d 20 4d 4f 44 45 5f 55 50 44 41 54 45 3b 0a   = MODE_UPDATE;.
1f20: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
1f30: 73 74 72 63 6d 70 28 7a 2c 22 64 65 6c 65 74 65  strcmp(z,"delete
1f40: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ")==0 ){.       
1f50: 20 69 4d 6f 64 65 20 3d 20 4d 4f 44 45 5f 44 45   iMode = MODE_DE
1f60: 4c 45 54 45 3b 0a 20 20 20 20 20 20 7d 65 6c 73  LETE;.      }els
1f70: 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22  e if( strcmp(z,"
1f80: 71 75 65 72 79 22 29 3d 3d 30 20 29 7b 0a 20 20  query")==0 ){.  
1f90: 20 20 20 20 20 20 69 4d 6f 64 65 20 3d 20 4d 4f        iMode = MO
1fa0: 44 45 5f 51 55 45 52 59 3b 0a 20 20 20 20 20 20  DE_QUERY;.      
1fb0: 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70  }else if( strcmp
1fc0: 28 7a 2c 22 6e 6f 63 61 73 65 22 29 3d 3d 30 20  (z,"nocase")==0 
1fd0: 29 7b 0a 20 20 20 20 20 20 20 20 75 73 65 4e 6f  ){.        useNo
1fe0: 63 61 73 65 20 3d 20 31 3b 0a 20 20 20 20 20 20  case = 1;.      
1ff0: 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70  }else if( strcmp
2000: 28 7a 2c 22 74 72 61 63 65 22 29 3d 3d 30 20 29  (z,"trace")==0 )
2010: 7b 0a 20 20 20 20 20 20 20 20 64 6f 54 72 61 63  {.        doTrac
2020: 65 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 65 6c  e = 1;.      }el
2030: 73 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c  se if( strcmp(z,
2040: 22 6e 6f 73 79 6e 63 22 29 3d 3d 30 20 29 7b 0a  "nosync")==0 ){.
2050: 20 20 20 20 20 20 20 20 6e 6f 53 79 6e 63 20 3d          noSync =
2060: 20 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20   1;.      }else 
2070: 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 73 74  if( strcmp(z,"st
2080: 61 74 73 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ats")==0 ){.    
2090: 20 20 20 20 73 68 6f 77 53 74 61 74 73 20 3d 20      showStats = 
20a0: 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  1;.      }else i
20b0: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 73 75 6d  f( strcmp(z,"sum
20c0: 6d 61 72 79 22 29 3d 3d 30 20 29 7b 0a 20 20 20  mary")==0 ){.   
20d0: 20 20 20 20 20 73 68 6f 77 53 75 6d 6d 61 72 79       showSummary
20e0: 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73   = 1;.      }els
20f0: 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22  e if( strcmp(z,"
2100: 74 69 6d 65 72 22 29 3d 3d 30 20 29 7b 0a 20 20  timer")==0 ){.  
2110: 20 20 20 20 20 20 73 68 6f 77 54 69 6d 65 72 20        showTimer 
2120: 3d 20 69 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  = i;.      }else
2130: 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 63   if( strcmp(z,"c
2140: 61 63 68 65 73 69 7a 65 22 29 3d 3d 30 20 26 26  achesize")==0 &&
2150: 20 69 3c 61 72 67 63 2d 31 20 29 7b 0a 20 20 20   i<argc-1 ){.   
2160: 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20 20 20 20       i++;.      
2170: 20 20 63 61 63 68 65 53 69 7a 65 20 3d 20 61 74    cacheSize = at
2180: 6f 69 28 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20  oi(argv[i]);.   
2190: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72     }else if( str
21a0: 63 6d 70 28 7a 2c 22 70 61 67 65 73 69 7a 65 22  cmp(z,"pagesize"
21b0: 29 3d 3d 30 20 26 26 20 69 3c 61 72 67 63 2d 31  )==0 && i<argc-1
21c0: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 2b 2b 3b   ){.        i++;
21d0: 0a 20 20 20 20 20 20 20 20 70 61 67 65 53 69 7a  .        pageSiz
21e0: 65 20 3d 20 61 74 6f 69 28 61 72 67 76 5b 69 5d  e = atoi(argv[i]
21f0: 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  );.      }else i
2200: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 63 6f 6d  f( strcmp(z,"com
2210: 6d 69 74 22 29 3d 3d 30 20 26 26 20 69 3c 61 72  mit")==0 && i<ar
2220: 67 63 2d 31 20 29 7b 0a 20 20 20 20 20 20 20 20  gc-1 ){.        
2230: 69 2b 2b 3b 0a 20 20 20 20 20 20 20 20 63 6f 6d  i++;.        com
2240: 6d 69 74 49 6e 74 65 72 76 61 6c 20 3d 20 61 74  mitInterval = at
2250: 6f 69 28 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20  oi(argv[i]);.   
2260: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72     }else if( str
2270: 63 6d 70 28 7a 2c 22 6a 6f 75 72 6e 61 6c 22 29  cmp(z,"journal")
2280: 3d 3d 30 20 26 26 20 69 3c 61 72 67 63 2d 31 20  ==0 && i<argc-1 
2290: 29 7b 0a 20 20 20 20 20 20 20 20 7a 4a 4d 6f 64  ){.        zJMod
22a0: 65 20 3d 20 61 72 67 76 5b 2b 2b 69 5d 3b 0a 20  e = argv[++i];. 
22b0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
22c0: 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72 28      fatal_error(
22d0: 22 75 6e 6b 6e 6f 77 6e 20 6f 70 74 69 6f 6e 3a  "unknown option:
22e0: 20 25 73 5c 6e 22 2c 20 61 72 67 76 5b 69 5d 29   %s\n", argv[i])
22f0: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 65  ;.      }.    }e
2300: 6c 73 65 20 69 66 28 20 7a 44 62 4e 61 6d 65 3d  lse if( zDbName=
2310: 3d 30 20 29 7b 0a 20 20 20 20 20 20 7a 44 62 4e  =0 ){.      zDbN
2320: 61 6d 65 20 3d 20 61 72 67 76 5b 69 5d 3b 0a 20  ame = argv[i];. 
2330: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 7a 46 69     }else if( zFi
2340: 6c 65 54 6f 52 65 61 64 3d 3d 30 20 29 7b 0a 20  leToRead==0 ){. 
2350: 20 20 20 20 20 7a 46 69 6c 65 54 6f 52 65 61 64       zFileToRead
2360: 20 3d 20 61 72 67 76 5b 69 5d 3b 0a 20 20 20 20   = argv[i];.    
2370: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 66 61 74  }else{.      fat
2380: 61 6c 5f 65 72 72 6f 72 28 22 73 75 72 70 6c 75  al_error("surplu
2390: 73 20 61 72 67 75 6d 65 6e 74 3a 20 25 73 5c 6e  s argument: %s\n
23a0: 22 2c 20 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20  ", argv[i]);.   
23b0: 20 7d 0a 20 20 7d 0a 20 20 69 66 28 20 7a 44 62   }.  }.  if( zDb
23c0: 4e 61 6d 65 3d 3d 30 20 29 7b 0a 20 20 20 20 66  Name==0 ){.    f
23d0: 61 74 61 6c 5f 65 72 72 6f 72 28 22 55 73 61 67  atal_error("Usag
23e0: 65 3a 20 25 73 20 5b 2d 2d 6f 70 74 69 6f 6e 73  e: %s [--options
23f0: 5d 20 44 41 54 41 42 41 53 45 20 5b 49 4e 50 55  ] DATABASE [INPU
2400: 54 46 49 4c 45 5d 5c 6e 22 2c 20 61 72 67 76 5b  TFILE]\n", argv[
2410: 30 5d 29 3b 0a 20 20 7d 0a 20 20 73 74 61 72 74  0]);.  }.  start
2420: 54 69 6d 65 20 3d 20 72 65 61 6c 54 69 6d 65 28  Time = realTime(
2430: 29 3b 0a 0a 20 20 2f 2a 20 4f 70 65 6e 20 74 68  );..  /* Open th
2440: 65 20 64 61 74 61 62 61 73 65 20 61 6e 64 20 74  e database and t
2450: 68 65 20 69 6e 70 75 74 20 66 69 6c 65 20 2a 2f  he input file */
2460: 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f 6f  .  if( sqlite3_o
2470: 70 65 6e 28 7a 44 62 4e 61 6d 65 2c 20 26 64 62  pen(zDbName, &db
2480: 29 20 29 7b 0a 20 20 20 20 66 61 74 61 6c 5f 65  ) ){.    fatal_e
2490: 72 72 6f 72 28 22 43 61 6e 6e 6f 74 20 6f 70 65  rror("Cannot ope
24a0: 6e 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 3a  n database file:
24b0: 20 25 73 5c 6e 22 2c 20 7a 44 62 4e 61 6d 65 29   %s\n", zDbName)
24c0: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 7a 46 69 6c  ;.  }.  if( zFil
24d0: 65 54 6f 52 65 61 64 20 29 7b 0a 20 20 20 20 69  eToRead ){.    i
24e0: 6e 20 3d 20 66 6f 70 65 6e 28 7a 46 69 6c 65 54  n = fopen(zFileT
24f0: 6f 52 65 61 64 2c 20 22 72 62 22 29 3b 0a 20 20  oRead, "rb");.  
2500: 20 20 69 66 28 20 69 6e 3d 3d 30 20 29 7b 0a 20    if( in==0 ){. 
2510: 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72       fatal_error
2520: 28 22 43 6f 75 6c 64 20 6e 6f 74 20 6f 70 65 6e  ("Could not open
2530: 20 69 6e 70 75 74 20 66 69 6c 65 20 5c 22 25 73   input file \"%s
2540: 5c 22 5c 6e 22 2c 20 7a 46 69 6c 65 54 6f 52 65  \"\n", zFileToRe
2550: 61 64 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c  ad);.    }.  }el
2560: 73 65 7b 0a 20 20 20 20 69 6e 20 3d 20 73 74 64  se{.    in = std
2570: 69 6e 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 53 65  in;.  }..  /* Se
2580: 74 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65  t database conne
2590: 63 74 69 6f 6e 20 6f 70 74 69 6f 6e 73 20 2a 2f  ction options */
25a0: 0a 20 20 69 66 28 20 64 6f 54 72 61 63 65 20 29  .  if( doTrace )
25b0: 20 73 71 6c 69 74 65 33 5f 74 72 61 63 65 28 64   sqlite3_trace(d
25c0: 62 2c 20 74 72 61 63 65 43 61 6c 6c 62 61 63 6b  b, traceCallback
25d0: 2c 20 30 29 3b 0a 20 20 69 66 28 20 70 61 67 65  , 0);.  if( page
25e0: 53 69 7a 65 20 29 7b 0a 20 20 20 20 7a 53 71 6c  Size ){.    zSql
25f0: 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e   = sqlite3_mprin
2600: 74 66 28 22 50 52 41 47 4d 41 20 70 61 67 65 5f  tf("PRAGMA page_
2610: 73 69 7a 65 3d 25 64 22 2c 20 70 61 67 65 53 69  size=%d", pageSi
2620: 7a 65 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  ze);.    sqlite3
2630: 5f 65 78 65 63 28 64 62 2c 20 7a 53 71 6c 2c 20  _exec(db, zSql, 
2640: 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 73 71  0, 0, 0);.    sq
2650: 6c 69 74 65 33 5f 66 72 65 65 28 7a 53 71 6c 29  lite3_free(zSql)
2660: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 63 61 63 68  ;.  }.  if( cach
2670: 65 53 69 7a 65 20 29 7b 0a 20 20 20 20 7a 53 71  eSize ){.    zSq
2680: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69  l = sqlite3_mpri
2690: 6e 74 66 28 22 50 52 41 47 4d 41 20 63 61 63 68  ntf("PRAGMA cach
26a0: 65 5f 73 69 7a 65 3d 25 64 22 2c 20 63 61 63 68  e_size=%d", cach
26b0: 65 53 69 7a 65 29 3b 0a 20 20 20 20 73 71 6c 69  eSize);.    sqli
26c0: 74 65 33 5f 65 78 65 63 28 64 62 2c 20 7a 53 71  te3_exec(db, zSq
26d0: 6c 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20  l, 0, 0, 0);.   
26e0: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a 53   sqlite3_free(zS
26f0: 71 6c 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 6e  ql);.  }.  if( n
2700: 6f 53 79 6e 63 20 29 20 73 71 6c 69 74 65 33 5f  oSync ) sqlite3_
2710: 65 78 65 63 28 64 62 2c 20 22 50 52 41 47 4d 41  exec(db, "PRAGMA
2720: 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f 46 46   synchronous=OFF
2730: 22 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 69  ", 0, 0, 0);.  i
2740: 66 28 20 7a 4a 4d 6f 64 65 20 29 7b 0a 20 20 20  f( zJMode ){.   
2750: 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33 5f   zSql = sqlite3_
2760: 6d 70 72 69 6e 74 66 28 22 50 52 41 47 4d 41 20  mprintf("PRAGMA 
2770: 6a 6f 75 72 6e 61 6c 5f 6d 6f 64 65 3d 25 73 22  journal_mode=%s"
2780: 2c 20 7a 4a 4d 6f 64 65 29 3b 0a 20 20 20 20 73  , zJMode);.    s
2790: 71 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20  qlite3_exec(db, 
27a0: 7a 53 71 6c 2c 20 30 2c 20 30 2c 20 30 29 3b 0a  zSql, 0, 0, 0);.
27b0: 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65      sqlite3_free
27c0: 28 7a 53 71 6c 29 3b 0a 20 20 7d 0a 0a 0a 20 20  (zSql);.  }...  
27d0: 2f 2a 20 43 6f 6e 73 74 72 75 63 74 20 74 68 65  /* Construct the
27e0: 20 22 77 6f 72 64 63 6f 75 6e 74 22 20 74 61 62   "wordcount" tab
27f0: 6c 65 20 69 6e 74 6f 20 77 68 69 63 68 20 74 6f  le into which to
2800: 20 70 75 74 20 74 68 65 20 77 6f 72 64 73 20 2a   put the words *
2810: 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f  /.  if( sqlite3_
2820: 65 78 65 63 28 64 62 2c 20 22 42 45 47 49 4e 20  exec(db, "BEGIN 
2830: 49 4d 4d 45 44 49 41 54 45 22 2c 20 30 2c 20 30  IMMEDIATE", 0, 0
2840: 2c 20 30 29 20 29 7b 0a 20 20 20 20 66 61 74 61  , 0) ){.    fata
2850: 6c 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e  l_error("Could n
2860: 6f 74 20 73 74 61 72 74 20 61 20 74 72 61 6e 73  ot start a trans
2870: 61 63 74 69 6f 6e 5c 6e 22 29 3b 0a 20 20 7d 0a  action\n");.  }.
2880: 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33    zSql = sqlite3
2890: 5f 6d 70 72 69 6e 74 66 28 0a 20 20 20 20 20 22  _mprintf(.     "
28a0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 49 46 20  CREATE TABLE IF 
28b0: 4e 4f 54 20 45 58 49 53 54 53 20 77 6f 72 64 63  NOT EXISTS wordc
28c0: 6f 75 6e 74 28 5c 6e 22 0a 20 20 20 20 20 22 20  ount(\n".     " 
28d0: 20 77 6f 72 64 20 54 45 58 54 20 50 52 49 4d 41   word TEXT PRIMA
28e0: 52 59 20 4b 45 59 20 43 4f 4c 4c 41 54 45 20 25  RY KEY COLLATE %
28f0: 73 2c 5c 6e 22 0a 20 20 20 20 20 22 20 20 63 6e  s,\n".     "  cn
2900: 74 20 49 4e 54 45 47 45 52 5c 6e 22 0a 20 20 20  t INTEGER\n".   
2910: 20 20 22 29 25 73 22 2c 0a 20 20 20 20 20 75 73    ")%s",.     us
2920: 65 4e 6f 63 61 73 65 20 3f 20 22 6e 6f 63 61 73  eNocase ? "nocas
2930: 65 22 20 3a 20 22 62 69 6e 61 72 79 22 2c 0a 20  e" : "binary",. 
2940: 20 20 20 20 75 73 65 57 69 74 68 6f 75 74 52 6f      useWithoutRo
2950: 77 69 64 20 3f 20 22 20 57 49 54 48 4f 55 54 20  wid ? " WITHOUT 
2960: 52 4f 57 49 44 22 20 3a 20 22 22 0a 20 20 29 3b  ROWID" : "".  );
2970: 0a 20 20 69 66 28 20 7a 53 71 6c 3d 3d 30 20 29  .  if( zSql==0 )
2980: 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 6f 75   fatal_error("ou
2990: 74 20 6f 66 20 6d 65 6d 6f 72 79 5c 6e 22 29 3b  t of memory\n");
29a0: 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f  .  rc = sqlite3_
29b0: 65 78 65 63 28 64 62 2c 20 7a 53 71 6c 2c 20 30  exec(db, zSql, 0
29c0: 2c 20 30 2c 20 30 29 3b 0a 20 20 69 66 28 20 72  , 0, 0);.  if( r
29d0: 63 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28  c ) fatal_error(
29e0: 22 43 6f 75 6c 64 20 6e 6f 74 20 63 72 65 61 74  "Could not creat
29f0: 65 20 74 68 65 20 77 6f 72 64 63 6f 75 6e 74 20  e the wordcount 
2a00: 74 61 62 6c 65 3a 20 25 73 2e 5c 6e 22 2c 0a 20  table: %s.\n",. 
2a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2a20: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65 72        sqlite3_er
2a30: 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 73 71 6c  rmsg(db));.  sql
2a40: 69 74 65 33 5f 66 72 65 65 28 7a 53 71 6c 29 3b  ite3_free(zSql);
2a50: 0a 0a 20 20 2f 2a 20 50 72 65 70 61 72 65 20 53  ..  /* Prepare S
2a60: 51 4c 20 73 74 61 74 65 6d 65 6e 74 73 20 74 68  QL statements th
2a70: 61 74 20 77 69 6c 6c 20 62 65 20 6e 65 65 64 65  at will be neede
2a80: 64 20 2a 2f 0a 20 20 69 66 28 20 69 4d 6f 64 65  d */.  if( iMode
2a90: 3d 3d 4d 4f 44 45 5f 51 55 45 52 59 20 29 7b 0a  ==MODE_QUERY ){.
2aa0: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
2ab0: 5f 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 0a  _prepare_v2(db,.
2ac0: 20 20 20 20 20 20 20 20 20 20 22 53 45 4c 45 43            "SELEC
2ad0: 54 20 63 6e 74 20 46 52 4f 4d 20 77 6f 72 64 63  T cnt FROM wordc
2ae0: 6f 75 6e 74 20 57 48 45 52 45 20 77 6f 72 64 3d  ount WHERE word=
2af0: 3f 31 22 2c 0a 20 20 20 20 20 20 20 20 20 20 2d  ?1",.          -
2b00: 31 2c 20 26 70 53 65 6c 65 63 74 2c 20 30 29 3b  1, &pSelect, 0);
2b10: 0a 20 20 20 20 69 66 28 20 72 63 20 29 20 66 61  .    if( rc ) fa
2b20: 74 61 6c 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64  tal_error("Could
2b30: 20 6e 6f 74 20 70 72 65 70 61 72 65 20 74 68 65   not prepare the
2b40: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
2b50: 74 3a 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20  t: %s\n",.      
2b60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b70: 20 20 20 20 73 71 6c 69 74 65 33 5f 65 72 72 6d      sqlite3_errm
2b80: 73 67 28 64 62 29 29 3b 0a 20 20 7d 0a 20 20 69  sg(db));.  }.  i
2b90: 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 53  f( iMode==MODE_S
2ba0: 45 4c 45 43 54 20 29 7b 0a 20 20 20 20 72 63 20  ELECT ){.    rc 
2bb0: 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  = sqlite3_prepar
2bc0: 65 5f 76 32 28 64 62 2c 0a 20 20 20 20 20 20 20  e_v2(db,.       
2bd0: 20 20 20 22 53 45 4c 45 43 54 20 31 20 46 52 4f     "SELECT 1 FRO
2be0: 4d 20 77 6f 72 64 63 6f 75 6e 74 20 57 48 45 52  M wordcount WHER
2bf0: 45 20 77 6f 72 64 3d 3f 31 22 2c 0a 20 20 20 20  E word=?1",.    
2c00: 20 20 20 20 20 20 2d 31 2c 20 26 70 53 65 6c 65        -1, &pSele
2c10: 63 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20  ct, 0);.    if( 
2c20: 72 63 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72  rc ) fatal_error
2c30: 28 22 43 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70  ("Could not prep
2c40: 61 72 65 20 74 68 65 20 53 45 4c 45 43 54 20 73  are the SELECT s
2c50: 74 61 74 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c  tatement: %s\n",
2c60: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2c70: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
2c80: 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a  e3_errmsg(db));.
2c90: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
2ca0: 5f 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 0a  _prepare_v2(db,.
2cb0: 20 20 20 20 20 20 20 20 20 20 22 49 4e 53 45 52            "INSER
2cc0: 54 20 49 4e 54 4f 20 77 6f 72 64 63 6f 75 6e 74  T INTO wordcount
2cd0: 28 77 6f 72 64 2c 63 6e 74 29 20 56 41 4c 55 45  (word,cnt) VALUE
2ce0: 53 28 3f 31 2c 31 29 22 2c 0a 20 20 20 20 20 20  S(?1,1)",.      
2cf0: 20 20 20 20 2d 31 2c 20 26 70 49 6e 73 65 72 74      -1, &pInsert
2d00: 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72 63  , 0);.    if( rc
2d10: 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22   ) fatal_error("
2d20: 43 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70 61 72  Could not prepar
2d30: 65 20 74 68 65 20 49 4e 53 45 52 54 20 73 74 61  e the INSERT sta
2d40: 74 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20  tement: %s\n",. 
2d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2d60: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
2d70: 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d  errmsg(db));.  }
2d80: 0a 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f  .  if( iMode==MO
2d90: 44 45 5f 53 45 4c 45 43 54 20 7c 7c 20 69 4d 6f  DE_SELECT || iMo
2da0: 64 65 3d 3d 4d 4f 44 45 5f 55 50 44 41 54 45 20  de==MODE_UPDATE 
2db0: 7c 7c 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 49  || iMode==MODE_I
2dc0: 4e 53 45 52 54 20 29 7b 0a 20 20 20 20 72 63 20  NSERT ){.    rc 
2dd0: 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  = sqlite3_prepar
2de0: 65 5f 76 32 28 64 62 2c 0a 20 20 20 20 20 20 20  e_v2(db,.       
2df0: 20 20 20 22 55 50 44 41 54 45 20 77 6f 72 64 63     "UPDATE wordc
2e00: 6f 75 6e 74 20 53 45 54 20 63 6e 74 3d 63 6e 74  ount SET cnt=cnt
2e10: 2b 31 20 57 48 45 52 45 20 77 6f 72 64 3d 3f 31  +1 WHERE word=?1
2e20: 22 2c 0a 20 20 20 20 20 20 20 20 20 20 2d 31 2c  ",.          -1,
2e30: 20 26 70 55 70 64 61 74 65 2c 20 30 29 3b 0a 20   &pUpdate, 0);. 
2e40: 20 20 20 69 66 28 20 72 63 20 29 20 66 61 74 61     if( rc ) fata
2e50: 6c 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e  l_error("Could n
2e60: 6f 74 20 70 72 65 70 61 72 65 20 74 68 65 20 55  ot prepare the U
2e70: 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 3a  PDATE statement:
2e80: 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20   %s\n",.        
2e90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ea0: 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28   sqlite3_errmsg(
2eb0: 64 62 29 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20  db));.  }.  if( 
2ec0: 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 49 4e 53 45  iMode==MODE_INSE
2ed0: 52 54 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73  RT ){.    rc = s
2ee0: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
2ef0: 32 28 64 62 2c 0a 20 20 20 20 20 20 20 20 20 20  2(db,.          
2f00: 22 49 4e 53 45 52 54 20 4f 52 20 49 47 4e 4f 52  "INSERT OR IGNOR
2f10: 45 20 49 4e 54 4f 20 77 6f 72 64 63 6f 75 6e 74  E INTO wordcount
2f20: 28 77 6f 72 64 2c 63 6e 74 29 20 56 41 4c 55 45  (word,cnt) VALUE
2f30: 53 28 3f 31 2c 31 29 22 2c 0a 20 20 20 20 20 20  S(?1,1)",.      
2f40: 20 20 20 20 2d 31 2c 20 26 70 49 6e 73 65 72 74      -1, &pInsert
2f50: 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72 63  , 0);.    if( rc
2f60: 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22   ) fatal_error("
2f70: 43 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70 61 72  Could not prepar
2f80: 65 20 74 68 65 20 49 4e 53 45 52 54 20 73 74 61  e the INSERT sta
2f90: 74 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20  tement: %s\n",. 
2fa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2fb0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
2fc0: 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d  errmsg(db));.  }
2fd0: 0a 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f  .  if( iMode==MO
2fe0: 44 45 5f 55 50 44 41 54 45 20 29 7b 0a 20 20 20  DE_UPDATE ){.   
2ff0: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70 72   rc = sqlite3_pr
3000: 65 70 61 72 65 5f 76 32 28 64 62 2c 0a 20 20 20  epare_v2(db,.   
3010: 20 20 20 20 20 20 20 22 49 4e 53 45 52 54 20 4f         "INSERT O
3020: 52 20 49 47 4e 4f 52 45 20 49 4e 54 4f 20 77 6f  R IGNORE INTO wo
3030: 72 64 63 6f 75 6e 74 28 77 6f 72 64 2c 63 6e 74  rdcount(word,cnt
3040: 29 20 56 41 4c 55 45 53 28 3f 31 2c 30 29 22 2c  ) VALUES(?1,0)",
3050: 0a 20 20 20 20 20 20 20 20 20 20 2d 31 2c 20 26  .          -1, &
3060: 70 49 6e 73 65 72 74 2c 20 30 29 3b 0a 20 20 20  pInsert, 0);.   
3070: 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c 5f   if( rc ) fatal_
3080: 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f 74  error("Could not
3090: 20 70 72 65 70 61 72 65 20 74 68 65 20 49 4e 53   prepare the INS
30a0: 45 52 54 20 73 74 61 74 65 6d 65 6e 74 3a 20 25  ERT statement: %
30b0: 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20  s\n",.          
30c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73                 s
30d0: 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62  qlite3_errmsg(db
30e0: 29 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 69 4d  ));.  }.  if( iM
30f0: 6f 64 65 3d 3d 4d 4f 44 45 5f 52 45 50 4c 41 43  ode==MODE_REPLAC
3100: 45 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73 71  E ){.    rc = sq
3110: 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32  lite3_prepare_v2
3120: 28 64 62 2c 0a 20 20 20 20 20 20 20 20 20 20 22  (db,.          "
3130: 52 45 50 4c 41 43 45 20 49 4e 54 4f 20 77 6f 72  REPLACE INTO wor
3140: 64 63 6f 75 6e 74 28 77 6f 72 64 2c 63 6e 74 29  dcount(word,cnt)
3150: 22 0a 20 20 20 20 20 20 20 20 20 20 22 56 41 4c  ".          "VAL
3160: 55 45 53 28 3f 31 2c 63 6f 61 6c 65 73 63 65 28  UES(?1,coalesce(
3170: 28 53 45 4c 45 43 54 20 63 6e 74 20 46 52 4f 4d  (SELECT cnt FROM
3180: 20 77 6f 72 64 63 6f 75 6e 74 20 57 48 45 52 45   wordcount WHERE
3190: 20 77 6f 72 64 3d 3f 31 29 2c 30 29 2b 31 29 22   word=?1),0)+1)"
31a0: 2c 0a 20 20 20 20 20 20 20 20 20 20 2d 31 2c 20  ,.          -1, 
31b0: 26 70 49 6e 73 65 72 74 2c 20 30 29 3b 0a 20 20  &pInsert, 0);.  
31c0: 20 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c    if( rc ) fatal
31d0: 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f  _error("Could no
31e0: 74 20 70 72 65 70 61 72 65 20 74 68 65 20 52 45  t prepare the RE
31f0: 50 4c 41 43 45 20 73 74 61 74 65 6d 65 6e 74 3a  PLACE statement:
3200: 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20   %s\n",.        
3210: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3220: 20 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67    sqlite3_errmsg
3230: 28 64 62 29 29 3b 0a 20 20 7d 0a 20 20 69 66 28  (db));.  }.  if(
3240: 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 44 45 4c   iMode==MODE_DEL
3250: 45 54 45 20 29 7b 0a 20 20 20 20 72 63 20 3d 20  ETE ){.    rc = 
3260: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
3270: 76 32 28 64 62 2c 0a 20 20 20 20 20 20 20 20 20  v2(db,.         
3280: 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 77 6f   "DELETE FROM wo
3290: 72 64 63 6f 75 6e 74 20 57 48 45 52 45 20 77 6f  rdcount WHERE wo
32a0: 72 64 3d 3f 31 22 2c 0a 20 20 20 20 20 20 20 20  rd=?1",.        
32b0: 20 20 2d 31 2c 20 26 70 44 65 6c 65 74 65 2c 20    -1, &pDelete, 
32c0: 30 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29  0);.    if( rc )
32d0: 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 43 6f   fatal_error("Co
32e0: 75 6c 64 20 6e 6f 74 20 70 72 65 70 61 72 65 20  uld not prepare 
32f0: 74 68 65 20 44 45 4c 45 54 45 20 73 74 61 74 65  the DELETE state
3300: 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20 20 20  ment: %s\n",.   
3310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3320: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65 72        sqlite3_er
3330: 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d 0a 0a  rmsg(db));.  }..
3340: 20 20 2f 2a 20 50 72 6f 63 65 73 73 20 74 68 65    /* Process the
3350: 20 69 6e 70 75 74 20 66 69 6c 65 20 2a 2f 0a 20   input file */. 
3360: 20 77 68 69 6c 65 28 20 66 67 65 74 73 28 7a 49   while( fgets(zI
3370: 6e 70 75 74 2c 20 73 69 7a 65 6f 66 28 7a 49 6e  nput, sizeof(zIn
3380: 70 75 74 29 2c 20 69 6e 29 20 29 7b 0a 20 20 20  put), in) ){.   
3390: 20 66 6f 72 28 69 3d 30 3b 20 7a 49 6e 70 75 74   for(i=0; zInput
33a0: 5b 69 5d 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20  [i]; i++){.     
33b0: 20 69 66 28 20 21 69 73 61 6c 70 68 61 28 7a 49   if( !isalpha(zI
33c0: 6e 70 75 74 5b 69 5d 29 20 29 20 63 6f 6e 74 69  nput[i]) ) conti
33d0: 6e 75 65 3b 0a 20 20 20 20 20 20 66 6f 72 28 6a  nue;.      for(j
33e0: 3d 69 2b 31 3b 20 69 73 61 6c 70 68 61 28 7a 49  =i+1; isalpha(zI
33f0: 6e 70 75 74 5b 6a 5d 29 3b 20 6a 2b 2b 29 7b 7d  nput[j]); j++){}
3400: 0a 0a 20 20 20 20 20 20 2f 2a 20 46 6f 75 6e 64  ..      /* Found
3410: 20 61 20 6e 65 77 20 77 6f 72 64 20 61 74 20 7a   a new word at z
3420: 49 6e 70 75 74 5b 69 5d 20 74 68 61 74 20 69 73  Input[i] that is
3430: 20 6a 2d 69 20 62 79 74 65 73 20 6c 6f 6e 67 2e   j-i bytes long.
3440: 20 0a 20 20 20 20 20 20 2a 2a 20 50 72 6f 63 65   .      ** Proce
3450: 73 73 20 69 74 20 69 6e 74 6f 20 74 68 65 20 77  ss it into the w
3460: 6f 72 64 63 6f 75 6e 74 20 74 61 62 6c 65 2e 20  ordcount table. 
3470: 20 2a 2f 0a 20 20 20 20 20 20 69 66 28 20 69 4d   */.      if( iM
3480: 6f 64 65 3d 3d 4d 4f 44 45 5f 44 45 4c 45 54 45  ode==MODE_DELETE
3490: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
34a0: 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 28 70 44  te3_bind_text(pD
34b0: 65 6c 65 74 65 2c 20 31 2c 20 7a 49 6e 70 75 74  elete, 1, zInput
34c0: 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54 45 5f  +i, j-i, SQLITE_
34d0: 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20  STATIC);.       
34e0: 20 69 66 28 20 73 71 6c 69 74 65 33 5f 73 74 65   if( sqlite3_ste
34f0: 70 28 70 44 65 6c 65 74 65 29 21 3d 53 51 4c 49  p(pDelete)!=SQLI
3500: 54 45 5f 44 4f 4e 45 20 29 7b 0a 20 20 20 20 20  TE_DONE ){.     
3510: 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72       fatal_error
3520: 28 22 44 45 4c 45 54 45 20 66 61 69 6c 65 64 3a  ("DELETE failed:
3530: 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65 33 5f   %s\n", sqlite3_
3540: 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20  errmsg(db));.   
3550: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 73       }.        s
3560: 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70 44 65  qlite3_reset(pDe
3570: 6c 65 74 65 29 3b 0a 20 20 20 20 20 20 7d 65 6c  lete);.      }el
3580: 73 65 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f  se if( iMode==MO
3590: 44 45 5f 53 45 4c 45 43 54 20 29 7b 0a 20 20 20  DE_SELECT ){.   
35a0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 62 69 6e       sqlite3_bin
35b0: 64 5f 74 65 78 74 28 70 53 65 6c 65 63 74 2c 20  d_text(pSelect, 
35c0: 31 2c 20 7a 49 6e 70 75 74 2b 69 2c 20 6a 2d 69  1, zInput+i, j-i
35d0: 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29  , SQLITE_STATIC)
35e0: 3b 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20 73  ;.        rc = s
35f0: 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53 65 6c  qlite3_step(pSel
3600: 65 63 74 29 3b 0a 20 20 20 20 20 20 20 20 73 71  ect);.        sq
3610: 6c 69 74 65 33 5f 72 65 73 65 74 28 70 53 65 6c  lite3_reset(pSel
3620: 65 63 74 29 3b 0a 20 20 20 20 20 20 20 20 69 66  ect);.        if
3630: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 52 4f 57  ( rc==SQLITE_ROW
3640: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71   ){.          sq
3650: 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 28  lite3_bind_text(
3660: 70 55 70 64 61 74 65 2c 20 31 2c 20 7a 49 6e 70  pUpdate, 1, zInp
3670: 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54  ut+i, j-i, SQLIT
3680: 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20  E_STATIC);.     
3690: 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33       if( sqlite3
36a0: 5f 73 74 65 70 28 70 55 70 64 61 74 65 29 21 3d  _step(pUpdate)!=
36b0: 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20  SQLITE_DONE ){. 
36c0: 20 20 20 20 20 20 20 20 20 20 20 66 61 74 61 6c             fatal
36d0: 5f 65 72 72 6f 72 28 22 55 50 44 41 54 45 20 66  _error("UPDATE f
36e0: 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20 73 71  ailed: %s\n", sq
36f0: 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29  lite3_errmsg(db)
3700: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  );.          }. 
3710: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
3720: 5f 72 65 73 65 74 28 70 55 70 64 61 74 65 29 3b  _reset(pUpdate);
3730: 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 20 69  .        }else i
3740: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 44 4f  f( rc==SQLITE_DO
3750: 4e 45 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  NE ){.          
3760: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78  sqlite3_bind_tex
3770: 74 28 70 49 6e 73 65 72 74 2c 20 31 2c 20 7a 49  t(pInsert, 1, zI
3780: 6e 70 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c  nput+i, j-i, SQL
3790: 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20  ITE_STATIC);.   
37a0: 20 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74         if( sqlit
37b0: 65 33 5f 73 74 65 70 28 70 49 6e 73 65 72 74 29  e3_step(pInsert)
37c0: 21 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b  !=SQLITE_DONE ){
37d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 61 74  .            fat
37e0: 61 6c 5f 65 72 72 6f 72 28 22 49 6e 73 65 72 74  al_error("Insert
37f0: 20 66 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20   failed: %s\n", 
3800: 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64  sqlite3_errmsg(d
3810: 62 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  b));.          }
3820: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
3830: 65 33 5f 72 65 73 65 74 28 70 49 6e 73 65 72 74  e3_reset(pInsert
3840: 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65  );.        }else
3850: 7b 0a 20 20 20 20 20 20 20 20 20 20 66 61 74 61  {.          fata
3860: 6c 5f 65 72 72 6f 72 28 22 53 45 4c 45 43 54 20  l_error("SELECT 
3870: 66 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20 73  failed: %s\n", s
3880: 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62  qlite3_errmsg(db
3890: 29 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ));.        }.  
38a0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 69 4d      }else if( iM
38b0: 6f 64 65 3d 3d 4d 4f 44 45 5f 51 55 45 52 59 20  ode==MODE_QUERY 
38c0: 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ){.        sqlit
38d0: 65 33 5f 62 69 6e 64 5f 74 65 78 74 28 70 53 65  e3_bind_text(pSe
38e0: 6c 65 63 74 2c 20 31 2c 20 7a 49 6e 70 75 74 2b  lect, 1, zInput+
38f0: 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54 45 5f 53  i, j-i, SQLITE_S
3900: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20  TATIC);.        
3910: 69 66 28 20 73 71 6c 69 74 65 33 5f 73 74 65 70  if( sqlite3_step
3920: 28 70 53 65 6c 65 63 74 29 3d 3d 53 51 4c 49 54  (pSelect)==SQLIT
3930: 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20 20 20  E_ROW ){.       
3940: 20 20 20 73 75 6d 43 6e 74 20 2b 3d 20 73 71 6c     sumCnt += sql
3950: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36  ite3_column_int6
3960: 34 28 70 53 65 6c 65 63 74 2c 20 30 29 3b 0a 20  4(pSelect, 0);. 
3970: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
3980: 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70   sqlite3_reset(p
3990: 53 65 6c 65 63 74 29 3b 0a 20 20 20 20 20 20 7d  Select);.      }
39a0: 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 73 71  else{.        sq
39b0: 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 28  lite3_bind_text(
39c0: 70 49 6e 73 65 72 74 2c 20 31 2c 20 7a 49 6e 70  pInsert, 1, zInp
39d0: 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54  ut+i, j-i, SQLIT
39e0: 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20  E_STATIC);.     
39f0: 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f 73     if( sqlite3_s
3a00: 74 65 70 28 70 49 6e 73 65 72 74 29 21 3d 53 51  tep(pInsert)!=SQ
3a10: 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20 20 20  LITE_DONE ){.   
3a20: 20 20 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72         fatal_err
3a30: 6f 72 28 22 49 4e 53 45 52 54 20 66 61 69 6c 65  or("INSERT faile
3a40: 64 3a 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65  d: %s\n", sqlite
3a50: 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20  3_errmsg(db));. 
3a60: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
3a70: 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70   sqlite3_reset(p
3a80: 49 6e 73 65 72 74 29 3b 0a 20 20 20 20 20 20 20  Insert);.       
3a90: 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45   if( iMode==MODE
3aa0: 5f 55 50 44 41 54 45 0a 20 20 20 20 20 20 20 20  _UPDATE.        
3ab0: 20 7c 7c 20 28 69 4d 6f 64 65 3d 3d 4d 4f 44 45   || (iMode==MODE
3ac0: 5f 49 4e 53 45 52 54 20 26 26 20 73 71 6c 69 74  _INSERT && sqlit
3ad0: 65 33 5f 63 68 61 6e 67 65 73 28 64 62 29 3d 3d  e3_changes(db)==
3ae0: 30 29 0a 20 20 20 20 20 20 20 20 29 7b 0a 20 20  0).        ){.  
3af0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
3b00: 62 69 6e 64 5f 74 65 78 74 28 70 55 70 64 61 74  bind_text(pUpdat
3b10: 65 2c 20 31 2c 20 7a 49 6e 70 75 74 2b 69 2c 20  e, 1, zInput+i, 
3b20: 6a 2d 69 2c 20 53 51 4c 49 54 45 5f 53 54 41 54  j-i, SQLITE_STAT
3b30: 49 43 29 3b 0a 20 20 20 20 20 20 20 20 20 20 69  IC);.          i
3b40: 66 28 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28  f( sqlite3_step(
3b50: 70 55 70 64 61 74 65 29 21 3d 53 51 4c 49 54 45  pUpdate)!=SQLITE
3b60: 5f 44 4f 4e 45 20 29 7b 0a 20 20 20 20 20 20 20  _DONE ){.       
3b70: 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72       fatal_error
3b80: 28 22 55 50 44 41 54 45 20 66 61 69 6c 65 64 3a  ("UPDATE failed:
3b90: 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65 33 5f   %s\n", sqlite3_
3ba0: 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20  errmsg(db));.   
3bb0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
3bc0: 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74     sqlite3_reset
3bd0: 28 70 55 70 64 61 74 65 29 3b 0a 20 20 20 20 20  (pUpdate);.     
3be0: 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20     }.      }.   
3bf0: 20 20 20 69 20 3d 20 6a 2d 31 3b 0a 0a 20 20 20     i = j-1;..   
3c00: 20 20 20 2f 2a 20 49 6e 63 72 65 6d 65 6e 74 20     /* Increment 
3c10: 74 68 65 20 6f 70 65 72 61 74 69 6f 6e 20 63 6f  the operation co
3c20: 75 6e 74 65 72 2e 20 20 44 6f 20 61 20 43 4f 4d  unter.  Do a COM
3c30: 4d 49 54 20 69 66 20 69 74 20 69 73 20 74 69 6d  MIT if it is tim
3c40: 65 2e 20 2a 2f 0a 20 20 20 20 20 20 6e 4f 70 2b  e. */.      nOp+
3c50: 2b 3b 0a 20 20 20 20 20 20 69 66 28 20 63 6f 6d  +;.      if( com
3c60: 6d 69 74 49 6e 74 65 72 76 61 6c 3e 30 20 26 26  mitInterval>0 &&
3c70: 20 28 6e 4f 70 25 63 6f 6d 6d 69 74 49 6e 74 65   (nOp%commitInte
3c80: 72 76 61 6c 29 3d 3d 30 20 29 7b 0a 20 20 20 20  rval)==0 ){.    
3c90: 20 20 20 20 73 71 6c 69 74 65 33 5f 65 78 65 63      sqlite3_exec
3ca0: 28 64 62 2c 20 22 43 4f 4d 4d 49 54 3b 20 42 45  (db, "COMMIT; BE
3cb0: 47 49 4e 20 49 4d 4d 45 44 49 41 54 45 22 2c 20  GIN IMMEDIATE", 
3cc0: 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20  0, 0, 0);.      
3cd0: 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 73 71  }.    }.  }.  sq
3ce0: 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20 22  lite3_exec(db, "
3cf0: 43 4f 4d 4d 49 54 22 2c 20 30 2c 20 30 2c 20 30  COMMIT", 0, 0, 0
3d00: 29 3b 0a 20 20 69 66 28 20 7a 46 69 6c 65 54 6f  );.  if( zFileTo
3d10: 52 65 61 64 20 29 20 66 63 6c 6f 73 65 28 69 6e  Read ) fclose(in
3d20: 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6e  );.  sqlite3_fin
3d30: 61 6c 69 7a 65 28 70 49 6e 73 65 72 74 29 3b 0a  alize(pInsert);.
3d40: 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69    sqlite3_finali
3d50: 7a 65 28 70 55 70 64 61 74 65 29 3b 0a 20 20 73  ze(pUpdate);.  s
3d60: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28  qlite3_finalize(
3d70: 70 53 65 6c 65 63 74 29 3b 0a 20 20 73 71 6c 69  pSelect);.  sqli
3d80: 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 44 65  te3_finalize(pDe
3d90: 6c 65 74 65 29 3b 0a 0a 20 20 69 66 28 20 69 4d  lete);..  if( iM
3da0: 6f 64 65 3d 3d 4d 4f 44 45 5f 51 55 45 52 59 20  ode==MODE_QUERY 
3db0: 29 7b 0a 20 20 20 20 70 72 69 6e 74 66 28 22 73  ){.    printf("s
3dc0: 75 6d 20 6f 66 20 63 6e 74 3a 20 25 6c 6c 64 5c  um of cnt: %lld\
3dd0: 6e 22 2c 20 73 75 6d 43 6e 74 29 3b 0a 20 20 20  n", sumCnt);.   
3de0: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70 72   rc = sqlite3_pr
3df0: 65 70 61 72 65 5f 76 32 28 64 62 2c 22 53 45 4c  epare_v2(db,"SEL
3e00: 45 43 54 20 73 75 6d 28 63 6e 74 2a 63 6e 74 29  ECT sum(cnt*cnt)
3e10: 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 22   FROM wordcount"
3e20: 2c 20 2d 31 2c 0a 20 20 20 20 20 20 20 20 20 20  , -1,.          
3e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3e40: 20 20 26 70 53 65 6c 65 63 74 2c 20 30 29 3b 0a    &pSelect, 0);.
3e50: 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49      if( rc==SQLI
3e60: 54 45 5f 4f 4b 20 26 26 20 73 71 6c 69 74 65 33  TE_OK && sqlite3
3e70: 5f 73 74 65 70 28 70 53 65 6c 65 63 74 29 3d 3d  _step(pSelect)==
3e80: 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20 20  SQLITE_ROW ){.  
3e90: 20 20 20 20 70 72 69 6e 74 66 28 22 64 6f 75 62      printf("doub
3ea0: 6c 65 2d 63 68 65 63 6b 3a 20 25 6c 6c 64 5c 6e  le-check: %lld\n
3eb0: 22 2c 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  ", sqlite3_colum
3ec0: 6e 5f 69 6e 74 36 34 28 70 53 65 6c 65 63 74 2c  n_int64(pSelect,
3ed0: 20 30 29 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20   0));.    }.    
3ee0: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
3ef0: 28 70 53 65 6c 65 63 74 29 3b 0a 20 20 7d 0a 0a  (pSelect);.  }..
3f00: 0a 20 20 69 66 28 20 73 68 6f 77 54 69 6d 65 72  .  if( showTimer
3f10: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f   ){.    sqlite3_
3f20: 69 6e 74 36 34 20 65 6c 61 70 73 65 54 69 6d 65  int64 elapseTime
3f30: 20 3d 20 72 65 61 6c 54 69 6d 65 28 29 20 2d 20   = realTime() - 
3f40: 73 74 61 72 74 54 69 6d 65 3b 0a 20 20 20 20 70  startTime;.    p
3f50: 72 69 6e 74 66 28 22 2f 2a 20 25 33 64 2e 25 30  rintf("/* %3d.%0
3f60: 33 64 22 2c 20 28 69 6e 74 29 28 65 6c 61 70 73  3d", (int)(elaps
3f70: 65 54 69 6d 65 2f 31 30 30 30 29 2c 20 28 69 6e  eTime/1000), (in
3f80: 74 29 28 65 6c 61 70 73 65 54 69 6d 65 25 31 30  t)(elapseTime%10
3f90: 30 30 29 29 3b 0a 20 20 20 20 66 6f 72 28 69 3d  00));.    for(i=
3fa0: 30 3b 20 69 3c 61 72 67 63 3b 20 69 2b 2b 29 20  0; i<argc; i++) 
3fb0: 69 66 28 20 69 21 3d 73 68 6f 77 54 69 6d 65 72  if( i!=showTimer
3fc0: 20 29 20 70 72 69 6e 74 66 28 22 20 25 73 22 2c   ) printf(" %s",
3fd0: 20 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 70   argv[i]);.    p
3fe0: 72 69 6e 74 66 28 22 20 2a 2f 5c 6e 22 29 3b 0a  rintf(" */\n");.
3ff0: 20 20 7d 0a 0a 20 20 69 66 28 20 73 68 6f 77 53    }..  if( showS
4000: 75 6d 6d 61 72 79 20 29 7b 0a 20 20 20 20 73 71  ummary ){.    sq
4010: 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 66 75 6e  lite3_create_fun
4020: 63 74 69 6f 6e 28 64 62 2c 20 22 63 68 65 63 6b  ction(db, "check
4030: 73 75 6d 22 2c 20 2d 31 2c 20 53 51 4c 49 54 45  sum", -1, SQLITE
4040: 5f 55 54 46 38 2c 20 30 2c 0a 20 20 20 20 20 20  _UTF8, 0,.      
4050: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4060: 20 20 20 20 20 20 30 2c 20 63 68 65 63 6b 73 75        0, checksu
4070: 6d 53 74 65 70 2c 20 63 68 65 63 6b 73 75 6d 46  mStep, checksumF
4080: 69 6e 61 6c 69 7a 65 29 3b 0a 20 20 20 20 73 71  inalize);.    sq
4090: 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20 0a  lite3_exec(db, .
40a0: 20 20 20 20 20 20 22 53 45 4c 45 43 54 20 27 63        "SELECT 'c
40b0: 6f 75 6e 74 28 2a 29 3a 20 20 27 2c 20 63 6f 75  ount(*):  ', cou
40c0: 6e 74 28 2a 29 20 46 52 4f 4d 20 77 6f 72 64 63  nt(*) FROM wordc
40d0: 6f 75 6e 74 3b 5c 6e 22 0a 20 20 20 20 20 20 22  ount;\n".      "
40e0: 53 45 4c 45 43 54 20 27 73 75 6d 28 63 6e 74 29  SELECT 'sum(cnt)
40f0: 3a 20 20 27 2c 20 73 75 6d 28 63 6e 74 29 20 46  :  ', sum(cnt) F
4100: 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 3b 5c 6e  ROM wordcount;\n
4110: 22 0a 20 20 20 20 20 20 22 53 45 4c 45 43 54 20  ".      "SELECT 
4120: 27 6d 61 78 28 63 6e 74 29 3a 20 20 27 2c 20 6d  'max(cnt):  ', m
4130: 61 78 28 63 6e 74 29 20 46 52 4f 4d 20 77 6f 72  ax(cnt) FROM wor
4140: 64 63 6f 75 6e 74 3b 5c 6e 22 0a 20 20 20 20 20  dcount;\n".     
4150: 20 22 53 45 4c 45 43 54 20 27 61 76 67 28 63 6e   "SELECT 'avg(cn
4160: 74 29 3a 20 20 27 2c 20 61 76 67 28 63 6e 74 29  t):  ', avg(cnt)
4170: 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 3b   FROM wordcount;
4180: 5c 6e 22 0a 20 20 20 20 20 20 22 53 45 4c 45 43  \n".      "SELEC
4190: 54 20 27 73 75 6d 28 63 6e 74 3d 31 29 3a 27 2c  T 'sum(cnt=1):',
41a0: 20 73 75 6d 28 63 6e 74 3d 31 29 20 46 52 4f 4d   sum(cnt=1) FROM
41b0: 20 77 6f 72 64 63 6f 75 6e 74 3b 5c 6e 22 0a 20   wordcount;\n". 
41c0: 20 20 20 20 20 22 53 45 4c 45 43 54 20 27 74 6f       "SELECT 'to
41d0: 70 20 31 30 3a 20 20 20 20 27 2c 20 67 72 6f 75  p 10:    ', grou
41e0: 70 5f 63 6f 6e 63 61 74 28 77 6f 72 64 2c 20 27  p_concat(word, '
41f0: 2c 20 27 29 20 46 52 4f 4d 20 22 0a 20 20 20 20  , ') FROM ".    
4200: 20 20 20 20 20 22 28 53 45 4c 45 43 54 20 77 6f       "(SELECT wo
4210: 72 64 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e  rd FROM wordcoun
4220: 74 20 4f 52 44 45 52 20 42 59 20 63 6e 74 20 44  t ORDER BY cnt D
4230: 45 53 43 2c 20 77 6f 72 64 20 4c 49 4d 49 54 20  ESC, word LIMIT 
4240: 31 30 29 3b 5c 6e 22 0a 20 20 20 20 20 20 22 53  10);\n".      "S
4250: 45 4c 45 43 54 20 27 63 68 65 63 6b 73 75 6d 3a  ELECT 'checksum:
4260: 20 20 27 2c 20 63 68 65 63 6b 73 75 6d 28 77 6f    ', checksum(wo
4270: 72 64 2c 20 63 6e 74 29 20 46 52 4f 4d 20 22 0a  rd, cnt) FROM ".
4280: 20 20 20 20 20 20 20 20 20 22 28 53 45 4c 45 43           "(SELEC
4290: 54 20 77 6f 72 64 2c 20 63 6e 74 20 46 52 4f 4d  T word, cnt FROM
42a0: 20 77 6f 72 64 63 6f 75 6e 74 20 4f 52 44 45 52   wordcount ORDER
42b0: 20 42 59 20 77 6f 72 64 29 3b 5c 6e 22 0a 20 20   BY word);\n".  
42c0: 20 20 20 20 22 50 52 41 47 4d 41 20 69 6e 74 65      "PRAGMA inte
42d0: 67 72 69 74 79 5f 63 68 65 63 6b 3b 5c 6e 22 2c  grity_check;\n",
42e0: 0a 20 20 20 20 20 20 70 72 69 6e 74 52 65 73 75  .      printResu
42f0: 6c 74 2c 20 30 2c 20 30 29 3b 0a 20 20 7d 0a 0a  lt, 0, 0);.  }..
4300: 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 63 6f    /* Database co
4310: 6e 6e 65 63 74 69 6f 6e 20 73 74 61 74 69 73 74  nnection statist
4320: 69 63 73 20 70 72 69 6e 74 65 64 20 61 66 74 65  ics printed afte
4330: 72 20 62 6f 74 68 20 70 72 65 70 61 72 65 64 20  r both prepared 
4340: 73 74 61 74 65 6d 65 6e 74 73 0a 20 20 2a 2a 20  statements.  ** 
4350: 68 61 76 65 20 62 65 65 6e 20 66 69 6e 61 6c 69  have been finali
4360: 7a 65 64 20 2a 2f 0a 20 20 69 66 28 20 73 68 6f  zed */.  if( sho
4370: 77 53 74 61 74 73 20 29 7b 0a 20 20 20 20 73 71  wStats ){.    sq
4380: 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73 28  lite3_db_status(
4390: 64 62 2c 20 53 51 4c 49 54 45 5f 44 42 53 54 41  db, SQLITE_DBSTA
43a0: 54 55 53 5f 4c 4f 4f 4b 41 53 49 44 45 5f 55 53  TUS_LOOKASIDE_US
43b0: 45 44 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77  ED, &iCur, &iHiw
43c0: 74 72 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e  tr, 0);.    prin
43d0: 74 66 28 22 2d 2d 20 4c 6f 6f 6b 61 73 69 64 65  tf("-- Lookaside
43e0: 20 53 6c 6f 74 73 20 55 73 65 64 3a 20 20 20 20   Slots Used:    
43f0: 20 20 20 20 25 64 20 28 6d 61 78 20 25 64 29 5c      %d (max %d)\
4400: 6e 22 2c 20 69 43 75 72 2c 69 48 69 77 74 72 29  n", iCur,iHiwtr)
4410: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62  ;.    sqlite3_db
4420: 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49  _status(db, SQLI
4430: 54 45 5f 44 42 53 54 41 54 55 53 5f 4c 4f 4f 4b  TE_DBSTATUS_LOOK
4440: 41 53 49 44 45 5f 48 49 54 2c 20 26 69 43 75 72  ASIDE_HIT, &iCur
4450: 2c 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20  , &iHiwtr, 0);. 
4460: 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 20 53 75     printf("-- Su
4470: 63 63 65 73 73 66 75 6c 20 6c 6f 6f 6b 61 73 69  ccessful lookasi
4480: 64 65 73 3a 20 20 20 20 20 20 20 25 64 5c 6e 22  des:       %d\n"
4490: 2c 20 69 48 69 77 74 72 29 3b 0a 20 20 20 20 73  , iHiwtr);.    s
44a0: 71 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73  qlite3_db_status
44b0: 28 64 62 2c 20 53 51 4c 49 54 45 5f 44 42 53 54  (db, SQLITE_DBST
44c0: 41 54 55 53 5f 4c 4f 4f 4b 41 53 49 44 45 5f 4d  ATUS_LOOKASIDE_M
44d0: 49 53 53 5f 53 49 5a 45 2c 20 26 69 43 75 72 2c  ISS_SIZE, &iCur,
44e0: 26 69 48 69 77 74 72 2c 30 29 3b 0a 20 20 20 20  &iHiwtr,0);.    
44f0: 70 72 69 6e 74 66 28 22 2d 2d 20 4c 6f 6f 6b 61  printf("-- Looka
4500: 73 69 64 65 20 73 69 7a 65 20 66 61 75 6c 74 73  side size faults
4510: 3a 20 20 20 20 20 20 20 25 64 5c 6e 22 2c 20 69  :       %d\n", i
4520: 48 69 77 74 72 29 3b 0a 20 20 20 20 73 71 6c 69  Hiwtr);.    sqli
4530: 74 65 33 5f 64 62 5f 73 74 61 74 75 73 28 64 62  te3_db_status(db
4540: 2c 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54 55  , SQLITE_DBSTATU
4550: 53 5f 4c 4f 4f 4b 41 53 49 44 45 5f 4d 49 53 53  S_LOOKASIDE_MISS
4560: 5f 46 55 4c 4c 2c 20 26 69 43 75 72 2c 26 69 48  _FULL, &iCur,&iH
4570: 69 77 74 72 2c 30 29 3b 0a 20 20 20 20 70 72 69  iwtr,0);.    pri
4580: 6e 74 66 28 22 2d 2d 20 4c 6f 6f 6b 61 73 69 64  ntf("-- Lookasid
4590: 65 20 4f 4f 4d 20 66 61 75 6c 74 73 3a 20 20 20  e OOM faults:   
45a0: 20 20 20 20 20 25 64 5c 6e 22 2c 20 69 48 69 77       %d\n", iHiw
45b0: 74 72 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  tr);.    sqlite3
45c0: 5f 64 62 5f 73 74 61 74 75 73 28 64 62 2c 20 53  _db_status(db, S
45d0: 51 4c 49 54 45 5f 44 42 53 54 41 54 55 53 5f 43  QLITE_DBSTATUS_C
45e0: 41 43 48 45 5f 55 53 45 44 2c 20 26 69 43 75 72  ACHE_USED, &iCur
45f0: 2c 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20  , &iHiwtr, 0);. 
4600: 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 20 50 61     printf("-- Pa
4610: 67 65 72 20 48 65 61 70 20 55 73 61 67 65 3a 20  ger Heap Usage: 
4620: 20 20 20 20 20 20 20 20 20 20 20 25 64 20 62 79             %d by
4630: 74 65 73 5c 6e 22 2c 20 69 43 75 72 29 3b 0a 20  tes\n", iCur);. 
4640: 20 20 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74     sqlite3_db_st
4650: 61 74 75 73 28 64 62 2c 20 53 51 4c 49 54 45 5f  atus(db, SQLITE_
4660: 44 42 53 54 41 54 55 53 5f 43 41 43 48 45 5f 48  DBSTATUS_CACHE_H
4670: 49 54 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77  IT, &iCur, &iHiw
4680: 74 72 2c 20 31 29 3b 0a 20 20 20 20 70 72 69 6e  tr, 1);.    prin
4690: 74 66 28 22 2d 2d 20 50 61 67 65 20 63 61 63 68  tf("-- Page cach
46a0: 65 20 68 69 74 73 3a 20 20 20 20 20 20 20 20 20  e hits:         
46b0: 20 20 20 20 25 64 5c 6e 22 2c 20 69 43 75 72 29      %d\n", iCur)
46c0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62  ;.    sqlite3_db
46d0: 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49  _status(db, SQLI
46e0: 54 45 5f 44 42 53 54 41 54 55 53 5f 43 41 43 48  TE_DBSTATUS_CACH
46f0: 45 5f 4d 49 53 53 2c 20 26 69 43 75 72 2c 20 26  E_MISS, &iCur, &
4700: 69 48 69 77 74 72 2c 20 31 29 3b 0a 20 20 20 20  iHiwtr, 1);.    
4710: 70 72 69 6e 74 66 28 22 2d 2d 20 50 61 67 65 20  printf("-- Page 
4720: 63 61 63 68 65 20 6d 69 73 73 65 73 3a 20 20 20  cache misses:   
4730: 20 20 20 20 20 20 20 20 25 64 5c 6e 22 2c 20 69          %d\n", i
4740: 43 75 72 29 3b 20 0a 20 20 20 20 73 71 6c 69 74  Cur); .    sqlit
4750: 65 33 5f 64 62 5f 73 74 61 74 75 73 28 64 62 2c  e3_db_status(db,
4760: 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54 55 53   SQLITE_DBSTATUS
4770: 5f 43 41 43 48 45 5f 57 52 49 54 45 2c 20 26 69  _CACHE_WRITE, &i
4780: 43 75 72 2c 20 26 69 48 69 77 74 72 2c 20 31 29  Cur, &iHiwtr, 1)
4790: 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d  ;.    printf("--
47a0: 20 50 61 67 65 20 63 61 63 68 65 20 77 72 69 74   Page cache writ
47b0: 65 73 3a 20 20 20 20 20 20 20 20 20 20 20 25 64  es:           %d
47c0: 5c 6e 22 2c 20 69 43 75 72 29 3b 20 0a 20 20 20  \n", iCur); .   
47d0: 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74 61 74   sqlite3_db_stat
47e0: 75 73 28 64 62 2c 20 53 51 4c 49 54 45 5f 44 42  us(db, SQLITE_DB
47f0: 53 54 41 54 55 53 5f 53 43 48 45 4d 41 5f 55 53  STATUS_SCHEMA_US
4800: 45 44 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77  ED, &iCur, &iHiw
4810: 74 72 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e  tr, 0);.    prin
4820: 74 66 28 22 2d 2d 20 53 63 68 65 6d 61 20 48 65  tf("-- Schema He
4830: 61 70 20 55 73 61 67 65 3a 20 20 20 20 20 20 20  ap Usage:       
4840: 20 20 20 20 25 64 20 62 79 74 65 73 5c 6e 22 2c      %d bytes\n",
4850: 20 69 43 75 72 29 3b 20 0a 20 20 20 20 73 71 6c   iCur); .    sql
4860: 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73 28 64  ite3_db_status(d
4870: 62 2c 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54  b, SQLITE_DBSTAT
4880: 55 53 5f 53 54 4d 54 5f 55 53 45 44 2c 20 26 69  US_STMT_USED, &i
4890: 43 75 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29  Cur, &iHiwtr, 0)
48a0: 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d  ;.    printf("--
48b0: 20 53 74 61 74 65 6d 65 6e 74 20 48 65 61 70 20   Statement Heap 
48c0: 55 73 61 67 65 3a 20 20 20 20 20 20 20 20 25 64  Usage:        %d
48d0: 20 62 79 74 65 73 5c 6e 22 2c 20 69 43 75 72 29   bytes\n", iCur)
48e0: 3b 20 0a 20 20 7d 0a 0a 20 20 73 71 6c 69 74 65  ; .  }..  sqlite
48f0: 33 5f 63 6c 6f 73 65 28 64 62 29 3b 0a 0a 20 20  3_close(db);..  
4900: 2f 2a 20 47 6c 6f 62 61 6c 20 6d 65 6d 6f 72 79  /* Global memory
4910: 20 75 73 61 67 65 20 73 74 61 74 69 73 74 69 63   usage statistic
4920: 73 20 70 72 69 6e 74 65 64 20 61 66 74 65 72 20  s printed after 
4930: 74 68 65 20 64 61 74 61 62 61 73 65 20 63 6f 6e  the database con
4940: 6e 65 63 74 69 6f 6e 0a 20 20 2a 2a 20 68 61 73  nection.  ** has
4950: 20 63 6c 6f 73 65 64 2e 20 20 4d 65 6d 6f 72 79   closed.  Memory
4960: 20 75 73 61 67 65 20 73 68 6f 75 6c 64 20 62 65   usage should be
4970: 20 7a 65 72 6f 20 61 74 20 74 68 69 73 20 70 6f   zero at this po
4980: 69 6e 74 2e 20 2a 2f 0a 20 20 69 66 28 20 73 68  int. */.  if( sh
4990: 6f 77 53 74 61 74 73 20 29 7b 0a 20 20 20 20 73  owStats ){.    s
49a0: 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28 53 51  qlite3_status(SQ
49b0: 4c 49 54 45 5f 53 54 41 54 55 53 5f 4d 45 4d 4f  LITE_STATUS_MEMO
49c0: 52 59 5f 55 53 45 44 2c 20 26 69 43 75 72 2c 20  RY_USED, &iCur, 
49d0: 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20  &iHiwtr, 0);.   
49e0: 20 70 72 69 6e 74 66 28 22 2d 2d 20 4d 65 6d 6f   printf("-- Memo
49f0: 72 79 20 55 73 65 64 20 28 62 79 74 65 73 29 3a  ry Used (bytes):
4a00: 20 20 20 20 20 20 20 20 20 25 64 20 28 6d 61 78           %d (max
4a10: 20 25 64 29 5c 6e 22 2c 20 69 43 75 72 2c 69 48   %d)\n", iCur,iH
4a20: 69 77 74 72 29 3b 0a 20 20 20 20 73 71 6c 69 74  iwtr);.    sqlit
4a30: 65 33 5f 73 74 61 74 75 73 28 53 51 4c 49 54 45  e3_status(SQLITE
4a40: 5f 53 54 41 54 55 53 5f 4d 41 4c 4c 4f 43 5f 43  _STATUS_MALLOC_C
4a50: 4f 55 4e 54 2c 20 26 69 43 75 72 2c 20 26 69 48  OUNT, &iCur, &iH
4a60: 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20 70 72  iwtr, 0);.    pr
4a70: 69 6e 74 66 28 22 2d 2d 20 4f 75 74 73 74 61 6e  intf("-- Outstan
4a80: 64 69 6e 67 20 41 6c 6c 6f 63 61 74 69 6f 6e 73  ding Allocations
4a90: 3a 20 20 20 20 20 25 64 20 28 6d 61 78 20 25 64  :     %d (max %d
4aa0: 29 5c 6e 22 2c 20 69 43 75 72 2c 69 48 69 77 74  )\n", iCur,iHiwt
4ab0: 72 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  r);.    sqlite3_
4ac0: 73 74 61 74 75 73 28 53 51 4c 49 54 45 5f 53 54  status(SQLITE_ST
4ad0: 41 54 55 53 5f 50 41 47 45 43 41 43 48 45 5f 4f  ATUS_PAGECACHE_O
4ae0: 56 45 52 46 4c 4f 57 2c 20 26 69 43 75 72 2c 20  VERFLOW, &iCur, 
4af0: 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20  &iHiwtr, 0);.   
4b00: 20 70 72 69 6e 74 66 28 22 2d 2d 20 50 63 61 63   printf("-- Pcac
4b10: 68 65 20 4f 76 65 72 66 6c 6f 77 20 42 79 74 65  he Overflow Byte
4b20: 73 3a 20 20 20 20 20 20 20 25 64 20 28 6d 61 78  s:       %d (max
4b30: 20 25 64 29 5c 6e 22 2c 20 69 43 75 72 2c 69 48   %d)\n", iCur,iH
4b40: 69 77 74 72 29 3b 0a 20 20 20 20 73 71 6c 69 74  iwtr);.    sqlit
4b50: 65 33 5f 73 74 61 74 75 73 28 53 51 4c 49 54 45  e3_status(SQLITE
4b60: 5f 53 54 41 54 55 53 5f 53 43 52 41 54 43 48 5f  _STATUS_SCRATCH_
4b70: 4f 56 45 52 46 4c 4f 57 2c 20 26 69 43 75 72 2c  OVERFLOW, &iCur,
4b80: 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20   &iHiwtr, 0);.  
4b90: 20 20 70 72 69 6e 74 66 28 22 2d 2d 20 53 63 72    printf("-- Scr
4ba0: 61 74 63 68 20 4f 76 65 72 66 6c 6f 77 20 42 79  atch Overflow By
4bb0: 74 65 73 3a 20 20 20 20 20 20 25 64 20 28 6d 61  tes:      %d (ma
4bc0: 78 20 25 64 29 5c 6e 22 2c 20 69 43 75 72 2c 69  x %d)\n", iCur,i
4bd0: 48 69 77 74 72 29 3b 0a 20 20 20 20 73 71 6c 69  Hiwtr);.    sqli
4be0: 74 65 33 5f 73 74 61 74 75 73 28 53 51 4c 49 54  te3_status(SQLIT
4bf0: 45 5f 53 54 41 54 55 53 5f 4d 41 4c 4c 4f 43 5f  E_STATUS_MALLOC_
4c00: 53 49 5a 45 2c 20 26 69 43 75 72 2c 20 26 69 48  SIZE, &iCur, &iH
4c10: 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20 70 72  iwtr, 0);.    pr
4c20: 69 6e 74 66 28 22 2d 2d 20 4c 61 72 67 65 73 74  intf("-- Largest
4c30: 20 41 6c 6c 6f 63 61 74 69 6f 6e 3a 20 20 20 20   Allocation:    
4c40: 20 20 20 20 20 20 25 64 20 62 79 74 65 73 5c 6e        %d bytes\n
4c50: 22 2c 69 48 69 77 74 72 29 3b 0a 20 20 20 20 73  ",iHiwtr);.    s
4c60: 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28 53 51  qlite3_status(SQ
4c70: 4c 49 54 45 5f 53 54 41 54 55 53 5f 50 41 47 45  LITE_STATUS_PAGE
4c80: 43 41 43 48 45 5f 53 49 5a 45 2c 20 26 69 43 75  CACHE_SIZE, &iCu
4c90: 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a  r, &iHiwtr, 0);.
4ca0: 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 20 4c      printf("-- L
4cb0: 61 72 67 65 73 74 20 50 63 61 63 68 65 20 41 6c  argest Pcache Al
4cc0: 6c 6f 63 61 74 69 6f 6e 3a 20 20 20 25 64 20 62  location:   %d b
4cd0: 79 74 65 73 5c 6e 22 2c 69 48 69 77 74 72 29 3b  ytes\n",iHiwtr);
4ce0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74 61  .    sqlite3_sta
4cf0: 74 75 73 28 53 51 4c 49 54 45 5f 53 54 41 54 55  tus(SQLITE_STATU
4d00: 53 5f 53 43 52 41 54 43 48 5f 53 49 5a 45 2c 20  S_SCRATCH_SIZE, 
4d10: 26 69 43 75 72 2c 20 26 69 48 69 77 74 72 2c 20  &iCur, &iHiwtr, 
4d20: 30 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22  0);.    printf("
4d30: 2d 2d 20 4c 61 72 67 65 73 74 20 53 63 72 61 74  -- Largest Scrat
4d40: 63 68 20 41 6c 6c 6f 63 61 74 69 6f 6e 3a 20 20  ch Allocation:  
4d50: 25 64 20 62 79 74 65 73 5c 6e 22 2c 20 69 48 69  %d bytes\n", iHi
4d60: 77 74 72 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75  wtr);.  }.  retu
4d70: 72 6e 20 30 3b 0a 7d 0a                          rn 0;.}.