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

Artifact ad2ff42ddc856aed2d05bf89dc1c578c8a39ea3b:


0000: 23 20 32 30 31 35 20 4a 61 6e 20 31 33 0a 23 0a  # 2015 Jan 13.#.
0010: 23 20 54 68 65 20 61 75 74 68 6f 72 20 64 69 73  # The author dis
0020: 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68 74  claims copyright
0030: 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65 20   to this source 
0040: 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65 20  code.  In place 
0050: 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f 74  of.# a legal not
0060: 69 63 65 2c 20 68 65 72 65 20 69 73 20 61 20 62  ice, here is a b
0070: 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20 20  lessing:.#.#    
0080: 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20  May you do good 
0090: 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23 20  and not evil..# 
00a0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00b0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00c0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00d0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20 20  give others..#  
00e0: 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20    May you share 
00f0: 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61  freely, never ta
0100: 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79  king more than y
0110: 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a 2a  ou give..#.#****
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 0a 23 0a 23 20 54 68 69 73 20 66 69 6c  ***.#.# This fil
0170: 65 20 66 6f 63 75 73 65 73 20 6f 6e 20 74 68 65  e focuses on the
0180: 20 63 6f 64 65 20 69 6e 20 66 74 73 35 5f 63 6f   code in fts5_co
0190: 6e 66 69 67 2e 63 2c 20 77 68 69 63 68 20 69 73  nfig.c, which is
01a0: 20 6c 61 72 67 65 6c 79 20 63 6f 6e 63 65 72 6e   largely concern
01b0: 65 64 0a 23 20 77 69 74 68 20 70 61 72 73 69 6e  ed.# with parsin
01c0: 67 20 74 68 65 20 76 61 72 69 6f 75 73 20 63 6f  g the various co
01d0: 6e 66 69 67 75 72 61 74 69 6f 6e 20 61 6e 64 20  nfiguration and 
01e0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 6f 70 74  CREATE TABLE opt
01f0: 69 6f 6e 73 2e 0a 23 0a 0a 73 6f 75 72 63 65 20  ions..#..source 
0200: 5b 66 69 6c 65 20 6a 6f 69 6e 20 5b 66 69 6c 65  [file join [file
0210: 20 64 69 72 6e 61 6d 65 20 5b 69 6e 66 6f 20 73   dirname [info s
0220: 63 72 69 70 74 5d 5d 20 66 74 73 35 5f 63 6f 6d  cript]] fts5_com
0230: 6d 6f 6e 2e 74 63 6c 5d 0a 73 65 74 20 74 65 73  mon.tcl].set tes
0240: 74 70 72 65 66 69 78 20 66 74 73 35 63 6f 6e 66  tprefix fts5conf
0250: 69 67 0a 0a 23 20 49 66 20 53 51 4c 49 54 45 5f  ig..# If SQLITE_
0260: 45 4e 41 42 4c 45 5f 46 54 53 35 20 69 73 20 64  ENABLE_FTS5 is d
0270: 65 66 69 6e 65 64 2c 20 6f 6d 69 74 20 74 68 69  efined, omit thi
0280: 73 20 66 69 6c 65 2e 0a 69 66 63 61 70 61 62 6c  s file..ifcapabl
0290: 65 20 21 66 74 73 35 20 7b 0a 20 20 66 69 6e 69  e !fts5 {.  fini
02a0: 73 68 5f 74 65 73 74 0a 20 20 72 65 74 75 72 6e  sh_test.  return
02b0: 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .}..#-----------
02c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
02f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
0300: 20 54 72 79 20 64 69 66 66 65 72 65 6e 74 20 74   Try different t
0310: 79 70 65 73 20 6f 66 20 71 75 6f 74 65 20 63 68  ypes of quote ch
0320: 61 72 61 63 74 65 72 73 2e 0a 23 0a 64 6f 5f 65  aracters..#.do_e
0330: 78 65 63 73 71 6c 5f 74 65 73 74 20 31 2e 30 20  xecsql_test 1.0 
0340: 7b 0a 20 20 43 52 45 41 54 45 20 56 49 52 54 55  {.  CREATE VIRTU
0350: 41 4c 20 54 41 42 4c 45 20 74 31 20 55 53 49 4e  AL TABLE t1 USIN
0360: 47 20 66 74 73 35 28 27 61 27 2c 20 22 62 22 2c  G fts5('a', "b",
0370: 20 5b 63 5d 2c 20 60 64 60 29 3b 0a 20 20 50 52   [c], `d`);.  PR
0380: 41 47 4d 41 20 74 61 62 6c 65 5f 69 6e 66 6f 20  AGMA table_info 
0390: 3d 20 74 31 3b 0a 7d 20 7b 0a 20 20 30 20 61 20  = t1;.} {.  0 a 
03a0: 7b 7d 20 30 20 7b 7d 20 30 20 0a 20 20 31 20 62  {} 0 {} 0 .  1 b
03b0: 20 7b 7d 20 30 20 7b 7d 20 30 20 0a 20 20 32 20   {} 0 {} 0 .  2 
03c0: 63 20 7b 7d 20 30 20 7b 7d 20 30 20 0a 20 20 33  c {} 0 {} 0 .  3
03d0: 20 64 20 7b 7d 20 30 20 7b 7d 20 30 0a 7d 0a 0a   d {} 0 {} 0.}..
03e0: 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  #---------------
03f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0400: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0410: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0420: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 53 79 6e  ----------.# Syn
0430: 74 61 78 20 65 72 72 6f 72 73 20 69 6e 20 74 68  tax errors in th
0440: 65 20 70 72 65 66 69 78 3d 20 6f 70 74 69 6f 6e  e prefix= option
0450: 2e 0a 23 0a 66 6f 72 65 61 63 68 20 7b 74 6e 20  ..#.foreach {tn 
0460: 6f 70 74 7d 20 7b 0a 20 20 31 20 7b 70 72 65 66  opt} {.  1 {pref
0470: 69 78 3d 78 7d 20 20 0a 20 20 32 20 7b 70 72 65  ix=x}  .  2 {pre
0480: 66 69 78 3d 27 78 27 7d 0a 20 20 33 20 7b 70 72  fix='x'}.  3 {pr
0490: 65 66 69 78 3d 27 24 27 7d 0a 7d 20 7b 0a 20 20  efix='$'}.} {.  
04a0: 73 65 74 20 72 65 73 20 5b 6c 69 73 74 20 31 20  set res [list 1 
04b0: 7b 6d 61 6c 66 6f 72 6d 65 64 20 70 72 65 66 69  {malformed prefi
04c0: 78 3d 2e 2e 2e 20 64 69 72 65 63 74 69 76 65 7d  x=... directive}
04d0: 5d 0a 20 20 64 6f 5f 63 61 74 63 68 73 71 6c 5f  ].  do_catchsql_
04e0: 74 65 73 74 20 32 2e 24 74 6e 20 22 43 52 45 41  test 2.$tn "CREA
04f0: 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45  TE VIRTUAL TABLE
0500: 20 66 31 20 55 53 49 4e 47 20 66 74 73 35 28 78   f1 USING fts5(x
0510: 2c 20 24 6f 70 74 29 22 20 24 72 65 73 0a 7d 0a  , $opt)" $res.}.
0520: 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .#--------------
0530: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0540: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0550: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0560: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 53 79  -----------.# Sy
0570: 6e 74 61 78 20 65 72 72 6f 72 73 20 69 6e 20 74  ntax errors in t
0580: 68 65 20 27 72 61 6e 6b 27 20 6f 70 74 69 6f 6e  he 'rank' option
0590: 2e 0a 23 0a 66 6f 72 65 61 63 68 20 7b 74 6e 20  ..#.foreach {tn 
05a0: 76 61 6c 7d 20 7b 0a 20 20 31 20 22 66 31 28 78  val} {.  1 "f1(x
05b0: 79 7a 29 22 0a 20 20 32 20 22 66 31 28 7a 79 78  yz)".  2 "f1(zyx
05c0: 29 22 0a 20 20 33 20 22 66 31 28 6e 7a 7a 29 22  )".  3 "f1(nzz)"
05d0: 0a 20 20 34 20 22 66 31 28 78 27 21 21 27 29 22  .  4 "f1(x'!!')"
05e0: 0a 20 20 35 20 22 66 31 28 78 27 3a 3b 27 29 22  .  5 "f1(x':;')"
05f0: 0a 20 20 36 20 22 66 31 28 78 27 5b 5d 27 29 22  .  6 "f1(x'[]')"
0600: 0a 20 20 37 20 22 66 31 28 78 27 7b 7d 27 29 22  .  7 "f1(x'{}')"
0610: 0a 20 20 38 20 22 66 31 28 27 61 62 63 29 22 0a  .  8 "f1('abc)".
0620: 7d 20 7b 0a 20 20 64 6f 5f 63 61 74 63 68 73 71  } {.  do_catchsq
0630: 6c 5f 74 65 73 74 20 33 2e 24 74 6e 20 7b 0a 20  l_test 3.$tn {. 
0640: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
0650: 31 28 74 31 2c 20 72 61 6e 6b 29 20 56 41 4c 55  1(t1, rank) VALU
0660: 45 53 28 27 72 61 6e 6b 27 2c 20 24 76 61 6c 29  ES('rank', $val)
0670: 3b 0a 20 20 7d 20 7b 31 20 7b 53 51 4c 20 6c 6f  ;.  } {1 {SQL lo
0680: 67 69 63 20 65 72 72 6f 72 20 6f 72 20 6d 69 73  gic error or mis
0690: 73 69 6e 67 20 64 61 74 61 62 61 73 65 7d 7d 0a  sing database}}.
06a0: 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }..#------------
06b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
06c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
06d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
06e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20  -------------.# 
06f0: 54 68 65 20 70 61 72 73 69 6e 67 20 6f 66 20 53  The parsing of S
0700: 51 4c 20 6c 69 74 65 72 61 6c 73 20 73 70 65 63  QL literals spec
0710: 69 66 69 65 64 20 61 73 20 70 61 72 74 20 6f 66  ified as part of
0720: 20 27 72 61 6e 6b 27 20 6f 70 74 69 6f 6e 73 2e   'rank' options.
0730: 0a 23 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  .#.do_execsql_te
0740: 73 74 20 34 2e 30 20 7b 0a 20 20 43 52 45 41 54  st 4.0 {.  CREAT
0750: 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45 20  E VIRTUAL TABLE 
0760: 7a 7a 7a 20 55 53 49 4e 47 20 66 74 73 35 28 6f  zzz USING fts5(o
0770: 6e 65 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e  ne);.  INSERT IN
0780: 54 4f 20 7a 7a 7a 20 56 41 4c 55 45 53 28 27 61  TO zzz VALUES('a
0790: 20 62 20 63 27 29 3b 0a 7d 0a 70 72 6f 63 20 66   b c');.}.proc f
07a0: 69 72 73 74 20 7b 63 6d 64 20 41 7d 20 7b 20 72  irst {cmd A} { r
07b0: 65 74 75 72 6e 20 24 41 20 7d 0a 73 71 6c 69 74  eturn $A }.sqlit
07c0: 65 33 5f 66 74 73 35 5f 63 72 65 61 74 65 5f 66  e3_fts5_create_f
07d0: 75 6e 63 74 69 6f 6e 20 64 62 20 66 69 72 73 74  unction db first
07e0: 20 66 69 72 73 74 0a 0a 66 6f 72 65 61 63 68 20   first..foreach 
07f0: 7b 74 6e 20 61 72 67 7d 20 7b 0a 20 20 31 20 22  {tn arg} {.  1 "
0800: 31 32 33 22 0a 20 20 32 20 22 27 30 31 32 33 34  123".  2 "'01234
0810: 35 36 37 38 39 30 41 42 43 44 45 46 27 22 0a 20  567890ABCDEF'". 
0820: 20 33 20 22 78 27 30 31 32 33 27 22 0a 20 20 34   3 "x'0123'".  4
0830: 20 22 78 27 41 42 43 44 27 22 0a 20 20 35 20 22   "x'ABCD'".  5 "
0840: 78 27 30 31 32 33 34 35 36 37 38 39 41 42 43 44  x'0123456789ABCD
0850: 45 46 27 22 0a 20 20 36 20 22 78 27 30 31 32 33  EF'".  6 "x'0123
0860: 34 35 36 37 38 39 61 62 63 64 65 66 27 22 0a 20  456789abcdef'". 
0870: 20 37 20 22 32 32 2e 35 22 0a 20 20 38 20 22 2d   7 "22.5".  8 "-
0880: 39 31 2e 35 22 0a 20 20 39 20 22 2d 2e 35 22 0a  91.5".  9 "-.5".
0890: 20 20 31 30 20 22 27 27 27 27 22 0a 20 20 31 31    10 "''''".  11
08a0: 20 22 2b 2e 35 22 0a 7d 20 7b 0a 20 20 73 65 74   "+.5".} {.  set
08b0: 20 66 75 6e 63 20 5b 73 74 72 69 6e 67 20 6d 61   func [string ma
08c0: 70 20 7b 27 20 27 27 7d 20 22 66 69 72 73 74 28  p {' ''} "first(
08d0: 24 61 72 67 29 22 5d 0a 20 20 64 6f 5f 65 78 65  $arg)"].  do_exe
08e0: 63 73 71 6c 5f 74 65 73 74 20 34 2e 31 2e 24 74  csql_test 4.1.$t
08f0: 6e 20 22 0a 20 20 20 20 49 4e 53 45 52 54 20 49  n ".    INSERT I
0900: 4e 54 4f 20 7a 7a 7a 28 7a 7a 7a 2c 20 72 61 6e  NTO zzz(zzz, ran
0910: 6b 29 20 56 41 4c 55 45 53 28 27 72 61 6e 6b 27  k) VALUES('rank'
0920: 2c 20 27 24 66 75 6e 63 27 29 3b 0a 20 20 20 20  , '$func');.    
0930: 53 45 4c 45 43 54 20 72 61 6e 6b 20 49 53 20 24  SELECT rank IS $
0940: 61 72 67 20 46 52 4f 4d 20 7a 7a 7a 20 57 48 45  arg FROM zzz WHE
0950: 52 45 20 7a 7a 7a 20 4d 41 54 43 48 20 27 61 20  RE zzz MATCH 'a 
0960: 2b 20 62 20 2b 20 63 27 0a 20 20 22 20 31 0a 7d  + b + c'.  " 1.}
0970: 0a 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73  ..do_execsql_tes
0980: 74 20 34 2e 32 20 7b 0a 20 20 49 4e 53 45 52 54  t 4.2 {.  INSERT
0990: 20 49 4e 54 4f 20 7a 7a 7a 28 7a 7a 7a 2c 20 72   INTO zzz(zzz, r
09a0: 61 6e 6b 29 20 56 41 4c 55 45 53 28 27 72 61 6e  ank) VALUES('ran
09b0: 6b 27 2c 20 27 66 31 28 29 27 29 3b 0a 7d 20 7b  k', 'f1()');.} {
09c0: 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  }..#------------
09d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
09e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
09f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0a00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20  -------------.# 
0a10: 4d 69 73 71 75 6f 74 69 6e 67 20 69 6e 20 74 6f  Misquoting in to
0a20: 6b 65 6e 69 7a 65 3d 20 61 6e 64 20 6f 74 68 65  kenize= and othe
0a30: 72 20 6f 70 74 69 6f 6e 73 2e 20 0a 23 0a 64 6f  r options. .#.do
0a40: 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20 35  _catchsql_test 5
0a50: 2e 31 20 7b 0a 20 20 43 52 45 41 54 45 20 56 49  .1 {.  CREATE VI
0a60: 52 54 55 41 4c 20 54 41 42 4c 45 20 78 78 20 55  RTUAL TABLE xx U
0a70: 53 49 4e 47 20 66 74 73 35 28 78 2c 20 74 6f 6b  SING fts5(x, tok
0a80: 65 6e 69 7a 65 3d 22 70 6f 72 74 65 72 20 27 61  enize="porter 'a
0a90: 73 63 69 69 22 29 3b 0a 7d 20 7b 31 20 7b 70 61  scii");.} {1 {pa
0aa0: 72 73 65 20 65 72 72 6f 72 20 69 6e 20 74 6f 6b  rse error in tok
0ab0: 65 6e 69 7a 65 20 64 69 72 65 63 74 69 76 65 7d  enize directive}
0ac0: 7d 20 0a 0a 62 72 65 61 6b 70 6f 69 6e 74 0a 64  } ..breakpoint.d
0ad0: 6f 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20  o_catchsql_test 
0ae0: 35 2e 32 20 7b 0a 20 20 43 52 45 41 54 45 20 56  5.2 {.  CREATE V
0af0: 49 52 54 55 41 4c 20 54 41 42 4c 45 20 78 78 20  IRTUAL TABLE xx 
0b00: 55 53 49 4e 47 20 66 74 73 35 28 78 2c 20 5b 79  USING fts5(x, [y
0b10: 5b 5d 29 3b 0a 7d 20 7b 30 20 7b 7d 7d 0a 0a 64  []);.} {0 {}}..d
0b20: 6f 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20  o_catchsql_test 
0b30: 35 2e 33 20 7b 0a 20 20 43 52 45 41 54 45 20 56  5.3 {.  CREATE V
0b40: 49 52 54 55 41 4c 20 54 41 42 4c 45 20 79 79 20  IRTUAL TABLE yy 
0b50: 55 53 49 4e 47 20 66 74 73 35 28 78 2c 20 5b 79  USING fts5(x, [y
0b60: 5d 5d 29 3b 0a 7d 20 7b 31 20 7b 75 6e 72 65 63  ]]);.} {1 {unrec
0b70: 6f 67 6e 69 7a 65 64 20 74 6f 6b 65 6e 3a 20 22  ognized token: "
0b80: 5d 22 7d 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d  ]"}}..#---------
0b90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ba0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0bb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0bc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0bd0: 0a 23 20 45 72 72 6f 72 73 20 69 6e 20 70 72 65  .# Errors in pre
0be0: 66 69 78 3d 20 64 69 72 65 63 74 69 76 65 73 2e  fix= directives.
0bf0: 0a 23 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74  .#.do_catchsql_t
0c00: 65 73 74 20 36 2e 31 20 7b 0a 20 20 43 52 45 41  est 6.1 {.  CREA
0c10: 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45  TE VIRTUAL TABLE
0c20: 20 61 62 63 20 55 53 49 4e 47 20 66 74 73 35 28   abc USING fts5(
0c30: 61 2c 20 70 72 65 66 69 78 3d 31 2c 20 70 72 65  a, prefix=1, pre
0c40: 66 69 78 3d 32 29 3b 0a 7d 20 7b 31 20 7b 6d 75  fix=2);.} {1 {mu
0c50: 6c 74 69 70 6c 65 20 70 72 65 66 69 78 3d 2e 2e  ltiple prefix=..
0c60: 2e 20 64 69 72 65 63 74 69 76 65 73 7d 7d 0a 64  . directives}}.d
0c70: 6f 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20  o_catchsql_test 
0c80: 36 2e 32 20 7b 0a 20 20 43 52 45 41 54 45 20 56  6.2 {.  CREATE V
0c90: 49 52 54 55 41 4c 20 54 41 42 4c 45 20 61 62 63  IRTUAL TABLE abc
0ca0: 20 55 53 49 4e 47 20 66 74 73 35 28 61 2c 20 70   USING fts5(a, p
0cb0: 72 65 66 69 78 3d 27 31 2c 20 32 2c 20 31 30 30  refix='1, 2, 100
0cc0: 31 27 29 3b 0a 7d 20 7b 31 20 7b 70 72 65 66 69  1');.} {1 {prefi
0cd0: 78 20 6c 65 6e 67 74 68 20 6f 75 74 20 6f 66 20  x length out of 
0ce0: 72 61 6e 67 65 3a 20 31 30 30 31 7d 7d 0a 64 6f  range: 1001}}.do
0cf0: 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20 36  _catchsql_test 6
0d00: 2e 33 20 7b 0a 20 20 43 52 45 41 54 45 20 56 49  .3 {.  CREATE VI
0d10: 52 54 55 41 4c 20 54 41 62 4c 45 20 61 62 63 20  RTUAL TAbLE abc 
0d20: 55 53 49 4e 47 20 66 74 73 35 28 61 2c 20 70 72  USING fts5(a, pr
0d30: 65 66 69 78 3d 27 31 2c 20 32 2c 20 30 30 30 30  efix='1, 2, 0000
0d40: 27 29 3b 0a 7d 20 7b 31 20 7b 70 72 65 66 69 78  ');.} {1 {prefix
0d50: 20 6c 65 6e 67 74 68 20 6f 75 74 20 6f 66 20 72   length out of r
0d60: 61 6e 67 65 3a 20 30 7d 7d 0a 64 6f 5f 63 61 74  ange: 0}}.do_cat
0d70: 63 68 73 71 6c 5f 74 65 73 74 20 36 2e 34 20 7b  chsql_test 6.4 {
0d80: 0a 20 20 43 52 45 41 54 45 20 56 49 52 54 55 41  .  CREATE VIRTUA
0d90: 4c 20 54 41 42 4c 45 20 61 62 63 20 55 53 49 4e  L TABLE abc USIN
0da0: 47 20 66 74 73 35 28 61 2c 20 70 72 65 66 69 78  G fts5(a, prefix
0db0: 3d 27 31 20 20 2c 20 31 30 30 30 30 30 30 27 29  ='1  , 1000000')
0dc0: 3b 0a 7d 20 7b 31 20 7b 6d 61 6c 66 6f 72 6d 65  ;.} {1 {malforme
0dd0: 64 20 70 72 65 66 69 78 3d 2e 2e 2e 20 64 69 72  d prefix=... dir
0de0: 65 63 74 69 76 65 7d 7d 0a 0a 23 2d 2d 2d 2d 2d  ective}}..#-----
0df0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e30: 2d 2d 2d 2d 0a 23 20 44 75 70 6c 69 63 61 74 65  ----.# Duplicate
0e40: 20 74 6f 6b 65 6e 69 7a 65 3d 20 61 6e 64 20 6f   tokenize= and o
0e50: 74 68 65 72 20 6f 70 74 69 6f 6e 73 2e 0a 23 0a  ther options..#.
0e60: 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74  do_catchsql_test
0e70: 20 37 2e 31 20 7b 0a 20 20 43 52 45 41 54 45 20   7.1 {.  CREATE 
0e80: 56 49 52 54 55 41 4c 20 54 41 42 4c 45 20 61 62  VIRTUAL TABLE ab
0e90: 63 20 55 53 49 4e 47 20 66 74 73 35 28 61 2c 20  c USING fts5(a, 
0ea0: 74 6f 6b 65 6e 69 7a 65 3d 70 6f 72 74 65 72 2c  tokenize=porter,
0eb0: 20 74 6f 6b 65 6e 69 7a 65 3d 61 73 63 69 69 29   tokenize=ascii)
0ec0: 3b 0a 7d 20 7b 31 20 7b 6d 75 6c 74 69 70 6c 65  ;.} {1 {multiple
0ed0: 20 74 6f 6b 65 6e 69 7a 65 3d 2e 2e 2e 20 64 69   tokenize=... di
0ee0: 72 65 63 74 69 76 65 73 7d 7d 0a 64 6f 5f 63 61  rectives}}.do_ca
0ef0: 74 63 68 73 71 6c 5f 74 65 73 74 20 37 2e 32 20  tchsql_test 7.2 
0f00: 7b 0a 20 20 43 52 45 41 54 45 20 56 49 52 54 55  {.  CREATE VIRTU
0f10: 41 4c 20 54 41 42 4c 45 20 61 62 63 20 55 53 49  AL TABLE abc USI
0f20: 4e 47 20 66 74 73 35 28 61 2c 20 63 6f 6e 74 65  NG fts5(a, conte
0f30: 6e 74 3d 70 6f 72 74 65 72 2c 20 63 6f 6e 74 65  nt=porter, conte
0f40: 6e 74 3d 61 73 63 69 69 29 3b 0a 7d 20 7b 31 20  nt=ascii);.} {1 
0f50: 7b 6d 75 6c 74 69 70 6c 65 20 63 6f 6e 74 65 6e  {multiple conten
0f60: 74 3d 2e 2e 2e 20 64 69 72 65 63 74 69 76 65 73  t=... directives
0f70: 7d 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74  }}.do_catchsql_t
0f80: 65 73 74 20 37 2e 33 20 7b 0a 20 20 43 52 45 41  est 7.3 {.  CREA
0f90: 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45  TE VIRTUAL TABLE
0fa0: 20 61 62 63 20 55 53 49 4e 47 20 66 74 73 35 28   abc USING fts5(
0fb0: 61 2c 20 63 6f 6e 74 65 6e 74 5f 72 6f 77 69 64  a, content_rowid
0fc0: 3d 70 6f 72 74 65 72 2c 20 63 6f 6e 74 65 6e 74  =porter, content
0fd0: 5f 72 6f 77 69 64 3d 61 29 3b 0a 7d 20 7b 31 20  _rowid=a);.} {1 
0fe0: 7b 6d 75 6c 74 69 70 6c 65 20 63 6f 6e 74 65 6e  {multiple conten
0ff0: 74 5f 72 6f 77 69 64 3d 2e 2e 2e 20 64 69 72 65  t_rowid=... dire
1000: 63 74 69 76 65 73 7d 7d 0a 0a 23 2d 2d 2d 2d 2d  ctives}}..#-----
1010: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1020: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1030: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1040: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1050: 2d 2d 2d 2d 0a 23 20 55 6e 72 65 63 6f 67 6e 69  ----.# Unrecogni
1060: 7a 65 64 20 6f 70 74 69 6f 6e 2e 0a 23 0a 64 6f  zed option..#.do
1070: 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20 38  _catchsql_test 8
1080: 2e 30 20 7b 0a 20 20 43 52 45 41 54 45 20 56 49  .0 {.  CREATE VI
1090: 52 54 55 41 4c 20 54 41 42 4c 45 20 61 62 63 20  RTUAL TABLE abc 
10a0: 55 53 49 4e 47 20 66 74 73 35 28 61 2c 20 6e 6f  USING fts5(a, no
10b0: 73 75 63 68 6f 70 74 69 6f 6e 3d 31 32 33 29 3b  suchoption=123);
10c0: 0a 7d 20 7b 31 20 7b 75 6e 72 65 63 6f 67 6e 69  .} {1 {unrecogni
10d0: 7a 65 64 20 6f 70 74 69 6f 6e 3a 20 22 6e 6f 73  zed option: "nos
10e0: 75 63 68 6f 70 74 69 6f 6e 22 7d 7d 0a 64 6f 5f  uchoption"}}.do_
10f0: 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20 38 2e  catchsql_test 8.
1100: 31 20 7b 0a 20 20 43 52 45 41 54 45 20 56 49 52  1 {.  CREATE VIR
1110: 54 55 41 4c 20 54 41 42 4c 45 20 61 62 63 20 55  TUAL TABLE abc U
1120: 53 49 4e 47 20 66 74 73 35 28 61 2c 20 22 6e 6f  SING fts5(a, "no
1130: 73 75 63 68 6f 70 74 69 6f 6e 22 3d 31 32 33 29  suchoption"=123)
1140: 3b 0a 7d 20 7b 31 20 7b 70 61 72 73 65 20 65 72  ;.} {1 {parse er
1150: 72 6f 72 20 69 6e 20 22 22 6e 6f 73 75 63 68 6f  ror in ""nosucho
1160: 70 74 69 6f 6e 22 3d 31 32 33 22 7d 7d 0a 0a 23  ption"=123"}}..#
1170: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1180: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1190: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 45 72 72 6f  ---------.# Erro
11c0: 72 73 20 69 6e 3a 0a 23 0a 23 20 20 20 39 2e 31  rs in:.#.#   9.1
11d0: 2e 2a 20 27 70 67 73 7a 27 20 6f 70 74 69 6f 6e  .* 'pgsz' option
11e0: 73 2e 0a 23 20 20 20 39 2e 32 2e 2a 20 27 61 75  s..#   9.2.* 'au
11f0: 74 6f 6d 65 72 67 65 27 20 6f 70 74 69 6f 6e 73  tomerge' options
1200: 2e 0a 23 20 20 20 39 2e 33 2e 2a 20 27 63 72 69  ..#   9.3.* 'cri
1210: 73 69 73 6d 65 72 67 65 27 20 6f 70 74 69 6f 6e  sismerge' option
1220: 73 2e 0a 23 0a 64 6f 5f 65 78 65 63 73 71 6c 5f  s..#.do_execsql_
1230: 74 65 73 74 20 39 2e 30 20 7b 0a 20 20 43 52 45  test 9.0 {.  CRE
1240: 41 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c  ATE VIRTUAL TABL
1250: 45 20 61 62 63 20 55 53 49 4e 47 20 66 74 73 35  E abc USING fts5
1260: 28 61 2c 20 62 29 3b 0a 7d 20 7b 7d 0a 64 6f 5f  (a, b);.} {}.do_
1270: 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20 39 2e  catchsql_test 9.
1280: 31 2e 31 20 7b 0a 20 20 49 4e 53 45 52 54 20 49  1.1 {.  INSERT I
1290: 4e 54 4f 20 61 62 63 28 61 62 63 2c 20 72 61 6e  NTO abc(abc, ran
12a0: 6b 29 20 56 41 4c 55 45 53 28 27 70 67 73 7a 27  k) VALUES('pgsz'
12b0: 2c 20 2d 35 29 3b 0a 7d 20 7b 31 20 7b 53 51 4c  , -5);.} {1 {SQL
12c0: 20 6c 6f 67 69 63 20 65 72 72 6f 72 20 6f 72 20   logic error or 
12d0: 6d 69 73 73 69 6e 67 20 64 61 74 61 62 61 73 65  missing database
12e0: 7d 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74  }}.do_catchsql_t
12f0: 65 73 74 20 39 2e 31 2e 32 20 7b 0a 20 20 49 4e  est 9.1.2 {.  IN
1300: 53 45 52 54 20 49 4e 54 4f 20 61 62 63 28 61 62  SERT INTO abc(ab
1310: 63 2c 20 72 61 6e 6b 29 20 56 41 4c 55 45 53 28  c, rank) VALUES(
1320: 27 70 67 73 7a 27 2c 20 35 30 30 30 30 30 30 30  'pgsz', 50000000
1330: 29 3b 0a 7d 20 7b 31 20 7b 53 51 4c 20 6c 6f 67  );.} {1 {SQL log
1340: 69 63 20 65 72 72 6f 72 20 6f 72 20 6d 69 73 73  ic error or miss
1350: 69 6e 67 20 64 61 74 61 62 61 73 65 7d 7d 0a 64  ing database}}.d
1360: 6f 5f 63 61 74 63 68 73 71 6c 5f 74 65 73 74 20  o_catchsql_test 
1370: 39 2e 31 2e 33 20 7b 0a 20 20 49 4e 53 45 52 54  9.1.3 {.  INSERT
1380: 20 49 4e 54 4f 20 61 62 63 28 61 62 63 2c 20 72   INTO abc(abc, r
1390: 61 6e 6b 29 20 56 41 4c 55 45 53 28 27 70 67 73  ank) VALUES('pgs
13a0: 7a 27 2c 20 36 36 2e 36 37 29 3b 0a 7d 20 7b 31  z', 66.67);.} {1
13b0: 20 7b 53 51 4c 20 6c 6f 67 69 63 20 65 72 72 6f   {SQL logic erro
13c0: 72 20 6f 72 20 6d 69 73 73 69 6e 67 20 64 61 74  r or missing dat
13d0: 61 62 61 73 65 7d 7d 0a 0a 64 6f 5f 63 61 74 63  abase}}..do_catc
13e0: 68 73 71 6c 5f 74 65 73 74 20 39 2e 32 2e 31 20  hsql_test 9.2.1 
13f0: 7b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  {.  INSERT INTO 
1400: 61 62 63 28 61 62 63 2c 20 72 61 6e 6b 29 20 56  abc(abc, rank) V
1410: 41 4c 55 45 53 28 27 61 75 74 6f 6d 65 72 67 65  ALUES('automerge
1420: 27 2c 20 2d 35 29 3b 0a 7d 20 7b 31 20 7b 53 51  ', -5);.} {1 {SQ
1430: 4c 20 6c 6f 67 69 63 20 65 72 72 6f 72 20 6f 72  L logic error or
1440: 20 6d 69 73 73 69 6e 67 20 64 61 74 61 62 61 73   missing databas
1450: 65 7d 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f  e}}.do_catchsql_
1460: 74 65 73 74 20 39 2e 32 2e 32 20 7b 0a 20 20 49  test 9.2.2 {.  I
1470: 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 28 61  NSERT INTO abc(a
1480: 62 63 2c 20 72 61 6e 6b 29 20 56 41 4c 55 45 53  bc, rank) VALUES
1490: 28 27 61 75 74 6f 6d 65 72 67 65 27 2c 20 35 30  ('automerge', 50
14a0: 30 30 30 30 30 30 29 3b 0a 7d 20 7b 31 20 7b 53  000000);.} {1 {S
14b0: 51 4c 20 6c 6f 67 69 63 20 65 72 72 6f 72 20 6f  QL logic error o
14c0: 72 20 6d 69 73 73 69 6e 67 20 64 61 74 61 62 61  r missing databa
14d0: 73 65 7d 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c  se}}.do_catchsql
14e0: 5f 74 65 73 74 20 39 2e 32 2e 33 20 7b 0a 20 20  _test 9.2.3 {.  
14f0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 28  INSERT INTO abc(
1500: 61 62 63 2c 20 72 61 6e 6b 29 20 56 41 4c 55 45  abc, rank) VALUE
1510: 53 28 27 61 75 74 6f 6d 65 72 67 65 27 2c 20 36  S('automerge', 6
1520: 36 2e 36 37 29 3b 0a 7d 20 7b 31 20 7b 53 51 4c  6.67);.} {1 {SQL
1530: 20 6c 6f 67 69 63 20 65 72 72 6f 72 20 6f 72 20   logic error or 
1540: 6d 69 73 73 69 6e 67 20 64 61 74 61 62 61 73 65  missing database
1550: 7d 7d 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  }}.do_execsql_te
1560: 73 74 20 39 2e 32 2e 34 20 7b 0a 20 20 49 4e 53  st 9.2.4 {.  INS
1570: 45 52 54 20 49 4e 54 4f 20 61 62 63 28 61 62 63  ERT INTO abc(abc
1580: 2c 20 72 61 6e 6b 29 20 56 41 4c 55 45 53 28 27  , rank) VALUES('
1590: 61 75 74 6f 6d 65 72 67 65 27 2c 20 31 29 3b 0a  automerge', 1);.
15a0: 7d 20 7b 7d 0a 0a 64 6f 5f 63 61 74 63 68 73 71  } {}..do_catchsq
15b0: 6c 5f 74 65 73 74 20 39 2e 33 2e 31 20 7b 0a 20  l_test 9.3.1 {. 
15c0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63   INSERT INTO abc
15d0: 28 61 62 63 2c 20 72 61 6e 6b 29 20 56 41 4c 55  (abc, rank) VALU
15e0: 45 53 28 27 63 72 69 73 69 73 6d 65 72 67 65 27  ES('crisismerge'
15f0: 2c 20 2d 35 29 3b 0a 7d 20 7b 31 20 7b 53 51 4c  , -5);.} {1 {SQL
1600: 20 6c 6f 67 69 63 20 65 72 72 6f 72 20 6f 72 20   logic error or 
1610: 6d 69 73 73 69 6e 67 20 64 61 74 61 62 61 73 65  missing database
1620: 7d 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74  }}.do_catchsql_t
1630: 65 73 74 20 39 2e 33 2e 32 20 7b 0a 20 20 49 4e  est 9.3.2 {.  IN
1640: 53 45 52 54 20 49 4e 54 4f 20 61 62 63 28 61 62  SERT INTO abc(ab
1650: 63 2c 20 72 61 6e 6b 29 20 56 41 4c 55 45 53 28  c, rank) VALUES(
1660: 27 63 72 69 73 69 73 6d 65 72 67 65 27 2c 20 36  'crisismerge', 6
1670: 36 2e 36 37 29 3b 0a 7d 20 7b 31 20 7b 53 51 4c  6.67);.} {1 {SQL
1680: 20 6c 6f 67 69 63 20 65 72 72 6f 72 20 6f 72 20   logic error or 
1690: 6d 69 73 73 69 6e 67 20 64 61 74 61 62 61 73 65  missing database
16a0: 7d 7d 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  }}.do_execsql_te
16b0: 73 74 20 39 2e 33 2e 33 20 7b 0a 20 20 49 4e 53  st 9.3.3 {.  INS
16c0: 45 52 54 20 49 4e 54 4f 20 61 62 63 28 61 62 63  ERT INTO abc(abc
16d0: 2c 20 72 61 6e 6b 29 20 56 41 4c 55 45 53 28 27  , rank) VALUES('
16e0: 63 72 69 73 69 73 6d 65 72 67 65 27 2c 20 31 29  crisismerge', 1)
16f0: 3b 0a 7d 20 7b 7d 0a 64 6f 5f 65 78 65 63 73 71  ;.} {}.do_execsq
1700: 6c 5f 74 65 73 74 20 39 2e 33 2e 34 20 7b 0a 20  l_test 9.3.4 {. 
1710: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63   INSERT INTO abc
1720: 28 61 62 63 2c 20 72 61 6e 6b 29 20 56 41 4c 55  (abc, rank) VALU
1730: 45 53 28 27 63 72 69 73 69 73 6d 65 72 67 65 27  ES('crisismerge'
1740: 2c 20 35 30 30 30 30 30 30 30 29 3b 0a 7d 20 7b  , 50000000);.} {
1750: 7d 0a 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f 74  }..do_catchsql_t
1760: 65 73 74 20 39 2e 34 2e 31 20 7b 0a 20 20 49 4e  est 9.4.1 {.  IN
1770: 53 45 52 54 20 49 4e 54 4f 20 61 62 63 28 61 62  SERT INTO abc(ab
1780: 63 2c 20 72 61 6e 6b 29 20 56 41 4c 55 45 53 28  c, rank) VALUES(
1790: 27 6e 6f 73 75 63 68 6f 70 74 69 6f 6e 27 2c 20  'nosuchoption', 
17a0: 31 29 3b 0a 7d 20 7b 31 20 7b 53 51 4c 20 6c 6f  1);.} {1 {SQL lo
17b0: 67 69 63 20 65 72 72 6f 72 20 6f 72 20 6d 69 73  gic error or mis
17c0: 73 69 6e 67 20 64 61 74 61 62 61 73 65 7d 7d 0a  sing database}}.
17d0: 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a 0a        .finish_test..