/ Hex Artifact Content
Login

Artifact 97856eec21fd00d77da720007b1888c383f63dcf:


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 20 20 20 20 20 2d 2d 74 61 67  ram.**     --tag
0620: 20 4e 41 4d 45 20 20 20 20 20 20 20 20 20 20 20   NAME           
0630: 54 61 67 20 61 6c 6c 20 6f 75 74 70 75 74 20 75  Tag all output u
0640: 73 69 6e 67 20 4e 41 4d 45 2e 20 20 55 73 65 20  sing NAME.  Use 
0650: 6f 6e 6c 79 20 73 74 64 6f 75 74 2e 0a 2a 2a 0a  only stdout..**.
0660: 2a 2a 20 4d 6f 64 65 73 3a 0a 2a 2a 0a 2a 2a 20  ** Modes:.**.** 
0670: 49 6e 73 65 72 74 20 6d 6f 64 65 20 6d 65 61 6e  Insert mode mean
0680: 73 3a 0a 2a 2a 20 20 20 20 28 31 29 20 49 4e 53  s:.**    (1) INS
0690: 45 52 54 20 4f 52 20 49 47 4e 4f 52 45 20 49 4e  ERT OR IGNORE IN
06a0: 54 4f 20 77 6f 72 64 63 6f 75 6e 74 20 56 41 4c  TO wordcount VAL
06b0: 55 45 53 28 24 6e 65 77 2c 31 29 0a 2a 2a 20 20  UES($new,1).**  
06c0: 20 20 28 32 29 20 55 50 44 41 54 45 20 77 6f 72    (2) UPDATE wor
06d0: 64 63 6f 75 6e 74 20 53 45 54 20 63 6e 74 3d 63  dcount SET cnt=c
06e0: 6e 74 2b 31 20 57 48 45 52 45 20 77 6f 72 64 3d  nt+1 WHERE word=
06f0: 24 6e 65 77 20 2d 2d 20 69 66 20 28 31 29 20 69  $new -- if (1) i
0700: 73 20 61 20 6e 6f 6f 70 0a 2a 2a 0a 2a 2a 20 55  s a noop.**.** U
0710: 70 64 61 74 65 20 6d 6f 64 65 20 6d 65 61 6e 73  pdate mode means
0720: 3a 0a 2a 2a 20 20 20 20 28 31 29 20 49 4e 53 45  :.**    (1) INSE
0730: 52 54 20 4f 52 20 49 47 4e 4f 52 45 20 49 4e 54  RT OR IGNORE INT
0740: 4f 20 77 6f 72 64 63 6f 75 6e 74 20 56 41 4c 55  O wordcount VALU
0750: 45 53 28 24 6e 65 77 2c 30 29 0a 2a 2a 20 20 20  ES($new,0).**   
0760: 20 28 32 29 20 55 50 44 41 54 45 20 77 6f 72 64   (2) UPDATE word
0770: 63 6f 75 6e 74 20 53 45 54 20 63 6e 74 3d 63 6e  count SET cnt=cn
0780: 74 2b 31 20 57 48 45 52 45 20 77 6f 72 64 3d 24  t+1 WHERE word=$
0790: 6e 65 77 0a 2a 2a 0a 2a 2a 20 52 65 70 6c 61 63  new.**.** Replac
07a0: 65 20 6d 6f 64 65 20 6d 65 61 6e 73 3a 0a 2a 2a  e mode means:.**
07b0: 20 20 20 20 28 31 29 20 52 45 50 4c 41 43 45 20      (1) REPLACE 
07c0: 49 4e 54 4f 20 77 6f 72 64 63 6f 75 6e 74 0a 2a  INTO wordcount.*
07d0: 2a 20 20 20 20 20 20 20 20 56 41 4c 55 45 53 28  *        VALUES(
07e0: 24 6e 65 77 2c 69 66 6e 75 6c 6c 28 28 53 45 4c  $new,ifnull((SEL
07f0: 45 43 54 20 63 6e 74 20 46 52 4f 4d 20 77 6f 72  ECT cnt FROM wor
0800: 64 63 6f 75 6e 74 20 57 48 45 52 45 20 77 6f 72  dcount WHERE wor
0810: 64 3d 24 6e 65 77 29 2c 30 29 2b 31 29 3b 0a 2a  d=$new),0)+1);.*
0820: 2a 0a 2a 2a 20 53 65 6c 65 63 74 20 6d 6f 64 65  *.** Select mode
0830: 20 6d 65 61 6e 73 3a 0a 2a 2a 20 20 20 20 28 31   means:.**    (1
0840: 29 20 53 45 4c 45 43 54 20 31 20 46 52 4f 4d 20  ) SELECT 1 FROM 
0850: 77 6f 72 64 63 6f 75 6e 74 20 57 48 45 52 45 20  wordcount WHERE 
0860: 77 6f 72 64 3d 24 6e 65 77 0a 2a 2a 20 20 20 20  word=$new.**    
0870: 28 32 29 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  (2) INSERT INTO 
0880: 77 6f 72 64 63 6f 75 6e 74 20 56 41 4c 55 45 53  wordcount VALUES
0890: 28 24 6e 65 77 2c 31 29 20 2d 2d 20 69 66 20 28  ($new,1) -- if (
08a0: 31 29 20 72 65 74 75 72 6e 73 20 6e 6f 74 68 69  1) returns nothi
08b0: 6e 67 0a 2a 2a 20 20 20 20 28 33 29 20 55 50 44  ng.**    (3) UPD
08c0: 41 54 45 20 77 6f 72 64 63 6f 75 6e 74 20 53 45  ATE wordcount SE
08d0: 54 20 63 6e 74 3d 63 6e 74 2b 31 20 57 48 45 52  T cnt=cnt+1 WHER
08e0: 45 20 77 6f 72 64 3d 24 6e 65 77 20 20 2d 2d 69  E word=$new  --i
08f0: 66 20 28 31 29 20 72 65 74 75 72 6e 20 54 52 55  f (1) return TRU
0900: 45 0a 2a 2a 0a 2a 2a 20 44 65 6c 65 74 65 20 6d  E.**.** Delete m
0910: 6f 64 65 20 6d 65 61 6e 73 3a 0a 2a 2a 20 20 20  ode means:.**   
0920: 20 28 31 29 20 44 45 4c 45 54 45 20 46 52 4f 4d   (1) DELETE FROM
0930: 20 77 6f 72 64 63 6f 75 6e 74 20 57 48 45 52 45   wordcount WHERE
0940: 20 77 6f 72 64 3d 24 6e 65 77 0a 2a 2a 0a 2a 2a   word=$new.**.**
0950: 20 51 75 65 72 79 20 6d 6f 64 65 20 6d 65 61 6e   Query mode mean
0960: 73 3a 0a 2a 2a 20 20 20 20 28 31 29 20 53 45 4c  s:.**    (1) SEL
0970: 45 43 54 20 63 6e 74 20 46 52 4f 4d 20 77 6f 72  ECT cnt FROM wor
0980: 64 63 6f 75 6e 74 20 57 48 45 52 45 20 77 6f 72  dcount WHERE wor
0990: 64 3d 24 6e 65 77 0a 2a 2a 0a 2a 2a 20 4e 6f 74  d=$new.**.** Not
09a0: 65 20 74 68 61 74 20 64 65 6c 65 74 65 20 6d 6f  e that delete mo
09b0: 64 65 20 61 6e 64 20 71 75 65 72 79 20 6d 6f 64  de and query mod
09c0: 65 20 61 72 65 20 6f 6e 6c 79 20 75 73 65 66 75  e are only usefu
09d0: 6c 20 66 6f 72 20 70 72 65 65 78 69 73 74 69 6e  l for preexistin
09e0: 67 0a 2a 2a 20 64 61 74 61 62 61 73 65 73 2e 20  g.** databases. 
09f0: 20 54 68 65 20 77 6f 72 64 63 6f 75 6e 74 20 74   The wordcount t
0a00: 61 62 6c 65 20 69 73 20 63 72 65 61 74 65 64 20  able is created 
0a10: 75 73 69 6e 67 20 49 46 20 4e 4f 54 20 45 58 49  using IF NOT EXI
0a20: 53 54 53 20 73 6f 20 74 68 69 73 0a 2a 2a 20 75  STS so this.** u
0a30: 74 69 6c 69 74 79 20 63 61 6e 20 62 65 20 72 75  tility can be ru
0a40: 6e 20 6d 75 6c 74 69 70 6c 65 20 74 69 6d 65 73  n multiple times
0a50: 20 6f 6e 20 74 68 65 20 73 61 6d 65 20 64 61 74   on the same dat
0a60: 61 62 61 73 65 20 66 69 6c 65 2e 20 20 54 68 65  abase file.  The
0a70: 0a 2a 2a 20 2d 2d 77 69 74 68 6f 75 74 2d 72 6f  .** --without-ro
0a80: 77 69 64 2c 20 2d 2d 6e 6f 63 61 73 65 2c 20 61  wid, --nocase, a
0a90: 6e 64 20 2d 2d 70 61 67 65 73 69 7a 65 20 70 61  nd --pagesize pa
0aa0: 72 61 6d 65 74 65 72 73 20 61 72 65 20 6f 6e 6c  rameters are onl
0ab0: 79 20 65 66 66 65 63 74 69 76 65 0a 2a 2a 20 77  y effective.** w
0ac0: 68 65 6e 20 63 72 65 61 74 69 6e 67 20 61 20 6e  hen creating a n
0ad0: 65 77 20 64 61 74 61 62 61 73 65 20 61 6e 64 20  ew database and 
0ae0: 61 72 65 20 68 61 72 6d 6c 65 73 73 20 6e 6f 2d  are harmless no-
0af0: 6f 70 73 20 6f 6e 20 70 72 65 65 78 69 73 74 69  ops on preexisti
0b00: 6e 67 0a 2a 2a 20 64 61 74 61 62 61 73 65 73 2e  ng.** databases.
0b10: 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .**.************
0b20: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0b30: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0b40: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0b50: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0b60: 2a 2a 0a 2a 2a 0a 2a 2a 20 43 6f 6d 70 69 6c 65  **.**.** Compile
0b70: 20 61 73 20 66 6f 6c 6c 6f 77 73 3a 0a 2a 2a 0a   as follows:.**.
0b80: 2a 2a 20 20 20 20 67 63 63 20 2d 49 2e 20 77 6f  **    gcc -I. wo
0b90: 72 64 63 6f 75 6e 74 2e 63 20 73 71 6c 69 74 65  rdcount.c sqlite
0ba0: 33 2e 63 20 2d 6c 64 6c 20 2d 6c 70 74 68 72 65  3.c -ldl -lpthre
0bb0: 61 64 73 0a 2a 2a 0a 2a 2a 20 4f 72 3a 0a 2a 2a  ads.**.** Or:.**
0bc0: 0a 2a 2a 20 20 20 20 67 63 63 20 2d 49 2e 20 2d  .**    gcc -I. -
0bd0: 44 53 51 4c 49 54 45 5f 54 48 52 45 41 44 53 41  DSQLITE_THREADSA
0be0: 46 45 3d 30 20 2d 44 53 51 4c 49 54 45 5f 4f 4d  FE=0 -DSQLITE_OM
0bf0: 49 54 5f 4c 4f 41 44 5f 45 58 54 45 4e 53 49 4f  IT_LOAD_EXTENSIO
0c00: 4e 20 5c 0a 2a 2a 20 20 20 20 20 20 20 20 77 6f  N \.**        wo
0c10: 72 64 63 6f 75 6e 74 2e 63 20 73 71 6c 69 74 65  rdcount.c sqlite
0c20: 33 2e 63 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20  3.c.*/.#include 
0c30: 3c 73 74 64 69 6f 2e 68 3e 0a 23 69 6e 63 6c 75  <stdio.h>.#inclu
0c40: 64 65 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69  de <string.h>.#i
0c50: 6e 63 6c 75 64 65 20 3c 63 74 79 70 65 2e 68 3e  nclude <ctype.h>
0c60: 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 64 6c 69  .#include <stdli
0c70: 62 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73  b.h>.#include <s
0c80: 74 64 61 72 67 2e 68 3e 0a 23 69 6e 63 6c 75 64  tdarg.h>.#includ
0c90: 65 20 22 73 71 6c 69 74 65 33 2e 68 22 0a 23 64  e "sqlite3.h".#d
0ca0: 65 66 69 6e 65 20 49 53 41 4c 50 48 41 28 58 29  efine ISALPHA(X)
0cb0: 20 69 73 61 6c 70 68 61 28 28 75 6e 73 69 67 6e   isalpha((unsign
0cc0: 65 64 20 63 68 61 72 29 28 58 29 29 0a 0a 2f 2a  ed char)(X))../*
0cd0: 20 4f 75 74 70 75 74 20 74 61 67 20 2a 2f 0a 63   Output tag */.c
0ce0: 68 61 72 20 2a 7a 54 61 67 20 3d 20 22 2d 2d 22  har *zTag = "--"
0cf0: 3b 0a 0a 2f 2a 20 52 65 74 75 72 6e 20 74 68 65  ;../* Return the
0d00: 20 63 75 72 72 65 6e 74 20 77 61 6c 6c 2d 63 6c   current wall-cl
0d10: 6f 63 6b 20 74 69 6d 65 20 2a 2f 0a 73 74 61 74  ock time */.stat
0d20: 69 63 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34  ic sqlite3_int64
0d30: 20 72 65 61 6c 54 69 6d 65 28 76 6f 69 64 29 7b   realTime(void){
0d40: 0a 20 20 73 74 61 74 69 63 20 73 71 6c 69 74 65  .  static sqlite
0d50: 33 5f 76 66 73 20 2a 63 6c 6f 63 6b 56 66 73 20  3_vfs *clockVfs 
0d60: 3d 20 30 3b 0a 20 20 73 71 6c 69 74 65 33 5f 69  = 0;.  sqlite3_i
0d70: 6e 74 36 34 20 74 3b 0a 20 20 69 66 28 20 63 6c  nt64 t;.  if( cl
0d80: 6f 63 6b 56 66 73 3d 3d 30 20 29 20 63 6c 6f 63  ockVfs==0 ) cloc
0d90: 6b 56 66 73 20 3d 20 73 71 6c 69 74 65 33 5f 76  kVfs = sqlite3_v
0da0: 66 73 5f 66 69 6e 64 28 30 29 3b 0a 20 20 69 66  fs_find(0);.  if
0db0: 28 20 63 6c 6f 63 6b 56 66 73 2d 3e 69 56 65 72  ( clockVfs->iVer
0dc0: 73 69 6f 6e 3e 3d 31 20 26 26 20 63 6c 6f 63 6b  sion>=1 && clock
0dd0: 56 66 73 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d  Vfs->xCurrentTim
0de0: 65 49 6e 74 36 34 21 3d 30 20 29 7b 0a 20 20 20  eInt64!=0 ){.   
0df0: 20 63 6c 6f 63 6b 56 66 73 2d 3e 78 43 75 72 72   clockVfs->xCurr
0e00: 65 6e 74 54 69 6d 65 49 6e 74 36 34 28 63 6c 6f  entTimeInt64(clo
0e10: 63 6b 56 66 73 2c 20 26 74 29 3b 0a 20 20 7d 65  ckVfs, &t);.  }e
0e20: 6c 73 65 7b 0a 20 20 20 20 64 6f 75 62 6c 65 20  lse{.    double 
0e30: 72 3b 0a 20 20 20 20 63 6c 6f 63 6b 56 66 73 2d  r;.    clockVfs-
0e40: 3e 78 43 75 72 72 65 6e 74 54 69 6d 65 28 63 6c  >xCurrentTime(cl
0e50: 6f 63 6b 56 66 73 2c 20 26 72 29 3b 0a 20 20 20  ockVfs, &r);.   
0e60: 20 74 20 3d 20 28 73 71 6c 69 74 65 33 5f 69 6e   t = (sqlite3_in
0e70: 74 36 34 29 28 72 2a 38 36 34 30 30 30 30 30 2e  t64)(r*86400000.
0e80: 30 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e  0);.  }.  return
0e90: 20 74 3b 0a 7d 0a 0a 2f 2a 20 50 72 69 6e 74 20   t;.}../* Print 
0ea0: 61 6e 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65  an error message
0eb0: 20 61 6e 64 20 65 78 69 74 20 2a 2f 0a 73 74 61   and exit */.sta
0ec0: 74 69 63 20 76 6f 69 64 20 66 61 74 61 6c 5f 65  tic void fatal_e
0ed0: 72 72 6f 72 28 63 6f 6e 73 74 20 63 68 61 72 20  rror(const char 
0ee0: 2a 7a 4d 73 67 2c 20 2e 2e 2e 29 7b 0a 20 20 76  *zMsg, ...){.  v
0ef0: 61 5f 6c 69 73 74 20 61 70 3b 0a 20 20 76 61 5f  a_list ap;.  va_
0f00: 73 74 61 72 74 28 61 70 2c 20 7a 4d 73 67 29 3b  start(ap, zMsg);
0f10: 0a 20 20 76 66 70 72 69 6e 74 66 28 73 74 64 65  .  vfprintf(stde
0f20: 72 72 2c 20 7a 4d 73 67 2c 20 61 70 29 3b 0a 20  rr, zMsg, ap);. 
0f30: 20 76 61 5f 65 6e 64 28 61 70 29 3b 0a 20 20 65   va_end(ap);.  e
0f40: 78 69 74 28 31 29 3b 0a 7d 0a 0a 2f 2a 20 54 68  xit(1);.}../* Th
0f50: 65 20 73 71 6c 69 74 65 33 5f 74 72 61 63 65 28  e sqlite3_trace(
0f60: 29 20 63 61 6c 6c 62 61 63 6b 20 66 75 6e 63 74  ) callback funct
0f70: 69 6f 6e 20 2a 2f 0a 73 74 61 74 69 63 20 76 6f  ion */.static vo
0f80: 69 64 20 74 72 61 63 65 43 61 6c 6c 62 61 63 6b  id traceCallback
0f90: 28 76 6f 69 64 20 2a 4e 6f 74 55 73 65 64 2c 20  (void *NotUsed, 
0fa0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53 71 6c  const char *zSql
0fb0: 29 7b 0a 20 20 70 72 69 6e 74 66 28 22 25 73 3b  ){.  printf("%s;
0fc0: 5c 6e 22 2c 20 7a 53 71 6c 29 3b 0a 7d 0a 0a 2f  \n", zSql);.}../
0fd0: 2a 20 41 6e 20 73 71 6c 69 74 65 33 5f 65 78 65  * An sqlite3_exe
0fe0: 63 28 29 20 63 61 6c 6c 62 61 63 6b 20 74 68 61  c() callback tha
0ff0: 74 20 70 72 69 6e 74 73 20 72 65 73 75 6c 74 73  t prints results
1000: 20 6f 6e 20 73 74 61 6e 64 61 72 64 20 6f 75 74   on standard out
1010: 70 75 74 2c 0a 2a 2a 20 65 61 63 68 20 63 6f 6c  put,.** each col
1020: 75 6d 6e 20 73 65 70 61 72 61 74 65 64 20 62 79  umn separated by
1030: 20 61 20 73 69 6e 67 6c 65 20 73 70 61 63 65 2e   a single space.
1040: 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 70   */.static int p
1050: 72 69 6e 74 52 65 73 75 6c 74 28 76 6f 69 64 20  rintResult(void 
1060: 2a 4e 6f 74 55 73 65 64 2c 20 69 6e 74 20 6e 41  *NotUsed, int nA
1070: 72 67 2c 20 63 68 61 72 20 2a 2a 61 7a 41 72 67  rg, char **azArg
1080: 2c 20 63 68 61 72 20 2a 2a 61 7a 4e 6d 29 7b 0a  , char **azNm){.
1090: 20 20 69 6e 74 20 69 3b 0a 20 20 70 72 69 6e 74    int i;.  print
10a0: 66 28 22 25 73 22 2c 20 7a 54 61 67 29 3b 0a 20  f("%s", zTag);. 
10b0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67   for(i=0; i<nArg
10c0: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 70 72 69 6e  ; i++){.    prin
10d0: 74 66 28 22 20 25 73 22 2c 20 61 7a 41 72 67 5b  tf(" %s", azArg[
10e0: 69 5d 20 3f 20 61 7a 41 72 67 5b 69 5d 20 3a 20  i] ? azArg[i] : 
10f0: 22 28 6e 75 6c 6c 29 22 29 3b 0a 20 20 7d 0a 20  "(null)");.  }. 
1100: 20 70 72 69 6e 74 66 28 22 5c 6e 22 29 3b 0a 20   printf("\n");. 
1110: 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 0a 2f   return 0;.}.../
1120: 2a 0a 2a 2a 20 41 64 64 20 6f 6e 65 20 63 68 61  *.** Add one cha
1130: 72 61 63 74 65 72 20 74 6f 20 61 20 68 61 73 68  racter to a hash
1140: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
1150: 61 64 64 43 68 61 72 54 6f 48 61 73 68 28 75 6e  addCharToHash(un
1160: 73 69 67 6e 65 64 20 69 6e 74 20 2a 61 2c 20 75  signed int *a, u
1170: 6e 73 69 67 6e 65 64 20 63 68 61 72 20 78 29 7b  nsigned char x){
1180: 0a 20 20 69 66 28 20 61 5b 30 5d 3c 34 20 29 7b  .  if( a[0]<4 ){
1190: 0a 20 20 20 20 61 5b 31 5d 20 3d 20 28 61 5b 31  .    a[1] = (a[1
11a0: 5d 3c 3c 38 29 20 7c 20 78 3b 0a 20 20 20 20 61  ]<<8) | x;.    a
11b0: 5b 30 5d 2b 2b 3b 0a 20 20 7d 65 6c 73 65 7b 0a  [0]++;.  }else{.
11c0: 20 20 20 20 61 5b 32 5d 20 3d 20 28 61 5b 32 5d      a[2] = (a[2]
11d0: 3c 3c 38 29 20 7c 20 78 3b 0a 20 20 20 20 61 5b  <<8) | x;.    a[
11e0: 30 5d 2b 2b 3b 0a 20 20 20 20 69 66 28 20 61 5b  0]++;.    if( a[
11f0: 30 5d 3d 3d 38 20 29 7b 0a 20 20 20 20 20 20 61  0]==8 ){.      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 3b 0a 20 20 20 20 20 20 61 5b 34 5d 20 2b  4];.      a[4] +
1220: 3d 20 61 5b 32 5d 20 2b 20 61 5b 33 5d 3b 0a 20  = a[2] + a[3];. 
1230: 20 20 20 20 20 61 5b 30 5d 20 3d 20 61 5b 31 5d       a[0] = a[1]
1240: 20 3d 20 61 5b 32 5d 20 3d 20 30 3b 0a 20 20 20   = a[2] = 0;.   
1250: 20 7d 0a 20 20 7d 20 20 20 20 0a 7d 0a 0a 2f 2a   }.  }    .}../*
1260: 0a 2a 2a 20 43 6f 6d 70 75 74 65 20 74 68 65 20  .** Compute the 
1270: 66 69 6e 61 6c 20 68 61 73 68 20 76 61 6c 75 65  final hash value
1280: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  ..*/.static void
1290: 20 66 69 6e 61 6c 48 61 73 68 28 75 6e 73 69 67   finalHash(unsig
12a0: 6e 65 64 20 69 6e 74 20 2a 61 2c 20 63 68 61 72  ned int *a, char
12b0: 20 2a 7a 29 7b 0a 20 20 61 5b 33 5d 20 2b 3d 20   *z){.  a[3] += 
12c0: 61 5b 31 5d 20 2b 20 61 5b 34 5d 20 2b 20 61 5b  a[1] + a[4] + a[
12d0: 30 5d 3b 0a 20 20 61 5b 34 5d 20 2b 3d 20 61 5b  0];.  a[4] += a[
12e0: 32 5d 20 2b 20 61 5b 33 5d 3b 0a 20 20 73 71 6c  2] + a[3];.  sql
12f0: 69 74 65 33 5f 73 6e 70 72 69 6e 74 66 28 31 37  ite3_snprintf(17
1300: 2c 20 7a 2c 20 22 25 30 38 78 25 30 38 78 22 2c  , z, "%08x%08x",
1310: 20 61 5b 33 5d 2c 20 61 5b 34 5d 29 3b 0a 7d 0a   a[3], a[4]);.}.
1320: 0a 0a 2f 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e  ../*.** Implemen
1330: 74 61 74 69 6f 6e 20 6f 66 20 61 20 63 68 65 63  tation of a chec
1340: 6b 73 75 6d 28 29 20 61 67 67 72 65 67 61 74 65  ksum() aggregate
1350: 20 53 51 4c 20 66 75 6e 63 74 69 6f 6e 0a 2a 2f   SQL function.*/
1360: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 63 68 65  .static void che
1370: 63 6b 73 75 6d 53 74 65 70 28 0a 20 20 73 71 6c  cksumStep(.  sql
1380: 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 63 6f  ite3_context *co
1390: 6e 74 65 78 74 2c 0a 20 20 69 6e 74 20 61 72 67  ntext,.  int arg
13a0: 63 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61 6c  c,.  sqlite3_val
13b0: 75 65 20 2a 2a 61 72 67 76 0a 29 7b 0a 20 20 63  ue **argv.){.  c
13c0: 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68  onst unsigned ch
13d0: 61 72 20 2a 7a 56 61 6c 3b 0a 20 20 69 6e 74 20  ar *zVal;.  int 
13e0: 6e 56 61 6c 2c 20 69 2c 20 6a 3b 0a 20 20 75 6e  nVal, i, j;.  un
13f0: 73 69 67 6e 65 64 20 69 6e 74 20 2a 61 3b 0a 20  signed int *a;. 
1400: 20 61 20 3d 20 28 75 6e 73 69 67 6e 65 64 2a 29   a = (unsigned*)
1410: 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67 61 74  sqlite3_aggregat
1420: 65 5f 63 6f 6e 74 65 78 74 28 63 6f 6e 74 65 78  e_context(contex
1430: 74 2c 20 73 69 7a 65 6f 66 28 75 6e 73 69 67 6e  t, sizeof(unsign
1440: 65 64 20 69 6e 74 29 2a 35 29 3b 0a 0a 20 20 69  ed int)*5);..  i
1450: 66 28 20 61 20 29 7b 0a 20 20 20 20 66 6f 72 28  f( a ){.    for(
1460: 69 3d 30 3b 20 69 3c 61 72 67 63 3b 20 69 2b 2b  i=0; i<argc; i++
1470: 29 7b 0a 20 20 20 20 20 20 6e 56 61 6c 20 3d 20  ){.      nVal = 
1480: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 79  sqlite3_value_by
1490: 74 65 73 28 61 72 67 76 5b 69 5d 29 3b 0a 20 20  tes(argv[i]);.  
14a0: 20 20 20 20 7a 56 61 6c 20 3d 20 28 63 6f 6e 73      zVal = (cons
14b0: 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 2a  t unsigned char*
14c0: 29 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74  )sqlite3_value_t
14d0: 65 78 74 28 61 72 67 76 5b 69 5d 29 3b 0a 20 20  ext(argv[i]);.  
14e0: 20 20 20 20 69 66 28 20 7a 56 61 6c 20 29 20 66      if( zVal ) f
14f0: 6f 72 28 6a 3d 30 3b 20 6a 3c 6e 56 61 6c 3b 20  or(j=0; j<nVal; 
1500: 6a 2b 2b 29 20 61 64 64 43 68 61 72 54 6f 48 61  j++) addCharToHa
1510: 73 68 28 61 2c 20 7a 56 61 6c 5b 6a 5d 29 3b 0a  sh(a, zVal[j]);.
1520: 20 20 20 20 20 20 61 64 64 43 68 61 72 54 6f 48        addCharToH
1530: 61 73 68 28 61 2c 20 27 7c 27 29 3b 0a 20 20 20  ash(a, '|');.   
1540: 20 7d 0a 20 20 20 20 61 64 64 43 68 61 72 54 6f   }.    addCharTo
1550: 48 61 73 68 28 61 2c 20 27 5c 6e 27 29 3b 0a 20  Hash(a, '\n');. 
1560: 20 7d 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69 64   }.}.static void
1570: 20 63 68 65 63 6b 73 75 6d 46 69 6e 61 6c 69 7a   checksumFinaliz
1580: 65 28 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78  e(sqlite3_contex
1590: 74 20 2a 63 6f 6e 74 65 78 74 29 7b 0a 20 20 75  t *context){.  u
15a0: 6e 73 69 67 6e 65 64 20 69 6e 74 20 2a 61 3b 0a  nsigned int *a;.
15b0: 20 20 63 68 61 72 20 7a 52 65 73 75 6c 74 5b 32    char zResult[2
15c0: 34 5d 3b 0a 20 20 61 20 3d 20 73 71 6c 69 74 65  4];.  a = sqlite
15d0: 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74  3_aggregate_cont
15e0: 65 78 74 28 63 6f 6e 74 65 78 74 2c 20 30 29 3b  ext(context, 0);
15f0: 0a 20 20 69 66 28 20 61 20 29 7b 0a 20 20 20 20  .  if( a ){.    
1600: 66 69 6e 61 6c 48 61 73 68 28 61 2c 20 7a 52 65  finalHash(a, zRe
1610: 73 75 6c 74 29 3b 0a 20 20 20 20 73 71 6c 69 74  sult);.    sqlit
1620: 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74 28 63  e3_result_text(c
1630: 6f 6e 74 65 78 74 2c 20 7a 52 65 73 75 6c 74 2c  ontext, zResult,
1640: 20 2d 31 2c 20 53 51 4c 49 54 45 5f 54 52 41 4e   -1, SQLITE_TRAN
1650: 53 49 45 4e 54 29 3b 0a 20 20 7d 0a 7d 0a 0a 0a  SIENT);.  }.}...
1660: 2f 2a 20 44 65 66 69 6e 65 20 6f 70 65 72 61 74  /* Define operat
1670: 69 6e 67 20 6d 6f 64 65 73 20 2a 2f 0a 23 64 65  ing modes */.#de
1680: 66 69 6e 65 20 4d 4f 44 45 5f 49 4e 53 45 52 54  fine MODE_INSERT
1690: 20 20 20 20 20 30 0a 23 64 65 66 69 6e 65 20 4d       0.#define M
16a0: 4f 44 45 5f 52 45 50 4c 41 43 45 20 20 20 20 31  ODE_REPLACE    1
16b0: 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f 53 45  .#define MODE_SE
16c0: 4c 45 43 54 20 20 20 20 20 32 0a 23 64 65 66 69  LECT     2.#defi
16d0: 6e 65 20 4d 4f 44 45 5f 55 50 44 41 54 45 20 20  ne MODE_UPDATE  
16e0: 20 20 20 33 0a 23 64 65 66 69 6e 65 20 4d 4f 44     3.#define MOD
16f0: 45 5f 44 45 4c 45 54 45 20 20 20 20 20 34 0a 23  E_DELETE     4.#
1700: 64 65 66 69 6e 65 20 4d 4f 44 45 5f 51 55 45 52  define MODE_QUER
1710: 59 20 20 20 20 20 20 35 0a 0a 69 6e 74 20 6d 61  Y      5..int ma
1720: 69 6e 28 69 6e 74 20 61 72 67 63 2c 20 63 68 61  in(int argc, cha
1730: 72 20 2a 2a 61 72 67 76 29 7b 0a 20 20 63 6f 6e  r **argv){.  con
1740: 73 74 20 63 68 61 72 20 2a 7a 46 69 6c 65 54 6f  st char *zFileTo
1750: 52 65 61 64 20 3d 20 30 3b 20 20 2f 2a 20 49 6e  Read = 0;  /* In
1760: 70 75 74 20 66 69 6c 65 2e 20 20 4e 55 4c 4c 20  put file.  NULL 
1770: 66 6f 72 20 73 74 64 69 6e 20 2a 2f 0a 20 20 63  for stdin */.  c
1780: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 4e 61  onst char *zDbNa
1790: 6d 65 20 3d 20 30 3b 20 20 20 20 20 20 2f 2a 20  me = 0;      /* 
17a0: 4e 61 6d 65 20 6f 66 20 74 68 65 20 64 61 74 61  Name of the data
17b0: 62 61 73 65 20 66 69 6c 65 20 74 6f 20 63 72 65  base file to cre
17c0: 61 74 65 20 2a 2f 0a 20 20 69 6e 74 20 75 73 65  ate */.  int use
17d0: 57 69 74 68 6f 75 74 52 6f 77 69 64 20 3d 20 30  WithoutRowid = 0
17e0: 3b 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 66  ;      /* True f
17f0: 6f 72 20 2d 2d 77 69 74 68 6f 75 74 2d 72 6f 77  or --without-row
1800: 69 64 20 2a 2f 0a 20 20 69 6e 74 20 69 4d 6f 64  id */.  int iMod
1810: 65 20 3d 20 4d 4f 44 45 5f 49 4e 53 45 52 54 3b  e = MODE_INSERT;
1820: 20 20 20 20 20 20 2f 2a 20 4f 6e 65 20 6f 66 20        /* One of 
1830: 4d 4f 44 45 5f 78 78 78 78 78 20 2a 2f 0a 20 20  MODE_xxxxx */.  
1840: 69 6e 74 20 75 73 65 4e 6f 63 61 73 65 20 3d 20  int useNocase = 
1850: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  0;            /*
1860: 20 54 72 75 65 20 66 6f 72 20 2d 2d 6e 6f 63 61   True for --noca
1870: 73 65 20 2a 2f 0a 20 20 69 6e 74 20 64 6f 54 72  se */.  int doTr
1880: 61 63 65 20 3d 20 30 3b 20 20 20 20 20 20 20 20  ace = 0;        
1890: 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 66 6f        /* True fo
18a0: 72 20 2d 2d 74 72 61 63 65 20 2a 2f 0a 20 20 69  r --trace */.  i
18b0: 6e 74 20 73 68 6f 77 53 74 61 74 73 20 3d 20 30  nt showStats = 0
18c0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  ;            /* 
18d0: 54 72 75 65 20 66 6f 72 20 2d 2d 73 74 61 74 73  True for --stats
18e0: 20 2a 2f 0a 20 20 69 6e 74 20 73 68 6f 77 53 75   */.  int showSu
18f0: 6d 6d 61 72 79 20 3d 20 30 3b 20 20 20 20 20 20  mmary = 0;      
1900: 20 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20      /* True for 
1910: 2d 2d 73 75 6d 6d 61 72 79 20 2a 2f 0a 20 20 69  --summary */.  i
1920: 6e 74 20 73 68 6f 77 54 69 6d 65 72 20 3d 20 30  nt showTimer = 0
1930: 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  ;            /* 
1940: 54 72 75 65 20 66 6f 72 20 2d 2d 74 69 6d 65 72  True for --timer
1950: 20 2a 2f 0a 20 20 69 6e 74 20 63 61 63 68 65 53   */.  int cacheS
1960: 69 7a 65 20 3d 20 30 3b 20 20 20 20 20 20 20 20  ize = 0;        
1970: 20 20 20 20 2f 2a 20 44 65 73 69 72 65 64 20 63      /* Desired c
1980: 61 63 68 65 20 73 69 7a 65 2e 20 20 30 20 6d 65  ache size.  0 me
1990: 61 6e 73 20 64 65 66 61 75 6c 74 20 2a 2f 0a 20  ans default */. 
19a0: 20 69 6e 74 20 70 61 67 65 53 69 7a 65 20 3d 20   int pageSize = 
19b0: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  0;             /
19c0: 2a 20 44 65 73 69 72 65 64 20 70 61 67 65 20 73  * Desired page s
19d0: 69 7a 65 2e 20 20 30 20 6d 65 61 6e 73 20 64 65  ize.  0 means de
19e0: 66 61 75 6c 74 20 2a 2f 0a 20 20 69 6e 74 20 63  fault */.  int c
19f0: 6f 6d 6d 69 74 49 6e 74 65 72 76 61 6c 20 3d 20  ommitInterval = 
1a00: 30 3b 20 20 20 20 20 20 20 2f 2a 20 48 6f 77 20  0;       /* How 
1a10: 6f 66 74 65 6e 20 74 6f 20 63 6f 6d 6d 69 74 2e  often to commit.
1a20: 20 20 30 20 6d 65 61 6e 73 20 6e 65 76 65 72 20    0 means never 
1a30: 2a 2f 0a 20 20 69 6e 74 20 6e 6f 53 79 6e 63 20  */.  int noSync 
1a40: 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20  = 0;            
1a50: 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20 2d     /* True for -
1a60: 2d 6e 6f 73 79 6e 63 20 2a 2f 0a 20 20 63 6f 6e  -nosync */.  con
1a70: 73 74 20 63 68 61 72 20 2a 7a 4a 4d 6f 64 65 20  st char *zJMode 
1a80: 3d 20 30 3b 20 20 20 20 20 20 20 2f 2a 20 4a 6f  = 0;       /* Jo
1a90: 75 72 6e 61 6c 20 6d 6f 64 65 20 2a 2f 0a 20 20  urnal mode */.  
1aa0: 69 6e 74 20 6e 4f 70 20 3d 20 30 3b 20 20 20 20  int nOp = 0;    
1ab0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
1ac0: 20 4f 70 65 72 61 74 69 6f 6e 20 63 6f 75 6e 74   Operation count
1ad0: 65 72 20 2a 2f 0a 20 20 69 6e 74 20 69 2c 20 6a  er */.  int i, j
1ae0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
1af0: 20 20 20 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f        /* Loop co
1b00: 75 6e 74 65 72 73 20 2a 2f 0a 20 20 73 71 6c 69  unters */.  sqli
1b10: 74 65 33 20 2a 64 62 3b 20 20 20 20 20 20 20 20  te3 *db;        
1b20: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65            /* The
1b30: 20 53 51 4c 69 74 65 20 64 61 74 61 62 61 73 65   SQLite database
1b40: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a 20   connection */. 
1b50: 20 63 68 61 72 20 2a 7a 53 71 6c 3b 20 20 20 20   char *zSql;    
1b60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
1b70: 2a 20 43 6f 6e 73 74 72 75 63 74 65 64 20 53 51  * Constructed SQ
1b80: 4c 20 73 74 61 74 65 6d 65 6e 74 20 2a 2f 0a 20  L statement */. 
1b90: 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70   sqlite3_stmt *p
1ba0: 49 6e 73 65 72 74 20 3d 20 30 3b 20 20 20 20 2f  Insert = 0;    /
1bb0: 2a 20 54 68 65 20 49 4e 53 45 52 54 20 73 74 61  * The INSERT sta
1bc0: 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 73 71 6c 69  tement */.  sqli
1bd0: 74 65 33 5f 73 74 6d 74 20 2a 70 55 70 64 61 74  te3_stmt *pUpdat
1be0: 65 20 3d 20 30 3b 20 20 20 20 2f 2a 20 54 68 65  e = 0;    /* The
1bf0: 20 55 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e   UPDATE statemen
1c00: 74 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 73  t */.  sqlite3_s
1c10: 74 6d 74 20 2a 70 53 65 6c 65 63 74 20 3d 20 30  tmt *pSelect = 0
1c20: 3b 20 20 20 20 2f 2a 20 54 68 65 20 53 45 4c 45  ;    /* The SELE
1c30: 43 54 20 73 74 61 74 65 6d 65 6e 74 20 2a 2f 0a  CT statement */.
1c40: 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a    sqlite3_stmt *
1c50: 70 44 65 6c 65 74 65 20 3d 20 30 3b 20 20 20 20  pDelete = 0;    
1c60: 2f 2a 20 54 68 65 20 44 45 4c 45 54 45 20 73 74  /* The DELETE st
1c70: 61 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 46 49 4c  atement */.  FIL
1c80: 45 20 2a 69 6e 3b 20 20 20 20 20 20 20 20 20 20  E *in;          
1c90: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68             /* Th
1ca0: 65 20 6f 70 65 6e 20 69 6e 70 75 74 20 66 69 6c  e open input fil
1cb0: 65 20 2a 2f 0a 20 20 69 6e 74 20 72 63 3b 20 20  e */.  int rc;  
1cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1cd0: 20 20 20 20 20 2f 2a 20 52 65 74 75 72 6e 20 63       /* Return c
1ce0: 6f 64 65 20 66 72 6f 6d 20 61 6e 20 53 51 4c 69  ode from an SQLi
1cf0: 74 65 20 69 6e 74 65 72 66 61 63 65 20 2a 2f 0a  te interface */.
1d00: 20 20 69 6e 74 20 69 43 75 72 2c 20 69 48 69 77    int iCur, iHiw
1d10: 74 72 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  tr;             
1d20: 2f 2a 20 53 74 61 74 69 73 74 69 63 73 20 76 61  /* Statistics va
1d30: 6c 75 65 73 2c 20 63 75 72 72 65 6e 74 20 61 6e  lues, current an
1d40: 64 20 22 68 69 67 68 77 61 74 65 72 22 20 2a 2f  d "highwater" */
1d50: 0a 20 20 46 49 4c 45 20 2a 70 54 69 6d 65 72 20  .  FILE *pTimer 
1d60: 3d 20 73 74 64 65 72 72 3b 20 20 20 20 20 20 20  = stderr;       
1d70: 20 2f 2a 20 4f 75 74 70 75 74 20 63 68 61 6e 6e   /* Output chann
1d80: 65 6c 20 66 6f 72 20 74 68 65 20 74 69 6d 65 72  el for the timer
1d90: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e   */.  sqlite3_in
1da0: 74 36 34 20 73 75 6d 43 6e 74 20 3d 20 30 3b 20  t64 sumCnt = 0; 
1db0: 20 20 20 20 2f 2a 20 53 75 6d 20 69 6e 20 51 55      /* Sum in QU
1dc0: 45 52 59 20 6d 6f 64 65 20 2a 2f 0a 20 20 73 71  ERY mode */.  sq
1dd0: 6c 69 74 65 33 5f 69 6e 74 36 34 20 73 74 61 72  lite3_int64 star
1de0: 74 54 69 6d 65 3b 0a 20 20 63 68 61 72 20 7a 49  tTime;.  char zI
1df0: 6e 70 75 74 5b 32 30 30 30 5d 3b 20 20 20 20 20  nput[2000];     
1e00: 20 20 20 20 20 20 20 2f 2a 20 41 20 73 69 6e 67         /* A sing
1e10: 6c 65 20 6c 69 6e 65 20 6f 66 20 69 6e 70 75 74  le line of input
1e20: 20 2a 2f 0a 0a 20 20 2f 2a 20 50 72 6f 63 65 73   */..  /* Proces
1e30: 73 20 63 6f 6d 6d 61 6e 64 2d 6c 69 6e 65 20 61  s command-line a
1e40: 72 67 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 66 6f  rguments */.  fo
1e50: 72 28 69 3d 31 3b 20 69 3c 61 72 67 63 3b 20 69  r(i=1; i<argc; i
1e60: 2b 2b 29 7b 0a 20 20 20 20 63 6f 6e 73 74 20 63  ++){.    const c
1e70: 68 61 72 20 2a 7a 20 3d 20 61 72 67 76 5b 69 5d  har *z = argv[i]
1e80: 3b 0a 20 20 20 20 69 66 28 20 7a 5b 30 5d 3d 3d  ;.    if( z[0]==
1e90: 27 2d 27 20 29 7b 0a 20 20 20 20 20 20 64 6f 7b  '-' ){.      do{
1ea0: 20 7a 2b 2b 3b 20 7d 77 68 69 6c 65 28 20 7a 5b   z++; }while( z[
1eb0: 30 5d 3d 3d 27 2d 27 20 29 3b 0a 20 20 20 20 20  0]=='-' );.     
1ec0: 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 77   if( strcmp(z,"w
1ed0: 69 74 68 6f 75 74 2d 72 6f 77 69 64 22 29 3d 3d  ithout-rowid")==
1ee0: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 75 73 65  0 ){.        use
1ef0: 57 69 74 68 6f 75 74 52 6f 77 69 64 20 3d 20 31  WithoutRowid = 1
1f00: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66  ;.      }else if
1f10: 28 20 73 74 72 63 6d 70 28 7a 2c 22 72 65 70 6c  ( strcmp(z,"repl
1f20: 61 63 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ace")==0 ){.    
1f30: 20 20 20 20 69 4d 6f 64 65 20 3d 20 4d 4f 44 45      iMode = MODE
1f40: 5f 52 45 50 4c 41 43 45 3b 0a 20 20 20 20 20 20  _REPLACE;.      
1f50: 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70  }else if( strcmp
1f60: 28 7a 2c 22 73 65 6c 65 63 74 22 29 3d 3d 30 20  (z,"select")==0 
1f70: 29 7b 0a 20 20 20 20 20 20 20 20 69 4d 6f 64 65  ){.        iMode
1f80: 20 3d 20 4d 4f 44 45 5f 53 45 4c 45 43 54 3b 0a   = MODE_SELECT;.
1f90: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
1fa0: 73 74 72 63 6d 70 28 7a 2c 22 69 6e 73 65 72 74  strcmp(z,"insert
1fb0: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ")==0 ){.       
1fc0: 20 69 4d 6f 64 65 20 3d 20 4d 4f 44 45 5f 49 4e   iMode = MODE_IN
1fd0: 53 45 52 54 3b 0a 20 20 20 20 20 20 7d 65 6c 73  SERT;.      }els
1fe0: 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22  e if( strcmp(z,"
1ff0: 75 70 64 61 74 65 22 29 3d 3d 30 20 29 7b 0a 20  update")==0 ){. 
2000: 20 20 20 20 20 20 20 69 4d 6f 64 65 20 3d 20 4d         iMode = M
2010: 4f 44 45 5f 55 50 44 41 54 45 3b 0a 20 20 20 20  ODE_UPDATE;.    
2020: 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63    }else if( strc
2030: 6d 70 28 7a 2c 22 64 65 6c 65 74 65 22 29 3d 3d  mp(z,"delete")==
2040: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 69 4d 6f  0 ){.        iMo
2050: 64 65 20 3d 20 4d 4f 44 45 5f 44 45 4c 45 54 45  de = MODE_DELETE
2060: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66  ;.      }else if
2070: 28 20 73 74 72 63 6d 70 28 7a 2c 22 71 75 65 72  ( strcmp(z,"quer
2080: 79 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  y")==0 ){.      
2090: 20 20 69 4d 6f 64 65 20 3d 20 4d 4f 44 45 5f 51    iMode = MODE_Q
20a0: 55 45 52 59 3b 0a 20 20 20 20 20 20 7d 65 6c 73  UERY;.      }els
20b0: 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22  e if( strcmp(z,"
20c0: 6e 6f 63 61 73 65 22 29 3d 3d 30 20 29 7b 0a 20  nocase")==0 ){. 
20d0: 20 20 20 20 20 20 20 75 73 65 4e 6f 63 61 73 65         useNocase
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 72 61 63 65 22 29 3d 3d 30 20 29 7b 0a 20 20  trace")==0 ){.  
2110: 20 20 20 20 20 20 64 6f 54 72 61 63 65 20 3d 20        doTrace = 
2120: 31 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  1;.      }else i
2130: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 6e 6f 73  f( strcmp(z,"nos
2140: 79 6e 63 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ync")==0 ){.    
2150: 20 20 20 20 6e 6f 53 79 6e 63 20 3d 20 31 3b 0a      noSync = 1;.
2160: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
2170: 73 74 72 63 6d 70 28 7a 2c 22 73 74 61 74 73 22  strcmp(z,"stats"
2180: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  )==0 ){.        
2190: 73 68 6f 77 53 74 61 74 73 20 3d 20 31 3b 0a 20  showStats = 1;. 
21a0: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73       }else if( s
21b0: 74 72 63 6d 70 28 7a 2c 22 73 75 6d 6d 61 72 79  trcmp(z,"summary
21c0: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ")==0 ){.       
21d0: 20 73 68 6f 77 53 75 6d 6d 61 72 79 20 3d 20 31   showSummary = 1
21e0: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66  ;.      }else if
21f0: 28 20 73 74 72 63 6d 70 28 7a 2c 22 74 69 6d 65  ( strcmp(z,"time
2200: 72 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  r")==0 ){.      
2210: 20 20 73 68 6f 77 54 69 6d 65 72 20 3d 20 69 3b    showTimer = i;
2220: 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28  .      }else if(
2230: 20 73 74 72 63 6d 70 28 7a 2c 22 63 61 63 68 65   strcmp(z,"cache
2240: 73 69 7a 65 22 29 3d 3d 30 20 26 26 20 69 3c 61  size")==0 && i<a
2250: 72 67 63 2d 31 20 29 7b 0a 20 20 20 20 20 20 20  rgc-1 ){.       
2260: 20 69 2b 2b 3b 0a 20 20 20 20 20 20 20 20 63 61   i++;.        ca
2270: 63 68 65 53 69 7a 65 20 3d 20 61 74 6f 69 28 61  cheSize = atoi(a
2280: 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20 20 7d  rgv[i]);.      }
2290: 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70 28  else if( strcmp(
22a0: 7a 2c 22 70 61 67 65 73 69 7a 65 22 29 3d 3d 30  z,"pagesize")==0
22b0: 20 26 26 20 69 3c 61 72 67 63 2d 31 20 29 7b 0a   && i<argc-1 ){.
22c0: 20 20 20 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20          i++;.   
22d0: 20 20 20 20 20 70 61 67 65 53 69 7a 65 20 3d 20       pageSize = 
22e0: 61 74 6f 69 28 61 72 67 76 5b 69 5d 29 3b 0a 20  atoi(argv[i]);. 
22f0: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73       }else if( s
2300: 74 72 63 6d 70 28 7a 2c 22 63 6f 6d 6d 69 74 22  trcmp(z,"commit"
2310: 29 3d 3d 30 20 26 26 20 69 3c 61 72 67 63 2d 31  )==0 && i<argc-1
2320: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 2b 2b 3b   ){.        i++;
2330: 0a 20 20 20 20 20 20 20 20 63 6f 6d 6d 69 74 49  .        commitI
2340: 6e 74 65 72 76 61 6c 20 3d 20 61 74 6f 69 28 61  nterval = atoi(a
2350: 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20 20 7d  rgv[i]);.      }
2360: 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70 28  else if( strcmp(
2370: 7a 2c 22 6a 6f 75 72 6e 61 6c 22 29 3d 3d 30 20  z,"journal")==0 
2380: 26 26 20 69 3c 61 72 67 63 2d 31 20 29 7b 0a 20  && i<argc-1 ){. 
2390: 20 20 20 20 20 20 20 7a 4a 4d 6f 64 65 20 3d 20         zJMode = 
23a0: 61 72 67 76 5b 2b 2b 69 5d 3b 0a 20 20 20 20 20  argv[++i];.     
23b0: 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d   }else if( strcm
23c0: 70 28 7a 2c 22 74 61 67 22 29 3d 3d 30 20 26 26  p(z,"tag")==0 &&
23d0: 20 69 3c 61 72 67 63 2d 31 20 29 7b 0a 20 20 20   i<argc-1 ){.   
23e0: 20 20 20 20 20 7a 54 61 67 20 3d 20 61 72 67 76       zTag = argv
23f0: 5b 2b 2b 69 5d 3b 0a 20 20 20 20 20 20 20 20 70  [++i];.        p
2400: 54 69 6d 65 72 20 3d 20 73 74 64 6f 75 74 3b 0a  Timer = stdout;.
2410: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
2420: 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72       fatal_error
2430: 28 22 75 6e 6b 6e 6f 77 6e 20 6f 70 74 69 6f 6e  ("unknown option
2440: 3a 20 25 73 5c 6e 22 2c 20 61 72 67 76 5b 69 5d  : %s\n", argv[i]
2450: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
2460: 65 6c 73 65 20 69 66 28 20 7a 44 62 4e 61 6d 65  else if( zDbName
2470: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 7a 44 62  ==0 ){.      zDb
2480: 4e 61 6d 65 20 3d 20 61 72 67 76 5b 69 5d 3b 0a  Name = argv[i];.
2490: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 7a 46      }else if( zF
24a0: 69 6c 65 54 6f 52 65 61 64 3d 3d 30 20 29 7b 0a  ileToRead==0 ){.
24b0: 20 20 20 20 20 20 7a 46 69 6c 65 54 6f 52 65 61        zFileToRea
24c0: 64 20 3d 20 61 72 67 76 5b 69 5d 3b 0a 20 20 20  d = argv[i];.   
24d0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 66 61   }else{.      fa
24e0: 74 61 6c 5f 65 72 72 6f 72 28 22 73 75 72 70 6c  tal_error("surpl
24f0: 75 73 20 61 72 67 75 6d 65 6e 74 3a 20 25 73 5c  us argument: %s\
2500: 6e 22 2c 20 61 72 67 76 5b 69 5d 29 3b 0a 20 20  n", argv[i]);.  
2510: 20 20 7d 0a 20 20 7d 0a 20 20 69 66 28 20 7a 44    }.  }.  if( zD
2520: 62 4e 61 6d 65 3d 3d 30 20 29 7b 0a 20 20 20 20  bName==0 ){.    
2530: 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 55 73 61  fatal_error("Usa
2540: 67 65 3a 20 25 73 20 5b 2d 2d 6f 70 74 69 6f 6e  ge: %s [--option
2550: 73 5d 20 44 41 54 41 42 41 53 45 20 5b 49 4e 50  s] DATABASE [INP
2560: 55 54 46 49 4c 45 5d 5c 6e 22 2c 20 61 72 67 76  UTFILE]\n", argv
2570: 5b 30 5d 29 3b 0a 20 20 7d 0a 20 20 73 74 61 72  [0]);.  }.  star
2580: 74 54 69 6d 65 20 3d 20 72 65 61 6c 54 69 6d 65  tTime = realTime
2590: 28 29 3b 0a 0a 20 20 2f 2a 20 4f 70 65 6e 20 74  ();..  /* Open t
25a0: 68 65 20 64 61 74 61 62 61 73 65 20 61 6e 64 20  he database and 
25b0: 74 68 65 20 69 6e 70 75 74 20 66 69 6c 65 20 2a  the input file *
25c0: 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f  /.  if( sqlite3_
25d0: 6f 70 65 6e 28 7a 44 62 4e 61 6d 65 2c 20 26 64  open(zDbName, &d
25e0: 62 29 20 29 7b 0a 20 20 20 20 66 61 74 61 6c 5f  b) ){.    fatal_
25f0: 65 72 72 6f 72 28 22 43 61 6e 6e 6f 74 20 6f 70  error("Cannot op
2600: 65 6e 20 64 61 74 61 62 61 73 65 20 66 69 6c 65  en database file
2610: 3a 20 25 73 5c 6e 22 2c 20 7a 44 62 4e 61 6d 65  : %s\n", zDbName
2620: 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 7a 46 69  );.  }.  if( zFi
2630: 6c 65 54 6f 52 65 61 64 20 29 7b 0a 20 20 20 20  leToRead ){.    
2640: 69 6e 20 3d 20 66 6f 70 65 6e 28 7a 46 69 6c 65  in = fopen(zFile
2650: 54 6f 52 65 61 64 2c 20 22 72 62 22 29 3b 0a 20  ToRead, "rb");. 
2660: 20 20 20 69 66 28 20 69 6e 3d 3d 30 20 29 7b 0a     if( in==0 ){.
2670: 20 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f        fatal_erro
2680: 72 28 22 43 6f 75 6c 64 20 6e 6f 74 20 6f 70 65  r("Could not ope
2690: 6e 20 69 6e 70 75 74 20 66 69 6c 65 20 5c 22 25  n input file \"%
26a0: 73 5c 22 5c 6e 22 2c 20 7a 46 69 6c 65 54 6f 52  s\"\n", zFileToR
26b0: 65 61 64 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65  ead);.    }.  }e
26c0: 6c 73 65 7b 0a 20 20 20 20 69 6e 20 3d 20 73 74  lse{.    in = st
26d0: 64 69 6e 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 53  din;.  }..  /* S
26e0: 65 74 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e  et database conn
26f0: 65 63 74 69 6f 6e 20 6f 70 74 69 6f 6e 73 20 2a  ection options *
2700: 2f 0a 20 20 69 66 28 20 64 6f 54 72 61 63 65 20  /.  if( doTrace 
2710: 29 20 73 71 6c 69 74 65 33 5f 74 72 61 63 65 28  ) sqlite3_trace(
2720: 64 62 2c 20 74 72 61 63 65 43 61 6c 6c 62 61 63  db, traceCallbac
2730: 6b 2c 20 30 29 3b 0a 20 20 69 66 28 20 70 61 67  k, 0);.  if( pag
2740: 65 53 69 7a 65 20 29 7b 0a 20 20 20 20 7a 53 71  eSize ){.    zSq
2750: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69  l = sqlite3_mpri
2760: 6e 74 66 28 22 50 52 41 47 4d 41 20 70 61 67 65  ntf("PRAGMA page
2770: 5f 73 69 7a 65 3d 25 64 22 2c 20 70 61 67 65 53  _size=%d", pageS
2780: 69 7a 65 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  ize);.    sqlite
2790: 33 5f 65 78 65 63 28 64 62 2c 20 7a 53 71 6c 2c  3_exec(db, zSql,
27a0: 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 73   0, 0, 0);.    s
27b0: 71 6c 69 74 65 33 5f 66 72 65 65 28 7a 53 71 6c  qlite3_free(zSql
27c0: 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 63 61 63  );.  }.  if( cac
27d0: 68 65 53 69 7a 65 20 29 7b 0a 20 20 20 20 7a 53  heSize ){.    zS
27e0: 71 6c 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72  ql = sqlite3_mpr
27f0: 69 6e 74 66 28 22 50 52 41 47 4d 41 20 63 61 63  intf("PRAGMA cac
2800: 68 65 5f 73 69 7a 65 3d 25 64 22 2c 20 63 61 63  he_size=%d", cac
2810: 68 65 53 69 7a 65 29 3b 0a 20 20 20 20 73 71 6c  heSize);.    sql
2820: 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20 7a 53  ite3_exec(db, zS
2830: 71 6c 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20  ql, 0, 0, 0);.  
2840: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a    sqlite3_free(z
2850: 53 71 6c 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20  Sql);.  }.  if( 
2860: 6e 6f 53 79 6e 63 20 29 20 73 71 6c 69 74 65 33  noSync ) sqlite3
2870: 5f 65 78 65 63 28 64 62 2c 20 22 50 52 41 47 4d  _exec(db, "PRAGM
2880: 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f 46  A synchronous=OF
2890: 46 22 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20  F", 0, 0, 0);.  
28a0: 69 66 28 20 7a 4a 4d 6f 64 65 20 29 7b 0a 20 20  if( zJMode ){.  
28b0: 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33    zSql = sqlite3
28c0: 5f 6d 70 72 69 6e 74 66 28 22 50 52 41 47 4d 41  _mprintf("PRAGMA
28d0: 20 6a 6f 75 72 6e 61 6c 5f 6d 6f 64 65 3d 25 73   journal_mode=%s
28e0: 22 2c 20 7a 4a 4d 6f 64 65 29 3b 0a 20 20 20 20  ", zJMode);.    
28f0: 73 71 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c  sqlite3_exec(db,
2900: 20 7a 53 71 6c 2c 20 30 2c 20 30 2c 20 30 29 3b   zSql, 0, 0, 0);
2910: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65  .    sqlite3_fre
2920: 65 28 7a 53 71 6c 29 3b 0a 20 20 7d 0a 0a 0a 20  e(zSql);.  }... 
2930: 20 2f 2a 20 43 6f 6e 73 74 72 75 63 74 20 74 68   /* Construct th
2940: 65 20 22 77 6f 72 64 63 6f 75 6e 74 22 20 74 61  e "wordcount" ta
2950: 62 6c 65 20 69 6e 74 6f 20 77 68 69 63 68 20 74  ble into which t
2960: 6f 20 70 75 74 20 74 68 65 20 77 6f 72 64 73 20  o put the words 
2970: 2a 2f 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33  */.  if( sqlite3
2980: 5f 65 78 65 63 28 64 62 2c 20 22 42 45 47 49 4e  _exec(db, "BEGIN
2990: 20 49 4d 4d 45 44 49 41 54 45 22 2c 20 30 2c 20   IMMEDIATE", 0, 
29a0: 30 2c 20 30 29 20 29 7b 0a 20 20 20 20 66 61 74  0, 0) ){.    fat
29b0: 61 6c 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20  al_error("Could 
29c0: 6e 6f 74 20 73 74 61 72 74 20 61 20 74 72 61 6e  not start a tran
29d0: 73 61 63 74 69 6f 6e 5c 6e 22 29 3b 0a 20 20 7d  saction\n");.  }
29e0: 0a 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65  .  zSql = sqlite
29f0: 33 5f 6d 70 72 69 6e 74 66 28 0a 20 20 20 20 20  3_mprintf(.     
2a00: 22 43 52 45 41 54 45 20 54 41 42 4c 45 20 49 46  "CREATE TABLE IF
2a10: 20 4e 4f 54 20 45 58 49 53 54 53 20 77 6f 72 64   NOT EXISTS word
2a20: 63 6f 75 6e 74 28 5c 6e 22 0a 20 20 20 20 20 22  count(\n".     "
2a30: 20 20 77 6f 72 64 20 54 45 58 54 20 50 52 49 4d    word TEXT PRIM
2a40: 41 52 59 20 4b 45 59 20 43 4f 4c 4c 41 54 45 20  ARY KEY COLLATE 
2a50: 25 73 2c 5c 6e 22 0a 20 20 20 20 20 22 20 20 63  %s,\n".     "  c
2a60: 6e 74 20 49 4e 54 45 47 45 52 5c 6e 22 0a 20 20  nt INTEGER\n".  
2a70: 20 20 20 22 29 25 73 22 2c 0a 20 20 20 20 20 75     ")%s",.     u
2a80: 73 65 4e 6f 63 61 73 65 20 3f 20 22 6e 6f 63 61  seNocase ? "noca
2a90: 73 65 22 20 3a 20 22 62 69 6e 61 72 79 22 2c 0a  se" : "binary",.
2aa0: 20 20 20 20 20 75 73 65 57 69 74 68 6f 75 74 52       useWithoutR
2ab0: 6f 77 69 64 20 3f 20 22 20 57 49 54 48 4f 55 54  owid ? " WITHOUT
2ac0: 20 52 4f 57 49 44 22 20 3a 20 22 22 0a 20 20 29   ROWID" : "".  )
2ad0: 3b 0a 20 20 69 66 28 20 7a 53 71 6c 3d 3d 30 20  ;.  if( zSql==0 
2ae0: 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 6f  ) fatal_error("o
2af0: 75 74 20 6f 66 20 6d 65 6d 6f 72 79 5c 6e 22 29  ut of memory\n")
2b00: 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33  ;.  rc = sqlite3
2b10: 5f 65 78 65 63 28 64 62 2c 20 7a 53 71 6c 2c 20  _exec(db, zSql, 
2b20: 30 2c 20 30 2c 20 30 29 3b 0a 20 20 69 66 28 20  0, 0, 0);.  if( 
2b30: 72 63 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72  rc ) fatal_error
2b40: 28 22 43 6f 75 6c 64 20 6e 6f 74 20 63 72 65 61  ("Could not crea
2b50: 74 65 20 74 68 65 20 77 6f 72 64 63 6f 75 6e 74  te the wordcount
2b60: 20 74 61 62 6c 65 3a 20 25 73 2e 5c 6e 22 2c 0a   table: %s.\n",.
2b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b80: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65         sqlite3_e
2b90: 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 73 71  rrmsg(db));.  sq
2ba0: 6c 69 74 65 33 5f 66 72 65 65 28 7a 53 71 6c 29  lite3_free(zSql)
2bb0: 3b 0a 0a 20 20 2f 2a 20 50 72 65 70 61 72 65 20  ;..  /* Prepare 
2bc0: 53 51 4c 20 73 74 61 74 65 6d 65 6e 74 73 20 74  SQL statements t
2bd0: 68 61 74 20 77 69 6c 6c 20 62 65 20 6e 65 65 64  hat will be need
2be0: 65 64 20 2a 2f 0a 20 20 69 66 28 20 69 4d 6f 64  ed */.  if( iMod
2bf0: 65 3d 3d 4d 4f 44 45 5f 51 55 45 52 59 20 29 7b  e==MODE_QUERY ){
2c00: 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65  .    rc = sqlite
2c10: 33 5f 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c  3_prepare_v2(db,
2c20: 0a 20 20 20 20 20 20 20 20 20 20 22 53 45 4c 45  .          "SELE
2c30: 43 54 20 63 6e 74 20 46 52 4f 4d 20 77 6f 72 64  CT cnt FROM word
2c40: 63 6f 75 6e 74 20 57 48 45 52 45 20 77 6f 72 64  count WHERE word
2c50: 3d 3f 31 22 2c 0a 20 20 20 20 20 20 20 20 20 20  =?1",.          
2c60: 2d 31 2c 20 26 70 53 65 6c 65 63 74 2c 20 30 29  -1, &pSelect, 0)
2c70: 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29 20 66  ;.    if( rc ) f
2c80: 61 74 61 6c 5f 65 72 72 6f 72 28 22 43 6f 75 6c  atal_error("Coul
2c90: 64 20 6e 6f 74 20 70 72 65 70 61 72 65 20 74 68  d not prepare th
2ca0: 65 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65  e SELECT stateme
2cb0: 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20  nt: %s\n",.     
2cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2cd0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65 72 72       sqlite3_err
2ce0: 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d 0a 20 20  msg(db));.  }.  
2cf0: 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f  if( iMode==MODE_
2d00: 53 45 4c 45 43 54 20 29 7b 0a 20 20 20 20 72 63  SELECT ){.    rc
2d10: 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61   = sqlite3_prepa
2d20: 72 65 5f 76 32 28 64 62 2c 0a 20 20 20 20 20 20  re_v2(db,.      
2d30: 20 20 20 20 22 53 45 4c 45 43 54 20 31 20 46 52      "SELECT 1 FR
2d40: 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 20 57 48 45  OM wordcount WHE
2d50: 52 45 20 77 6f 72 64 3d 3f 31 22 2c 0a 20 20 20  RE word=?1",.   
2d60: 20 20 20 20 20 20 20 2d 31 2c 20 26 70 53 65 6c         -1, &pSel
2d70: 65 63 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28  ect, 0);.    if(
2d80: 20 72 63 20 29 20 66 61 74 61 6c 5f 65 72 72 6f   rc ) fatal_erro
2d90: 72 28 22 43 6f 75 6c 64 20 6e 6f 74 20 70 72 65  r("Could not pre
2da0: 70 61 72 65 20 74 68 65 20 53 45 4c 45 43 54 20  pare the SELECT 
2db0: 73 74 61 74 65 6d 65 6e 74 3a 20 25 73 5c 6e 22  statement: %s\n"
2dc0: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
2dd0: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
2de0: 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b  te3_errmsg(db));
2df0: 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65  .    rc = sqlite
2e00: 33 5f 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c  3_prepare_v2(db,
2e10: 0a 20 20 20 20 20 20 20 20 20 20 22 49 4e 53 45  .          "INSE
2e20: 52 54 20 49 4e 54 4f 20 77 6f 72 64 63 6f 75 6e  RT INTO wordcoun
2e30: 74 28 77 6f 72 64 2c 63 6e 74 29 20 56 41 4c 55  t(word,cnt) VALU
2e40: 45 53 28 3f 31 2c 31 29 22 2c 0a 20 20 20 20 20  ES(?1,1)",.     
2e50: 20 20 20 20 20 2d 31 2c 20 26 70 49 6e 73 65 72       -1, &pInser
2e60: 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72  t, 0);.    if( r
2e70: 63 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28  c ) fatal_error(
2e80: 22 43 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70 61  "Could not prepa
2e90: 72 65 20 74 68 65 20 49 4e 53 45 52 54 20 73 74  re the INSERT st
2ea0: 61 74 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a  atement: %s\n",.
2eb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ec0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
2ed0: 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20  _errmsg(db));.  
2ee0: 7d 0a 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d  }.  if( iMode==M
2ef0: 4f 44 45 5f 53 45 4c 45 43 54 20 7c 7c 20 69 4d  ODE_SELECT || iM
2f00: 6f 64 65 3d 3d 4d 4f 44 45 5f 55 50 44 41 54 45  ode==MODE_UPDATE
2f10: 20 7c 7c 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f   || iMode==MODE_
2f20: 49 4e 53 45 52 54 20 29 7b 0a 20 20 20 20 72 63  INSERT ){.    rc
2f30: 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61   = sqlite3_prepa
2f40: 72 65 5f 76 32 28 64 62 2c 0a 20 20 20 20 20 20  re_v2(db,.      
2f50: 20 20 20 20 22 55 50 44 41 54 45 20 77 6f 72 64      "UPDATE word
2f60: 63 6f 75 6e 74 20 53 45 54 20 63 6e 74 3d 63 6e  count SET cnt=cn
2f70: 74 2b 31 20 57 48 45 52 45 20 77 6f 72 64 3d 3f  t+1 WHERE word=?
2f80: 31 22 2c 0a 20 20 20 20 20 20 20 20 20 20 2d 31  1",.          -1
2f90: 2c 20 26 70 55 70 64 61 74 65 2c 20 30 29 3b 0a  , &pUpdate, 0);.
2fa0: 20 20 20 20 69 66 28 20 72 63 20 29 20 66 61 74      if( rc ) fat
2fb0: 61 6c 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20  al_error("Could 
2fc0: 6e 6f 74 20 70 72 65 70 61 72 65 20 74 68 65 20  not prepare the 
2fd0: 55 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74  UPDATE statement
2fe0: 3a 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20  : %s\n",.       
2ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3000: 20 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67    sqlite3_errmsg
3010: 28 64 62 29 29 3b 0a 20 20 7d 0a 20 20 69 66 28  (db));.  }.  if(
3020: 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 49 4e 53   iMode==MODE_INS
3030: 45 52 54 20 29 7b 0a 20 20 20 20 72 63 20 3d 20  ERT ){.    rc = 
3040: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
3050: 76 32 28 64 62 2c 0a 20 20 20 20 20 20 20 20 20  v2(db,.         
3060: 20 22 49 4e 53 45 52 54 20 4f 52 20 49 47 4e 4f   "INSERT OR IGNO
3070: 52 45 20 49 4e 54 4f 20 77 6f 72 64 63 6f 75 6e  RE INTO wordcoun
3080: 74 28 77 6f 72 64 2c 63 6e 74 29 20 56 41 4c 55  t(word,cnt) VALU
3090: 45 53 28 3f 31 2c 31 29 22 2c 0a 20 20 20 20 20  ES(?1,1)",.     
30a0: 20 20 20 20 20 2d 31 2c 20 26 70 49 6e 73 65 72       -1, &pInser
30b0: 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72  t, 0);.    if( r
30c0: 63 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28  c ) fatal_error(
30d0: 22 43 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70 61  "Could not prepa
30e0: 72 65 20 74 68 65 20 49 4e 53 45 52 54 20 73 74  re the INSERT st
30f0: 61 74 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a  atement: %s\n",.
3100: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3110: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
3120: 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20  _errmsg(db));.  
3130: 7d 0a 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d  }.  if( iMode==M
3140: 4f 44 45 5f 55 50 44 41 54 45 20 29 7b 0a 20 20  ODE_UPDATE ){.  
3150: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70    rc = sqlite3_p
3160: 72 65 70 61 72 65 5f 76 32 28 64 62 2c 0a 20 20  repare_v2(db,.  
3170: 20 20 20 20 20 20 20 20 22 49 4e 53 45 52 54 20          "INSERT 
3180: 4f 52 20 49 47 4e 4f 52 45 20 49 4e 54 4f 20 77  OR IGNORE INTO w
3190: 6f 72 64 63 6f 75 6e 74 28 77 6f 72 64 2c 63 6e  ordcount(word,cn
31a0: 74 29 20 56 41 4c 55 45 53 28 3f 31 2c 30 29 22  t) VALUES(?1,0)"
31b0: 2c 0a 20 20 20 20 20 20 20 20 20 20 2d 31 2c 20  ,.          -1, 
31c0: 26 70 49 6e 73 65 72 74 2c 20 30 29 3b 0a 20 20  &pInsert, 0);.  
31d0: 20 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c    if( rc ) fatal
31e0: 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f  _error("Could no
31f0: 74 20 70 72 65 70 61 72 65 20 74 68 65 20 49 4e  t prepare the IN
3200: 53 45 52 54 20 73 74 61 74 65 6d 65 6e 74 3a 20  SERT statement: 
3210: 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20  %s\n",.         
3220: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3230: 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64  sqlite3_errmsg(d
3240: 62 29 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 69  b));.  }.  if( i
3250: 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 52 45 50 4c 41  Mode==MODE_REPLA
3260: 43 45 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73  CE ){.    rc = s
3270: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
3280: 32 28 64 62 2c 0a 20 20 20 20 20 20 20 20 20 20  2(db,.          
3290: 22 52 45 50 4c 41 43 45 20 49 4e 54 4f 20 77 6f  "REPLACE INTO wo
32a0: 72 64 63 6f 75 6e 74 28 77 6f 72 64 2c 63 6e 74  rdcount(word,cnt
32b0: 29 22 0a 20 20 20 20 20 20 20 20 20 20 22 56 41  )".          "VA
32c0: 4c 55 45 53 28 3f 31 2c 63 6f 61 6c 65 73 63 65  LUES(?1,coalesce
32d0: 28 28 53 45 4c 45 43 54 20 63 6e 74 20 46 52 4f  ((SELECT cnt FRO
32e0: 4d 20 77 6f 72 64 63 6f 75 6e 74 20 57 48 45 52  M wordcount WHER
32f0: 45 20 77 6f 72 64 3d 3f 31 29 2c 30 29 2b 31 29  E word=?1),0)+1)
3300: 22 2c 0a 20 20 20 20 20 20 20 20 20 20 2d 31 2c  ",.          -1,
3310: 20 26 70 49 6e 73 65 72 74 2c 20 30 29 3b 0a 20   &pInsert, 0);. 
3320: 20 20 20 69 66 28 20 72 63 20 29 20 66 61 74 61     if( rc ) fata
3330: 6c 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e  l_error("Could n
3340: 6f 74 20 70 72 65 70 61 72 65 20 74 68 65 20 52  ot prepare the R
3350: 45 50 4c 41 43 45 20 73 74 61 74 65 6d 65 6e 74  EPLACE statement
3360: 3a 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20  : %s\n",.       
3370: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3380: 20 20 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73     sqlite3_errms
3390: 67 28 64 62 29 29 3b 0a 20 20 7d 0a 20 20 69 66  g(db));.  }.  if
33a0: 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 44 45  ( iMode==MODE_DE
33b0: 4c 45 54 45 20 29 7b 0a 20 20 20 20 72 63 20 3d  LETE ){.    rc =
33c0: 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65   sqlite3_prepare
33d0: 5f 76 32 28 64 62 2c 0a 20 20 20 20 20 20 20 20  _v2(db,.        
33e0: 20 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 77    "DELETE FROM w
33f0: 6f 72 64 63 6f 75 6e 74 20 57 48 45 52 45 20 77  ordcount WHERE w
3400: 6f 72 64 3d 3f 31 22 2c 0a 20 20 20 20 20 20 20  ord=?1",.       
3410: 20 20 20 2d 31 2c 20 26 70 44 65 6c 65 74 65 2c     -1, &pDelete,
3420: 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20   0);.    if( rc 
3430: 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 43  ) fatal_error("C
3440: 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70 61 72 65  ould not prepare
3450: 20 74 68 65 20 44 45 4c 45 54 45 20 73 74 61 74   the DELETE stat
3460: 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20 20  ement: %s\n",.  
3470: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3480: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65         sqlite3_e
3490: 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d 0a  rrmsg(db));.  }.
34a0: 0a 20 20 2f 2a 20 50 72 6f 63 65 73 73 20 74 68  .  /* Process th
34b0: 65 20 69 6e 70 75 74 20 66 69 6c 65 20 2a 2f 0a  e input file */.
34c0: 20 20 77 68 69 6c 65 28 20 66 67 65 74 73 28 7a    while( fgets(z
34d0: 49 6e 70 75 74 2c 20 73 69 7a 65 6f 66 28 7a 49  Input, sizeof(zI
34e0: 6e 70 75 74 29 2c 20 69 6e 29 20 29 7b 0a 20 20  nput), in) ){.  
34f0: 20 20 66 6f 72 28 69 3d 30 3b 20 7a 49 6e 70 75    for(i=0; zInpu
3500: 74 5b 69 5d 3b 20 69 2b 2b 29 7b 0a 20 20 20 20  t[i]; i++){.    
3510: 20 20 69 66 28 20 21 49 53 41 4c 50 48 41 28 7a    if( !ISALPHA(z
3520: 49 6e 70 75 74 5b 69 5d 29 20 29 20 63 6f 6e 74  Input[i]) ) cont
3530: 69 6e 75 65 3b 0a 20 20 20 20 20 20 66 6f 72 28  inue;.      for(
3540: 6a 3d 69 2b 31 3b 20 49 53 41 4c 50 48 41 28 7a  j=i+1; ISALPHA(z
3550: 49 6e 70 75 74 5b 6a 5d 29 3b 20 6a 2b 2b 29 7b  Input[j]); j++){
3560: 7d 0a 0a 20 20 20 20 20 20 2f 2a 20 46 6f 75 6e  }..      /* Foun
3570: 64 20 61 20 6e 65 77 20 77 6f 72 64 20 61 74 20  d a new word at 
3580: 7a 49 6e 70 75 74 5b 69 5d 20 74 68 61 74 20 69  zInput[i] that i
3590: 73 20 6a 2d 69 20 62 79 74 65 73 20 6c 6f 6e 67  s j-i bytes long
35a0: 2e 20 0a 20 20 20 20 20 20 2a 2a 20 50 72 6f 63  . .      ** Proc
35b0: 65 73 73 20 69 74 20 69 6e 74 6f 20 74 68 65 20  ess it into the 
35c0: 77 6f 72 64 63 6f 75 6e 74 20 74 61 62 6c 65 2e  wordcount table.
35d0: 20 20 2a 2f 0a 20 20 20 20 20 20 69 66 28 20 69    */.      if( i
35e0: 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 44 45 4c 45 54  Mode==MODE_DELET
35f0: 45 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  E ){.        sql
3600: 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 28 70  ite3_bind_text(p
3610: 44 65 6c 65 74 65 2c 20 31 2c 20 7a 49 6e 70 75  Delete, 1, zInpu
3620: 74 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54 45  t+i, j-i, SQLITE
3630: 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20  _STATIC);.      
3640: 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f 73 74    if( sqlite3_st
3650: 65 70 28 70 44 65 6c 65 74 65 29 21 3d 53 51 4c  ep(pDelete)!=SQL
3660: 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20 20 20 20  ITE_DONE ){.    
3670: 20 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f        fatal_erro
3680: 72 28 22 44 45 4c 45 54 45 20 66 61 69 6c 65 64  r("DELETE failed
3690: 3a 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65 33  : %s\n", sqlite3
36a0: 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20  _errmsg(db));.  
36b0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
36c0: 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70 44  sqlite3_reset(pD
36d0: 65 6c 65 74 65 29 3b 0a 20 20 20 20 20 20 7d 65  elete);.      }e
36e0: 6c 73 65 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d  lse if( iMode==M
36f0: 4f 44 45 5f 53 45 4c 45 43 54 20 29 7b 0a 20 20  ODE_SELECT ){.  
3700: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 62 69        sqlite3_bi
3710: 6e 64 5f 74 65 78 74 28 70 53 65 6c 65 63 74 2c  nd_text(pSelect,
3720: 20 31 2c 20 7a 49 6e 70 75 74 2b 69 2c 20 6a 2d   1, zInput+i, j-
3730: 69 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  i, SQLITE_STATIC
3740: 29 3b 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20  );.        rc = 
3750: 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53 65  sqlite3_step(pSe
3760: 6c 65 63 74 29 3b 0a 20 20 20 20 20 20 20 20 73  lect);.        s
3770: 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70 53 65  qlite3_reset(pSe
3780: 6c 65 63 74 29 3b 0a 20 20 20 20 20 20 20 20 69  lect);.        i
3790: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 52 4f  f( rc==SQLITE_RO
37a0: 57 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 73  W ){.          s
37b0: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74  qlite3_bind_text
37c0: 28 70 55 70 64 61 74 65 2c 20 31 2c 20 7a 49 6e  (pUpdate, 1, zIn
37d0: 70 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49  put+i, j-i, SQLI
37e0: 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  TE_STATIC);.    
37f0: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
3800: 33 5f 73 74 65 70 28 70 55 70 64 61 74 65 29 21  3_step(pUpdate)!
3810: 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a  =SQLITE_DONE ){.
3820: 20 20 20 20 20 20 20 20 20 20 20 20 66 61 74 61              fata
3830: 6c 5f 65 72 72 6f 72 28 22 55 50 44 41 54 45 20  l_error("UPDATE 
3840: 66 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20 73  failed: %s\n", s
3850: 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62  qlite3_errmsg(db
3860: 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a  ));.          }.
3870: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
3880: 33 5f 72 65 73 65 74 28 70 55 70 64 61 74 65 29  3_reset(pUpdate)
3890: 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 20  ;.        }else 
38a0: 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 44  if( rc==SQLITE_D
38b0: 4f 4e 45 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ONE ){.         
38c0: 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65   sqlite3_bind_te
38d0: 78 74 28 70 49 6e 73 65 72 74 2c 20 31 2c 20 7a  xt(pInsert, 1, z
38e0: 49 6e 70 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51  Input+i, j-i, SQ
38f0: 4c 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20  LITE_STATIC);.  
3900: 20 20 20 20 20 20 20 20 69 66 28 20 73 71 6c 69          if( sqli
3910: 74 65 33 5f 73 74 65 70 28 70 49 6e 73 65 72 74  te3_step(pInsert
3920: 29 21 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29  )!=SQLITE_DONE )
3930: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 61  {.            fa
3940: 74 61 6c 5f 65 72 72 6f 72 28 22 49 6e 73 65 72  tal_error("Inser
3950: 74 20 66 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c  t failed: %s\n",
3960: 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28   sqlite3_errmsg(
3970: 64 62 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20  db));.          
3980: 7d 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  }.          sqli
3990: 74 65 33 5f 72 65 73 65 74 28 70 49 6e 73 65 72  te3_reset(pInser
39a0: 74 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73  t);.        }els
39b0: 65 7b 0a 20 20 20 20 20 20 20 20 20 20 66 61 74  e{.          fat
39c0: 61 6c 5f 65 72 72 6f 72 28 22 53 45 4c 45 43 54  al_error("SELECT
39d0: 20 66 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20   failed: %s\n", 
39e0: 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64  sqlite3_errmsg(d
39f0: 62 29 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  b));.        }. 
3a00: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 69       }else if( i
3a10: 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 51 55 45 52 59  Mode==MODE_QUERY
3a20: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
3a30: 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 28 70 53  te3_bind_text(pS
3a40: 65 6c 65 63 74 2c 20 31 2c 20 7a 49 6e 70 75 74  elect, 1, zInput
3a50: 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54 45 5f  +i, j-i, SQLITE_
3a60: 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20  STATIC);.       
3a70: 20 69 66 28 20 73 71 6c 69 74 65 33 5f 73 74 65   if( sqlite3_ste
3a80: 70 28 70 53 65 6c 65 63 74 29 3d 3d 53 51 4c 49  p(pSelect)==SQLI
3a90: 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20 20  TE_ROW ){.      
3aa0: 20 20 20 20 73 75 6d 43 6e 74 20 2b 3d 20 73 71      sumCnt += sq
3ab0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74  lite3_column_int
3ac0: 36 34 28 70 53 65 6c 65 63 74 2c 20 30 29 3b 0a  64(pSelect, 0);.
3ad0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3ae0: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28    sqlite3_reset(
3af0: 70 53 65 6c 65 63 74 29 3b 0a 20 20 20 20 20 20  pSelect);.      
3b00: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 73  }else{.        s
3b10: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74  qlite3_bind_text
3b20: 28 70 49 6e 73 65 72 74 2c 20 31 2c 20 7a 49 6e  (pInsert, 1, zIn
3b30: 70 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49  put+i, j-i, SQLI
3b40: 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20  TE_STATIC);.    
3b50: 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33 5f      if( sqlite3_
3b60: 73 74 65 70 28 70 49 6e 73 65 72 74 29 21 3d 53  step(pInsert)!=S
3b70: 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20 20  QLITE_DONE ){.  
3b80: 20 20 20 20 20 20 20 20 66 61 74 61 6c 5f 65 72          fatal_er
3b90: 72 6f 72 28 22 49 4e 53 45 52 54 20 66 61 69 6c  ror("INSERT fail
3ba0: 65 64 3a 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74  ed: %s\n", sqlit
3bb0: 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a  e3_errmsg(db));.
3bc0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3bd0: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28    sqlite3_reset(
3be0: 70 49 6e 73 65 72 74 29 3b 0a 20 20 20 20 20 20  pInsert);.      
3bf0: 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44    if( iMode==MOD
3c00: 45 5f 55 50 44 41 54 45 0a 20 20 20 20 20 20 20  E_UPDATE.       
3c10: 20 20 7c 7c 20 28 69 4d 6f 64 65 3d 3d 4d 4f 44    || (iMode==MOD
3c20: 45 5f 49 4e 53 45 52 54 20 26 26 20 73 71 6c 69  E_INSERT && sqli
3c30: 74 65 33 5f 63 68 61 6e 67 65 73 28 64 62 29 3d  te3_changes(db)=
3c40: 3d 30 29 0a 20 20 20 20 20 20 20 20 29 7b 0a 20  =0).        ){. 
3c50: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
3c60: 5f 62 69 6e 64 5f 74 65 78 74 28 70 55 70 64 61  _bind_text(pUpda
3c70: 74 65 2c 20 31 2c 20 7a 49 6e 70 75 74 2b 69 2c  te, 1, zInput+i,
3c80: 20 6a 2d 69 2c 20 53 51 4c 49 54 45 5f 53 54 41   j-i, SQLITE_STA
3c90: 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20 20 20  TIC);.          
3ca0: 69 66 28 20 73 71 6c 69 74 65 33 5f 73 74 65 70  if( sqlite3_step
3cb0: 28 70 55 70 64 61 74 65 29 21 3d 53 51 4c 49 54  (pUpdate)!=SQLIT
3cc0: 45 5f 44 4f 4e 45 20 29 7b 0a 20 20 20 20 20 20  E_DONE ){.      
3cd0: 20 20 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f        fatal_erro
3ce0: 72 28 22 55 50 44 41 54 45 20 66 61 69 6c 65 64  r("UPDATE failed
3cf0: 3a 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65 33  : %s\n", sqlite3
3d00: 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20  _errmsg(db));.  
3d10: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3d20: 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65      sqlite3_rese
3d30: 74 28 70 55 70 64 61 74 65 29 3b 0a 20 20 20 20  t(pUpdate);.    
3d40: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20      }.      }.  
3d50: 20 20 20 20 69 20 3d 20 6a 2d 31 3b 0a 0a 20 20      i = j-1;..  
3d60: 20 20 20 20 2f 2a 20 49 6e 63 72 65 6d 65 6e 74      /* Increment
3d70: 20 74 68 65 20 6f 70 65 72 61 74 69 6f 6e 20 63   the operation c
3d80: 6f 75 6e 74 65 72 2e 20 20 44 6f 20 61 20 43 4f  ounter.  Do a CO
3d90: 4d 4d 49 54 20 69 66 20 69 74 20 69 73 20 74 69  MMIT if it is ti
3da0: 6d 65 2e 20 2a 2f 0a 20 20 20 20 20 20 6e 4f 70  me. */.      nOp
3db0: 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28 20 63 6f  ++;.      if( co
3dc0: 6d 6d 69 74 49 6e 74 65 72 76 61 6c 3e 30 20 26  mmitInterval>0 &
3dd0: 26 20 28 6e 4f 70 25 63 6f 6d 6d 69 74 49 6e 74  & (nOp%commitInt
3de0: 65 72 76 61 6c 29 3d 3d 30 20 29 7b 0a 20 20 20  erval)==0 ){.   
3df0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65 78 65       sqlite3_exe
3e00: 63 28 64 62 2c 20 22 43 4f 4d 4d 49 54 3b 20 42  c(db, "COMMIT; B
3e10: 45 47 49 4e 20 49 4d 4d 45 44 49 41 54 45 22 2c  EGIN IMMEDIATE",
3e20: 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20   0, 0, 0);.     
3e30: 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 73   }.    }.  }.  s
3e40: 71 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20  qlite3_exec(db, 
3e50: 22 43 4f 4d 4d 49 54 22 2c 20 30 2c 20 30 2c 20  "COMMIT", 0, 0, 
3e60: 30 29 3b 0a 20 20 69 66 28 20 7a 46 69 6c 65 54  0);.  if( zFileT
3e70: 6f 52 65 61 64 20 29 20 66 63 6c 6f 73 65 28 69  oRead ) fclose(i
3e80: 6e 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69  n);.  sqlite3_fi
3e90: 6e 61 6c 69 7a 65 28 70 49 6e 73 65 72 74 29 3b  nalize(pInsert);
3ea0: 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c  .  sqlite3_final
3eb0: 69 7a 65 28 70 55 70 64 61 74 65 29 3b 0a 20 20  ize(pUpdate);.  
3ec0: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
3ed0: 28 70 53 65 6c 65 63 74 29 3b 0a 20 20 73 71 6c  (pSelect);.  sql
3ee0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 44  ite3_finalize(pD
3ef0: 65 6c 65 74 65 29 3b 0a 0a 20 20 69 66 28 20 69  elete);..  if( i
3f00: 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 51 55 45 52 59  Mode==MODE_QUERY
3f10: 20 29 7b 0a 20 20 20 20 70 72 69 6e 74 66 28 22   ){.    printf("
3f20: 25 73 20 73 75 6d 20 6f 66 20 63 6e 74 3a 20 25  %s sum of cnt: %
3f30: 6c 6c 64 5c 6e 22 2c 20 7a 54 61 67 2c 20 73 75  lld\n", zTag, su
3f40: 6d 43 6e 74 29 3b 0a 20 20 20 20 72 63 20 3d 20  mCnt);.    rc = 
3f50: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
3f60: 76 32 28 64 62 2c 22 53 45 4c 45 43 54 20 73 75  v2(db,"SELECT su
3f70: 6d 28 63 6e 74 2a 63 6e 74 29 20 46 52 4f 4d 20  m(cnt*cnt) FROM 
3f80: 77 6f 72 64 63 6f 75 6e 74 22 2c 20 2d 31 2c 0a  wordcount", -1,.
3f90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3fa0: 20 20 20 20 20 20 20 20 20 20 20 20 26 70 53 65              &pSe
3fb0: 6c 65 63 74 2c 20 30 29 3b 0a 20 20 20 20 69 66  lect, 0);.    if
3fc0: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
3fd0: 26 26 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28  && sqlite3_step(
3fe0: 70 53 65 6c 65 63 74 29 3d 3d 53 51 4c 49 54 45  pSelect)==SQLITE
3ff0: 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20 20 70 72  _ROW ){.      pr
4000: 69 6e 74 66 28 22 25 73 20 64 6f 75 62 6c 65 2d  intf("%s double-
4010: 63 68 65 63 6b 3a 20 25 6c 6c 64 5c 6e 22 2c 20  check: %lld\n", 
4020: 7a 54 61 67 2c 20 73 71 6c 69 74 65 33 5f 63 6f  zTag, sqlite3_co
4030: 6c 75 6d 6e 5f 69 6e 74 36 34 28 70 53 65 6c 65  lumn_int64(pSele
4040: 63 74 2c 20 30 29 29 3b 0a 20 20 20 20 7d 0a 20  ct, 0));.    }. 
4050: 20 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c     sqlite3_final
4060: 69 7a 65 28 70 53 65 6c 65 63 74 29 3b 0a 20 20  ize(pSelect);.  
4070: 7d 0a 0a 0a 20 20 69 66 28 20 73 68 6f 77 54 69  }...  if( showTi
4080: 6d 65 72 20 29 7b 0a 20 20 20 20 73 71 6c 69 74  mer ){.    sqlit
4090: 65 33 5f 69 6e 74 36 34 20 65 6c 61 70 73 65 54  e3_int64 elapseT
40a0: 69 6d 65 20 3d 20 72 65 61 6c 54 69 6d 65 28 29  ime = realTime()
40b0: 20 2d 20 73 74 61 72 74 54 69 6d 65 3b 0a 20 20   - startTime;.  
40c0: 20 20 66 70 72 69 6e 74 66 28 70 54 69 6d 65 72    fprintf(pTimer
40d0: 2c 20 22 25 33 64 2e 25 30 33 64 20 77 6f 72 64  , "%3d.%03d word
40e0: 63 6f 75 6e 74 22 2c 20 28 69 6e 74 29 28 65 6c  count", (int)(el
40f0: 61 70 73 65 54 69 6d 65 2f 31 30 30 30 29 2c 0a  apseTime/1000),.
4100: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4110: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4120: 20 20 20 28 69 6e 74 29 28 65 6c 61 70 73 65 54     (int)(elapseT
4130: 69 6d 65 25 31 30 30 30 29 29 3b 0a 20 20 20 20  ime%1000));.    
4140: 66 6f 72 28 69 3d 31 3b 20 69 3c 61 72 67 63 3b  for(i=1; i<argc;
4150: 20 69 2b 2b 29 20 69 66 28 20 69 21 3d 73 68 6f   i++) if( i!=sho
4160: 77 54 69 6d 65 72 20 29 20 66 70 72 69 6e 74 66  wTimer ) fprintf
4170: 28 70 54 69 6d 65 72 2c 20 22 20 25 73 22 2c 20  (pTimer, " %s", 
4180: 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 66 70  argv[i]);.    fp
4190: 72 69 6e 74 66 28 70 54 69 6d 65 72 2c 20 22 5c  rintf(pTimer, "\
41a0: 6e 22 29 3b 0a 20 20 7d 0a 0a 20 20 69 66 28 20  n");.  }..  if( 
41b0: 73 68 6f 77 53 75 6d 6d 61 72 79 20 29 7b 0a 20  showSummary ){. 
41c0: 20 20 20 73 71 6c 69 74 65 33 5f 63 72 65 61 74     sqlite3_creat
41d0: 65 5f 66 75 6e 63 74 69 6f 6e 28 64 62 2c 20 22  e_function(db, "
41e0: 63 68 65 63 6b 73 75 6d 22 2c 20 2d 31 2c 20 53  checksum", -1, S
41f0: 51 4c 49 54 45 5f 55 54 46 38 2c 20 30 2c 0a 20  QLITE_UTF8, 0,. 
4200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4210: 20 20 20 20 20 20 20 20 20 20 20 30 2c 20 63 68             0, ch
4220: 65 63 6b 73 75 6d 53 74 65 70 2c 20 63 68 65 63  ecksumStep, chec
4230: 6b 73 75 6d 46 69 6e 61 6c 69 7a 65 29 3b 0a 20  ksumFinalize);. 
4240: 20 20 20 73 71 6c 69 74 65 33 5f 65 78 65 63 28     sqlite3_exec(
4250: 64 62 2c 20 0a 20 20 20 20 20 20 22 53 45 4c 45  db, .      "SELE
4260: 43 54 20 27 63 6f 75 6e 74 28 2a 29 3a 20 20 27  CT 'count(*):  '
4270: 2c 20 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20  , count(*) FROM 
4280: 77 6f 72 64 63 6f 75 6e 74 3b 5c 6e 22 0a 20 20  wordcount;\n".  
4290: 20 20 20 20 22 53 45 4c 45 43 54 20 27 73 75 6d      "SELECT 'sum
42a0: 28 63 6e 74 29 3a 20 20 27 2c 20 73 75 6d 28 63  (cnt):  ', sum(c
42b0: 6e 74 29 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75  nt) FROM wordcou
42c0: 6e 74 3b 5c 6e 22 0a 20 20 20 20 20 20 22 53 45  nt;\n".      "SE
42d0: 4c 45 43 54 20 27 6d 61 78 28 63 6e 74 29 3a 20  LECT 'max(cnt): 
42e0: 20 27 2c 20 6d 61 78 28 63 6e 74 29 20 46 52 4f   ', max(cnt) FRO
42f0: 4d 20 77 6f 72 64 63 6f 75 6e 74 3b 5c 6e 22 0a  M wordcount;\n".
4300: 20 20 20 20 20 20 22 53 45 4c 45 43 54 20 27 61        "SELECT 'a
4310: 76 67 28 63 6e 74 29 3a 20 20 27 2c 20 61 76 67  vg(cnt):  ', avg
4320: 28 63 6e 74 29 20 46 52 4f 4d 20 77 6f 72 64 63  (cnt) FROM wordc
4330: 6f 75 6e 74 3b 5c 6e 22 0a 20 20 20 20 20 20 22  ount;\n".      "
4340: 53 45 4c 45 43 54 20 27 73 75 6d 28 63 6e 74 3d  SELECT 'sum(cnt=
4350: 31 29 3a 27 2c 20 73 75 6d 28 63 6e 74 3d 31 29  1):', sum(cnt=1)
4360: 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 3b   FROM wordcount;
4370: 5c 6e 22 0a 20 20 20 20 20 20 22 53 45 4c 45 43  \n".      "SELEC
4380: 54 20 27 74 6f 70 20 31 30 3a 20 20 20 20 27 2c  T 'top 10:    ',
4390: 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74 28 77 6f   group_concat(wo
43a0: 72 64 2c 20 27 2c 20 27 29 20 46 52 4f 4d 20 22  rd, ', ') FROM "
43b0: 0a 20 20 20 20 20 20 20 20 20 22 28 53 45 4c 45  .         "(SELE
43c0: 43 54 20 77 6f 72 64 20 46 52 4f 4d 20 77 6f 72  CT word FROM wor
43d0: 64 63 6f 75 6e 74 20 4f 52 44 45 52 20 42 59 20  dcount ORDER BY 
43e0: 63 6e 74 20 44 45 53 43 2c 20 77 6f 72 64 20 4c  cnt DESC, word L
43f0: 49 4d 49 54 20 31 30 29 3b 5c 6e 22 0a 20 20 20  IMIT 10);\n".   
4400: 20 20 20 22 53 45 4c 45 43 54 20 27 63 68 65 63     "SELECT 'chec
4410: 6b 73 75 6d 3a 20 20 27 2c 20 63 68 65 63 6b 73  ksum:  ', checks
4420: 75 6d 28 77 6f 72 64 2c 20 63 6e 74 29 20 46 52  um(word, cnt) FR
4430: 4f 4d 20 22 0a 20 20 20 20 20 20 20 20 20 22 28  OM ".         "(
4440: 53 45 4c 45 43 54 20 77 6f 72 64 2c 20 63 6e 74  SELECT word, cnt
4450: 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 20   FROM wordcount 
4460: 4f 52 44 45 52 20 42 59 20 77 6f 72 64 29 3b 5c  ORDER BY word);\
4470: 6e 22 0a 20 20 20 20 20 20 22 50 52 41 47 4d 41  n".      "PRAGMA
4480: 20 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63 6b   integrity_check
4490: 3b 5c 6e 22 2c 0a 20 20 20 20 20 20 70 72 69 6e  ;\n",.      prin
44a0: 74 52 65 73 75 6c 74 2c 20 30 2c 20 30 29 3b 0a  tResult, 0, 0);.
44b0: 20 20 7d 0a 0a 20 20 2f 2a 20 44 61 74 61 62 61    }..  /* Databa
44c0: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 73 74  se connection st
44d0: 61 74 69 73 74 69 63 73 20 70 72 69 6e 74 65 64  atistics printed
44e0: 20 61 66 74 65 72 20 62 6f 74 68 20 70 72 65 70   after both prep
44f0: 61 72 65 64 20 73 74 61 74 65 6d 65 6e 74 73 0a  ared statements.
4500: 20 20 2a 2a 20 68 61 76 65 20 62 65 65 6e 20 66    ** have been f
4510: 69 6e 61 6c 69 7a 65 64 20 2a 2f 0a 20 20 69 66  inalized */.  if
4520: 28 20 73 68 6f 77 53 74 61 74 73 20 29 7b 0a 20  ( showStats ){. 
4530: 20 20 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74     sqlite3_db_st
4540: 61 74 75 73 28 64 62 2c 20 53 51 4c 49 54 45 5f  atus(db, SQLITE_
4550: 44 42 53 54 41 54 55 53 5f 4c 4f 4f 4b 41 53 49  DBSTATUS_LOOKASI
4560: 44 45 5f 55 53 45 44 2c 20 26 69 43 75 72 2c 20  DE_USED, &iCur, 
4570: 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20  &iHiwtr, 0);.   
4580: 20 70 72 69 6e 74 66 28 22 25 73 20 4c 6f 6f 6b   printf("%s Look
4590: 61 73 69 64 65 20 53 6c 6f 74 73 20 55 73 65 64  aside Slots Used
45a0: 3a 20 20 20 20 20 20 20 20 25 64 20 28 6d 61 78  :        %d (max
45b0: 20 25 64 29 5c 6e 22 2c 20 7a 54 61 67 2c 20 69   %d)\n", zTag, i
45c0: 43 75 72 2c 69 48 69 77 74 72 29 3b 0a 20 20 20  Cur,iHiwtr);.   
45d0: 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74 61 74   sqlite3_db_stat
45e0: 75 73 28 64 62 2c 20 53 51 4c 49 54 45 5f 44 42  us(db, SQLITE_DB
45f0: 53 54 41 54 55 53 5f 4c 4f 4f 4b 41 53 49 44 45  STATUS_LOOKASIDE
4600: 5f 48 49 54 2c 20 26 69 43 75 72 2c 20 26 69 48  _HIT, &iCur, &iH
4610: 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20 70 72  iwtr, 0);.    pr
4620: 69 6e 74 66 28 22 25 73 20 53 75 63 63 65 73 73  intf("%s Success
4630: 66 75 6c 20 6c 6f 6f 6b 61 73 69 64 65 73 3a 20  ful lookasides: 
4640: 20 20 20 20 20 20 25 64 5c 6e 22 2c 20 7a 54 61        %d\n", zTa
4650: 67 2c 20 69 48 69 77 74 72 29 3b 0a 20 20 20 20  g, iHiwtr);.    
4660: 73 71 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75  sqlite3_db_statu
4670: 73 28 64 62 2c 20 53 51 4c 49 54 45 5f 44 42 53  s(db, SQLITE_DBS
4680: 54 41 54 55 53 5f 4c 4f 4f 4b 41 53 49 44 45 5f  TATUS_LOOKASIDE_
4690: 4d 49 53 53 5f 53 49 5a 45 2c 20 26 69 43 75 72  MISS_SIZE, &iCur
46a0: 2c 26 69 48 69 77 74 72 2c 30 29 3b 0a 20 20 20  ,&iHiwtr,0);.   
46b0: 20 70 72 69 6e 74 66 28 22 25 73 20 4c 6f 6f 6b   printf("%s Look
46c0: 61 73 69 64 65 20 73 69 7a 65 20 66 61 75 6c 74  aside size fault
46d0: 73 3a 20 20 20 20 20 20 20 25 64 5c 6e 22 2c 20  s:       %d\n", 
46e0: 7a 54 61 67 2c 20 69 48 69 77 74 72 29 3b 0a 20  zTag, iHiwtr);. 
46f0: 20 20 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74     sqlite3_db_st
4700: 61 74 75 73 28 64 62 2c 20 53 51 4c 49 54 45 5f  atus(db, SQLITE_
4710: 44 42 53 54 41 54 55 53 5f 4c 4f 4f 4b 41 53 49  DBSTATUS_LOOKASI
4720: 44 45 5f 4d 49 53 53 5f 46 55 4c 4c 2c 20 26 69  DE_MISS_FULL, &i
4730: 43 75 72 2c 26 69 48 69 77 74 72 2c 30 29 3b 0a  Cur,&iHiwtr,0);.
4740: 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 20 4c      printf("%s L
4750: 6f 6f 6b 61 73 69 64 65 20 4f 4f 4d 20 66 61 75  ookaside OOM fau
4760: 6c 74 73 3a 20 20 20 20 20 20 20 20 25 64 5c 6e  lts:        %d\n
4770: 22 2c 20 7a 54 61 67 2c 20 69 48 69 77 74 72 29  ", zTag, iHiwtr)
4780: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62  ;.    sqlite3_db
4790: 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49  _status(db, SQLI
47a0: 54 45 5f 44 42 53 54 41 54 55 53 5f 43 41 43 48  TE_DBSTATUS_CACH
47b0: 45 5f 55 53 45 44 2c 20 26 69 43 75 72 2c 20 26  E_USED, &iCur, &
47c0: 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20  iHiwtr, 0);.    
47d0: 70 72 69 6e 74 66 28 22 25 73 20 50 61 67 65 72  printf("%s Pager
47e0: 20 48 65 61 70 20 55 73 61 67 65 3a 20 20 20 20   Heap Usage:    
47f0: 20 20 20 20 20 20 20 20 25 64 20 62 79 74 65 73          %d bytes
4800: 5c 6e 22 2c 20 7a 54 61 67 2c 20 69 43 75 72 29  \n", zTag, iCur)
4810: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62  ;.    sqlite3_db
4820: 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49  _status(db, SQLI
4830: 54 45 5f 44 42 53 54 41 54 55 53 5f 43 41 43 48  TE_DBSTATUS_CACH
4840: 45 5f 48 49 54 2c 20 26 69 43 75 72 2c 20 26 69  E_HIT, &iCur, &i
4850: 48 69 77 74 72 2c 20 31 29 3b 0a 20 20 20 20 70  Hiwtr, 1);.    p
4860: 72 69 6e 74 66 28 22 25 73 20 50 61 67 65 20 63  rintf("%s Page c
4870: 61 63 68 65 20 68 69 74 73 3a 20 20 20 20 20 20  ache hits:      
4880: 20 20 20 20 20 20 20 25 64 5c 6e 22 2c 20 7a 54         %d\n", zT
4890: 61 67 2c 20 69 43 75 72 29 3b 0a 20 20 20 20 73  ag, iCur);.    s
48a0: 71 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73  qlite3_db_status
48b0: 28 64 62 2c 20 53 51 4c 49 54 45 5f 44 42 53 54  (db, SQLITE_DBST
48c0: 41 54 55 53 5f 43 41 43 48 45 5f 4d 49 53 53 2c  ATUS_CACHE_MISS,
48d0: 20 26 69 43 75 72 2c 20 26 69 48 69 77 74 72 2c   &iCur, &iHiwtr,
48e0: 20 31 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28   1);.    printf(
48f0: 22 25 73 20 50 61 67 65 20 63 61 63 68 65 20 6d  "%s Page cache m
4900: 69 73 73 65 73 3a 20 20 20 20 20 20 20 20 20 20  isses:          
4910: 20 25 64 5c 6e 22 2c 20 7a 54 61 67 2c 20 69 43   %d\n", zTag, iC
4920: 75 72 29 3b 20 0a 20 20 20 20 73 71 6c 69 74 65  ur); .    sqlite
4930: 33 5f 64 62 5f 73 74 61 74 75 73 28 64 62 2c 20  3_db_status(db, 
4940: 53 51 4c 49 54 45 5f 44 42 53 54 41 54 55 53 5f  SQLITE_DBSTATUS_
4950: 43 41 43 48 45 5f 57 52 49 54 45 2c 20 26 69 43  CACHE_WRITE, &iC
4960: 75 72 2c 20 26 69 48 69 77 74 72 2c 20 31 29 3b  ur, &iHiwtr, 1);
4970: 0a 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 20  .    printf("%s 
4980: 50 61 67 65 20 63 61 63 68 65 20 77 72 69 74 65  Page cache write
4990: 73 3a 20 20 20 20 20 20 20 20 20 20 20 25 64 5c  s:           %d\
49a0: 6e 22 2c 20 7a 54 61 67 2c 20 69 43 75 72 29 3b  n", zTag, iCur);
49b0: 20 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62   .    sqlite3_db
49c0: 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49  _status(db, SQLI
49d0: 54 45 5f 44 42 53 54 41 54 55 53 5f 53 43 48 45  TE_DBSTATUS_SCHE
49e0: 4d 41 5f 55 53 45 44 2c 20 26 69 43 75 72 2c 20  MA_USED, &iCur, 
49f0: 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20  &iHiwtr, 0);.   
4a00: 20 70 72 69 6e 74 66 28 22 25 73 20 53 63 68 65   printf("%s Sche
4a10: 6d 61 20 48 65 61 70 20 55 73 61 67 65 3a 20 20  ma Heap Usage:  
4a20: 20 20 20 20 20 20 20 20 20 25 64 20 62 79 74 65           %d byte
4a30: 73 5c 6e 22 2c 20 7a 54 61 67 2c 20 69 43 75 72  s\n", zTag, iCur
4a40: 29 3b 20 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  ); .    sqlite3_
4a50: 64 62 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51  db_status(db, SQ
4a60: 4c 49 54 45 5f 44 42 53 54 41 54 55 53 5f 53 54  LITE_DBSTATUS_ST
4a70: 4d 54 5f 55 53 45 44 2c 20 26 69 43 75 72 2c 20  MT_USED, &iCur, 
4a80: 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20  &iHiwtr, 0);.   
4a90: 20 70 72 69 6e 74 66 28 22 25 73 20 53 74 61 74   printf("%s Stat
4aa0: 65 6d 65 6e 74 20 48 65 61 70 20 55 73 61 67 65  ement Heap Usage
4ab0: 3a 20 20 20 20 20 20 20 20 25 64 20 62 79 74 65  :        %d byte
4ac0: 73 5c 6e 22 2c 20 7a 54 61 67 2c 20 69 43 75 72  s\n", zTag, iCur
4ad0: 29 3b 20 0a 20 20 7d 0a 0a 20 20 73 71 6c 69 74  ); .  }..  sqlit
4ae0: 65 33 5f 63 6c 6f 73 65 28 64 62 29 3b 0a 0a 20  e3_close(db);.. 
4af0: 20 2f 2a 20 47 6c 6f 62 61 6c 20 6d 65 6d 6f 72   /* Global memor
4b00: 79 20 75 73 61 67 65 20 73 74 61 74 69 73 74 69  y usage statisti
4b10: 63 73 20 70 72 69 6e 74 65 64 20 61 66 74 65 72  cs printed after
4b20: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 63 6f   the database co
4b30: 6e 6e 65 63 74 69 6f 6e 0a 20 20 2a 2a 20 68 61  nnection.  ** ha
4b40: 73 20 63 6c 6f 73 65 64 2e 20 20 4d 65 6d 6f 72  s closed.  Memor
4b50: 79 20 75 73 61 67 65 20 73 68 6f 75 6c 64 20 62  y usage should b
4b60: 65 20 7a 65 72 6f 20 61 74 20 74 68 69 73 20 70  e zero at this p
4b70: 6f 69 6e 74 2e 20 2a 2f 0a 20 20 69 66 28 20 73  oint. */.  if( s
4b80: 68 6f 77 53 74 61 74 73 20 29 7b 0a 20 20 20 20  howStats ){.    
4b90: 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28 53  sqlite3_status(S
4ba0: 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 4d 45 4d  QLITE_STATUS_MEM
4bb0: 4f 52 59 5f 55 53 45 44 2c 20 26 69 43 75 72 2c  ORY_USED, &iCur,
4bc0: 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20   &iHiwtr, 0);.  
4bd0: 20 20 70 72 69 6e 74 66 28 22 25 73 20 4d 65 6d    printf("%s Mem
4be0: 6f 72 79 20 55 73 65 64 20 28 62 79 74 65 73 29  ory Used (bytes)
4bf0: 3a 20 20 20 20 20 20 20 20 20 25 64 20 28 6d 61  :         %d (ma
4c00: 78 20 25 64 29 5c 6e 22 2c 20 7a 54 61 67 2c 69  x %d)\n", zTag,i
4c10: 43 75 72 2c 69 48 69 77 74 72 29 3b 0a 20 20 20  Cur,iHiwtr);.   
4c20: 20 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28   sqlite3_status(
4c30: 53 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 4d 41  SQLITE_STATUS_MA
4c40: 4c 4c 4f 43 5f 43 4f 55 4e 54 2c 20 26 69 43 75  LLOC_COUNT, &iCu
4c50: 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a  r, &iHiwtr, 0);.
4c60: 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 20 4f      printf("%s O
4c70: 75 74 73 74 61 6e 64 69 6e 67 20 41 6c 6c 6f 63  utstanding Alloc
4c80: 61 74 69 6f 6e 73 3a 20 20 20 20 20 25 64 20 28  ations:     %d (
4c90: 6d 61 78 20 25 64 29 5c 6e 22 2c 7a 54 61 67 2c  max %d)\n",zTag,
4ca0: 69 43 75 72 2c 69 48 69 77 74 72 29 3b 0a 20 20  iCur,iHiwtr);.  
4cb0: 20 20 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73    sqlite3_status
4cc0: 28 53 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 50  (SQLITE_STATUS_P
4cd0: 41 47 45 43 41 43 48 45 5f 4f 56 45 52 46 4c 4f  AGECACHE_OVERFLO
4ce0: 57 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77 74  W, &iCur, &iHiwt
4cf0: 72 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e 74  r, 0);.    print
4d00: 66 28 22 25 73 20 50 63 61 63 68 65 20 4f 76 65  f("%s Pcache Ove
4d10: 72 66 6c 6f 77 20 42 79 74 65 73 3a 20 20 20 20  rflow Bytes:    
4d20: 20 20 20 25 64 20 28 6d 61 78 20 25 64 29 5c 6e     %d (max %d)\n
4d30: 22 2c 7a 54 61 67 2c 69 43 75 72 2c 69 48 69 77  ",zTag,iCur,iHiw
4d40: 74 72 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  tr);.    sqlite3
4d50: 5f 73 74 61 74 75 73 28 53 51 4c 49 54 45 5f 53  _status(SQLITE_S
4d60: 54 41 54 55 53 5f 53 43 52 41 54 43 48 5f 4f 56  TATUS_SCRATCH_OV
4d70: 45 52 46 4c 4f 57 2c 20 26 69 43 75 72 2c 20 26  ERFLOW, &iCur, &
4d80: 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20  iHiwtr, 0);.    
4d90: 70 72 69 6e 74 66 28 22 25 73 20 53 63 72 61 74  printf("%s Scrat
4da0: 63 68 20 4f 76 65 72 66 6c 6f 77 20 42 79 74 65  ch Overflow Byte
4db0: 73 3a 20 20 20 20 20 20 25 64 20 28 6d 61 78 20  s:      %d (max 
4dc0: 25 64 29 5c 6e 22 2c 7a 54 61 67 2c 69 43 75 72  %d)\n",zTag,iCur
4dd0: 2c 69 48 69 77 74 72 29 3b 0a 20 20 20 20 73 71  ,iHiwtr);.    sq
4de0: 6c 69 74 65 33 5f 73 74 61 74 75 73 28 53 51 4c  lite3_status(SQL
4df0: 49 54 45 5f 53 54 41 54 55 53 5f 4d 41 4c 4c 4f  ITE_STATUS_MALLO
4e00: 43 5f 53 49 5a 45 2c 20 26 69 43 75 72 2c 20 26  C_SIZE, &iCur, &
4e10: 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20  iHiwtr, 0);.    
4e20: 70 72 69 6e 74 66 28 22 25 73 20 4c 61 72 67 65  printf("%s Large
4e30: 73 74 20 41 6c 6c 6f 63 61 74 69 6f 6e 3a 20 20  st Allocation:  
4e40: 20 20 20 20 20 20 20 20 25 64 20 62 79 74 65 73          %d bytes
4e50: 5c 6e 22 2c 7a 54 61 67 2c 69 48 69 77 74 72 29  \n",zTag,iHiwtr)
4e60: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74  ;.    sqlite3_st
4e70: 61 74 75 73 28 53 51 4c 49 54 45 5f 53 54 41 54  atus(SQLITE_STAT
4e80: 55 53 5f 50 41 47 45 43 41 43 48 45 5f 53 49 5a  US_PAGECACHE_SIZ
4e90: 45 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77 74  E, &iCur, &iHiwt
4ea0: 72 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e 74  r, 0);.    print
4eb0: 66 28 22 25 73 20 4c 61 72 67 65 73 74 20 50 63  f("%s Largest Pc
4ec0: 61 63 68 65 20 41 6c 6c 6f 63 61 74 69 6f 6e 3a  ache Allocation:
4ed0: 20 20 20 25 64 20 62 79 74 65 73 5c 6e 22 2c 7a     %d bytes\n",z
4ee0: 54 61 67 2c 69 48 69 77 74 72 29 3b 0a 20 20 20  Tag,iHiwtr);.   
4ef0: 20 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28   sqlite3_status(
4f00: 53 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 53 43  SQLITE_STATUS_SC
4f10: 52 41 54 43 48 5f 53 49 5a 45 2c 20 26 69 43 75  RATCH_SIZE, &iCu
4f20: 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a  r, &iHiwtr, 0);.
4f30: 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 20 4c      printf("%s L
4f40: 61 72 67 65 73 74 20 53 63 72 61 74 63 68 20 41  argest Scratch A
4f50: 6c 6c 6f 63 61 74 69 6f 6e 3a 20 20 25 64 20 62  llocation:  %d b
4f60: 79 74 65 73 5c 6e 22 2c 7a 54 61 67 2c 69 48 69  ytes\n",zTag,iHi
4f70: 77 74 72 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75  wtr);.  }.  retu
4f80: 72 6e 20 30 3b 0a 7d 0a                          rn 0;.}.