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

Artifact e44b37b926a5f5f2ef9f8e69488c7dc137db3f52:


0000: 23 20 32 30 30 31 20 53 65 70 74 65 6d 62 65 72  # 2001 September
0010: 20 31 35 0a 23 0a 23 20 54 68 65 20 61 75 74 68   15.#.# The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67  place of.# a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23  is a blessing:.#
0080: 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f  .#    May you do
0090: 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76   good and not ev
00a0: 69 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75  il..#    May you
00b0: 20 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73   find forgivenes
00c0: 73 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61  s for yourself a
00d0: 6e 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72  nd forgive other
00e0: 73 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  s..#    May you 
00f0: 73 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65  share freely, ne
0100: 76 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20  ver taking more 
0110: 74 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23  than you give..#
0120: 0a 23 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 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69 73  *********.# This
0170: 20 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73   file implements
0180: 20 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74   regression test
0190: 73 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62  s for SQLite lib
01a0: 72 61 72 79 2e 20 20 54 68 65 0a 23 20 66 6f 63  rary.  The.# foc
01b0: 75 73 20 6f 66 20 74 68 69 73 20 66 69 6c 65 20  us of this file 
01c0: 69 73 20 74 65 73 74 69 6e 67 20 65 78 70 72 65  is testing expre
01d0: 73 73 69 6f 6e 73 2e 0a 23 0a 23 20 24 49 64 3a  ssions..#.# $Id:
01e0: 20 65 78 70 72 2e 74 65 73 74 2c 76 20 31 2e 34   expr.test,v 1.4
01f0: 37 20 32 30 30 35 2f 31 31 2f 30 31 20 31 35 3a  7 2005/11/01 15:
0200: 34 38 3a 32 35 20 64 72 68 20 45 78 70 20 24 0a  48:25 drh Exp $.
0210: 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b 66 69  .set testdir [fi
0220: 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72 67 76  le dirname $argv
0230: 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73 74 64  0].source $testd
0240: 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a 0a 23  ir/tester.tcl..#
0250: 20 43 72 65 61 74 65 20 61 20 74 61 62 6c 65 20   Create a table 
0260: 74 6f 20 77 6f 72 6b 20 77 69 74 68 2e 0a 23 0a  to work with..#.
0270: 65 78 65 63 73 71 6c 20 7b 43 52 45 41 54 45 20  execsql {CREATE 
0280: 54 41 42 4c 45 20 74 65 73 74 31 28 69 31 20 69  TABLE test1(i1 i
0290: 6e 74 2c 20 69 32 20 69 6e 74 2c 20 72 31 20 72  nt, i2 int, r1 r
02a0: 65 61 6c 2c 20 72 32 20 72 65 61 6c 2c 20 74 31  eal, r2 real, t1
02b0: 20 74 65 78 74 2c 20 74 32 20 74 65 78 74 29 7d   text, t2 text)}
02c0: 0a 65 78 65 63 73 71 6c 20 7b 49 4e 53 45 52 54  .execsql {INSERT
02d0: 20 49 4e 54 4f 20 74 65 73 74 31 20 56 41 4c 55   INTO test1 VALU
02e0: 45 53 28 31 2c 32 2c 31 2e 31 2c 32 2e 32 2c 27  ES(1,2,1.1,2.2,'
02f0: 68 65 6c 6c 6f 27 2c 27 77 6f 72 6c 64 27 29 7d  hello','world')}
0300: 0a 70 72 6f 63 20 74 65 73 74 5f 65 78 70 72 20  .proc test_expr 
0310: 7b 6e 61 6d 65 20 73 65 74 74 69 6e 67 73 20 65  {name settings e
0320: 78 70 72 20 72 65 73 75 6c 74 7d 20 7b 0a 20 20  xpr result} {.  
0330: 64 6f 5f 74 65 73 74 20 24 6e 61 6d 65 20 5b 66  do_test $name [f
0340: 6f 72 6d 61 74 20 7b 0a 20 20 20 20 65 78 65 63  ormat {.    exec
0350: 73 71 6c 20 7b 42 45 47 49 4e 3b 20 55 50 44 41  sql {BEGIN; UPDA
0360: 54 45 20 74 65 73 74 31 20 53 45 54 20 25 73 3b  TE test1 SET %s;
0370: 20 53 45 4c 45 43 54 20 25 73 20 46 52 4f 4d 20   SELECT %s FROM 
0380: 74 65 73 74 31 3b 20 52 4f 4c 4c 42 41 43 4b 3b  test1; ROLLBACK;
0390: 7d 0a 20 20 7d 20 24 73 65 74 74 69 6e 67 73 20  }.  } $settings 
03a0: 24 65 78 70 72 5d 20 24 72 65 73 75 6c 74 0a 7d  $expr] $result.}
03b0: 0a 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  ..test_expr expr
03c0: 2d 31 2e 31 20 7b 69 31 3d 31 30 2c 20 69 32 3d  -1.1 {i1=10, i2=
03d0: 32 30 7d 20 7b 69 31 2b 69 32 7d 20 33 30 0a 74  20} {i1+i2} 30.t
03e0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
03f0: 32 20 7b 69 31 3d 31 30 2c 20 69 32 3d 32 30 7d  2 {i1=10, i2=20}
0400: 20 7b 69 31 2d 69 32 7d 20 2d 31 30 0a 74 65 73   {i1-i2} -10.tes
0410: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 33 20  t_expr expr-1.3 
0420: 7b 69 31 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b  {i1=10, i2=20} {
0430: 69 31 2a 69 32 7d 20 32 30 30 0a 74 65 73 74 5f  i1*i2} 200.test_
0440: 65 78 70 72 20 65 78 70 72 2d 31 2e 34 20 7b 69  expr expr-1.4 {i
0450: 31 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b 69 31  1=10, i2=20} {i1
0460: 2f 69 32 7d 20 30 2e 35 0a 74 65 73 74 5f 65 78  /i2} 0.5.test_ex
0470: 70 72 20 65 78 70 72 2d 31 2e 35 20 7b 69 31 3d  pr expr-1.5 {i1=
0480: 31 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 2f 69  10, i2=20} {i2/i
0490: 31 7d 20 32 0a 74 65 73 74 5f 65 78 70 72 20 65  1} 2.test_expr e
04a0: 78 70 72 2d 31 2e 36 20 7b 69 31 3d 31 30 2c 20  xpr-1.6 {i1=10, 
04b0: 69 32 3d 32 30 7d 20 7b 69 32 3c 69 31 7d 20 30  i2=20} {i2<i1} 0
04c0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
04d0: 31 2e 37 20 7b 69 31 3d 31 30 2c 20 69 32 3d 32  1.7 {i1=10, i2=2
04e0: 30 7d 20 7b 69 32 3c 3d 69 31 7d 20 30 0a 74 65  0} {i2<=i1} 0.te
04f0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 38  st_expr expr-1.8
0500: 20 7b 69 31 3d 31 30 2c 20 69 32 3d 32 30 7d 20   {i1=10, i2=20} 
0510: 7b 69 32 3e 69 31 7d 20 31 0a 74 65 73 74 5f 65  {i2>i1} 1.test_e
0520: 78 70 72 20 65 78 70 72 2d 31 2e 39 20 7b 69 31  xpr expr-1.9 {i1
0530: 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3e  =10, i2=20} {i2>
0540: 3d 69 31 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  =i1} 1.test_expr
0550: 20 65 78 70 72 2d 31 2e 31 30 20 7b 69 31 3d 31   expr-1.10 {i1=1
0560: 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 21 3d 69  0, i2=20} {i2!=i
0570: 31 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65  1} 1.test_expr e
0580: 78 70 72 2d 31 2e 31 31 20 7b 69 31 3d 31 30 2c  xpr-1.11 {i1=10,
0590: 20 69 32 3d 32 30 7d 20 7b 69 32 3d 69 31 7d 20   i2=20} {i2=i1} 
05a0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
05b0: 2d 31 2e 31 32 20 7b 69 31 3d 31 30 2c 20 69 32  -1.12 {i1=10, i2
05c0: 3d 32 30 7d 20 7b 69 32 3c 3e 69 31 7d 20 31 0a  =20} {i2<>i1} 1.
05d0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
05e0: 2e 31 33 20 7b 69 31 3d 31 30 2c 20 69 32 3d 32  .13 {i1=10, i2=2
05f0: 30 7d 20 7b 69 32 3d 3d 69 31 7d 20 30 0a 74 65  0} {i2==i1} 0.te
0600: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 31  st_expr expr-1.1
0610: 34 20 7b 69 31 3d 32 30 2c 20 69 32 3d 32 30 7d  4 {i1=20, i2=20}
0620: 20 7b 69 32 3c 69 31 7d 20 30 0a 74 65 73 74 5f   {i2<i1} 0.test_
0630: 65 78 70 72 20 65 78 70 72 2d 31 2e 31 35 20 7b  expr expr-1.15 {
0640: 69 31 3d 32 30 2c 20 69 32 3d 32 30 7d 20 7b 69  i1=20, i2=20} {i
0650: 32 3c 3d 69 31 7d 20 31 0a 74 65 73 74 5f 65 78  2<=i1} 1.test_ex
0660: 70 72 20 65 78 70 72 2d 31 2e 31 36 20 7b 69 31  pr expr-1.16 {i1
0670: 3d 32 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3e  =20, i2=20} {i2>
0680: 69 31 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  i1} 0.test_expr 
0690: 65 78 70 72 2d 31 2e 31 37 20 7b 69 31 3d 32 30  expr-1.17 {i1=20
06a0: 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3e 3d 69 31  , i2=20} {i2>=i1
06b0: 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 1.test_expr ex
06c0: 70 72 2d 31 2e 31 38 20 7b 69 31 3d 32 30 2c 20  pr-1.18 {i1=20, 
06d0: 69 32 3d 32 30 7d 20 7b 69 32 21 3d 69 31 7d 20  i2=20} {i2!=i1} 
06e0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
06f0: 2d 31 2e 31 39 20 7b 69 31 3d 32 30 2c 20 69 32  -1.19 {i1=20, i2
0700: 3d 32 30 7d 20 7b 69 32 3d 69 31 7d 20 31 0a 74  =20} {i2=i1} 1.t
0710: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0720: 32 30 20 7b 69 31 3d 32 30 2c 20 69 32 3d 32 30  20 {i1=20, i2=20
0730: 7d 20 7b 69 32 3c 3e 69 31 7d 20 30 0a 74 65 73  } {i2<>i1} 0.tes
0740: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 32 31  t_expr expr-1.21
0750: 20 7b 69 31 3d 32 30 2c 20 69 32 3d 32 30 7d 20   {i1=20, i2=20} 
0760: 7b 69 32 3d 3d 69 31 7d 20 31 0a 74 65 73 74 5f  {i2==i1} 1.test_
0770: 65 78 70 72 20 65 78 70 72 2d 31 2e 32 32 20 7b  expr expr-1.22 {
0780: 69 31 3d 31 2c 20 69 32 3d 32 2c 20 72 31 3d 33  i1=1, i2=2, r1=3
0790: 2e 30 7d 20 7b 69 31 2b 69 32 2a 72 31 7d 20 7b  .0} {i1+i2*r1} {
07a0: 37 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  7}.test_expr exp
07b0: 72 2d 31 2e 32 33 20 7b 69 31 3d 31 2c 20 69 32  r-1.23 {i1=1, i2
07c0: 3d 32 2c 20 72 31 3d 33 2e 30 7d 20 7b 28 69 31  =2, r1=3.0} {(i1
07d0: 2b 69 32 29 2a 72 31 7d 20 7b 39 7d 0a 74 65 73  +i2)*r1} {9}.tes
07e0: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 32 34  t_expr expr-1.24
07f0: 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 6d   {i1=1, i2=2} {m
0800: 69 6e 28 69 31 2c 69 32 2c 69 31 2b 69 32 2c 69  in(i1,i2,i1+i2,i
0810: 31 2d 69 32 29 7d 20 7b 2d 31 7d 0a 74 65 73 74  1-i2)} {-1}.test
0820: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 32 35 20  _expr expr-1.25 
0830: 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 6d 61  {i1=1, i2=2} {ma
0840: 78 28 69 31 2c 69 32 2c 69 31 2b 69 32 2c 69 31  x(i1,i2,i1+i2,i1
0850: 2d 69 32 29 7d 20 7b 33 7d 0a 74 65 73 74 5f 65  -i2)} {3}.test_e
0860: 78 70 72 20 65 78 70 72 2d 31 2e 32 36 20 7b 69  xpr expr-1.26 {i
0870: 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 6d 61 78 28  1=1, i2=2} {max(
0880: 69 31 2c 69 32 2c 69 31 2b 69 32 2c 69 31 2d 69  i1,i2,i1+i2,i1-i
0890: 32 29 7d 20 7b 33 7d 0a 74 65 73 74 5f 65 78 70  2)} {3}.test_exp
08a0: 72 20 65 78 70 72 2d 31 2e 32 37 20 7b 69 31 3d  r expr-1.27 {i1=
08b0: 31 2c 20 69 32 3d 32 7d 20 7b 69 31 3d 3d 31 20  1, i2=2} {i1==1 
08c0: 41 4e 44 20 69 32 3d 32 7d 20 7b 31 7d 0a 74 65  AND i2=2} {1}.te
08d0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 32  st_expr expr-1.2
08e0: 38 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b  8 {i1=1, i2=2} {
08f0: 69 31 3d 32 20 41 4e 44 20 69 32 3d 31 7d 20 7b  i1=2 AND i2=1} {
0900: 30 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  0}.test_expr exp
0910: 72 2d 31 2e 32 39 20 7b 69 31 3d 31 2c 20 69 32  r-1.29 {i1=1, i2
0920: 3d 32 7d 20 7b 69 31 3d 31 20 41 4e 44 20 69 32  =2} {i1=1 AND i2
0930: 3d 31 7d 20 7b 30 7d 0a 74 65 73 74 5f 65 78 70  =1} {0}.test_exp
0940: 72 20 65 78 70 72 2d 31 2e 33 30 20 7b 69 31 3d  r expr-1.30 {i1=
0950: 31 2c 20 69 32 3d 32 7d 20 7b 69 31 3d 32 20 41  1, i2=2} {i1=2 A
0960: 4e 44 20 69 32 3d 32 7d 20 7b 30 7d 0a 74 65 73  ND i2=2} {0}.tes
0970: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 33 31  t_expr expr-1.31
0980: 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 69   {i1=1, i2=2} {i
0990: 31 3d 3d 31 20 4f 52 20 69 32 3d 32 7d 20 7b 31  1==1 OR i2=2} {1
09a0: 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  }.test_expr expr
09b0: 2d 31 2e 33 32 20 7b 69 31 3d 31 2c 20 69 32 3d  -1.32 {i1=1, i2=
09c0: 32 7d 20 7b 69 31 3d 32 20 4f 52 20 69 32 3d 31  2} {i1=2 OR i2=1
09d0: 7d 20 7b 30 7d 0a 74 65 73 74 5f 65 78 70 72 20  } {0}.test_expr 
09e0: 65 78 70 72 2d 31 2e 33 33 20 7b 69 31 3d 31 2c  expr-1.33 {i1=1,
09f0: 20 69 32 3d 32 7d 20 7b 69 31 3d 31 20 4f 52 20   i2=2} {i1=1 OR 
0a00: 69 32 3d 31 7d 20 7b 31 7d 0a 74 65 73 74 5f 65  i2=1} {1}.test_e
0a10: 78 70 72 20 65 78 70 72 2d 31 2e 33 34 20 7b 69  xpr expr-1.34 {i
0a20: 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 69 31 3d 32  1=1, i2=2} {i1=2
0a30: 20 4f 52 20 69 32 3d 32 7d 20 7b 31 7d 0a 74 65   OR i2=2} {1}.te
0a40: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 33  st_expr expr-1.3
0a50: 35 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b  5 {i1=1, i2=2} {
0a60: 69 31 2d 69 32 3d 2d 31 7d 20 7b 31 7d 0a 74 65  i1-i2=-1} {1}.te
0a70: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 33  st_expr expr-1.3
0a80: 36 20 7b 69 31 3d 31 2c 20 69 32 3d 30 7d 20 7b  6 {i1=1, i2=0} {
0a90: 6e 6f 74 20 69 31 7d 20 7b 30 7d 0a 74 65 73 74  not i1} {0}.test
0aa0: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 33 37 20  _expr expr-1.37 
0ab0: 7b 69 31 3d 31 2c 20 69 32 3d 30 7d 20 7b 6e 6f  {i1=1, i2=0} {no
0ac0: 74 20 69 32 7d 20 7b 31 7d 0a 74 65 73 74 5f 65  t i2} {1}.test_e
0ad0: 78 70 72 20 65 78 70 72 2d 31 2e 33 38 20 7b 69  xpr expr-1.38 {i
0ae0: 31 3d 31 7d 20 7b 2d 69 31 7d 20 7b 2d 31 7d 0a  1=1} {-i1} {-1}.
0af0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
0b00: 2e 33 39 20 7b 69 31 3d 31 7d 20 7b 2b 69 31 7d  .39 {i1=1} {+i1}
0b10: 20 7b 31 7d 0a 74 65 73 74 5f 65 78 70 72 20 65   {1}.test_expr e
0b20: 78 70 72 2d 31 2e 34 30 20 7b 69 31 3d 31 2c 20  xpr-1.40 {i1=1, 
0b30: 69 32 3d 32 7d 20 7b 2b 28 69 32 2b 69 31 29 7d  i2=2} {+(i2+i1)}
0b40: 20 7b 33 7d 0a 74 65 73 74 5f 65 78 70 72 20 65   {3}.test_expr e
0b50: 78 70 72 2d 31 2e 34 31 20 7b 69 31 3d 31 2c 20  xpr-1.41 {i1=1, 
0b60: 69 32 3d 32 7d 20 7b 2d 28 69 32 2b 69 31 29 7d  i2=2} {-(i2+i1)}
0b70: 20 7b 2d 33 7d 0a 74 65 73 74 5f 65 78 70 72 20   {-3}.test_expr 
0b80: 65 78 70 72 2d 31 2e 34 32 20 7b 69 31 3d 31 2c  expr-1.42 {i1=1,
0b90: 20 69 32 3d 32 7d 20 7b 69 31 7c 69 32 7d 20 7b   i2=2} {i1|i2} {
0ba0: 33 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  3}.test_expr exp
0bb0: 72 2d 31 2e 34 32 62 20 7b 69 31 3d 31 2c 20 69  r-1.42b {i1=1, i
0bc0: 32 3d 32 7d 20 7b 34 7c 32 7d 20 7b 36 7d 0a 74  2=2} {4|2} {6}.t
0bd0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0be0: 34 33 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20  43 {i1=1, i2=2} 
0bf0: 7b 69 31 26 69 32 7d 20 7b 30 7d 0a 74 65 73 74  {i1&i2} {0}.test
0c00: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 34 33 62  _expr expr-1.43b
0c10: 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 34   {i1=1, i2=2} {4
0c20: 26 35 7d 20 7b 34 7d 0a 74 65 73 74 5f 65 78 70  &5} {4}.test_exp
0c30: 72 20 65 78 70 72 2d 31 2e 34 34 20 7b 69 31 3d  r expr-1.44 {i1=
0c40: 31 7d 20 7b 7e 69 31 7d 20 7b 2d 32 7d 0a 74 65  1} {~i1} {-2}.te
0c50: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 34  st_expr expr-1.4
0c60: 35 20 7b 69 31 3d 31 2c 20 69 32 3d 33 7d 20 7b  5 {i1=1, i2=3} {
0c70: 69 31 3c 3c 69 32 7d 20 7b 38 7d 0a 74 65 73 74  i1<<i2} {8}.test
0c80: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 34 36 20  _expr expr-1.46 
0c90: 7b 69 31 3d 33 32 2c 20 69 32 3d 33 7d 20 7b 69  {i1=32, i2=3} {i
0ca0: 31 3e 3e 69 32 7d 20 7b 34 7d 0a 74 65 73 74 5f  1>>i2} {4}.test_
0cb0: 65 78 70 72 20 65 78 70 72 2d 31 2e 34 37 20 7b  expr expr-1.47 {
0cc0: 69 31 3d 39 39 39 39 39 39 39 39 39 39 2c 20 69  i1=9999999999, i
0cd0: 32 3d 38 38 38 38 38 38 38 38 38 38 7d 20 7b 69  2=8888888888} {i
0ce0: 31 3c 69 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  1<i2} 0.test_exp
0cf0: 72 20 65 78 70 72 2d 31 2e 34 38 20 7b 69 31 3d  r expr-1.48 {i1=
0d00: 39 39 39 39 39 39 39 39 39 39 2c 20 69 32 3d 38  9999999999, i2=8
0d10: 38 38 38 38 38 38 38 38 38 7d 20 7b 69 31 3d 69  888888888} {i1=i
0d20: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
0d30: 78 70 72 2d 31 2e 34 39 20 7b 69 31 3d 39 39 39  xpr-1.49 {i1=999
0d40: 39 39 39 39 39 39 39 2c 20 69 32 3d 38 38 38 38  9999999, i2=8888
0d50: 38 38 38 38 38 38 7d 20 7b 69 31 3e 69 32 7d 20  888888} {i1>i2} 
0d60: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
0d70: 2d 31 2e 35 30 20 7b 69 31 3d 39 39 39 39 39 39  -1.50 {i1=999999
0d80: 39 39 39 39 39 2c 20 69 32 3d 39 39 39 39 39 39  99999, i2=999999
0d90: 39 39 39 39 38 7d 20 7b 69 31 3c 69 32 7d 20 30  99998} {i1<i2} 0
0da0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
0db0: 31 2e 35 31 20 7b 69 31 3d 39 39 39 39 39 39 39  1.51 {i1=9999999
0dc0: 39 39 39 39 2c 20 69 32 3d 39 39 39 39 39 39 39  9999, i2=9999999
0dd0: 39 39 39 38 7d 20 7b 69 31 3d 69 32 7d 20 30 0a  9998} {i1=i2} 0.
0de0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
0df0: 2e 35 32 20 7b 69 31 3d 39 39 39 39 39 39 39 39  .52 {i1=99999999
0e00: 39 39 39 2c 20 69 32 3d 39 39 39 39 39 39 39 39  999, i2=99999999
0e10: 39 39 38 7d 20 7b 69 31 3e 69 32 7d 20 31 0a 74  998} {i1>i2} 1.t
0e20: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0e30: 35 33 20 7b 69 31 3d 30 39 39 39 39 39 39 39 39  53 {i1=099999999
0e40: 39 39 39 2c 20 69 32 3d 39 39 39 39 39 39 39 39  999, i2=99999999
0e50: 39 39 39 7d 20 7b 69 31 3c 69 32 7d 20 30 0a 74  999} {i1<i2} 0.t
0e60: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0e70: 35 34 20 7b 69 31 3d 30 39 39 39 39 39 39 39 39  54 {i1=099999999
0e80: 39 39 39 2c 20 69 32 3d 39 39 39 39 39 39 39 39  999, i2=99999999
0e90: 39 39 39 7d 20 7b 69 31 3d 69 32 7d 20 31 0a 74  999} {i1=i2} 1.t
0ea0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0eb0: 35 35 20 7b 69 31 3d 30 39 39 39 39 39 39 39 39  55 {i1=099999999
0ec0: 39 39 39 2c 20 69 32 3d 39 39 39 39 39 39 39 39  999, i2=99999999
0ed0: 39 39 39 7d 20 7b 69 31 3e 69 32 7d 20 30 0a 74  999} {i1>i2} 0.t
0ee0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0ef0: 35 36 20 7b 69 31 3d 32 35 2c 20 69 32 3d 31 31  56 {i1=25, i2=11
0f00: 7d 20 7b 69 31 25 69 32 7d 20 33 0a 74 65 73 74  } {i1%i2} 3.test
0f10: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 35 38 20  _expr expr-1.58 
0f20: 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 31 7d 20  {i1=NULL, i2=1} 
0f30: 7b 63 6f 61 6c 65 73 63 65 28 69 31 2b 69 32 2c  {coalesce(i1+i2,
0f40: 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70  99)} 99.test_exp
0f50: 72 20 65 78 70 72 2d 31 2e 35 39 20 7b 69 31 3d  r expr-1.59 {i1=
0f60: 31 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61  1, i2=NULL} {coa
0f70: 6c 65 73 63 65 28 69 31 2b 69 32 2c 39 39 29 7d  lesce(i1+i2,99)}
0f80: 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78   99.test_expr ex
0f90: 70 72 2d 31 2e 36 30 20 7b 69 31 3d 4e 55 4c 4c  pr-1.60 {i1=NULL
0fa0: 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , i2=NULL} {coal
0fb0: 65 73 63 65 28 69 31 2b 69 32 2c 39 39 29 7d 20  esce(i1+i2,99)} 
0fc0: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  99.test_expr exp
0fd0: 72 2d 31 2e 36 31 20 7b 69 31 3d 4e 55 4c 4c 2c  r-1.61 {i1=NULL,
0fe0: 20 69 32 3d 31 7d 20 7b 63 6f 61 6c 65 73 63 65   i2=1} {coalesce
0ff0: 28 69 31 2d 69 32 2c 39 39 29 7d 20 39 39 0a 74  (i1-i2,99)} 99.t
1000: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
1010: 36 32 20 7b 69 31 3d 31 2c 20 69 32 3d 4e 55 4c  62 {i1=1, i2=NUL
1020: 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 2d  L} {coalesce(i1-
1030: 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f  i2,99)} 99.test_
1040: 65 78 70 72 20 65 78 70 72 2d 31 2e 36 33 20 7b  expr expr-1.63 {
1050: 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c  i1=NULL, i2=NULL
1060: 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 2d 69  } {coalesce(i1-i
1070: 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  2,99)} 99.test_e
1080: 78 70 72 20 65 78 70 72 2d 31 2e 36 34 20 7b 69  xpr expr-1.64 {i
1090: 31 3d 4e 55 4c 4c 2c 20 69 32 3d 31 7d 20 7b 63  1=NULL, i2=1} {c
10a0: 6f 61 6c 65 73 63 65 28 69 31 2a 69 32 2c 39 39  oalesce(i1*i2,99
10b0: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
10c0: 65 78 70 72 2d 31 2e 36 35 20 7b 69 31 3d 31 2c  expr-1.65 {i1=1,
10d0: 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65   i2=NULL} {coale
10e0: 73 63 65 28 69 31 2a 69 32 2c 39 39 29 7d 20 39  sce(i1*i2,99)} 9
10f0: 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  9.test_expr expr
1100: 2d 31 2e 36 36 20 7b 69 31 3d 4e 55 4c 4c 2c 20  -1.66 {i1=NULL, 
1110: 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73  i2=NULL} {coales
1120: 63 65 28 69 31 2a 69 32 2c 39 39 29 7d 20 39 39  ce(i1*i2,99)} 99
1130: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1140: 31 2e 36 37 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.67 {i1=NULL, i
1150: 32 3d 31 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69  2=1} {coalesce(i
1160: 31 2f 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73  1/i2,99)} 99.tes
1170: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 36 38  t_expr expr-1.68
1180: 20 7b 69 31 3d 31 2c 20 69 32 3d 4e 55 4c 4c 7d   {i1=1, i2=NULL}
1190: 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 2f 69 32   {coalesce(i1/i2
11a0: 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78  ,99)} 99.test_ex
11b0: 70 72 20 65 78 70 72 2d 31 2e 36 39 20 7b 69 31  pr expr-1.69 {i1
11c0: 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d 20  =NULL, i2=NULL} 
11d0: 7b 63 6f 61 6c 65 73 63 65 28 69 31 2f 69 32 2c  {coalesce(i1/i2,
11e0: 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70  99)} 99.test_exp
11f0: 72 20 65 78 70 72 2d 31 2e 37 30 20 7b 69 31 3d  r expr-1.70 {i1=
1200: 4e 55 4c 4c 2c 20 69 32 3d 31 7d 20 7b 63 6f 61  NULL, i2=1} {coa
1210: 6c 65 73 63 65 28 69 31 3c 69 32 2c 39 39 29 7d  lesce(i1<i2,99)}
1220: 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78   99.test_expr ex
1230: 70 72 2d 31 2e 37 31 20 7b 69 31 3d 31 2c 20 69  pr-1.71 {i1=1, i
1240: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
1250: 65 28 69 31 3e 69 32 2c 39 39 29 7d 20 39 39 0a  e(i1>i2,99)} 99.
1260: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
1270: 2e 37 32 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32  .72 {i1=NULL, i2
1280: 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65  =NULL} {coalesce
1290: 28 69 31 3c 3d 69 32 2c 39 39 29 7d 20 39 39 0a  (i1<=i2,99)} 99.
12a0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
12b0: 2e 37 33 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32  .73 {i1=NULL, i2
12c0: 3d 31 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31  =1} {coalesce(i1
12d0: 3e 3d 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73  >=i2,99)} 99.tes
12e0: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 37 34  t_expr expr-1.74
12f0: 20 7b 69 31 3d 31 2c 20 69 32 3d 4e 55 4c 4c 7d   {i1=1, i2=NULL}
1300: 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 21 3d 69   {coalesce(i1!=i
1310: 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  2,99)} 99.test_e
1320: 78 70 72 20 65 78 70 72 2d 31 2e 37 35 20 7b 69  xpr expr-1.75 {i
1330: 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d  1=NULL, i2=NULL}
1340: 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 3d 3d 69   {coalesce(i1==i
1350: 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  2,99)} 99.test_e
1360: 78 70 72 20 65 78 70 72 2d 31 2e 37 36 20 7b 69  xpr expr-1.76 {i
1370: 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d  1=NULL, i2=NULL}
1380: 20 7b 63 6f 61 6c 65 73 63 65 28 6e 6f 74 20 69   {coalesce(not i
1390: 31 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  1,99)} 99.test_e
13a0: 78 70 72 20 65 78 70 72 2d 31 2e 37 37 20 7b 69  xpr expr-1.77 {i
13b0: 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d  1=NULL, i2=NULL}
13c0: 20 7b 63 6f 61 6c 65 73 63 65 28 2d 69 31 2c 39   {coalesce(-i1,9
13d0: 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72  9)} 99.test_expr
13e0: 20 65 78 70 72 2d 31 2e 37 38 20 7b 69 31 3d 4e   expr-1.78 {i1=N
13f0: 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63  ULL, i2=NULL} {c
1400: 6f 61 6c 65 73 63 65 28 69 31 20 49 53 20 4e 55  oalesce(i1 IS NU
1410: 4c 4c 20 41 4e 44 20 69 32 3d 35 2c 39 39 29 7d  LL AND i2=5,99)}
1420: 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78   99.test_expr ex
1430: 70 72 2d 31 2e 37 39 20 7b 69 31 3d 4e 55 4c 4c  pr-1.79 {i1=NULL
1440: 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , i2=NULL} {coal
1450: 65 73 63 65 28 69 31 20 49 53 20 4e 55 4c 4c 20  esce(i1 IS NULL 
1460: 4f 52 20 69 32 3d 35 2c 39 39 29 7d 20 31 0a 74  OR i2=5,99)} 1.t
1470: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
1480: 38 30 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d  80 {i1=NULL, i2=
1490: 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28  NULL} {coalesce(
14a0: 69 31 3d 35 20 41 4e 44 20 69 32 20 49 53 20 4e  i1=5 AND i2 IS N
14b0: 55 4c 4c 2c 39 39 29 7d 20 39 39 0a 74 65 73 74  ULL,99)} 99.test
14c0: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 38 31 20  _expr expr-1.81 
14d0: 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c  {i1=NULL, i2=NUL
14e0: 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 3d  L} {coalesce(i1=
14f0: 35 20 4f 52 20 69 32 20 49 53 20 4e 55 4c 4c 2c  5 OR i2 IS NULL,
1500: 39 39 29 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  99)} 1.test_expr
1510: 20 65 78 70 72 2d 31 2e 38 32 20 7b 69 31 3d 4e   expr-1.82 {i1=N
1520: 55 4c 4c 2c 20 69 32 3d 33 7d 20 7b 63 6f 61 6c  ULL, i2=3} {coal
1530: 65 73 63 65 28 6d 69 6e 28 69 31 2c 69 32 2c 31  esce(min(i1,i2,1
1540: 29 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  ),99)} 99.test_e
1550: 78 70 72 20 65 78 70 72 2d 31 2e 38 33 20 7b 69  xpr expr-1.83 {i
1560: 31 3d 4e 55 4c 4c 2c 20 69 32 3d 33 7d 20 7b 63  1=NULL, i2=3} {c
1570: 6f 61 6c 65 73 63 65 28 6d 61 78 28 69 31 2c 69  oalesce(max(i1,i
1580: 32 2c 31 29 2c 39 39 29 7d 20 39 39 0a 74 65 73  2,1),99)} 99.tes
1590: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 38 34  t_expr expr-1.84
15a0: 20 7b 69 31 3d 33 2c 20 69 32 3d 4e 55 4c 4c 7d   {i1=3, i2=NULL}
15b0: 20 7b 63 6f 61 6c 65 73 63 65 28 6d 69 6e 28 69   {coalesce(min(i
15c0: 31 2c 69 32 2c 31 29 2c 39 39 29 7d 20 39 39 0a  1,i2,1),99)} 99.
15d0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
15e0: 2e 38 35 20 7b 69 31 3d 33 2c 20 69 32 3d 4e 55  .85 {i1=3, i2=NU
15f0: 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 6d 61  LL} {coalesce(ma
1600: 78 28 69 31 2c 69 32 2c 31 29 2c 39 39 29 7d 20  x(i1,i2,1),99)} 
1610: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  99.test_expr exp
1620: 72 2d 31 2e 38 36 20 7b 69 31 3d 33 2c 20 69 32  r-1.86 {i1=3, i2
1630: 3d 38 7d 20 7b 35 20 62 65 74 77 65 65 6e 20 69  =8} {5 between i
1640: 31 20 61 6e 64 20 69 32 7d 20 31 0a 74 65 73 74  1 and i2} 1.test
1650: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 38 37 20  _expr expr-1.87 
1660: 7b 69 31 3d 33 2c 20 69 32 3d 38 7d 20 7b 35 20  {i1=3, i2=8} {5 
1670: 6e 6f 74 20 62 65 74 77 65 65 6e 20 69 31 20 61  not between i1 a
1680: 6e 64 20 69 32 7d 20 30 0a 74 65 73 74 5f 65 78  nd i2} 0.test_ex
1690: 70 72 20 65 78 70 72 2d 31 2e 38 38 20 7b 69 31  pr expr-1.88 {i1
16a0: 3d 33 2c 20 69 32 3d 38 7d 20 7b 35 35 20 62 65  =3, i2=8} {55 be
16b0: 74 77 65 65 6e 20 69 31 20 61 6e 64 20 69 32 7d  tween i1 and i2}
16c0: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
16d0: 72 2d 31 2e 38 39 20 7b 69 31 3d 33 2c 20 69 32  r-1.89 {i1=3, i2
16e0: 3d 38 7d 20 7b 35 35 20 6e 6f 74 20 62 65 74 77  =8} {55 not betw
16f0: 65 65 6e 20 69 31 20 61 6e 64 20 69 32 7d 20 31  een i1 and i2} 1
1700: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1710: 31 2e 39 30 20 7b 69 31 3d 33 2c 20 69 32 3d 4e  1.90 {i1=3, i2=N
1720: 55 4c 4c 7d 20 7b 35 20 62 65 74 77 65 65 6e 20  ULL} {5 between 
1730: 69 31 20 61 6e 64 20 69 32 7d 20 7b 7b 7d 7d 0a  i1 and i2} {{}}.
1740: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
1750: 2e 39 31 20 7b 69 31 3d 33 2c 20 69 32 3d 4e 55  .91 {i1=3, i2=NU
1760: 4c 4c 7d 20 7b 35 20 6e 6f 74 20 62 65 74 77 65  LL} {5 not betwe
1770: 65 6e 20 69 31 20 61 6e 64 20 69 32 7d 20 7b 7b  en i1 and i2} {{
1780: 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  }}.test_expr exp
1790: 72 2d 31 2e 39 32 20 7b 69 31 3d 33 2c 20 69 32  r-1.92 {i1=3, i2
17a0: 3d 4e 55 4c 4c 7d 20 7b 32 20 62 65 74 77 65 65  =NULL} {2 betwee
17b0: 6e 20 69 31 20 61 6e 64 20 69 32 7d 20 30 0a 74  n i1 and i2} 0.t
17c0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
17d0: 39 33 20 7b 69 31 3d 33 2c 20 69 32 3d 4e 55 4c  93 {i1=3, i2=NUL
17e0: 4c 7d 20 7b 32 20 6e 6f 74 20 62 65 74 77 65 65  L} {2 not betwee
17f0: 6e 20 69 31 20 61 6e 64 20 69 32 7d 20 31 0a 74  n i1 and i2} 1.t
1800: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
1810: 39 34 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d  94 {i1=NULL, i2=
1820: 38 7d 20 7b 32 20 62 65 74 77 65 65 6e 20 69 31  8} {2 between i1
1830: 20 61 6e 64 20 69 32 7d 20 7b 7b 7d 7d 0a 74 65   and i2} {{}}.te
1840: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 39  st_expr expr-1.9
1850: 35 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 38  5 {i1=NULL, i2=8
1860: 7d 20 7b 32 20 6e 6f 74 20 62 65 74 77 65 65 6e  } {2 not between
1870: 20 69 31 20 61 6e 64 20 69 32 7d 20 7b 7b 7d 7d   i1 and i2} {{}}
1880: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1890: 31 2e 39 34 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.94 {i1=NULL, i
18a0: 32 3d 38 7d 20 7b 35 35 20 62 65 74 77 65 65 6e  2=8} {55 between
18b0: 20 69 31 20 61 6e 64 20 69 32 7d 20 30 0a 74 65   i1 and i2} 0.te
18c0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 39  st_expr expr-1.9
18d0: 35 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 38  5 {i1=NULL, i2=8
18e0: 7d 20 7b 35 35 20 6e 6f 74 20 62 65 74 77 65 65  } {55 not betwee
18f0: 6e 20 69 31 20 61 6e 64 20 69 32 7d 20 31 0a 74  n i1 and i2} 1.t
1900: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
1910: 39 36 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d  96 {i1=NULL, i2=
1920: 33 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 3c  3} {coalesce(i1<
1930: 3c 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74  <i2,99)} 99.test
1940: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 39 37 20  _expr expr-1.97 
1950: 7b 69 31 3d 33 32 2c 20 69 32 3d 4e 55 4c 4c 7d  {i1=32, i2=NULL}
1960: 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 3e 3e 69   {coalesce(i1>>i
1970: 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  2,99)} 99.test_e
1980: 78 70 72 20 65 78 70 72 2d 31 2e 39 38 20 7b 69  xpr expr-1.98 {i
1990: 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d  1=NULL, i2=NULL}
19a0: 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 7c 69 32   {coalesce(i1|i2
19b0: 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78  ,99)} 99.test_ex
19c0: 70 72 20 65 78 70 72 2d 31 2e 39 39 20 7b 69 31  pr expr-1.99 {i1
19d0: 3d 33 32 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63  =32, i2=NULL} {c
19e0: 6f 61 6c 65 73 63 65 28 69 31 26 69 32 2c 39 39  oalesce(i1&i2,99
19f0: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
1a00: 65 78 70 72 2d 31 2e 31 30 30 20 7b 69 31 3d 31  expr-1.100 {i1=1
1a10: 2c 20 69 32 3d 27 27 7d 20 7b 69 31 3d 69 32 7d  , i2=''} {i1=i2}
1a20: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
1a30: 72 2d 31 2e 31 30 31 20 7b 69 31 3d 30 2c 20 69  r-1.101 {i1=0, i
1a40: 32 3d 27 27 7d 20 7b 69 31 3d 69 32 7d 20 30 0a  2=''} {i1=i2} 0.
1a50: 0a 23 20 43 68 65 63 6b 20 66 6f 72 20 70 72 6f  .# Check for pro
1a60: 70 65 72 20 68 61 6e 64 6c 69 6e 67 20 6f 66 20  per handling of 
1a70: 36 34 2d 62 69 74 20 69 6e 74 65 67 65 72 20 76  64-bit integer v
1a80: 61 6c 75 65 73 2e 0a 23 0a 74 65 73 74 5f 65 78  alues..#.test_ex
1a90: 70 72 20 65 78 70 72 2d 31 2e 31 30 32 20 7b 69  pr expr-1.102 {i
1aa0: 31 3d 34 30 2c 20 69 32 3d 31 7d 20 7b 69 32 3c  1=40, i2=1} {i2<
1ab0: 3c 69 31 7d 20 31 30 39 39 35 31 31 36 32 37 37  <i1} 10995116277
1ac0: 37 36 0a 0a 0a 74 65 73 74 5f 65 78 70 72 20 65  76...test_expr e
1ad0: 78 70 72 2d 32 2e 31 20 7b 72 31 3d 31 2e 32 33  xpr-2.1 {r1=1.23
1ae0: 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 31 2b 72  , r2=2.34} {r1+r
1af0: 32 7d 20 33 2e 35 37 0a 74 65 73 74 5f 65 78 70  2} 3.57.test_exp
1b00: 72 20 65 78 70 72 2d 32 2e 32 20 7b 72 31 3d 31  r expr-2.2 {r1=1
1b10: 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72  .23, r2=2.34} {r
1b20: 31 2d 72 32 7d 20 2d 31 2e 31 31 0a 74 65 73 74  1-r2} -1.11.test
1b30: 5f 65 78 70 72 20 65 78 70 72 2d 32 2e 33 20 7b  _expr expr-2.3 {
1b40: 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33 34  r1=1.23, r2=2.34
1b50: 7d 20 7b 72 31 2a 72 32 7d 20 32 2e 38 37 38 32  } {r1*r2} 2.8782
1b60: 0a 73 65 74 20 74 63 6c 5f 70 72 65 63 69 73 69  .set tcl_precisi
1b70: 6f 6e 20 31 35 0a 74 65 73 74 5f 65 78 70 72 20  on 15.test_expr 
1b80: 65 78 70 72 2d 32 2e 34 20 7b 72 31 3d 31 2e 32  expr-2.4 {r1=1.2
1b90: 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 31 2f  3, r2=2.34} {r1/
1ba0: 72 32 7d 20 30 2e 35 32 35 36 34 31 30 32 35 36  r2} 0.5256410256
1bb0: 34 31 30 32 36 0a 74 65 73 74 5f 65 78 70 72 20  41026.test_expr 
1bc0: 65 78 70 72 2d 32 2e 35 20 7b 72 31 3d 31 2e 32  expr-2.5 {r1=1.2
1bd0: 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 2f  3, r2=2.34} {r2/
1be0: 72 31 7d 20 31 2e 39 30 32 34 33 39 30 32 34 33  r1} 1.9024390243
1bf0: 39 30 32 34 0a 74 65 73 74 5f 65 78 70 72 20 65  9024.test_expr e
1c00: 78 70 72 2d 32 2e 36 20 7b 72 31 3d 31 2e 32 33  xpr-2.6 {r1=1.23
1c10: 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 3c 72  , r2=2.34} {r2<r
1c20: 31 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  1} 0.test_expr e
1c30: 78 70 72 2d 32 2e 37 20 7b 72 31 3d 31 2e 32 33  xpr-2.7 {r1=1.23
1c40: 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 3c 3d  , r2=2.34} {r2<=
1c50: 72 31 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  r1} 0.test_expr 
1c60: 65 78 70 72 2d 32 2e 38 20 7b 72 31 3d 31 2e 32  expr-2.8 {r1=1.2
1c70: 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 3e  3, r2=2.34} {r2>
1c80: 72 31 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  r1} 1.test_expr 
1c90: 65 78 70 72 2d 32 2e 39 20 7b 72 31 3d 31 2e 32  expr-2.9 {r1=1.2
1ca0: 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 3e  3, r2=2.34} {r2>
1cb0: 3d 72 31 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  =r1} 1.test_expr
1cc0: 20 65 78 70 72 2d 32 2e 31 30 20 7b 72 31 3d 31   expr-2.10 {r1=1
1cd0: 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72  .23, r2=2.34} {r
1ce0: 32 21 3d 72 31 7d 20 31 0a 74 65 73 74 5f 65 78  2!=r1} 1.test_ex
1cf0: 70 72 20 65 78 70 72 2d 32 2e 31 31 20 7b 72 31  pr expr-2.11 {r1
1d00: 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20  =1.23, r2=2.34} 
1d10: 7b 72 32 3d 72 31 7d 20 30 0a 74 65 73 74 5f 65  {r2=r1} 0.test_e
1d20: 78 70 72 20 65 78 70 72 2d 32 2e 31 32 20 7b 72  xpr expr-2.12 {r
1d30: 31 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d  1=1.23, r2=2.34}
1d40: 20 7b 72 32 3c 3e 72 31 7d 20 31 0a 74 65 73 74   {r2<>r1} 1.test
1d50: 5f 65 78 70 72 20 65 78 70 72 2d 32 2e 31 33 20  _expr expr-2.13 
1d60: 7b 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33  {r1=1.23, r2=2.3
1d70: 34 7d 20 7b 72 32 3d 3d 72 31 7d 20 30 0a 74 65  4} {r2==r1} 0.te
1d80: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e 31  st_expr expr-2.1
1d90: 34 20 7b 72 31 3d 32 2e 33 34 2c 20 72 32 3d 32  4 {r1=2.34, r2=2
1da0: 2e 33 34 7d 20 7b 72 32 3c 72 31 7d 20 30 0a 74  .34} {r2<r1} 0.t
1db0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e  est_expr expr-2.
1dc0: 31 35 20 7b 72 31 3d 32 2e 33 34 2c 20 72 32 3d  15 {r1=2.34, r2=
1dd0: 32 2e 33 34 7d 20 7b 72 32 3c 3d 72 31 7d 20 31  2.34} {r2<=r1} 1
1de0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1df0: 32 2e 31 36 20 7b 72 31 3d 32 2e 33 34 2c 20 72  2.16 {r1=2.34, r
1e00: 32 3d 32 2e 33 34 7d 20 7b 72 32 3e 72 31 7d 20  2=2.34} {r2>r1} 
1e10: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
1e20: 2d 32 2e 31 37 20 7b 72 31 3d 32 2e 33 34 2c 20  -2.17 {r1=2.34, 
1e30: 72 32 3d 32 2e 33 34 7d 20 7b 72 32 3e 3d 72 31  r2=2.34} {r2>=r1
1e40: 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 1.test_expr ex
1e50: 70 72 2d 32 2e 31 38 20 7b 72 31 3d 32 2e 33 34  pr-2.18 {r1=2.34
1e60: 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 21 3d  , r2=2.34} {r2!=
1e70: 72 31 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  r1} 0.test_expr 
1e80: 65 78 70 72 2d 32 2e 31 39 20 7b 72 31 3d 32 2e  expr-2.19 {r1=2.
1e90: 33 34 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32  34, r2=2.34} {r2
1ea0: 3d 72 31 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  =r1} 1.test_expr
1eb0: 20 65 78 70 72 2d 32 2e 32 30 20 7b 72 31 3d 32   expr-2.20 {r1=2
1ec0: 2e 33 34 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72  .34, r2=2.34} {r
1ed0: 32 3c 3e 72 31 7d 20 30 0a 74 65 73 74 5f 65 78  2<>r1} 0.test_ex
1ee0: 70 72 20 65 78 70 72 2d 32 2e 32 31 20 7b 72 31  pr expr-2.21 {r1
1ef0: 3d 32 2e 33 34 2c 20 72 32 3d 32 2e 33 34 7d 20  =2.34, r2=2.34} 
1f00: 7b 72 32 3d 3d 72 31 7d 20 31 0a 74 65 73 74 5f  {r2==r1} 1.test_
1f10: 65 78 70 72 20 65 78 70 72 2d 32 2e 32 32 20 7b  expr expr-2.22 {
1f20: 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33 34  r1=1.23, r2=2.34
1f30: 7d 20 7b 6d 69 6e 28 72 31 2c 72 32 2c 72 31 2b  } {min(r1,r2,r1+
1f40: 72 32 2c 72 31 2d 72 32 29 7d 20 7b 2d 31 2e 31  r2,r1-r2)} {-1.1
1f50: 31 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  1}.test_expr exp
1f60: 72 2d 32 2e 32 33 20 7b 72 31 3d 31 2e 32 33 2c  r-2.23 {r1=1.23,
1f70: 20 72 32 3d 32 2e 33 34 7d 20 7b 6d 61 78 28 72   r2=2.34} {max(r
1f80: 31 2c 72 32 2c 72 31 2b 72 32 2c 72 31 2d 72 32  1,r2,r1+r2,r1-r2
1f90: 29 7d 20 7b 33 2e 35 37 7d 0a 74 65 73 74 5f 65  )} {3.57}.test_e
1fa0: 78 70 72 20 65 78 70 72 2d 32 2e 32 34 20 7b 72  xpr expr-2.24 {r
1fb0: 31 3d 32 35 2e 30 2c 20 72 32 3d 31 31 2e 30 7d  1=25.0, r2=11.0}
1fc0: 20 7b 72 31 25 72 32 7d 20 33 0a 74 65 73 74 5f   {r1%r2} 3.test_
1fd0: 65 78 70 72 20 65 78 70 72 2d 32 2e 32 35 20 7b  expr expr-2.25 {
1fe0: 72 31 3d 31 2e 32 33 2c 20 72 32 3d 4e 55 4c 4c  r1=1.23, r2=NULL
1ff0: 7d 20 7b 63 6f 61 6c 65 73 63 65 28 72 31 2b 72  } {coalesce(r1+r
2000: 32 2c 39 39 2e 30 29 7d 20 39 39 0a 0a 74 65 73  2,99.0)} 99..tes
2010: 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 31 20  t_expr expr-3.1 
2020: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 78  {t1='abc', t2='x
2030: 79 7a 27 7d 20 7b 74 31 3c 74 32 7d 20 31 0a 74  yz'} {t1<t2} 1.t
2040: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e  est_expr expr-3.
2050: 32 20 7b 74 31 3d 27 78 79 7a 27 2c 20 74 32 3d  2 {t1='xyz', t2=
2060: 27 61 62 63 27 7d 20 7b 74 31 3c 74 32 7d 20 30  'abc'} {t1<t2} 0
2070: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
2080: 33 2e 33 20 7b 74 31 3d 27 61 62 63 27 2c 20 74  3.3 {t1='abc', t
2090: 32 3d 27 61 62 63 27 7d 20 7b 74 31 3c 74 32 7d  2='abc'} {t1<t2}
20a0: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
20b0: 72 2d 33 2e 34 20 7b 74 31 3d 27 61 62 63 27 2c  r-3.4 {t1='abc',
20c0: 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74 31 3c 3d   t2='xyz'} {t1<=
20d0: 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  t2} 1.test_expr 
20e0: 65 78 70 72 2d 33 2e 35 20 7b 74 31 3d 27 78 79  expr-3.5 {t1='xy
20f0: 7a 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74  z', t2='abc'} {t
2100: 31 3c 3d 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  1<=t2} 0.test_ex
2110: 70 72 20 65 78 70 72 2d 33 2e 36 20 7b 74 31 3d  pr expr-3.6 {t1=
2120: 27 61 62 63 27 2c 20 74 32 3d 27 61 62 63 27 7d  'abc', t2='abc'}
2130: 20 7b 74 31 3c 3d 74 32 7d 20 31 0a 74 65 73 74   {t1<=t2} 1.test
2140: 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 37 20 7b  _expr expr-3.7 {
2150: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 78 79  t1='abc', t2='xy
2160: 7a 27 7d 20 7b 74 31 3e 74 32 7d 20 30 0a 74 65  z'} {t1>t2} 0.te
2170: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 38  st_expr expr-3.8
2180: 20 7b 74 31 3d 27 78 79 7a 27 2c 20 74 32 3d 27   {t1='xyz', t2='
2190: 61 62 63 27 7d 20 7b 74 31 3e 74 32 7d 20 31 0a  abc'} {t1>t2} 1.
21a0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33  test_expr expr-3
21b0: 2e 39 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  .9 {t1='abc', t2
21c0: 3d 27 61 62 63 27 7d 20 7b 74 31 3e 74 32 7d 20  ='abc'} {t1>t2} 
21d0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
21e0: 2d 33 2e 31 30 20 7b 74 31 3d 27 61 62 63 27 2c  -3.10 {t1='abc',
21f0: 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74 31 3e 3d   t2='xyz'} {t1>=
2200: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
2210: 65 78 70 72 2d 33 2e 31 31 20 7b 74 31 3d 27 78  expr-3.11 {t1='x
2220: 79 7a 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b  yz', t2='abc'} {
2230: 74 31 3e 3d 74 32 7d 20 31 0a 74 65 73 74 5f 65  t1>=t2} 1.test_e
2240: 78 70 72 20 65 78 70 72 2d 33 2e 31 32 20 7b 74  xpr expr-3.12 {t
2250: 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 62 63  1='abc', t2='abc
2260: 27 7d 20 7b 74 31 3e 3d 74 32 7d 20 31 0a 74 65  '} {t1>=t2} 1.te
2270: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 31  st_expr expr-3.1
2280: 33 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  3 {t1='abc', t2=
2290: 27 78 79 7a 27 7d 20 7b 74 31 3d 74 32 7d 20 30  'xyz'} {t1=t2} 0
22a0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
22b0: 33 2e 31 34 20 7b 74 31 3d 27 78 79 7a 27 2c 20  3.14 {t1='xyz', 
22c0: 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 3d 74 32  t2='abc'} {t1=t2
22d0: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
22e0: 70 72 2d 33 2e 31 35 20 7b 74 31 3d 27 61 62 63  pr-3.15 {t1='abc
22f0: 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31  ', t2='abc'} {t1
2300: 3d 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  =t2} 1.test_expr
2310: 20 65 78 70 72 2d 33 2e 31 36 20 7b 74 31 3d 27   expr-3.16 {t1='
2320: 61 62 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20  abc', t2='xyz'} 
2330: 7b 74 31 3d 3d 74 32 7d 20 30 0a 74 65 73 74 5f  {t1==t2} 0.test_
2340: 65 78 70 72 20 65 78 70 72 2d 33 2e 31 37 20 7b  expr expr-3.17 {
2350: 74 31 3d 27 78 79 7a 27 2c 20 74 32 3d 27 61 62  t1='xyz', t2='ab
2360: 63 27 7d 20 7b 74 31 3d 3d 74 32 7d 20 30 0a 74  c'} {t1==t2} 0.t
2370: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e  est_expr expr-3.
2380: 31 38 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  18 {t1='abc', t2
2390: 3d 27 61 62 63 27 7d 20 7b 74 31 3d 3d 74 32 7d  ='abc'} {t1==t2}
23a0: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
23b0: 72 2d 33 2e 31 39 20 7b 74 31 3d 27 61 62 63 27  r-3.19 {t1='abc'
23c0: 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74 31 3c  , t2='xyz'} {t1<
23d0: 3e 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  >t2} 1.test_expr
23e0: 20 65 78 70 72 2d 33 2e 32 30 20 7b 74 31 3d 27   expr-3.20 {t1='
23f0: 78 79 7a 27 2c 20 74 32 3d 27 61 62 63 27 7d 20  xyz', t2='abc'} 
2400: 7b 74 31 3c 3e 74 32 7d 20 31 0a 74 65 73 74 5f  {t1<>t2} 1.test_
2410: 65 78 70 72 20 65 78 70 72 2d 33 2e 32 31 20 7b  expr expr-3.21 {
2420: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 62  t1='abc', t2='ab
2430: 63 27 7d 20 7b 74 31 3c 3e 74 32 7d 20 30 0a 74  c'} {t1<>t2} 0.t
2440: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e  est_expr expr-3.
2450: 32 32 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  22 {t1='abc', t2
2460: 3d 27 78 79 7a 27 7d 20 7b 74 31 21 3d 74 32 7d  ='xyz'} {t1!=t2}
2470: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
2480: 72 2d 33 2e 32 33 20 7b 74 31 3d 27 78 79 7a 27  r-3.23 {t1='xyz'
2490: 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 21  , t2='abc'} {t1!
24a0: 3d 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  =t2} 1.test_expr
24b0: 20 65 78 70 72 2d 33 2e 32 34 20 7b 74 31 3d 27   expr-3.24 {t1='
24c0: 61 62 63 27 2c 20 74 32 3d 27 61 62 63 27 7d 20  abc', t2='abc'} 
24d0: 7b 74 31 21 3d 74 32 7d 20 30 0a 74 65 73 74 5f  {t1!=t2} 0.test_
24e0: 65 78 70 72 20 65 78 70 72 2d 33 2e 32 35 20 7b  expr expr-3.25 {
24f0: 74 31 3d 4e 55 4c 4c 2c 20 74 32 3d 27 68 69 27  t1=NULL, t2='hi'
2500: 7d 20 7b 74 31 20 69 73 6e 75 6c 6c 7d 20 31 0a  } {t1 isnull} 1.
2510: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33  test_expr expr-3
2520: 2e 32 35 62 20 7b 74 31 3d 4e 55 4c 4c 2c 20 74  .25b {t1=NULL, t
2530: 32 3d 27 68 69 27 7d 20 7b 74 31 20 69 73 20 6e  2='hi'} {t1 is n
2540: 75 6c 6c 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  ull} 1.test_expr
2550: 20 65 78 70 72 2d 33 2e 32 36 20 7b 74 31 3d 4e   expr-3.26 {t1=N
2560: 55 4c 4c 2c 20 74 32 3d 27 68 69 27 7d 20 7b 74  ULL, t2='hi'} {t
2570: 32 20 69 73 6e 75 6c 6c 7d 20 30 0a 74 65 73 74  2 isnull} 0.test
2580: 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 32 37 20  _expr expr-3.27 
2590: 7b 74 31 3d 4e 55 4c 4c 2c 20 74 32 3d 27 68 69  {t1=NULL, t2='hi
25a0: 27 7d 20 7b 74 31 20 6e 6f 74 6e 75 6c 6c 7d 20  '} {t1 notnull} 
25b0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
25c0: 2d 33 2e 32 38 20 7b 74 31 3d 4e 55 4c 4c 2c 20  -3.28 {t1=NULL, 
25d0: 74 32 3d 27 68 69 27 7d 20 7b 74 32 20 6e 6f 74  t2='hi'} {t2 not
25e0: 6e 75 6c 6c 7d 20 31 0a 74 65 73 74 5f 65 78 70  null} 1.test_exp
25f0: 72 20 65 78 70 72 2d 33 2e 32 38 62 20 7b 74 31  r expr-3.28b {t1
2600: 3d 4e 55 4c 4c 2c 20 74 32 3d 27 68 69 27 7d 20  =NULL, t2='hi'} 
2610: 7b 74 32 20 69 73 20 6e 6f 74 20 6e 75 6c 6c 7d  {t2 is not null}
2620: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
2630: 72 2d 33 2e 32 39 20 7b 74 31 3d 27 78 79 7a 27  r-3.29 {t1='xyz'
2640: 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 7c  , t2='abc'} {t1|
2650: 7c 74 32 7d 20 7b 78 79 7a 61 62 63 7d 0a 74 65  |t2} {xyzabc}.te
2660: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 33  st_expr expr-3.3
2670: 30 20 7b 74 31 3d 4e 55 4c 4c 2c 20 74 32 3d 27  0 {t1=NULL, t2='
2680: 61 62 63 27 7d 20 7b 74 31 7c 7c 74 32 7d 20 7b  abc'} {t1||t2} {
2690: 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78  {}}.test_expr ex
26a0: 70 72 2d 33 2e 33 31 20 7b 74 31 3d 27 78 79 7a  pr-3.31 {t1='xyz
26b0: 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 74 31 7c  ', t2=NULL} {t1|
26c0: 7c 74 32 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65  |t2} {{}}.test_e
26d0: 78 70 72 20 65 78 70 72 2d 33 2e 33 32 20 7b 74  xpr expr-3.32 {t
26e0: 31 3d 27 78 79 7a 27 2c 20 74 32 3d 27 61 62 63  1='xyz', t2='abc
26f0: 27 7d 20 7b 74 31 7c 7c 27 20 68 69 20 27 7c 7c  '} {t1||' hi '||
2700: 74 32 7d 20 7b 7b 78 79 7a 20 68 69 20 61 62 63  t2} {{xyz hi abc
2710: 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 70 78  }}.test_expr epx
2720: 72 2d 33 2e 33 33 20 7b 74 31 3d 27 61 62 63 27  r-3.33 {t1='abc'
2730: 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , t2=NULL} {coal
2740: 65 73 63 65 28 74 31 3c 74 32 2c 39 39 29 7d 20  esce(t1<t2,99)} 
2750: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 70 78  99.test_expr epx
2760: 72 2d 33 2e 33 34 20 7b 74 31 3d 27 61 62 63 27  r-3.34 {t1='abc'
2770: 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , t2=NULL} {coal
2780: 65 73 63 65 28 74 32 3c 74 31 2c 39 39 29 7d 20  esce(t2<t1,99)} 
2790: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 70 78  99.test_expr epx
27a0: 72 2d 33 2e 33 35 20 7b 74 31 3d 27 61 62 63 27  r-3.35 {t1='abc'
27b0: 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , t2=NULL} {coal
27c0: 65 73 63 65 28 74 31 3e 74 32 2c 39 39 29 7d 20  esce(t1>t2,99)} 
27d0: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 70 78  99.test_expr epx
27e0: 72 2d 33 2e 33 36 20 7b 74 31 3d 27 61 62 63 27  r-3.36 {t1='abc'
27f0: 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , t2=NULL} {coal
2800: 65 73 63 65 28 74 32 3e 74 31 2c 39 39 29 7d 20  esce(t2>t1,99)} 
2810: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 70 78  99.test_expr epx
2820: 72 2d 33 2e 33 37 20 7b 74 31 3d 27 61 62 63 27  r-3.37 {t1='abc'
2830: 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , t2=NULL} {coal
2840: 65 73 63 65 28 74 31 3c 3d 74 32 2c 39 39 29 7d  esce(t1<=t2,99)}
2850: 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 70   99.test_expr ep
2860: 78 72 2d 33 2e 33 38 20 7b 74 31 3d 27 61 62 63  xr-3.38 {t1='abc
2870: 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61  ', t2=NULL} {coa
2880: 6c 65 73 63 65 28 74 32 3c 3d 74 31 2c 39 39 29  lesce(t2<=t1,99)
2890: 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65  } 99.test_expr e
28a0: 70 78 72 2d 33 2e 33 39 20 7b 74 31 3d 27 61 62  pxr-3.39 {t1='ab
28b0: 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63 6f  c', t2=NULL} {co
28c0: 61 6c 65 73 63 65 28 74 31 3e 3d 74 32 2c 39 39  alesce(t1>=t2,99
28d0: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
28e0: 65 70 78 72 2d 33 2e 34 30 20 7b 74 31 3d 27 61  epxr-3.40 {t1='a
28f0: 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63  bc', t2=NULL} {c
2900: 6f 61 6c 65 73 63 65 28 74 32 3e 3d 74 31 2c 39  oalesce(t2>=t1,9
2910: 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72  9)} 99.test_expr
2920: 20 65 70 78 72 2d 33 2e 34 31 20 7b 74 31 3d 27   epxr-3.41 {t1='
2930: 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b  abc', t2=NULL} {
2940: 63 6f 61 6c 65 73 63 65 28 74 31 3d 3d 74 32 2c  coalesce(t1==t2,
2950: 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70  99)} 99.test_exp
2960: 72 20 65 70 78 72 2d 33 2e 34 32 20 7b 74 31 3d  r epxr-3.42 {t1=
2970: 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20  'abc', t2=NULL} 
2980: 7b 63 6f 61 6c 65 73 63 65 28 74 32 3d 3d 74 31  {coalesce(t2==t1
2990: 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78  ,99)} 99.test_ex
29a0: 70 72 20 65 70 78 72 2d 33 2e 34 33 20 7b 74 31  pr epxr-3.43 {t1
29b0: 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d  ='abc', t2=NULL}
29c0: 20 7b 63 6f 61 6c 65 73 63 65 28 74 31 21 3d 74   {coalesce(t1!=t
29d0: 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  2,99)} 99.test_e
29e0: 78 70 72 20 65 70 78 72 2d 33 2e 34 34 20 7b 74  xpr epxr-3.44 {t
29f0: 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c  1='abc', t2=NULL
2a00: 7d 20 7b 63 6f 61 6c 65 73 63 65 28 74 32 21 3d  } {coalesce(t2!=
2a10: 74 31 2c 39 39 29 7d 20 39 39 0a 0a 74 65 73 74  t1,99)} 99..test
2a20: 5f 65 78 70 72 20 65 78 70 72 2d 34 2e 31 20 7b  _expr expr-4.1 {
2a30: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 41 62  t1='abc', t2='Ab
2a40: 63 27 7d 20 7b 74 31 3c 74 32 7d 20 30 0a 74 65  c'} {t1<t2} 0.te
2a50: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 34 2e 32  st_expr expr-4.2
2a60: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27   {t1='abc', t2='
2a70: 41 62 63 27 7d 20 7b 74 31 3e 74 32 7d 20 31 0a  Abc'} {t1>t2} 1.
2a80: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 34  test_expr expr-4
2a90: 2e 33 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  .3 {t1='abc', t2
2aa0: 3d 27 42 62 63 27 7d 20 7b 74 31 3c 74 32 7d 20  ='Bbc'} {t1<t2} 
2ab0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
2ac0: 2d 34 2e 34 20 7b 74 31 3d 27 61 62 63 27 2c 20  -4.4 {t1='abc', 
2ad0: 74 32 3d 27 42 62 63 27 7d 20 7b 74 31 3e 74 32  t2='Bbc'} {t1>t2
2ae0: 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 1.test_expr ex
2af0: 70 72 2d 34 2e 35 20 7b 74 31 3d 27 30 27 2c 20  pr-4.5 {t1='0', 
2b00: 74 32 3d 27 30 2e 30 27 7d 20 7b 74 31 3d 3d 74  t2='0.0'} {t1==t
2b10: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
2b20: 78 70 72 2d 34 2e 36 20 7b 74 31 3d 27 30 2e 30  xpr-4.6 {t1='0.0
2b30: 30 30 27 2c 20 74 32 3d 27 30 2e 30 27 7d 20 7b  00', t2='0.0'} {
2b40: 74 31 3d 3d 74 32 7d 20 30 0a 74 65 73 74 5f 65  t1==t2} 0.test_e
2b50: 78 70 72 20 65 78 70 72 2d 34 2e 37 20 7b 74 31  xpr expr-4.7 {t1
2b60: 3d 27 20 30 2e 30 30 30 27 2c 20 74 32 3d 27 20  =' 0.000', t2=' 
2b70: 30 2e 30 27 7d 20 7b 74 31 3d 3d 74 32 7d 20 30  0.0'} {t1==t2} 0
2b80: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
2b90: 34 2e 38 20 7b 74 31 3d 27 30 2e 30 27 2c 20 74  4.8 {t1='0.0', t
2ba0: 32 3d 27 61 62 63 27 7d 20 7b 74 31 3c 74 32 7d  2='abc'} {t1<t2}
2bb0: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
2bc0: 72 2d 34 2e 39 20 7b 74 31 3d 27 30 2e 30 27 2c  r-4.9 {t1='0.0',
2bd0: 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 3d 3d   t2='abc'} {t1==
2be0: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
2bf0: 65 78 70 72 2d 34 2e 31 30 20 7b 72 31 3d 27 30  expr-4.10 {r1='0
2c00: 2e 30 27 2c 20 72 32 3d 27 61 62 63 27 7d 20 7b  .0', r2='abc'} {
2c10: 72 31 3e 72 32 7d 20 30 0a 74 65 73 74 5f 65 78  r1>r2} 0.test_ex
2c20: 70 72 20 65 78 70 72 2d 34 2e 31 31 20 7b 72 31  pr expr-4.11 {r1
2c30: 3d 27 61 62 63 27 2c 20 72 32 3d 27 41 62 63 27  ='abc', r2='Abc'
2c40: 7d 20 7b 72 31 3c 72 32 7d 20 30 0a 74 65 73 74  } {r1<r2} 0.test
2c50: 5f 65 78 70 72 20 65 78 70 72 2d 34 2e 31 32 20  _expr expr-4.12 
2c60: 7b 72 31 3d 27 61 62 63 27 2c 20 72 32 3d 27 41  {r1='abc', r2='A
2c70: 62 63 27 7d 20 7b 72 31 3e 72 32 7d 20 31 0a 74  bc'} {r1>r2} 1.t
2c80: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 34 2e  est_expr expr-4.
2c90: 31 33 20 7b 72 31 3d 27 61 62 63 27 2c 20 72 32  13 {r1='abc', r2
2ca0: 3d 27 42 62 63 27 7d 20 7b 72 31 3c 72 32 7d 20  ='Bbc'} {r1<r2} 
2cb0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
2cc0: 2d 34 2e 31 34 20 7b 72 31 3d 27 61 62 63 27 2c  -4.14 {r1='abc',
2cd0: 20 72 32 3d 27 42 62 63 27 7d 20 7b 72 31 3e 72   r2='Bbc'} {r1>r
2ce0: 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 1.test_expr e
2cf0: 78 70 72 2d 34 2e 31 35 20 7b 72 31 3d 27 30 27  xpr-4.15 {r1='0'
2d00: 2c 20 72 32 3d 27 30 2e 30 27 7d 20 7b 72 31 3d  , r2='0.0'} {r1=
2d10: 3d 72 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  =r2} 1.test_expr
2d20: 20 65 78 70 72 2d 34 2e 31 36 20 7b 72 31 3d 27   expr-4.16 {r1='
2d30: 30 2e 30 30 30 27 2c 20 72 32 3d 27 30 2e 30 27  0.000', r2='0.0'
2d40: 7d 20 7b 72 31 3d 3d 72 32 7d 20 31 0a 74 65 73  } {r1==r2} 1.tes
2d50: 74 5f 65 78 70 72 20 65 78 70 72 2d 34 2e 31 37  t_expr expr-4.17
2d60: 20 7b 72 31 3d 27 20 30 2e 30 30 30 27 2c 20 72   {r1=' 0.000', r
2d70: 32 3d 27 20 30 2e 30 27 7d 20 7b 72 31 3d 3d 72  2=' 0.0'} {r1==r
2d80: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
2d90: 78 70 72 2d 34 2e 31 38 20 7b 72 31 3d 27 30 2e  xpr-4.18 {r1='0.
2da0: 30 27 2c 20 72 32 3d 27 61 62 63 27 7d 20 7b 72  0', r2='abc'} {r
2db0: 31 3c 72 32 7d 20 31 0a 74 65 73 74 5f 65 78 70  1<r2} 1.test_exp
2dc0: 72 20 65 78 70 72 2d 34 2e 31 39 20 7b 72 31 3d  r expr-4.19 {r1=
2dd0: 27 30 2e 30 27 2c 20 72 32 3d 27 61 62 63 27 7d  '0.0', r2='abc'}
2de0: 20 7b 72 31 3d 3d 72 32 7d 20 30 0a 74 65 73 74   {r1==r2} 0.test
2df0: 5f 65 78 70 72 20 65 78 70 72 2d 34 2e 32 30 20  _expr expr-4.20 
2e00: 7b 72 31 3d 27 30 2e 30 27 2c 20 72 32 3d 27 61  {r1='0.0', r2='a
2e10: 62 63 27 7d 20 7b 72 31 3e 72 32 7d 20 30 0a 0a  bc'} {r1>r2} 0..
2e20: 23 20 43 53 4c 20 69 73 20 74 72 75 65 20 69 66  # CSL is true if
2e30: 20 4c 49 4b 45 20 69 73 20 63 61 73 65 20 73 65   LIKE is case se
2e40: 6e 73 69 74 69 76 65 20 61 6e 64 20 66 61 6c 73  nsitive and fals
2e50: 65 20 69 66 20 6e 6f 74 2e 0a 23 20 4e 43 53 4c  e if not..# NCSL
2e60: 20 69 73 20 74 68 65 20 6f 70 70 6f 73 69 74 65   is the opposite
2e70: 2e 20 20 55 73 65 20 74 68 65 73 65 20 76 61 72  .  Use these var
2e80: 69 61 62 6c 65 73 20 61 73 20 74 68 65 20 72 65  iables as the re
2e90: 73 75 6c 74 0a 23 20 6f 6e 20 6f 70 65 72 61 74  sult.# on operat
2ea0: 69 6f 6e 73 20 77 68 65 72 65 20 63 61 73 65 20  ions where case 
2eb0: 6d 61 6b 65 73 20 61 20 64 69 66 66 65 72 65 6e  makes a differen
2ec0: 63 65 2e 0a 73 65 74 20 43 53 4c 20 24 73 71 6c  ce..set CSL $sql
2ed0: 69 74 65 5f 6f 70 74 69 6f 6e 73 28 63 61 73 65  ite_options(case
2ee0: 73 65 6e 73 69 74 69 76 65 6c 69 6b 65 29 0a 73  sensitivelike).s
2ef0: 65 74 20 4e 43 53 4c 20 5b 65 78 70 72 20 7b 21  et NCSL [expr {!
2f00: 24 43 53 4c 7d 5d 0a 0a 74 65 73 74 5f 65 78 70  $CSL}]..test_exp
2f10: 72 20 65 78 70 72 2d 35 2e 31 20 7b 74 31 3d 27  r expr-5.1 {t1='
2f20: 61 62 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20  abc', t2='xyz'} 
2f30: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 74  {t1 LIKE t2} 0.t
2f40: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
2f50: 32 61 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  2a {t1='abc', t2
2f60: 3d 27 61 62 63 27 7d 20 7b 74 31 20 4c 49 4b 45  ='abc'} {t1 LIKE
2f70: 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72   t2} 1.test_expr
2f80: 20 65 78 70 72 2d 35 2e 32 62 20 7b 74 31 3d 27   expr-5.2b {t1='
2f90: 61 62 63 27 2c 20 74 32 3d 27 41 42 43 27 7d 20  abc', t2='ABC'} 
2fa0: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 24 4e 43  {t1 LIKE t2} $NC
2fb0: 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  SL.test_expr exp
2fc0: 72 2d 35 2e 33 61 20 7b 74 31 3d 27 61 62 63 27  r-5.3a {t1='abc'
2fd0: 2c 20 74 32 3d 27 61 5f 63 27 7d 20 7b 74 31 20  , t2='a_c'} {t1 
2fe0: 4c 49 4b 45 20 74 32 7d 20 31 0a 74 65 73 74 5f  LIKE t2} 1.test_
2ff0: 65 78 70 72 20 65 78 70 72 2d 35 2e 33 62 20 7b  expr expr-5.3b {
3000: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 41 5f  t1='abc', t2='A_
3010: 43 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  C'} {t1 LIKE t2}
3020: 20 24 4e 43 53 4c 0a 74 65 73 74 5f 65 78 70 72   $NCSL.test_expr
3030: 20 65 78 70 72 2d 35 2e 34 20 7b 74 31 3d 27 61   expr-5.4 {t1='a
3040: 62 63 27 2c 20 74 32 3d 27 61 62 63 5f 27 7d 20  bc', t2='abc_'} 
3050: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 74  {t1 LIKE t2} 0.t
3060: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
3070: 35 61 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  5a {t1='abc', t2
3080: 3d 27 61 25 63 27 7d 20 7b 74 31 20 4c 49 4b 45  ='a%c'} {t1 LIKE
3090: 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72   t2} 1.test_expr
30a0: 20 65 78 70 72 2d 35 2e 35 62 20 7b 74 31 3d 27   expr-5.5b {t1='
30b0: 61 62 63 27 2c 20 74 32 3d 27 41 25 43 27 7d 20  abc', t2='A%C'} 
30c0: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 24 4e 43  {t1 LIKE t2} $NC
30d0: 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  SL.test_expr exp
30e0: 72 2d 35 2e 35 63 20 7b 74 31 3d 27 61 62 64 63  r-5.5c {t1='abdc
30f0: 27 2c 20 74 32 3d 27 61 25 63 27 7d 20 7b 74 31  ', t2='a%c'} {t1
3100: 20 4c 49 4b 45 20 74 32 7d 20 31 0a 74 65 73 74   LIKE t2} 1.test
3110: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 35 64 20  _expr expr-5.5d 
3120: 7b 74 31 3d 27 61 63 27 2c 20 74 32 3d 27 61 25  {t1='ac', t2='a%
3130: 63 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  c'} {t1 LIKE t2}
3140: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
3150: 72 2d 35 2e 35 65 20 7b 74 31 3d 27 61 63 27 2c  r-5.5e {t1='ac',
3160: 20 74 32 3d 27 41 25 43 27 7d 20 7b 74 31 20 4c   t2='A%C'} {t1 L
3170: 49 4b 45 20 74 32 7d 20 24 4e 43 53 4c 0a 74 65  IKE t2} $NCSL.te
3180: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 36  st_expr expr-5.6
3190: 61 20 7b 74 31 3d 27 61 62 78 79 7a 7a 79 63 27  a {t1='abxyzzyc'
31a0: 2c 20 74 32 3d 27 61 25 63 27 7d 20 7b 74 31 20  , t2='a%c'} {t1 
31b0: 4c 49 4b 45 20 74 32 7d 20 31 0a 74 65 73 74 5f  LIKE t2} 1.test_
31c0: 65 78 70 72 20 65 78 70 72 2d 35 2e 36 62 20 7b  expr expr-5.6b {
31d0: 74 31 3d 27 61 62 78 79 7a 7a 79 63 27 2c 20 74  t1='abxyzzyc', t
31e0: 32 3d 27 41 25 43 27 7d 20 7b 74 31 20 4c 49 4b  2='A%C'} {t1 LIK
31f0: 45 20 74 32 7d 20 24 4e 43 53 4c 0a 74 65 73 74  E t2} $NCSL.test
3200: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37 61 20  _expr expr-5.7a 
3210: 7b 74 31 3d 27 61 62 78 79 7a 7a 79 27 2c 20 74  {t1='abxyzzy', t
3220: 32 3d 27 61 25 63 27 7d 20 7b 74 31 20 4c 49 4b  2='a%c'} {t1 LIK
3230: 45 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  E t2} 0.test_exp
3240: 72 20 65 78 70 72 2d 35 2e 37 62 20 7b 74 31 3d  r expr-5.7b {t1=
3250: 27 61 62 78 79 7a 7a 79 27 2c 20 74 32 3d 27 41  'abxyzzy', t2='A
3260: 25 43 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32  %C'} {t1 LIKE t2
3270: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
3280: 70 72 2d 35 2e 38 61 20 7b 74 31 3d 27 61 62 78  pr-5.8a {t1='abx
3290: 79 7a 7a 79 63 78 27 2c 20 74 32 3d 27 61 25 63  yzzycx', t2='a%c
32a0: 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20  '} {t1 LIKE t2} 
32b0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
32c0: 2d 35 2e 38 62 20 7b 74 31 3d 27 61 62 78 79 7a  -5.8b {t1='abxyz
32d0: 7a 79 63 79 27 2c 20 74 32 3d 27 61 25 63 78 27  zycy', t2='a%cx'
32e0: 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30  } {t1 LIKE t2} 0
32f0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
3300: 35 2e 38 63 20 7b 74 31 3d 27 61 62 78 79 7a 7a  5.8c {t1='abxyzz
3310: 79 63 78 27 2c 20 74 32 3d 27 41 25 43 27 7d 20  ycx', t2='A%C'} 
3320: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 74  {t1 LIKE t2} 0.t
3330: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
3340: 38 64 20 7b 74 31 3d 27 61 62 78 79 7a 7a 79 63  8d {t1='abxyzzyc
3350: 79 27 2c 20 74 32 3d 27 41 25 43 58 27 7d 20 7b  y', t2='A%CX'} {
3360: 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 74 65  t1 LIKE t2} 0.te
3370: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 39  st_expr expr-5.9
3380: 61 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  a {t1='abc', t2=
3390: 27 61 25 5f 63 27 7d 20 7b 74 31 20 4c 49 4b 45  'a%_c'} {t1 LIKE
33a0: 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72   t2} 1.test_expr
33b0: 20 65 78 70 72 2d 35 2e 39 62 20 7b 74 31 3d 27   expr-5.9b {t1='
33c0: 61 63 27 2c 20 74 32 3d 27 61 25 5f 63 27 7d 20  ac', t2='a%_c'} 
33d0: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 74  {t1 LIKE t2} 0.t
33e0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
33f0: 39 63 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  9c {t1='abc', t2
3400: 3d 27 41 25 5f 43 27 7d 20 7b 74 31 20 4c 49 4b  ='A%_C'} {t1 LIK
3410: 45 20 74 32 7d 20 24 4e 43 53 4c 0a 74 65 73 74  E t2} $NCSL.test
3420: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 39 64 20  _expr expr-5.9d 
3430: 7b 74 31 3d 27 61 63 27 2c 20 74 32 3d 27 41 25  {t1='ac', t2='A%
3440: 5f 43 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32  _C'} {t1 LIKE t2
3450: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
3460: 70 72 2d 35 2e 31 30 61 20 7b 74 31 3d 27 61 62  pr-5.10a {t1='ab
3470: 78 79 7a 7a 79 63 27 2c 20 74 32 3d 27 61 25 5f  xyzzyc', t2='a%_
3480: 63 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  c'} {t1 LIKE t2}
3490: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
34a0: 72 2d 35 2e 31 30 62 20 7b 74 31 3d 27 61 62 78  r-5.10b {t1='abx
34b0: 79 7a 7a 79 63 27 2c 20 74 32 3d 27 41 25 5f 43  yzzyc', t2='A%_C
34c0: 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20  '} {t1 LIKE t2} 
34d0: 24 4e 43 53 4c 0a 74 65 73 74 5f 65 78 70 72 20  $NCSL.test_expr 
34e0: 65 78 70 72 2d 35 2e 31 31 20 7b 74 31 3d 27 61  expr-5.11 {t1='a
34f0: 62 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b  bc', t2='xyz'} {
3500: 74 31 20 4e 4f 54 20 4c 49 4b 45 20 74 32 7d 20  t1 NOT LIKE t2} 
3510: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
3520: 2d 35 2e 31 32 61 20 7b 74 31 3d 27 61 62 63 27  -5.12a {t1='abc'
3530: 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 20  , t2='abc'} {t1 
3540: 4e 4f 54 20 4c 49 4b 45 20 74 32 7d 20 30 0a 74  NOT LIKE t2} 0.t
3550: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
3560: 31 32 62 20 7b 74 31 3d 27 61 62 63 27 2c 20 74  12b {t1='abc', t
3570: 32 3d 27 41 42 43 27 7d 20 7b 74 31 20 4e 4f 54  2='ABC'} {t1 NOT
3580: 20 4c 49 4b 45 20 74 32 7d 20 24 43 53 4c 0a 0a   LIKE t2} $CSL..
3590: 23 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20  # The following 
35a0: 74 65 73 74 73 20 6f 6e 6c 79 20 77 6f 72 6b 20  tests only work 
35b0: 6f 6e 20 76 65 72 73 69 6f 6e 73 20 6f 66 20 54  on versions of T
35c0: 43 4c 20 74 68 61 74 20 73 75 70 70 6f 72 74 20  CL that support 
35d0: 55 6e 69 63 6f 64 65 0a 23 0a 69 66 20 7b 22 5c  Unicode.#.if {"\
35e0: 75 31 32 33 34 22 21 3d 22 75 31 32 33 34 22 7d  u1234"!="u1234"}
35f0: 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   {.  test_expr e
3600: 78 70 72 2d 35 2e 31 33 61 20 22 74 31 3d 27 61  xpr-5.13a "t1='a
3610: 5c 75 30 30 38 30 63 27 2c 20 74 32 3d 27 61 5f  \u0080c', t2='a_
3620: 63 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  c'" {t1 LIKE t2}
3630: 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   1.  test_expr e
3640: 78 70 72 2d 35 2e 31 33 62 20 22 74 31 3d 27 61  xpr-5.13b "t1='a
3650: 5c 75 30 30 38 30 63 27 2c 20 74 32 3d 27 41 5f  \u0080c', t2='A_
3660: 43 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  C'" {t1 LIKE t2}
3670: 20 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f 65 78   $NCSL.  test_ex
3680: 70 72 20 65 78 70 72 2d 35 2e 31 34 61 20 22 74  pr expr-5.14a "t
3690: 31 3d 27 61 5c 75 30 37 46 46 63 27 2c 20 74 32  1='a\u07FFc', t2
36a0: 3d 27 61 5f 63 27 22 20 7b 74 31 20 4c 49 4b 45  ='a_c'" {t1 LIKE
36b0: 20 74 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78   t2} 1.  test_ex
36c0: 70 72 20 65 78 70 72 2d 35 2e 31 34 62 20 22 74  pr expr-5.14b "t
36d0: 31 3d 27 61 5c 75 30 37 46 46 63 27 2c 20 74 32  1='a\u07FFc', t2
36e0: 3d 27 41 5f 43 27 22 20 7b 74 31 20 4c 49 4b 45  ='A_C'" {t1 LIKE
36f0: 20 74 32 7d 20 24 4e 43 53 4c 0a 20 20 74 65 73   t2} $NCSL.  tes
3700: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 31 35  t_expr expr-5.15
3710: 61 20 22 74 31 3d 27 61 5c 75 30 38 30 30 63 27  a "t1='a\u0800c'
3720: 2c 20 74 32 3d 27 61 5f 63 27 22 20 7b 74 31 20  , t2='a_c'" {t1 
3730: 4c 49 4b 45 20 74 32 7d 20 31 0a 20 20 74 65 73  LIKE t2} 1.  tes
3740: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 31 35  t_expr expr-5.15
3750: 62 20 22 74 31 3d 27 61 5c 75 30 38 30 30 63 27  b "t1='a\u0800c'
3760: 2c 20 74 32 3d 27 41 5f 43 27 22 20 7b 74 31 20  , t2='A_C'" {t1 
3770: 4c 49 4b 45 20 74 32 7d 20 24 4e 43 53 4c 0a 20  LIKE t2} $NCSL. 
3780: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
3790: 35 2e 31 36 61 20 22 74 31 3d 27 61 5c 75 46 46  5.16a "t1='a\uFF
37a0: 46 46 63 27 2c 20 74 32 3d 27 61 5f 63 27 22 20  FFc', t2='a_c'" 
37b0: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 31 0a 20  {t1 LIKE t2} 1. 
37c0: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
37d0: 35 2e 31 36 62 20 22 74 31 3d 27 61 5c 75 46 46  5.16b "t1='a\uFF
37e0: 46 46 63 27 2c 20 74 32 3d 27 41 5f 43 27 22 20  FFc', t2='A_C'" 
37f0: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 24 4e 43  {t1 LIKE t2} $NC
3800: 53 4c 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65  SL.  test_expr e
3810: 78 70 72 2d 35 2e 31 37 20 22 74 31 3d 27 61 5c  xpr-5.17 "t1='a\
3820: 75 30 30 38 30 27 2c 20 74 32 3d 27 41 5f 5f 27  u0080', t2='A__'
3830: 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30  " {t1 LIKE t2} 0
3840: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
3850: 72 2d 35 2e 31 38 20 22 74 31 3d 27 61 5c 75 30  r-5.18 "t1='a\u0
3860: 37 46 46 27 2c 20 74 32 3d 27 41 5f 5f 27 22 20  7FF', t2='A__'" 
3870: 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 20  {t1 LIKE t2} 0. 
3880: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
3890: 35 2e 31 39 20 22 74 31 3d 27 61 5c 75 30 38 30  5.19 "t1='a\u080
38a0: 30 27 2c 20 74 32 3d 27 41 5f 5f 27 22 20 7b 74  0', t2='A__'" {t
38b0: 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 20 20 74  1 LIKE t2} 0.  t
38c0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
38d0: 32 30 20 22 74 31 3d 27 61 5c 75 46 46 46 46 27  20 "t1='a\uFFFF'
38e0: 2c 20 74 32 3d 27 41 5f 5f 27 22 20 7b 74 31 20  , t2='A__'" {t1 
38f0: 4c 49 4b 45 20 74 32 7d 20 30 0a 20 20 74 65 73  LIKE t2} 0.  tes
3900: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 32 31  t_expr expr-5.21
3910: 61 20 22 74 31 3d 27 61 78 5c 75 41 42 43 44 27  a "t1='ax\uABCD'
3920: 2c 20 74 32 3d 27 61 5f 5c 75 41 42 43 44 27 22  , t2='a_\uABCD'"
3930: 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 31 0a   {t1 LIKE t2} 1.
3940: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
3950: 2d 35 2e 32 31 62 20 22 74 31 3d 27 61 78 5c 75  -5.21b "t1='ax\u
3960: 41 42 43 44 27 2c 20 74 32 3d 27 41 5f 5c 75 41  ABCD', t2='A_\uA
3970: 42 43 44 27 22 20 7b 74 31 20 4c 49 4b 45 20 74  BCD'" {t1 LIKE t
3980: 32 7d 20 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f  2} $NCSL.  test_
3990: 65 78 70 72 20 65 78 70 72 2d 35 2e 32 32 61 20  expr expr-5.22a 
39a0: 22 74 31 3d 27 61 78 5c 75 31 32 33 34 27 2c 20  "t1='ax\u1234', 
39b0: 74 32 3d 27 61 25 5c 75 31 32 33 34 27 22 20 7b  t2='a%\u1234'" {
39c0: 74 31 20 4c 49 4b 45 20 74 32 7d 20 31 0a 20 20  t1 LIKE t2} 1.  
39d0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
39e0: 2e 32 32 62 20 22 74 31 3d 27 61 78 5c 75 31 32  .22b "t1='ax\u12
39f0: 33 34 27 2c 20 74 32 3d 27 41 25 5c 75 31 32 33  34', t2='A%\u123
3a00: 34 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  4'" {t1 LIKE t2}
3a10: 20 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f 65 78   $NCSL.  test_ex
3a20: 70 72 20 65 78 70 72 2d 35 2e 32 33 61 20 22 74  pr expr-5.23a "t
3a30: 31 3d 27 61 78 5c 75 46 45 44 43 27 2c 20 74 32  1='ax\uFEDC', t2
3a40: 3d 27 61 5f 25 27 22 20 7b 74 31 20 4c 49 4b 45  ='a_%'" {t1 LIKE
3a50: 20 74 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78   t2} 1.  test_ex
3a60: 70 72 20 65 78 70 72 2d 35 2e 32 33 62 20 22 74  pr expr-5.23b "t
3a70: 31 3d 27 61 78 5c 75 46 45 44 43 27 2c 20 74 32  1='ax\uFEDC', t2
3a80: 3d 27 41 5f 25 27 22 20 7b 74 31 20 4c 49 4b 45  ='A_%'" {t1 LIKE
3a90: 20 74 32 7d 20 24 4e 43 53 4c 0a 20 20 74 65 73   t2} $NCSL.  tes
3aa0: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 32 34  t_expr expr-5.24
3ab0: 61 20 22 74 31 3d 27 61 78 5c 75 46 45 44 43 79  a "t1='ax\uFEDCy
3ac0: 5c 75 46 45 44 43 27 2c 20 74 32 3d 27 61 25 5c  \uFEDC', t2='a%\
3ad0: 75 46 45 44 43 27 22 20 7b 74 31 20 4c 49 4b 45  uFEDC'" {t1 LIKE
3ae0: 20 74 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78   t2} 1.  test_ex
3af0: 70 72 20 65 78 70 72 2d 35 2e 32 34 62 20 22 74  pr expr-5.24b "t
3b00: 31 3d 27 61 78 5c 75 46 45 44 43 79 5c 75 46 45  1='ax\uFEDCy\uFE
3b10: 44 43 27 2c 20 74 32 3d 27 41 25 5c 75 46 45 44  DC', t2='A%\uFED
3b20: 43 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  C'" {t1 LIKE t2}
3b30: 20 24 4e 43 53 4c 0a 7d 0a 0a 74 65 73 74 5f 65   $NCSL.}..test_e
3b40: 78 70 72 20 65 78 70 72 2d 35 2e 35 34 20 7b 74  xpr expr-5.54 {t
3b50: 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c  1='abc', t2=NULL
3b60: 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 7b  } {t1 LIKE t2} {
3b70: 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78  {}}.test_expr ex
3b80: 70 72 2d 35 2e 35 35 20 7b 74 31 3d 27 61 62 63  pr-5.55 {t1='abc
3b90: 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 74 31 20  ', t2=NULL} {t1 
3ba0: 4e 4f 54 20 4c 49 4b 45 20 74 32 7d 20 7b 7b 7d  NOT LIKE t2} {{}
3bb0: 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  }.test_expr expr
3bc0: 2d 35 2e 35 36 20 7b 74 31 3d 27 61 62 63 27 2c  -5.56 {t1='abc',
3bd0: 20 74 32 3d 4e 55 4c 4c 7d 20 7b 74 32 20 4c 49   t2=NULL} {t2 LI
3be0: 4b 45 20 74 31 7d 20 7b 7b 7d 7d 0a 74 65 73 74  KE t1} {{}}.test
3bf0: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 35 37 20  _expr expr-5.57 
3c00: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55  {t1='abc', t2=NU
3c10: 4c 4c 7d 20 7b 74 32 20 4e 4f 54 20 4c 49 4b 45  LL} {t2 NOT LIKE
3c20: 20 74 31 7d 20 7b 7b 7d 7d 0a 0a 23 20 4c 49 4b   t1} {{}}..# LIK
3c30: 45 20 65 78 70 72 65 73 73 69 6f 6e 73 20 74 68  E expressions th
3c40: 61 74 20 75 73 65 20 45 53 43 41 50 45 20 63 68  at use ESCAPE ch
3c50: 61 72 61 63 74 65 72 73 2e 0a 74 65 73 74 5f 65  aracters..test_e
3c60: 78 70 72 20 65 78 70 72 2d 35 2e 35 38 61 20 7b  xpr expr-5.58a {
3c70: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 5f  t1='abc', t2='a_
3c80: 63 27 7d 20 20 20 7b 74 31 20 4c 49 4b 45 20 74  c'}   {t1 LIKE t
3c90: 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 31 0a  2 ESCAPE '7'} 1.
3ca0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
3cb0: 2e 35 38 62 20 7b 74 31 3d 27 61 62 63 27 2c 20  .58b {t1='abc', 
3cc0: 74 32 3d 27 41 5f 43 27 7d 20 20 20 7b 74 31 20  t2='A_C'}   {t1 
3cd0: 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27  LIKE t2 ESCAPE '
3ce0: 37 27 7d 20 24 4e 43 53 4c 0a 74 65 73 74 5f 65  7'} $NCSL.test_e
3cf0: 78 70 72 20 65 78 70 72 2d 35 2e 35 39 61 20 7b  xpr expr-5.59a {
3d00: 74 31 3d 27 61 5f 63 27 2c 20 74 32 3d 27 61 37  t1='a_c', t2='a7
3d10: 5f 63 27 7d 20 20 7b 74 31 20 4c 49 4b 45 20 74  _c'}  {t1 LIKE t
3d20: 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 31 0a  2 ESCAPE '7'} 1.
3d30: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
3d40: 2e 35 39 62 20 7b 74 31 3d 27 61 5f 63 27 2c 20  .59b {t1='a_c', 
3d50: 74 32 3d 27 41 37 5f 43 27 7d 20 20 7b 74 31 20  t2='A7_C'}  {t1 
3d60: 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27  LIKE t2 ESCAPE '
3d70: 37 27 7d 20 24 4e 43 53 4c 0a 74 65 73 74 5f 65  7'} $NCSL.test_e
3d80: 78 70 72 20 65 78 70 72 2d 35 2e 36 30 61 20 7b  xpr expr-5.60a {
3d90: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 37  t1='abc', t2='a7
3da0: 5f 63 27 7d 20 20 7b 74 31 20 4c 49 4b 45 20 74  _c'}  {t1 LIKE t
3db0: 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 30 0a  2 ESCAPE '7'} 0.
3dc0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
3dd0: 2e 36 30 62 20 7b 74 31 3d 27 61 62 63 27 2c 20  .60b {t1='abc', 
3de0: 74 32 3d 27 41 37 5f 43 27 7d 20 20 7b 74 31 20  t2='A7_C'}  {t1 
3df0: 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27  LIKE t2 ESCAPE '
3e00: 37 27 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  7'} 0.test_expr 
3e10: 65 78 70 72 2d 35 2e 36 31 61 20 7b 74 31 3d 27  expr-5.61a {t1='
3e20: 61 37 58 63 27 2c 20 74 32 3d 27 61 37 5f 63 27  a7Xc', t2='a7_c'
3e30: 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20 45 53  } {t1 LIKE t2 ES
3e40: 43 41 50 45 20 27 37 27 7d 20 30 0a 74 65 73 74  CAPE '7'} 0.test
3e50: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 36 31 62  _expr expr-5.61b
3e60: 20 7b 74 31 3d 27 61 37 58 63 27 2c 20 74 32 3d   {t1='a7Xc', t2=
3e70: 27 41 37 5f 43 27 7d 20 7b 74 31 20 4c 49 4b 45  'A7_C'} {t1 LIKE
3e80: 20 74 32 20 45 53 43 41 50 45 20 27 37 27 7d 20   t2 ESCAPE '7'} 
3e90: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
3ea0: 2d 35 2e 36 32 61 20 7b 74 31 3d 27 61 62 63 64  -5.62a {t1='abcd
3eb0: 65 27 2c 20 74 32 3d 27 61 25 65 27 7d 20 7b 74  e', t2='a%e'} {t
3ec0: 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45  1 LIKE t2 ESCAPE
3ed0: 20 27 37 27 7d 20 31 0a 74 65 73 74 5f 65 78 70   '7'} 1.test_exp
3ee0: 72 20 65 78 70 72 2d 35 2e 36 32 62 20 7b 74 31  r expr-5.62b {t1
3ef0: 3d 27 61 62 63 64 65 27 2c 20 74 32 3d 27 41 25  ='abcde', t2='A%
3f00: 45 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20  E'} {t1 LIKE t2 
3f10: 45 53 43 41 50 45 20 27 37 27 7d 20 24 4e 43 53  ESCAPE '7'} $NCS
3f20: 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  L.test_expr expr
3f30: 2d 35 2e 36 33 61 20 7b 74 31 3d 27 61 62 63 64  -5.63a {t1='abcd
3f40: 65 27 2c 20 74 32 3d 27 61 37 25 65 27 7d 20 7b  e', t2='a7%e'} {
3f50: 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50  t1 LIKE t2 ESCAP
3f60: 45 20 27 37 27 7d 20 30 0a 74 65 73 74 5f 65 78  E '7'} 0.test_ex
3f70: 70 72 20 65 78 70 72 2d 35 2e 36 33 62 20 7b 74  pr expr-5.63b {t
3f80: 31 3d 27 61 62 63 64 65 27 2c 20 74 32 3d 27 41  1='abcde', t2='A
3f90: 37 25 45 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74  7%E'} {t1 LIKE t
3fa0: 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 30 0a  2 ESCAPE '7'} 0.
3fb0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
3fc0: 2e 36 34 61 20 7b 74 31 3d 27 61 37 63 64 65 27  .64a {t1='a7cde'
3fd0: 2c 20 74 32 3d 27 61 37 25 65 27 7d 20 7b 74 31  , t2='a7%e'} {t1
3fe0: 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20   LIKE t2 ESCAPE 
3ff0: 27 37 27 7d 20 30 0a 74 65 73 74 5f 65 78 70 72  '7'} 0.test_expr
4000: 20 65 78 70 72 2d 35 2e 36 34 62 20 7b 74 31 3d   expr-5.64b {t1=
4010: 27 61 37 63 64 65 27 2c 20 74 32 3d 27 41 37 25  'a7cde', t2='A7%
4020: 45 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20  E'} {t1 LIKE t2 
4030: 45 53 43 41 50 45 20 27 37 27 7d 20 30 0a 74 65  ESCAPE '7'} 0.te
4040: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 36  st_expr expr-5.6
4050: 35 61 20 7b 74 31 3d 27 61 37 63 64 65 27 2c 20  5a {t1='a7cde', 
4060: 74 32 3d 27 61 37 37 25 65 27 7d 20 7b 74 31 20  t2='a77%e'} {t1 
4070: 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27  LIKE t2 ESCAPE '
4080: 37 27 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  7'} 1.test_expr 
4090: 65 78 70 72 2d 35 2e 36 35 62 20 7b 74 31 3d 27  expr-5.65b {t1='
40a0: 61 37 63 64 65 27 2c 20 74 32 3d 27 41 37 37 25  a7cde', t2='A77%
40b0: 45 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20  E'} {t1 LIKE t2 
40c0: 45 53 43 41 50 45 20 27 37 27 7d 20 24 4e 43 53  ESCAPE '7'} $NCS
40d0: 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  L.test_expr expr
40e0: 2d 35 2e 36 36 61 20 7b 74 31 3d 27 61 62 63 37  -5.66a {t1='abc7
40f0: 27 2c 20 74 32 3d 27 61 25 37 37 27 7d 20 7b 74  ', t2='a%77'} {t
4100: 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45  1 LIKE t2 ESCAPE
4110: 20 27 37 27 7d 20 31 0a 74 65 73 74 5f 65 78 70   '7'} 1.test_exp
4120: 72 20 65 78 70 72 2d 35 2e 36 36 62 20 7b 74 31  r expr-5.66b {t1
4130: 3d 27 61 62 63 37 27 2c 20 74 32 3d 27 41 25 37  ='abc7', t2='A%7
4140: 37 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20  7'} {t1 LIKE t2 
4150: 45 53 43 41 50 45 20 27 37 27 7d 20 24 4e 43 53  ESCAPE '7'} $NCS
4160: 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  L.test_expr expr
4170: 2d 35 2e 36 37 61 20 7b 74 31 3d 27 61 62 63 5f  -5.67a {t1='abc_
4180: 27 2c 20 74 32 3d 27 61 25 37 5f 27 7d 20 7b 74  ', t2='a%7_'} {t
4190: 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45  1 LIKE t2 ESCAPE
41a0: 20 27 37 27 7d 20 31 0a 74 65 73 74 5f 65 78 70   '7'} 1.test_exp
41b0: 72 20 65 78 70 72 2d 35 2e 36 37 62 20 7b 74 31  r expr-5.67b {t1
41c0: 3d 27 61 62 63 5f 27 2c 20 74 32 3d 27 41 25 37  ='abc_', t2='A%7
41d0: 5f 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20  _'} {t1 LIKE t2 
41e0: 45 53 43 41 50 45 20 27 37 27 7d 20 24 4e 43 53  ESCAPE '7'} $NCS
41f0: 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  L.test_expr expr
4200: 2d 35 2e 36 38 61 20 7b 74 31 3d 27 61 62 63 37  -5.68a {t1='abc7
4210: 27 2c 20 74 32 3d 27 61 25 37 5f 27 7d 20 7b 74  ', t2='a%7_'} {t
4220: 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45  1 LIKE t2 ESCAPE
4230: 20 27 37 27 7d 20 30 0a 74 65 73 74 5f 65 78 70   '7'} 0.test_exp
4240: 72 20 65 78 70 72 2d 35 2e 36 38 62 20 7b 74 31  r expr-5.68b {t1
4250: 3d 27 61 62 63 37 27 2c 20 74 32 3d 27 41 25 37  ='abc7', t2='A%7
4260: 5f 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20  _'} {t1 LIKE t2 
4270: 45 53 43 41 50 45 20 27 37 27 7d 20 30 0a 0a 23  ESCAPE '7'} 0..#
4280: 20 54 68 65 73 65 20 61 72 65 20 74 68 65 20 73   These are the s
4290: 61 6d 65 20 74 65 73 74 20 61 73 20 74 68 65 20  ame test as the 
42a0: 62 6c 6f 63 6b 20 61 62 6f 76 65 2c 20 62 75 74  block above, but
42b0: 20 75 73 69 6e 67 20 61 20 6d 75 6c 74 69 2d 62   using a multi-b
42c0: 79 74 65 20 0a 23 20 63 68 61 72 61 63 74 65 72  yte .# character
42d0: 20 61 73 20 74 68 65 20 65 73 63 61 70 65 20 63   as the escape c
42e0: 68 61 72 61 63 74 65 72 2e 0a 69 66 20 7b 22 5c  haracter..if {"\
42f0: 75 31 32 33 34 22 21 3d 22 75 31 32 33 34 22 7d  u1234"!="u1234"}
4300: 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   {.  test_expr e
4310: 78 70 72 2d 35 2e 36 39 61 20 22 74 31 3d 27 61  xpr-5.69a "t1='a
4320: 62 63 27 2c 20 74 32 3d 27 61 5f 63 27 22 20 5c  bc', t2='a_c'" \
4330: 0a 20 20 20 20 20 20 22 74 31 20 4c 49 4b 45 20  .      "t1 LIKE 
4340: 74 32 20 45 53 43 41 50 45 20 27 5c 75 31 32 33  t2 ESCAPE '\u123
4350: 34 27 22 20 31 0a 20 20 74 65 73 74 5f 65 78 70  4'" 1.  test_exp
4360: 72 20 65 78 70 72 2d 35 2e 36 39 62 20 22 74 31  r expr-5.69b "t1
4370: 3d 27 61 62 63 27 2c 20 74 32 3d 27 41 5f 43 27  ='abc', t2='A_C'
4380: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
4390: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
43a0: 31 32 33 34 27 22 20 24 4e 43 53 4c 0a 20 20 74  1234'" $NCSL.  t
43b0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
43c0: 37 30 61 20 22 74 31 3d 27 61 5f 63 27 2c 20 74  70a "t1='a_c', t
43d0: 32 3d 27 61 5c 75 31 32 33 34 5f 63 27 22 20 5c  2='a\u1234_c'" \
43e0: 0a 20 20 20 20 20 20 22 74 31 20 4c 49 4b 45 20  .      "t1 LIKE 
43f0: 74 32 20 45 53 43 41 50 45 20 27 5c 75 31 32 33  t2 ESCAPE '\u123
4400: 34 27 22 20 31 0a 20 20 74 65 73 74 5f 65 78 70  4'" 1.  test_exp
4410: 72 20 65 78 70 72 2d 35 2e 37 30 62 20 22 74 31  r expr-5.70b "t1
4420: 3d 27 61 5f 63 27 2c 20 74 32 3d 27 41 5c 75 31  ='a_c', t2='A\u1
4430: 32 33 34 5f 43 27 22 20 5c 0a 20 20 20 20 20 20  234_C'" \.      
4440: 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41  "t1 LIKE t2 ESCA
4450: 50 45 20 27 5c 75 31 32 33 34 27 22 20 24 4e 43  PE '\u1234'" $NC
4460: 53 4c 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65  SL.  test_expr e
4470: 78 70 72 2d 35 2e 37 31 61 20 22 74 31 3d 27 61  xpr-5.71a "t1='a
4480: 62 63 27 2c 20 74 32 3d 27 61 5c 75 31 32 33 34  bc', t2='a\u1234
4490: 5f 63 27 22 20 5c 0a 20 20 20 20 20 20 20 22 74  _c'" \.       "t
44a0: 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45  1 LIKE t2 ESCAPE
44b0: 20 27 5c 75 31 32 33 34 27 22 20 30 0a 20 20 74   '\u1234'" 0.  t
44c0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
44d0: 37 31 62 20 22 74 31 3d 27 61 62 63 27 2c 20 74  71b "t1='abc', t
44e0: 32 3d 27 41 5c 75 31 32 33 34 5f 43 27 22 20 5c  2='A\u1234_C'" \
44f0: 0a 20 20 20 20 20 20 20 22 74 31 20 4c 49 4b 45  .       "t1 LIKE
4500: 20 74 32 20 45 53 43 41 50 45 20 27 5c 75 31 32   t2 ESCAPE '\u12
4510: 33 34 27 22 20 30 0a 20 20 74 65 73 74 5f 65 78  34'" 0.  test_ex
4520: 70 72 20 65 78 70 72 2d 35 2e 37 32 61 20 22 74  pr expr-5.72a "t
4530: 31 3d 27 61 5c 75 31 32 33 34 58 63 27 2c 20 74  1='a\u1234Xc', t
4540: 32 3d 27 61 5c 75 31 32 33 34 5f 63 27 22 20 5c  2='a\u1234_c'" \
4550: 0a 20 20 20 20 20 20 22 74 31 20 4c 49 4b 45 20  .      "t1 LIKE 
4560: 74 32 20 45 53 43 41 50 45 20 27 5c 75 31 32 33  t2 ESCAPE '\u123
4570: 34 27 22 20 30 0a 20 20 74 65 73 74 5f 65 78 70  4'" 0.  test_exp
4580: 72 20 65 78 70 72 2d 35 2e 37 32 62 20 22 74 31  r expr-5.72b "t1
4590: 3d 27 61 5c 75 31 32 33 34 58 63 27 2c 20 74 32  ='a\u1234Xc', t2
45a0: 3d 27 41 5c 75 31 32 33 34 5f 43 27 22 20 5c 0a  ='A\u1234_C'" \.
45b0: 20 20 20 20 20 20 22 74 31 20 4c 49 4b 45 20 74        "t1 LIKE t
45c0: 32 20 45 53 43 41 50 45 20 27 5c 75 31 32 33 34  2 ESCAPE '\u1234
45d0: 27 22 20 30 0a 20 20 74 65 73 74 5f 65 78 70 72  '" 0.  test_expr
45e0: 20 65 78 70 72 2d 35 2e 37 33 61 20 22 74 31 3d   expr-5.73a "t1=
45f0: 27 61 62 63 64 65 27 2c 20 74 32 3d 27 61 25 65  'abcde', t2='a%e
4600: 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c  '" \.      "t1 L
4610: 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c  IKE t2 ESCAPE '\
4620: 75 31 32 33 34 27 22 20 31 0a 20 20 74 65 73 74  u1234'" 1.  test
4630: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37 33 62  _expr expr-5.73b
4640: 20 22 74 31 3d 27 61 62 63 64 65 27 2c 20 74 32   "t1='abcde', t2
4650: 3d 27 41 25 45 27 22 20 5c 0a 20 20 20 20 20 20  ='A%E'" \.      
4660: 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41  "t1 LIKE t2 ESCA
4670: 50 45 20 27 5c 75 31 32 33 34 27 22 20 24 4e 43  PE '\u1234'" $NC
4680: 53 4c 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65  SL.  test_expr e
4690: 78 70 72 2d 35 2e 37 34 61 20 22 74 31 3d 27 61  xpr-5.74a "t1='a
46a0: 62 63 64 65 27 2c 20 74 32 3d 27 61 5c 75 31 32  bcde', t2='a\u12
46b0: 33 34 25 65 27 22 20 5c 0a 20 20 20 20 20 20 22  34%e'" \.      "
46c0: 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50  t1 LIKE t2 ESCAP
46d0: 45 20 27 5c 75 31 32 33 34 27 22 20 30 0a 20 20  E '\u1234'" 0.  
46e0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
46f0: 2e 37 34 62 20 22 74 31 3d 27 61 62 63 64 65 27  .74b "t1='abcde'
4700: 2c 20 74 32 3d 27 41 5c 75 31 32 33 34 25 45 27  , t2='A\u1234%E'
4710: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
4720: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
4730: 31 32 33 34 27 22 20 30 0a 20 20 74 65 73 74 5f  1234'" 0.  test_
4740: 65 78 70 72 20 65 78 70 72 2d 35 2e 37 35 61 20  expr expr-5.75a 
4750: 22 74 31 3d 27 61 5c 75 31 32 33 34 63 64 65 27  "t1='a\u1234cde'
4760: 2c 20 74 32 3d 27 61 5c 75 31 32 33 34 25 65 27  , t2='a\u1234%e'
4770: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
4780: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
4790: 31 32 33 34 27 22 20 30 0a 20 20 74 65 73 74 5f  1234'" 0.  test_
47a0: 65 78 70 72 20 65 78 70 72 2d 35 2e 37 35 62 20  expr expr-5.75b 
47b0: 22 74 31 3d 27 61 5c 75 31 32 33 34 63 64 65 27  "t1='a\u1234cde'
47c0: 2c 20 74 32 3d 27 41 5c 75 31 32 33 34 25 45 27  , t2='A\u1234%E'
47d0: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
47e0: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
47f0: 31 32 33 34 27 22 20 30 0a 20 20 74 65 73 74 5f  1234'" 0.  test_
4800: 65 78 70 72 20 65 78 70 72 2d 35 2e 37 36 61 20  expr expr-5.76a 
4810: 22 74 31 3d 27 61 5c 75 31 32 33 34 63 64 65 27  "t1='a\u1234cde'
4820: 2c 20 74 32 3d 27 61 5c 75 31 32 33 34 5c 75 31  , t2='a\u1234\u1
4830: 32 33 34 25 65 27 22 20 5c 0a 20 20 20 20 20 20  234%e'" \.      
4840: 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41  "t1 LIKE t2 ESCA
4850: 50 45 20 27 5c 75 31 32 33 34 27 22 20 31 0a 20  PE '\u1234'" 1. 
4860: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
4870: 35 2e 37 36 62 20 22 74 31 3d 27 61 5c 75 31 32  5.76b "t1='a\u12
4880: 33 34 63 64 65 27 2c 20 74 32 3d 27 41 5c 75 31  34cde', t2='A\u1
4890: 32 33 34 5c 75 31 32 33 34 25 45 27 22 20 5c 0a  234\u1234%E'" \.
48a0: 20 20 20 20 20 20 22 74 31 20 4c 49 4b 45 20 74        "t1 LIKE t
48b0: 32 20 45 53 43 41 50 45 20 27 5c 75 31 32 33 34  2 ESCAPE '\u1234
48c0: 27 22 20 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f  '" $NCSL.  test_
48d0: 65 78 70 72 20 65 78 70 72 2d 35 2e 37 37 61 20  expr expr-5.77a 
48e0: 22 74 31 3d 27 61 62 63 5c 75 31 32 33 34 27 2c  "t1='abc\u1234',
48f0: 20 74 32 3d 27 61 25 5c 75 31 32 33 34 5c 75 31   t2='a%\u1234\u1
4900: 32 33 34 27 22 20 5c 0a 20 20 20 20 20 20 22 74  234'" \.      "t
4910: 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45  1 LIKE t2 ESCAPE
4920: 20 27 5c 75 31 32 33 34 27 22 20 31 0a 20 20 74   '\u1234'" 1.  t
4930: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
4940: 37 37 62 20 22 74 31 3d 27 61 62 63 5c 75 31 32  77b "t1='abc\u12
4950: 33 34 27 2c 20 74 32 3d 27 41 25 5c 75 31 32 33  34', t2='A%\u123
4960: 34 5c 75 31 32 33 34 27 22 20 5c 0a 20 20 20 20  4\u1234'" \.    
4970: 20 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53    "t1 LIKE t2 ES
4980: 43 41 50 45 20 27 5c 75 31 32 33 34 27 22 20 24  CAPE '\u1234'" $
4990: 4e 43 53 4c 0a 20 20 74 65 73 74 5f 65 78 70 72  NCSL.  test_expr
49a0: 20 65 78 70 72 2d 35 2e 37 38 61 20 22 74 31 3d   expr-5.78a "t1=
49b0: 27 61 62 63 5f 27 2c 20 74 32 3d 27 61 25 5c 75  'abc_', t2='a%\u
49c0: 31 32 33 34 5f 27 22 20 5c 0a 20 20 20 20 20 20  1234_'" \.      
49d0: 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41  "t1 LIKE t2 ESCA
49e0: 50 45 20 27 5c 75 31 32 33 34 27 22 20 31 0a 20  PE '\u1234'" 1. 
49f0: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
4a00: 35 2e 37 38 62 20 22 74 31 3d 27 61 62 63 5f 27  5.78b "t1='abc_'
4a10: 2c 20 74 32 3d 27 41 25 5c 75 31 32 33 34 5f 27  , t2='A%\u1234_'
4a20: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
4a30: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
4a40: 31 32 33 34 27 22 20 24 4e 43 53 4c 0a 20 20 74  1234'" $NCSL.  t
4a50: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
4a60: 37 39 61 20 22 74 31 3d 27 61 62 63 5c 75 31 32  79a "t1='abc\u12
4a70: 33 34 27 2c 20 74 32 3d 27 61 25 5c 75 31 32 33  34', t2='a%\u123
4a80: 34 5f 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31  4_'" \.      "t1
4a90: 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20   LIKE t2 ESCAPE 
4aa0: 27 5c 75 31 32 33 34 27 22 20 30 0a 20 20 74 65  '\u1234'" 0.  te
4ab0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37  st_expr expr-5.7
4ac0: 39 62 20 22 74 31 3d 27 61 62 63 5c 75 31 32 33  9b "t1='abc\u123
4ad0: 34 27 2c 20 74 32 3d 27 41 25 5c 75 31 32 33 34  4', t2='A%\u1234
4ae0: 5f 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20  _'" \.      "t1 
4af0: 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27  LIKE t2 ESCAPE '
4b00: 5c 75 31 32 33 34 27 22 20 30 0a 7d 0a 0a 74 65  \u1234'" 0.}..te
4b10: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 31  st_expr expr-6.1
4b20: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27   {t1='abc', t2='
4b30: 78 79 7a 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  xyz'} {t1 GLOB t
4b40: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
4b50: 78 70 72 2d 36 2e 32 20 7b 74 31 3d 27 61 62 63  xpr-6.2 {t1='abc
4b60: 27 2c 20 74 32 3d 27 41 42 43 27 7d 20 7b 74 31  ', t2='ABC'} {t1
4b70: 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74   GLOB t2} 0.test
4b80: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 33 20 7b  _expr expr-6.3 {
4b90: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 41 3f  t1='abc', t2='A?
4ba0: 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  C'} {t1 GLOB t2}
4bb0: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
4bc0: 72 2d 36 2e 34 20 7b 74 31 3d 27 61 62 63 27 2c  r-6.4 {t1='abc',
4bd0: 20 74 32 3d 27 61 3f 63 27 7d 20 7b 74 31 20 47   t2='a?c'} {t1 G
4be0: 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65  LOB t2} 1.test_e
4bf0: 78 70 72 20 65 78 70 72 2d 36 2e 35 20 7b 74 31  xpr expr-6.5 {t1
4c00: 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 62 63 3f  ='abc', t2='abc?
4c10: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
4c20: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
4c30: 2d 36 2e 36 20 7b 74 31 3d 27 61 62 63 27 2c 20  -6.6 {t1='abc', 
4c40: 74 32 3d 27 41 2a 43 27 7d 20 7b 74 31 20 47 4c  t2='A*C'} {t1 GL
4c50: 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  OB t2} 0.test_ex
4c60: 70 72 20 65 78 70 72 2d 36 2e 37 20 7b 74 31 3d  pr expr-6.7 {t1=
4c70: 27 61 62 63 27 2c 20 74 32 3d 27 61 2a 63 27 7d  'abc', t2='a*c'}
4c80: 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a   {t1 GLOB t2} 1.
4c90: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
4ca0: 2e 38 20 7b 74 31 3d 27 61 62 78 79 7a 7a 79 63  .8 {t1='abxyzzyc
4cb0: 27 2c 20 74 32 3d 27 61 2a 63 27 7d 20 7b 74 31  ', t2='a*c'} {t1
4cc0: 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74   GLOB t2} 1.test
4cd0: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 39 20 7b  _expr expr-6.9 {
4ce0: 74 31 3d 27 61 62 78 79 7a 7a 79 27 2c 20 74 32  t1='abxyzzy', t2
4cf0: 3d 27 61 2a 63 27 7d 20 7b 74 31 20 47 4c 4f 42  ='a*c'} {t1 GLOB
4d00: 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72   t2} 0.test_expr
4d10: 20 65 78 70 72 2d 36 2e 31 30 20 7b 74 31 3d 27   expr-6.10 {t1='
4d20: 61 62 78 79 7a 7a 79 63 78 27 2c 20 74 32 3d 27  abxyzzycx', t2='
4d30: 61 2a 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  a*c'} {t1 GLOB t
4d40: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
4d50: 78 70 72 2d 36 2e 31 31 20 7b 74 31 3d 27 61 62  xpr-6.11 {t1='ab
4d60: 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74  c', t2='xyz'} {t
4d70: 31 20 4e 4f 54 20 47 4c 4f 42 20 74 32 7d 20 31  1 NOT GLOB t2} 1
4d80: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
4d90: 36 2e 31 32 20 7b 74 31 3d 27 61 62 63 27 2c 20  6.12 {t1='abc', 
4da0: 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 20 4e 4f  t2='abc'} {t1 NO
4db0: 54 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73  T GLOB t2} 0.tes
4dc0: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 31 33  t_expr expr-6.13
4dd0: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27   {t1='abc', t2='
4de0: 61 5b 62 78 5d 63 27 7d 20 7b 74 31 20 47 4c 4f  a[bx]c'} {t1 GLO
4df0: 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70  B t2} 1.test_exp
4e00: 72 20 65 78 70 72 2d 36 2e 31 34 20 7b 74 31 3d  r expr-6.14 {t1=
4e10: 27 61 62 63 27 2c 20 74 32 3d 27 61 5b 63 78 5d  'abc', t2='a[cx]
4e20: 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  c'} {t1 GLOB t2}
4e30: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
4e40: 72 2d 36 2e 31 35 20 7b 74 31 3d 27 61 62 63 27  r-6.15 {t1='abc'
4e50: 2c 20 74 32 3d 27 61 5b 61 2d 64 5d 63 27 7d 20  , t2='a[a-d]c'} 
4e60: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74  {t1 GLOB t2} 1.t
4e70: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
4e80: 31 36 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  16 {t1='abc', t2
4e90: 3d 27 61 5b 5e 61 2d 64 5d 63 27 7d 20 7b 74 31  ='a[^a-d]c'} {t1
4ea0: 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74   GLOB t2} 0.test
4eb0: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 31 37 20  _expr expr-6.17 
4ec0: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61  {t1='abc', t2='a
4ed0: 5b 41 2d 44 63 5d 63 27 7d 20 7b 74 31 20 47 4c  [A-Dc]c'} {t1 GL
4ee0: 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  OB t2} 0.test_ex
4ef0: 70 72 20 65 78 70 72 2d 36 2e 31 38 20 7b 74 31  pr expr-6.18 {t1
4f00: 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 5b 5e 41  ='abc', t2='a[^A
4f10: 2d 44 63 5d 63 27 7d 20 7b 74 31 20 47 4c 4f 42  -Dc]c'} {t1 GLOB
4f20: 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72   t2} 1.test_expr
4f30: 20 65 78 70 72 2d 36 2e 31 39 20 7b 74 31 3d 27   expr-6.19 {t1='
4f40: 61 62 63 27 2c 20 74 32 3d 27 61 5b 5d 62 5d 63  abc', t2='a[]b]c
4f50: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
4f60: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
4f70: 2d 36 2e 32 30 20 7b 74 31 3d 27 61 62 63 27 2c  -6.20 {t1='abc',
4f80: 20 74 32 3d 27 61 5b 5e 5d 62 5d 63 27 7d 20 7b   t2='a[^]b]c'} {
4f90: 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65  t1 GLOB t2} 0.te
4fa0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 32  st_expr expr-6.2
4fb0: 31 61 20 7b 74 31 3d 27 61 62 63 64 65 66 67 27  1a {t1='abcdefg'
4fc0: 2c 20 74 32 3d 27 61 2a 5b 64 65 5d 67 27 7d 20  , t2='a*[de]g'} 
4fd0: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74  {t1 GLOB t2} 0.t
4fe0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
4ff0: 32 31 62 20 7b 74 31 3d 27 61 62 63 64 65 66 67  21b {t1='abcdefg
5000: 27 2c 20 74 32 3d 27 61 2a 5b 64 66 5d 67 27 7d  ', t2='a*[df]g'}
5010: 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a   {t1 GLOB t2} 1.
5020: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5030: 2e 32 31 63 20 7b 74 31 3d 27 61 62 63 64 65 66  .21c {t1='abcdef
5040: 67 27 2c 20 74 32 3d 27 61 2a 5b 64 2d 68 5d 67  g', t2='a*[d-h]g
5050: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
5060: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
5070: 2d 36 2e 32 31 64 20 7b 74 31 3d 27 61 62 63 64  -6.21d {t1='abcd
5080: 65 66 67 27 2c 20 74 32 3d 27 61 2a 5b 62 2d 65  efg', t2='a*[b-e
5090: 5d 67 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32  ]g'} {t1 GLOB t2
50a0: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
50b0: 70 72 2d 36 2e 32 32 61 20 7b 74 31 3d 27 61 62  pr-6.22a {t1='ab
50c0: 63 64 65 66 67 27 2c 20 74 32 3d 27 61 2a 5b 5e  cdefg', t2='a*[^
50d0: 64 65 5d 67 27 7d 20 7b 74 31 20 47 4c 4f 42 20  de]g'} {t1 GLOB 
50e0: 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  t2} 1.test_expr 
50f0: 65 78 70 72 2d 36 2e 32 32 62 20 7b 74 31 3d 27  expr-6.22b {t1='
5100: 61 62 63 64 65 66 67 27 2c 20 74 32 3d 27 61 2a  abcdefg', t2='a*
5110: 5b 5e 64 65 66 5d 67 27 7d 20 7b 74 31 20 47 4c  [^def]g'} {t1 GL
5120: 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  OB t2} 0.test_ex
5130: 70 72 20 65 78 70 72 2d 36 2e 32 33 20 7b 74 31  pr expr-6.23 {t1
5140: 3d 27 61 62 63 64 65 66 67 27 2c 20 74 32 3d 27  ='abcdefg', t2='
5150: 61 2a 3f 67 27 7d 20 7b 74 31 20 47 4c 4f 42 20  a*?g'} {t1 GLOB 
5160: 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  t2} 1.test_expr 
5170: 65 78 70 72 2d 36 2e 32 34 20 7b 74 31 3d 27 61  expr-6.24 {t1='a
5180: 63 27 2c 20 74 32 3d 27 61 2a 63 27 7d 20 7b 74  c', t2='a*c'} {t
5190: 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73  1 GLOB t2} 1.tes
51a0: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 32 35  t_expr expr-6.25
51b0: 20 7b 74 31 3d 27 61 63 27 2c 20 74 32 3d 27 61   {t1='ac', t2='a
51c0: 2a 3f 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  *?c'} {t1 GLOB t
51d0: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
51e0: 78 70 72 2d 36 2e 32 36 20 7b 74 31 3d 27 61 2a  xpr-6.26 {t1='a*
51f0: 63 27 2c 20 74 32 3d 27 61 5b 2a 5d 63 27 7d 20  c', t2='a[*]c'} 
5200: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74  {t1 GLOB t2} 1.t
5210: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
5220: 32 37 20 7b 74 31 3d 27 61 3f 63 27 2c 20 74 32  27 {t1='a?c', t2
5230: 3d 27 61 5b 3f 5d 63 27 7d 20 7b 74 31 20 47 4c  ='a[?]c'} {t1 GL
5240: 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78  OB t2} 1.test_ex
5250: 70 72 20 65 78 70 72 2d 36 2e 32 38 20 7b 74 31  pr expr-6.28 {t1
5260: 3d 27 61 5b 63 27 2c 20 74 32 3d 27 61 5b 5b 5d  ='a[c', t2='a[[]
5270: 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  c'} {t1 GLOB t2}
5280: 20 31 0a 0a 0a 23 20 54 68 65 73 65 20 74 65 73   1...# These tes
5290: 74 73 20 6f 6e 6c 79 20 77 6f 72 6b 20 6f 6e 20  ts only work on 
52a0: 76 65 72 73 69 6f 6e 73 20 6f 66 20 54 43 4c 20  versions of TCL 
52b0: 74 68 61 74 20 73 75 70 70 6f 72 74 20 55 6e 69  that support Uni
52c0: 63 6f 64 65 0a 23 0a 69 66 20 7b 22 5c 75 31 32  code.#.if {"\u12
52d0: 33 34 22 21 3d 22 75 31 32 33 34 22 7d 20 7b 0a  34"!="u1234"} {.
52e0: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
52f0: 2d 36 2e 32 36 20 22 74 31 3d 27 61 5c 75 30 30  -6.26 "t1='a\u00
5300: 38 30 63 27 2c 20 74 32 3d 27 61 3f 63 27 22 20  80c', t2='a?c'" 
5310: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20  {t1 GLOB t2} 1. 
5320: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
5330: 36 2e 32 37 20 22 74 31 3d 27 61 5c 75 30 37 66  6.27 "t1='a\u07f
5340: 66 63 27 2c 20 74 32 3d 27 61 3f 63 27 22 20 7b  fc', t2='a?c'" {
5350: 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20  t1 GLOB t2} 1.  
5360: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5370: 2e 32 38 20 22 74 31 3d 27 61 5c 75 30 38 30 30  .28 "t1='a\u0800
5380: 63 27 2c 20 74 32 3d 27 61 3f 63 27 22 20 7b 74  c', t2='a?c'" {t
5390: 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20 74  1 GLOB t2} 1.  t
53a0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
53b0: 32 39 20 22 74 31 3d 27 61 5c 75 66 66 66 66 63  29 "t1='a\uffffc
53c0: 27 2c 20 74 32 3d 27 61 3f 63 27 22 20 7b 74 31  ', t2='a?c'" {t1
53d0: 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20 74 65   GLOB t2} 1.  te
53e0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 33  st_expr expr-6.3
53f0: 30 20 22 74 31 3d 27 61 5c 75 31 32 33 34 27 2c  0 "t1='a\u1234',
5400: 20 74 32 3d 27 61 3f 27 22 20 7b 74 31 20 47 4c   t2='a?'" {t1 GL
5410: 4f 42 20 74 32 7d 20 31 0a 20 20 74 65 73 74 5f  OB t2} 1.  test_
5420: 65 78 70 72 20 65 78 70 72 2d 36 2e 33 31 20 22  expr expr-6.31 "
5430: 74 31 3d 27 61 5c 75 31 32 33 34 27 2c 20 74 32  t1='a\u1234', t2
5440: 3d 27 61 3f 3f 27 22 20 7b 74 31 20 47 4c 4f 42  ='a??'" {t1 GLOB
5450: 20 74 32 7d 20 30 0a 20 20 74 65 73 74 5f 65 78   t2} 0.  test_ex
5460: 70 72 20 65 78 70 72 2d 36 2e 33 32 20 22 74 31  pr expr-6.32 "t1
5470: 3d 27 61 78 5c 75 31 32 33 34 27 2c 20 74 32 3d  ='ax\u1234', t2=
5480: 27 61 3f 5c 75 31 32 33 34 27 22 20 7b 74 31 20  'a?\u1234'" {t1 
5490: 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20 74 65 73  GLOB t2} 1.  tes
54a0: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 33 33  t_expr expr-6.33
54b0: 20 22 74 31 3d 27 61 78 5c 75 31 32 33 34 27 2c   "t1='ax\u1234',
54c0: 20 74 32 3d 27 61 2a 5c 75 31 32 33 34 27 22 20   t2='a*\u1234'" 
54d0: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20  {t1 GLOB t2} 1. 
54e0: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
54f0: 36 2e 33 34 20 22 74 31 3d 27 61 78 5c 75 31 32  6.34 "t1='ax\u12
5500: 33 34 79 5c 75 31 32 33 34 27 2c 20 74 32 3d 27  34y\u1234', t2='
5510: 61 2a 5c 75 31 32 33 34 27 22 20 7b 74 31 20 47  a*\u1234'" {t1 G
5520: 4c 4f 42 20 74 32 7d 20 31 0a 20 20 74 65 73 74  LOB t2} 1.  test
5530: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 33 35 20  _expr expr-6.35 
5540: 22 74 31 3d 27 61 5c 75 31 32 33 34 62 27 2c 20  "t1='a\u1234b', 
5550: 74 32 3d 27 61 5c 5b 78 5c 75 31 32 33 34 79 5c  t2='a\[x\u1234y\
5560: 5d 62 27 22 20 7b 74 31 20 47 4c 4f 42 20 74 32  ]b'" {t1 GLOB t2
5570: 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20  } 1.  test_expr 
5580: 65 78 70 72 2d 36 2e 33 36 20 22 74 31 3d 27 61  expr-6.36 "t1='a
5590: 5c 75 31 32 33 34 62 27 2c 20 74 32 3d 27 61 5c  \u1234b', t2='a\
55a0: 5b 5c 75 31 32 33 33 2d 5c 75 31 32 33 35 5c 5d  [\u1233-\u1235\]
55b0: 62 27 22 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  b'" {t1 GLOB t2}
55c0: 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   1.  test_expr e
55d0: 78 70 72 2d 36 2e 33 37 20 22 74 31 3d 27 61 5c  xpr-6.37 "t1='a\
55e0: 75 31 32 33 34 62 27 2c 20 74 32 3d 27 61 5c 5b  u1234b', t2='a\[
55f0: 5c 75 31 32 33 34 2d 5c 75 31 32 34 66 5c 5d 62  \u1234-\u124f\]b
5600: 27 22 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '" {t1 GLOB t2} 
5610: 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  1.  test_expr ex
5620: 70 72 2d 36 2e 33 38 20 22 74 31 3d 27 61 5c 75  pr-6.38 "t1='a\u
5630: 31 32 33 34 62 27 2c 20 74 32 3d 27 61 5c 5b 5c  1234b', t2='a\[\
5640: 75 31 32 33 35 2d 5c 75 31 32 34 66 5c 5d 62 27  u1235-\u124f\]b'
5650: 22 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30  " {t1 GLOB t2} 0
5660: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
5670: 72 2d 36 2e 33 39 20 22 74 31 3d 27 61 5c 75 31  r-6.39 "t1='a\u1
5680: 32 33 34 62 27 2c 20 74 32 3d 27 61 5c 5b 61 2d  234b', t2='a\[a-
5690: 5c 75 31 32 33 35 5c 5d 62 27 22 20 7b 74 31 20  \u1235\]b'" {t1 
56a0: 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20 74 65 73  GLOB t2} 1.  tes
56b0: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 34 30  t_expr expr-6.40
56c0: 20 22 74 31 3d 27 61 5c 75 31 32 33 34 62 27 2c   "t1='a\u1234b',
56d0: 20 74 32 3d 27 61 5c 5b 61 2d 5c 75 31 32 33 34   t2='a\[a-\u1234
56e0: 5c 5d 62 27 22 20 7b 74 31 20 47 4c 4f 42 20 74  \]b'" {t1 GLOB t
56f0: 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72  2} 1.  test_expr
5700: 20 65 78 70 72 2d 36 2e 34 31 20 22 74 31 3d 27   expr-6.41 "t1='
5710: 61 5c 75 31 32 33 34 62 27 2c 20 74 32 3d 27 61  a\u1234b', t2='a
5720: 5c 5b 61 2d 5c 75 31 32 33 33 5c 5d 62 27 22 20  \[a-\u1233\]b'" 
5730: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 7d  {t1 GLOB t2} 0.}
5740: 0a 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  ..test_expr expr
5750: 2d 36 2e 35 31 20 7b 74 31 3d 27 41 42 43 27 2c  -6.51 {t1='ABC',
5760: 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74 31 20 47   t2='xyz'} {t1 G
5770: 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65  LOB t2} 0.test_e
5780: 78 70 72 20 65 78 70 72 2d 36 2e 35 32 20 7b 74  xpr expr-6.52 {t
5790: 31 3d 27 41 42 43 27 2c 20 74 32 3d 27 61 62 63  1='ABC', t2='abc
57a0: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
57b0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
57c0: 2d 36 2e 35 33 20 7b 74 31 3d 27 41 42 43 27 2c  -6.53 {t1='ABC',
57d0: 20 74 32 3d 27 61 3f 63 27 7d 20 7b 74 31 20 47   t2='a?c'} {t1 G
57e0: 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65  LOB t2} 0.test_e
57f0: 78 70 72 20 65 78 70 72 2d 36 2e 35 34 20 7b 74  xpr expr-6.54 {t
5800: 31 3d 27 41 42 43 27 2c 20 74 32 3d 27 41 3f 43  1='ABC', t2='A?C
5810: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
5820: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
5830: 2d 36 2e 35 35 20 7b 74 31 3d 27 41 42 43 27 2c  -6.55 {t1='ABC',
5840: 20 74 32 3d 27 61 62 63 3f 27 7d 20 7b 74 31 20   t2='abc?'} {t1 
5850: 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f  GLOB t2} 0.test_
5860: 65 78 70 72 20 65 78 70 72 2d 36 2e 35 36 20 7b  expr expr-6.56 {
5870: 74 31 3d 27 41 42 43 27 2c 20 74 32 3d 27 61 2a  t1='ABC', t2='a*
5880: 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  c'} {t1 GLOB t2}
5890: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
58a0: 72 2d 36 2e 35 37 20 7b 74 31 3d 27 41 42 43 27  r-6.57 {t1='ABC'
58b0: 2c 20 74 32 3d 27 41 2a 43 27 7d 20 7b 74 31 20  , t2='A*C'} {t1 
58c0: 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f  GLOB t2} 1.test_
58d0: 65 78 70 72 20 65 78 70 72 2d 36 2e 35 38 20 7b  expr expr-6.58 {
58e0: 74 31 3d 27 41 42 78 79 7a 7a 79 43 27 2c 20 74  t1='ABxyzzyC', t
58f0: 32 3d 27 41 2a 43 27 7d 20 7b 74 31 20 47 4c 4f  2='A*C'} {t1 GLO
5900: 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70  B t2} 1.test_exp
5910: 72 20 65 78 70 72 2d 36 2e 35 39 20 7b 74 31 3d  r expr-6.59 {t1=
5920: 27 41 42 78 79 7a 7a 79 27 2c 20 74 32 3d 27 41  'ABxyzzy', t2='A
5930: 2a 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32  *C'} {t1 GLOB t2
5940: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
5950: 70 72 2d 36 2e 36 30 20 7b 74 31 3d 27 41 42 78  pr-6.60 {t1='ABx
5960: 79 7a 7a 79 43 78 27 2c 20 74 32 3d 27 41 2a 43  yzzyCx', t2='A*C
5970: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
5980: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
5990: 2d 36 2e 36 31 20 7b 74 31 3d 27 41 42 43 27 2c  -6.61 {t1='ABC',
59a0: 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74 31 20 4e   t2='xyz'} {t1 N
59b0: 4f 54 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65  OT GLOB t2} 1.te
59c0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 36  st_expr expr-6.6
59d0: 32 20 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d  2 {t1='ABC', t2=
59e0: 27 41 42 43 27 7d 20 7b 74 31 20 4e 4f 54 20 47  'ABC'} {t1 NOT G
59f0: 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65  LOB t2} 0.test_e
5a00: 78 70 72 20 65 78 70 72 2d 36 2e 36 33 20 7b 74  xpr expr-6.63 {t
5a10: 31 3d 27 41 42 43 27 2c 20 74 32 3d 27 41 5b 42  1='ABC', t2='A[B
5a20: 78 5d 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  x]C'} {t1 GLOB t
5a30: 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 1.test_expr e
5a40: 78 70 72 2d 36 2e 36 34 20 7b 74 31 3d 27 41 42  xpr-6.64 {t1='AB
5a50: 43 27 2c 20 74 32 3d 27 41 5b 43 78 5d 43 27 7d  C', t2='A[Cx]C'}
5a60: 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a   {t1 GLOB t2} 0.
5a70: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5a80: 2e 36 35 20 7b 74 31 3d 27 41 42 43 27 2c 20 74  .65 {t1='ABC', t
5a90: 32 3d 27 41 5b 41 2d 44 5d 43 27 7d 20 7b 74 31  2='A[A-D]C'} {t1
5aa0: 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74   GLOB t2} 1.test
5ab0: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 36 36 20  _expr expr-6.66 
5ac0: 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d 27 41  {t1='ABC', t2='A
5ad0: 5b 5e 41 2d 44 5d 43 27 7d 20 7b 74 31 20 47 4c  [^A-D]C'} {t1 GL
5ae0: 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  OB t2} 0.test_ex
5af0: 70 72 20 65 78 70 72 2d 36 2e 36 37 20 7b 74 31  pr expr-6.67 {t1
5b00: 3d 27 41 42 43 27 2c 20 74 32 3d 27 41 5b 61 2d  ='ABC', t2='A[a-
5b10: 64 43 5d 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20  dC]C'} {t1 GLOB 
5b20: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
5b30: 65 78 70 72 2d 36 2e 36 38 20 7b 74 31 3d 27 41  expr-6.68 {t1='A
5b40: 42 43 27 2c 20 74 32 3d 27 41 5b 5e 61 2d 64 43  BC', t2='A[^a-dC
5b50: 5d 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32  ]C'} {t1 GLOB t2
5b60: 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 1.test_expr ex
5b70: 70 72 2d 36 2e 36 39 61 20 7b 74 31 3d 27 41 42  pr-6.69a {t1='AB
5b80: 43 27 2c 20 74 32 3d 27 41 5b 5d 42 5d 43 27 7d  C', t2='A[]B]C'}
5b90: 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a   {t1 GLOB t2} 1.
5ba0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5bb0: 2e 36 39 62 20 7b 74 31 3d 27 41 5d 43 27 2c 20  .69b {t1='A]C', 
5bc0: 74 32 3d 27 41 5b 5d 42 5d 43 27 7d 20 7b 74 31  t2='A[]B]C'} {t1
5bd0: 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74   GLOB t2} 1.test
5be0: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 37 30 61  _expr expr-6.70a
5bf0: 20 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d 27   {t1='ABC', t2='
5c00: 41 5b 5e 5d 42 5d 43 27 7d 20 7b 74 31 20 47 4c  A[^]B]C'} {t1 GL
5c10: 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  OB t2} 0.test_ex
5c20: 70 72 20 65 78 70 72 2d 36 2e 37 30 62 20 7b 74  pr expr-6.70b {t
5c30: 31 3d 27 41 78 43 27 2c 20 74 32 3d 27 41 5b 5e  1='AxC', t2='A[^
5c40: 5d 42 5d 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20  ]B]C'} {t1 GLOB 
5c50: 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  t2} 1.test_expr 
5c60: 65 78 70 72 2d 36 2e 37 30 63 20 7b 74 31 3d 27  expr-6.70c {t1='
5c70: 41 5d 43 27 2c 20 74 32 3d 27 41 5b 5e 5d 42 5d  A]C', t2='A[^]B]
5c80: 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  C'} {t1 GLOB t2}
5c90: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
5ca0: 72 2d 36 2e 37 31 20 7b 74 31 3d 27 41 42 43 44  r-6.71 {t1='ABCD
5cb0: 45 46 47 27 2c 20 74 32 3d 27 41 2a 5b 44 45 5d  EFG', t2='A*[DE]
5cc0: 47 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  G'} {t1 GLOB t2}
5cd0: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
5ce0: 72 2d 36 2e 37 32 20 7b 74 31 3d 27 41 42 43 44  r-6.72 {t1='ABCD
5cf0: 45 46 47 27 2c 20 74 32 3d 27 41 2a 5b 5e 44 45  EFG', t2='A*[^DE
5d00: 5d 47 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32  ]G'} {t1 GLOB t2
5d10: 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 1.test_expr ex
5d20: 70 72 2d 36 2e 37 33 20 7b 74 31 3d 27 41 42 43  pr-6.73 {t1='ABC
5d30: 44 45 46 47 27 2c 20 74 32 3d 27 41 2a 3f 47 27  DEFG', t2='A*?G'
5d40: 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31  } {t1 GLOB t2} 1
5d50: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
5d60: 36 2e 37 34 20 7b 74 31 3d 27 41 43 27 2c 20 74  6.74 {t1='AC', t
5d70: 32 3d 27 41 2a 43 27 7d 20 7b 74 31 20 47 4c 4f  2='A*C'} {t1 GLO
5d80: 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70  B t2} 1.test_exp
5d90: 72 20 65 78 70 72 2d 36 2e 37 35 20 7b 74 31 3d  r expr-6.75 {t1=
5da0: 27 41 43 27 2c 20 74 32 3d 27 41 2a 3f 43 27 7d  'AC', t2='A*?C'}
5db0: 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a   {t1 GLOB t2} 0.
5dc0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
5dd0: 36 2e 36 33 20 7b 74 31 3d 4e 55 4c 4c 2c 20 74  6.63 {t1=NULL, t
5de0: 32 3d 27 61 2a 3f 63 27 7d 20 7b 74 31 20 47 4c  2='a*?c'} {t1 GL
5df0: 4f 42 20 74 32 7d 20 7b 7b 7d 7d 0a 74 65 73 74  OB t2} {{}}.test
5e00: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 36 34 20  _expr expr-6.64 
5e10: 7b 74 31 3d 27 61 63 27 2c 20 74 32 3d 4e 55 4c  {t1='ac', t2=NUL
5e20: 4c 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  L} {t1 GLOB t2} 
5e30: 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65  {{}}.test_expr e
5e40: 78 70 72 2d 36 2e 36 35 20 7b 74 31 3d 4e 55 4c  xpr-6.65 {t1=NUL
5e50: 4c 2c 20 74 32 3d 27 61 2a 3f 63 27 7d 20 7b 74  L, t2='a*?c'} {t
5e60: 31 20 4e 4f 54 20 47 4c 4f 42 20 74 32 7d 20 7b  1 NOT GLOB t2} {
5e70: 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78  {}}.test_expr ex
5e80: 70 72 2d 36 2e 36 36 20 7b 74 31 3d 27 61 63 27  pr-6.66 {t1='ac'
5e90: 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 74 31 20 4e  , t2=NULL} {t1 N
5ea0: 4f 54 20 47 4c 4f 42 20 74 32 7d 20 7b 7b 7d 7d  OT GLOB t2} {{}}
5eb0: 0a 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  ..test_expr expr
5ec0: 2d 63 61 73 65 2e 31 20 7b 69 31 3d 31 2c 20 69  -case.1 {i1=1, i
5ed0: 32 3d 32 7d 20 5c 0a 09 7b 43 41 53 45 20 57 48  2=2} \..{CASE WH
5ee0: 45 4e 20 69 31 20 3d 20 69 32 20 54 48 45 4e 20  EN i1 = i2 THEN 
5ef0: 27 65 71 27 20 45 4c 53 45 20 27 6e 65 27 20 45  'eq' ELSE 'ne' E
5f00: 4e 44 7d 20 6e 65 0a 74 65 73 74 5f 65 78 70 72  ND} ne.test_expr
5f10: 20 65 78 70 72 2d 63 61 73 65 2e 32 20 7b 69 31   expr-case.2 {i1
5f20: 3d 32 2c 20 69 32 3d 32 7d 20 5c 0a 09 7b 43 41  =2, i2=2} \..{CA
5f30: 53 45 20 57 48 45 4e 20 69 31 20 3d 20 69 32 20  SE WHEN i1 = i2 
5f40: 54 48 45 4e 20 27 65 71 27 20 45 4c 53 45 20 27  THEN 'eq' ELSE '
5f50: 6e 65 27 20 45 4e 44 7d 20 65 71 0a 74 65 73 74  ne' END} eq.test
5f60: 5f 65 78 70 72 20 65 78 70 72 2d 63 61 73 65 2e  _expr expr-case.
5f70: 33 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 32  3 {i1=NULL, i2=2
5f80: 7d 20 5c 0a 09 7b 43 41 53 45 20 57 48 45 4e 20  } \..{CASE WHEN 
5f90: 69 31 20 3d 20 69 32 20 54 48 45 4e 20 27 65 71  i1 = i2 THEN 'eq
5fa0: 27 20 45 4c 53 45 20 27 6e 65 27 20 45 4e 44 7d  ' ELSE 'ne' END}
5fb0: 20 6e 65 0a 74 65 73 74 5f 65 78 70 72 20 65 78   ne.test_expr ex
5fc0: 70 72 2d 63 61 73 65 2e 34 20 7b 69 31 3d 32 2c  pr-case.4 {i1=2,
5fd0: 20 69 32 3d 4e 55 4c 4c 7d 20 5c 0a 09 7b 43 41   i2=NULL} \..{CA
5fe0: 53 45 20 57 48 45 4e 20 69 31 20 3d 20 69 32 20  SE WHEN i1 = i2 
5ff0: 54 48 45 4e 20 27 65 71 27 20 45 4c 53 45 20 27  THEN 'eq' ELSE '
6000: 6e 65 27 20 45 4e 44 7d 20 6e 65 0a 74 65 73 74  ne' END} ne.test
6010: 5f 65 78 70 72 20 65 78 70 72 2d 63 61 73 65 2e  _expr expr-case.
6020: 35 20 7b 69 31 3d 32 7d 20 5c 0a 09 7b 43 41 53  5 {i1=2} \..{CAS
6030: 45 20 69 31 20 57 48 45 4e 20 31 20 54 48 45 4e  E i1 WHEN 1 THEN
6040: 20 27 6f 6e 65 27 20 57 48 45 4e 20 32 20 54 48   'one' WHEN 2 TH
6050: 45 4e 20 27 74 77 6f 27 20 45 4c 53 45 20 27 65  EN 'two' ELSE 'e
6060: 72 72 6f 72 27 20 45 4e 44 7d 20 74 77 6f 0a 74  rror' END} two.t
6070: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 63 61  est_expr expr-ca
6080: 73 65 2e 36 20 7b 69 31 3d 31 7d 20 5c 0a 09 7b  se.6 {i1=1} \..{
6090: 43 41 53 45 20 69 31 20 57 48 45 4e 20 31 20 54  CASE i1 WHEN 1 T
60a0: 48 45 4e 20 27 6f 6e 65 27 20 57 48 45 4e 20 4e  HEN 'one' WHEN N
60b0: 55 4c 4c 20 54 48 45 4e 20 27 74 77 6f 27 20 45  ULL THEN 'two' E
60c0: 4c 53 45 20 27 65 72 72 6f 72 27 20 45 4e 44 7d  LSE 'error' END}
60d0: 20 6f 6e 65 0a 74 65 73 74 5f 65 78 70 72 20 65   one.test_expr e
60e0: 78 70 72 2d 63 61 73 65 2e 37 20 7b 69 31 3d 32  xpr-case.7 {i1=2
60f0: 7d 20 5c 0a 09 7b 43 41 53 45 20 69 31 20 57 48  } \..{CASE i1 WH
6100: 45 4e 20 31 20 54 48 45 4e 20 27 6f 6e 65 27 20  EN 1 THEN 'one' 
6110: 57 48 45 4e 20 4e 55 4c 4c 20 54 48 45 4e 20 27  WHEN NULL THEN '
6120: 74 77 6f 27 20 45 4c 53 45 20 27 65 72 72 6f 72  two' ELSE 'error
6130: 27 20 45 4e 44 7d 20 65 72 72 6f 72 0a 74 65 73  ' END} error.tes
6140: 74 5f 65 78 70 72 20 65 78 70 72 2d 63 61 73 65  t_expr expr-case
6150: 2e 38 20 7b 69 31 3d 33 7d 20 5c 0a 09 7b 43 41  .8 {i1=3} \..{CA
6160: 53 45 20 69 31 20 57 48 45 4e 20 31 20 54 48 45  SE i1 WHEN 1 THE
6170: 4e 20 27 6f 6e 65 27 20 57 48 45 4e 20 4e 55 4c  N 'one' WHEN NUL
6180: 4c 20 54 48 45 4e 20 27 74 77 6f 27 20 45 4c 53  L THEN 'two' ELS
6190: 45 20 27 65 72 72 6f 72 27 20 45 4e 44 7d 20 65  E 'error' END} e
61a0: 72 72 6f 72 0a 74 65 73 74 5f 65 78 70 72 20 65  rror.test_expr e
61b0: 78 70 72 2d 63 61 73 65 2e 39 20 7b 69 31 3d 33  xpr-case.9 {i1=3
61c0: 7d 20 5c 0a 09 7b 43 41 53 45 20 69 31 20 57 48  } \..{CASE i1 WH
61d0: 45 4e 20 31 20 54 48 45 4e 20 27 6f 6e 65 27 20  EN 1 THEN 'one' 
61e0: 57 48 45 4e 20 32 20 54 48 45 4e 20 27 74 77 6f  WHEN 2 THEN 'two
61f0: 27 20 45 4c 53 45 20 27 65 72 72 6f 72 27 20 45  ' ELSE 'error' E
6200: 4e 44 7d 20 65 72 72 6f 72 0a 74 65 73 74 5f 65  ND} error.test_e
6210: 78 70 72 20 65 78 70 72 2d 63 61 73 65 2e 31 30  xpr expr-case.10
6220: 20 7b 69 31 3d 33 7d 20 5c 0a 09 7b 43 41 53 45   {i1=3} \..{CASE
6230: 20 69 31 20 57 48 45 4e 20 31 20 54 48 45 4e 20   i1 WHEN 1 THEN 
6240: 27 6f 6e 65 27 20 57 48 45 4e 20 32 20 54 48 45  'one' WHEN 2 THE
6250: 4e 20 27 74 77 6f 27 20 45 4e 44 7d 20 7b 7b 7d  N 'two' END} {{}
6260: 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  }.test_expr expr
6270: 2d 63 61 73 65 2e 31 31 20 7b 69 31 3d 6e 75 6c  -case.11 {i1=nul
6280: 6c 7d 20 5c 0a 09 7b 43 41 53 45 20 69 31 20 57  l} \..{CASE i1 W
6290: 48 45 4e 20 31 20 54 48 45 4e 20 27 6f 6e 65 27  HEN 1 THEN 'one'
62a0: 20 57 48 45 4e 20 32 20 54 48 45 4e 20 27 74 77   WHEN 2 THEN 'tw
62b0: 6f 27 20 45 4c 53 45 20 33 20 45 4e 44 7d 20 33  o' ELSE 3 END} 3
62c0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
62d0: 63 61 73 65 2e 31 32 20 7b 69 31 3d 31 7d 20 5c  case.12 {i1=1} \
62e0: 0a 09 7b 43 41 53 45 20 69 31 20 57 48 45 4e 20  ..{CASE i1 WHEN 
62f0: 31 20 54 48 45 4e 20 6e 75 6c 6c 20 57 48 45 4e  1 THEN null WHEN
6300: 20 32 20 54 48 45 4e 20 27 74 77 6f 27 20 45 4c   2 THEN 'two' EL
6310: 53 45 20 33 20 45 4e 44 7d 20 7b 7b 7d 7d 0a 74  SE 3 END} {{}}.t
6320: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 63 61  est_expr expr-ca
6330: 73 65 2e 31 33 20 7b 69 31 3d 37 7d 20 5c 0a 09  se.13 {i1=7} \..
6340: 7b 20 43 41 53 45 20 57 48 45 4e 20 69 31 20 3c  { CASE WHEN i1 <
6350: 20 35 20 54 48 45 4e 20 27 6c 6f 77 27 20 0a 09   5 THEN 'low' ..
6360: 20 20 20 20 20 20 20 57 48 45 4e 20 69 31 20 3c         WHEN i1 <
6370: 20 31 30 20 54 48 45 4e 20 27 6d 65 64 69 75 6d   10 THEN 'medium
6380: 27 20 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ' .             
6390: 20 20 57 48 45 4e 20 69 31 20 3c 20 31 35 20 54    WHEN i1 < 15 T
63a0: 48 45 4e 20 27 68 69 67 68 27 20 45 4c 53 45 20  HEN 'high' ELSE 
63b0: 27 65 72 72 6f 72 27 20 45 4e 44 7d 20 6d 65 64  'error' END} med
63c0: 69 75 6d 0a 0a 0a 23 20 54 68 65 20 73 71 6c 69  ium...# The sqli
63d0: 74 65 45 78 70 72 49 66 46 61 6c 73 65 20 61 6e  teExprIfFalse an
63e0: 64 20 73 71 6c 69 74 65 45 78 70 72 49 66 54 72  d sqliteExprIfTr
63f0: 75 65 20 72 6f 75 74 69 6e 65 73 20 61 72 65 20  ue routines are 
6400: 6f 6e 6c 79 0a 23 20 65 78 65 63 75 74 65 64 20  only.# executed 
6410: 61 73 20 70 61 72 74 20 6f 66 20 61 20 57 48 45  as part of a WHE
6420: 52 45 20 63 6c 61 75 73 65 2e 20 20 43 72 65 61  RE clause.  Crea
6430: 74 65 20 61 20 74 61 62 6c 65 20 73 75 69 74 61  te a table suita
6440: 62 6c 65 0a 23 20 66 6f 72 20 74 65 73 74 69 6e  ble.# for testin
6450: 67 20 74 68 65 73 65 20 66 75 6e 63 74 69 6f 6e  g these function
6460: 73 2e 0a 23 0a 65 78 65 63 73 71 6c 20 7b 44 52  s..#.execsql {DR
6470: 4f 50 20 54 41 42 4c 45 20 74 65 73 74 31 7d 0a  OP TABLE test1}.
6480: 65 78 65 63 73 71 6c 20 7b 43 52 45 41 54 45 20  execsql {CREATE 
6490: 54 41 42 4c 45 20 74 65 73 74 31 28 61 20 69 6e  TABLE test1(a in
64a0: 74 2c 20 62 20 69 6e 74 29 3b 7d 0a 66 6f 72 20  t, b int);}.for 
64b0: 7b 73 65 74 20 69 20 31 7d 20 7b 24 69 3c 3d 32  {set i 1} {$i<=2
64c0: 30 7d 20 7b 69 6e 63 72 20 69 7d 20 7b 0a 20 20  0} {incr i} {.  
64d0: 65 78 65 63 73 71 6c 20 22 49 4e 53 45 52 54 20  execsql "INSERT 
64e0: 49 4e 54 4f 20 74 65 73 74 31 20 56 41 4c 55 45  INTO test1 VALUE
64f0: 53 28 24 69 2c 5b 65 78 70 72 20 7b 69 6e 74 28  S($i,[expr {int(
6500: 70 6f 77 28 32 2c 24 69 29 29 7d 5d 29 22 0a 7d  pow(2,$i))}])".}
6510: 0a 65 78 65 63 73 71 6c 20 22 49 4e 53 45 52 54  .execsql "INSERT
6520: 20 49 4e 54 4f 20 74 65 73 74 31 20 56 41 4c 55   INTO test1 VALU
6530: 45 53 28 4e 55 4c 4c 2c 30 29 22 0a 64 6f 5f 74  ES(NULL,0)".do_t
6540: 65 73 74 20 65 78 70 72 2d 37 2e 31 20 7b 0a 20  est expr-7.1 {. 
6550: 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54   execsql {SELECT
6560: 20 2a 20 46 52 4f 4d 20 74 65 73 74 31 20 4f 52   * FROM test1 OR
6570: 44 45 52 20 42 59 20 61 7d 0a 7d 20 7b 7b 7d 20  DER BY a}.} {{} 
6580: 30 20 31 20 32 20 32 20 34 20 33 20 38 20 34 20  0 1 2 2 4 3 8 4 
6590: 31 36 20 35 20 33 32 20 36 20 36 34 20 37 20 31  16 5 32 6 64 7 1
65a0: 32 38 20 38 20 32 35 36 20 39 20 35 31 32 20 31  28 8 256 9 512 1
65b0: 30 20 31 30 32 34 20 31 31 20 32 30 34 38 20 31  0 1024 11 2048 1
65c0: 32 20 34 30 39 36 20 31 33 20 38 31 39 32 20 31  2 4096 13 8192 1
65d0: 34 20 31 36 33 38 34 20 31 35 20 33 32 37 36 38  4 16384 15 32768
65e0: 20 31 36 20 36 35 35 33 36 20 31 37 20 31 33 31   16 65536 17 131
65f0: 30 37 32 20 31 38 20 32 36 32 31 34 34 20 31 39  072 18 262144 19
6600: 20 35 32 34 32 38 38 20 32 30 20 31 30 34 38 35   524288 20 10485
6610: 37 36 7d 0a 0a 70 72 6f 63 20 74 65 73 74 5f 65  76}..proc test_e
6620: 78 70 72 32 20 7b 6e 61 6d 65 20 65 78 70 72 20  xpr2 {name expr 
6630: 72 65 73 75 6c 74 7d 20 7b 0a 20 20 64 6f 5f 74  result} {.  do_t
6640: 65 73 74 20 24 6e 61 6d 65 20 5b 66 6f 72 6d 61  est $name [forma
6650: 74 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  t {.    execsql 
6660: 7b 53 45 4c 45 43 54 20 61 20 46 52 4f 4d 20 74  {SELECT a FROM t
6670: 65 73 74 31 20 57 48 45 52 45 20 25 73 20 4f 52  est1 WHERE %s OR
6680: 44 45 52 20 42 59 20 61 7d 0a 20 20 7d 20 24 65  DER BY a}.  } $e
6690: 78 70 72 5d 20 24 72 65 73 75 6c 74 0a 7d 0a 0a  xpr] $result.}..
66a0: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
66b0: 37 2e 32 20 20 7b 61 3c 31 30 20 41 4e 44 20 61  7.2  {a<10 AND a
66c0: 3e 38 7d 20 20 20 20 20 20 20 20 20 20 20 20 20  >8}             
66d0: 20 20 20 20 20 7b 39 7d 0a 74 65 73 74 5f 65 78       {9}.test_ex
66e0: 70 72 32 20 65 78 70 72 2d 37 2e 33 20 20 7b 61  pr2 expr-7.3  {a
66f0: 3c 3d 31 30 20 41 4e 44 20 61 3e 3d 38 7d 20 20  <=10 AND a>=8}  
6700: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 38                {8
6710: 20 39 20 31 30 7d 0a 74 65 73 74 5f 65 78 70 72   9 10}.test_expr
6720: 32 20 65 78 70 72 2d 37 2e 34 20 20 7b 61 3e 3d  2 expr-7.4  {a>=
6730: 38 20 41 4e 44 20 61 3c 3d 31 30 7d 20 20 20 20  8 AND a<=10}    
6740: 20 20 20 20 20 20 20 20 20 20 20 20 7b 38 20 39              {8 9
6750: 20 31 30 7d 0a 74 65 73 74 5f 65 78 70 72 32 20   10}.test_expr2 
6760: 65 78 70 72 2d 37 2e 35 20 20 7b 61 3e 3d 32 30  expr-7.5  {a>=20
6770: 20 4f 52 20 61 3c 3d 31 7d 20 20 20 20 20 20 20   OR a<=1}       
6780: 20 20 20 20 20 20 20 20 20 20 7b 31 20 32 30 7d            {1 20}
6790: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
67a0: 2d 37 2e 36 20 20 7b 62 21 3d 34 20 41 4e 44 20  -7.6  {b!=4 AND 
67b0: 61 3c 3d 33 7d 20 20 20 20 20 20 20 20 20 20 20  a<=3}           
67c0: 20 20 20 20 20 20 7b 31 20 33 7d 0a 74 65 73 74        {1 3}.test
67d0: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 37 20  _expr2 expr-7.7 
67e0: 20 7b 62 3d 3d 38 20 4f 52 20 62 3d 3d 31 36 20   {b==8 OR b==16 
67f0: 4f 52 20 62 3d 3d 33 32 7d 20 20 20 20 20 20 20  OR b==32}       
6800: 20 7b 33 20 34 20 35 7d 0a 74 65 73 74 5f 65 78   {3 4 5}.test_ex
6810: 70 72 32 20 65 78 70 72 2d 37 2e 38 20 20 7b 4e  pr2 expr-7.8  {N
6820: 4f 54 20 62 3c 3e 38 20 4f 52 20 62 3d 3d 31 30  OT b<>8 OR b==10
6830: 32 34 7d 20 20 20 20 20 20 20 20 20 20 20 7b 33  24}           {3
6840: 20 31 30 7d 0a 74 65 73 74 5f 65 78 70 72 32 20   10}.test_expr2 
6850: 65 78 70 72 2d 37 2e 39 20 20 7b 62 20 4c 49 4b  expr-7.9  {b LIK
6860: 45 20 27 31 30 25 27 7d 20 20 20 20 20 20 20 20  E '10%'}        
6870: 20 20 20 20 20 20 20 20 20 20 7b 31 30 20 32 30            {10 20
6880: 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70  }.test_expr2 exp
6890: 72 2d 37 2e 31 30 20 7b 62 20 4c 49 4b 45 20 27  r-7.10 {b LIKE '
68a0: 5f 34 27 7d 20 20 20 20 20 20 20 20 20 20 20 20  _4'}            
68b0: 20 20 20 20 20 20 20 7b 36 7d 0a 74 65 73 74 5f         {6}.test_
68c0: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 31 31 20  expr2 expr-7.11 
68d0: 7b 61 20 47 4c 4f 42 20 27 31 3f 27 7d 20 20 20  {a GLOB '1?'}   
68e0: 20 20 20 20 20 20 20 20 20 7b 31 30 20 31 31 20           {10 11 
68f0: 31 32 20 31 33 20 31 34 20 31 35 20 31 36 20 31  12 13 14 15 16 1
6900: 37 20 31 38 20 31 39 7d 0a 74 65 73 74 5f 65 78  7 18 19}.test_ex
6910: 70 72 32 20 65 78 70 72 2d 37 2e 31 32 20 7b 62  pr2 expr-7.12 {b
6920: 20 47 4c 4f 42 20 27 31 2a 34 27 7d 20 20 20 20   GLOB '1*4'}    
6930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 31                {1
6940: 30 20 31 34 7d 0a 74 65 73 74 5f 65 78 70 72 32  0 14}.test_expr2
6950: 20 65 78 70 72 2d 37 2e 31 33 20 7b 62 20 47 4c   expr-7.13 {b GL
6960: 4f 42 20 27 2a 31 5b 34 35 36 5d 27 7d 20 20 20  OB '*1[456]'}   
6970: 20 20 20 20 20 20 20 20 20 20 20 7b 34 7d 0a 74             {4}.t
6980: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
6990: 2e 31 34 20 7b 61 20 49 53 4e 55 4c 4c 7d 20 20  .14 {a ISNULL}  
69a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
69b0: 20 20 20 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78      {{}}.test_ex
69c0: 70 72 32 20 65 78 70 72 2d 37 2e 31 35 20 7b 61  pr2 expr-7.15 {a
69d0: 20 4e 4f 54 4e 55 4c 4c 20 41 4e 44 20 61 3c 33   NOTNULL AND a<3
69e0: 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 31  }             {1
69f0: 20 32 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65   2}.test_expr2 e
6a00: 78 70 72 2d 37 2e 31 36 20 7b 61 20 41 4e 44 20  xpr-7.16 {a AND 
6a10: 61 3c 33 7d 20 20 20 20 20 20 20 20 20 20 20 20  a<3}            
6a20: 20 20 20 20 20 20 20 20 20 7b 31 20 32 7d 0a 74           {1 2}.t
6a30: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
6a40: 2e 31 37 20 7b 4e 4f 54 20 61 7d 20 20 20 20 20  .17 {NOT a}     
6a50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6a60: 20 20 20 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72      {}.test_expr
6a70: 32 20 65 78 70 72 2d 37 2e 31 38 20 7b 61 3d 3d  2 expr-7.18 {a==
6a80: 31 31 20 4f 52 20 28 62 3e 31 30 30 30 20 41 4e  11 OR (b>1000 AN
6a90: 44 20 62 3c 32 30 30 30 29 7d 20 20 7b 31 30 20  D b<2000)}  {10 
6aa0: 31 31 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65  11}.test_expr2 e
6ab0: 78 70 72 2d 37 2e 31 39 20 7b 61 3c 3d 31 20 4f  xpr-7.19 {a<=1 O
6ac0: 52 20 61 3e 3d 32 30 7d 20 20 20 20 20 20 20 20  R a>=20}        
6ad0: 20 20 20 20 20 20 20 20 20 7b 31 20 32 30 7d 0a           {1 20}.
6ae0: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
6af0: 37 2e 32 30 20 7b 61 3c 31 20 4f 52 20 61 3e 32  7.20 {a<1 OR a>2
6b00: 30 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20  0}              
6b10: 20 20 20 20 20 7b 7d 0a 74 65 73 74 5f 65 78 70       {}.test_exp
6b20: 72 32 20 65 78 70 72 2d 37 2e 32 31 20 7b 61 3e  r2 expr-7.21 {a>
6b30: 31 39 20 4f 52 20 61 3c 31 7d 20 20 20 20 20 20  19 OR a<1}      
6b40: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 32 30               {20
6b50: 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70  }.test_expr2 exp
6b60: 72 2d 37 2e 32 32 20 7b 61 21 3d 31 20 4f 52 20  r-7.22 {a!=1 OR 
6b70: 61 3d 31 30 30 7d 20 5c 0a 20 20 20 20 20 20 20  a=100} \.       
6b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6b90: 20 20 7b 32 20 33 20 34 20 35 20 36 20 37 20 38    {2 3 4 5 6 7 8
6ba0: 20 39 20 31 30 20 31 31 20 31 32 20 31 33 20 31   9 10 11 12 13 1
6bb0: 34 20 31 35 20 31 36 20 31 37 20 31 38 20 31 39  4 15 16 17 18 19
6bc0: 20 32 30 7d 0a 74 65 73 74 5f 65 78 70 72 32 20   20}.test_expr2 
6bd0: 65 78 70 72 2d 37 2e 32 33 20 7b 28 61 20 6e 6f  expr-7.23 {(a no
6be0: 74 6e 75 6c 6c 20 41 4e 44 20 61 3c 34 29 20 4f  tnull AND a<4) O
6bf0: 52 20 61 3d 3d 38 7d 20 20 20 7b 31 20 32 20 33  R a==8}   {1 2 3
6c00: 20 38 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65   8}.test_expr2 e
6c10: 78 70 72 2d 37 2e 32 34 20 7b 61 20 4c 49 4b 45  xpr-7.24 {a LIKE
6c20: 20 27 32 5f 27 20 4f 52 20 61 3d 3d 38 7d 20 20   '2_' OR a==8}  
6c30: 20 20 20 20 20 20 20 20 20 7b 38 20 32 30 7d 0a           {8 20}.
6c40: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
6c50: 37 2e 32 35 20 7b 61 20 47 4c 4f 42 20 27 32 3f  7.25 {a GLOB '2?
6c60: 27 20 4f 52 20 61 3d 3d 38 7d 20 20 20 20 20 20  ' OR a==8}      
6c70: 20 20 20 20 20 7b 38 20 32 30 7d 0a 74 65 73 74       {8 20}.test
6c80: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 32 36  _expr2 expr-7.26
6c90: 20 7b 61 20 69 73 6e 75 6c 6c 20 4f 52 20 61 3d   {a isnull OR a=
6ca0: 38 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20  8}              
6cb0: 20 7b 7b 7d 20 38 7d 0a 74 65 73 74 5f 65 78 70   {{} 8}.test_exp
6cc0: 72 32 20 65 78 70 72 2d 37 2e 32 37 20 7b 61 20  r2 expr-7.27 {a 
6cd0: 6e 6f 74 6e 75 6c 6c 20 4f 52 20 61 3d 38 7d 20  notnull OR a=8} 
6ce0: 5c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  \.              
6cf0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 31 20 32              {1 2
6d00: 20 33 20 34 20 35 20 36 20 37 20 38 20 39 20 31   3 4 5 6 7 8 9 1
6d10: 30 20 31 31 20 31 32 20 31 33 20 31 34 20 31 35  0 11 12 13 14 15
6d20: 20 31 36 20 31 37 20 31 38 20 31 39 20 32 30 7d   16 17 18 19 20}
6d30: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
6d40: 2d 37 2e 32 38 20 7b 61 3c 30 20 4f 52 20 62 3d  -7.28 {a<0 OR b=
6d50: 30 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70  0} {{}}.test_exp
6d60: 72 32 20 65 78 70 72 2d 37 2e 32 39 20 7b 62 3d  r2 expr-7.29 {b=
6d70: 30 20 4f 52 20 61 3c 30 7d 20 7b 7b 7d 7d 0a 74  0 OR a<0} {{}}.t
6d80: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
6d90: 2e 33 30 20 7b 61 3c 30 20 41 4e 44 20 62 3d 30  .30 {a<0 AND b=0
6da0: 7d 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20  } {}.test_expr2 
6db0: 65 78 70 72 2d 37 2e 33 31 20 7b 62 3d 30 20 41  expr-7.31 {b=0 A
6dc0: 4e 44 20 61 3c 30 7d 20 7b 7d 0a 74 65 73 74 5f  ND a<0} {}.test_
6dd0: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 33 32 20  expr2 expr-7.32 
6de0: 7b 61 20 49 53 20 4e 55 4c 4c 20 41 4e 44 20 28  {a IS NULL AND (
6df0: 61 3c 30 20 4f 52 20 62 3d 30 29 7d 20 7b 7b 7d  a<0 OR b=0)} {{}
6e00: 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70  }.test_expr2 exp
6e10: 72 2d 37 2e 33 33 20 7b 61 20 49 53 20 4e 55 4c  r-7.33 {a IS NUL
6e20: 4c 20 41 4e 44 20 28 62 3d 30 20 4f 52 20 61 3c  L AND (b=0 OR a<
6e30: 30 29 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78  0)} {{}}.test_ex
6e40: 70 72 32 20 65 78 70 72 2d 37 2e 33 34 20 7b 61  pr2 expr-7.34 {a
6e50: 20 49 53 20 4e 55 4c 4c 20 41 4e 44 20 28 61 3c   IS NULL AND (a<
6e60: 30 20 41 4e 44 20 62 3d 30 29 7d 20 7b 7d 0a 74  0 AND b=0)} {}.t
6e70: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
6e80: 2e 33 35 20 7b 61 20 49 53 20 4e 55 4c 4c 20 41  .35 {a IS NULL A
6e90: 4e 44 20 28 62 3d 30 20 41 4e 44 20 61 3c 30 29  ND (b=0 AND a<0)
6ea0: 7d 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20  } {}.test_expr2 
6eb0: 65 78 70 72 2d 37 2e 33 32 20 7b 28 61 3c 30 20  expr-7.32 {(a<0 
6ec0: 4f 52 20 62 3d 30 29 20 41 4e 44 20 61 20 49 53  OR b=0) AND a IS
6ed0: 20 4e 55 4c 4c 7d 20 7b 7b 7d 7d 0a 74 65 73 74   NULL} {{}}.test
6ee0: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 33 33  _expr2 expr-7.33
6ef0: 20 7b 28 62 3d 30 20 4f 52 20 61 3c 30 29 20 41   {(b=0 OR a<0) A
6f00: 4e 44 20 61 20 49 53 20 4e 55 4c 4c 7d 20 7b 7b  ND a IS NULL} {{
6f10: 7d 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  }}.test_expr2 ex
6f20: 70 72 2d 37 2e 33 34 20 7b 28 61 3c 30 20 41 4e  pr-7.34 {(a<0 AN
6f30: 44 20 62 3d 30 29 20 41 4e 44 20 61 20 49 53 20  D b=0) AND a IS 
6f40: 4e 55 4c 4c 7d 20 7b 7d 0a 74 65 73 74 5f 65 78  NULL} {}.test_ex
6f50: 70 72 32 20 65 78 70 72 2d 37 2e 33 35 20 7b 28  pr2 expr-7.35 {(
6f60: 62 3d 30 20 41 4e 44 20 61 3c 30 29 20 41 4e 44  b=0 AND a<0) AND
6f70: 20 61 20 49 53 20 4e 55 4c 4c 7d 20 7b 7d 0a 74   a IS NULL} {}.t
6f80: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
6f90: 2e 33 36 20 7b 61 3c 32 20 4f 52 20 28 61 3c 30  .36 {a<2 OR (a<0
6fa0: 20 4f 52 20 62 3d 30 29 7d 20 7b 7b 7d 20 31 7d   OR b=0)} {{} 1}
6fb0: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
6fc0: 2d 37 2e 33 37 20 7b 61 3c 32 20 4f 52 20 28 62  -7.37 {a<2 OR (b
6fd0: 3d 30 20 4f 52 20 61 3c 30 29 7d 20 7b 7b 7d 20  =0 OR a<0)} {{} 
6fe0: 31 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  1}.test_expr2 ex
6ff0: 70 72 2d 37 2e 33 38 20 7b 61 3c 32 20 4f 52 20  pr-7.38 {a<2 OR 
7000: 28 61 3c 30 20 41 4e 44 20 62 3d 30 29 7d 20 7b  (a<0 AND b=0)} {
7010: 31 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  1}.test_expr2 ex
7020: 70 72 2d 37 2e 33 39 20 7b 61 3c 32 20 4f 52 20  pr-7.39 {a<2 OR 
7030: 28 62 3d 30 20 41 4e 44 20 61 3c 30 29 7d 20 7b  (b=0 AND a<0)} {
7040: 31 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  1}.test_expr2 ex
7050: 70 72 2d 37 2e 34 30 20 7b 28 28 61 3c 32 20 4f  pr-7.40 {((a<2 O
7060: 52 20 61 20 49 53 20 4e 55 4c 4c 29 20 41 4e 44  R a IS NULL) AND
7070: 20 62 3c 33 29 20 4f 52 20 62 3e 31 65 31 30 7d   b<3) OR b>1e10}
7080: 20 7b 7b 7d 20 31 7d 0a 74 65 73 74 5f 65 78 70   {{} 1}.test_exp
7090: 72 32 20 65 78 70 72 2d 37 2e 34 31 20 7b 61 20  r2 expr-7.41 {a 
70a0: 42 45 54 57 45 45 4e 20 2d 31 20 41 4e 44 20 31  BETWEEN -1 AND 1
70b0: 7d 20 7b 31 7d 0a 74 65 73 74 5f 65 78 70 72 32  } {1}.test_expr2
70c0: 20 65 78 70 72 2d 37 2e 34 32 20 7b 61 20 4e 4f   expr-7.42 {a NO
70d0: 54 20 42 45 54 57 45 45 4e 20 32 20 41 4e 44 20  T BETWEEN 2 AND 
70e0: 31 30 30 7d 20 7b 31 7d 0a 74 65 73 74 5f 65 78  100} {1}.test_ex
70f0: 70 72 32 20 65 78 70 72 2d 37 2e 34 33 20 7b 28  pr2 expr-7.43 {(
7100: 62 2b 31 32 33 34 29 7c 7c 27 74 68 69 73 20 69  b+1234)||'this i
7110: 73 20 61 20 73 74 72 69 6e 67 20 74 68 61 74 20  s a string that 
7120: 69 73 20 61 74 20 6c 65 61 73 74 20 33 32 20 63  is at least 32 c
7130: 68 61 72 61 63 74 65 72 73 20 6c 6f 6e 67 27 20  haracters long' 
7140: 42 45 54 57 45 45 4e 20 31 20 41 4e 44 20 32 7d  BETWEEN 1 AND 2}
7150: 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65   {}.test_expr2 e
7160: 78 70 72 2d 37 2e 34 34 20 7b 31 32 33 7c 7c 27  xpr-7.44 {123||'
7170: 78 61 62 63 64 65 66 67 68 69 6a 6b 6c 6d 6e 6f  xabcdefghijklmno
7180: 70 71 72 73 74 75 76 77 79 78 7a 30 31 32 33 34  pqrstuvwyxz01234
7190: 35 36 37 38 39 30 27 7c 7c 61 20 42 45 54 57 45  567890'||a BETWE
71a0: 45 4e 20 27 31 32 33 61 27 20 41 4e 44 20 27 31  EN '123a' AND '1
71b0: 32 33 62 27 7d 20 7b 7d 0a 74 65 73 74 5f 65 78  23b'} {}.test_ex
71c0: 70 72 32 20 65 78 70 72 2d 37 2e 34 35 20 7b 28  pr2 expr-7.45 {(
71d0: 28 31 32 33 7c 7c 27 78 61 62 63 64 65 66 67 68  (123||'xabcdefgh
71e0: 69 6a 6b 6c 6d 6e 6f 70 71 72 73 74 75 76 77 79  ijklmnopqrstuvwy
71f0: 78 7a 30 31 32 33 34 35 36 37 38 39 30 27 7c 7c  xz01234567890'||
7200: 61 29 20 42 45 54 57 45 45 4e 20 27 31 32 33 61  a) BETWEEN '123a
7210: 27 20 41 4e 44 20 27 31 32 33 62 27 29 3c 30 7d  ' AND '123b')<0}
7220: 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65   {}.test_expr2 e
7230: 78 70 72 2d 37 2e 34 36 20 7b 28 28 31 32 33 7c  xpr-7.46 {((123|
7240: 7c 27 78 61 62 63 64 65 66 67 68 69 6a 6b 6c 6d  |'xabcdefghijklm
7250: 6e 6f 70 71 72 73 74 75 76 77 79 78 7a 30 31 32  nopqrstuvwyxz012
7260: 33 34 35 36 37 38 39 30 27 7c 7c 61 29 20 42 45  34567890'||a) BE
7270: 54 57 45 45 4e 20 27 31 32 33 61 27 20 41 4e 44  TWEEN '123a' AND
7280: 20 27 31 32 33 7a 27 29 3e 30 7d 20 7b 31 20 32   '123z')>0} {1 2
7290: 20 33 20 34 20 35 20 36 20 37 20 38 20 39 20 31   3 4 5 6 7 8 9 1
72a0: 30 20 31 31 20 31 32 20 31 33 20 31 34 20 31 35  0 11 12 13 14 15
72b0: 20 31 36 20 31 37 20 31 38 20 31 39 20 32 30 7d   16 17 18 19 20}
72c0: 0a 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70  ..test_expr2 exp
72d0: 72 2d 37 2e 35 30 20 7b 28 28 61 20 62 65 74 77  r-7.50 {((a betw
72e0: 65 65 6e 20 31 20 61 6e 64 20 32 20 4f 52 20 30  een 1 and 2 OR 0
72f0: 29 20 41 4e 44 20 31 29 20 4f 52 20 30 7d 20 7b  ) AND 1) OR 0} {
7300: 31 20 32 7d 0a 74 65 73 74 5f 65 78 70 72 32 20  1 2}.test_expr2 
7310: 65 78 70 72 2d 37 2e 35 31 20 7b 28 28 61 20 6e  expr-7.51 {((a n
7320: 6f 74 20 62 65 74 77 65 65 6e 20 33 20 61 6e 64  ot between 3 and
7330: 20 31 30 30 20 4f 52 20 30 29 20 41 4e 44 20 31   100 OR 0) AND 1
7340: 29 20 4f 52 20 30 7d 20 7b 31 20 32 7d 0a 0a 69  ) OR 0} {1 2}..i
7350: 66 63 61 70 61 62 6c 65 20 73 75 62 71 75 65 72  fcapable subquer
7360: 79 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 32  y {.  test_expr2
7370: 20 65 78 70 72 2d 37 2e 35 32 20 7b 28 28 61 20   expr-7.52 {((a 
7380: 69 6e 20 28 31 2c 32 29 20 4f 52 20 30 29 20 41  in (1,2) OR 0) A
7390: 4e 44 20 31 29 20 4f 52 20 30 7d 20 7b 31 20 32  ND 1) OR 0} {1 2
73a0: 7d 0a 20 20 74 65 73 74 5f 65 78 70 72 32 20 65  }.  test_expr2 e
73b0: 78 70 72 2d 37 2e 35 33 20 5c 0a 20 20 20 20 20  xpr-7.53 \.     
73c0: 20 7b 28 28 61 20 6e 6f 74 20 69 6e 20 28 33 2c   {((a not in (3,
73d0: 34 2c 35 2c 36 2c 37 2c 38 2c 39 2c 31 30 29 20  4,5,6,7,8,9,10) 
73e0: 4f 52 20 30 29 20 41 4e 44 20 61 3c 31 31 29 20  OR 0) AND a<11) 
73f0: 4f 52 20 30 7d 20 7b 31 20 32 7d 0a 7d 0a 74 65  OR 0} {1 2}.}.te
7400: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
7410: 35 34 20 7b 28 28 61 3e 30 20 4f 52 20 30 29 20  54 {((a>0 OR 0) 
7420: 41 4e 44 20 61 3c 33 29 20 4f 52 20 30 7d 20 7b  AND a<3) OR 0} {
7430: 31 20 32 7d 0a 69 66 63 61 70 61 62 6c 65 20 73  1 2}.ifcapable s
7440: 75 62 71 75 65 72 79 20 7b 0a 20 20 74 65 73 74  ubquery {.  test
7450: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 35 35  _expr2 expr-7.55
7460: 20 7b 28 28 61 20 69 6e 20 28 31 2c 32 29 20 4f   {((a in (1,2) O
7470: 52 20 30 29 20 49 53 20 4e 55 4c 4c 20 41 4e 44  R 0) IS NULL AND
7480: 20 31 29 20 4f 52 20 30 7d 20 7b 7b 7d 7d 0a 20   1) OR 0} {{}}. 
7490: 20 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72   test_expr2 expr
74a0: 2d 37 2e 35 36 20 5c 0a 20 20 20 20 20 20 7b 28  -7.56 \.      {(
74b0: 28 61 20 6e 6f 74 20 69 6e 20 28 33 2c 34 2c 35  (a not in (3,4,5
74c0: 2c 36 2c 37 2c 38 2c 39 2c 31 30 29 20 49 53 20  ,6,7,8,9,10) IS 
74d0: 4e 55 4c 4c 20 4f 52 20 30 29 20 41 4e 44 20 31  NULL OR 0) AND 1
74e0: 29 20 4f 52 20 30 7d 20 7b 7b 7d 7d 0a 7d 0a 74  ) OR 0} {{}}.}.t
74f0: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
7500: 2e 35 37 20 7b 28 28 61 3e 30 20 49 53 20 4e 55  .57 {((a>0 IS NU
7510: 4c 4c 20 4f 52 20 30 29 20 41 4e 44 20 31 29 20  LL OR 0) AND 1) 
7520: 4f 52 20 30 7d 20 7b 7b 7d 7d 0a 0a 74 65 73 74  OR 0} {{}}..test
7530: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 35 38  _expr2 expr-7.58
7540: 20 20 7b 28 61 7c 7c 27 27 29 3c 3d 27 31 27 7d    {(a||'')<='1'}
7550: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7560: 20 20 7b 31 7d 0a 0a 74 65 73 74 5f 65 78 70 72    {1}..test_expr
7570: 32 20 65 78 70 72 2d 37 2e 35 39 20 7b 4c 49 4b  2 expr-7.59 {LIK
7580: 45 28 27 31 30 25 27 2c 62 29 7d 20 20 20 20 20  E('10%',b)}     
7590: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 31 30               {10
75a0: 20 32 30 7d 0a 74 65 73 74 5f 65 78 70 72 32 20   20}.test_expr2 
75b0: 65 78 70 72 2d 37 2e 36 30 20 7b 4c 49 4b 45 28  expr-7.60 {LIKE(
75c0: 27 5f 34 27 2c 62 29 7d 20 20 20 20 20 20 20 20  '_4',b)}        
75d0: 20 20 20 20 20 20 20 20 20 20 20 7b 36 7d 0a 74             {6}.t
75e0: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
75f0: 2e 36 31 20 7b 47 4c 4f 42 28 27 31 3f 27 2c 61  .61 {GLOB('1?',a
7600: 29 7d 20 20 20 20 20 20 20 20 20 20 20 20 7b 31  )}            {1
7610: 30 20 31 31 20 31 32 20 31 33 20 31 34 20 31 35  0 11 12 13 14 15
7620: 20 31 36 20 31 37 20 31 38 20 31 39 7d 0a 74 65   16 17 18 19}.te
7630: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
7640: 36 32 20 7b 47 4c 4f 42 28 27 31 2a 34 27 2c 62  62 {GLOB('1*4',b
7650: 29 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20  )}              
7660: 20 20 20 20 7b 31 30 20 31 34 7d 0a 74 65 73 74      {10 14}.test
7670: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 36 33  _expr2 expr-7.63
7680: 20 7b 47 4c 4f 42 28 27 2a 31 5b 34 35 36 5d 27   {GLOB('*1[456]'
7690: 2c 62 29 7d 20 20 20 20 20 20 20 20 20 20 20 20  ,b)}            
76a0: 20 20 7b 34 7d 0a 0a 23 20 54 65 73 74 20 74 68    {4}..# Test th
76b0: 65 20 43 55 52 52 45 4e 54 5f 54 49 4d 45 2c 20  e CURRENT_TIME, 
76c0: 43 55 52 52 45 4e 54 5f 44 41 54 45 2c 20 61 6e  CURRENT_DATE, an
76d0: 64 20 43 55 52 52 45 4e 54 5f 54 49 4d 45 53 54  d CURRENT_TIMEST
76e0: 41 4d 50 20 65 78 70 72 65 73 73 69 6f 6e 73 2e  AMP expressions.
76f0: 0a 23 0a 73 65 74 20 73 71 6c 69 74 65 5f 63 75  .#.set sqlite_cu
7700: 72 72 65 6e 74 5f 74 69 6d 65 20 5b 63 6c 6f 63  rrent_time [cloc
7710: 6b 20 73 65 63 6f 6e 64 73 5d 0a 73 65 74 20 64  k seconds].set d
7720: 61 74 65 20 5b 63 6c 6f 63 6b 20 66 6f 72 6d 61  ate [clock forma
7730: 74 20 24 73 71 6c 69 74 65 5f 63 75 72 72 65 6e  t $sqlite_curren
7740: 74 5f 74 69 6d 65 20 2d 66 6f 72 6d 61 74 20 25  t_time -format %
7750: 59 2d 25 6d 2d 25 64 20 2d 67 6d 74 20 31 5d 0a  Y-%m-%d -gmt 1].
7760: 73 65 74 20 74 69 6d 65 20 5b 63 6c 6f 63 6b 20  set time [clock 
7770: 66 6f 72 6d 61 74 20 24 73 71 6c 69 74 65 5f 63  format $sqlite_c
7780: 75 72 72 65 6e 74 5f 74 69 6d 65 20 2d 66 6f 72  urrent_time -for
7790: 6d 61 74 20 25 48 3a 25 4d 3a 25 53 20 2d 67 6d  mat %H:%M:%S -gm
77a0: 74 20 31 5d 0a 64 6f 5f 74 65 73 74 20 65 78 70  t 1].do_test exp
77b0: 72 2d 38 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  r-8.1 {.  execsq
77c0: 6c 20 7b 53 45 4c 45 43 54 20 43 55 52 52 45 4e  l {SELECT CURREN
77d0: 54 5f 54 49 4d 45 7d 0a 7d 20 24 74 69 6d 65 0a  T_TIME}.} $time.
77e0: 64 6f 5f 74 65 73 74 20 65 78 70 72 2d 38 2e 32  do_test expr-8.2
77f0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 53 45   {.  execsql {SE
7800: 4c 45 43 54 20 43 55 52 52 45 4e 54 5f 44 41 54  LECT CURRENT_DAT
7810: 45 7d 0a 7d 20 24 64 61 74 65 0a 64 6f 5f 74 65  E}.} $date.do_te
7820: 73 74 20 65 78 70 72 2d 38 2e 33 20 7b 0a 20 20  st expr-8.3 {.  
7830: 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54 20  execsql {SELECT 
7840: 43 55 52 52 45 4e 54 5f 54 49 4d 45 53 54 41 4d  CURRENT_TIMESTAM
7850: 50 7d 0a 7d 20 5b 6c 69 73 74 20 22 24 64 61 74  P}.} [list "$dat
7860: 65 20 24 74 69 6d 65 22 5d 0a 69 66 63 61 70 61  e $time"].ifcapa
7870: 62 6c 65 20 64 61 74 65 74 69 6d 65 20 7b 0a 20  ble datetime {. 
7880: 20 64 6f 5f 74 65 73 74 20 65 78 70 72 2d 38 2e   do_test expr-8.
7890: 34 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20  4 {.    execsql 
78a0: 7b 53 45 4c 45 43 54 20 43 55 52 52 45 4e 54 5f  {SELECT CURRENT_
78b0: 54 49 4d 45 3d 3d 74 69 6d 65 28 27 6e 6f 77 27  TIME==time('now'
78c0: 29 3b 7d 0a 20 20 7d 20 31 0a 20 20 64 6f 5f 74  );}.  } 1.  do_t
78d0: 65 73 74 20 65 78 70 72 2d 38 2e 35 20 7b 0a 20  est expr-8.5 {. 
78e0: 20 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45     execsql {SELE
78f0: 43 54 20 43 55 52 52 45 4e 54 5f 44 41 54 45 3d  CT CURRENT_DATE=
7900: 3d 64 61 74 65 28 27 6e 6f 77 27 29 3b 7d 0a 20  =date('now');}. 
7910: 20 7d 20 31 0a 20 20 64 6f 5f 74 65 73 74 20 65   } 1.  do_test e
7920: 78 70 72 2d 38 2e 36 20 7b 0a 20 20 20 20 65 78  xpr-8.6 {.    ex
7930: 65 63 73 71 6c 20 7b 53 45 4c 45 43 54 20 43 55  ecsql {SELECT CU
7940: 52 52 45 4e 54 5f 54 49 4d 45 53 54 41 4d 50 3d  RRENT_TIMESTAMP=
7950: 3d 64 61 74 65 74 69 6d 65 28 27 6e 6f 77 27 29  =datetime('now')
7960: 3b 7d 0a 20 20 7d 20 31 0a 7d 0a 73 65 74 20 73  ;}.  } 1.}.set s
7970: 71 6c 69 74 65 5f 63 75 72 72 65 6e 74 5f 74 69  qlite_current_ti
7980: 6d 65 20 30 0a 0a 64 6f 5f 74 65 73 74 20 65 78  me 0..do_test ex
7990: 70 72 2d 39 2e 31 20 7b 0a 20 20 65 78 65 63 73  pr-9.1 {.  execs
79a0: 71 6c 20 7b 53 45 4c 45 43 54 20 72 6f 75 6e 64  ql {SELECT round
79b0: 28 2d 28 27 2d 27 7c 7c 27 31 32 33 27 29 29 7d  (-('-'||'123'))}
79c0: 0a 7d 20 31 32 33 0a 0a 23 20 54 65 73 74 20 61  .} 123..# Test a
79d0: 6e 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20  n error message 
79e0: 74 68 61 74 20 63 61 6e 20 62 65 20 67 65 6e 65  that can be gene
79f0: 72 61 74 65 64 20 62 79 20 74 68 65 20 4c 49 4b  rated by the LIK
7a00: 45 20 65 78 70 72 65 73 73 69 6f 6e 0a 64 6f 5f  E expression.do_
7a10: 74 65 73 74 20 65 78 70 72 2d 31 30 2e 31 20 7b  test expr-10.1 {
7a20: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 53 45 4c  .  catchsql {SEL
7a30: 45 43 54 20 27 61 62 63 27 20 4c 49 4b 45 20 27  ECT 'abc' LIKE '
7a40: 61 62 63 27 20 45 53 43 41 50 45 20 27 27 7d 0a  abc' ESCAPE ''}.
7a50: 7d 20 7b 31 20 7b 45 53 43 41 50 45 20 65 78 70  } {1 {ESCAPE exp
7a60: 72 65 73 73 69 6f 6e 20 6d 75 73 74 20 62 65 20  ression must be 
7a70: 61 20 73 69 6e 67 6c 65 20 63 68 61 72 61 63 74  a single charact
7a80: 65 72 7d 7d 0a 64 6f 5f 74 65 73 74 20 65 78 70  er}}.do_test exp
7a90: 72 2d 31 30 2e 32 20 7b 0a 20 20 63 61 74 63 68  r-10.2 {.  catch
7aa0: 73 71 6c 20 7b 53 45 4c 45 43 54 20 27 61 62 63  sql {SELECT 'abc
7ab0: 27 20 4c 49 4b 45 20 27 61 62 63 27 20 45 53 43  ' LIKE 'abc' ESC
7ac0: 41 50 45 20 27 61 62 27 7d 0a 7d 20 7b 31 20 7b  APE 'ab'}.} {1 {
7ad0: 45 53 43 41 50 45 20 65 78 70 72 65 73 73 69 6f  ESCAPE expressio
7ae0: 6e 20 6d 75 73 74 20 62 65 20 61 20 73 69 6e 67  n must be a sing
7af0: 6c 65 20 63 68 61 72 61 63 74 65 72 7d 7d 0a 0a  le character}}..
7b00: 23 20 49 66 20 77 65 20 73 70 65 63 69 66 79 20  # If we specify 
7b10: 61 6e 20 69 6e 74 65 67 65 72 20 63 6f 6e 73 74  an integer const
7b20: 61 6e 74 20 74 68 61 74 20 69 73 20 62 69 67 67  ant that is bigg
7b30: 65 72 20 74 68 61 6e 20 74 68 65 20 6c 61 72 67  er than the larg
7b40: 65 73 74 0a 23 20 70 6f 73 73 69 62 6c 65 20 69  est.# possible i
7b50: 6e 74 65 67 65 72 2c 20 63 6f 64 65 20 74 68 65  nteger, code the
7b60: 20 69 6e 74 65 67 65 72 20 61 73 20 61 20 72 65   integer as a re
7b70: 61 6c 20 6e 75 6d 62 65 72 2e 0a 23 0a 64 6f 5f  al number..#.do_
7b80: 74 65 73 74 20 65 78 70 72 2d 31 31 2e 31 20 7b  test expr-11.1 {
7b90: 0a 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45  .  execsql {SELE
7ba0: 43 54 20 74 79 70 65 6f 66 28 39 32 32 33 33 37  CT typeof(922337
7bb0: 32 30 33 36 38 35 34 37 37 35 38 30 37 29 7d 0a  2036854775807)}.
7bc0: 7d 20 7b 69 6e 74 65 67 65 72 7d 0a 64 6f 5f 74  } {integer}.do_t
7bd0: 65 73 74 20 65 78 70 72 2d 31 31 2e 32 20 7b 0a  est expr-11.2 {.
7be0: 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43    execsql {SELEC
7bf0: 54 20 74 79 70 65 6f 66 28 39 32 32 33 33 37 32  T typeof(9223372
7c00: 30 33 36 38 35 34 37 37 35 38 30 38 29 7d 0a 7d  036854775808)}.}
7c10: 20 7b 72 65 61 6c 7d 0a 0a 0a 0a 66 69 6e 69 73   {real}....finis
7c20: 68 5f 74 65 73 74 0a                             h_test.