/ Hex Artifact Content
Login

Artifact 9915e06cb33d8ca8109b8700791afe80d305afda:


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 20  " %s", azArg[i] 
1040: 3f 20 61 7a 41 72 67 5b 69 5d 20 3a 20 22 28 6e  ? azArg[i] : "(n
1050: 75 6c 6c 29 22 29 3b 0a 20 20 7d 0a 20 20 70 72  ull)");.  }.  pr
1060: 69 6e 74 66 28 22 5c 6e 22 29 3b 0a 20 20 72 65  intf("\n");.  re
1070: 74 75 72 6e 20 30 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a  turn 0;.}.../*.*
1080: 2a 20 41 64 64 20 6f 6e 65 20 63 68 61 72 61 63  * Add one charac
1090: 74 65 72 20 74 6f 20 61 20 68 61 73 68 0a 2a 2f  ter to a hash.*/
10a0: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 61 64 64  .static void add
10b0: 43 68 61 72 54 6f 48 61 73 68 28 75 6e 73 69 67  CharToHash(unsig
10c0: 6e 65 64 20 69 6e 74 20 2a 61 2c 20 75 6e 73 69  ned int *a, unsi
10d0: 67 6e 65 64 20 63 68 61 72 20 78 29 7b 0a 20 20  gned char x){.  
10e0: 69 66 28 20 61 5b 30 5d 3c 34 20 29 7b 0a 20 20  if( a[0]<4 ){.  
10f0: 20 20 61 5b 31 5d 20 3d 20 28 61 5b 31 5d 3c 3c    a[1] = (a[1]<<
1100: 38 29 20 7c 20 78 3b 0a 20 20 20 20 61 5b 30 5d  8) | x;.    a[0]
1110: 2b 2b 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ++;.  }else{.   
1120: 20 61 5b 32 5d 20 3d 20 28 61 5b 32 5d 3c 3c 38   a[2] = (a[2]<<8
1130: 29 20 7c 20 78 3b 0a 20 20 20 20 61 5b 30 5d 2b  ) | x;.    a[0]+
1140: 2b 3b 0a 20 20 20 20 69 66 28 20 61 5b 30 5d 3d  +;.    if( a[0]=
1150: 3d 38 20 29 7b 0a 20 20 20 20 20 20 61 5b 33 5d  =8 ){.      a[3]
1160: 20 2b 3d 20 61 5b 31 5d 20 2b 20 61 5b 34 5d 3b   += a[1] + a[4];
1170: 0a 20 20 20 20 20 20 61 5b 34 5d 20 2b 3d 20 61  .      a[4] += a
1180: 5b 32 5d 20 2b 20 61 5b 33 5d 3b 0a 20 20 20 20  [2] + a[3];.    
1190: 20 20 61 5b 30 5d 20 3d 20 61 5b 31 5d 20 3d 20    a[0] = a[1] = 
11a0: 61 5b 32 5d 20 3d 20 30 3b 0a 20 20 20 20 7d 0a  a[2] = 0;.    }.
11b0: 20 20 7d 20 20 20 20 0a 7d 0a 0a 2f 2a 0a 2a 2a    }    .}../*.**
11c0: 20 43 6f 6d 70 75 74 65 20 74 68 65 20 66 69 6e   Compute the fin
11d0: 61 6c 20 68 61 73 68 20 76 61 6c 75 65 2e 0a 2a  al hash value..*
11e0: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 66 69  /.static void fi
11f0: 6e 61 6c 48 61 73 68 28 75 6e 73 69 67 6e 65 64  nalHash(unsigned
1200: 20 69 6e 74 20 2a 61 2c 20 63 68 61 72 20 2a 7a   int *a, char *z
1210: 29 7b 0a 20 20 61 5b 33 5d 20 2b 3d 20 61 5b 31  ){.  a[3] += a[1
1220: 5d 20 2b 20 61 5b 34 5d 20 2b 20 61 5b 30 5d 3b  ] + a[4] + a[0];
1230: 0a 20 20 61 5b 34 5d 20 2b 3d 20 61 5b 32 5d 20  .  a[4] += a[2] 
1240: 2b 20 61 5b 33 5d 3b 0a 20 20 73 71 6c 69 74 65  + a[3];.  sqlite
1250: 33 5f 73 6e 70 72 69 6e 74 66 28 31 37 2c 20 7a  3_snprintf(17, z
1260: 2c 20 22 25 30 38 78 25 30 38 78 22 2c 20 61 5b  , "%08x%08x", a[
1270: 33 5d 2c 20 61 5b 34 5d 29 3b 0a 7d 0a 0a 0a 2f  3], a[4]);.}.../
1280: 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e 74 61 74  *.** Implementat
1290: 69 6f 6e 20 6f 66 20 61 20 63 68 65 63 6b 73 75  ion of a checksu
12a0: 6d 28 29 20 61 67 67 72 65 67 61 74 65 20 53 51  m() aggregate SQ
12b0: 4c 20 66 75 6e 63 74 69 6f 6e 0a 2a 2f 0a 73 74  L function.*/.st
12c0: 61 74 69 63 20 76 6f 69 64 20 63 68 65 63 6b 73  atic void checks
12d0: 75 6d 53 74 65 70 28 0a 20 20 73 71 6c 69 74 65  umStep(.  sqlite
12e0: 33 5f 63 6f 6e 74 65 78 74 20 2a 63 6f 6e 74 65  3_context *conte
12f0: 78 74 2c 0a 20 20 69 6e 74 20 61 72 67 63 2c 0a  xt,.  int argc,.
1300: 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20    sqlite3_value 
1310: 2a 2a 61 72 67 76 0a 29 7b 0a 20 20 63 6f 6e 73  **argv.){.  cons
1320: 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20  t unsigned char 
1330: 2a 7a 56 61 6c 3b 0a 20 20 69 6e 74 20 6e 56 61  *zVal;.  int nVa
1340: 6c 2c 20 69 2c 20 6a 3b 0a 20 20 75 6e 73 69 67  l, i, j;.  unsig
1350: 6e 65 64 20 69 6e 74 20 2a 61 3b 0a 20 20 61 20  ned int *a;.  a 
1360: 3d 20 28 75 6e 73 69 67 6e 65 64 2a 29 73 71 6c  = (unsigned*)sql
1370: 69 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63  ite3_aggregate_c
1380: 6f 6e 74 65 78 74 28 63 6f 6e 74 65 78 74 2c 20  ontext(context, 
1390: 73 69 7a 65 6f 66 28 75 6e 73 69 67 6e 65 64 20  sizeof(unsigned 
13a0: 69 6e 74 29 2a 35 29 3b 0a 0a 20 20 69 66 28 20  int)*5);..  if( 
13b0: 61 20 29 7b 0a 20 20 20 20 66 6f 72 28 69 3d 30  a ){.    for(i=0
13c0: 3b 20 69 3c 61 72 67 63 3b 20 69 2b 2b 29 7b 0a  ; i<argc; i++){.
13d0: 20 20 20 20 20 20 6e 56 61 6c 20 3d 20 73 71 6c        nVal = sql
13e0: 69 74 65 33 5f 76 61 6c 75 65 5f 62 79 74 65 73  ite3_value_bytes
13f0: 28 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20  (argv[i]);.     
1400: 20 7a 56 61 6c 20 3d 20 28 63 6f 6e 73 74 20 75   zVal = (const u
1410: 6e 73 69 67 6e 65 64 20 63 68 61 72 2a 29 73 71  nsigned char*)sq
1420: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74  lite3_value_text
1430: 28 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20  (argv[i]);.     
1440: 20 69 66 28 20 7a 56 61 6c 20 29 20 66 6f 72 28   if( zVal ) for(
1450: 6a 3d 30 3b 20 6a 3c 6e 56 61 6c 3b 20 6a 2b 2b  j=0; j<nVal; j++
1460: 29 20 61 64 64 43 68 61 72 54 6f 48 61 73 68 28  ) addCharToHash(
1470: 61 2c 20 7a 56 61 6c 5b 6a 5d 29 3b 0a 20 20 20  a, zVal[j]);.   
1480: 20 20 20 61 64 64 43 68 61 72 54 6f 48 61 73 68     addCharToHash
1490: 28 61 2c 20 27 7c 27 29 3b 0a 20 20 20 20 7d 0a  (a, '|');.    }.
14a0: 20 20 20 20 61 64 64 43 68 61 72 54 6f 48 61 73      addCharToHas
14b0: 68 28 61 2c 20 27 5c 6e 27 29 3b 0a 20 20 7d 0a  h(a, '\n');.  }.
14c0: 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 63 68  }.static void ch
14d0: 65 63 6b 73 75 6d 46 69 6e 61 6c 69 7a 65 28 73  ecksumFinalize(s
14e0: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
14f0: 63 6f 6e 74 65 78 74 29 7b 0a 20 20 75 6e 73 69  context){.  unsi
1500: 67 6e 65 64 20 69 6e 74 20 2a 61 3b 0a 20 20 63  gned int *a;.  c
1510: 68 61 72 20 7a 52 65 73 75 6c 74 5b 32 34 5d 3b  har zResult[24];
1520: 0a 20 20 61 20 3d 20 73 71 6c 69 74 65 33 5f 61  .  a = sqlite3_a
1530: 67 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78 74  ggregate_context
1540: 28 63 6f 6e 74 65 78 74 2c 20 30 29 3b 0a 20 20  (context, 0);.  
1550: 69 66 28 20 61 20 29 7b 0a 20 20 20 20 66 69 6e  if( a ){.    fin
1560: 61 6c 48 61 73 68 28 61 2c 20 7a 52 65 73 75 6c  alHash(a, zResul
1570: 74 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  t);.    sqlite3_
1580: 72 65 73 75 6c 74 5f 74 65 78 74 28 63 6f 6e 74  result_text(cont
1590: 65 78 74 2c 20 7a 52 65 73 75 6c 74 2c 20 2d 31  ext, zResult, -1
15a0: 2c 20 53 51 4c 49 54 45 5f 54 52 41 4e 53 49 45  , SQLITE_TRANSIE
15b0: 4e 54 29 3b 0a 20 20 7d 0a 7d 0a 0a 0a 2f 2a 20  NT);.  }.}.../* 
15c0: 44 65 66 69 6e 65 20 6f 70 65 72 61 74 69 6e 67  Define operating
15d0: 20 6d 6f 64 65 73 20 2a 2f 0a 23 64 65 66 69 6e   modes */.#defin
15e0: 65 20 4d 4f 44 45 5f 49 4e 53 45 52 54 20 20 20  e MODE_INSERT   
15f0: 20 20 30 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45    0.#define MODE
1600: 5f 52 45 50 4c 41 43 45 20 20 20 20 31 0a 23 64  _REPLACE    1.#d
1610: 65 66 69 6e 65 20 4d 4f 44 45 5f 53 45 4c 45 43  efine MODE_SELEC
1620: 54 20 20 20 20 20 32 0a 23 64 65 66 69 6e 65 20  T     2.#define 
1630: 4d 4f 44 45 5f 55 50 44 41 54 45 20 20 20 20 20  MODE_UPDATE     
1640: 33 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f 44  3.#define MODE_D
1650: 45 4c 45 54 45 20 20 20 20 20 34 0a 23 64 65 66  ELETE     4.#def
1660: 69 6e 65 20 4d 4f 44 45 5f 51 55 45 52 59 20 20  ine MODE_QUERY  
1670: 20 20 20 20 35 0a 0a 69 6e 74 20 6d 61 69 6e 28      5..int main(
1680: 69 6e 74 20 61 72 67 63 2c 20 63 68 61 72 20 2a  int argc, char *
1690: 2a 61 72 67 76 29 7b 0a 20 20 63 6f 6e 73 74 20  *argv){.  const 
16a0: 63 68 61 72 20 2a 7a 46 69 6c 65 54 6f 52 65 61  char *zFileToRea
16b0: 64 20 3d 20 30 3b 20 20 2f 2a 20 49 6e 70 75 74  d = 0;  /* Input
16c0: 20 66 69 6c 65 2e 20 20 4e 55 4c 4c 20 66 6f 72   file.  NULL for
16d0: 20 73 74 64 69 6e 20 2a 2f 0a 20 20 63 6f 6e 73   stdin */.  cons
16e0: 74 20 63 68 61 72 20 2a 7a 44 62 4e 61 6d 65 20  t char *zDbName 
16f0: 3d 20 30 3b 20 20 20 20 20 20 2f 2a 20 4e 61 6d  = 0;      /* Nam
1700: 65 20 6f 66 20 74 68 65 20 64 61 74 61 62 61 73  e of the databas
1710: 65 20 66 69 6c 65 20 74 6f 20 63 72 65 61 74 65  e file to create
1720: 20 2a 2f 0a 20 20 69 6e 74 20 75 73 65 57 69 74   */.  int useWit
1730: 68 6f 75 74 52 6f 77 69 64 20 3d 20 30 3b 20 20  houtRowid = 0;  
1740: 20 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20      /* True for 
1750: 2d 2d 77 69 74 68 6f 75 74 2d 72 6f 77 69 64 20  --without-rowid 
1760: 2a 2f 0a 20 20 69 6e 74 20 69 4d 6f 64 65 20 3d  */.  int iMode =
1770: 20 4d 4f 44 45 5f 49 4e 53 45 52 54 3b 20 20 20   MODE_INSERT;   
1780: 20 20 20 2f 2a 20 4f 6e 65 20 6f 66 20 4d 4f 44     /* One of MOD
1790: 45 5f 78 78 78 78 78 20 2a 2f 0a 20 20 69 6e 74  E_xxxxx */.  int
17a0: 20 75 73 65 4e 6f 63 61 73 65 20 3d 20 30 3b 20   useNocase = 0; 
17b0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72             /* Tr
17c0: 75 65 20 66 6f 72 20 2d 2d 6e 6f 63 61 73 65 20  ue for --nocase 
17d0: 2a 2f 0a 20 20 69 6e 74 20 64 6f 54 72 61 63 65  */.  int doTrace
17e0: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
17f0: 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20 2d     /* True for -
1800: 2d 74 72 61 63 65 20 2a 2f 0a 20 20 69 6e 74 20  -trace */.  int 
1810: 73 68 6f 77 53 74 61 74 73 20 3d 20 30 3b 20 20  showStats = 0;  
1820: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75            /* Tru
1830: 65 20 66 6f 72 20 2d 2d 73 74 61 74 73 20 2a 2f  e for --stats */
1840: 0a 20 20 69 6e 74 20 73 68 6f 77 53 75 6d 6d 61  .  int showSumma
1850: 72 79 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20  ry = 0;         
1860: 20 2f 2a 20 54 72 75 65 20 66 6f 72 20 2d 2d 73   /* True for --s
1870: 75 6d 6d 61 72 79 20 2a 2f 0a 20 20 69 6e 74 20  ummary */.  int 
1880: 73 68 6f 77 54 69 6d 65 72 20 3d 20 30 3b 20 20  showTimer = 0;  
1890: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75            /* Tru
18a0: 65 20 66 6f 72 20 2d 2d 74 69 6d 65 72 20 2a 2f  e for --timer */
18b0: 0a 20 20 69 6e 74 20 63 61 63 68 65 53 69 7a 65  .  int cacheSize
18c0: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
18d0: 20 2f 2a 20 44 65 73 69 72 65 64 20 63 61 63 68   /* Desired cach
18e0: 65 20 73 69 7a 65 2e 20 20 30 20 6d 65 61 6e 73  e size.  0 means
18f0: 20 64 65 66 61 75 6c 74 20 2a 2f 0a 20 20 69 6e   default */.  in
1900: 74 20 70 61 67 65 53 69 7a 65 20 3d 20 30 3b 20  t pageSize = 0; 
1910: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44              /* D
1920: 65 73 69 72 65 64 20 70 61 67 65 20 73 69 7a 65  esired page size
1930: 2e 20 20 30 20 6d 65 61 6e 73 20 64 65 66 61 75  .  0 means defau
1940: 6c 74 20 2a 2f 0a 20 20 69 6e 74 20 63 6f 6d 6d  lt */.  int comm
1950: 69 74 49 6e 74 65 72 76 61 6c 20 3d 20 30 3b 20  itInterval = 0; 
1960: 20 20 20 20 20 20 2f 2a 20 48 6f 77 20 6f 66 74        /* How oft
1970: 65 6e 20 74 6f 20 63 6f 6d 6d 69 74 2e 20 20 30  en to commit.  0
1980: 20 6d 65 61 6e 73 20 6e 65 76 65 72 20 2a 2f 0a   means never */.
1990: 20 20 69 6e 74 20 6e 6f 53 79 6e 63 20 3d 20 30    int noSync = 0
19a0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
19b0: 2f 2a 20 54 72 75 65 20 66 6f 72 20 2d 2d 6e 6f  /* True for --no
19c0: 73 79 6e 63 20 2a 2f 0a 20 20 63 6f 6e 73 74 20  sync */.  const 
19d0: 63 68 61 72 20 2a 7a 4a 4d 6f 64 65 20 3d 20 30  char *zJMode = 0
19e0: 3b 20 20 20 20 20 20 20 2f 2a 20 4a 6f 75 72 6e  ;       /* Journ
19f0: 61 6c 20 6d 6f 64 65 20 2a 2f 0a 20 20 69 6e 74  al mode */.  int
1a00: 20 6e 4f 70 20 3d 20 30 3b 20 20 20 20 20 20 20   nOp = 0;       
1a10: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 70             /* Op
1a20: 65 72 61 74 69 6f 6e 20 63 6f 75 6e 74 65 72 20  eration counter 
1a30: 2a 2f 0a 20 20 69 6e 74 20 69 2c 20 6a 3b 20 20  */.  int i, j;  
1a40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a50: 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e 74     /* Loop count
1a60: 65 72 73 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  ers */.  sqlite3
1a70: 20 2a 64 62 3b 20 20 20 20 20 20 20 20 20 20 20   *db;           
1a80: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 53 51         /* The SQ
1a90: 4c 69 74 65 20 64 61 74 61 62 61 73 65 20 63 6f  Lite database co
1aa0: 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a 20 20 63 68  nnection */.  ch
1ab0: 61 72 20 2a 7a 53 71 6c 3b 20 20 20 20 20 20 20  ar *zSql;       
1ac0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43              /* C
1ad0: 6f 6e 73 74 72 75 63 74 65 64 20 53 51 4c 20 73  onstructed SQL s
1ae0: 74 61 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 73 71  tatement */.  sq
1af0: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 49 6e 73  lite3_stmt *pIns
1b00: 65 72 74 20 3d 20 30 3b 20 20 20 20 2f 2a 20 54  ert = 0;    /* T
1b10: 68 65 20 49 4e 53 45 52 54 20 73 74 61 74 65 6d  he INSERT statem
1b20: 65 6e 74 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  ent */.  sqlite3
1b30: 5f 73 74 6d 74 20 2a 70 55 70 64 61 74 65 20 3d  _stmt *pUpdate =
1b40: 20 30 3b 20 20 20 20 2f 2a 20 54 68 65 20 55 50   0;    /* The UP
1b50: 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 20 2a  DATE statement *
1b60: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74  /.  sqlite3_stmt
1b70: 20 2a 70 53 65 6c 65 63 74 20 3d 20 30 3b 20 20   *pSelect = 0;  
1b80: 20 20 2f 2a 20 54 68 65 20 53 45 4c 45 43 54 20    /* The SELECT 
1b90: 73 74 61 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 73  statement */.  s
1ba0: 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 44 65  qlite3_stmt *pDe
1bb0: 6c 65 74 65 20 3d 20 30 3b 20 20 20 20 2f 2a 20  lete = 0;    /* 
1bc0: 54 68 65 20 44 45 4c 45 54 45 20 73 74 61 74 65  The DELETE state
1bd0: 6d 65 6e 74 20 2a 2f 0a 20 20 46 49 4c 45 20 2a  ment */.  FILE *
1be0: 69 6e 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  in;             
1bf0: 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6f          /* The o
1c00: 70 65 6e 20 69 6e 70 75 74 20 66 69 6c 65 20 2a  pen input file *
1c10: 2f 0a 20 20 69 6e 74 20 72 63 3b 20 20 20 20 20  /.  int rc;     
1c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1c30: 20 20 2f 2a 20 52 65 74 75 72 6e 20 63 6f 64 65    /* Return code
1c40: 20 66 72 6f 6d 20 61 6e 20 53 51 4c 69 74 65 20   from an SQLite 
1c50: 69 6e 74 65 72 66 61 63 65 20 2a 2f 0a 20 20 69  interface */.  i
1c60: 6e 74 20 69 43 75 72 2c 20 69 48 69 77 74 72 3b  nt iCur, iHiwtr;
1c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1c80: 53 74 61 74 69 73 74 69 63 73 20 76 61 6c 75 65  Statistics value
1c90: 73 2c 20 63 75 72 72 65 6e 74 20 61 6e 64 20 22  s, current and "
1ca0: 68 69 67 68 77 61 74 65 72 22 20 2a 2f 0a 20 20  highwater" */.  
1cb0: 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 73 75  sqlite3_int64 su
1cc0: 6d 43 6e 74 20 3d 20 30 3b 20 20 20 20 20 2f 2a  mCnt = 0;     /*
1cd0: 20 53 75 6d 20 69 6e 20 51 55 45 52 59 20 6d 6f   Sum in QUERY mo
1ce0: 64 65 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f  de */.  sqlite3_
1cf0: 69 6e 74 36 34 20 73 74 61 72 74 54 69 6d 65 3b  int64 startTime;
1d00: 0a 20 20 63 68 61 72 20 7a 49 6e 70 75 74 5b 32  .  char zInput[2
1d10: 30 30 30 5d 3b 20 20 20 20 20 20 20 20 20 20 20  000];           
1d20: 20 2f 2a 20 41 20 73 69 6e 67 6c 65 20 6c 69 6e   /* A single lin
1d30: 65 20 6f 66 20 69 6e 70 75 74 20 2a 2f 0a 0a 20  e of input */.. 
1d40: 20 2f 2a 20 50 72 6f 63 65 73 73 20 63 6f 6d 6d   /* Process comm
1d50: 61 6e 64 2d 6c 69 6e 65 20 61 72 67 75 6d 65 6e  and-line argumen
1d60: 74 73 20 2a 2f 0a 20 20 66 6f 72 28 69 3d 31 3b  ts */.  for(i=1;
1d70: 20 69 3c 61 72 67 63 3b 20 69 2b 2b 29 7b 0a 20   i<argc; i++){. 
1d80: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a     const char *z
1d90: 20 3d 20 61 72 67 76 5b 69 5d 3b 0a 20 20 20 20   = argv[i];.    
1da0: 69 66 28 20 7a 5b 30 5d 3d 3d 27 2d 27 20 29 7b  if( z[0]=='-' ){
1db0: 0a 20 20 20 20 20 20 64 6f 7b 20 7a 2b 2b 3b 20  .      do{ z++; 
1dc0: 7d 77 68 69 6c 65 28 20 7a 5b 30 5d 3d 3d 27 2d  }while( z[0]=='-
1dd0: 27 20 29 3b 0a 20 20 20 20 20 20 69 66 28 20 73  ' );.      if( s
1de0: 74 72 63 6d 70 28 7a 2c 22 77 69 74 68 6f 75 74  trcmp(z,"without
1df0: 2d 72 6f 77 69 64 22 29 3d 3d 30 20 29 7b 0a 20  -rowid")==0 ){. 
1e00: 20 20 20 20 20 20 20 75 73 65 57 69 74 68 6f 75         useWithou
1e10: 74 52 6f 77 69 64 20 3d 20 31 3b 0a 20 20 20 20  tRowid = 1;.    
1e20: 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63    }else if( strc
1e30: 6d 70 28 7a 2c 22 72 65 70 6c 61 63 65 22 29 3d  mp(z,"replace")=
1e40: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 69 4d  =0 ){.        iM
1e50: 6f 64 65 20 3d 20 4d 4f 44 45 5f 52 45 50 4c 41  ode = MODE_REPLA
1e60: 43 45 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20  CE;.      }else 
1e70: 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 73 65  if( strcmp(z,"se
1e80: 6c 65 63 74 22 29 3d 3d 30 20 29 7b 0a 20 20 20  lect")==0 ){.   
1e90: 20 20 20 20 20 69 4d 6f 64 65 20 3d 20 4d 4f 44       iMode = MOD
1ea0: 45 5f 53 45 4c 45 43 54 3b 0a 20 20 20 20 20 20  E_SELECT;.      
1eb0: 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70  }else if( strcmp
1ec0: 28 7a 2c 22 69 6e 73 65 72 74 22 29 3d 3d 30 20  (z,"insert")==0 
1ed0: 29 7b 0a 20 20 20 20 20 20 20 20 69 4d 6f 64 65  ){.        iMode
1ee0: 20 3d 20 4d 4f 44 45 5f 49 4e 53 45 52 54 3b 0a   = MODE_INSERT;.
1ef0: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
1f00: 73 74 72 63 6d 70 28 7a 2c 22 75 70 64 61 74 65  strcmp(z,"update
1f10: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ")==0 ){.       
1f20: 20 69 4d 6f 64 65 20 3d 20 4d 4f 44 45 5f 55 50   iMode = MODE_UP
1f30: 44 41 54 45 3b 0a 20 20 20 20 20 20 7d 65 6c 73  DATE;.      }els
1f40: 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22  e if( strcmp(z,"
1f50: 64 65 6c 65 74 65 22 29 3d 3d 30 20 29 7b 0a 20  delete")==0 ){. 
1f60: 20 20 20 20 20 20 20 69 4d 6f 64 65 20 3d 20 4d         iMode = M
1f70: 4f 44 45 5f 44 45 4c 45 54 45 3b 0a 20 20 20 20  ODE_DELETE;.    
1f80: 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63    }else if( strc
1f90: 6d 70 28 7a 2c 22 71 75 65 72 79 22 29 3d 3d 30  mp(z,"query")==0
1fa0: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 4d 6f 64   ){.        iMod
1fb0: 65 20 3d 20 4d 4f 44 45 5f 51 55 45 52 59 3b 0a  e = MODE_QUERY;.
1fc0: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
1fd0: 73 74 72 63 6d 70 28 7a 2c 22 6e 6f 63 61 73 65  strcmp(z,"nocase
1fe0: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ")==0 ){.       
1ff0: 20 75 73 65 4e 6f 63 61 73 65 20 3d 20 31 3b 0a   useNocase = 1;.
2000: 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20        }else if( 
2010: 73 74 72 63 6d 70 28 7a 2c 22 74 72 61 63 65 22  strcmp(z,"trace"
2020: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  )==0 ){.        
2030: 64 6f 54 72 61 63 65 20 3d 20 31 3b 0a 20 20 20  doTrace = 1;.   
2040: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72     }else if( str
2050: 63 6d 70 28 7a 2c 22 6e 6f 73 79 6e 63 22 29 3d  cmp(z,"nosync")=
2060: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 6e 6f  =0 ){.        no
2070: 53 79 6e 63 20 3d 20 31 3b 0a 20 20 20 20 20 20  Sync = 1;.      
2080: 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70  }else if( strcmp
2090: 28 7a 2c 22 73 74 61 74 73 22 29 3d 3d 30 20 29  (z,"stats")==0 )
20a0: 7b 0a 20 20 20 20 20 20 20 20 73 68 6f 77 53 74  {.        showSt
20b0: 61 74 73 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d  ats = 1;.      }
20c0: 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70 28  else if( strcmp(
20d0: 7a 2c 22 73 75 6d 6d 61 72 79 22 29 3d 3d 30 20  z,"summary")==0 
20e0: 29 7b 0a 20 20 20 20 20 20 20 20 73 68 6f 77 53  ){.        showS
20f0: 75 6d 6d 61 72 79 20 3d 20 31 3b 0a 20 20 20 20  ummary = 1;.    
2100: 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63    }else if( strc
2110: 6d 70 28 7a 2c 22 74 69 6d 65 72 22 29 3d 3d 30  mp(z,"timer")==0
2120: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 68 6f 77   ){.        show
2130: 54 69 6d 65 72 20 3d 20 69 3b 0a 20 20 20 20 20  Timer = i;.     
2140: 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d   }else if( strcm
2150: 70 28 7a 2c 22 63 61 63 68 65 73 69 7a 65 22 29  p(z,"cachesize")
2160: 3d 3d 30 20 26 26 20 69 3c 61 72 67 63 2d 31 20  ==0 && i<argc-1 
2170: 29 7b 0a 20 20 20 20 20 20 20 20 69 2b 2b 3b 0a  ){.        i++;.
2180: 20 20 20 20 20 20 20 20 63 61 63 68 65 53 69 7a          cacheSiz
2190: 65 20 3d 20 61 74 6f 69 28 61 72 67 76 5b 69 5d  e = atoi(argv[i]
21a0: 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  );.      }else i
21b0: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 70 61 67  f( strcmp(z,"pag
21c0: 65 73 69 7a 65 22 29 3d 3d 30 20 26 26 20 69 3c  esize")==0 && i<
21d0: 61 72 67 63 2d 31 20 29 7b 0a 20 20 20 20 20 20  argc-1 ){.      
21e0: 20 20 69 2b 2b 3b 0a 20 20 20 20 20 20 20 20 70    i++;.        p
21f0: 61 67 65 53 69 7a 65 20 3d 20 61 74 6f 69 28 61  ageSize = atoi(a
2200: 72 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20 20 7d  rgv[i]);.      }
2210: 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70 28  else if( strcmp(
2220: 7a 2c 22 63 6f 6d 6d 69 74 22 29 3d 3d 30 20 26  z,"commit")==0 &
2230: 26 20 69 3c 61 72 67 63 2d 31 20 29 7b 0a 20 20  & i<argc-1 ){.  
2240: 20 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20 20 20        i++;.     
2250: 20 20 20 63 6f 6d 6d 69 74 49 6e 74 65 72 76 61     commitInterva
2260: 6c 20 3d 20 61 74 6f 69 28 61 72 67 76 5b 69 5d  l = atoi(argv[i]
2270: 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69  );.      }else i
2280: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 6a 6f 75  f( strcmp(z,"jou
2290: 72 6e 61 6c 22 29 3d 3d 30 20 26 26 20 69 3c 61  rnal")==0 && i<a
22a0: 72 67 63 2d 31 20 29 7b 0a 20 20 20 20 20 20 20  rgc-1 ){.       
22b0: 20 7a 4a 4d 6f 64 65 20 3d 20 61 72 67 76 5b 2b   zJMode = argv[+
22c0: 2b 69 5d 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  +i];.      }else
22d0: 7b 0a 20 20 20 20 20 20 20 20 66 61 74 61 6c 5f  {.        fatal_
22e0: 65 72 72 6f 72 28 22 75 6e 6b 6e 6f 77 6e 20 6f  error("unknown o
22f0: 70 74 69 6f 6e 3a 20 25 73 5c 6e 22 2c 20 61 72  ption: %s\n", ar
2300: 67 76 5b 69 5d 29 3b 0a 20 20 20 20 20 20 7d 0a  gv[i]);.      }.
2310: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 7a 44      }else if( zD
2320: 62 4e 61 6d 65 3d 3d 30 20 29 7b 0a 20 20 20 20  bName==0 ){.    
2330: 20 20 7a 44 62 4e 61 6d 65 20 3d 20 61 72 67 76    zDbName = argv
2340: 5b 69 5d 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69  [i];.    }else i
2350: 66 28 20 7a 46 69 6c 65 54 6f 52 65 61 64 3d 3d  f( zFileToRead==
2360: 30 20 29 7b 0a 20 20 20 20 20 20 7a 46 69 6c 65  0 ){.      zFile
2370: 54 6f 52 65 61 64 20 3d 20 61 72 67 76 5b 69 5d  ToRead = argv[i]
2380: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
2390: 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22     fatal_error("
23a0: 73 75 72 70 6c 75 73 20 61 72 67 75 6d 65 6e 74  surplus argument
23b0: 3a 20 25 73 5c 6e 22 2c 20 61 72 67 76 5b 69 5d  : %s\n", argv[i]
23c0: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 69  );.    }.  }.  i
23d0: 66 28 20 7a 44 62 4e 61 6d 65 3d 3d 30 20 29 7b  f( zDbName==0 ){
23e0: 0a 20 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72  .    fatal_error
23f0: 28 22 55 73 61 67 65 3a 20 25 73 20 5b 2d 2d 6f  ("Usage: %s [--o
2400: 70 74 69 6f 6e 73 5d 20 44 41 54 41 42 41 53 45  ptions] DATABASE
2410: 20 5b 49 4e 50 55 54 46 49 4c 45 5d 5c 6e 22 2c   [INPUTFILE]\n",
2420: 20 61 72 67 76 5b 30 5d 29 3b 0a 20 20 7d 0a 20   argv[0]);.  }. 
2430: 20 73 74 61 72 74 54 69 6d 65 20 3d 20 72 65 61   startTime = rea
2440: 6c 54 69 6d 65 28 29 3b 0a 0a 20 20 2f 2a 20 4f  lTime();..  /* O
2450: 70 65 6e 20 74 68 65 20 64 61 74 61 62 61 73 65  pen the database
2460: 20 61 6e 64 20 74 68 65 20 69 6e 70 75 74 20 66   and the input f
2470: 69 6c 65 20 2a 2f 0a 20 20 69 66 28 20 73 71 6c  ile */.  if( sql
2480: 69 74 65 33 5f 6f 70 65 6e 28 7a 44 62 4e 61 6d  ite3_open(zDbNam
2490: 65 2c 20 26 64 62 29 20 29 7b 0a 20 20 20 20 66  e, &db) ){.    f
24a0: 61 74 61 6c 5f 65 72 72 6f 72 28 22 43 61 6e 6e  atal_error("Cann
24b0: 6f 74 20 6f 70 65 6e 20 64 61 74 61 62 61 73 65  ot open database
24c0: 20 66 69 6c 65 3a 20 25 73 5c 6e 22 2c 20 7a 44   file: %s\n", zD
24d0: 62 4e 61 6d 65 29 3b 0a 20 20 7d 0a 20 20 69 66  bName);.  }.  if
24e0: 28 20 7a 46 69 6c 65 54 6f 52 65 61 64 20 29 7b  ( zFileToRead ){
24f0: 0a 20 20 20 20 69 6e 20 3d 20 66 6f 70 65 6e 28  .    in = fopen(
2500: 7a 46 69 6c 65 54 6f 52 65 61 64 2c 20 22 72 62  zFileToRead, "rb
2510: 22 29 3b 0a 20 20 20 20 69 66 28 20 69 6e 3d 3d  ");.    if( in==
2520: 30 20 29 7b 0a 20 20 20 20 20 20 66 61 74 61 6c  0 ){.      fatal
2530: 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f  _error("Could no
2540: 74 20 6f 70 65 6e 20 69 6e 70 75 74 20 66 69 6c  t open input fil
2550: 65 20 5c 22 25 73 5c 22 5c 6e 22 2c 20 7a 46 69  e \"%s\"\n", zFi
2560: 6c 65 54 6f 52 65 61 64 29 3b 0a 20 20 20 20 7d  leToRead);.    }
2570: 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 69 6e  .  }else{.    in
2580: 20 3d 20 73 74 64 69 6e 3b 0a 20 20 7d 0a 0a 20   = stdin;.  }.. 
2590: 20 2f 2a 20 53 65 74 20 64 61 74 61 62 61 73 65   /* Set database
25a0: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 6f 70 74 69   connection opti
25b0: 6f 6e 73 20 2a 2f 0a 20 20 69 66 28 20 64 6f 54  ons */.  if( doT
25c0: 72 61 63 65 20 29 20 73 71 6c 69 74 65 33 5f 74  race ) sqlite3_t
25d0: 72 61 63 65 28 64 62 2c 20 74 72 61 63 65 43 61  race(db, traceCa
25e0: 6c 6c 62 61 63 6b 2c 20 30 29 3b 0a 20 20 69 66  llback, 0);.  if
25f0: 28 20 70 61 67 65 53 69 7a 65 20 29 7b 0a 20 20  ( pageSize ){.  
2600: 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33    zSql = sqlite3
2610: 5f 6d 70 72 69 6e 74 66 28 22 50 52 41 47 4d 41  _mprintf("PRAGMA
2620: 20 70 61 67 65 5f 73 69 7a 65 3d 25 64 22 2c 20   page_size=%d", 
2630: 70 61 67 65 53 69 7a 65 29 3b 0a 20 20 20 20 73  pageSize);.    s
2640: 71 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20  qlite3_exec(db, 
2650: 7a 53 71 6c 2c 20 30 2c 20 30 2c 20 30 29 3b 0a  zSql, 0, 0, 0);.
2660: 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65      sqlite3_free
2670: 28 7a 53 71 6c 29 3b 0a 20 20 7d 0a 20 20 69 66  (zSql);.  }.  if
2680: 28 20 63 61 63 68 65 53 69 7a 65 20 29 7b 0a 20  ( cacheSize ){. 
2690: 20 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65     zSql = sqlite
26a0: 33 5f 6d 70 72 69 6e 74 66 28 22 50 52 41 47 4d  3_mprintf("PRAGM
26b0: 41 20 63 61 63 68 65 5f 73 69 7a 65 3d 25 64 22  A cache_size=%d"
26c0: 2c 20 63 61 63 68 65 53 69 7a 65 29 3b 0a 20 20  , cacheSize);.  
26d0: 20 20 73 71 6c 69 74 65 33 5f 65 78 65 63 28 64    sqlite3_exec(d
26e0: 62 2c 20 7a 53 71 6c 2c 20 30 2c 20 30 2c 20 30  b, zSql, 0, 0, 0
26f0: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66  );.    sqlite3_f
2700: 72 65 65 28 7a 53 71 6c 29 3b 0a 20 20 7d 0a 20  ree(zSql);.  }. 
2710: 20 69 66 28 20 6e 6f 53 79 6e 63 20 29 20 73 71   if( noSync ) sq
2720: 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20 22  lite3_exec(db, "
2730: 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f  PRAGMA synchrono
2740: 75 73 3d 4f 46 46 22 2c 20 30 2c 20 30 2c 20 30  us=OFF", 0, 0, 0
2750: 29 3b 0a 20 20 69 66 28 20 7a 4a 4d 6f 64 65 20  );.  if( zJMode 
2760: 29 7b 0a 20 20 20 20 7a 53 71 6c 20 3d 20 73 71  ){.    zSql = sq
2770: 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 22 50  lite3_mprintf("P
2780: 52 41 47 4d 41 20 6a 6f 75 72 6e 61 6c 5f 6d 6f  RAGMA journal_mo
2790: 64 65 3d 25 73 22 2c 20 7a 4a 4d 6f 64 65 29 3b  de=%s", zJMode);
27a0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 65 78 65  .    sqlite3_exe
27b0: 63 28 64 62 2c 20 7a 53 71 6c 2c 20 30 2c 20 30  c(db, zSql, 0, 0
27c0: 2c 20 30 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  , 0);.    sqlite
27d0: 33 5f 66 72 65 65 28 7a 53 71 6c 29 3b 0a 20 20  3_free(zSql);.  
27e0: 7d 0a 0a 0a 20 20 2f 2a 20 43 6f 6e 73 74 72 75  }...  /* Constru
27f0: 63 74 20 74 68 65 20 22 77 6f 72 64 63 6f 75 6e  ct the "wordcoun
2800: 74 22 20 74 61 62 6c 65 20 69 6e 74 6f 20 77 68  t" table into wh
2810: 69 63 68 20 74 6f 20 70 75 74 20 74 68 65 20 77  ich to put the w
2820: 6f 72 64 73 20 2a 2f 0a 20 20 69 66 28 20 73 71  ords */.  if( sq
2830: 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20 22  lite3_exec(db, "
2840: 42 45 47 49 4e 20 49 4d 4d 45 44 49 41 54 45 22  BEGIN IMMEDIATE"
2850: 2c 20 30 2c 20 30 2c 20 30 29 20 29 7b 0a 20 20  , 0, 0, 0) ){.  
2860: 20 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 43    fatal_error("C
2870: 6f 75 6c 64 20 6e 6f 74 20 73 74 61 72 74 20 61  ould not start a
2880: 20 74 72 61 6e 73 61 63 74 69 6f 6e 5c 6e 22 29   transaction\n")
2890: 3b 0a 20 20 7d 0a 20 20 7a 53 71 6c 20 3d 20 73  ;.  }.  zSql = s
28a0: 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 0a  qlite3_mprintf(.
28b0: 20 20 20 20 20 22 43 52 45 41 54 45 20 54 41 42       "CREATE TAB
28c0: 4c 45 20 49 46 20 4e 4f 54 20 45 58 49 53 54 53  LE IF NOT EXISTS
28d0: 20 77 6f 72 64 63 6f 75 6e 74 28 5c 6e 22 0a 20   wordcount(\n". 
28e0: 20 20 20 20 22 20 20 77 6f 72 64 20 54 45 58 54      "  word TEXT
28f0: 20 50 52 49 4d 41 52 59 20 4b 45 59 20 43 4f 4c   PRIMARY KEY COL
2900: 4c 41 54 45 20 25 73 2c 5c 6e 22 0a 20 20 20 20  LATE %s,\n".    
2910: 20 22 20 20 63 6e 74 20 49 4e 54 45 47 45 52 5c   "  cnt INTEGER\
2920: 6e 22 0a 20 20 20 20 20 22 29 25 73 22 2c 0a 20  n".     ")%s",. 
2930: 20 20 20 20 75 73 65 4e 6f 63 61 73 65 20 3f 20      useNocase ? 
2940: 22 6e 6f 63 61 73 65 22 20 3a 20 22 62 69 6e 61  "nocase" : "bina
2950: 72 79 22 2c 0a 20 20 20 20 20 75 73 65 57 69 74  ry",.     useWit
2960: 68 6f 75 74 52 6f 77 69 64 20 3f 20 22 20 57 49  houtRowid ? " WI
2970: 54 48 4f 55 54 20 52 4f 57 49 44 22 20 3a 20 22  THOUT ROWID" : "
2980: 22 0a 20 20 29 3b 0a 20 20 69 66 28 20 7a 53 71  ".  );.  if( zSq
2990: 6c 3d 3d 30 20 29 20 66 61 74 61 6c 5f 65 72 72  l==0 ) fatal_err
29a0: 6f 72 28 22 6f 75 74 20 6f 66 20 6d 65 6d 6f 72  or("out of memor
29b0: 79 5c 6e 22 29 3b 0a 20 20 72 63 20 3d 20 73 71  y\n");.  rc = sq
29c0: 6c 69 74 65 33 5f 65 78 65 63 28 64 62 2c 20 7a  lite3_exec(db, z
29d0: 53 71 6c 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20  Sql, 0, 0, 0);. 
29e0: 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c 5f   if( rc ) fatal_
29f0: 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f 74  error("Could not
2a00: 20 63 72 65 61 74 65 20 74 68 65 20 77 6f 72 64   create the word
2a10: 63 6f 75 6e 74 20 74 61 62 6c 65 3a 20 25 73 2e  count table: %s.
2a20: 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20  \n",.           
2a30: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
2a40: 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b  te3_errmsg(db));
2a50: 0a 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28  .  sqlite3_free(
2a60: 7a 53 71 6c 29 3b 0a 0a 20 20 2f 2a 20 50 72 65  zSql);..  /* Pre
2a70: 70 61 72 65 20 53 51 4c 20 73 74 61 74 65 6d 65  pare SQL stateme
2a80: 6e 74 73 20 74 68 61 74 20 77 69 6c 6c 20 62 65  nts that will be
2a90: 20 6e 65 65 64 65 64 20 2a 2f 0a 20 20 69 66 28   needed */.  if(
2aa0: 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 51 55 45   iMode==MODE_QUE
2ab0: 52 59 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73  RY ){.    rc = s
2ac0: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
2ad0: 32 28 64 62 2c 0a 20 20 20 20 20 20 20 20 20 20  2(db,.          
2ae0: 22 53 45 4c 45 43 54 20 63 6e 74 20 46 52 4f 4d  "SELECT cnt FROM
2af0: 20 77 6f 72 64 63 6f 75 6e 74 20 57 48 45 52 45   wordcount WHERE
2b00: 20 77 6f 72 64 3d 3f 31 22 2c 0a 20 20 20 20 20   word=?1",.     
2b10: 20 20 20 20 20 2d 31 2c 20 26 70 53 65 6c 65 63       -1, &pSelec
2b20: 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72  t, 0);.    if( r
2b30: 63 20 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28  c ) fatal_error(
2b40: 22 43 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70 61  "Could not prepa
2b50: 72 65 20 74 68 65 20 53 45 4c 45 43 54 20 73 74  re the SELECT st
2b60: 61 74 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a  atement: %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 20 20 20 73 71 6c 69 74 65            sqlite
2b90: 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20  3_errmsg(db));. 
2ba0: 20 7d 0a 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d   }.  if( iMode==
2bb0: 4d 4f 44 45 5f 53 45 4c 45 43 54 20 29 7b 0a 20  MODE_SELECT ){. 
2bc0: 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f     rc = sqlite3_
2bd0: 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 0a 20  prepare_v2(db,. 
2be0: 20 20 20 20 20 20 20 20 20 22 53 45 4c 45 43 54           "SELECT
2bf0: 20 31 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e   1 FROM wordcoun
2c00: 74 20 57 48 45 52 45 20 77 6f 72 64 3d 3f 31 22  t WHERE word=?1"
2c10: 2c 0a 20 20 20 20 20 20 20 20 20 20 2d 31 2c 20  ,.          -1, 
2c20: 26 70 53 65 6c 65 63 74 2c 20 30 29 3b 0a 20 20  &pSelect, 0);.  
2c30: 20 20 69 66 28 20 72 63 20 29 20 66 61 74 61 6c    if( rc ) fatal
2c40: 5f 65 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f  _error("Could no
2c50: 74 20 70 72 65 70 61 72 65 20 74 68 65 20 53 45  t prepare the SE
2c60: 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 3a 20  LECT statement: 
2c70: 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20  %s\n",.         
2c80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c90: 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28   sqlite3_errmsg(
2ca0: 64 62 29 29 3b 0a 20 20 20 20 72 63 20 3d 20 73  db));.    rc = s
2cb0: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
2cc0: 32 28 64 62 2c 0a 20 20 20 20 20 20 20 20 20 20  2(db,.          
2cd0: 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 77 6f 72  "INSERT INTO wor
2ce0: 64 63 6f 75 6e 74 28 77 6f 72 64 2c 63 6e 74 29  dcount(word,cnt)
2cf0: 20 56 41 4c 55 45 53 28 3f 31 2c 31 29 22 2c 0a   VALUES(?1,1)",.
2d00: 20 20 20 20 20 20 20 20 20 20 2d 31 2c 20 26 70            -1, &p
2d10: 49 6e 73 65 72 74 2c 20 30 29 3b 0a 20 20 20 20  Insert, 0);.    
2d20: 69 66 28 20 72 63 20 29 20 66 61 74 61 6c 5f 65  if( rc ) fatal_e
2d30: 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f 74 20  rror("Could not 
2d40: 70 72 65 70 61 72 65 20 74 68 65 20 49 4e 53 45  prepare the INSE
2d50: 52 54 20 73 74 61 74 65 6d 65 6e 74 3a 20 25 73  RT statement: %s
2d60: 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20  \n",.           
2d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 71                sq
2d80: 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29  lite3_errmsg(db)
2d90: 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 69 4d 6f  );.  }.  if( iMo
2da0: 64 65 3d 3d 4d 4f 44 45 5f 53 45 4c 45 43 54 20  de==MODE_SELECT 
2db0: 7c 7c 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f 55  || iMode==MODE_U
2dc0: 50 44 41 54 45 20 7c 7c 20 69 4d 6f 64 65 3d 3d  PDATE || iMode==
2dd0: 4d 4f 44 45 5f 49 4e 53 45 52 54 20 29 7b 0a 20  MODE_INSERT ){. 
2de0: 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f     rc = sqlite3_
2df0: 70 72 65 70 61 72 65 5f 76 32 28 64 62 2c 0a 20  prepare_v2(db,. 
2e00: 20 20 20 20 20 20 20 20 20 22 55 50 44 41 54 45           "UPDATE
2e10: 20 77 6f 72 64 63 6f 75 6e 74 20 53 45 54 20 63   wordcount SET c
2e20: 6e 74 3d 63 6e 74 2b 31 20 57 48 45 52 45 20 77  nt=cnt+1 WHERE w
2e30: 6f 72 64 3d 3f 31 22 2c 0a 20 20 20 20 20 20 20  ord=?1",.       
2e40: 20 20 20 2d 31 2c 20 26 70 55 70 64 61 74 65 2c     -1, &pUpdate,
2e50: 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20   0);.    if( rc 
2e60: 29 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 43  ) fatal_error("C
2e70: 6f 75 6c 64 20 6e 6f 74 20 70 72 65 70 61 72 65  ould not prepare
2e80: 20 74 68 65 20 55 50 44 41 54 45 20 73 74 61 74   the UPDATE stat
2e90: 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20 20  ement: %s\n",.  
2ea0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2eb0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65         sqlite3_e
2ec0: 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d 0a  rrmsg(db));.  }.
2ed0: 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44    if( iMode==MOD
2ee0: 45 5f 49 4e 53 45 52 54 20 29 7b 0a 20 20 20 20  E_INSERT ){.    
2ef0: 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65  rc = sqlite3_pre
2f00: 70 61 72 65 5f 76 32 28 64 62 2c 0a 20 20 20 20  pare_v2(db,.    
2f10: 20 20 20 20 20 20 22 49 4e 53 45 52 54 20 4f 52        "INSERT OR
2f20: 20 49 47 4e 4f 52 45 20 49 4e 54 4f 20 77 6f 72   IGNORE INTO wor
2f30: 64 63 6f 75 6e 74 28 77 6f 72 64 2c 63 6e 74 29  dcount(word,cnt)
2f40: 20 56 41 4c 55 45 53 28 3f 31 2c 31 29 22 2c 0a   VALUES(?1,1)",.
2f50: 20 20 20 20 20 20 20 20 20 20 2d 31 2c 20 26 70            -1, &p
2f60: 49 6e 73 65 72 74 2c 20 30 29 3b 0a 20 20 20 20  Insert, 0);.    
2f70: 69 66 28 20 72 63 20 29 20 66 61 74 61 6c 5f 65  if( rc ) fatal_e
2f80: 72 72 6f 72 28 22 43 6f 75 6c 64 20 6e 6f 74 20  rror("Could not 
2f90: 70 72 65 70 61 72 65 20 74 68 65 20 49 4e 53 45  prepare the INSE
2fa0: 52 54 20 73 74 61 74 65 6d 65 6e 74 3a 20 25 73  RT statement: %s
2fb0: 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20  \n",.           
2fc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 71                sq
2fd0: 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29  lite3_errmsg(db)
2fe0: 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 69 4d 6f  );.  }.  if( iMo
2ff0: 64 65 3d 3d 4d 4f 44 45 5f 55 50 44 41 54 45 20  de==MODE_UPDATE 
3000: 29 7b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69  ){.    rc = sqli
3010: 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 28 64  te3_prepare_v2(d
3020: 62 2c 0a 20 20 20 20 20 20 20 20 20 20 22 49 4e  b,.          "IN
3030: 53 45 52 54 20 4f 52 20 49 47 4e 4f 52 45 20 49  SERT OR IGNORE I
3040: 4e 54 4f 20 77 6f 72 64 63 6f 75 6e 74 28 77 6f  NTO wordcount(wo
3050: 72 64 2c 63 6e 74 29 20 56 41 4c 55 45 53 28 3f  rd,cnt) VALUES(?
3060: 31 2c 30 29 22 2c 0a 20 20 20 20 20 20 20 20 20  1,0)",.         
3070: 20 2d 31 2c 20 26 70 49 6e 73 65 72 74 2c 20 30   -1, &pInsert, 0
3080: 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29 20  );.    if( rc ) 
3090: 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 43 6f 75  fatal_error("Cou
30a0: 6c 64 20 6e 6f 74 20 70 72 65 70 61 72 65 20 74  ld not prepare t
30b0: 68 65 20 49 4e 53 45 52 54 20 73 74 61 74 65 6d  he INSERT statem
30c0: 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20 20 20 20  ent: %s\n",.    
30d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30e0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 65 72 72       sqlite3_err
30f0: 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d 0a 20 20  msg(db));.  }.  
3100: 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f  if( iMode==MODE_
3110: 52 45 50 4c 41 43 45 20 29 7b 0a 20 20 20 20 72  REPLACE ){.    r
3120: 63 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70  c = sqlite3_prep
3130: 61 72 65 5f 76 32 28 64 62 2c 0a 20 20 20 20 20  are_v2(db,.     
3140: 20 20 20 20 20 22 52 45 50 4c 41 43 45 20 49 4e       "REPLACE IN
3150: 54 4f 20 77 6f 72 64 63 6f 75 6e 74 28 77 6f 72  TO wordcount(wor
3160: 64 2c 63 6e 74 29 22 0a 20 20 20 20 20 20 20 20  d,cnt)".        
3170: 20 20 22 56 41 4c 55 45 53 28 3f 31 2c 63 6f 61    "VALUES(?1,coa
3180: 6c 65 73 63 65 28 28 53 45 4c 45 43 54 20 63 6e  lesce((SELECT cn
3190: 74 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74  t FROM wordcount
31a0: 20 57 48 45 52 45 20 77 6f 72 64 3d 3f 31 29 2c   WHERE word=?1),
31b0: 30 29 2b 31 29 22 2c 0a 20 20 20 20 20 20 20 20  0)+1)",.        
31c0: 20 20 2d 31 2c 20 26 70 49 6e 73 65 72 74 2c 20    -1, &pInsert, 
31d0: 30 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29  0);.    if( rc )
31e0: 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 43 6f   fatal_error("Co
31f0: 75 6c 64 20 6e 6f 74 20 70 72 65 70 61 72 65 20  uld not prepare 
3200: 74 68 65 20 52 45 50 4c 41 43 45 20 73 74 61 74  the REPLACE stat
3210: 65 6d 65 6e 74 3a 20 25 73 5c 6e 22 2c 0a 20 20  ement: %s\n",.  
3220: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3230: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
3240: 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 7d  errmsg(db));.  }
3250: 0a 20 20 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f  .  if( iMode==MO
3260: 44 45 5f 44 45 4c 45 54 45 20 29 7b 0a 20 20 20  DE_DELETE ){.   
3270: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70 72   rc = sqlite3_pr
3280: 65 70 61 72 65 5f 76 32 28 64 62 2c 0a 20 20 20  epare_v2(db,.   
3290: 20 20 20 20 20 20 20 22 44 45 4c 45 54 45 20 46         "DELETE F
32a0: 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 20 57 48  ROM wordcount WH
32b0: 45 52 45 20 77 6f 72 64 3d 3f 31 22 2c 0a 20 20  ERE word=?1",.  
32c0: 20 20 20 20 20 20 20 20 2d 31 2c 20 26 70 44 65          -1, &pDe
32d0: 6c 65 74 65 2c 20 30 29 3b 0a 20 20 20 20 69 66  lete, 0);.    if
32e0: 28 20 72 63 20 29 20 66 61 74 61 6c 5f 65 72 72  ( rc ) fatal_err
32f0: 6f 72 28 22 43 6f 75 6c 64 20 6e 6f 74 20 70 72  or("Could not pr
3300: 65 70 61 72 65 20 74 68 65 20 44 45 4c 45 54 45  epare the DELETE
3310: 20 73 74 61 74 65 6d 65 6e 74 3a 20 25 73 5c 6e   statement: %s\n
3320: 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ",.             
3330: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
3340: 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b  te3_errmsg(db));
3350: 0a 20 20 7d 0a 0a 20 20 2f 2a 20 50 72 6f 63 65  .  }..  /* Proce
3360: 73 73 20 74 68 65 20 69 6e 70 75 74 20 66 69 6c  ss the input fil
3370: 65 20 2a 2f 0a 20 20 77 68 69 6c 65 28 20 66 67  e */.  while( fg
3380: 65 74 73 28 7a 49 6e 70 75 74 2c 20 73 69 7a 65  ets(zInput, size
3390: 6f 66 28 7a 49 6e 70 75 74 29 2c 20 69 6e 29 20  of(zInput), in) 
33a0: 29 7b 0a 20 20 20 20 66 6f 72 28 69 3d 30 3b 20  ){.    for(i=0; 
33b0: 7a 49 6e 70 75 74 5b 69 5d 3b 20 69 2b 2b 29 7b  zInput[i]; i++){
33c0: 0a 20 20 20 20 20 20 69 66 28 20 21 69 73 61 6c  .      if( !isal
33d0: 70 68 61 28 7a 49 6e 70 75 74 5b 69 5d 29 20 29  pha(zInput[i]) )
33e0: 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20   continue;.     
33f0: 20 66 6f 72 28 6a 3d 69 2b 31 3b 20 69 73 61 6c   for(j=i+1; isal
3400: 70 68 61 28 7a 49 6e 70 75 74 5b 6a 5d 29 3b 20  pha(zInput[j]); 
3410: 6a 2b 2b 29 7b 7d 0a 0a 20 20 20 20 20 20 2f 2a  j++){}..      /*
3420: 20 46 6f 75 6e 64 20 61 20 6e 65 77 20 77 6f 72   Found a new wor
3430: 64 20 61 74 20 7a 49 6e 70 75 74 5b 69 5d 20 74  d at zInput[i] t
3440: 68 61 74 20 69 73 20 6a 2d 69 20 62 79 74 65 73  hat is j-i bytes
3450: 20 6c 6f 6e 67 2e 20 0a 20 20 20 20 20 20 2a 2a   long. .      **
3460: 20 50 72 6f 63 65 73 73 20 69 74 20 69 6e 74 6f   Process it into
3470: 20 74 68 65 20 77 6f 72 64 63 6f 75 6e 74 20 74   the wordcount t
3480: 61 62 6c 65 2e 20 20 2a 2f 0a 20 20 20 20 20 20  able.  */.      
3490: 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f  if( iMode==MODE_
34a0: 44 45 4c 45 54 45 20 29 7b 0a 20 20 20 20 20 20  DELETE ){.      
34b0: 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74    sqlite3_bind_t
34c0: 65 78 74 28 70 44 65 6c 65 74 65 2c 20 31 2c 20  ext(pDelete, 1, 
34d0: 7a 49 6e 70 75 74 2b 69 2c 20 6a 2d 69 2c 20 53  zInput+i, j-i, S
34e0: 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 20  QLITE_STATIC);. 
34f0: 20 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74         if( sqlit
3500: 65 33 5f 73 74 65 70 28 70 44 65 6c 65 74 65 29  e3_step(pDelete)
3510: 21 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b  !=SQLITE_DONE ){
3520: 0a 20 20 20 20 20 20 20 20 20 20 66 61 74 61 6c  .          fatal
3530: 5f 65 72 72 6f 72 28 22 44 45 4c 45 54 45 20 66  _error("DELETE f
3540: 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20 73 71  ailed: %s\n", sq
3550: 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29  lite3_errmsg(db)
3560: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
3570: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73       sqlite3_res
3580: 65 74 28 70 44 65 6c 65 74 65 29 3b 0a 20 20 20  et(pDelete);.   
3590: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 69 4d 6f     }else if( iMo
35a0: 64 65 3d 3d 4d 4f 44 45 5f 53 45 4c 45 43 54 20  de==MODE_SELECT 
35b0: 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ){.        sqlit
35c0: 65 33 5f 62 69 6e 64 5f 74 65 78 74 28 70 53 65  e3_bind_text(pSe
35d0: 6c 65 63 74 2c 20 31 2c 20 7a 49 6e 70 75 74 2b  lect, 1, zInput+
35e0: 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54 45 5f 53  i, j-i, SQLITE_S
35f0: 54 41 54 49 43 29 3b 0a 20 20 20 20 20 20 20 20  TATIC);.        
3600: 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 73 74 65  rc = sqlite3_ste
3610: 70 28 70 53 65 6c 65 63 74 29 3b 0a 20 20 20 20  p(pSelect);.    
3620: 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65      sqlite3_rese
3630: 74 28 70 53 65 6c 65 63 74 29 3b 0a 20 20 20 20  t(pSelect);.    
3640: 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49      if( rc==SQLI
3650: 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20 20  TE_ROW ){.      
3660: 20 20 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64      sqlite3_bind
3670: 5f 74 65 78 74 28 70 55 70 64 61 74 65 2c 20 31  _text(pUpdate, 1
3680: 2c 20 7a 49 6e 70 75 74 2b 69 2c 20 6a 2d 69 2c  , zInput+i, j-i,
3690: 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b   SQLITE_STATIC);
36a0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20 73  .          if( s
36b0: 71 6c 69 74 65 33 5f 73 74 65 70 28 70 55 70 64  qlite3_step(pUpd
36c0: 61 74 65 29 21 3d 53 51 4c 49 54 45 5f 44 4f 4e  ate)!=SQLITE_DON
36d0: 45 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  E ){.           
36e0: 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 55 50   fatal_error("UP
36f0: 44 41 54 45 20 66 61 69 6c 65 64 3a 20 25 73 5c  DATE failed: %s\
3700: 6e 22 2c 20 73 71 6c 69 74 65 33 5f 65 72 72 6d  n", sqlite3_errm
3710: 73 67 28 64 62 29 29 3b 0a 20 20 20 20 20 20 20  sg(db));.       
3720: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 73     }.          s
3730: 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70 55 70  qlite3_reset(pUp
3740: 64 61 74 65 29 3b 0a 20 20 20 20 20 20 20 20 7d  date);.        }
3750: 65 6c 73 65 20 69 66 28 20 72 63 3d 3d 53 51 4c  else if( rc==SQL
3760: 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20 20 20 20  ITE_DONE ){.    
3770: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 62 69        sqlite3_bi
3780: 6e 64 5f 74 65 78 74 28 70 49 6e 73 65 72 74 2c  nd_text(pInsert,
3790: 20 31 2c 20 7a 49 6e 70 75 74 2b 69 2c 20 6a 2d   1, zInput+i, j-
37a0: 69 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  i, SQLITE_STATIC
37b0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28  );.          if(
37c0: 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70 49   sqlite3_step(pI
37d0: 6e 73 65 72 74 29 21 3d 53 51 4c 49 54 45 5f 44  nsert)!=SQLITE_D
37e0: 4f 4e 45 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ONE ){.         
37f0: 20 20 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22     fatal_error("
3800: 49 6e 73 65 72 74 20 66 61 69 6c 65 64 3a 20 25  Insert failed: %
3810: 73 5c 6e 22 2c 20 73 71 6c 69 74 65 33 5f 65 72  s\n", sqlite3_er
3820: 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 20  rmsg(db));.     
3830: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
3840: 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70   sqlite3_reset(p
3850: 49 6e 73 65 72 74 29 3b 0a 20 20 20 20 20 20 20  Insert);.       
3860: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
3870: 20 20 66 61 74 61 6c 5f 65 72 72 6f 72 28 22 53    fatal_error("S
3880: 45 4c 45 43 54 20 66 61 69 6c 65 64 3a 20 25 73  ELECT failed: %s
3890: 5c 6e 22 2c 20 73 71 6c 69 74 65 33 5f 65 72 72  \n", sqlite3_err
38a0: 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 20 20  msg(db));.      
38b0: 20 20 7d 0a 20 20 20 20 20 20 7d 65 6c 73 65 20    }.      }else 
38c0: 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f  if( iMode==MODE_
38d0: 51 55 45 52 59 20 29 7b 0a 20 20 20 20 20 20 20  QUERY ){.       
38e0: 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65   sqlite3_bind_te
38f0: 78 74 28 70 53 65 6c 65 63 74 2c 20 31 2c 20 7a  xt(pSelect, 1, z
3900: 49 6e 70 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51  Input+i, j-i, SQ
3910: 4c 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 20 20  LITE_STATIC);.  
3920: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
3930: 33 5f 73 74 65 70 28 70 53 65 6c 65 63 74 29 3d  3_step(pSelect)=
3940: 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20  =SQLITE_ROW ){. 
3950: 20 20 20 20 20 20 20 20 20 73 75 6d 43 6e 74 20           sumCnt 
3960: 2b 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  += sqlite3_colum
3970: 6e 5f 69 6e 74 36 34 28 70 53 65 6c 65 63 74 2c  n_int64(pSelect,
3980: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20   0);.        }. 
3990: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 72         sqlite3_r
39a0: 65 73 65 74 28 70 53 65 6c 65 63 74 29 3b 0a 20  eset(pSelect);. 
39b0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
39c0: 20 20 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64      sqlite3_bind
39d0: 5f 74 65 78 74 28 70 49 6e 73 65 72 74 2c 20 31  _text(pInsert, 1
39e0: 2c 20 7a 49 6e 70 75 74 2b 69 2c 20 6a 2d 69 2c  , zInput+i, j-i,
39f0: 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b   SQLITE_STATIC);
3a00: 0a 20 20 20 20 20 20 20 20 69 66 28 20 73 71 6c  .        if( sql
3a10: 69 74 65 33 5f 73 74 65 70 28 70 49 6e 73 65 72  ite3_step(pInser
3a20: 74 29 21 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20  t)!=SQLITE_DONE 
3a30: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 66 61 74  ){.          fat
3a40: 61 6c 5f 65 72 72 6f 72 28 22 49 4e 53 45 52 54  al_error("INSERT
3a50: 20 66 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20   failed: %s\n", 
3a60: 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64  sqlite3_errmsg(d
3a70: 62 29 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  b));.        }. 
3a80: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 72         sqlite3_r
3a90: 65 73 65 74 28 70 49 6e 73 65 72 74 29 3b 0a 20  eset(pInsert);. 
3aa0: 20 20 20 20 20 20 20 69 66 28 20 69 4d 6f 64 65         if( iMode
3ab0: 3d 3d 4d 4f 44 45 5f 55 50 44 41 54 45 0a 20 20  ==MODE_UPDATE.  
3ac0: 20 20 20 20 20 20 20 7c 7c 20 28 69 4d 6f 64 65         || (iMode
3ad0: 3d 3d 4d 4f 44 45 5f 49 4e 53 45 52 54 20 26 26  ==MODE_INSERT &&
3ae0: 20 73 71 6c 69 74 65 33 5f 63 68 61 6e 67 65 73   sqlite3_changes
3af0: 28 64 62 29 3d 3d 30 29 0a 20 20 20 20 20 20 20  (db)==0).       
3b00: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71   ){.          sq
3b10: 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 28  lite3_bind_text(
3b20: 70 55 70 64 61 74 65 2c 20 31 2c 20 7a 49 6e 70  pUpdate, 1, zInp
3b30: 75 74 2b 69 2c 20 6a 2d 69 2c 20 53 51 4c 49 54  ut+i, j-i, SQLIT
3b40: 45 5f 53 54 41 54 49 43 29 3b 0a 20 20 20 20 20  E_STATIC);.     
3b50: 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65 33       if( sqlite3
3b60: 5f 73 74 65 70 28 70 55 70 64 61 74 65 29 21 3d  _step(pUpdate)!=
3b70: 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20  SQLITE_DONE ){. 
3b80: 20 20 20 20 20 20 20 20 20 20 20 66 61 74 61 6c             fatal
3b90: 5f 65 72 72 6f 72 28 22 55 50 44 41 54 45 20 66  _error("UPDATE f
3ba0: 61 69 6c 65 64 3a 20 25 73 5c 6e 22 2c 20 73 71  ailed: %s\n", sq
3bb0: 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29  lite3_errmsg(db)
3bc0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  );.          }. 
3bd0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
3be0: 5f 72 65 73 65 74 28 70 55 70 64 61 74 65 29 3b  _reset(pUpdate);
3bf0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
3c00: 20 7d 0a 20 20 20 20 20 20 69 20 3d 20 6a 2d 31   }.      i = j-1
3c10: 3b 0a 0a 20 20 20 20 20 20 2f 2a 20 49 6e 63 72  ;..      /* Incr
3c20: 65 6d 65 6e 74 20 74 68 65 20 6f 70 65 72 61 74  ement the operat
3c30: 69 6f 6e 20 63 6f 75 6e 74 65 72 2e 20 20 44 6f  ion counter.  Do
3c40: 20 61 20 43 4f 4d 4d 49 54 20 69 66 20 69 74 20   a COMMIT if it 
3c50: 69 73 20 74 69 6d 65 2e 20 2a 2f 0a 20 20 20 20  is time. */.    
3c60: 20 20 6e 4f 70 2b 2b 3b 0a 20 20 20 20 20 20 69    nOp++;.      i
3c70: 66 28 20 63 6f 6d 6d 69 74 49 6e 74 65 72 76 61  f( commitInterva
3c80: 6c 3e 30 20 26 26 20 28 6e 4f 70 25 63 6f 6d 6d  l>0 && (nOp%comm
3c90: 69 74 49 6e 74 65 72 76 61 6c 29 3d 3d 30 20 29  itInterval)==0 )
3ca0: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
3cb0: 33 5f 65 78 65 63 28 64 62 2c 20 22 43 4f 4d 4d  3_exec(db, "COMM
3cc0: 49 54 3b 20 42 45 47 49 4e 20 49 4d 4d 45 44 49  IT; BEGIN IMMEDI
3cd0: 41 54 45 22 2c 20 30 2c 20 30 2c 20 30 29 3b 0a  ATE", 0, 0, 0);.
3ce0: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
3cf0: 7d 0a 20 20 73 71 6c 69 74 65 33 5f 65 78 65 63  }.  sqlite3_exec
3d00: 28 64 62 2c 20 22 43 4f 4d 4d 49 54 22 2c 20 30  (db, "COMMIT", 0
3d10: 2c 20 30 2c 20 30 29 3b 0a 20 20 69 66 28 20 7a  , 0, 0);.  if( z
3d20: 46 69 6c 65 54 6f 52 65 61 64 20 29 20 66 63 6c  FileToRead ) fcl
3d30: 6f 73 65 28 69 6e 29 3b 0a 20 20 73 71 6c 69 74  ose(in);.  sqlit
3d40: 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 49 6e 73  e3_finalize(pIns
3d50: 65 72 74 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f  ert);.  sqlite3_
3d60: 66 69 6e 61 6c 69 7a 65 28 70 55 70 64 61 74 65  finalize(pUpdate
3d70: 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6e  );.  sqlite3_fin
3d80: 61 6c 69 7a 65 28 70 53 65 6c 65 63 74 29 3b 0a  alize(pSelect);.
3d90: 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69    sqlite3_finali
3da0: 7a 65 28 70 44 65 6c 65 74 65 29 3b 0a 0a 20 20  ze(pDelete);..  
3db0: 69 66 28 20 69 4d 6f 64 65 3d 3d 4d 4f 44 45 5f  if( iMode==MODE_
3dc0: 51 55 45 52 59 20 29 7b 0a 20 20 20 20 70 72 69  QUERY ){.    pri
3dd0: 6e 74 66 28 22 73 75 6d 20 6f 66 20 63 6e 74 3a  ntf("sum of cnt:
3de0: 20 25 6c 6c 64 5c 6e 22 2c 20 73 75 6d 43 6e 74   %lld\n", sumCnt
3df0: 29 3b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69  );.    rc = sqli
3e00: 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 28 64  te3_prepare_v2(d
3e10: 62 2c 22 53 45 4c 45 43 54 20 73 75 6d 28 63 6e  b,"SELECT sum(cn
3e20: 74 2a 63 6e 74 29 20 46 52 4f 4d 20 77 6f 72 64  t*cnt) FROM word
3e30: 63 6f 75 6e 74 22 2c 20 2d 31 2c 0a 20 20 20 20  count", -1,.    
3e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3e50: 20 20 20 20 20 20 20 20 26 70 53 65 6c 65 63 74          &pSelect
3e60: 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20 72 63  , 0);.    if( rc
3e70: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 73  ==SQLITE_OK && s
3e80: 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53 65 6c  qlite3_step(pSel
3e90: 65 63 74 29 3d 3d 53 51 4c 49 54 45 5f 52 4f 57  ect)==SQLITE_ROW
3ea0: 20 29 7b 0a 20 20 20 20 20 20 70 72 69 6e 74 66   ){.      printf
3eb0: 28 22 64 6f 75 62 6c 65 2d 63 68 65 63 6b 3a 20  ("double-check: 
3ec0: 25 6c 6c 64 5c 6e 22 2c 20 73 71 6c 69 74 65 33  %lld\n", sqlite3
3ed0: 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 28 70 53  _column_int64(pS
3ee0: 65 6c 65 63 74 2c 20 30 29 29 3b 0a 20 20 20 20  elect, 0));.    
3ef0: 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 69  }.    sqlite3_fi
3f00: 6e 61 6c 69 7a 65 28 70 53 65 6c 65 63 74 29 3b  nalize(pSelect);
3f10: 0a 20 20 7d 0a 0a 0a 20 20 69 66 28 20 73 68 6f  .  }...  if( sho
3f20: 77 54 69 6d 65 72 20 29 7b 0a 20 20 20 20 73 71  wTimer ){.    sq
3f30: 6c 69 74 65 33 5f 69 6e 74 36 34 20 65 6c 61 70  lite3_int64 elap
3f40: 73 65 54 69 6d 65 20 3d 20 72 65 61 6c 54 69 6d  seTime = realTim
3f50: 65 28 29 20 2d 20 73 74 61 72 74 54 69 6d 65 3b  e() - startTime;
3f60: 0a 20 20 20 20 66 70 72 69 6e 74 66 28 73 74 64  .    fprintf(std
3f70: 65 72 72 2c 20 22 25 33 64 2e 25 30 33 64 20 77  err, "%3d.%03d w
3f80: 6f 72 64 63 6f 75 6e 74 22 2c 20 28 69 6e 74 29  ordcount", (int)
3f90: 28 65 6c 61 70 73 65 54 69 6d 65 2f 31 30 30 30  (elapseTime/1000
3fa0: 29 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ),.             
3fb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3fc0: 20 20 20 20 20 20 28 69 6e 74 29 28 65 6c 61 70        (int)(elap
3fd0: 73 65 54 69 6d 65 25 31 30 30 30 29 29 3b 0a 20  seTime%1000));. 
3fe0: 20 20 20 66 6f 72 28 69 3d 31 3b 20 69 3c 61 72     for(i=1; i<ar
3ff0: 67 63 3b 20 69 2b 2b 29 20 69 66 28 20 69 21 3d  gc; i++) if( i!=
4000: 73 68 6f 77 54 69 6d 65 72 20 29 20 66 70 72 69  showTimer ) fpri
4010: 6e 74 66 28 73 74 64 65 72 72 2c 20 22 20 25 73  ntf(stderr, " %s
4020: 22 2c 20 61 72 67 76 5b 69 5d 29 3b 0a 20 20 20  ", argv[i]);.   
4030: 20 66 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c   fprintf(stderr,
4040: 20 22 5c 6e 22 29 3b 0a 20 20 7d 0a 0a 20 20 69   "\n");.  }..  i
4050: 66 28 20 73 68 6f 77 53 75 6d 6d 61 72 79 20 29  f( showSummary )
4060: 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 63 72  {.    sqlite3_cr
4070: 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 28 64 62  eate_function(db
4080: 2c 20 22 63 68 65 63 6b 73 75 6d 22 2c 20 2d 31  , "checksum", -1
4090: 2c 20 53 51 4c 49 54 45 5f 55 54 46 38 2c 20 30  , SQLITE_UTF8, 0
40a0: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
40b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 30 2c                0,
40c0: 20 63 68 65 63 6b 73 75 6d 53 74 65 70 2c 20 63   checksumStep, c
40d0: 68 65 63 6b 73 75 6d 46 69 6e 61 6c 69 7a 65 29  hecksumFinalize)
40e0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 65 78  ;.    sqlite3_ex
40f0: 65 63 28 64 62 2c 20 0a 20 20 20 20 20 20 22 53  ec(db, .      "S
4100: 45 4c 45 43 54 20 27 63 6f 75 6e 74 28 2a 29 3a  ELECT 'count(*):
4110: 20 20 27 2c 20 63 6f 75 6e 74 28 2a 29 20 46 52    ', count(*) FR
4120: 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 3b 5c 6e 22  OM wordcount;\n"
4130: 0a 20 20 20 20 20 20 22 53 45 4c 45 43 54 20 27  .      "SELECT '
4140: 73 75 6d 28 63 6e 74 29 3a 20 20 27 2c 20 73 75  sum(cnt):  ', su
4150: 6d 28 63 6e 74 29 20 46 52 4f 4d 20 77 6f 72 64  m(cnt) FROM word
4160: 63 6f 75 6e 74 3b 5c 6e 22 0a 20 20 20 20 20 20  count;\n".      
4170: 22 53 45 4c 45 43 54 20 27 6d 61 78 28 63 6e 74  "SELECT 'max(cnt
4180: 29 3a 20 20 27 2c 20 6d 61 78 28 63 6e 74 29 20  ):  ', max(cnt) 
4190: 46 52 4f 4d 20 77 6f 72 64 63 6f 75 6e 74 3b 5c  FROM wordcount;\
41a0: 6e 22 0a 20 20 20 20 20 20 22 53 45 4c 45 43 54  n".      "SELECT
41b0: 20 27 61 76 67 28 63 6e 74 29 3a 20 20 27 2c 20   'avg(cnt):  ', 
41c0: 61 76 67 28 63 6e 74 29 20 46 52 4f 4d 20 77 6f  avg(cnt) FROM wo
41d0: 72 64 63 6f 75 6e 74 3b 5c 6e 22 0a 20 20 20 20  rdcount;\n".    
41e0: 20 20 22 53 45 4c 45 43 54 20 27 73 75 6d 28 63    "SELECT 'sum(c
41f0: 6e 74 3d 31 29 3a 27 2c 20 73 75 6d 28 63 6e 74  nt=1):', sum(cnt
4200: 3d 31 29 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75  =1) FROM wordcou
4210: 6e 74 3b 5c 6e 22 0a 20 20 20 20 20 20 22 53 45  nt;\n".      "SE
4220: 4c 45 43 54 20 27 74 6f 70 20 31 30 3a 20 20 20  LECT 'top 10:   
4230: 20 27 2c 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74   ', group_concat
4240: 28 77 6f 72 64 2c 20 27 2c 20 27 29 20 46 52 4f  (word, ', ') FRO
4250: 4d 20 22 0a 20 20 20 20 20 20 20 20 20 22 28 53  M ".         "(S
4260: 45 4c 45 43 54 20 77 6f 72 64 20 46 52 4f 4d 20  ELECT word FROM 
4270: 77 6f 72 64 63 6f 75 6e 74 20 4f 52 44 45 52 20  wordcount ORDER 
4280: 42 59 20 63 6e 74 20 44 45 53 43 2c 20 77 6f 72  BY cnt DESC, wor
4290: 64 20 4c 49 4d 49 54 20 31 30 29 3b 5c 6e 22 0a  d LIMIT 10);\n".
42a0: 20 20 20 20 20 20 22 53 45 4c 45 43 54 20 27 63        "SELECT 'c
42b0: 68 65 63 6b 73 75 6d 3a 20 20 27 2c 20 63 68 65  hecksum:  ', che
42c0: 63 6b 73 75 6d 28 77 6f 72 64 2c 20 63 6e 74 29  cksum(word, cnt)
42d0: 20 46 52 4f 4d 20 22 0a 20 20 20 20 20 20 20 20   FROM ".        
42e0: 20 22 28 53 45 4c 45 43 54 20 77 6f 72 64 2c 20   "(SELECT word, 
42f0: 63 6e 74 20 46 52 4f 4d 20 77 6f 72 64 63 6f 75  cnt FROM wordcou
4300: 6e 74 20 4f 52 44 45 52 20 42 59 20 77 6f 72 64  nt ORDER BY word
4310: 29 3b 5c 6e 22 0a 20 20 20 20 20 20 22 50 52 41  );\n".      "PRA
4320: 47 4d 41 20 69 6e 74 65 67 72 69 74 79 5f 63 68  GMA integrity_ch
4330: 65 63 6b 3b 5c 6e 22 2c 0a 20 20 20 20 20 20 70  eck;\n",.      p
4340: 72 69 6e 74 52 65 73 75 6c 74 2c 20 30 2c 20 30  rintResult, 0, 0
4350: 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 44 61 74  );.  }..  /* Dat
4360: 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  abase connection
4370: 20 73 74 61 74 69 73 74 69 63 73 20 70 72 69 6e   statistics prin
4380: 74 65 64 20 61 66 74 65 72 20 62 6f 74 68 20 70  ted after both p
4390: 72 65 70 61 72 65 64 20 73 74 61 74 65 6d 65 6e  repared statemen
43a0: 74 73 0a 20 20 2a 2a 20 68 61 76 65 20 62 65 65  ts.  ** have bee
43b0: 6e 20 66 69 6e 61 6c 69 7a 65 64 20 2a 2f 0a 20  n finalized */. 
43c0: 20 69 66 28 20 73 68 6f 77 53 74 61 74 73 20 29   if( showStats )
43d0: 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62  {.    sqlite3_db
43e0: 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49  _status(db, SQLI
43f0: 54 45 5f 44 42 53 54 41 54 55 53 5f 4c 4f 4f 4b  TE_DBSTATUS_LOOK
4400: 41 53 49 44 45 5f 55 53 45 44 2c 20 26 69 43 75  ASIDE_USED, &iCu
4410: 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a  r, &iHiwtr, 0);.
4420: 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 20 4c      printf("-- L
4430: 6f 6f 6b 61 73 69 64 65 20 53 6c 6f 74 73 20 55  ookaside Slots U
4440: 73 65 64 3a 20 20 20 20 20 20 20 20 25 64 20 28  sed:        %d (
4450: 6d 61 78 20 25 64 29 5c 6e 22 2c 20 69 43 75 72  max %d)\n", iCur
4460: 2c 69 48 69 77 74 72 29 3b 0a 20 20 20 20 73 71  ,iHiwtr);.    sq
4470: 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73 28  lite3_db_status(
4480: 64 62 2c 20 53 51 4c 49 54 45 5f 44 42 53 54 41  db, SQLITE_DBSTA
4490: 54 55 53 5f 4c 4f 4f 4b 41 53 49 44 45 5f 48 49  TUS_LOOKASIDE_HI
44a0: 54 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77 74  T, &iCur, &iHiwt
44b0: 72 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e 74  r, 0);.    print
44c0: 66 28 22 2d 2d 20 53 75 63 63 65 73 73 66 75 6c  f("-- Successful
44d0: 20 6c 6f 6f 6b 61 73 69 64 65 73 3a 20 20 20 20   lookasides:    
44e0: 20 20 20 25 64 5c 6e 22 2c 20 69 48 69 77 74 72     %d\n", iHiwtr
44f0: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64  );.    sqlite3_d
4500: 62 5f 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c  b_status(db, SQL
4510: 49 54 45 5f 44 42 53 54 41 54 55 53 5f 4c 4f 4f  ITE_DBSTATUS_LOO
4520: 4b 41 53 49 44 45 5f 4d 49 53 53 5f 53 49 5a 45  KASIDE_MISS_SIZE
4530: 2c 20 26 69 43 75 72 2c 26 69 48 69 77 74 72 2c  , &iCur,&iHiwtr,
4540: 30 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22  0);.    printf("
4550: 2d 2d 20 4c 6f 6f 6b 61 73 69 64 65 20 73 69 7a  -- Lookaside siz
4560: 65 20 66 61 75 6c 74 73 3a 20 20 20 20 20 20 20  e faults:       
4570: 25 64 5c 6e 22 2c 20 69 48 69 77 74 72 29 3b 0a  %d\n", iHiwtr);.
4580: 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62 5f 73      sqlite3_db_s
4590: 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49 54 45  tatus(db, SQLITE
45a0: 5f 44 42 53 54 41 54 55 53 5f 4c 4f 4f 4b 41 53  _DBSTATUS_LOOKAS
45b0: 49 44 45 5f 4d 49 53 53 5f 46 55 4c 4c 2c 20 26  IDE_MISS_FULL, &
45c0: 69 43 75 72 2c 26 69 48 69 77 74 72 2c 30 29 3b  iCur,&iHiwtr,0);
45d0: 0a 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 20  .    printf("-- 
45e0: 4c 6f 6f 6b 61 73 69 64 65 20 4f 4f 4d 20 66 61  Lookaside OOM fa
45f0: 75 6c 74 73 3a 20 20 20 20 20 20 20 20 25 64 5c  ults:        %d\
4600: 6e 22 2c 20 69 48 69 77 74 72 29 3b 0a 20 20 20  n", iHiwtr);.   
4610: 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74 61 74   sqlite3_db_stat
4620: 75 73 28 64 62 2c 20 53 51 4c 49 54 45 5f 44 42  us(db, SQLITE_DB
4630: 53 54 41 54 55 53 5f 43 41 43 48 45 5f 55 53 45  STATUS_CACHE_USE
4640: 44 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77 74  D, &iCur, &iHiwt
4650: 72 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e 74  r, 0);.    print
4660: 66 28 22 2d 2d 20 50 61 67 65 72 20 48 65 61 70  f("-- Pager Heap
4670: 20 55 73 61 67 65 3a 20 20 20 20 20 20 20 20 20   Usage:         
4680: 20 20 20 25 64 20 62 79 74 65 73 5c 6e 22 2c 20     %d bytes\n", 
4690: 69 43 75 72 29 3b 0a 20 20 20 20 73 71 6c 69 74  iCur);.    sqlit
46a0: 65 33 5f 64 62 5f 73 74 61 74 75 73 28 64 62 2c  e3_db_status(db,
46b0: 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54 55 53   SQLITE_DBSTATUS
46c0: 5f 43 41 43 48 45 5f 48 49 54 2c 20 26 69 43 75  _CACHE_HIT, &iCu
46d0: 72 2c 20 26 69 48 69 77 74 72 2c 20 31 29 3b 0a  r, &iHiwtr, 1);.
46e0: 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 20 50      printf("-- P
46f0: 61 67 65 20 63 61 63 68 65 20 68 69 74 73 3a 20  age cache hits: 
4700: 20 20 20 20 20 20 20 20 20 20 20 20 25 64 5c 6e              %d\n
4710: 22 2c 20 69 43 75 72 29 3b 0a 20 20 20 20 73 71  ", iCur);.    sq
4720: 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73 28  lite3_db_status(
4730: 64 62 2c 20 53 51 4c 49 54 45 5f 44 42 53 54 41  db, SQLITE_DBSTA
4740: 54 55 53 5f 43 41 43 48 45 5f 4d 49 53 53 2c 20  TUS_CACHE_MISS, 
4750: 26 69 43 75 72 2c 20 26 69 48 69 77 74 72 2c 20  &iCur, &iHiwtr, 
4760: 31 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22  1);.    printf("
4770: 2d 2d 20 50 61 67 65 20 63 61 63 68 65 20 6d 69  -- Page cache mi
4780: 73 73 65 73 3a 20 20 20 20 20 20 20 20 20 20 20  sses:           
4790: 25 64 5c 6e 22 2c 20 69 43 75 72 29 3b 20 0a 20  %d\n", iCur); . 
47a0: 20 20 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74     sqlite3_db_st
47b0: 61 74 75 73 28 64 62 2c 20 53 51 4c 49 54 45 5f  atus(db, SQLITE_
47c0: 44 42 53 54 41 54 55 53 5f 43 41 43 48 45 5f 57  DBSTATUS_CACHE_W
47d0: 52 49 54 45 2c 20 26 69 43 75 72 2c 20 26 69 48  RITE, &iCur, &iH
47e0: 69 77 74 72 2c 20 31 29 3b 0a 20 20 20 20 70 72  iwtr, 1);.    pr
47f0: 69 6e 74 66 28 22 2d 2d 20 50 61 67 65 20 63 61  intf("-- Page ca
4800: 63 68 65 20 77 72 69 74 65 73 3a 20 20 20 20 20  che writes:     
4810: 20 20 20 20 20 20 25 64 5c 6e 22 2c 20 69 43 75        %d\n", iCu
4820: 72 29 3b 20 0a 20 20 20 20 73 71 6c 69 74 65 33  r); .    sqlite3
4830: 5f 64 62 5f 73 74 61 74 75 73 28 64 62 2c 20 53  _db_status(db, S
4840: 51 4c 49 54 45 5f 44 42 53 54 41 54 55 53 5f 53  QLITE_DBSTATUS_S
4850: 43 48 45 4d 41 5f 55 53 45 44 2c 20 26 69 43 75  CHEMA_USED, &iCu
4860: 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29 3b 0a  r, &iHiwtr, 0);.
4870: 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d 20 53      printf("-- S
4880: 63 68 65 6d 61 20 48 65 61 70 20 55 73 61 67 65  chema Heap Usage
4890: 3a 20 20 20 20 20 20 20 20 20 20 20 25 64 20 62  :           %d b
48a0: 79 74 65 73 5c 6e 22 2c 20 69 43 75 72 29 3b 20  ytes\n", iCur); 
48b0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 64 62 5f  .    sqlite3_db_
48c0: 73 74 61 74 75 73 28 64 62 2c 20 53 51 4c 49 54  status(db, SQLIT
48d0: 45 5f 44 42 53 54 41 54 55 53 5f 53 54 4d 54 5f  E_DBSTATUS_STMT_
48e0: 55 53 45 44 2c 20 26 69 43 75 72 2c 20 26 69 48  USED, &iCur, &iH
48f0: 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20 70 72  iwtr, 0);.    pr
4900: 69 6e 74 66 28 22 2d 2d 20 53 74 61 74 65 6d 65  intf("-- Stateme
4910: 6e 74 20 48 65 61 70 20 55 73 61 67 65 3a 20 20  nt Heap Usage:  
4920: 20 20 20 20 20 20 25 64 20 62 79 74 65 73 5c 6e        %d bytes\n
4930: 22 2c 20 69 43 75 72 29 3b 20 0a 20 20 7d 0a 0a  ", iCur); .  }..
4940: 20 20 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 28    sqlite3_close(
4950: 64 62 29 3b 0a 0a 20 20 2f 2a 20 47 6c 6f 62 61  db);..  /* Globa
4960: 6c 20 6d 65 6d 6f 72 79 20 75 73 61 67 65 20 73  l memory usage s
4970: 74 61 74 69 73 74 69 63 73 20 70 72 69 6e 74 65  tatistics printe
4980: 64 20 61 66 74 65 72 20 74 68 65 20 64 61 74 61  d after the data
4990: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 0a  base connection.
49a0: 20 20 2a 2a 20 68 61 73 20 63 6c 6f 73 65 64 2e    ** has closed.
49b0: 20 20 4d 65 6d 6f 72 79 20 75 73 61 67 65 20 73    Memory usage s
49c0: 68 6f 75 6c 64 20 62 65 20 7a 65 72 6f 20 61 74  hould be zero at
49d0: 20 74 68 69 73 20 70 6f 69 6e 74 2e 20 2a 2f 0a   this point. */.
49e0: 20 20 69 66 28 20 73 68 6f 77 53 74 61 74 73 20    if( showStats 
49f0: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73  ){.    sqlite3_s
4a00: 74 61 74 75 73 28 53 51 4c 49 54 45 5f 53 54 41  tatus(SQLITE_STA
4a10: 54 55 53 5f 4d 45 4d 4f 52 59 5f 55 53 45 44 2c  TUS_MEMORY_USED,
4a20: 20 26 69 43 75 72 2c 20 26 69 48 69 77 74 72 2c   &iCur, &iHiwtr,
4a30: 20 30 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28   0);.    printf(
4a40: 22 2d 2d 20 4d 65 6d 6f 72 79 20 55 73 65 64 20  "-- Memory Used 
4a50: 28 62 79 74 65 73 29 3a 20 20 20 20 20 20 20 20  (bytes):        
4a60: 20 25 64 20 28 6d 61 78 20 25 64 29 5c 6e 22 2c   %d (max %d)\n",
4a70: 20 69 43 75 72 2c 69 48 69 77 74 72 29 3b 0a 20   iCur,iHiwtr);. 
4a80: 20 20 20 73 71 6c 69 74 65 33 5f 73 74 61 74 75     sqlite3_statu
4a90: 73 28 53 51 4c 49 54 45 5f 53 54 41 54 55 53 5f  s(SQLITE_STATUS_
4aa0: 4d 41 4c 4c 4f 43 5f 43 4f 55 4e 54 2c 20 26 69  MALLOC_COUNT, &i
4ab0: 43 75 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29  Cur, &iHiwtr, 0)
4ac0: 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d  ;.    printf("--
4ad0: 20 4f 75 74 73 74 61 6e 64 69 6e 67 20 41 6c 6c   Outstanding All
4ae0: 6f 63 61 74 69 6f 6e 73 3a 20 20 20 20 20 25 64  ocations:     %d
4af0: 20 28 6d 61 78 20 25 64 29 5c 6e 22 2c 20 69 43   (max %d)\n", iC
4b00: 75 72 2c 69 48 69 77 74 72 29 3b 0a 20 20 20 20  ur,iHiwtr);.    
4b10: 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28 53  sqlite3_status(S
4b20: 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 50 41 47  QLITE_STATUS_PAG
4b30: 45 43 41 43 48 45 5f 4f 56 45 52 46 4c 4f 57 2c  ECACHE_OVERFLOW,
4b40: 20 26 69 43 75 72 2c 20 26 69 48 69 77 74 72 2c   &iCur, &iHiwtr,
4b50: 20 30 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28   0);.    printf(
4b60: 22 2d 2d 20 50 63 61 63 68 65 20 4f 76 65 72 66  "-- Pcache Overf
4b70: 6c 6f 77 20 42 79 74 65 73 3a 20 20 20 20 20 20  low Bytes:      
4b80: 20 25 64 20 28 6d 61 78 20 25 64 29 5c 6e 22 2c   %d (max %d)\n",
4b90: 20 69 43 75 72 2c 69 48 69 77 74 72 29 3b 0a 20   iCur,iHiwtr);. 
4ba0: 20 20 20 73 71 6c 69 74 65 33 5f 73 74 61 74 75     sqlite3_statu
4bb0: 73 28 53 51 4c 49 54 45 5f 53 54 41 54 55 53 5f  s(SQLITE_STATUS_
4bc0: 53 43 52 41 54 43 48 5f 4f 56 45 52 46 4c 4f 57  SCRATCH_OVERFLOW
4bd0: 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77 74 72  , &iCur, &iHiwtr
4be0: 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e 74 66  , 0);.    printf
4bf0: 28 22 2d 2d 20 53 63 72 61 74 63 68 20 4f 76 65  ("-- Scratch Ove
4c00: 72 66 6c 6f 77 20 42 79 74 65 73 3a 20 20 20 20  rflow Bytes:    
4c10: 20 20 25 64 20 28 6d 61 78 20 25 64 29 5c 6e 22    %d (max %d)\n"
4c20: 2c 20 69 43 75 72 2c 69 48 69 77 74 72 29 3b 0a  , iCur,iHiwtr);.
4c30: 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74 61 74      sqlite3_stat
4c40: 75 73 28 53 51 4c 49 54 45 5f 53 54 41 54 55 53  us(SQLITE_STATUS
4c50: 5f 4d 41 4c 4c 4f 43 5f 53 49 5a 45 2c 20 26 69  _MALLOC_SIZE, &i
4c60: 43 75 72 2c 20 26 69 48 69 77 74 72 2c 20 30 29  Cur, &iHiwtr, 0)
4c70: 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22 2d 2d  ;.    printf("--
4c80: 20 4c 61 72 67 65 73 74 20 41 6c 6c 6f 63 61 74   Largest Allocat
4c90: 69 6f 6e 3a 20 20 20 20 20 20 20 20 20 20 25 64  ion:          %d
4ca0: 20 62 79 74 65 73 5c 6e 22 2c 69 48 69 77 74 72   bytes\n",iHiwtr
4cb0: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73  );.    sqlite3_s
4cc0: 74 61 74 75 73 28 53 51 4c 49 54 45 5f 53 54 41  tatus(SQLITE_STA
4cd0: 54 55 53 5f 50 41 47 45 43 41 43 48 45 5f 53 49  TUS_PAGECACHE_SI
4ce0: 5a 45 2c 20 26 69 43 75 72 2c 20 26 69 48 69 77  ZE, &iCur, &iHiw
4cf0: 74 72 2c 20 30 29 3b 0a 20 20 20 20 70 72 69 6e  tr, 0);.    prin
4d00: 74 66 28 22 2d 2d 20 4c 61 72 67 65 73 74 20 50  tf("-- Largest P
4d10: 63 61 63 68 65 20 41 6c 6c 6f 63 61 74 69 6f 6e  cache Allocation
4d20: 3a 20 20 20 25 64 20 62 79 74 65 73 5c 6e 22 2c  :   %d bytes\n",
4d30: 69 48 69 77 74 72 29 3b 0a 20 20 20 20 73 71 6c  iHiwtr);.    sql
4d40: 69 74 65 33 5f 73 74 61 74 75 73 28 53 51 4c 49  ite3_status(SQLI
4d50: 54 45 5f 53 54 41 54 55 53 5f 53 43 52 41 54 43  TE_STATUS_SCRATC
4d60: 48 5f 53 49 5a 45 2c 20 26 69 43 75 72 2c 20 26  H_SIZE, &iCur, &
4d70: 69 48 69 77 74 72 2c 20 30 29 3b 0a 20 20 20 20  iHiwtr, 0);.    
4d80: 70 72 69 6e 74 66 28 22 2d 2d 20 4c 61 72 67 65  printf("-- Large
4d90: 73 74 20 53 63 72 61 74 63 68 20 41 6c 6c 6f 63  st Scratch Alloc
4da0: 61 74 69 6f 6e 3a 20 20 25 64 20 62 79 74 65 73  ation:  %d bytes
4db0: 5c 6e 22 2c 20 69 48 69 77 74 72 29 3b 0a 20 20  \n", iHiwtr);.  
4dc0: 7d 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a  }.  return 0;.}.