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

Artifact 80f3cf99f786ffbac19d2b0083673e7fc797030f:


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 36   expr.test,v 1.6
01f0: 37 20 32 30 30 39 2f 30 32 2f 30 34 20 30 33 3a  7 2009/02/04 03:
0200: 35 39 3a 32 35 20 73 68 61 6e 65 20 45 78 70 20  59:25 shane Exp 
0210: 24 0a 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b  $..set testdir [
0220: 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72  file dirname $ar
0230: 67 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73  gv0].source $tes
0240: 74 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a  tdir/tester.tcl.
0250: 0a 23 20 43 72 65 61 74 65 20 61 20 74 61 62 6c  .# Create a tabl
0260: 65 20 74 6f 20 77 6f 72 6b 20 77 69 74 68 2e 0a  e to work with..
0270: 23 0a 69 66 63 61 70 61 62 6c 65 20 66 6c 6f 61  #.ifcapable floa
0280: 74 69 6e 67 70 6f 69 6e 74 20 7b 0a 20 20 65 78  tingpoint {.  ex
0290: 65 63 73 71 6c 20 7b 43 52 45 41 54 45 20 54 41  ecsql {CREATE TA
02a0: 42 4c 45 20 74 65 73 74 31 28 69 31 20 69 6e 74  BLE test1(i1 int
02b0: 2c 20 69 32 20 69 6e 74 2c 20 72 31 20 72 65 61  , i2 int, r1 rea
02c0: 6c 2c 20 72 32 20 72 65 61 6c 2c 20 74 31 20 74  l, r2 real, t1 t
02d0: 65 78 74 2c 20 74 32 20 74 65 78 74 29 7d 0a 20  ext, t2 text)}. 
02e0: 20 65 78 65 63 73 71 6c 20 7b 49 4e 53 45 52 54   execsql {INSERT
02f0: 20 49 4e 54 4f 20 74 65 73 74 31 20 56 41 4c 55   INTO test1 VALU
0300: 45 53 28 31 2c 32 2c 31 2e 31 2c 32 2e 32 2c 27  ES(1,2,1.1,2.2,'
0310: 68 65 6c 6c 6f 27 2c 27 77 6f 72 6c 64 27 29 7d  hello','world')}
0320: 0a 7d 0a 69 66 63 61 70 61 62 6c 65 20 21 66 6c  .}.ifcapable !fl
0330: 6f 61 74 69 6e 67 70 6f 69 6e 74 20 7b 0a 20 20  oatingpoint {.  
0340: 65 78 65 63 73 71 6c 20 7b 43 52 45 41 54 45 20  execsql {CREATE 
0350: 54 41 42 4c 45 20 74 65 73 74 31 28 69 31 20 69  TABLE test1(i1 i
0360: 6e 74 2c 20 69 32 20 69 6e 74 2c 20 74 31 20 74  nt, i2 int, t1 t
0370: 65 78 74 2c 20 74 32 20 74 65 78 74 29 7d 0a 20  ext, t2 text)}. 
0380: 20 65 78 65 63 73 71 6c 20 7b 49 4e 53 45 52 54   execsql {INSERT
0390: 20 49 4e 54 4f 20 74 65 73 74 31 20 56 41 4c 55   INTO test1 VALU
03a0: 45 53 28 31 2c 32 2c 27 68 65 6c 6c 6f 27 2c 27  ES(1,2,'hello','
03b0: 77 6f 72 6c 64 27 29 7d 0a 7d 0a 0a 70 72 6f 63  world')}.}..proc
03c0: 20 74 65 73 74 5f 65 78 70 72 20 7b 6e 61 6d 65   test_expr {name
03d0: 20 73 65 74 74 69 6e 67 73 20 65 78 70 72 20 72   settings expr r
03e0: 65 73 75 6c 74 7d 20 7b 0a 20 20 64 6f 5f 74 65  esult} {.  do_te
03f0: 73 74 20 24 6e 61 6d 65 20 5b 66 6f 72 6d 61 74  st $name [format
0400: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
0410: 42 45 47 49 4e 3b 20 55 50 44 41 54 45 20 74 65  BEGIN; UPDATE te
0420: 73 74 31 20 53 45 54 20 25 73 3b 20 53 45 4c 45  st1 SET %s; SELE
0430: 43 54 20 25 73 20 46 52 4f 4d 20 74 65 73 74 31  CT %s FROM test1
0440: 3b 20 52 4f 4c 4c 42 41 43 4b 3b 7d 0a 20 20 7d  ; ROLLBACK;}.  }
0450: 20 24 73 65 74 74 69 6e 67 73 20 24 65 78 70 72   $settings $expr
0460: 5d 20 24 72 65 73 75 6c 74 0a 7d 0a 0a 74 65 73  ] $result.}..tes
0470: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 31 20  t_expr expr-1.1 
0480: 7b 69 31 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b  {i1=10, i2=20} {
0490: 69 31 2b 69 32 7d 20 33 30 0a 74 65 73 74 5f 65  i1+i2} 30.test_e
04a0: 78 70 72 20 65 78 70 72 2d 31 2e 32 20 7b 69 31  xpr expr-1.2 {i1
04b0: 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b 69 31 2d  =10, i2=20} {i1-
04c0: 69 32 7d 20 2d 31 30 0a 74 65 73 74 5f 65 78 70  i2} -10.test_exp
04d0: 72 20 65 78 70 72 2d 31 2e 33 20 7b 69 31 3d 31  r expr-1.3 {i1=1
04e0: 30 2c 20 69 32 3d 32 30 7d 20 7b 69 31 2a 69 32  0, i2=20} {i1*i2
04f0: 7d 20 32 30 30 0a 74 65 73 74 5f 65 78 70 72 20  } 200.test_expr 
0500: 65 78 70 72 2d 31 2e 34 20 7b 69 31 3d 31 30 2c  expr-1.4 {i1=10,
0510: 20 69 32 3d 32 30 7d 20 7b 69 31 2f 69 32 7d 20   i2=20} {i1/i2} 
0520: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
0530: 2d 31 2e 35 20 7b 69 31 3d 31 30 2c 20 69 32 3d  -1.5 {i1=10, i2=
0540: 32 30 7d 20 7b 69 32 2f 69 31 7d 20 32 0a 74 65  20} {i2/i1} 2.te
0550: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 36  st_expr expr-1.6
0560: 20 7b 69 31 3d 31 30 2c 20 69 32 3d 32 30 7d 20   {i1=10, i2=20} 
0570: 7b 69 32 3c 69 31 7d 20 30 0a 74 65 73 74 5f 65  {i2<i1} 0.test_e
0580: 78 70 72 20 65 78 70 72 2d 31 2e 37 20 7b 69 31  xpr expr-1.7 {i1
0590: 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3c  =10, i2=20} {i2<
05a0: 3d 69 31 7d 20 30 0a 74 65 73 74 5f 65 78 70 72  =i1} 0.test_expr
05b0: 20 65 78 70 72 2d 31 2e 38 20 7b 69 31 3d 31 30   expr-1.8 {i1=10
05c0: 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3e 69 31 7d  , i2=20} {i2>i1}
05d0: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
05e0: 72 2d 31 2e 39 20 7b 69 31 3d 31 30 2c 20 69 32  r-1.9 {i1=10, i2
05f0: 3d 32 30 7d 20 7b 69 32 3e 3d 69 31 7d 20 31 0a  =20} {i2>=i1} 1.
0600: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
0610: 2e 31 30 20 7b 69 31 3d 31 30 2c 20 69 32 3d 32  .10 {i1=10, i2=2
0620: 30 7d 20 7b 69 32 21 3d 69 31 7d 20 31 0a 74 65  0} {i2!=i1} 1.te
0630: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 31  st_expr expr-1.1
0640: 31 20 7b 69 31 3d 31 30 2c 20 69 32 3d 32 30 7d  1 {i1=10, i2=20}
0650: 20 7b 69 32 3d 69 31 7d 20 30 0a 74 65 73 74 5f   {i2=i1} 0.test_
0660: 65 78 70 72 20 65 78 70 72 2d 31 2e 31 32 20 7b  expr expr-1.12 {
0670: 69 31 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b 69  i1=10, i2=20} {i
0680: 32 3c 3e 69 31 7d 20 31 0a 74 65 73 74 5f 65 78  2<>i1} 1.test_ex
0690: 70 72 20 65 78 70 72 2d 31 2e 31 33 20 7b 69 31  pr expr-1.13 {i1
06a0: 3d 31 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3d  =10, i2=20} {i2=
06b0: 3d 69 31 7d 20 30 0a 74 65 73 74 5f 65 78 70 72  =i1} 0.test_expr
06c0: 20 65 78 70 72 2d 31 2e 31 34 20 7b 69 31 3d 32   expr-1.14 {i1=2
06d0: 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3c 69 31  0, i2=20} {i2<i1
06e0: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
06f0: 70 72 2d 31 2e 31 35 20 7b 69 31 3d 32 30 2c 20  pr-1.15 {i1=20, 
0700: 69 32 3d 32 30 7d 20 7b 69 32 3c 3d 69 31 7d 20  i2=20} {i2<=i1} 
0710: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
0720: 2d 31 2e 31 36 20 7b 69 31 3d 32 30 2c 20 69 32  -1.16 {i1=20, i2
0730: 3d 32 30 7d 20 7b 69 32 3e 69 31 7d 20 30 0a 74  =20} {i2>i1} 0.t
0740: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0750: 31 37 20 7b 69 31 3d 32 30 2c 20 69 32 3d 32 30  17 {i1=20, i2=20
0760: 7d 20 7b 69 32 3e 3d 69 31 7d 20 31 0a 74 65 73  } {i2>=i1} 1.tes
0770: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 31 38  t_expr expr-1.18
0780: 20 7b 69 31 3d 32 30 2c 20 69 32 3d 32 30 7d 20   {i1=20, i2=20} 
0790: 7b 69 32 21 3d 69 31 7d 20 30 0a 74 65 73 74 5f  {i2!=i1} 0.test_
07a0: 65 78 70 72 20 65 78 70 72 2d 31 2e 31 39 20 7b  expr expr-1.19 {
07b0: 69 31 3d 32 30 2c 20 69 32 3d 32 30 7d 20 7b 69  i1=20, i2=20} {i
07c0: 32 3d 69 31 7d 20 31 0a 74 65 73 74 5f 65 78 70  2=i1} 1.test_exp
07d0: 72 20 65 78 70 72 2d 31 2e 32 30 20 7b 69 31 3d  r expr-1.20 {i1=
07e0: 32 30 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3c 3e  20, i2=20} {i2<>
07f0: 69 31 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  i1} 0.test_expr 
0800: 65 78 70 72 2d 31 2e 32 31 20 7b 69 31 3d 32 30  expr-1.21 {i1=20
0810: 2c 20 69 32 3d 32 30 7d 20 7b 69 32 3d 3d 69 31  , i2=20} {i2==i1
0820: 7d 20 31 0a 69 66 63 61 70 61 62 6c 65 20 66 6c  } 1.ifcapable fl
0830: 6f 61 74 69 6e 67 70 6f 69 6e 74 20 7b 0a 20 20  oatingpoint {.  
0840: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
0850: 2e 32 32 20 7b 69 31 3d 31 2c 20 69 32 3d 32 2c  .22 {i1=1, i2=2,
0860: 20 72 31 3d 33 2e 30 7d 20 7b 69 31 2b 69 32 2a   r1=3.0} {i1+i2*
0870: 72 31 7d 20 7b 37 2e 30 7d 0a 20 20 74 65 73 74  r1} {7.0}.  test
0880: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 32 33 20  _expr expr-1.23 
0890: 7b 69 31 3d 31 2c 20 69 32 3d 32 2c 20 72 31 3d  {i1=1, i2=2, r1=
08a0: 33 2e 30 7d 20 7b 28 69 31 2b 69 32 29 2a 72 31  3.0} {(i1+i2)*r1
08b0: 7d 20 7b 39 2e 30 7d 0a 7d 0a 74 65 73 74 5f 65  } {9.0}.}.test_e
08c0: 78 70 72 20 65 78 70 72 2d 31 2e 32 34 20 7b 69  xpr expr-1.24 {i
08d0: 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 6d 69 6e 28  1=1, i2=2} {min(
08e0: 69 31 2c 69 32 2c 69 31 2b 69 32 2c 69 31 2d 69  i1,i2,i1+i2,i1-i
08f0: 32 29 7d 20 7b 2d 31 7d 0a 74 65 73 74 5f 65 78  2)} {-1}.test_ex
0900: 70 72 20 65 78 70 72 2d 31 2e 32 35 20 7b 69 31  pr expr-1.25 {i1
0910: 3d 31 2c 20 69 32 3d 32 7d 20 7b 6d 61 78 28 69  =1, i2=2} {max(i
0920: 31 2c 69 32 2c 69 31 2b 69 32 2c 69 31 2d 69 32  1,i2,i1+i2,i1-i2
0930: 29 7d 20 7b 33 7d 0a 74 65 73 74 5f 65 78 70 72  )} {3}.test_expr
0940: 20 65 78 70 72 2d 31 2e 32 36 20 7b 69 31 3d 31   expr-1.26 {i1=1
0950: 2c 20 69 32 3d 32 7d 20 7b 6d 61 78 28 69 31 2c  , i2=2} {max(i1,
0960: 69 32 2c 69 31 2b 69 32 2c 69 31 2d 69 32 29 7d  i2,i1+i2,i1-i2)}
0970: 20 7b 33 7d 0a 74 65 73 74 5f 65 78 70 72 20 65   {3}.test_expr e
0980: 78 70 72 2d 31 2e 32 37 20 7b 69 31 3d 31 2c 20  xpr-1.27 {i1=1, 
0990: 69 32 3d 32 7d 20 7b 69 31 3d 3d 31 20 41 4e 44  i2=2} {i1==1 AND
09a0: 20 69 32 3d 32 7d 20 7b 31 7d 0a 74 65 73 74 5f   i2=2} {1}.test_
09b0: 65 78 70 72 20 65 78 70 72 2d 31 2e 32 38 20 7b  expr expr-1.28 {
09c0: 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 69 31 3d  i1=1, i2=2} {i1=
09d0: 32 20 41 4e 44 20 69 32 3d 31 7d 20 7b 30 7d 0a  2 AND i2=1} {0}.
09e0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
09f0: 2e 32 39 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d  .29 {i1=1, i2=2}
0a00: 20 7b 69 31 3d 31 20 41 4e 44 20 69 32 3d 31 7d   {i1=1 AND i2=1}
0a10: 20 7b 30 7d 0a 74 65 73 74 5f 65 78 70 72 20 65   {0}.test_expr e
0a20: 78 70 72 2d 31 2e 33 30 20 7b 69 31 3d 31 2c 20  xpr-1.30 {i1=1, 
0a30: 69 32 3d 32 7d 20 7b 69 31 3d 32 20 41 4e 44 20  i2=2} {i1=2 AND 
0a40: 69 32 3d 32 7d 20 7b 30 7d 0a 74 65 73 74 5f 65  i2=2} {0}.test_e
0a50: 78 70 72 20 65 78 70 72 2d 31 2e 33 31 20 7b 69  xpr expr-1.31 {i
0a60: 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 69 31 3d 3d  1=1, i2=2} {i1==
0a70: 31 20 4f 52 20 69 32 3d 32 7d 20 7b 31 7d 0a 74  1 OR i2=2} {1}.t
0a80: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0a90: 33 32 20 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20  32 {i1=1, i2=2} 
0aa0: 7b 69 31 3d 32 20 4f 52 20 69 32 3d 31 7d 20 7b  {i1=2 OR i2=1} {
0ab0: 30 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  0}.test_expr exp
0ac0: 72 2d 31 2e 33 33 20 7b 69 31 3d 31 2c 20 69 32  r-1.33 {i1=1, i2
0ad0: 3d 32 7d 20 7b 69 31 3d 31 20 4f 52 20 69 32 3d  =2} {i1=1 OR i2=
0ae0: 31 7d 20 7b 31 7d 0a 74 65 73 74 5f 65 78 70 72  1} {1}.test_expr
0af0: 20 65 78 70 72 2d 31 2e 33 34 20 7b 69 31 3d 31   expr-1.34 {i1=1
0b00: 2c 20 69 32 3d 32 7d 20 7b 69 31 3d 32 20 4f 52  , i2=2} {i1=2 OR
0b10: 20 69 32 3d 32 7d 20 7b 31 7d 0a 74 65 73 74 5f   i2=2} {1}.test_
0b20: 65 78 70 72 20 65 78 70 72 2d 31 2e 33 35 20 7b  expr expr-1.35 {
0b30: 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 69 31 2d  i1=1, i2=2} {i1-
0b40: 69 32 3d 2d 31 7d 20 7b 31 7d 0a 74 65 73 74 5f  i2=-1} {1}.test_
0b50: 65 78 70 72 20 65 78 70 72 2d 31 2e 33 36 20 7b  expr expr-1.36 {
0b60: 69 31 3d 31 2c 20 69 32 3d 30 7d 20 7b 6e 6f 74  i1=1, i2=0} {not
0b70: 20 69 31 7d 20 7b 30 7d 0a 74 65 73 74 5f 65 78   i1} {0}.test_ex
0b80: 70 72 20 65 78 70 72 2d 31 2e 33 37 20 7b 69 31  pr expr-1.37 {i1
0b90: 3d 31 2c 20 69 32 3d 30 7d 20 7b 6e 6f 74 20 69  =1, i2=0} {not i
0ba0: 32 7d 20 7b 31 7d 0a 74 65 73 74 5f 65 78 70 72  2} {1}.test_expr
0bb0: 20 65 78 70 72 2d 31 2e 33 38 20 7b 69 31 3d 31   expr-1.38 {i1=1
0bc0: 7d 20 7b 2d 69 31 7d 20 7b 2d 31 7d 0a 74 65 73  } {-i1} {-1}.tes
0bd0: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 33 39  t_expr expr-1.39
0be0: 20 7b 69 31 3d 31 7d 20 7b 2b 69 31 7d 20 7b 31   {i1=1} {+i1} {1
0bf0: 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  }.test_expr expr
0c00: 2d 31 2e 34 30 20 7b 69 31 3d 31 2c 20 69 32 3d  -1.40 {i1=1, i2=
0c10: 32 7d 20 7b 2b 28 69 32 2b 69 31 29 7d 20 7b 33  2} {+(i2+i1)} {3
0c20: 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  }.test_expr expr
0c30: 2d 31 2e 34 31 20 7b 69 31 3d 31 2c 20 69 32 3d  -1.41 {i1=1, i2=
0c40: 32 7d 20 7b 2d 28 69 32 2b 69 31 29 7d 20 7b 2d  2} {-(i2+i1)} {-
0c50: 33 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  3}.test_expr exp
0c60: 72 2d 31 2e 34 32 20 7b 69 31 3d 31 2c 20 69 32  r-1.42 {i1=1, i2
0c70: 3d 32 7d 20 7b 69 31 7c 69 32 7d 20 7b 33 7d 0a  =2} {i1|i2} {3}.
0c80: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
0c90: 2e 34 32 62 20 7b 69 31 3d 31 2c 20 69 32 3d 32  .42b {i1=1, i2=2
0ca0: 7d 20 7b 34 7c 32 7d 20 7b 36 7d 0a 74 65 73 74  } {4|2} {6}.test
0cb0: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 34 33 20  _expr expr-1.43 
0cc0: 7b 69 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 69 31  {i1=1, i2=2} {i1
0cd0: 26 69 32 7d 20 7b 30 7d 0a 74 65 73 74 5f 65 78  &i2} {0}.test_ex
0ce0: 70 72 20 65 78 70 72 2d 31 2e 34 33 62 20 7b 69  pr expr-1.43b {i
0cf0: 31 3d 31 2c 20 69 32 3d 32 7d 20 7b 34 26 35 7d  1=1, i2=2} {4&5}
0d00: 20 7b 34 7d 0a 74 65 73 74 5f 65 78 70 72 20 65   {4}.test_expr e
0d10: 78 70 72 2d 31 2e 34 34 20 7b 69 31 3d 31 7d 20  xpr-1.44 {i1=1} 
0d20: 7b 7e 69 31 7d 20 7b 2d 32 7d 0a 74 65 73 74 5f  {~i1} {-2}.test_
0d30: 65 78 70 72 20 65 78 70 72 2d 31 2e 34 34 62 20  expr expr-1.44b 
0d40: 7b 69 31 3d 4e 55 4c 4c 7d 20 7b 7e 69 31 7d 20  {i1=NULL} {~i1} 
0d50: 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65  {{}}.test_expr e
0d60: 78 70 72 2d 31 2e 34 35 20 7b 69 31 3d 31 2c 20  xpr-1.45 {i1=1, 
0d70: 69 32 3d 33 7d 20 7b 69 31 3c 3c 69 32 7d 20 7b  i2=3} {i1<<i2} {
0d80: 38 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  8}.test_expr exp
0d90: 72 2d 31 2e 34 36 20 7b 69 31 3d 33 32 2c 20 69  r-1.46 {i1=32, i
0da0: 32 3d 33 7d 20 7b 69 31 3e 3e 69 32 7d 20 7b 34  2=3} {i1>>i2} {4
0db0: 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  }.test_expr expr
0dc0: 2d 31 2e 34 37 20 7b 69 31 3d 39 39 39 39 39 39  -1.47 {i1=999999
0dd0: 39 39 39 39 2c 20 69 32 3d 38 38 38 38 38 38 38  9999, i2=8888888
0de0: 38 38 38 7d 20 7b 69 31 3c 69 32 7d 20 30 0a 74  888} {i1<i2} 0.t
0df0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
0e00: 34 38 20 7b 69 31 3d 39 39 39 39 39 39 39 39 39  48 {i1=999999999
0e10: 39 2c 20 69 32 3d 38 38 38 38 38 38 38 38 38 38  9, i2=8888888888
0e20: 7d 20 7b 69 31 3d 69 32 7d 20 30 0a 74 65 73 74  } {i1=i2} 0.test
0e30: 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 34 39 20  _expr expr-1.49 
0e40: 7b 69 31 3d 39 39 39 39 39 39 39 39 39 39 2c 20  {i1=9999999999, 
0e50: 69 32 3d 38 38 38 38 38 38 38 38 38 38 7d 20 7b  i2=8888888888} {
0e60: 69 31 3e 69 32 7d 20 31 0a 74 65 73 74 5f 65 78  i1>i2} 1.test_ex
0e70: 70 72 20 65 78 70 72 2d 31 2e 35 30 20 7b 69 31  pr expr-1.50 {i1
0e80: 3d 39 39 39 39 39 39 39 39 39 39 39 2c 20 69 32  =99999999999, i2
0e90: 3d 39 39 39 39 39 39 39 39 39 39 38 7d 20 7b 69  =99999999998} {i
0ea0: 31 3c 69 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  1<i2} 0.test_exp
0eb0: 72 20 65 78 70 72 2d 31 2e 35 31 20 7b 69 31 3d  r expr-1.51 {i1=
0ec0: 39 39 39 39 39 39 39 39 39 39 39 2c 20 69 32 3d  99999999999, i2=
0ed0: 39 39 39 39 39 39 39 39 39 39 38 7d 20 7b 69 31  99999999998} {i1
0ee0: 3d 69 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72  =i2} 0.test_expr
0ef0: 20 65 78 70 72 2d 31 2e 35 32 20 7b 69 31 3d 39   expr-1.52 {i1=9
0f00: 39 39 39 39 39 39 39 39 39 39 2c 20 69 32 3d 39  9999999999, i2=9
0f10: 39 39 39 39 39 39 39 39 39 38 7d 20 7b 69 31 3e  9999999998} {i1>
0f20: 69 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  i2} 1.test_expr 
0f30: 65 78 70 72 2d 31 2e 35 33 20 7b 69 31 3d 30 39  expr-1.53 {i1=09
0f40: 39 39 39 39 39 39 39 39 39 39 2c 20 69 32 3d 39  9999999999, i2=9
0f50: 39 39 39 39 39 39 39 39 39 39 7d 20 7b 69 31 3c  9999999999} {i1<
0f60: 69 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  i2} 0.test_expr 
0f70: 65 78 70 72 2d 31 2e 35 34 20 7b 69 31 3d 30 39  expr-1.54 {i1=09
0f80: 39 39 39 39 39 39 39 39 39 39 2c 20 69 32 3d 39  9999999999, i2=9
0f90: 39 39 39 39 39 39 39 39 39 39 7d 20 7b 69 31 3d  9999999999} {i1=
0fa0: 69 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  i2} 1.test_expr 
0fb0: 65 78 70 72 2d 31 2e 35 35 20 7b 69 31 3d 30 39  expr-1.55 {i1=09
0fc0: 39 39 39 39 39 39 39 39 39 39 2c 20 69 32 3d 39  9999999999, i2=9
0fd0: 39 39 39 39 39 39 39 39 39 39 7d 20 7b 69 31 3e  9999999999} {i1>
0fe0: 69 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  i2} 0.test_expr 
0ff0: 65 78 70 72 2d 31 2e 35 36 20 7b 69 31 3d 32 35  expr-1.56 {i1=25
1000: 2c 20 69 32 3d 31 31 7d 20 7b 69 31 25 69 32 7d  , i2=11} {i1%i2}
1010: 20 33 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   3.test_expr exp
1020: 72 2d 31 2e 35 38 20 7b 69 31 3d 4e 55 4c 4c 2c  r-1.58 {i1=NULL,
1030: 20 69 32 3d 31 7d 20 7b 63 6f 61 6c 65 73 63 65   i2=1} {coalesce
1040: 28 69 31 2b 69 32 2c 39 39 29 7d 20 39 39 0a 74  (i1+i2,99)} 99.t
1050: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
1060: 35 39 20 7b 69 31 3d 31 2c 20 69 32 3d 4e 55 4c  59 {i1=1, i2=NUL
1070: 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 2b  L} {coalesce(i1+
1080: 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f  i2,99)} 99.test_
1090: 65 78 70 72 20 65 78 70 72 2d 31 2e 36 30 20 7b  expr expr-1.60 {
10a0: 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c  i1=NULL, i2=NULL
10b0: 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 2b 69  } {coalesce(i1+i
10c0: 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  2,99)} 99.test_e
10d0: 78 70 72 20 65 78 70 72 2d 31 2e 36 31 20 7b 69  xpr expr-1.61 {i
10e0: 31 3d 4e 55 4c 4c 2c 20 69 32 3d 31 7d 20 7b 63  1=NULL, i2=1} {c
10f0: 6f 61 6c 65 73 63 65 28 69 31 2d 69 32 2c 39 39  oalesce(i1-i2,99
1100: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
1110: 65 78 70 72 2d 31 2e 36 32 20 7b 69 31 3d 31 2c  expr-1.62 {i1=1,
1120: 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65   i2=NULL} {coale
1130: 73 63 65 28 69 31 2d 69 32 2c 39 39 29 7d 20 39  sce(i1-i2,99)} 9
1140: 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  9.test_expr expr
1150: 2d 31 2e 36 33 20 7b 69 31 3d 4e 55 4c 4c 2c 20  -1.63 {i1=NULL, 
1160: 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73  i2=NULL} {coales
1170: 63 65 28 69 31 2d 69 32 2c 39 39 29 7d 20 39 39  ce(i1-i2,99)} 99
1180: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1190: 31 2e 36 34 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.64 {i1=NULL, i
11a0: 32 3d 31 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69  2=1} {coalesce(i
11b0: 31 2a 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73  1*i2,99)} 99.tes
11c0: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 36 35  t_expr expr-1.65
11d0: 20 7b 69 31 3d 31 2c 20 69 32 3d 4e 55 4c 4c 7d   {i1=1, i2=NULL}
11e0: 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 2a 69 32   {coalesce(i1*i2
11f0: 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78  ,99)} 99.test_ex
1200: 70 72 20 65 78 70 72 2d 31 2e 36 36 20 7b 69 31  pr expr-1.66 {i1
1210: 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d 20  =NULL, i2=NULL} 
1220: 7b 63 6f 61 6c 65 73 63 65 28 69 31 2a 69 32 2c  {coalesce(i1*i2,
1230: 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70  99)} 99.test_exp
1240: 72 20 65 78 70 72 2d 31 2e 36 37 20 7b 69 31 3d  r expr-1.67 {i1=
1250: 4e 55 4c 4c 2c 20 69 32 3d 31 7d 20 7b 63 6f 61  NULL, i2=1} {coa
1260: 6c 65 73 63 65 28 69 31 2f 69 32 2c 39 39 29 7d  lesce(i1/i2,99)}
1270: 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78   99.test_expr ex
1280: 70 72 2d 31 2e 36 38 20 7b 69 31 3d 31 2c 20 69  pr-1.68 {i1=1, i
1290: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
12a0: 65 28 69 31 2f 69 32 2c 39 39 29 7d 20 39 39 0a  e(i1/i2,99)} 99.
12b0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
12c0: 2e 36 39 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32  .69 {i1=NULL, i2
12d0: 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65  =NULL} {coalesce
12e0: 28 69 31 2f 69 32 2c 39 39 29 7d 20 39 39 0a 74  (i1/i2,99)} 99.t
12f0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
1300: 37 30 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d  70 {i1=NULL, i2=
1310: 31 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 3c  1} {coalesce(i1<
1320: 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f  i2,99)} 99.test_
1330: 65 78 70 72 20 65 78 70 72 2d 31 2e 37 31 20 7b  expr expr-1.71 {
1340: 69 31 3d 31 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b  i1=1, i2=NULL} {
1350: 63 6f 61 6c 65 73 63 65 28 69 31 3e 69 32 2c 39  coalesce(i1>i2,9
1360: 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72  9)} 99.test_expr
1370: 20 65 78 70 72 2d 31 2e 37 32 20 7b 69 31 3d 4e   expr-1.72 {i1=N
1380: 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63  ULL, i2=NULL} {c
1390: 6f 61 6c 65 73 63 65 28 69 31 3c 3d 69 32 2c 39  oalesce(i1<=i2,9
13a0: 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72  9)} 99.test_expr
13b0: 20 65 78 70 72 2d 31 2e 37 33 20 7b 69 31 3d 4e   expr-1.73 {i1=N
13c0: 55 4c 4c 2c 20 69 32 3d 31 7d 20 7b 63 6f 61 6c  ULL, i2=1} {coal
13d0: 65 73 63 65 28 69 31 3e 3d 69 32 2c 39 39 29 7d  esce(i1>=i2,99)}
13e0: 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78   99.test_expr ex
13f0: 70 72 2d 31 2e 37 34 20 7b 69 31 3d 31 2c 20 69  pr-1.74 {i1=1, i
1400: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
1410: 65 28 69 31 21 3d 69 32 2c 39 39 29 7d 20 39 39  e(i1!=i2,99)} 99
1420: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1430: 31 2e 37 35 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.75 {i1=NULL, i
1440: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
1450: 65 28 69 31 3d 3d 69 32 2c 39 39 29 7d 20 39 39  e(i1==i2,99)} 99
1460: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1470: 31 2e 37 36 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.76 {i1=NULL, i
1480: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
1490: 65 28 6e 6f 74 20 69 31 2c 39 39 29 7d 20 39 39  e(not i1,99)} 99
14a0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
14b0: 31 2e 37 37 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.77 {i1=NULL, i
14c0: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
14d0: 65 28 2d 69 31 2c 39 39 29 7d 20 39 39 0a 74 65  e(-i1,99)} 99.te
14e0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 37  st_expr expr-1.7
14f0: 38 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e  8 {i1=NULL, i2=N
1500: 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69  ULL} {coalesce(i
1510: 31 20 49 53 20 4e 55 4c 4c 20 41 4e 44 20 69 32  1 IS NULL AND i2
1520: 3d 35 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f  =5,99)} 99.test_
1530: 65 78 70 72 20 65 78 70 72 2d 31 2e 37 39 20 7b  expr expr-1.79 {
1540: 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 4e 55 4c 4c  i1=NULL, i2=NULL
1550: 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69 31 20 49  } {coalesce(i1 I
1560: 53 20 4e 55 4c 4c 20 4f 52 20 69 32 3d 35 2c 39  S NULL OR i2=5,9
1570: 39 29 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  9)} 1.test_expr 
1580: 65 78 70 72 2d 31 2e 38 30 20 7b 69 31 3d 4e 55  expr-1.80 {i1=NU
1590: 4c 4c 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f  LL, i2=NULL} {co
15a0: 61 6c 65 73 63 65 28 69 31 3d 35 20 41 4e 44 20  alesce(i1=5 AND 
15b0: 69 32 20 49 53 20 4e 55 4c 4c 2c 39 39 29 7d 20  i2 IS NULL,99)} 
15c0: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  99.test_expr exp
15d0: 72 2d 31 2e 38 31 20 7b 69 31 3d 4e 55 4c 4c 2c  r-1.81 {i1=NULL,
15e0: 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65   i2=NULL} {coale
15f0: 73 63 65 28 69 31 3d 35 20 4f 52 20 69 32 20 49  sce(i1=5 OR i2 I
1600: 53 20 4e 55 4c 4c 2c 39 39 29 7d 20 31 0a 74 65  S NULL,99)} 1.te
1610: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 38  st_expr expr-1.8
1620: 32 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69 32 3d 33  2 {i1=NULL, i2=3
1630: 7d 20 7b 63 6f 61 6c 65 73 63 65 28 6d 69 6e 28  } {coalesce(min(
1640: 69 31 2c 69 32 2c 31 29 2c 39 39 29 7d 20 39 39  i1,i2,1),99)} 99
1650: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1660: 31 2e 38 33 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.83 {i1=NULL, i
1670: 32 3d 33 7d 20 7b 63 6f 61 6c 65 73 63 65 28 6d  2=3} {coalesce(m
1680: 61 78 28 69 31 2c 69 32 2c 31 29 2c 39 39 29 7d  ax(i1,i2,1),99)}
1690: 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78   99.test_expr ex
16a0: 70 72 2d 31 2e 38 34 20 7b 69 31 3d 33 2c 20 69  pr-1.84 {i1=3, i
16b0: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
16c0: 65 28 6d 69 6e 28 69 31 2c 69 32 2c 31 29 2c 39  e(min(i1,i2,1),9
16d0: 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72  9)} 99.test_expr
16e0: 20 65 78 70 72 2d 31 2e 38 35 20 7b 69 31 3d 33   expr-1.85 {i1=3
16f0: 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c  , i2=NULL} {coal
1700: 65 73 63 65 28 6d 61 78 28 69 31 2c 69 32 2c 31  esce(max(i1,i2,1
1710: 29 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  ),99)} 99.test_e
1720: 78 70 72 20 65 78 70 72 2d 31 2e 38 36 20 7b 69  xpr expr-1.86 {i
1730: 31 3d 33 2c 20 69 32 3d 38 7d 20 7b 35 20 62 65  1=3, i2=8} {5 be
1740: 74 77 65 65 6e 20 69 31 20 61 6e 64 20 69 32 7d  tween i1 and i2}
1750: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
1760: 72 2d 31 2e 38 37 20 7b 69 31 3d 33 2c 20 69 32  r-1.87 {i1=3, i2
1770: 3d 38 7d 20 7b 35 20 6e 6f 74 20 62 65 74 77 65  =8} {5 not betwe
1780: 65 6e 20 69 31 20 61 6e 64 20 69 32 7d 20 30 0a  en i1 and i2} 0.
1790: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
17a0: 2e 38 38 20 7b 69 31 3d 33 2c 20 69 32 3d 38 7d  .88 {i1=3, i2=8}
17b0: 20 7b 35 35 20 62 65 74 77 65 65 6e 20 69 31 20   {55 between i1 
17c0: 61 6e 64 20 69 32 7d 20 30 0a 74 65 73 74 5f 65  and i2} 0.test_e
17d0: 78 70 72 20 65 78 70 72 2d 31 2e 38 39 20 7b 69  xpr expr-1.89 {i
17e0: 31 3d 33 2c 20 69 32 3d 38 7d 20 7b 35 35 20 6e  1=3, i2=8} {55 n
17f0: 6f 74 20 62 65 74 77 65 65 6e 20 69 31 20 61 6e  ot between i1 an
1800: 64 20 69 32 7d 20 31 0a 74 65 73 74 5f 65 78 70  d i2} 1.test_exp
1810: 72 20 65 78 70 72 2d 31 2e 39 30 20 7b 69 31 3d  r expr-1.90 {i1=
1820: 33 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 35 20 62  3, i2=NULL} {5 b
1830: 65 74 77 65 65 6e 20 69 31 20 61 6e 64 20 69 32  etween i1 and i2
1840: 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72  } {{}}.test_expr
1850: 20 65 78 70 72 2d 31 2e 39 31 20 7b 69 31 3d 33   expr-1.91 {i1=3
1860: 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 35 20 6e 6f  , i2=NULL} {5 no
1870: 74 20 62 65 74 77 65 65 6e 20 69 31 20 61 6e 64  t between i1 and
1880: 20 69 32 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65   i2} {{}}.test_e
1890: 78 70 72 20 65 78 70 72 2d 31 2e 39 32 20 7b 69  xpr expr-1.92 {i
18a0: 31 3d 33 2c 20 69 32 3d 4e 55 4c 4c 7d 20 7b 32  1=3, i2=NULL} {2
18b0: 20 62 65 74 77 65 65 6e 20 69 31 20 61 6e 64 20   between i1 and 
18c0: 69 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  i2} 0.test_expr 
18d0: 65 78 70 72 2d 31 2e 39 33 20 7b 69 31 3d 33 2c  expr-1.93 {i1=3,
18e0: 20 69 32 3d 4e 55 4c 4c 7d 20 7b 32 20 6e 6f 74   i2=NULL} {2 not
18f0: 20 62 65 74 77 65 65 6e 20 69 31 20 61 6e 64 20   between i1 and 
1900: 69 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  i2} 1.test_expr 
1910: 65 78 70 72 2d 31 2e 39 34 20 7b 69 31 3d 4e 55  expr-1.94 {i1=NU
1920: 4c 4c 2c 20 69 32 3d 38 7d 20 7b 32 20 62 65 74  LL, i2=8} {2 bet
1930: 77 65 65 6e 20 69 31 20 61 6e 64 20 69 32 7d 20  ween i1 and i2} 
1940: 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65  {{}}.test_expr e
1950: 78 70 72 2d 31 2e 39 35 20 7b 69 31 3d 4e 55 4c  xpr-1.95 {i1=NUL
1960: 4c 2c 20 69 32 3d 38 7d 20 7b 32 20 6e 6f 74 20  L, i2=8} {2 not 
1970: 62 65 74 77 65 65 6e 20 69 31 20 61 6e 64 20 69  between i1 and i
1980: 32 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70  2} {{}}.test_exp
1990: 72 20 65 78 70 72 2d 31 2e 39 34 20 7b 69 31 3d  r expr-1.94 {i1=
19a0: 4e 55 4c 4c 2c 20 69 32 3d 38 7d 20 7b 35 35 20  NULL, i2=8} {55 
19b0: 62 65 74 77 65 65 6e 20 69 31 20 61 6e 64 20 69  between i1 and i
19c0: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
19d0: 78 70 72 2d 31 2e 39 35 20 7b 69 31 3d 4e 55 4c  xpr-1.95 {i1=NUL
19e0: 4c 2c 20 69 32 3d 38 7d 20 7b 35 35 20 6e 6f 74  L, i2=8} {55 not
19f0: 20 62 65 74 77 65 65 6e 20 69 31 20 61 6e 64 20   between i1 and 
1a00: 69 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  i2} 1.test_expr 
1a10: 65 78 70 72 2d 31 2e 39 36 20 7b 69 31 3d 4e 55  expr-1.96 {i1=NU
1a20: 4c 4c 2c 20 69 32 3d 33 7d 20 7b 63 6f 61 6c 65  LL, i2=3} {coale
1a30: 73 63 65 28 69 31 3c 3c 69 32 2c 39 39 29 7d 20  sce(i1<<i2,99)} 
1a40: 39 39 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70  99.test_expr exp
1a50: 72 2d 31 2e 39 37 20 7b 69 31 3d 33 32 2c 20 69  r-1.97 {i1=32, i
1a60: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
1a70: 65 28 69 31 3e 3e 69 32 2c 39 39 29 7d 20 39 39  e(i1>>i2,99)} 99
1a80: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
1a90: 31 2e 39 38 20 7b 69 31 3d 4e 55 4c 4c 2c 20 69  1.98 {i1=NULL, i
1aa0: 32 3d 4e 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63  2=NULL} {coalesc
1ab0: 65 28 69 31 7c 69 32 2c 39 39 29 7d 20 39 39 0a  e(i1|i2,99)} 99.
1ac0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31  test_expr expr-1
1ad0: 2e 39 39 20 7b 69 31 3d 33 32 2c 20 69 32 3d 4e  .99 {i1=32, i2=N
1ae0: 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 69  ULL} {coalesce(i
1af0: 31 26 69 32 2c 39 39 29 7d 20 39 39 0a 74 65 73  1&i2,99)} 99.tes
1b00: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 31 30  t_expr expr-1.10
1b10: 30 20 7b 69 31 3d 31 2c 20 69 32 3d 27 27 7d 20  0 {i1=1, i2=''} 
1b20: 7b 69 31 3d 69 32 7d 20 30 0a 74 65 73 74 5f 65  {i1=i2} 0.test_e
1b30: 78 70 72 20 65 78 70 72 2d 31 2e 31 30 31 20 7b  xpr expr-1.101 {
1b40: 69 31 3d 30 2c 20 69 32 3d 27 27 7d 20 7b 69 31  i1=0, i2=''} {i1
1b50: 3d 69 32 7d 20 30 0a 0a 23 20 43 68 65 63 6b 20  =i2} 0..# Check 
1b60: 66 6f 72 20 70 72 6f 70 65 72 20 68 61 6e 64 6c  for proper handl
1b70: 69 6e 67 20 6f 66 20 36 34 2d 62 69 74 20 69 6e  ing of 64-bit in
1b80: 74 65 67 65 72 20 76 61 6c 75 65 73 2e 0a 23 0a  teger values..#.
1b90: 69 66 20 7b 5b 77 6f 72 6b 69 6e 67 5f 36 34 62  if {[working_64b
1ba0: 69 74 5f 69 6e 74 5d 7d 20 7b 0a 20 20 74 65 73  it_int]} {.  tes
1bb0: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 31 30  t_expr expr-1.10
1bc0: 32 20 7b 69 31 3d 34 30 2c 20 69 32 3d 31 7d 20  2 {i1=40, i2=1} 
1bd0: 7b 69 32 3c 3c 69 31 7d 20 31 30 39 39 35 31 31  {i2<<i1} 1099511
1be0: 36 32 37 37 37 36 0a 7d 0a 0a 69 66 63 61 70 61  627776.}..ifcapa
1bf0: 62 6c 65 20 66 6c 6f 61 74 69 6e 67 70 6f 69 6e  ble floatingpoin
1c00: 74 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 20  t {.  test_expr 
1c10: 65 78 70 72 2d 31 2e 31 30 33 20 7b 69 31 3d 30  expr-1.103 {i1=0
1c20: 7d 20 7b 28 2d 32 31 34 37 34 38 33 36 34 38 2e  } {(-2147483648.
1c30: 30 20 25 20 2d 31 29 7d 20 30 2e 30 0a 20 20 74  0 % -1)} 0.0.  t
1c40: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e  est_expr expr-1.
1c50: 31 30 34 20 7b 69 31 3d 30 7d 20 7b 28 2d 39 32  104 {i1=0} {(-92
1c60: 32 33 33 37 32 30 33 36 38 35 34 37 37 35 38 30  2337203685477580
1c70: 38 2e 30 20 25 20 2d 31 29 7d 20 30 2e 30 0a 20  8.0 % -1)} 0.0. 
1c80: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
1c90: 31 2e 31 30 35 20 7b 69 31 3d 30 7d 20 7b 28 2d  1.105 {i1=0} {(-
1ca0: 39 32 32 33 33 37 32 30 33 36 38 35 34 37 37 35  9223372036854775
1cb0: 38 30 38 2e 30 20 2f 20 2d 31 29 3e 31 7d 20 31  808.0 / -1)>1} 1
1cc0: 0a 7d 0a 0a 69 66 20 7b 5b 77 6f 72 6b 69 6e 67  .}..if {[working
1cd0: 5f 36 34 62 69 74 5f 69 6e 74 5d 7d 20 7b 0a 20  _64bit_int]} {. 
1ce0: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
1cf0: 31 2e 31 30 36 20 7b 69 31 3d 30 7d 20 7b 28 31  1.106 {i1=0} {(1
1d00: 3c 3c 36 33 29 2f 2d 31 7d 20 2d 39 32 32 33 33  <<63)/-1} -92233
1d10: 37 32 30 33 36 38 35 34 37 37 35 38 30 38 0a 7d  72036854775808.}
1d20: 0a 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  ..test_expr expr
1d30: 2d 31 2e 31 30 37 20 7b 69 31 3d 30 7d 20 7b 28  -1.107 {i1=0} {(
1d40: 31 3c 3c 36 33 29 25 2d 31 7d 20 30 0a 74 65 73  1<<63)%-1} 0.tes
1d50: 74 5f 65 78 70 72 20 65 78 70 72 2d 31 2e 31 30  t_expr expr-1.10
1d60: 38 20 7b 69 31 3d 30 7d 20 7b 31 25 30 7d 20 7b  8 {i1=0} {1%0} {
1d70: 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78  {}}.test_expr ex
1d80: 70 72 2d 31 2e 31 30 39 20 7b 69 31 3d 30 7d 20  pr-1.109 {i1=0} 
1d90: 7b 31 2f 30 7d 20 7b 7b 7d 7d 0a 0a 69 66 20 7b  {1/0} {{}}..if {
1da0: 5b 77 6f 72 6b 69 6e 67 5f 36 34 62 69 74 5f 69  [working_64bit_i
1db0: 6e 74 5d 7d 20 7b 0a 20 20 74 65 73 74 5f 65 78  nt]} {.  test_ex
1dc0: 70 72 20 65 78 70 72 2d 31 2e 31 31 30 20 7b 69  pr expr-1.110 {i
1dd0: 31 3d 30 7d 20 7b 2d 39 32 32 33 33 37 32 30 33  1=0} {-922337203
1de0: 36 38 35 34 37 37 35 38 30 37 2f 2d 31 7d 20 39  6854775807/-1} 9
1df0: 32 32 33 33 37 32 30 33 36 38 35 34 37 37 35 38  2233720368547758
1e00: 30 37 0a 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20  07.}..ifcapable 
1e10: 66 6c 6f 61 74 69 6e 67 70 6f 69 6e 74 20 7b 0a  floatingpoint {.
1e20: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
1e30: 2d 32 2e 31 20 7b 72 31 3d 31 2e 32 33 2c 20 72  -2.1 {r1=1.23, r
1e40: 32 3d 32 2e 33 34 7d 20 7b 72 31 2b 72 32 7d 20  2=2.34} {r1+r2} 
1e50: 33 2e 35 37 0a 20 20 74 65 73 74 5f 65 78 70 72  3.57.  test_expr
1e60: 20 65 78 70 72 2d 32 2e 32 20 7b 72 31 3d 31 2e   expr-2.2 {r1=1.
1e70: 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 31  23, r2=2.34} {r1
1e80: 2d 72 32 7d 20 2d 31 2e 31 31 0a 20 20 74 65 73  -r2} -1.11.  tes
1e90: 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e 33 20  t_expr expr-2.3 
1ea0: 7b 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33  {r1=1.23, r2=2.3
1eb0: 34 7d 20 7b 72 31 2a 72 32 7d 20 32 2e 38 37 38  4} {r1*r2} 2.878
1ec0: 32 0a 7d 0a 73 65 74 20 74 63 6c 5f 70 72 65 63  2.}.set tcl_prec
1ed0: 69 73 69 6f 6e 20 31 35 0a 69 66 63 61 70 61 62  ision 15.ifcapab
1ee0: 6c 65 20 66 6c 6f 61 74 69 6e 67 70 6f 69 6e 74  le floatingpoint
1ef0: 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   {.  test_expr e
1f00: 78 70 72 2d 32 2e 34 20 7b 72 31 3d 31 2e 32 33  xpr-2.4 {r1=1.23
1f10: 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 31 2f 72  , r2=2.34} {r1/r
1f20: 32 7d 20 30 2e 35 32 35 36 34 31 30 32 35 36 34  2} 0.52564102564
1f30: 31 30 32 36 0a 20 20 74 65 73 74 5f 65 78 70 72  1026.  test_expr
1f40: 20 65 78 70 72 2d 32 2e 35 20 7b 72 31 3d 31 2e   expr-2.5 {r1=1.
1f50: 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32  23, r2=2.34} {r2
1f60: 2f 72 31 7d 20 31 2e 39 30 32 34 33 39 30 32 34  /r1} 1.902439024
1f70: 33 39 30 32 34 0a 20 20 74 65 73 74 5f 65 78 70  39024.  test_exp
1f80: 72 20 65 78 70 72 2d 32 2e 36 20 7b 72 31 3d 31  r expr-2.6 {r1=1
1f90: 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72  .23, r2=2.34} {r
1fa0: 32 3c 72 31 7d 20 30 0a 20 20 74 65 73 74 5f 65  2<r1} 0.  test_e
1fb0: 78 70 72 20 65 78 70 72 2d 32 2e 37 20 7b 72 31  xpr expr-2.7 {r1
1fc0: 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20  =1.23, r2=2.34} 
1fd0: 7b 72 32 3c 3d 72 31 7d 20 30 0a 20 20 74 65 73  {r2<=r1} 0.  tes
1fe0: 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e 38 20  t_expr expr-2.8 
1ff0: 7b 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33  {r1=1.23, r2=2.3
2000: 34 7d 20 7b 72 32 3e 72 31 7d 20 31 0a 20 20 74  4} {r2>r1} 1.  t
2010: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e  est_expr expr-2.
2020: 39 20 7b 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32  9 {r1=1.23, r2=2
2030: 2e 33 34 7d 20 7b 72 32 3e 3d 72 31 7d 20 31 0a  .34} {r2>=r1} 1.
2040: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
2050: 2d 32 2e 31 30 20 7b 72 31 3d 31 2e 32 33 2c 20  -2.10 {r1=1.23, 
2060: 72 32 3d 32 2e 33 34 7d 20 7b 72 32 21 3d 72 31  r2=2.34} {r2!=r1
2070: 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20  } 1.  test_expr 
2080: 65 78 70 72 2d 32 2e 31 31 20 7b 72 31 3d 31 2e  expr-2.11 {r1=1.
2090: 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32  23, r2=2.34} {r2
20a0: 3d 72 31 7d 20 30 0a 20 20 74 65 73 74 5f 65 78  =r1} 0.  test_ex
20b0: 70 72 20 65 78 70 72 2d 32 2e 31 32 20 7b 72 31  pr expr-2.12 {r1
20c0: 3d 31 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20  =1.23, r2=2.34} 
20d0: 7b 72 32 3c 3e 72 31 7d 20 31 0a 20 20 74 65 73  {r2<>r1} 1.  tes
20e0: 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e 31 33  t_expr expr-2.13
20f0: 20 7b 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32 2e   {r1=1.23, r2=2.
2100: 33 34 7d 20 7b 72 32 3d 3d 72 31 7d 20 30 0a 20  34} {r2==r1} 0. 
2110: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
2120: 32 2e 31 34 20 7b 72 31 3d 32 2e 33 34 2c 20 72  2.14 {r1=2.34, r
2130: 32 3d 32 2e 33 34 7d 20 7b 72 32 3c 72 31 7d 20  2=2.34} {r2<r1} 
2140: 30 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  0.  test_expr ex
2150: 70 72 2d 32 2e 31 35 20 7b 72 31 3d 32 2e 33 34  pr-2.15 {r1=2.34
2160: 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 3c 3d  , r2=2.34} {r2<=
2170: 72 31 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70  r1} 1.  test_exp
2180: 72 20 65 78 70 72 2d 32 2e 31 36 20 7b 72 31 3d  r expr-2.16 {r1=
2190: 32 2e 33 34 2c 20 72 32 3d 32 2e 33 34 7d 20 7b  2.34, r2=2.34} {
21a0: 72 32 3e 72 31 7d 20 30 0a 20 20 74 65 73 74 5f  r2>r1} 0.  test_
21b0: 65 78 70 72 20 65 78 70 72 2d 32 2e 31 37 20 7b  expr expr-2.17 {
21c0: 72 31 3d 32 2e 33 34 2c 20 72 32 3d 32 2e 33 34  r1=2.34, r2=2.34
21d0: 7d 20 7b 72 32 3e 3d 72 31 7d 20 31 0a 20 20 74  } {r2>=r1} 1.  t
21e0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e  est_expr expr-2.
21f0: 31 38 20 7b 72 31 3d 32 2e 33 34 2c 20 72 32 3d  18 {r1=2.34, r2=
2200: 32 2e 33 34 7d 20 7b 72 32 21 3d 72 31 7d 20 30  2.34} {r2!=r1} 0
2210: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
2220: 72 2d 32 2e 31 39 20 7b 72 31 3d 32 2e 33 34 2c  r-2.19 {r1=2.34,
2230: 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32 3d 72 31   r2=2.34} {r2=r1
2240: 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20  } 1.  test_expr 
2250: 65 78 70 72 2d 32 2e 32 30 20 7b 72 31 3d 32 2e  expr-2.20 {r1=2.
2260: 33 34 2c 20 72 32 3d 32 2e 33 34 7d 20 7b 72 32  34, r2=2.34} {r2
2270: 3c 3e 72 31 7d 20 30 0a 20 20 74 65 73 74 5f 65  <>r1} 0.  test_e
2280: 78 70 72 20 65 78 70 72 2d 32 2e 32 31 20 7b 72  xpr expr-2.21 {r
2290: 31 3d 32 2e 33 34 2c 20 72 32 3d 32 2e 33 34 7d  1=2.34, r2=2.34}
22a0: 20 7b 72 32 3d 3d 72 31 7d 20 31 0a 20 20 74 65   {r2==r1} 1.  te
22b0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 32 2e 32  st_expr expr-2.2
22c0: 32 20 7b 72 31 3d 31 2e 32 33 2c 20 72 32 3d 32  2 {r1=1.23, r2=2
22d0: 2e 33 34 7d 20 7b 6d 69 6e 28 72 31 2c 72 32 2c  .34} {min(r1,r2,
22e0: 72 31 2b 72 32 2c 72 31 2d 72 32 29 7d 20 7b 2d  r1+r2,r1-r2)} {-
22f0: 31 2e 31 31 7d 0a 20 20 74 65 73 74 5f 65 78 70  1.11}.  test_exp
2300: 72 20 65 78 70 72 2d 32 2e 32 33 20 7b 72 31 3d  r expr-2.23 {r1=
2310: 31 2e 32 33 2c 20 72 32 3d 32 2e 33 34 7d 20 7b  1.23, r2=2.34} {
2320: 6d 61 78 28 72 31 2c 72 32 2c 72 31 2b 72 32 2c  max(r1,r2,r1+r2,
2330: 72 31 2d 72 32 29 7d 20 7b 33 2e 35 37 7d 0a 20  r1-r2)} {3.57}. 
2340: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
2350: 32 2e 32 34 20 7b 72 31 3d 32 35 2e 30 2c 20 72  2.24 {r1=25.0, r
2360: 32 3d 31 31 2e 30 7d 20 7b 72 31 25 72 32 7d 20  2=11.0} {r1%r2} 
2370: 33 2e 30 0a 20 20 74 65 73 74 5f 65 78 70 72 20  3.0.  test_expr 
2380: 65 78 70 72 2d 32 2e 32 35 20 7b 72 31 3d 31 2e  expr-2.25 {r1=1.
2390: 32 33 2c 20 72 32 3d 4e 55 4c 4c 7d 20 7b 63 6f  23, r2=NULL} {co
23a0: 61 6c 65 73 63 65 28 72 31 2b 72 32 2c 39 39 2e  alesce(r1+r2,99.
23b0: 30 29 7d 20 39 39 2e 30 0a 20 20 74 65 73 74 5f  0)} 99.0.  test_
23c0: 65 78 70 72 20 65 78 70 72 2d 32 2e 32 36 20 7b  expr expr-2.26 {
23d0: 72 31 3d 31 65 33 30 30 2c 20 72 32 3d 31 65 33  r1=1e300, r2=1e3
23e0: 30 30 7d 20 7b 63 6f 61 6c 65 73 63 65 28 28 72  00} {coalesce((r
23f0: 31 2a 72 32 29 2a 30 2e 30 2c 39 39 2e 30 29 7d  1*r2)*0.0,99.0)}
2400: 20 39 39 2e 30 0a 20 20 74 65 73 74 5f 65 78 70   99.0.  test_exp
2410: 72 20 65 78 70 72 2d 32 2e 32 36 62 20 7b 72 31  r expr-2.26b {r1
2420: 3d 31 65 33 30 30 2c 20 72 32 3d 2d 31 65 33 30  =1e300, r2=-1e30
2430: 30 7d 20 7b 63 6f 61 6c 65 73 63 65 28 28 72 31  0} {coalesce((r1
2440: 2a 72 32 29 2a 30 2e 30 2c 39 39 2e 30 29 7d 20  *r2)*0.0,99.0)} 
2450: 39 39 2e 30 0a 20 20 74 65 73 74 5f 65 78 70 72  99.0.  test_expr
2460: 20 65 78 70 72 2d 32 2e 32 37 20 7b 72 31 3d 31   expr-2.27 {r1=1
2470: 2e 31 2c 20 72 32 3d 30 2e 30 7d 20 7b 72 31 2f  .1, r2=0.0} {r1/
2480: 72 32 7d 20 7b 7b 7d 7d 0a 20 20 74 65 73 74 5f  r2} {{}}.  test_
2490: 65 78 70 72 20 65 78 70 72 2d 32 2e 32 38 20 7b  expr expr-2.28 {
24a0: 72 31 3d 31 2e 31 2c 20 72 32 3d 30 2e 30 7d 20  r1=1.1, r2=0.0} 
24b0: 7b 72 31 25 72 32 7d 20 7b 7b 7d 7d 0a 7d 0a 0a  {r1%r2} {{}}.}..
24c0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33  test_expr expr-3
24d0: 2e 31 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  .1 {t1='abc', t2
24e0: 3d 27 78 79 7a 27 7d 20 7b 74 31 3c 74 32 7d 20  ='xyz'} {t1<t2} 
24f0: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
2500: 2d 33 2e 32 20 7b 74 31 3d 27 78 79 7a 27 2c 20  -3.2 {t1='xyz', 
2510: 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 3c 74 32  t2='abc'} {t1<t2
2520: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
2530: 70 72 2d 33 2e 33 20 7b 74 31 3d 27 61 62 63 27  pr-3.3 {t1='abc'
2540: 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 3c  , t2='abc'} {t1<
2550: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
2560: 65 78 70 72 2d 33 2e 34 20 7b 74 31 3d 27 61 62  expr-3.4 {t1='ab
2570: 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74  c', t2='xyz'} {t
2580: 31 3c 3d 74 32 7d 20 31 0a 74 65 73 74 5f 65 78  1<=t2} 1.test_ex
2590: 70 72 20 65 78 70 72 2d 33 2e 35 20 7b 74 31 3d  pr expr-3.5 {t1=
25a0: 27 78 79 7a 27 2c 20 74 32 3d 27 61 62 63 27 7d  'xyz', t2='abc'}
25b0: 20 7b 74 31 3c 3d 74 32 7d 20 30 0a 74 65 73 74   {t1<=t2} 0.test
25c0: 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 36 20 7b  _expr expr-3.6 {
25d0: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 62  t1='abc', t2='ab
25e0: 63 27 7d 20 7b 74 31 3c 3d 74 32 7d 20 31 0a 74  c'} {t1<=t2} 1.t
25f0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e  est_expr expr-3.
2600: 37 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  7 {t1='abc', t2=
2610: 27 78 79 7a 27 7d 20 7b 74 31 3e 74 32 7d 20 30  'xyz'} {t1>t2} 0
2620: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
2630: 33 2e 38 20 7b 74 31 3d 27 78 79 7a 27 2c 20 74  3.8 {t1='xyz', t
2640: 32 3d 27 61 62 63 27 7d 20 7b 74 31 3e 74 32 7d  2='abc'} {t1>t2}
2650: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
2660: 72 2d 33 2e 39 20 7b 74 31 3d 27 61 62 63 27 2c  r-3.9 {t1='abc',
2670: 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 3e 74   t2='abc'} {t1>t
2680: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
2690: 78 70 72 2d 33 2e 31 30 20 7b 74 31 3d 27 61 62  xpr-3.10 {t1='ab
26a0: 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74  c', t2='xyz'} {t
26b0: 31 3e 3d 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  1>=t2} 0.test_ex
26c0: 70 72 20 65 78 70 72 2d 33 2e 31 31 20 7b 74 31  pr expr-3.11 {t1
26d0: 3d 27 78 79 7a 27 2c 20 74 32 3d 27 61 62 63 27  ='xyz', t2='abc'
26e0: 7d 20 7b 74 31 3e 3d 74 32 7d 20 31 0a 74 65 73  } {t1>=t2} 1.tes
26f0: 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 31 32  t_expr expr-3.12
2700: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27   {t1='abc', t2='
2710: 61 62 63 27 7d 20 7b 74 31 3e 3d 74 32 7d 20 31  abc'} {t1>=t2} 1
2720: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
2730: 33 2e 31 33 20 7b 74 31 3d 27 61 62 63 27 2c 20  3.13 {t1='abc', 
2740: 74 32 3d 27 78 79 7a 27 7d 20 7b 74 31 3d 74 32  t2='xyz'} {t1=t2
2750: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
2760: 70 72 2d 33 2e 31 34 20 7b 74 31 3d 27 78 79 7a  pr-3.14 {t1='xyz
2770: 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31  ', t2='abc'} {t1
2780: 3d 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72  =t2} 0.test_expr
2790: 20 65 78 70 72 2d 33 2e 31 35 20 7b 74 31 3d 27   expr-3.15 {t1='
27a0: 61 62 63 27 2c 20 74 32 3d 27 61 62 63 27 7d 20  abc', t2='abc'} 
27b0: 7b 74 31 3d 74 32 7d 20 31 0a 74 65 73 74 5f 65  {t1=t2} 1.test_e
27c0: 78 70 72 20 65 78 70 72 2d 33 2e 31 36 20 7b 74  xpr expr-3.16 {t
27d0: 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 78 79 7a  1='abc', t2='xyz
27e0: 27 7d 20 7b 74 31 3d 3d 74 32 7d 20 30 0a 74 65  '} {t1==t2} 0.te
27f0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 31  st_expr expr-3.1
2800: 37 20 7b 74 31 3d 27 78 79 7a 27 2c 20 74 32 3d  7 {t1='xyz', t2=
2810: 27 61 62 63 27 7d 20 7b 74 31 3d 3d 74 32 7d 20  'abc'} {t1==t2} 
2820: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
2830: 2d 33 2e 31 38 20 7b 74 31 3d 27 61 62 63 27 2c  -3.18 {t1='abc',
2840: 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 3d 3d   t2='abc'} {t1==
2850: 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  t2} 1.test_expr 
2860: 65 78 70 72 2d 33 2e 31 39 20 7b 74 31 3d 27 61  expr-3.19 {t1='a
2870: 62 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b  bc', t2='xyz'} {
2880: 74 31 3c 3e 74 32 7d 20 31 0a 74 65 73 74 5f 65  t1<>t2} 1.test_e
2890: 78 70 72 20 65 78 70 72 2d 33 2e 32 30 20 7b 74  xpr expr-3.20 {t
28a0: 31 3d 27 78 79 7a 27 2c 20 74 32 3d 27 61 62 63  1='xyz', t2='abc
28b0: 27 7d 20 7b 74 31 3c 3e 74 32 7d 20 31 0a 74 65  '} {t1<>t2} 1.te
28c0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 32  st_expr expr-3.2
28d0: 31 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  1 {t1='abc', t2=
28e0: 27 61 62 63 27 7d 20 7b 74 31 3c 3e 74 32 7d 20  'abc'} {t1<>t2} 
28f0: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
2900: 2d 33 2e 32 32 20 7b 74 31 3d 27 61 62 63 27 2c  -3.22 {t1='abc',
2910: 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74 31 21 3d   t2='xyz'} {t1!=
2920: 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  t2} 1.test_expr 
2930: 65 78 70 72 2d 33 2e 32 33 20 7b 74 31 3d 27 78  expr-3.23 {t1='x
2940: 79 7a 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b  yz', t2='abc'} {
2950: 74 31 21 3d 74 32 7d 20 31 0a 74 65 73 74 5f 65  t1!=t2} 1.test_e
2960: 78 70 72 20 65 78 70 72 2d 33 2e 32 34 20 7b 74  xpr expr-3.24 {t
2970: 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 62 63  1='abc', t2='abc
2980: 27 7d 20 7b 74 31 21 3d 74 32 7d 20 30 0a 74 65  '} {t1!=t2} 0.te
2990: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 32  st_expr expr-3.2
29a0: 35 20 7b 74 31 3d 4e 55 4c 4c 2c 20 74 32 3d 27  5 {t1=NULL, t2='
29b0: 68 69 27 7d 20 7b 74 31 20 69 73 6e 75 6c 6c 7d  hi'} {t1 isnull}
29c0: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
29d0: 72 2d 33 2e 32 35 62 20 7b 74 31 3d 4e 55 4c 4c  r-3.25b {t1=NULL
29e0: 2c 20 74 32 3d 27 68 69 27 7d 20 7b 74 31 20 69  , t2='hi'} {t1 i
29f0: 73 20 6e 75 6c 6c 7d 20 31 0a 74 65 73 74 5f 65  s null} 1.test_e
2a00: 78 70 72 20 65 78 70 72 2d 33 2e 32 36 20 7b 74  xpr expr-3.26 {t
2a10: 31 3d 4e 55 4c 4c 2c 20 74 32 3d 27 68 69 27 7d  1=NULL, t2='hi'}
2a20: 20 7b 74 32 20 69 73 6e 75 6c 6c 7d 20 30 0a 74   {t2 isnull} 0.t
2a30: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e  est_expr expr-3.
2a40: 32 37 20 7b 74 31 3d 4e 55 4c 4c 2c 20 74 32 3d  27 {t1=NULL, t2=
2a50: 27 68 69 27 7d 20 7b 74 31 20 6e 6f 74 6e 75 6c  'hi'} {t1 notnul
2a60: 6c 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  l} 0.test_expr e
2a70: 78 70 72 2d 33 2e 32 38 20 7b 74 31 3d 4e 55 4c  xpr-3.28 {t1=NUL
2a80: 4c 2c 20 74 32 3d 27 68 69 27 7d 20 7b 74 32 20  L, t2='hi'} {t2 
2a90: 6e 6f 74 6e 75 6c 6c 7d 20 31 0a 74 65 73 74 5f  notnull} 1.test_
2aa0: 65 78 70 72 20 65 78 70 72 2d 33 2e 32 38 62 20  expr expr-3.28b 
2ab0: 7b 74 31 3d 4e 55 4c 4c 2c 20 74 32 3d 27 68 69  {t1=NULL, t2='hi
2ac0: 27 7d 20 7b 74 32 20 69 73 20 6e 6f 74 20 6e 75  '} {t2 is not nu
2ad0: 6c 6c 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  ll} 1.test_expr 
2ae0: 65 78 70 72 2d 33 2e 32 39 20 7b 74 31 3d 27 78  expr-3.29 {t1='x
2af0: 79 7a 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b  yz', t2='abc'} {
2b00: 74 31 7c 7c 74 32 7d 20 7b 78 79 7a 61 62 63 7d  t1||t2} {xyzabc}
2b10: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
2b20: 33 2e 33 30 20 7b 74 31 3d 4e 55 4c 4c 2c 20 74  3.30 {t1=NULL, t
2b30: 32 3d 27 61 62 63 27 7d 20 7b 74 31 7c 7c 74 32  2='abc'} {t1||t2
2b40: 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72  } {{}}.test_expr
2b50: 20 65 78 70 72 2d 33 2e 33 31 20 7b 74 31 3d 27   expr-3.31 {t1='
2b60: 78 79 7a 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b  xyz', t2=NULL} {
2b70: 74 31 7c 7c 74 32 7d 20 7b 7b 7d 7d 0a 74 65 73  t1||t2} {{}}.tes
2b80: 74 5f 65 78 70 72 20 65 78 70 72 2d 33 2e 33 32  t_expr expr-3.32
2b90: 20 7b 74 31 3d 27 78 79 7a 27 2c 20 74 32 3d 27   {t1='xyz', t2='
2ba0: 61 62 63 27 7d 20 7b 74 31 7c 7c 27 20 68 69 20  abc'} {t1||' hi 
2bb0: 27 7c 7c 74 32 7d 20 7b 7b 78 79 7a 20 68 69 20  '||t2} {{xyz hi 
2bc0: 61 62 63 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20  abc}}.test_expr 
2bd0: 65 70 78 72 2d 33 2e 33 33 20 7b 74 31 3d 27 61  epxr-3.33 {t1='a
2be0: 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63  bc', t2=NULL} {c
2bf0: 6f 61 6c 65 73 63 65 28 74 31 3c 74 32 2c 39 39  oalesce(t1<t2,99
2c00: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
2c10: 65 70 78 72 2d 33 2e 33 34 20 7b 74 31 3d 27 61  epxr-3.34 {t1='a
2c20: 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63  bc', t2=NULL} {c
2c30: 6f 61 6c 65 73 63 65 28 74 32 3c 74 31 2c 39 39  oalesce(t2<t1,99
2c40: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
2c50: 65 70 78 72 2d 33 2e 33 35 20 7b 74 31 3d 27 61  epxr-3.35 {t1='a
2c60: 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63  bc', t2=NULL} {c
2c70: 6f 61 6c 65 73 63 65 28 74 31 3e 74 32 2c 39 39  oalesce(t1>t2,99
2c80: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
2c90: 65 70 78 72 2d 33 2e 33 36 20 7b 74 31 3d 27 61  epxr-3.36 {t1='a
2ca0: 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63  bc', t2=NULL} {c
2cb0: 6f 61 6c 65 73 63 65 28 74 32 3e 74 31 2c 39 39  oalesce(t2>t1,99
2cc0: 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72 20  )} 99.test_expr 
2cd0: 65 70 78 72 2d 33 2e 33 37 20 7b 74 31 3d 27 61  epxr-3.37 {t1='a
2ce0: 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 63  bc', t2=NULL} {c
2cf0: 6f 61 6c 65 73 63 65 28 74 31 3c 3d 74 32 2c 39  oalesce(t1<=t2,9
2d00: 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70 72  9)} 99.test_expr
2d10: 20 65 70 78 72 2d 33 2e 33 38 20 7b 74 31 3d 27   epxr-3.38 {t1='
2d20: 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b  abc', t2=NULL} {
2d30: 63 6f 61 6c 65 73 63 65 28 74 32 3c 3d 74 31 2c  coalesce(t2<=t1,
2d40: 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78 70  99)} 99.test_exp
2d50: 72 20 65 70 78 72 2d 33 2e 33 39 20 7b 74 31 3d  r epxr-3.39 {t1=
2d60: 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20  'abc', t2=NULL} 
2d70: 7b 63 6f 61 6c 65 73 63 65 28 74 31 3e 3d 74 32  {coalesce(t1>=t2
2d80: 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65 78  ,99)} 99.test_ex
2d90: 70 72 20 65 70 78 72 2d 33 2e 34 30 20 7b 74 31  pr epxr-3.40 {t1
2da0: 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d  ='abc', t2=NULL}
2db0: 20 7b 63 6f 61 6c 65 73 63 65 28 74 32 3e 3d 74   {coalesce(t2>=t
2dc0: 31 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f 65  1,99)} 99.test_e
2dd0: 78 70 72 20 65 70 78 72 2d 33 2e 34 31 20 7b 74  xpr epxr-3.41 {t
2de0: 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c  1='abc', t2=NULL
2df0: 7d 20 7b 63 6f 61 6c 65 73 63 65 28 74 31 3d 3d  } {coalesce(t1==
2e00: 74 32 2c 39 39 29 7d 20 39 39 0a 74 65 73 74 5f  t2,99)} 99.test_
2e10: 65 78 70 72 20 65 70 78 72 2d 33 2e 34 32 20 7b  expr epxr-3.42 {
2e20: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55 4c  t1='abc', t2=NUL
2e30: 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 74 32 3d  L} {coalesce(t2=
2e40: 3d 74 31 2c 39 39 29 7d 20 39 39 0a 74 65 73 74  =t1,99)} 99.test
2e50: 5f 65 78 70 72 20 65 70 78 72 2d 33 2e 34 33 20  _expr epxr-3.43 
2e60: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e 55  {t1='abc', t2=NU
2e70: 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 74 31  LL} {coalesce(t1
2e80: 21 3d 74 32 2c 39 39 29 7d 20 39 39 0a 74 65 73  !=t2,99)} 99.tes
2e90: 74 5f 65 78 70 72 20 65 70 78 72 2d 33 2e 34 34  t_expr epxr-3.44
2ea0: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e   {t1='abc', t2=N
2eb0: 55 4c 4c 7d 20 7b 63 6f 61 6c 65 73 63 65 28 74  ULL} {coalesce(t
2ec0: 32 21 3d 74 31 2c 39 39 29 7d 20 39 39 0a 0a 74  2!=t1,99)} 99..t
2ed0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 34 2e  est_expr expr-4.
2ee0: 31 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  1 {t1='abc', t2=
2ef0: 27 41 62 63 27 7d 20 7b 74 31 3c 74 32 7d 20 30  'Abc'} {t1<t2} 0
2f00: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
2f10: 34 2e 32 20 7b 74 31 3d 27 61 62 63 27 2c 20 74  4.2 {t1='abc', t
2f20: 32 3d 27 41 62 63 27 7d 20 7b 74 31 3e 74 32 7d  2='Abc'} {t1>t2}
2f30: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
2f40: 72 2d 34 2e 33 20 7b 74 31 3d 27 61 62 63 27 2c  r-4.3 {t1='abc',
2f50: 20 74 32 3d 27 42 62 63 27 7d 20 7b 74 31 3c 74   t2='Bbc'} {t1<t
2f60: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
2f70: 78 70 72 2d 34 2e 34 20 7b 74 31 3d 27 61 62 63  xpr-4.4 {t1='abc
2f80: 27 2c 20 74 32 3d 27 42 62 63 27 7d 20 7b 74 31  ', t2='Bbc'} {t1
2f90: 3e 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72  >t2} 1.test_expr
2fa0: 20 65 78 70 72 2d 34 2e 35 20 7b 74 31 3d 27 30   expr-4.5 {t1='0
2fb0: 27 2c 20 74 32 3d 27 30 2e 30 27 7d 20 7b 74 31  ', t2='0.0'} {t1
2fc0: 3d 3d 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  ==t2} 0.test_exp
2fd0: 72 20 65 78 70 72 2d 34 2e 36 20 7b 74 31 3d 27  r expr-4.6 {t1='
2fe0: 30 2e 30 30 30 27 2c 20 74 32 3d 27 30 2e 30 27  0.000', t2='0.0'
2ff0: 7d 20 7b 74 31 3d 3d 74 32 7d 20 30 0a 74 65 73  } {t1==t2} 0.tes
3000: 74 5f 65 78 70 72 20 65 78 70 72 2d 34 2e 37 20  t_expr expr-4.7 
3010: 7b 74 31 3d 27 20 30 2e 30 30 30 27 2c 20 74 32  {t1=' 0.000', t2
3020: 3d 27 20 30 2e 30 27 7d 20 7b 74 31 3d 3d 74 32  =' 0.0'} {t1==t2
3030: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
3040: 70 72 2d 34 2e 38 20 7b 74 31 3d 27 30 2e 30 27  pr-4.8 {t1='0.0'
3050: 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31 3c  , t2='abc'} {t1<
3060: 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20  t2} 1.test_expr 
3070: 65 78 70 72 2d 34 2e 39 20 7b 74 31 3d 27 30 2e  expr-4.9 {t1='0.
3080: 30 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74  0', t2='abc'} {t
3090: 31 3d 3d 74 32 7d 20 30 0a 0a 69 66 63 61 70 61  1==t2} 0..ifcapa
30a0: 62 6c 65 20 66 6c 6f 61 74 69 6e 67 70 6f 69 6e  ble floatingpoin
30b0: 74 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 20  t {.  test_expr 
30c0: 65 78 70 72 2d 34 2e 31 30 20 7b 72 31 3d 27 30  expr-4.10 {r1='0
30d0: 2e 30 27 2c 20 72 32 3d 27 61 62 63 27 7d 20 7b  .0', r2='abc'} {
30e0: 72 31 3e 72 32 7d 20 30 0a 20 20 74 65 73 74 5f  r1>r2} 0.  test_
30f0: 65 78 70 72 20 65 78 70 72 2d 34 2e 31 31 20 7b  expr expr-4.11 {
3100: 72 31 3d 27 61 62 63 27 2c 20 72 32 3d 27 41 62  r1='abc', r2='Ab
3110: 63 27 7d 20 7b 72 31 3c 72 32 7d 20 30 0a 20 20  c'} {r1<r2} 0.  
3120: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 34  test_expr expr-4
3130: 2e 31 32 20 7b 72 31 3d 27 61 62 63 27 2c 20 72  .12 {r1='abc', r
3140: 32 3d 27 41 62 63 27 7d 20 7b 72 31 3e 72 32 7d  2='Abc'} {r1>r2}
3150: 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   1.  test_expr e
3160: 78 70 72 2d 34 2e 31 33 20 7b 72 31 3d 27 61 62  xpr-4.13 {r1='ab
3170: 63 27 2c 20 72 32 3d 27 42 62 63 27 7d 20 7b 72  c', r2='Bbc'} {r
3180: 31 3c 72 32 7d 20 30 0a 20 20 74 65 73 74 5f 65  1<r2} 0.  test_e
3190: 78 70 72 20 65 78 70 72 2d 34 2e 31 34 20 7b 72  xpr expr-4.14 {r
31a0: 31 3d 27 61 62 63 27 2c 20 72 32 3d 27 42 62 63  1='abc', r2='Bbc
31b0: 27 7d 20 7b 72 31 3e 72 32 7d 20 31 0a 20 20 74  '} {r1>r2} 1.  t
31c0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 34 2e  est_expr expr-4.
31d0: 31 35 20 7b 72 31 3d 27 30 27 2c 20 72 32 3d 27  15 {r1='0', r2='
31e0: 30 2e 30 27 7d 20 7b 72 31 3d 3d 72 32 7d 20 31  0.0'} {r1==r2} 1
31f0: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
3200: 72 2d 34 2e 31 36 20 7b 72 31 3d 27 30 2e 30 30  r-4.16 {r1='0.00
3210: 30 27 2c 20 72 32 3d 27 30 2e 30 27 7d 20 7b 72  0', r2='0.0'} {r
3220: 31 3d 3d 72 32 7d 20 31 0a 20 20 74 65 73 74 5f  1==r2} 1.  test_
3230: 65 78 70 72 20 65 78 70 72 2d 34 2e 31 37 20 7b  expr expr-4.17 {
3240: 72 31 3d 27 20 30 2e 30 30 30 27 2c 20 72 32 3d  r1=' 0.000', r2=
3250: 27 20 30 2e 30 27 7d 20 7b 72 31 3d 3d 72 32 7d  ' 0.0'} {r1==r2}
3260: 20 30 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   0.  test_expr e
3270: 78 70 72 2d 34 2e 31 38 20 7b 72 31 3d 27 30 2e  xpr-4.18 {r1='0.
3280: 30 27 2c 20 72 32 3d 27 61 62 63 27 7d 20 7b 72  0', r2='abc'} {r
3290: 31 3c 72 32 7d 20 31 0a 20 20 74 65 73 74 5f 65  1<r2} 1.  test_e
32a0: 78 70 72 20 65 78 70 72 2d 34 2e 31 39 20 7b 72  xpr expr-4.19 {r
32b0: 31 3d 27 30 2e 30 27 2c 20 72 32 3d 27 61 62 63  1='0.0', r2='abc
32c0: 27 7d 20 7b 72 31 3d 3d 72 32 7d 20 30 0a 20 20  '} {r1==r2} 0.  
32d0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 34  test_expr expr-4
32e0: 2e 32 30 20 7b 72 31 3d 27 30 2e 30 27 2c 20 72  .20 {r1='0.0', r
32f0: 32 3d 27 61 62 63 27 7d 20 7b 72 31 3e 72 32 7d  2='abc'} {r1>r2}
3300: 20 30 0a 7d 0a 0a 23 20 43 53 4c 20 69 73 20 74   0.}..# CSL is t
3310: 72 75 65 20 69 66 20 4c 49 4b 45 20 69 73 20 63  rue if LIKE is c
3320: 61 73 65 20 73 65 6e 73 69 74 69 76 65 20 61 6e  ase sensitive an
3330: 64 20 66 61 6c 73 65 20 69 66 20 6e 6f 74 2e 0a  d false if not..
3340: 23 20 4e 43 53 4c 20 69 73 20 74 68 65 20 6f 70  # NCSL is the op
3350: 70 6f 73 69 74 65 2e 20 20 55 73 65 20 74 68 65  posite.  Use the
3360: 73 65 20 76 61 72 69 61 62 6c 65 73 20 61 73 20  se variables as 
3370: 74 68 65 20 72 65 73 75 6c 74 0a 23 20 6f 6e 20  the result.# on 
3380: 6f 70 65 72 61 74 69 6f 6e 73 20 77 68 65 72 65  operations where
3390: 20 63 61 73 65 20 6d 61 6b 65 73 20 61 20 64 69   case makes a di
33a0: 66 66 65 72 65 6e 63 65 2e 0a 73 65 74 20 43 53  fference..set CS
33b0: 4c 20 24 73 71 6c 69 74 65 5f 6f 70 74 69 6f 6e  L $sqlite_option
33c0: 73 28 63 61 73 65 73 65 6e 73 69 74 69 76 65 6c  s(casesensitivel
33d0: 69 6b 65 29 0a 73 65 74 20 4e 43 53 4c 20 5b 65  ike).set NCSL [e
33e0: 78 70 72 20 7b 21 24 43 53 4c 7d 5d 0a 0a 74 65  xpr {!$CSL}]..te
33f0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 31  st_expr expr-5.1
3400: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27   {t1='abc', t2='
3410: 78 79 7a 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74  xyz'} {t1 LIKE t
3420: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
3430: 78 70 72 2d 35 2e 32 61 20 7b 74 31 3d 27 61 62  xpr-5.2a {t1='ab
3440: 63 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74  c', t2='abc'} {t
3450: 31 20 4c 49 4b 45 20 74 32 7d 20 31 0a 74 65 73  1 LIKE t2} 1.tes
3460: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 32 62  t_expr expr-5.2b
3470: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27   {t1='abc', t2='
3480: 41 42 43 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74  ABC'} {t1 LIKE t
3490: 32 7d 20 24 4e 43 53 4c 0a 74 65 73 74 5f 65 78  2} $NCSL.test_ex
34a0: 70 72 20 65 78 70 72 2d 35 2e 33 61 20 7b 74 31  pr expr-5.3a {t1
34b0: 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 5f 63 27  ='abc', t2='a_c'
34c0: 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 31  } {t1 LIKE t2} 1
34d0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
34e0: 35 2e 33 62 20 7b 74 31 3d 27 61 62 63 27 2c 20  5.3b {t1='abc', 
34f0: 74 32 3d 27 41 5f 43 27 7d 20 7b 74 31 20 4c 49  t2='A_C'} {t1 LI
3500: 4b 45 20 74 32 7d 20 24 4e 43 53 4c 0a 74 65 73  KE t2} $NCSL.tes
3510: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 34 20  t_expr expr-5.4 
3520: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61  {t1='abc', t2='a
3530: 62 63 5f 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74  bc_'} {t1 LIKE t
3540: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
3550: 78 70 72 2d 35 2e 35 61 20 7b 74 31 3d 27 61 62  xpr-5.5a {t1='ab
3560: 63 27 2c 20 74 32 3d 27 61 25 63 27 7d 20 7b 74  c', t2='a%c'} {t
3570: 31 20 4c 49 4b 45 20 74 32 7d 20 31 0a 74 65 73  1 LIKE t2} 1.tes
3580: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 35 62  t_expr expr-5.5b
3590: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27   {t1='abc', t2='
35a0: 41 25 43 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74  A%C'} {t1 LIKE t
35b0: 32 7d 20 24 4e 43 53 4c 0a 74 65 73 74 5f 65 78  2} $NCSL.test_ex
35c0: 70 72 20 65 78 70 72 2d 35 2e 35 63 20 7b 74 31  pr expr-5.5c {t1
35d0: 3d 27 61 62 64 63 27 2c 20 74 32 3d 27 61 25 63  ='abdc', t2='a%c
35e0: 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20  '} {t1 LIKE t2} 
35f0: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
3600: 2d 35 2e 35 64 20 7b 74 31 3d 27 61 63 27 2c 20  -5.5d {t1='ac', 
3610: 74 32 3d 27 61 25 63 27 7d 20 7b 74 31 20 4c 49  t2='a%c'} {t1 LI
3620: 4b 45 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78  KE t2} 1.test_ex
3630: 70 72 20 65 78 70 72 2d 35 2e 35 65 20 7b 74 31  pr expr-5.5e {t1
3640: 3d 27 61 63 27 2c 20 74 32 3d 27 41 25 43 27 7d  ='ac', t2='A%C'}
3650: 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 24 4e   {t1 LIKE t2} $N
3660: 43 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78  CSL.test_expr ex
3670: 70 72 2d 35 2e 36 61 20 7b 74 31 3d 27 61 62 78  pr-5.6a {t1='abx
3680: 79 7a 7a 79 63 27 2c 20 74 32 3d 27 61 25 63 27  yzzyc', t2='a%c'
3690: 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 31  } {t1 LIKE t2} 1
36a0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
36b0: 35 2e 36 62 20 7b 74 31 3d 27 61 62 78 79 7a 7a  5.6b {t1='abxyzz
36c0: 79 63 27 2c 20 74 32 3d 27 41 25 43 27 7d 20 7b  yc', t2='A%C'} {
36d0: 74 31 20 4c 49 4b 45 20 74 32 7d 20 24 4e 43 53  t1 LIKE t2} $NCS
36e0: 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  L.test_expr expr
36f0: 2d 35 2e 37 61 20 7b 74 31 3d 27 61 62 78 79 7a  -5.7a {t1='abxyz
3700: 7a 79 27 2c 20 74 32 3d 27 61 25 63 27 7d 20 7b  zy', t2='a%c'} {
3710: 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 74 65  t1 LIKE t2} 0.te
3720: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37  st_expr expr-5.7
3730: 62 20 7b 74 31 3d 27 61 62 78 79 7a 7a 79 27 2c  b {t1='abxyzzy',
3740: 20 74 32 3d 27 41 25 43 27 7d 20 7b 74 31 20 4c   t2='A%C'} {t1 L
3750: 49 4b 45 20 74 32 7d 20 30 0a 74 65 73 74 5f 65  IKE t2} 0.test_e
3760: 78 70 72 20 65 78 70 72 2d 35 2e 38 61 20 7b 74  xpr expr-5.8a {t
3770: 31 3d 27 61 62 78 79 7a 7a 79 63 78 27 2c 20 74  1='abxyzzycx', t
3780: 32 3d 27 61 25 63 27 7d 20 7b 74 31 20 4c 49 4b  2='a%c'} {t1 LIK
3790: 45 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  E t2} 0.test_exp
37a0: 72 20 65 78 70 72 2d 35 2e 38 62 20 7b 74 31 3d  r expr-5.8b {t1=
37b0: 27 61 62 78 79 7a 7a 79 63 79 27 2c 20 74 32 3d  'abxyzzycy', t2=
37c0: 27 61 25 63 78 27 7d 20 7b 74 31 20 4c 49 4b 45  'a%cx'} {t1 LIKE
37d0: 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72   t2} 0.test_expr
37e0: 20 65 78 70 72 2d 35 2e 38 63 20 7b 74 31 3d 27   expr-5.8c {t1='
37f0: 61 62 78 79 7a 7a 79 63 78 27 2c 20 74 32 3d 27  abxyzzycx', t2='
3800: 41 25 43 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74  A%C'} {t1 LIKE t
3810: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
3820: 78 70 72 2d 35 2e 38 64 20 7b 74 31 3d 27 61 62  xpr-5.8d {t1='ab
3830: 78 79 7a 7a 79 63 79 27 2c 20 74 32 3d 27 41 25  xyzzycy', t2='A%
3840: 43 58 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32  CX'} {t1 LIKE t2
3850: 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 0.test_expr ex
3860: 70 72 2d 35 2e 39 61 20 7b 74 31 3d 27 61 62 63  pr-5.9a {t1='abc
3870: 27 2c 20 74 32 3d 27 61 25 5f 63 27 7d 20 7b 74  ', t2='a%_c'} {t
3880: 31 20 4c 49 4b 45 20 74 32 7d 20 31 0a 74 65 73  1 LIKE t2} 1.tes
3890: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 39 62  t_expr expr-5.9b
38a0: 20 7b 74 31 3d 27 61 63 27 2c 20 74 32 3d 27 61   {t1='ac', t2='a
38b0: 25 5f 63 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74  %_c'} {t1 LIKE t
38c0: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
38d0: 78 70 72 2d 35 2e 39 63 20 7b 74 31 3d 27 61 62  xpr-5.9c {t1='ab
38e0: 63 27 2c 20 74 32 3d 27 41 25 5f 43 27 7d 20 7b  c', t2='A%_C'} {
38f0: 74 31 20 4c 49 4b 45 20 74 32 7d 20 24 4e 43 53  t1 LIKE t2} $NCS
3900: 4c 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  L.test_expr expr
3910: 2d 35 2e 39 64 20 7b 74 31 3d 27 61 63 27 2c 20  -5.9d {t1='ac', 
3920: 74 32 3d 27 41 25 5f 43 27 7d 20 7b 74 31 20 4c  t2='A%_C'} {t1 L
3930: 49 4b 45 20 74 32 7d 20 30 0a 74 65 73 74 5f 65  IKE t2} 0.test_e
3940: 78 70 72 20 65 78 70 72 2d 35 2e 31 30 61 20 7b  xpr expr-5.10a {
3950: 74 31 3d 27 61 62 78 79 7a 7a 79 63 27 2c 20 74  t1='abxyzzyc', t
3960: 32 3d 27 61 25 5f 63 27 7d 20 7b 74 31 20 4c 49  2='a%_c'} {t1 LI
3970: 4b 45 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78  KE t2} 1.test_ex
3980: 70 72 20 65 78 70 72 2d 35 2e 31 30 62 20 7b 74  pr expr-5.10b {t
3990: 31 3d 27 61 62 78 79 7a 7a 79 63 27 2c 20 74 32  1='abxyzzyc', t2
39a0: 3d 27 41 25 5f 43 27 7d 20 7b 74 31 20 4c 49 4b  ='A%_C'} {t1 LIK
39b0: 45 20 74 32 7d 20 24 4e 43 53 4c 0a 74 65 73 74  E t2} $NCSL.test
39c0: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 31 31 20  _expr expr-5.11 
39d0: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 78  {t1='abc', t2='x
39e0: 79 7a 27 7d 20 7b 74 31 20 4e 4f 54 20 4c 49 4b  yz'} {t1 NOT LIK
39f0: 45 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70  E t2} 1.test_exp
3a00: 72 20 65 78 70 72 2d 35 2e 31 32 61 20 7b 74 31  r expr-5.12a {t1
3a10: 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 62 63 27  ='abc', t2='abc'
3a20: 7d 20 7b 74 31 20 4e 4f 54 20 4c 49 4b 45 20 74  } {t1 NOT LIKE t
3a30: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
3a40: 78 70 72 2d 35 2e 31 32 62 20 7b 74 31 3d 27 61  xpr-5.12b {t1='a
3a50: 62 63 27 2c 20 74 32 3d 27 41 42 43 27 7d 20 7b  bc', t2='ABC'} {
3a60: 74 31 20 4e 4f 54 20 4c 49 4b 45 20 74 32 7d 20  t1 NOT LIKE t2} 
3a70: 24 43 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65  $CSL.test_expr e
3a80: 78 70 72 2d 35 2e 31 33 20 20 7b 74 31 3d 27 41  xpr-5.13  {t1='A
3a90: 27 7d 20 20 7b 74 31 20 4c 49 4b 45 20 27 41 25  '}  {t1 LIKE 'A%
3aa0: 5f 27 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  _'} 0.test_expr 
3ab0: 65 78 70 72 2d 35 2e 31 34 20 20 7b 74 31 3d 27  expr-5.14  {t1='
3ac0: 41 42 27 7d 20 7b 74 31 20 4c 49 4b 45 20 27 41  AB'} {t1 LIKE 'A
3ad0: 25 62 27 20 45 53 43 41 50 45 20 27 62 27 7d 20  %b' ESCAPE 'b'} 
3ae0: 30 0a 0a 23 20 54 68 65 20 66 6f 6c 6c 6f 77 69  0..# The followi
3af0: 6e 67 20 74 65 73 74 73 20 6f 6e 6c 79 20 77 6f  ng tests only wo
3b00: 72 6b 20 6f 6e 20 76 65 72 73 69 6f 6e 73 20 6f  rk on versions o
3b10: 66 20 54 43 4c 20 74 68 61 74 20 73 75 70 70 6f  f TCL that suppo
3b20: 72 74 20 55 6e 69 63 6f 64 65 0a 23 0a 69 66 20  rt Unicode.#.if 
3b30: 7b 22 5c 75 31 32 33 34 22 21 3d 22 75 31 32 33  {"\u1234"!="u123
3b40: 34 22 7d 20 7b 0a 20 20 74 65 73 74 5f 65 78 70  4"} {.  test_exp
3b50: 72 20 65 78 70 72 2d 35 2e 31 33 61 20 22 74 31  r expr-5.13a "t1
3b60: 3d 27 61 5c 75 30 30 38 30 63 27 2c 20 74 32 3d  ='a\u0080c', t2=
3b70: 27 61 5f 63 27 22 20 7b 74 31 20 4c 49 4b 45 20  'a_c'" {t1 LIKE 
3b80: 74 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70  t2} 1.  test_exp
3b90: 72 20 65 78 70 72 2d 35 2e 31 33 62 20 22 74 31  r expr-5.13b "t1
3ba0: 3d 27 61 5c 75 30 30 38 30 63 27 2c 20 74 32 3d  ='a\u0080c', t2=
3bb0: 27 41 5f 43 27 22 20 7b 74 31 20 4c 49 4b 45 20  'A_C'" {t1 LIKE 
3bc0: 74 32 7d 20 24 4e 43 53 4c 0a 20 20 74 65 73 74  t2} $NCSL.  test
3bd0: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 31 34 61  _expr expr-5.14a
3be0: 20 22 74 31 3d 27 61 5c 75 30 37 46 46 63 27 2c   "t1='a\u07FFc',
3bf0: 20 74 32 3d 27 61 5f 63 27 22 20 7b 74 31 20 4c   t2='a_c'" {t1 L
3c00: 49 4b 45 20 74 32 7d 20 31 0a 20 20 74 65 73 74  IKE t2} 1.  test
3c10: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 31 34 62  _expr expr-5.14b
3c20: 20 22 74 31 3d 27 61 5c 75 30 37 46 46 63 27 2c   "t1='a\u07FFc',
3c30: 20 74 32 3d 27 41 5f 43 27 22 20 7b 74 31 20 4c   t2='A_C'" {t1 L
3c40: 49 4b 45 20 74 32 7d 20 24 4e 43 53 4c 0a 20 20  IKE t2} $NCSL.  
3c50: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
3c60: 2e 31 35 61 20 22 74 31 3d 27 61 5c 75 30 38 30  .15a "t1='a\u080
3c70: 30 63 27 2c 20 74 32 3d 27 61 5f 63 27 22 20 7b  0c', t2='a_c'" {
3c80: 74 31 20 4c 49 4b 45 20 74 32 7d 20 31 0a 20 20  t1 LIKE t2} 1.  
3c90: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
3ca0: 2e 31 35 62 20 22 74 31 3d 27 61 5c 75 30 38 30  .15b "t1='a\u080
3cb0: 30 63 27 2c 20 74 32 3d 27 41 5f 43 27 22 20 7b  0c', t2='A_C'" {
3cc0: 74 31 20 4c 49 4b 45 20 74 32 7d 20 24 4e 43 53  t1 LIKE t2} $NCS
3cd0: 4c 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  L.  test_expr ex
3ce0: 70 72 2d 35 2e 31 36 61 20 22 74 31 3d 27 61 5c  pr-5.16a "t1='a\
3cf0: 75 46 46 46 46 63 27 2c 20 74 32 3d 27 61 5f 63  uFFFFc', t2='a_c
3d00: 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20  '" {t1 LIKE t2} 
3d10: 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  1.  test_expr ex
3d20: 70 72 2d 35 2e 31 36 62 20 22 74 31 3d 27 61 5c  pr-5.16b "t1='a\
3d30: 75 46 46 46 46 63 27 2c 20 74 32 3d 27 41 5f 43  uFFFFc', t2='A_C
3d40: 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20  '" {t1 LIKE t2} 
3d50: 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f 65 78 70  $NCSL.  test_exp
3d60: 72 20 65 78 70 72 2d 35 2e 31 37 20 22 74 31 3d  r expr-5.17 "t1=
3d70: 27 61 5c 75 30 30 38 30 27 2c 20 74 32 3d 27 41  'a\u0080', t2='A
3d80: 5f 5f 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32  __'" {t1 LIKE t2
3d90: 7d 20 30 0a 20 20 74 65 73 74 5f 65 78 70 72 20  } 0.  test_expr 
3da0: 65 78 70 72 2d 35 2e 31 38 20 22 74 31 3d 27 61  expr-5.18 "t1='a
3db0: 5c 75 30 37 46 46 27 2c 20 74 32 3d 27 41 5f 5f  \u07FF', t2='A__
3dc0: 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20  '" {t1 LIKE t2} 
3dd0: 30 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  0.  test_expr ex
3de0: 70 72 2d 35 2e 31 39 20 22 74 31 3d 27 61 5c 75  pr-5.19 "t1='a\u
3df0: 30 38 30 30 27 2c 20 74 32 3d 27 41 5f 5f 27 22  0800', t2='A__'"
3e00: 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a   {t1 LIKE t2} 0.
3e10: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
3e20: 2d 35 2e 32 30 20 22 74 31 3d 27 61 5c 75 46 46  -5.20 "t1='a\uFF
3e30: 46 46 27 2c 20 74 32 3d 27 41 5f 5f 27 22 20 7b  FF', t2='A__'" {
3e40: 74 31 20 4c 49 4b 45 20 74 32 7d 20 30 0a 20 20  t1 LIKE t2} 0.  
3e50: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
3e60: 2e 32 31 61 20 22 74 31 3d 27 61 78 5c 75 41 42  .21a "t1='ax\uAB
3e70: 43 44 27 2c 20 74 32 3d 27 61 5f 5c 75 41 42 43  CD', t2='a_\uABC
3e80: 44 27 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d  D'" {t1 LIKE t2}
3e90: 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   1.  test_expr e
3ea0: 78 70 72 2d 35 2e 32 31 62 20 22 74 31 3d 27 61  xpr-5.21b "t1='a
3eb0: 78 5c 75 41 42 43 44 27 2c 20 74 32 3d 27 41 5f  x\uABCD', t2='A_
3ec0: 5c 75 41 42 43 44 27 22 20 7b 74 31 20 4c 49 4b  \uABCD'" {t1 LIK
3ed0: 45 20 74 32 7d 20 24 4e 43 53 4c 0a 20 20 74 65  E t2} $NCSL.  te
3ee0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 32  st_expr expr-5.2
3ef0: 32 61 20 22 74 31 3d 27 61 78 5c 75 31 32 33 34  2a "t1='ax\u1234
3f00: 27 2c 20 74 32 3d 27 61 25 5c 75 31 32 33 34 27  ', t2='a%\u1234'
3f10: 22 20 7b 74 31 20 4c 49 4b 45 20 74 32 7d 20 31  " {t1 LIKE t2} 1
3f20: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
3f30: 72 2d 35 2e 32 32 62 20 22 74 31 3d 27 61 78 5c  r-5.22b "t1='ax\
3f40: 75 31 32 33 34 27 2c 20 74 32 3d 27 41 25 5c 75  u1234', t2='A%\u
3f50: 31 32 33 34 27 22 20 7b 74 31 20 4c 49 4b 45 20  1234'" {t1 LIKE 
3f60: 74 32 7d 20 24 4e 43 53 4c 0a 20 20 74 65 73 74  t2} $NCSL.  test
3f70: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 32 33 61  _expr expr-5.23a
3f80: 20 22 74 31 3d 27 61 78 5c 75 46 45 44 43 27 2c   "t1='ax\uFEDC',
3f90: 20 74 32 3d 27 61 5f 25 27 22 20 7b 74 31 20 4c   t2='a_%'" {t1 L
3fa0: 49 4b 45 20 74 32 7d 20 31 0a 20 20 74 65 73 74  IKE t2} 1.  test
3fb0: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 32 33 62  _expr expr-5.23b
3fc0: 20 22 74 31 3d 27 61 78 5c 75 46 45 44 43 27 2c   "t1='ax\uFEDC',
3fd0: 20 74 32 3d 27 41 5f 25 27 22 20 7b 74 31 20 4c   t2='A_%'" {t1 L
3fe0: 49 4b 45 20 74 32 7d 20 24 4e 43 53 4c 0a 20 20  IKE t2} $NCSL.  
3ff0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35  test_expr expr-5
4000: 2e 32 34 61 20 22 74 31 3d 27 61 78 5c 75 46 45  .24a "t1='ax\uFE
4010: 44 43 79 5c 75 46 45 44 43 27 2c 20 74 32 3d 27  DCy\uFEDC', t2='
4020: 61 25 5c 75 46 45 44 43 27 22 20 7b 74 31 20 4c  a%\uFEDC'" {t1 L
4030: 49 4b 45 20 74 32 7d 20 31 0a 20 20 74 65 73 74  IKE t2} 1.  test
4040: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 32 34 62  _expr expr-5.24b
4050: 20 22 74 31 3d 27 61 78 5c 75 46 45 44 43 79 5c   "t1='ax\uFEDCy\
4060: 75 46 45 44 43 27 2c 20 74 32 3d 27 41 25 5c 75  uFEDC', t2='A%\u
4070: 46 45 44 43 27 22 20 7b 74 31 20 4c 49 4b 45 20  FEDC'" {t1 LIKE 
4080: 74 32 7d 20 24 4e 43 53 4c 0a 7d 0a 0a 74 65 73  t2} $NCSL.}..tes
4090: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 35 34  t_expr expr-5.54
40a0: 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 4e   {t1='abc', t2=N
40b0: 55 4c 4c 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32  ULL} {t1 LIKE t2
40c0: 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72  } {{}}.test_expr
40d0: 20 65 78 70 72 2d 35 2e 35 35 20 7b 74 31 3d 27   expr-5.55 {t1='
40e0: 61 62 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b  abc', t2=NULL} {
40f0: 74 31 20 4e 4f 54 20 4c 49 4b 45 20 74 32 7d 20  t1 NOT LIKE t2} 
4100: 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65  {{}}.test_expr e
4110: 78 70 72 2d 35 2e 35 36 20 7b 74 31 3d 27 61 62  xpr-5.56 {t1='ab
4120: 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 74 32  c', t2=NULL} {t2
4130: 20 4c 49 4b 45 20 74 31 7d 20 7b 7b 7d 7d 0a 74   LIKE t1} {{}}.t
4140: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
4150: 35 37 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  57 {t1='abc', t2
4160: 3d 4e 55 4c 4c 7d 20 7b 74 32 20 4e 4f 54 20 4c  =NULL} {t2 NOT L
4170: 49 4b 45 20 74 31 7d 20 7b 7b 7d 7d 0a 0a 23 20  IKE t1} {{}}..# 
4180: 4c 49 4b 45 20 65 78 70 72 65 73 73 69 6f 6e 73  LIKE expressions
4190: 20 74 68 61 74 20 75 73 65 20 45 53 43 41 50 45   that use ESCAPE
41a0: 20 63 68 61 72 61 63 74 65 72 73 2e 0a 74 65 73   characters..tes
41b0: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 35 38  t_expr expr-5.58
41c0: 61 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  a {t1='abc', t2=
41d0: 27 61 5f 63 27 7d 20 20 20 7b 74 31 20 4c 49 4b  'a_c'}   {t1 LIK
41e0: 45 20 74 32 20 45 53 43 41 50 45 20 27 37 27 7d  E t2 ESCAPE '7'}
41f0: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
4200: 72 2d 35 2e 35 38 62 20 7b 74 31 3d 27 61 62 63  r-5.58b {t1='abc
4210: 27 2c 20 74 32 3d 27 41 5f 43 27 7d 20 20 20 7b  ', t2='A_C'}   {
4220: 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50  t1 LIKE t2 ESCAP
4230: 45 20 27 37 27 7d 20 24 4e 43 53 4c 0a 74 65 73  E '7'} $NCSL.tes
4240: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 35 39  t_expr expr-5.59
4250: 61 20 7b 74 31 3d 27 61 5f 63 27 2c 20 74 32 3d  a {t1='a_c', t2=
4260: 27 61 37 5f 63 27 7d 20 20 7b 74 31 20 4c 49 4b  'a7_c'}  {t1 LIK
4270: 45 20 74 32 20 45 53 43 41 50 45 20 27 37 27 7d  E t2 ESCAPE '7'}
4280: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
4290: 72 2d 35 2e 35 39 62 20 7b 74 31 3d 27 61 5f 63  r-5.59b {t1='a_c
42a0: 27 2c 20 74 32 3d 27 41 37 5f 43 27 7d 20 20 7b  ', t2='A7_C'}  {
42b0: 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50  t1 LIKE t2 ESCAP
42c0: 45 20 27 37 27 7d 20 24 4e 43 53 4c 0a 74 65 73  E '7'} $NCSL.tes
42d0: 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 36 30  t_expr expr-5.60
42e0: 61 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  a {t1='abc', t2=
42f0: 27 61 37 5f 63 27 7d 20 20 7b 74 31 20 4c 49 4b  'a7_c'}  {t1 LIK
4300: 45 20 74 32 20 45 53 43 41 50 45 20 27 37 27 7d  E t2 ESCAPE '7'}
4310: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
4320: 72 2d 35 2e 36 30 62 20 7b 74 31 3d 27 61 62 63  r-5.60b {t1='abc
4330: 27 2c 20 74 32 3d 27 41 37 5f 43 27 7d 20 20 7b  ', t2='A7_C'}  {
4340: 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50  t1 LIKE t2 ESCAP
4350: 45 20 27 37 27 7d 20 30 0a 74 65 73 74 5f 65 78  E '7'} 0.test_ex
4360: 70 72 20 65 78 70 72 2d 35 2e 36 31 61 20 7b 74  pr expr-5.61a {t
4370: 31 3d 27 61 37 58 63 27 2c 20 74 32 3d 27 61 37  1='a7Xc', t2='a7
4380: 5f 63 27 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32  _c'} {t1 LIKE t2
4390: 20 45 53 43 41 50 45 20 27 37 27 7d 20 30 0a 74   ESCAPE '7'} 0.t
43a0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
43b0: 36 31 62 20 7b 74 31 3d 27 61 37 58 63 27 2c 20  61b {t1='a7Xc', 
43c0: 74 32 3d 27 41 37 5f 43 27 7d 20 7b 74 31 20 4c  t2='A7_C'} {t1 L
43d0: 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 37  IKE t2 ESCAPE '7
43e0: 27 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  '} 0.test_expr e
43f0: 78 70 72 2d 35 2e 36 32 61 20 7b 74 31 3d 27 61  xpr-5.62a {t1='a
4400: 62 63 64 65 27 2c 20 74 32 3d 27 61 25 65 27 7d  bcde', t2='a%e'}
4410: 20 7b 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43   {t1 LIKE t2 ESC
4420: 41 50 45 20 27 37 27 7d 20 31 0a 74 65 73 74 5f  APE '7'} 1.test_
4430: 65 78 70 72 20 65 78 70 72 2d 35 2e 36 32 62 20  expr expr-5.62b 
4440: 7b 74 31 3d 27 61 62 63 64 65 27 2c 20 74 32 3d  {t1='abcde', t2=
4450: 27 41 25 45 27 7d 20 7b 74 31 20 4c 49 4b 45 20  'A%E'} {t1 LIKE 
4460: 74 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 24  t2 ESCAPE '7'} $
4470: 4e 43 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65  NCSL.test_expr e
4480: 78 70 72 2d 35 2e 36 33 61 20 7b 74 31 3d 27 61  xpr-5.63a {t1='a
4490: 62 63 64 65 27 2c 20 74 32 3d 27 61 37 25 65 27  bcde', t2='a7%e'
44a0: 7d 20 7b 74 31 20 4c 49 4b 45 20 74 32 20 45 53  } {t1 LIKE t2 ES
44b0: 43 41 50 45 20 27 37 27 7d 20 30 0a 74 65 73 74  CAPE '7'} 0.test
44c0: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 36 33 62  _expr expr-5.63b
44d0: 20 7b 74 31 3d 27 61 62 63 64 65 27 2c 20 74 32   {t1='abcde', t2
44e0: 3d 27 41 37 25 45 27 7d 20 7b 74 31 20 4c 49 4b  ='A7%E'} {t1 LIK
44f0: 45 20 74 32 20 45 53 43 41 50 45 20 27 37 27 7d  E t2 ESCAPE '7'}
4500: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
4510: 72 2d 35 2e 36 34 61 20 7b 74 31 3d 27 61 37 63  r-5.64a {t1='a7c
4520: 64 65 27 2c 20 74 32 3d 27 61 37 25 65 27 7d 20  de', t2='a7%e'} 
4530: 7b 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41  {t1 LIKE t2 ESCA
4540: 50 45 20 27 37 27 7d 20 30 0a 74 65 73 74 5f 65  PE '7'} 0.test_e
4550: 78 70 72 20 65 78 70 72 2d 35 2e 36 34 62 20 7b  xpr expr-5.64b {
4560: 74 31 3d 27 61 37 63 64 65 27 2c 20 74 32 3d 27  t1='a7cde', t2='
4570: 41 37 25 45 27 7d 20 7b 74 31 20 4c 49 4b 45 20  A7%E'} {t1 LIKE 
4580: 74 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 30  t2 ESCAPE '7'} 0
4590: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
45a0: 35 2e 36 35 61 20 7b 74 31 3d 27 61 37 63 64 65  5.65a {t1='a7cde
45b0: 27 2c 20 74 32 3d 27 61 37 37 25 65 27 7d 20 7b  ', t2='a77%e'} {
45c0: 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50  t1 LIKE t2 ESCAP
45d0: 45 20 27 37 27 7d 20 31 0a 74 65 73 74 5f 65 78  E '7'} 1.test_ex
45e0: 70 72 20 65 78 70 72 2d 35 2e 36 35 62 20 7b 74  pr expr-5.65b {t
45f0: 31 3d 27 61 37 63 64 65 27 2c 20 74 32 3d 27 41  1='a7cde', t2='A
4600: 37 37 25 45 27 7d 20 7b 74 31 20 4c 49 4b 45 20  77%E'} {t1 LIKE 
4610: 74 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 24  t2 ESCAPE '7'} $
4620: 4e 43 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65  NCSL.test_expr e
4630: 78 70 72 2d 35 2e 36 36 61 20 7b 74 31 3d 27 61  xpr-5.66a {t1='a
4640: 62 63 37 27 2c 20 74 32 3d 27 61 25 37 37 27 7d  bc7', t2='a%77'}
4650: 20 7b 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43   {t1 LIKE t2 ESC
4660: 41 50 45 20 27 37 27 7d 20 31 0a 74 65 73 74 5f  APE '7'} 1.test_
4670: 65 78 70 72 20 65 78 70 72 2d 35 2e 36 36 62 20  expr expr-5.66b 
4680: 7b 74 31 3d 27 61 62 63 37 27 2c 20 74 32 3d 27  {t1='abc7', t2='
4690: 41 25 37 37 27 7d 20 7b 74 31 20 4c 49 4b 45 20  A%77'} {t1 LIKE 
46a0: 74 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 24  t2 ESCAPE '7'} $
46b0: 4e 43 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65  NCSL.test_expr e
46c0: 78 70 72 2d 35 2e 36 37 61 20 7b 74 31 3d 27 61  xpr-5.67a {t1='a
46d0: 62 63 5f 27 2c 20 74 32 3d 27 61 25 37 5f 27 7d  bc_', t2='a%7_'}
46e0: 20 7b 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43   {t1 LIKE t2 ESC
46f0: 41 50 45 20 27 37 27 7d 20 31 0a 74 65 73 74 5f  APE '7'} 1.test_
4700: 65 78 70 72 20 65 78 70 72 2d 35 2e 36 37 62 20  expr expr-5.67b 
4710: 7b 74 31 3d 27 61 62 63 5f 27 2c 20 74 32 3d 27  {t1='abc_', t2='
4720: 41 25 37 5f 27 7d 20 7b 74 31 20 4c 49 4b 45 20  A%7_'} {t1 LIKE 
4730: 74 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 24  t2 ESCAPE '7'} $
4740: 4e 43 53 4c 0a 74 65 73 74 5f 65 78 70 72 20 65  NCSL.test_expr e
4750: 78 70 72 2d 35 2e 36 38 61 20 7b 74 31 3d 27 61  xpr-5.68a {t1='a
4760: 62 63 37 27 2c 20 74 32 3d 27 61 25 37 5f 27 7d  bc7', t2='a%7_'}
4770: 20 7b 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43   {t1 LIKE t2 ESC
4780: 41 50 45 20 27 37 27 7d 20 30 0a 74 65 73 74 5f  APE '7'} 0.test_
4790: 65 78 70 72 20 65 78 70 72 2d 35 2e 36 38 62 20  expr expr-5.68b 
47a0: 7b 74 31 3d 27 61 62 63 37 27 2c 20 74 32 3d 27  {t1='abc7', t2='
47b0: 41 25 37 5f 27 7d 20 7b 74 31 20 4c 49 4b 45 20  A%7_'} {t1 LIKE 
47c0: 74 32 20 45 53 43 41 50 45 20 27 37 27 7d 20 30  t2 ESCAPE '7'} 0
47d0: 0a 0a 23 20 54 68 65 73 65 20 61 72 65 20 74 68  ..# These are th
47e0: 65 20 73 61 6d 65 20 74 65 73 74 20 61 73 20 74  e same test as t
47f0: 68 65 20 62 6c 6f 63 6b 20 61 62 6f 76 65 2c 20  he block above, 
4800: 62 75 74 20 75 73 69 6e 67 20 61 20 6d 75 6c 74  but using a mult
4810: 69 2d 62 79 74 65 20 0a 23 20 63 68 61 72 61 63  i-byte .# charac
4820: 74 65 72 20 61 73 20 74 68 65 20 65 73 63 61 70  ter as the escap
4830: 65 20 63 68 61 72 61 63 74 65 72 2e 0a 69 66 20  e character..if 
4840: 7b 22 5c 75 31 32 33 34 22 21 3d 22 75 31 32 33  {"\u1234"!="u123
4850: 34 22 7d 20 7b 0a 20 20 74 65 73 74 5f 65 78 70  4"} {.  test_exp
4860: 72 20 65 78 70 72 2d 35 2e 36 39 61 20 22 74 31  r expr-5.69a "t1
4870: 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 5f 63 27  ='abc', t2='a_c'
4880: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
4890: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
48a0: 31 32 33 34 27 22 20 31 0a 20 20 74 65 73 74 5f  1234'" 1.  test_
48b0: 65 78 70 72 20 65 78 70 72 2d 35 2e 36 39 62 20  expr expr-5.69b 
48c0: 22 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 41  "t1='abc', t2='A
48d0: 5f 43 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31  _C'" \.      "t1
48e0: 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20   LIKE t2 ESCAPE 
48f0: 27 5c 75 31 32 33 34 27 22 20 24 4e 43 53 4c 0a  '\u1234'" $NCSL.
4900: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
4910: 2d 35 2e 37 30 61 20 22 74 31 3d 27 61 5f 63 27  -5.70a "t1='a_c'
4920: 2c 20 74 32 3d 27 61 5c 75 31 32 33 34 5f 63 27  , t2='a\u1234_c'
4930: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
4940: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
4950: 31 32 33 34 27 22 20 31 0a 20 20 74 65 73 74 5f  1234'" 1.  test_
4960: 65 78 70 72 20 65 78 70 72 2d 35 2e 37 30 62 20  expr expr-5.70b 
4970: 22 74 31 3d 27 61 5f 63 27 2c 20 74 32 3d 27 41  "t1='a_c', t2='A
4980: 5c 75 31 32 33 34 5f 43 27 22 20 5c 0a 20 20 20  \u1234_C'" \.   
4990: 20 20 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45     "t1 LIKE t2 E
49a0: 53 43 41 50 45 20 27 5c 75 31 32 33 34 27 22 20  SCAPE '\u1234'" 
49b0: 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f 65 78 70  $NCSL.  test_exp
49c0: 72 20 65 78 70 72 2d 35 2e 37 31 61 20 22 74 31  r expr-5.71a "t1
49d0: 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 5c 75 31  ='abc', t2='a\u1
49e0: 32 33 34 5f 63 27 22 20 5c 0a 20 20 20 20 20 20  234_c'" \.      
49f0: 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43   "t1 LIKE t2 ESC
4a00: 41 50 45 20 27 5c 75 31 32 33 34 27 22 20 30 0a  APE '\u1234'" 0.
4a10: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
4a20: 2d 35 2e 37 31 62 20 22 74 31 3d 27 61 62 63 27  -5.71b "t1='abc'
4a30: 2c 20 74 32 3d 27 41 5c 75 31 32 33 34 5f 43 27  , t2='A\u1234_C'
4a40: 22 20 5c 0a 20 20 20 20 20 20 20 22 74 31 20 4c  " \.       "t1 L
4a50: 49 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c  IKE t2 ESCAPE '\
4a60: 75 31 32 33 34 27 22 20 30 0a 20 20 74 65 73 74  u1234'" 0.  test
4a70: 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37 32 61  _expr expr-5.72a
4a80: 20 22 74 31 3d 27 61 5c 75 31 32 33 34 58 63 27   "t1='a\u1234Xc'
4a90: 2c 20 74 32 3d 27 61 5c 75 31 32 33 34 5f 63 27  , t2='a\u1234_c'
4aa0: 22 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49  " \.      "t1 LI
4ab0: 4b 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75  KE t2 ESCAPE '\u
4ac0: 31 32 33 34 27 22 20 30 0a 20 20 74 65 73 74 5f  1234'" 0.  test_
4ad0: 65 78 70 72 20 65 78 70 72 2d 35 2e 37 32 62 20  expr expr-5.72b 
4ae0: 22 74 31 3d 27 61 5c 75 31 32 33 34 58 63 27 2c  "t1='a\u1234Xc',
4af0: 20 74 32 3d 27 41 5c 75 31 32 33 34 5f 43 27 22   t2='A\u1234_C'"
4b00: 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49 4b   \.      "t1 LIK
4b10: 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75 31  E t2 ESCAPE '\u1
4b20: 32 33 34 27 22 20 30 0a 20 20 74 65 73 74 5f 65  234'" 0.  test_e
4b30: 78 70 72 20 65 78 70 72 2d 35 2e 37 33 61 20 22  xpr expr-5.73a "
4b40: 74 31 3d 27 61 62 63 64 65 27 2c 20 74 32 3d 27  t1='abcde', t2='
4b50: 61 25 65 27 22 20 5c 0a 20 20 20 20 20 20 22 74  a%e'" \.      "t
4b60: 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45  1 LIKE t2 ESCAPE
4b70: 20 27 5c 75 31 32 33 34 27 22 20 31 0a 20 20 74   '\u1234'" 1.  t
4b80: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e  est_expr expr-5.
4b90: 37 33 62 20 22 74 31 3d 27 61 62 63 64 65 27 2c  73b "t1='abcde',
4ba0: 20 74 32 3d 27 41 25 45 27 22 20 5c 0a 20 20 20   t2='A%E'" \.   
4bb0: 20 20 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45     "t1 LIKE t2 E
4bc0: 53 43 41 50 45 20 27 5c 75 31 32 33 34 27 22 20  SCAPE '\u1234'" 
4bd0: 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f 65 78 70  $NCSL.  test_exp
4be0: 72 20 65 78 70 72 2d 35 2e 37 34 61 20 22 74 31  r expr-5.74a "t1
4bf0: 3d 27 61 62 63 64 65 27 2c 20 74 32 3d 27 61 5c  ='abcde', t2='a\
4c00: 75 31 32 33 34 25 65 27 22 20 5c 0a 20 20 20 20  u1234%e'" \.    
4c10: 20 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53    "t1 LIKE t2 ES
4c20: 43 41 50 45 20 27 5c 75 31 32 33 34 27 22 20 30  CAPE '\u1234'" 0
4c30: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
4c40: 72 2d 35 2e 37 34 62 20 22 74 31 3d 27 61 62 63  r-5.74b "t1='abc
4c50: 64 65 27 2c 20 74 32 3d 27 41 5c 75 31 32 33 34  de', t2='A\u1234
4c60: 25 45 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31  %E'" \.      "t1
4c70: 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20   LIKE t2 ESCAPE 
4c80: 27 5c 75 31 32 33 34 27 22 20 30 0a 20 20 74 65  '\u1234'" 0.  te
4c90: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37  st_expr expr-5.7
4ca0: 35 61 20 22 74 31 3d 27 61 5c 75 31 32 33 34 63  5a "t1='a\u1234c
4cb0: 64 65 27 2c 20 74 32 3d 27 61 5c 75 31 32 33 34  de', t2='a\u1234
4cc0: 25 65 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31  %e'" \.      "t1
4cd0: 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20   LIKE t2 ESCAPE 
4ce0: 27 5c 75 31 32 33 34 27 22 20 30 0a 20 20 74 65  '\u1234'" 0.  te
4cf0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37  st_expr expr-5.7
4d00: 35 62 20 22 74 31 3d 27 61 5c 75 31 32 33 34 63  5b "t1='a\u1234c
4d10: 64 65 27 2c 20 74 32 3d 27 41 5c 75 31 32 33 34  de', t2='A\u1234
4d20: 25 45 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31  %E'" \.      "t1
4d30: 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20   LIKE t2 ESCAPE 
4d40: 27 5c 75 31 32 33 34 27 22 20 30 0a 20 20 74 65  '\u1234'" 0.  te
4d50: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37  st_expr expr-5.7
4d60: 36 61 20 22 74 31 3d 27 61 5c 75 31 32 33 34 63  6a "t1='a\u1234c
4d70: 64 65 27 2c 20 74 32 3d 27 61 5c 75 31 32 33 34  de', t2='a\u1234
4d80: 5c 75 31 32 33 34 25 65 27 22 20 5c 0a 20 20 20  \u1234%e'" \.   
4d90: 20 20 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45     "t1 LIKE t2 E
4da0: 53 43 41 50 45 20 27 5c 75 31 32 33 34 27 22 20  SCAPE '\u1234'" 
4db0: 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  1.  test_expr ex
4dc0: 70 72 2d 35 2e 37 36 62 20 22 74 31 3d 27 61 5c  pr-5.76b "t1='a\
4dd0: 75 31 32 33 34 63 64 65 27 2c 20 74 32 3d 27 41  u1234cde', t2='A
4de0: 5c 75 31 32 33 34 5c 75 31 32 33 34 25 45 27 22  \u1234\u1234%E'"
4df0: 20 5c 0a 20 20 20 20 20 20 22 74 31 20 4c 49 4b   \.      "t1 LIK
4e00: 45 20 74 32 20 45 53 43 41 50 45 20 27 5c 75 31  E t2 ESCAPE '\u1
4e10: 32 33 34 27 22 20 24 4e 43 53 4c 0a 20 20 74 65  234'" $NCSL.  te
4e20: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 35 2e 37  st_expr expr-5.7
4e30: 37 61 20 22 74 31 3d 27 61 62 63 5c 75 31 32 33  7a "t1='abc\u123
4e40: 34 27 2c 20 74 32 3d 27 61 25 5c 75 31 32 33 34  4', t2='a%\u1234
4e50: 5c 75 31 32 33 34 27 22 20 5c 0a 20 20 20 20 20  \u1234'" \.     
4e60: 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43   "t1 LIKE t2 ESC
4e70: 41 50 45 20 27 5c 75 31 32 33 34 27 22 20 31 0a  APE '\u1234'" 1.
4e80: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
4e90: 2d 35 2e 37 37 62 20 22 74 31 3d 27 61 62 63 5c  -5.77b "t1='abc\
4ea0: 75 31 32 33 34 27 2c 20 74 32 3d 27 41 25 5c 75  u1234', t2='A%\u
4eb0: 31 32 33 34 5c 75 31 32 33 34 27 22 20 5c 0a 20  1234\u1234'" \. 
4ec0: 20 20 20 20 20 22 74 31 20 4c 49 4b 45 20 74 32       "t1 LIKE t2
4ed0: 20 45 53 43 41 50 45 20 27 5c 75 31 32 33 34 27   ESCAPE '\u1234'
4ee0: 22 20 24 4e 43 53 4c 0a 20 20 74 65 73 74 5f 65  " $NCSL.  test_e
4ef0: 78 70 72 20 65 78 70 72 2d 35 2e 37 38 61 20 22  xpr expr-5.78a "
4f00: 74 31 3d 27 61 62 63 5f 27 2c 20 74 32 3d 27 61  t1='abc_', t2='a
4f10: 25 5c 75 31 32 33 34 5f 27 22 20 5c 0a 20 20 20  %\u1234_'" \.   
4f20: 20 20 20 22 74 31 20 4c 49 4b 45 20 74 32 20 45     "t1 LIKE t2 E
4f30: 53 43 41 50 45 20 27 5c 75 31 32 33 34 27 22 20  SCAPE '\u1234'" 
4f40: 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  1.  test_expr ex
4f50: 70 72 2d 35 2e 37 38 62 20 22 74 31 3d 27 61 62  pr-5.78b "t1='ab
4f60: 63 5f 27 2c 20 74 32 3d 27 41 25 5c 75 31 32 33  c_', t2='A%\u123
4f70: 34 5f 27 22 20 5c 0a 20 20 20 20 20 20 22 74 31  4_'" \.      "t1
4f80: 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50 45 20   LIKE t2 ESCAPE 
4f90: 27 5c 75 31 32 33 34 27 22 20 24 4e 43 53 4c 0a  '\u1234'" $NCSL.
4fa0: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
4fb0: 2d 35 2e 37 39 61 20 22 74 31 3d 27 61 62 63 5c  -5.79a "t1='abc\
4fc0: 75 31 32 33 34 27 2c 20 74 32 3d 27 61 25 5c 75  u1234', t2='a%\u
4fd0: 31 32 33 34 5f 27 22 20 5c 0a 20 20 20 20 20 20  1234_'" \.      
4fe0: 22 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41  "t1 LIKE t2 ESCA
4ff0: 50 45 20 27 5c 75 31 32 33 34 27 22 20 30 0a 20  PE '\u1234'" 0. 
5000: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
5010: 35 2e 37 39 62 20 22 74 31 3d 27 61 62 63 5c 75  5.79b "t1='abc\u
5020: 31 32 33 34 27 2c 20 74 32 3d 27 41 25 5c 75 31  1234', t2='A%\u1
5030: 32 33 34 5f 27 22 20 5c 0a 20 20 20 20 20 20 22  234_'" \.      "
5040: 74 31 20 4c 49 4b 45 20 74 32 20 45 53 43 41 50  t1 LIKE t2 ESCAP
5050: 45 20 27 5c 75 31 32 33 34 27 22 20 30 0a 7d 0a  E '\u1234'" 0.}.
5060: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
5070: 36 2e 31 20 7b 74 31 3d 27 61 62 63 27 2c 20 74  6.1 {t1='abc', t
5080: 32 3d 27 78 79 7a 27 7d 20 7b 74 31 20 47 4c 4f  2='xyz'} {t1 GLO
5090: 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  B t2} 0.test_exp
50a0: 72 20 65 78 70 72 2d 36 2e 32 20 7b 74 31 3d 27  r expr-6.2 {t1='
50b0: 61 62 63 27 2c 20 74 32 3d 27 41 42 43 27 7d 20  abc', t2='ABC'} 
50c0: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74  {t1 GLOB t2} 0.t
50d0: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
50e0: 33 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d  3 {t1='abc', t2=
50f0: 27 41 3f 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20  'A?C'} {t1 GLOB 
5100: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
5110: 65 78 70 72 2d 36 2e 34 20 7b 74 31 3d 27 61 62  expr-6.4 {t1='ab
5120: 63 27 2c 20 74 32 3d 27 61 3f 63 27 7d 20 7b 74  c', t2='a?c'} {t
5130: 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73  1 GLOB t2} 1.tes
5140: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 35 20  t_expr expr-6.5 
5150: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61  {t1='abc', t2='a
5160: 62 63 3f 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  bc?'} {t1 GLOB t
5170: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
5180: 78 70 72 2d 36 2e 36 20 7b 74 31 3d 27 61 62 63  xpr-6.6 {t1='abc
5190: 27 2c 20 74 32 3d 27 41 2a 43 27 7d 20 7b 74 31  ', t2='A*C'} {t1
51a0: 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74   GLOB t2} 0.test
51b0: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 37 20 7b  _expr expr-6.7 {
51c0: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 2a  t1='abc', t2='a*
51d0: 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  c'} {t1 GLOB t2}
51e0: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
51f0: 72 2d 36 2e 38 20 7b 74 31 3d 27 61 62 78 79 7a  r-6.8 {t1='abxyz
5200: 7a 79 63 27 2c 20 74 32 3d 27 61 2a 63 27 7d 20  zyc', t2='a*c'} 
5210: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74  {t1 GLOB t2} 1.t
5220: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
5230: 39 20 7b 74 31 3d 27 61 62 78 79 7a 7a 79 27 2c  9 {t1='abxyzzy',
5240: 20 74 32 3d 27 61 2a 63 27 7d 20 7b 74 31 20 47   t2='a*c'} {t1 G
5250: 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65  LOB t2} 0.test_e
5260: 78 70 72 20 65 78 70 72 2d 36 2e 31 30 20 7b 74  xpr expr-6.10 {t
5270: 31 3d 27 61 62 78 79 7a 7a 79 63 78 27 2c 20 74  1='abxyzzycx', t
5280: 32 3d 27 61 2a 63 27 7d 20 7b 74 31 20 47 4c 4f  2='a*c'} {t1 GLO
5290: 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  B t2} 0.test_exp
52a0: 72 20 65 78 70 72 2d 36 2e 31 31 20 7b 74 31 3d  r expr-6.11 {t1=
52b0: 27 61 62 63 27 2c 20 74 32 3d 27 78 79 7a 27 7d  'abc', t2='xyz'}
52c0: 20 7b 74 31 20 4e 4f 54 20 47 4c 4f 42 20 74 32   {t1 NOT GLOB t2
52d0: 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 1.test_expr ex
52e0: 70 72 2d 36 2e 31 32 20 7b 74 31 3d 27 61 62 63  pr-6.12 {t1='abc
52f0: 27 2c 20 74 32 3d 27 61 62 63 27 7d 20 7b 74 31  ', t2='abc'} {t1
5300: 20 4e 4f 54 20 47 4c 4f 42 20 74 32 7d 20 30 0a   NOT GLOB t2} 0.
5310: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5320: 2e 31 33 20 7b 74 31 3d 27 61 62 63 27 2c 20 74  .13 {t1='abc', t
5330: 32 3d 27 61 5b 62 78 5d 63 27 7d 20 7b 74 31 20  2='a[bx]c'} {t1 
5340: 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f  GLOB t2} 1.test_
5350: 65 78 70 72 20 65 78 70 72 2d 36 2e 31 34 20 7b  expr expr-6.14 {
5360: 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 5b  t1='abc', t2='a[
5370: 63 78 5d 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20  cx]c'} {t1 GLOB 
5380: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
5390: 65 78 70 72 2d 36 2e 31 35 20 7b 74 31 3d 27 61  expr-6.15 {t1='a
53a0: 62 63 27 2c 20 74 32 3d 27 61 5b 61 2d 64 5d 63  bc', t2='a[a-d]c
53b0: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
53c0: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
53d0: 2d 36 2e 31 36 20 7b 74 31 3d 27 61 62 63 27 2c  -6.16 {t1='abc',
53e0: 20 74 32 3d 27 61 5b 5e 61 2d 64 5d 63 27 7d 20   t2='a[^a-d]c'} 
53f0: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74  {t1 GLOB t2} 0.t
5400: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
5410: 31 37 20 7b 74 31 3d 27 61 62 63 27 2c 20 74 32  17 {t1='abc', t2
5420: 3d 27 61 5b 41 2d 44 63 5d 63 27 7d 20 7b 74 31  ='a[A-Dc]c'} {t1
5430: 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74   GLOB t2} 0.test
5440: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 31 38 20  _expr expr-6.18 
5450: 7b 74 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61  {t1='abc', t2='a
5460: 5b 5e 41 2d 44 63 5d 63 27 7d 20 7b 74 31 20 47  [^A-Dc]c'} {t1 G
5470: 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65  LOB t2} 1.test_e
5480: 78 70 72 20 65 78 70 72 2d 36 2e 31 39 20 7b 74  xpr expr-6.19 {t
5490: 31 3d 27 61 62 63 27 2c 20 74 32 3d 27 61 5b 5d  1='abc', t2='a[]
54a0: 62 5d 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  b]c'} {t1 GLOB t
54b0: 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 1.test_expr e
54c0: 78 70 72 2d 36 2e 32 30 20 7b 74 31 3d 27 61 62  xpr-6.20 {t1='ab
54d0: 63 27 2c 20 74 32 3d 27 61 5b 5e 5d 62 5d 63 27  c', t2='a[^]b]c'
54e0: 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 30  } {t1 GLOB t2} 0
54f0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
5500: 36 2e 32 31 61 20 7b 74 31 3d 27 61 62 63 64 65  6.21a {t1='abcde
5510: 66 67 27 2c 20 74 32 3d 27 61 2a 5b 64 65 5d 67  fg', t2='a*[de]g
5520: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
5530: 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  0.test_expr expr
5540: 2d 36 2e 32 31 62 20 7b 74 31 3d 27 61 62 63 64  -6.21b {t1='abcd
5550: 65 66 67 27 2c 20 74 32 3d 27 61 2a 5b 64 66 5d  efg', t2='a*[df]
5560: 67 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  g'} {t1 GLOB t2}
5570: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
5580: 72 2d 36 2e 32 31 63 20 7b 74 31 3d 27 61 62 63  r-6.21c {t1='abc
5590: 64 65 66 67 27 2c 20 74 32 3d 27 61 2a 5b 64 2d  defg', t2='a*[d-
55a0: 68 5d 67 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  h]g'} {t1 GLOB t
55b0: 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 1.test_expr e
55c0: 78 70 72 2d 36 2e 32 31 64 20 7b 74 31 3d 27 61  xpr-6.21d {t1='a
55d0: 62 63 64 65 66 67 27 2c 20 74 32 3d 27 61 2a 5b  bcdefg', t2='a*[
55e0: 62 2d 65 5d 67 27 7d 20 7b 74 31 20 47 4c 4f 42  b-e]g'} {t1 GLOB
55f0: 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72   t2} 0.test_expr
5600: 20 65 78 70 72 2d 36 2e 32 32 61 20 7b 74 31 3d   expr-6.22a {t1=
5610: 27 61 62 63 64 65 66 67 27 2c 20 74 32 3d 27 61  'abcdefg', t2='a
5620: 2a 5b 5e 64 65 5d 67 27 7d 20 7b 74 31 20 47 4c  *[^de]g'} {t1 GL
5630: 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78  OB t2} 1.test_ex
5640: 70 72 20 65 78 70 72 2d 36 2e 32 32 62 20 7b 74  pr expr-6.22b {t
5650: 31 3d 27 61 62 63 64 65 66 67 27 2c 20 74 32 3d  1='abcdefg', t2=
5660: 27 61 2a 5b 5e 64 65 66 5d 67 27 7d 20 7b 74 31  'a*[^def]g'} {t1
5670: 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74   GLOB t2} 0.test
5680: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 32 33 20  _expr expr-6.23 
5690: 7b 74 31 3d 27 61 62 63 64 65 66 67 27 2c 20 74  {t1='abcdefg', t
56a0: 32 3d 27 61 2a 3f 67 27 7d 20 7b 74 31 20 47 4c  2='a*?g'} {t1 GL
56b0: 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78  OB t2} 1.test_ex
56c0: 70 72 20 65 78 70 72 2d 36 2e 32 34 20 7b 74 31  pr expr-6.24 {t1
56d0: 3d 27 61 63 27 2c 20 74 32 3d 27 61 2a 63 27 7d  ='ac', t2='a*c'}
56e0: 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a   {t1 GLOB t2} 1.
56f0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5700: 2e 32 35 20 7b 74 31 3d 27 61 63 27 2c 20 74 32  .25 {t1='ac', t2
5710: 3d 27 61 2a 3f 63 27 7d 20 7b 74 31 20 47 4c 4f  ='a*?c'} {t1 GLO
5720: 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70  B t2} 0.test_exp
5730: 72 20 65 78 70 72 2d 36 2e 32 36 20 7b 74 31 3d  r expr-6.26 {t1=
5740: 27 61 2a 63 27 2c 20 74 32 3d 27 61 5b 2a 5d 63  'a*c', t2='a[*]c
5750: 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '} {t1 GLOB t2} 
5760: 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  1.test_expr expr
5770: 2d 36 2e 32 37 20 7b 74 31 3d 27 61 3f 63 27 2c  -6.27 {t1='a?c',
5780: 20 74 32 3d 27 61 5b 3f 5d 63 27 7d 20 7b 74 31   t2='a[?]c'} {t1
5790: 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74   GLOB t2} 1.test
57a0: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 32 38 20  _expr expr-6.28 
57b0: 7b 74 31 3d 27 61 5b 63 27 2c 20 74 32 3d 27 61  {t1='a[c', t2='a
57c0: 5b 5b 5d 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20  [[]c'} {t1 GLOB 
57d0: 74 32 7d 20 31 0a 0a 0a 23 20 54 68 65 73 65 20  t2} 1...# These 
57e0: 74 65 73 74 73 20 6f 6e 6c 79 20 77 6f 72 6b 20  tests only work 
57f0: 6f 6e 20 76 65 72 73 69 6f 6e 73 20 6f 66 20 54  on versions of T
5800: 43 4c 20 74 68 61 74 20 73 75 70 70 6f 72 74 20  CL that support 
5810: 55 6e 69 63 6f 64 65 0a 23 0a 69 66 20 7b 22 5c  Unicode.#.if {"\
5820: 75 31 32 33 34 22 21 3d 22 75 31 32 33 34 22 7d  u1234"!="u1234"}
5830: 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65   {.  test_expr e
5840: 78 70 72 2d 36 2e 32 36 20 22 74 31 3d 27 61 5c  xpr-6.26 "t1='a\
5850: 75 30 30 38 30 63 27 2c 20 74 32 3d 27 61 3f 63  u0080c', t2='a?c
5860: 27 22 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '" {t1 GLOB t2} 
5870: 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  1.  test_expr ex
5880: 70 72 2d 36 2e 32 37 20 22 74 31 3d 27 61 5c 75  pr-6.27 "t1='a\u
5890: 30 37 66 66 63 27 2c 20 74 32 3d 27 61 3f 63 27  07ffc', t2='a?c'
58a0: 22 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31  " {t1 GLOB t2} 1
58b0: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
58c0: 72 2d 36 2e 32 38 20 22 74 31 3d 27 61 5c 75 30  r-6.28 "t1='a\u0
58d0: 38 30 30 63 27 2c 20 74 32 3d 27 61 3f 63 27 22  800c', t2='a?c'"
58e0: 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a   {t1 GLOB t2} 1.
58f0: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
5900: 2d 36 2e 32 39 20 22 74 31 3d 27 61 5c 75 66 66  -6.29 "t1='a\uff
5910: 66 66 63 27 2c 20 74 32 3d 27 61 3f 63 27 22 20  ffc', t2='a?c'" 
5920: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20  {t1 GLOB t2} 1. 
5930: 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d   test_expr expr-
5940: 36 2e 33 30 20 22 74 31 3d 27 61 5c 75 31 32 33  6.30 "t1='a\u123
5950: 34 27 2c 20 74 32 3d 27 61 3f 27 22 20 7b 74 31  4', t2='a?'" {t1
5960: 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20 74 65   GLOB t2} 1.  te
5970: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 33  st_expr expr-6.3
5980: 31 20 22 74 31 3d 27 61 5c 75 31 32 33 34 27 2c  1 "t1='a\u1234',
5990: 20 74 32 3d 27 61 3f 3f 27 22 20 7b 74 31 20 47   t2='a??'" {t1 G
59a0: 4c 4f 42 20 74 32 7d 20 30 0a 20 20 74 65 73 74  LOB t2} 0.  test
59b0: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 33 32 20  _expr expr-6.32 
59c0: 22 74 31 3d 27 61 78 5c 75 31 32 33 34 27 2c 20  "t1='ax\u1234', 
59d0: 74 32 3d 27 61 3f 5c 75 31 32 33 34 27 22 20 7b  t2='a?\u1234'" {
59e0: 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20  t1 GLOB t2} 1.  
59f0: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5a00: 2e 33 33 20 22 74 31 3d 27 61 78 5c 75 31 32 33  .33 "t1='ax\u123
5a10: 34 27 2c 20 74 32 3d 27 61 2a 5c 75 31 32 33 34  4', t2='a*\u1234
5a20: 27 22 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '" {t1 GLOB t2} 
5a30: 31 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78  1.  test_expr ex
5a40: 70 72 2d 36 2e 33 34 20 22 74 31 3d 27 61 78 5c  pr-6.34 "t1='ax\
5a50: 75 31 32 33 34 79 5c 75 31 32 33 34 27 2c 20 74  u1234y\u1234', t
5a60: 32 3d 27 61 2a 5c 75 31 32 33 34 27 22 20 7b 74  2='a*\u1234'" {t
5a70: 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20 74  1 GLOB t2} 1.  t
5a80: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
5a90: 33 35 20 22 74 31 3d 27 61 5c 75 31 32 33 34 62  35 "t1='a\u1234b
5aa0: 27 2c 20 74 32 3d 27 61 5c 5b 78 5c 75 31 32 33  ', t2='a\[x\u123
5ab0: 34 79 5c 5d 62 27 22 20 7b 74 31 20 47 4c 4f 42  4y\]b'" {t1 GLOB
5ac0: 20 74 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78   t2} 1.  test_ex
5ad0: 70 72 20 65 78 70 72 2d 36 2e 33 36 20 22 74 31  pr expr-6.36 "t1
5ae0: 3d 27 61 5c 75 31 32 33 34 62 27 2c 20 74 32 3d  ='a\u1234b', t2=
5af0: 27 61 5c 5b 5c 75 31 32 33 33 2d 5c 75 31 32 33  'a\[\u1233-\u123
5b00: 35 5c 5d 62 27 22 20 7b 74 31 20 47 4c 4f 42 20  5\]b'" {t1 GLOB 
5b10: 74 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70  t2} 1.  test_exp
5b20: 72 20 65 78 70 72 2d 36 2e 33 37 20 22 74 31 3d  r expr-6.37 "t1=
5b30: 27 61 5c 75 31 32 33 34 62 27 2c 20 74 32 3d 27  'a\u1234b', t2='
5b40: 61 5c 5b 5c 75 31 32 33 34 2d 5c 75 31 32 34 66  a\[\u1234-\u124f
5b50: 5c 5d 62 27 22 20 7b 74 31 20 47 4c 4f 42 20 74  \]b'" {t1 GLOB t
5b60: 32 7d 20 31 0a 20 20 74 65 73 74 5f 65 78 70 72  2} 1.  test_expr
5b70: 20 65 78 70 72 2d 36 2e 33 38 20 22 74 31 3d 27   expr-6.38 "t1='
5b80: 61 5c 75 31 32 33 34 62 27 2c 20 74 32 3d 27 61  a\u1234b', t2='a
5b90: 5c 5b 5c 75 31 32 33 35 2d 5c 75 31 32 34 66 5c  \[\u1235-\u124f\
5ba0: 5d 62 27 22 20 7b 74 31 20 47 4c 4f 42 20 74 32  ]b'" {t1 GLOB t2
5bb0: 7d 20 30 0a 20 20 74 65 73 74 5f 65 78 70 72 20  } 0.  test_expr 
5bc0: 65 78 70 72 2d 36 2e 33 39 20 22 74 31 3d 27 61  expr-6.39 "t1='a
5bd0: 5c 75 31 32 33 34 62 27 2c 20 74 32 3d 27 61 5c  \u1234b', t2='a\
5be0: 5b 61 2d 5c 75 31 32 33 35 5c 5d 62 27 22 20 7b  [a-\u1235\]b'" {
5bf0: 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 20 20  t1 GLOB t2} 1.  
5c00: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
5c10: 2e 34 30 20 22 74 31 3d 27 61 5c 75 31 32 33 34  .40 "t1='a\u1234
5c20: 62 27 2c 20 74 32 3d 27 61 5c 5b 61 2d 5c 75 31  b', t2='a\[a-\u1
5c30: 32 33 34 5c 5d 62 27 22 20 7b 74 31 20 47 4c 4f  234\]b'" {t1 GLO
5c40: 42 20 74 32 7d 20 31 0a 20 20 74 65 73 74 5f 65  B t2} 1.  test_e
5c50: 78 70 72 20 65 78 70 72 2d 36 2e 34 31 20 22 74  xpr expr-6.41 "t
5c60: 31 3d 27 61 5c 75 31 32 33 34 62 27 2c 20 74 32  1='a\u1234b', t2
5c70: 3d 27 61 5c 5b 61 2d 5c 75 31 32 33 33 5c 5d 62  ='a\[a-\u1233\]b
5c80: 27 22 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20  '" {t1 GLOB t2} 
5c90: 30 0a 7d 0a 0a 74 65 73 74 5f 65 78 70 72 20 65  0.}..test_expr e
5ca0: 78 70 72 2d 36 2e 35 31 20 7b 74 31 3d 27 41 42  xpr-6.51 {t1='AB
5cb0: 43 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74  C', t2='xyz'} {t
5cc0: 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73  1 GLOB t2} 0.tes
5cd0: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 35 32  t_expr expr-6.52
5ce0: 20 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d 27   {t1='ABC', t2='
5cf0: 61 62 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  abc'} {t1 GLOB t
5d00: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
5d10: 78 70 72 2d 36 2e 35 33 20 7b 74 31 3d 27 41 42  xpr-6.53 {t1='AB
5d20: 43 27 2c 20 74 32 3d 27 61 3f 63 27 7d 20 7b 74  C', t2='a?c'} {t
5d30: 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73  1 GLOB t2} 0.tes
5d40: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 35 34  t_expr expr-6.54
5d50: 20 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d 27   {t1='ABC', t2='
5d60: 41 3f 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  A?C'} {t1 GLOB t
5d70: 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 1.test_expr e
5d80: 78 70 72 2d 36 2e 35 35 20 7b 74 31 3d 27 41 42  xpr-6.55 {t1='AB
5d90: 43 27 2c 20 74 32 3d 27 61 62 63 3f 27 7d 20 7b  C', t2='abc?'} {
5da0: 74 31 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65  t1 GLOB t2} 0.te
5db0: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 35  st_expr expr-6.5
5dc0: 36 20 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d  6 {t1='ABC', t2=
5dd0: 27 61 2a 63 27 7d 20 7b 74 31 20 47 4c 4f 42 20  'a*c'} {t1 GLOB 
5de0: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
5df0: 65 78 70 72 2d 36 2e 35 37 20 7b 74 31 3d 27 41  expr-6.57 {t1='A
5e00: 42 43 27 2c 20 74 32 3d 27 41 2a 43 27 7d 20 7b  BC', t2='A*C'} {
5e10: 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65  t1 GLOB t2} 1.te
5e20: 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 35  st_expr expr-6.5
5e30: 38 20 7b 74 31 3d 27 41 42 78 79 7a 7a 79 43 27  8 {t1='ABxyzzyC'
5e40: 2c 20 74 32 3d 27 41 2a 43 27 7d 20 7b 74 31 20  , t2='A*C'} {t1 
5e50: 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f  GLOB t2} 1.test_
5e60: 65 78 70 72 20 65 78 70 72 2d 36 2e 35 39 20 7b  expr expr-6.59 {
5e70: 74 31 3d 27 41 42 78 79 7a 7a 79 27 2c 20 74 32  t1='ABxyzzy', t2
5e80: 3d 27 41 2a 43 27 7d 20 7b 74 31 20 47 4c 4f 42  ='A*C'} {t1 GLOB
5e90: 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72   t2} 0.test_expr
5ea0: 20 65 78 70 72 2d 36 2e 36 30 20 7b 74 31 3d 27   expr-6.60 {t1='
5eb0: 41 42 78 79 7a 7a 79 43 78 27 2c 20 74 32 3d 27  ABxyzzyCx', t2='
5ec0: 41 2a 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74  A*C'} {t1 GLOB t
5ed0: 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65  2} 0.test_expr e
5ee0: 78 70 72 2d 36 2e 36 31 20 7b 74 31 3d 27 41 42  xpr-6.61 {t1='AB
5ef0: 43 27 2c 20 74 32 3d 27 78 79 7a 27 7d 20 7b 74  C', t2='xyz'} {t
5f00: 31 20 4e 4f 54 20 47 4c 4f 42 20 74 32 7d 20 31  1 NOT GLOB t2} 1
5f10: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
5f20: 36 2e 36 32 20 7b 74 31 3d 27 41 42 43 27 2c 20  6.62 {t1='ABC', 
5f30: 74 32 3d 27 41 42 43 27 7d 20 7b 74 31 20 4e 4f  t2='ABC'} {t1 NO
5f40: 54 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73  T GLOB t2} 0.tes
5f50: 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 36 33  t_expr expr-6.63
5f60: 20 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d 27   {t1='ABC', t2='
5f70: 41 5b 42 78 5d 43 27 7d 20 7b 74 31 20 47 4c 4f  A[Bx]C'} {t1 GLO
5f80: 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70  B t2} 1.test_exp
5f90: 72 20 65 78 70 72 2d 36 2e 36 34 20 7b 74 31 3d  r expr-6.64 {t1=
5fa0: 27 41 42 43 27 2c 20 74 32 3d 27 41 5b 43 78 5d  'ABC', t2='A[Cx]
5fb0: 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  C'} {t1 GLOB t2}
5fc0: 20 30 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   0.test_expr exp
5fd0: 72 2d 36 2e 36 35 20 7b 74 31 3d 27 41 42 43 27  r-6.65 {t1='ABC'
5fe0: 2c 20 74 32 3d 27 41 5b 41 2d 44 5d 43 27 7d 20  , t2='A[A-D]C'} 
5ff0: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74  {t1 GLOB t2} 1.t
6000: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
6010: 36 36 20 7b 74 31 3d 27 41 42 43 27 2c 20 74 32  66 {t1='ABC', t2
6020: 3d 27 41 5b 5e 41 2d 44 5d 43 27 7d 20 7b 74 31  ='A[^A-D]C'} {t1
6030: 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74   GLOB t2} 0.test
6040: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 36 37 20  _expr expr-6.67 
6050: 7b 74 31 3d 27 41 42 43 27 2c 20 74 32 3d 27 41  {t1='ABC', t2='A
6060: 5b 61 2d 64 43 5d 43 27 7d 20 7b 74 31 20 47 4c  [a-dC]C'} {t1 GL
6070: 4f 42 20 74 32 7d 20 30 0a 74 65 73 74 5f 65 78  OB t2} 0.test_ex
6080: 70 72 20 65 78 70 72 2d 36 2e 36 38 20 7b 74 31  pr expr-6.68 {t1
6090: 3d 27 41 42 43 27 2c 20 74 32 3d 27 41 5b 5e 61  ='ABC', t2='A[^a
60a0: 2d 64 43 5d 43 27 7d 20 7b 74 31 20 47 4c 4f 42  -dC]C'} {t1 GLOB
60b0: 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72   t2} 1.test_expr
60c0: 20 65 78 70 72 2d 36 2e 36 39 61 20 7b 74 31 3d   expr-6.69a {t1=
60d0: 27 41 42 43 27 2c 20 74 32 3d 27 41 5b 5d 42 5d  'ABC', t2='A[]B]
60e0: 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  C'} {t1 GLOB t2}
60f0: 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70   1.test_expr exp
6100: 72 2d 36 2e 36 39 62 20 7b 74 31 3d 27 41 5d 43  r-6.69b {t1='A]C
6110: 27 2c 20 74 32 3d 27 41 5b 5d 42 5d 43 27 7d 20  ', t2='A[]B]C'} 
6120: 7b 74 31 20 47 4c 4f 42 20 74 32 7d 20 31 0a 74  {t1 GLOB t2} 1.t
6130: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
6140: 37 30 61 20 7b 74 31 3d 27 41 42 43 27 2c 20 74  70a {t1='ABC', t
6150: 32 3d 27 41 5b 5e 5d 42 5d 43 27 7d 20 7b 74 31  2='A[^]B]C'} {t1
6160: 20 47 4c 4f 42 20 74 32 7d 20 30 0a 74 65 73 74   GLOB t2} 0.test
6170: 5f 65 78 70 72 20 65 78 70 72 2d 36 2e 37 30 62  _expr expr-6.70b
6180: 20 7b 74 31 3d 27 41 78 43 27 2c 20 74 32 3d 27   {t1='AxC', t2='
6190: 41 5b 5e 5d 42 5d 43 27 7d 20 7b 74 31 20 47 4c  A[^]B]C'} {t1 GL
61a0: 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78  OB t2} 1.test_ex
61b0: 70 72 20 65 78 70 72 2d 36 2e 37 30 63 20 7b 74  pr expr-6.70c {t
61c0: 31 3d 27 41 5d 43 27 2c 20 74 32 3d 27 41 5b 5e  1='A]C', t2='A[^
61d0: 5d 42 5d 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20  ]B]C'} {t1 GLOB 
61e0: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
61f0: 65 78 70 72 2d 36 2e 37 31 20 7b 74 31 3d 27 41  expr-6.71 {t1='A
6200: 42 43 44 45 46 47 27 2c 20 74 32 3d 27 41 2a 5b  BCDEFG', t2='A*[
6210: 44 45 5d 47 27 7d 20 7b 74 31 20 47 4c 4f 42 20  DE]G'} {t1 GLOB 
6220: 74 32 7d 20 30 0a 74 65 73 74 5f 65 78 70 72 20  t2} 0.test_expr 
6230: 65 78 70 72 2d 36 2e 37 32 20 7b 74 31 3d 27 41  expr-6.72 {t1='A
6240: 42 43 44 45 46 47 27 2c 20 74 32 3d 27 41 2a 5b  BCDEFG', t2='A*[
6250: 5e 44 45 5d 47 27 7d 20 7b 74 31 20 47 4c 4f 42  ^DE]G'} {t1 GLOB
6260: 20 74 32 7d 20 31 0a 74 65 73 74 5f 65 78 70 72   t2} 1.test_expr
6270: 20 65 78 70 72 2d 36 2e 37 33 20 7b 74 31 3d 27   expr-6.73 {t1='
6280: 41 42 43 44 45 46 47 27 2c 20 74 32 3d 27 41 2a  ABCDEFG', t2='A*
6290: 3f 47 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32  ?G'} {t1 GLOB t2
62a0: 7d 20 31 0a 74 65 73 74 5f 65 78 70 72 20 65 78  } 1.test_expr ex
62b0: 70 72 2d 36 2e 37 34 20 7b 74 31 3d 27 41 43 27  pr-6.74 {t1='AC'
62c0: 2c 20 74 32 3d 27 41 2a 43 27 7d 20 7b 74 31 20  , t2='A*C'} {t1 
62d0: 47 4c 4f 42 20 74 32 7d 20 31 0a 74 65 73 74 5f  GLOB t2} 1.test_
62e0: 65 78 70 72 20 65 78 70 72 2d 36 2e 37 35 20 7b  expr expr-6.75 {
62f0: 74 31 3d 27 41 43 27 2c 20 74 32 3d 27 41 2a 3f  t1='AC', t2='A*?
6300: 43 27 7d 20 7b 74 31 20 47 4c 4f 42 20 74 32 7d  C'} {t1 GLOB t2}
6310: 20 30 0a 0a 74 65 73 74 5f 65 78 70 72 20 65 78   0..test_expr ex
6320: 70 72 2d 36 2e 36 33 20 7b 74 31 3d 4e 55 4c 4c  pr-6.63 {t1=NULL
6330: 2c 20 74 32 3d 27 61 2a 3f 63 27 7d 20 7b 74 31  , t2='a*?c'} {t1
6340: 20 47 4c 4f 42 20 74 32 7d 20 7b 7b 7d 7d 0a 74   GLOB t2} {{}}.t
6350: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36 2e  est_expr expr-6.
6360: 36 34 20 7b 74 31 3d 27 61 63 27 2c 20 74 32 3d  64 {t1='ac', t2=
6370: 4e 55 4c 4c 7d 20 7b 74 31 20 47 4c 4f 42 20 74  NULL} {t1 GLOB t
6380: 32 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70  2} {{}}.test_exp
6390: 72 20 65 78 70 72 2d 36 2e 36 35 20 7b 74 31 3d  r expr-6.65 {t1=
63a0: 4e 55 4c 4c 2c 20 74 32 3d 27 61 2a 3f 63 27 7d  NULL, t2='a*?c'}
63b0: 20 7b 74 31 20 4e 4f 54 20 47 4c 4f 42 20 74 32   {t1 NOT GLOB t2
63c0: 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72  } {{}}.test_expr
63d0: 20 65 78 70 72 2d 36 2e 36 36 20 7b 74 31 3d 27   expr-6.66 {t1='
63e0: 61 63 27 2c 20 74 32 3d 4e 55 4c 4c 7d 20 7b 74  ac', t2=NULL} {t
63f0: 31 20 4e 4f 54 20 47 4c 4f 42 20 74 32 7d 20 7b  1 NOT GLOB t2} {
6400: 7b 7d 7d 0a 0a 23 20 43 68 65 63 6b 20 74 68 61  {}}..# Check tha
6410: 74 20 74 68 65 20 61 66 66 69 6e 69 74 79 20 6f  t the affinity o
6420: 66 20 61 20 43 41 53 54 20 65 78 70 72 65 73 73  f a CAST express
6430: 69 6f 6e 20 69 73 20 63 61 6c 63 75 6c 61 74 65  ion is calculate
6440: 64 20 63 6f 72 72 65 63 74 6c 79 2e 0a 69 66 63  d correctly..ifc
6450: 61 70 61 62 6c 65 20 63 61 73 74 20 7b 0a 20 20  apable cast {.  
6460: 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 36  test_expr expr-6
6470: 2e 36 37 20 7b 74 31 3d 27 30 31 27 2c 20 74 32  .67 {t1='01', t2
6480: 3d 31 7d 20 7b 74 31 20 3d 20 74 32 7d 20 30 0a  =1} {t1 = t2} 0.
6490: 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70 72    test_expr expr
64a0: 2d 36 2e 36 38 20 7b 74 31 3d 27 31 27 2c 20 74  -6.68 {t1='1', t
64b0: 32 3d 31 7d 20 7b 74 31 20 3d 20 74 32 7d 20 31  2=1} {t1 = t2} 1
64c0: 0a 20 20 74 65 73 74 5f 65 78 70 72 20 65 78 70  .  test_expr exp
64d0: 72 2d 36 2e 36 39 20 7b 74 31 3d 27 30 31 27 2c  r-6.69 {t1='01',
64e0: 20 74 32 3d 31 7d 20 7b 43 41 53 54 28 74 31 20   t2=1} {CAST(t1 
64f0: 41 53 20 49 4e 54 45 47 45 52 29 20 3d 20 74 32  AS INTEGER) = t2
6500: 7d 20 31 0a 7d 0a 0a 74 65 73 74 5f 65 78 70 72  } 1.}..test_expr
6510: 20 65 78 70 72 2d 63 61 73 65 2e 31 20 7b 69 31   expr-case.1 {i1
6520: 3d 31 2c 20 69 32 3d 32 7d 20 5c 0a 09 7b 43 41  =1, i2=2} \..{CA
6530: 53 45 20 57 48 45 4e 20 69 31 20 3d 20 69 32 20  SE WHEN i1 = i2 
6540: 54 48 45 4e 20 27 65 71 27 20 45 4c 53 45 20 27  THEN 'eq' ELSE '
6550: 6e 65 27 20 45 4e 44 7d 20 6e 65 0a 74 65 73 74  ne' END} ne.test
6560: 5f 65 78 70 72 20 65 78 70 72 2d 63 61 73 65 2e  _expr expr-case.
6570: 32 20 7b 69 31 3d 32 2c 20 69 32 3d 32 7d 20 5c  2 {i1=2, i2=2} \
6580: 0a 09 7b 43 41 53 45 20 57 48 45 4e 20 69 31 20  ..{CASE WHEN i1 
6590: 3d 20 69 32 20 54 48 45 4e 20 27 65 71 27 20 45  = i2 THEN 'eq' E
65a0: 4c 53 45 20 27 6e 65 27 20 45 4e 44 7d 20 65 71  LSE 'ne' END} eq
65b0: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
65c0: 63 61 73 65 2e 33 20 7b 69 31 3d 4e 55 4c 4c 2c  case.3 {i1=NULL,
65d0: 20 69 32 3d 32 7d 20 5c 0a 09 7b 43 41 53 45 20   i2=2} \..{CASE 
65e0: 57 48 45 4e 20 69 31 20 3d 20 69 32 20 54 48 45  WHEN i1 = i2 THE
65f0: 4e 20 27 65 71 27 20 45 4c 53 45 20 27 6e 65 27  N 'eq' ELSE 'ne'
6600: 20 45 4e 44 7d 20 6e 65 0a 74 65 73 74 5f 65 78   END} ne.test_ex
6610: 70 72 20 65 78 70 72 2d 63 61 73 65 2e 34 20 7b  pr expr-case.4 {
6620: 69 31 3d 32 2c 20 69 32 3d 4e 55 4c 4c 7d 20 5c  i1=2, i2=NULL} \
6630: 0a 09 7b 43 41 53 45 20 57 48 45 4e 20 69 31 20  ..{CASE WHEN i1 
6640: 3d 20 69 32 20 54 48 45 4e 20 27 65 71 27 20 45  = i2 THEN 'eq' E
6650: 4c 53 45 20 27 6e 65 27 20 45 4e 44 7d 20 6e 65  LSE 'ne' END} ne
6660: 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d  .test_expr expr-
6670: 63 61 73 65 2e 35 20 7b 69 31 3d 32 7d 20 5c 0a  case.5 {i1=2} \.
6680: 09 7b 43 41 53 45 20 69 31 20 57 48 45 4e 20 31  .{CASE i1 WHEN 1
6690: 20 54 48 45 4e 20 27 6f 6e 65 27 20 57 48 45 4e   THEN 'one' WHEN
66a0: 20 32 20 54 48 45 4e 20 27 74 77 6f 27 20 45 4c   2 THEN 'two' EL
66b0: 53 45 20 27 65 72 72 6f 72 27 20 45 4e 44 7d 20  SE 'error' END} 
66c0: 74 77 6f 0a 74 65 73 74 5f 65 78 70 72 20 65 78  two.test_expr ex
66d0: 70 72 2d 63 61 73 65 2e 36 20 7b 69 31 3d 31 7d  pr-case.6 {i1=1}
66e0: 20 5c 0a 09 7b 43 41 53 45 20 69 31 20 57 48 45   \..{CASE i1 WHE
66f0: 4e 20 31 20 54 48 45 4e 20 27 6f 6e 65 27 20 57  N 1 THEN 'one' W
6700: 48 45 4e 20 4e 55 4c 4c 20 54 48 45 4e 20 27 74  HEN NULL THEN 't
6710: 77 6f 27 20 45 4c 53 45 20 27 65 72 72 6f 72 27  wo' ELSE 'error'
6720: 20 45 4e 44 7d 20 6f 6e 65 0a 74 65 73 74 5f 65   END} one.test_e
6730: 78 70 72 20 65 78 70 72 2d 63 61 73 65 2e 37 20  xpr expr-case.7 
6740: 7b 69 31 3d 32 7d 20 5c 0a 09 7b 43 41 53 45 20  {i1=2} \..{CASE 
6750: 69 31 20 57 48 45 4e 20 31 20 54 48 45 4e 20 27  i1 WHEN 1 THEN '
6760: 6f 6e 65 27 20 57 48 45 4e 20 4e 55 4c 4c 20 54  one' WHEN NULL T
6770: 48 45 4e 20 27 74 77 6f 27 20 45 4c 53 45 20 27  HEN 'two' ELSE '
6780: 65 72 72 6f 72 27 20 45 4e 44 7d 20 65 72 72 6f  error' END} erro
6790: 72 0a 74 65 73 74 5f 65 78 70 72 20 65 78 70 72  r.test_expr expr
67a0: 2d 63 61 73 65 2e 38 20 7b 69 31 3d 33 7d 20 5c  -case.8 {i1=3} \
67b0: 0a 09 7b 43 41 53 45 20 69 31 20 57 48 45 4e 20  ..{CASE i1 WHEN 
67c0: 31 20 54 48 45 4e 20 27 6f 6e 65 27 20 57 48 45  1 THEN 'one' WHE
67d0: 4e 20 4e 55 4c 4c 20 54 48 45 4e 20 27 74 77 6f  N NULL THEN 'two
67e0: 27 20 45 4c 53 45 20 27 65 72 72 6f 72 27 20 45  ' ELSE 'error' E
67f0: 4e 44 7d 20 65 72 72 6f 72 0a 74 65 73 74 5f 65  ND} error.test_e
6800: 78 70 72 20 65 78 70 72 2d 63 61 73 65 2e 39 20  xpr expr-case.9 
6810: 7b 69 31 3d 33 7d 20 5c 0a 09 7b 43 41 53 45 20  {i1=3} \..{CASE 
6820: 69 31 20 57 48 45 4e 20 31 20 54 48 45 4e 20 27  i1 WHEN 1 THEN '
6830: 6f 6e 65 27 20 57 48 45 4e 20 32 20 54 48 45 4e  one' WHEN 2 THEN
6840: 20 27 74 77 6f 27 20 45 4c 53 45 20 27 65 72 72   'two' ELSE 'err
6850: 6f 72 27 20 45 4e 44 7d 20 65 72 72 6f 72 0a 74  or' END} error.t
6860: 65 73 74 5f 65 78 70 72 20 65 78 70 72 2d 63 61  est_expr expr-ca
6870: 73 65 2e 31 30 20 7b 69 31 3d 33 7d 20 5c 0a 09  se.10 {i1=3} \..
6880: 7b 43 41 53 45 20 69 31 20 57 48 45 4e 20 31 20  {CASE i1 WHEN 1 
6890: 54 48 45 4e 20 27 6f 6e 65 27 20 57 48 45 4e 20  THEN 'one' WHEN 
68a0: 32 20 54 48 45 4e 20 27 74 77 6f 27 20 45 4e 44  2 THEN 'two' END
68b0: 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72  } {{}}.test_expr
68c0: 20 65 78 70 72 2d 63 61 73 65 2e 31 31 20 7b 69   expr-case.11 {i
68d0: 31 3d 6e 75 6c 6c 7d 20 5c 0a 09 7b 43 41 53 45  1=null} \..{CASE
68e0: 20 69 31 20 57 48 45 4e 20 31 20 54 48 45 4e 20   i1 WHEN 1 THEN 
68f0: 27 6f 6e 65 27 20 57 48 45 4e 20 32 20 54 48 45  'one' WHEN 2 THE
6900: 4e 20 27 74 77 6f 27 20 45 4c 53 45 20 33 20 45  N 'two' ELSE 3 E
6910: 4e 44 7d 20 33 0a 74 65 73 74 5f 65 78 70 72 20  ND} 3.test_expr 
6920: 65 78 70 72 2d 63 61 73 65 2e 31 32 20 7b 69 31  expr-case.12 {i1
6930: 3d 31 7d 20 5c 0a 09 7b 43 41 53 45 20 69 31 20  =1} \..{CASE i1 
6940: 57 48 45 4e 20 31 20 54 48 45 4e 20 6e 75 6c 6c  WHEN 1 THEN null
6950: 20 57 48 45 4e 20 32 20 54 48 45 4e 20 27 74 77   WHEN 2 THEN 'tw
6960: 6f 27 20 45 4c 53 45 20 33 20 45 4e 44 7d 20 7b  o' ELSE 3 END} {
6970: 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 20 65 78  {}}.test_expr ex
6980: 70 72 2d 63 61 73 65 2e 31 33 20 7b 69 31 3d 37  pr-case.13 {i1=7
6990: 7d 20 5c 0a 09 7b 20 43 41 53 45 20 57 48 45 4e  } \..{ CASE WHEN
69a0: 20 69 31 20 3c 20 35 20 54 48 45 4e 20 27 6c 6f   i1 < 5 THEN 'lo
69b0: 77 27 20 0a 09 20 20 20 20 20 20 20 57 48 45 4e  w' ..       WHEN
69c0: 20 69 31 20 3c 20 31 30 20 54 48 45 4e 20 27 6d   i1 < 10 THEN 'm
69d0: 65 64 69 75 6d 27 20 0a 20 20 20 20 20 20 20 20  edium' .        
69e0: 20 20 20 20 20 20 20 57 48 45 4e 20 69 31 20 3c         WHEN i1 <
69f0: 20 31 35 20 54 48 45 4e 20 27 68 69 67 68 27 20   15 THEN 'high' 
6a00: 45 4c 53 45 20 27 65 72 72 6f 72 27 20 45 4e 44  ELSE 'error' END
6a10: 7d 20 6d 65 64 69 75 6d 0a 0a 0a 23 20 54 68 65  } medium...# The
6a20: 20 73 71 6c 69 74 65 45 78 70 72 49 66 46 61 6c   sqliteExprIfFal
6a30: 73 65 20 61 6e 64 20 73 71 6c 69 74 65 45 78 70  se and sqliteExp
6a40: 72 49 66 54 72 75 65 20 72 6f 75 74 69 6e 65 73  rIfTrue routines
6a50: 20 61 72 65 20 6f 6e 6c 79 0a 23 20 65 78 65 63   are only.# exec
6a60: 75 74 65 64 20 61 73 20 70 61 72 74 20 6f 66 20  uted as part of 
6a70: 61 20 57 48 45 52 45 20 63 6c 61 75 73 65 2e 20  a WHERE clause. 
6a80: 20 43 72 65 61 74 65 20 61 20 74 61 62 6c 65 20   Create a table 
6a90: 73 75 69 74 61 62 6c 65 0a 23 20 66 6f 72 20 74  suitable.# for t
6aa0: 65 73 74 69 6e 67 20 74 68 65 73 65 20 66 75 6e  esting these fun
6ab0: 63 74 69 6f 6e 73 2e 0a 23 0a 65 78 65 63 73 71  ctions..#.execsq
6ac0: 6c 20 7b 44 52 4f 50 20 54 41 42 4c 45 20 74 65  l {DROP TABLE te
6ad0: 73 74 31 7d 0a 65 78 65 63 73 71 6c 20 7b 43 52  st1}.execsql {CR
6ae0: 45 41 54 45 20 54 41 42 4c 45 20 74 65 73 74 31  EATE TABLE test1
6af0: 28 61 20 69 6e 74 2c 20 62 20 69 6e 74 29 3b 7d  (a int, b int);}
6b00: 0a 66 6f 72 20 7b 73 65 74 20 69 20 31 7d 20 7b  .for {set i 1} {
6b10: 24 69 3c 3d 32 30 7d 20 7b 69 6e 63 72 20 69 7d  $i<=20} {incr i}
6b20: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 22 49 4e   {.  execsql "IN
6b30: 53 45 52 54 20 49 4e 54 4f 20 74 65 73 74 31 20  SERT INTO test1 
6b40: 56 41 4c 55 45 53 28 24 69 2c 5b 65 78 70 72 20  VALUES($i,[expr 
6b50: 7b 31 3c 3c 24 69 7d 5d 29 22 0a 7d 0a 65 78 65  {1<<$i}])".}.exe
6b60: 63 73 71 6c 20 22 49 4e 53 45 52 54 20 49 4e 54  csql "INSERT INT
6b70: 4f 20 74 65 73 74 31 20 56 41 4c 55 45 53 28 4e  O test1 VALUES(N
6b80: 55 4c 4c 2c 30 29 22 0a 64 6f 5f 74 65 73 74 20  ULL,0)".do_test 
6b90: 65 78 70 72 2d 37 2e 31 20 7b 0a 20 20 65 78 65  expr-7.1 {.  exe
6ba0: 63 73 71 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46  csql {SELECT * F
6bb0: 52 4f 4d 20 74 65 73 74 31 20 4f 52 44 45 52 20  ROM test1 ORDER 
6bc0: 42 59 20 61 7d 0a 7d 20 7b 7b 7d 20 30 20 31 20  BY a}.} {{} 0 1 
6bd0: 32 20 32 20 34 20 33 20 38 20 34 20 31 36 20 35  2 2 4 3 8 4 16 5
6be0: 20 33 32 20 36 20 36 34 20 37 20 31 32 38 20 38   32 6 64 7 128 8
6bf0: 20 32 35 36 20 39 20 35 31 32 20 31 30 20 31 30   256 9 512 10 10
6c00: 32 34 20 31 31 20 32 30 34 38 20 31 32 20 34 30  24 11 2048 12 40
6c10: 39 36 20 31 33 20 38 31 39 32 20 31 34 20 31 36  96 13 8192 14 16
6c20: 33 38 34 20 31 35 20 33 32 37 36 38 20 31 36 20  384 15 32768 16 
6c30: 36 35 35 33 36 20 31 37 20 31 33 31 30 37 32 20  65536 17 131072 
6c40: 31 38 20 32 36 32 31 34 34 20 31 39 20 35 32 34  18 262144 19 524
6c50: 32 38 38 20 32 30 20 31 30 34 38 35 37 36 7d 0a  288 20 1048576}.
6c60: 0a 70 72 6f 63 20 74 65 73 74 5f 65 78 70 72 32  .proc test_expr2
6c70: 20 7b 6e 61 6d 65 20 65 78 70 72 20 72 65 73 75   {name expr resu
6c80: 6c 74 7d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  lt} {.  do_test 
6c90: 24 6e 61 6d 65 20 5b 66 6f 72 6d 61 74 20 7b 0a  $name [format {.
6ca0: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c      execsql {SEL
6cb0: 45 43 54 20 61 20 46 52 4f 4d 20 74 65 73 74 31  ECT a FROM test1
6cc0: 20 57 48 45 52 45 20 25 73 20 4f 52 44 45 52 20   WHERE %s ORDER 
6cd0: 42 59 20 61 7d 0a 20 20 7d 20 24 65 78 70 72 5d  BY a}.  } $expr]
6ce0: 20 24 72 65 73 75 6c 74 0a 7d 0a 0a 74 65 73 74   $result.}..test
6cf0: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 32 20  _expr2 expr-7.2 
6d00: 20 7b 61 3c 31 30 20 41 4e 44 20 61 3e 38 7d 20   {a<10 AND a>8} 
6d10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6d20: 20 7b 39 7d 0a 74 65 73 74 5f 65 78 70 72 32 20   {9}.test_expr2 
6d30: 65 78 70 72 2d 37 2e 33 20 20 7b 61 3c 3d 31 30  expr-7.3  {a<=10
6d40: 20 41 4e 44 20 61 3e 3d 38 7d 20 20 20 20 20 20   AND a>=8}      
6d50: 20 20 20 20 20 20 20 20 20 20 7b 38 20 39 20 31            {8 9 1
6d60: 30 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  0}.test_expr2 ex
6d70: 70 72 2d 37 2e 34 20 20 7b 61 3e 3d 38 20 41 4e  pr-7.4  {a>=8 AN
6d80: 44 20 61 3c 3d 31 30 7d 20 20 20 20 20 20 20 20  D a<=10}        
6d90: 20 20 20 20 20 20 20 20 7b 38 20 39 20 31 30 7d          {8 9 10}
6da0: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
6db0: 2d 37 2e 35 20 20 7b 61 3e 3d 32 30 20 4f 52 20  -7.5  {a>=20 OR 
6dc0: 61 3c 3d 31 7d 20 20 20 20 20 20 20 20 20 20 20  a<=1}           
6dd0: 20 20 20 20 20 20 7b 31 20 32 30 7d 0a 74 65 73        {1 20}.tes
6de0: 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 36  t_expr2 expr-7.6
6df0: 20 20 7b 62 21 3d 34 20 41 4e 44 20 61 3c 3d 33    {b!=4 AND a<=3
6e00: 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }               
6e10: 20 20 7b 31 20 33 7d 0a 74 65 73 74 5f 65 78 70    {1 3}.test_exp
6e20: 72 32 20 65 78 70 72 2d 37 2e 37 20 20 7b 62 3d  r2 expr-7.7  {b=
6e30: 3d 38 20 4f 52 20 62 3d 3d 31 36 20 4f 52 20 62  =8 OR b==16 OR b
6e40: 3d 3d 33 32 7d 20 20 20 20 20 20 20 20 7b 33 20  ==32}        {3 
6e50: 34 20 35 7d 0a 74 65 73 74 5f 65 78 70 72 32 20  4 5}.test_expr2 
6e60: 65 78 70 72 2d 37 2e 38 20 20 7b 4e 4f 54 20 62  expr-7.8  {NOT b
6e70: 3c 3e 38 20 4f 52 20 62 3d 3d 31 30 32 34 7d 20  <>8 OR b==1024} 
6e80: 20 20 20 20 20 20 20 20 20 20 7b 33 20 31 30 7d            {3 10}
6e90: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
6ea0: 2d 37 2e 39 20 20 7b 62 20 4c 49 4b 45 20 27 31  -7.9  {b LIKE '1
6eb0: 30 25 27 7d 20 20 20 20 20 20 20 20 20 20 20 20  0%'}            
6ec0: 20 20 20 20 20 20 7b 31 30 20 32 30 7d 0a 74 65        {10 20}.te
6ed0: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
6ee0: 31 30 20 7b 62 20 4c 49 4b 45 20 27 5f 34 27 7d  10 {b LIKE '_4'}
6ef0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6f00: 20 20 20 7b 36 7d 0a 74 65 73 74 5f 65 78 70 72     {6}.test_expr
6f10: 32 20 65 78 70 72 2d 37 2e 31 31 20 7b 61 20 47  2 expr-7.11 {a G
6f20: 4c 4f 42 20 27 31 3f 27 7d 20 20 20 20 20 20 20  LOB '1?'}       
6f30: 20 20 20 20 20 7b 31 30 20 31 31 20 31 32 20 31       {10 11 12 1
6f40: 33 20 31 34 20 31 35 20 31 36 20 31 37 20 31 38  3 14 15 16 17 18
6f50: 20 31 39 7d 0a 74 65 73 74 5f 65 78 70 72 32 20   19}.test_expr2 
6f60: 65 78 70 72 2d 37 2e 31 32 20 7b 62 20 47 4c 4f  expr-7.12 {b GLO
6f70: 42 20 27 31 2a 34 27 7d 20 20 20 20 20 20 20 20  B '1*4'}        
6f80: 20 20 20 20 20 20 20 20 20 20 7b 31 30 20 31 34            {10 14
6f90: 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70  }.test_expr2 exp
6fa0: 72 2d 37 2e 31 33 20 7b 62 20 47 4c 4f 42 20 27  r-7.13 {b GLOB '
6fb0: 2a 31 5b 34 35 36 5d 27 7d 20 20 20 20 20 20 20  *1[456]'}       
6fc0: 20 20 20 20 20 20 20 7b 34 7d 0a 74 65 73 74 5f         {4}.test_
6fd0: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 31 34 20  expr2 expr-7.14 
6fe0: 7b 61 20 49 53 4e 55 4c 4c 7d 20 20 20 20 20 20  {a ISNULL}      
6ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7000: 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 32 20  {{}}.test_expr2 
7010: 65 78 70 72 2d 37 2e 31 35 20 7b 61 20 4e 4f 54  expr-7.15 {a NOT
7020: 4e 55 4c 4c 20 41 4e 44 20 61 3c 33 7d 20 20 20  NULL AND a<3}   
7030: 20 20 20 20 20 20 20 20 20 20 7b 31 20 32 7d 0a            {1 2}.
7040: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
7050: 37 2e 31 36 20 7b 61 20 41 4e 44 20 61 3c 33 7d  7.16 {a AND a<3}
7060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7070: 20 20 20 20 20 7b 31 20 32 7d 0a 74 65 73 74 5f       {1 2}.test_
7080: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 31 37 20  expr2 expr-7.17 
7090: 7b 4e 4f 54 20 61 7d 20 20 20 20 20 20 20 20 20  {NOT a}         
70a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
70b0: 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  {}.test_expr2 ex
70c0: 70 72 2d 37 2e 31 38 20 7b 61 3d 3d 31 31 20 4f  pr-7.18 {a==11 O
70d0: 52 20 28 62 3e 31 30 30 30 20 41 4e 44 20 62 3c  R (b>1000 AND b<
70e0: 32 30 30 30 29 7d 20 20 7b 31 30 20 31 31 7d 0a  2000)}  {10 11}.
70f0: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
7100: 37 2e 31 39 20 7b 61 3c 3d 31 20 4f 52 20 61 3e  7.19 {a<=1 OR a>
7110: 3d 32 30 7d 20 20 20 20 20 20 20 20 20 20 20 20  =20}            
7120: 20 20 20 20 20 7b 31 20 32 30 7d 0a 74 65 73 74       {1 20}.test
7130: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 32 30  _expr2 expr-7.20
7140: 20 7b 61 3c 31 20 4f 52 20 61 3e 32 30 7d 20 20   {a<1 OR a>20}  
7150: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7160: 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65   {}.test_expr2 e
7170: 78 70 72 2d 37 2e 32 31 20 7b 61 3e 31 39 20 4f  xpr-7.21 {a>19 O
7180: 52 20 61 3c 31 7d 20 20 20 20 20 20 20 20 20 20  R a<1}          
7190: 20 20 20 20 20 20 20 20 20 7b 32 30 7d 0a 74 65           {20}.te
71a0: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
71b0: 32 32 20 7b 61 21 3d 31 20 4f 52 20 61 3d 31 30  22 {a!=1 OR a=10
71c0: 30 7d 20 5c 0a 20 20 20 20 20 20 20 20 20 20 20  0} \.           
71d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 32                {2
71e0: 20 33 20 34 20 35 20 36 20 37 20 38 20 39 20 31   3 4 5 6 7 8 9 1
71f0: 30 20 31 31 20 31 32 20 31 33 20 31 34 20 31 35  0 11 12 13 14 15
7200: 20 31 36 20 31 37 20 31 38 20 31 39 20 32 30 7d   16 17 18 19 20}
7210: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
7220: 2d 37 2e 32 33 20 7b 28 61 20 6e 6f 74 6e 75 6c  -7.23 {(a notnul
7230: 6c 20 41 4e 44 20 61 3c 34 29 20 4f 52 20 61 3d  l AND a<4) OR a=
7240: 3d 38 7d 20 20 20 7b 31 20 32 20 33 20 38 7d 0a  =8}   {1 2 3 8}.
7250: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
7260: 37 2e 32 34 20 7b 61 20 4c 49 4b 45 20 27 32 5f  7.24 {a LIKE '2_
7270: 27 20 4f 52 20 61 3d 3d 38 7d 20 20 20 20 20 20  ' OR a==8}      
7280: 20 20 20 20 20 7b 38 20 32 30 7d 0a 74 65 73 74       {8 20}.test
7290: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 32 35  _expr2 expr-7.25
72a0: 20 7b 61 20 47 4c 4f 42 20 27 32 3f 27 20 4f 52   {a GLOB '2?' OR
72b0: 20 61 3d 3d 38 7d 20 20 20 20 20 20 20 20 20 20   a==8}          
72c0: 20 7b 38 20 32 30 7d 0a 74 65 73 74 5f 65 78 70   {8 20}.test_exp
72d0: 72 32 20 65 78 70 72 2d 37 2e 32 36 20 7b 61 20  r2 expr-7.26 {a 
72e0: 69 73 6e 75 6c 6c 20 4f 52 20 61 3d 38 7d 20 20  isnull OR a=8}  
72f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 7b 7d               {{}
7300: 20 38 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65   8}.test_expr2 e
7310: 78 70 72 2d 37 2e 32 37 20 7b 61 20 6e 6f 74 6e  xpr-7.27 {a notn
7320: 75 6c 6c 20 4f 52 20 61 3d 38 7d 20 5c 0a 20 20  ull OR a=8} \.  
7330: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7340: 20 20 20 20 20 20 20 20 7b 31 20 32 20 33 20 34          {1 2 3 4
7350: 20 35 20 36 20 37 20 38 20 39 20 31 30 20 31 31   5 6 7 8 9 10 11
7360: 20 31 32 20 31 33 20 31 34 20 31 35 20 31 36 20   12 13 14 15 16 
7370: 31 37 20 31 38 20 31 39 20 32 30 7d 0a 74 65 73  17 18 19 20}.tes
7380: 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 32  t_expr2 expr-7.2
7390: 38 20 7b 61 3c 30 20 4f 52 20 62 3d 30 7d 20 7b  8 {a<0 OR b=0} {
73a0: 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65  {}}.test_expr2 e
73b0: 78 70 72 2d 37 2e 32 39 20 7b 62 3d 30 20 4f 52  xpr-7.29 {b=0 OR
73c0: 20 61 3c 30 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f   a<0} {{}}.test_
73d0: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 33 30 20  expr2 expr-7.30 
73e0: 7b 61 3c 30 20 41 4e 44 20 62 3d 30 7d 20 7b 7d  {a<0 AND b=0} {}
73f0: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
7400: 2d 37 2e 33 31 20 7b 62 3d 30 20 41 4e 44 20 61  -7.31 {b=0 AND a
7410: 3c 30 7d 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72  <0} {}.test_expr
7420: 32 20 65 78 70 72 2d 37 2e 33 32 20 7b 61 20 49  2 expr-7.32 {a I
7430: 53 20 4e 55 4c 4c 20 41 4e 44 20 28 61 3c 30 20  S NULL AND (a<0 
7440: 4f 52 20 62 3d 30 29 7d 20 7b 7b 7d 7d 0a 74 65  OR b=0)} {{}}.te
7450: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
7460: 33 33 20 7b 61 20 49 53 20 4e 55 4c 4c 20 41 4e  33 {a IS NULL AN
7470: 44 20 28 62 3d 30 20 4f 52 20 61 3c 30 29 7d 20  D (b=0 OR a<0)} 
7480: 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70 72 32 20  {{}}.test_expr2 
7490: 65 78 70 72 2d 37 2e 33 34 20 7b 61 20 49 53 20  expr-7.34 {a IS 
74a0: 4e 55 4c 4c 20 41 4e 44 20 28 61 3c 30 20 41 4e  NULL AND (a<0 AN
74b0: 44 20 62 3d 30 29 7d 20 7b 7d 0a 74 65 73 74 5f  D b=0)} {}.test_
74c0: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 33 35 20  expr2 expr-7.35 
74d0: 7b 61 20 49 53 20 4e 55 4c 4c 20 41 4e 44 20 28  {a IS NULL AND (
74e0: 62 3d 30 20 41 4e 44 20 61 3c 30 29 7d 20 7b 7d  b=0 AND a<0)} {}
74f0: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
7500: 2d 37 2e 33 32 20 7b 28 61 3c 30 20 4f 52 20 62  -7.32 {(a<0 OR b
7510: 3d 30 29 20 41 4e 44 20 61 20 49 53 20 4e 55 4c  =0) AND a IS NUL
7520: 4c 7d 20 7b 7b 7d 7d 0a 74 65 73 74 5f 65 78 70  L} {{}}.test_exp
7530: 72 32 20 65 78 70 72 2d 37 2e 33 33 20 7b 28 62  r2 expr-7.33 {(b
7540: 3d 30 20 4f 52 20 61 3c 30 29 20 41 4e 44 20 61  =0 OR a<0) AND a
7550: 20 49 53 20 4e 55 4c 4c 7d 20 7b 7b 7d 7d 0a 74   IS NULL} {{}}.t
7560: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
7570: 2e 33 34 20 7b 28 61 3c 30 20 41 4e 44 20 62 3d  .34 {(a<0 AND b=
7580: 30 29 20 41 4e 44 20 61 20 49 53 20 4e 55 4c 4c  0) AND a IS NULL
7590: 7d 20 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20  } {}.test_expr2 
75a0: 65 78 70 72 2d 37 2e 33 35 20 7b 28 62 3d 30 20  expr-7.35 {(b=0 
75b0: 41 4e 44 20 61 3c 30 29 20 41 4e 44 20 61 20 49  AND a<0) AND a I
75c0: 53 20 4e 55 4c 4c 7d 20 7b 7d 0a 74 65 73 74 5f  S NULL} {}.test_
75d0: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 33 36 20  expr2 expr-7.36 
75e0: 7b 61 3c 32 20 4f 52 20 28 61 3c 30 20 4f 52 20  {a<2 OR (a<0 OR 
75f0: 62 3d 30 29 7d 20 7b 7b 7d 20 31 7d 0a 74 65 73  b=0)} {{} 1}.tes
7600: 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 33  t_expr2 expr-7.3
7610: 37 20 7b 61 3c 32 20 4f 52 20 28 62 3d 30 20 4f  7 {a<2 OR (b=0 O
7620: 52 20 61 3c 30 29 7d 20 7b 7b 7d 20 31 7d 0a 74  R a<0)} {{} 1}.t
7630: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
7640: 2e 33 38 20 7b 61 3c 32 20 4f 52 20 28 61 3c 30  .38 {a<2 OR (a<0
7650: 20 41 4e 44 20 62 3d 30 29 7d 20 7b 31 7d 0a 74   AND b=0)} {1}.t
7660: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
7670: 2e 33 39 20 7b 61 3c 32 20 4f 52 20 28 62 3d 30  .39 {a<2 OR (b=0
7680: 20 41 4e 44 20 61 3c 30 29 7d 20 7b 31 7d 0a 69   AND a<0)} {1}.i
7690: 66 63 61 70 61 62 6c 65 20 66 6c 6f 61 74 69 6e  fcapable floatin
76a0: 67 70 6f 69 6e 74 20 7b 0a 20 20 74 65 73 74 5f  gpoint {.  test_
76b0: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 34 30 20  expr2 expr-7.40 
76c0: 7b 28 28 61 3c 32 20 4f 52 20 61 20 49 53 20 4e  {((a<2 OR a IS N
76d0: 55 4c 4c 29 20 41 4e 44 20 62 3c 33 29 20 4f 52  ULL) AND b<3) OR
76e0: 20 62 3e 31 65 31 30 7d 20 7b 7b 7d 20 31 7d 0a   b>1e10} {{} 1}.
76f0: 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70  }.test_expr2 exp
7700: 72 2d 37 2e 34 31 20 7b 61 20 42 45 54 57 45 45  r-7.41 {a BETWEE
7710: 4e 20 2d 31 20 41 4e 44 20 31 7d 20 7b 31 7d 0a  N -1 AND 1} {1}.
7720: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
7730: 37 2e 34 32 20 7b 61 20 4e 4f 54 20 42 45 54 57  7.42 {a NOT BETW
7740: 45 45 4e 20 32 20 41 4e 44 20 31 30 30 7d 20 7b  EEN 2 AND 100} {
7750: 31 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  1}.test_expr2 ex
7760: 70 72 2d 37 2e 34 33 20 7b 28 62 2b 31 32 33 34  pr-7.43 {(b+1234
7770: 29 7c 7c 27 74 68 69 73 20 69 73 20 61 20 73 74  )||'this is a st
7780: 72 69 6e 67 20 74 68 61 74 20 69 73 20 61 74 20  ring that is at 
7790: 6c 65 61 73 74 20 33 32 20 63 68 61 72 61 63 74  least 32 charact
77a0: 65 72 73 20 6c 6f 6e 67 27 20 42 45 54 57 45 45  ers long' BETWEE
77b0: 4e 20 31 20 41 4e 44 20 32 7d 20 7b 7d 0a 74 65  N 1 AND 2} {}.te
77c0: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
77d0: 34 34 20 7b 31 32 33 7c 7c 27 78 61 62 63 64 65  44 {123||'xabcde
77e0: 66 67 68 69 6a 6b 6c 6d 6e 6f 70 71 72 73 74 75  fghijklmnopqrstu
77f0: 76 77 79 78 7a 30 31 32 33 34 35 36 37 38 39 30  vwyxz01234567890
7800: 27 7c 7c 61 20 42 45 54 57 45 45 4e 20 27 31 32  '||a BETWEEN '12
7810: 33 61 27 20 41 4e 44 20 27 31 32 33 62 27 7d 20  3a' AND '123b'} 
7820: 7b 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78  {}.test_expr2 ex
7830: 70 72 2d 37 2e 34 35 20 7b 28 28 31 32 33 7c 7c  pr-7.45 {((123||
7840: 27 78 61 62 63 64 65 66 67 68 69 6a 6b 6c 6d 6e  'xabcdefghijklmn
7850: 6f 70 71 72 73 74 75 76 77 79 78 7a 30 31 32 33  opqrstuvwyxz0123
7860: 34 35 36 37 38 39 30 27 7c 7c 61 29 20 42 45 54  4567890'||a) BET
7870: 57 45 45 4e 20 27 31 32 33 61 27 20 41 4e 44 20  WEEN '123a' AND 
7880: 27 31 32 33 62 27 29 3c 30 7d 20 7b 7d 0a 74 65  '123b')<0} {}.te
7890: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
78a0: 34 36 20 7b 28 28 31 32 33 7c 7c 27 78 61 62 63  46 {((123||'xabc
78b0: 64 65 66 67 68 69 6a 6b 6c 6d 6e 6f 70 71 72 73  defghijklmnopqrs
78c0: 74 75 76 77 79 78 7a 30 31 32 33 34 35 36 37 38  tuvwyxz012345678
78d0: 39 30 27 7c 7c 61 29 20 42 45 54 57 45 45 4e 20  90'||a) BETWEEN 
78e0: 27 31 32 33 61 27 20 41 4e 44 20 27 31 32 33 7a  '123a' AND '123z
78f0: 27 29 3e 30 7d 20 7b 31 20 32 20 33 20 34 20 35  ')>0} {1 2 3 4 5
7900: 20 36 20 37 20 38 20 39 20 31 30 20 31 31 20 31   6 7 8 9 10 11 1
7910: 32 20 31 33 20 31 34 20 31 35 20 31 36 20 31 37  2 13 14 15 16 17
7920: 20 31 38 20 31 39 20 32 30 7d 0a 0a 74 65 73 74   18 19 20}..test
7930: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 35 30  _expr2 expr-7.50
7940: 20 7b 28 28 61 20 62 65 74 77 65 65 6e 20 31 20   {((a between 1 
7950: 61 6e 64 20 32 20 4f 52 20 30 29 20 41 4e 44 20  and 2 OR 0) AND 
7960: 31 29 20 4f 52 20 30 7d 20 7b 31 20 32 7d 0a 74  1) OR 0} {1 2}.t
7970: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
7980: 2e 35 31 20 7b 28 28 61 20 6e 6f 74 20 62 65 74  .51 {((a not bet
7990: 77 65 65 6e 20 33 20 61 6e 64 20 31 30 30 20 4f  ween 3 and 100 O
79a0: 52 20 30 29 20 41 4e 44 20 31 29 20 4f 52 20 30  R 0) AND 1) OR 0
79b0: 7d 20 7b 31 20 32 7d 0a 0a 69 66 63 61 70 61 62  } {1 2}..ifcapab
79c0: 6c 65 20 73 75 62 71 75 65 72 79 20 7b 0a 20 20  le subquery {.  
79d0: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
79e0: 37 2e 35 32 20 7b 28 28 61 20 69 6e 20 28 31 2c  7.52 {((a in (1,
79f0: 32 29 20 4f 52 20 30 29 20 41 4e 44 20 31 29 20  2) OR 0) AND 1) 
7a00: 4f 52 20 30 7d 20 7b 31 20 32 7d 0a 20 20 74 65  OR 0} {1 2}.  te
7a10: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
7a20: 35 33 20 5c 0a 20 20 20 20 20 20 7b 28 28 61 20  53 \.      {((a 
7a30: 6e 6f 74 20 69 6e 20 28 33 2c 34 2c 35 2c 36 2c  not in (3,4,5,6,
7a40: 37 2c 38 2c 39 2c 31 30 29 20 4f 52 20 30 29 20  7,8,9,10) OR 0) 
7a50: 41 4e 44 20 61 3c 31 31 29 20 4f 52 20 30 7d 20  AND a<11) OR 0} 
7a60: 7b 31 20 32 7d 0a 7d 0a 74 65 73 74 5f 65 78 70  {1 2}.}.test_exp
7a70: 72 32 20 65 78 70 72 2d 37 2e 35 34 20 7b 28 28  r2 expr-7.54 {((
7a80: 61 3e 30 20 4f 52 20 30 29 20 41 4e 44 20 61 3c  a>0 OR 0) AND a<
7a90: 33 29 20 4f 52 20 30 7d 20 7b 31 20 32 7d 0a 69  3) OR 0} {1 2}.i
7aa0: 66 63 61 70 61 62 6c 65 20 73 75 62 71 75 65 72  fcapable subquer
7ab0: 79 20 7b 0a 20 20 74 65 73 74 5f 65 78 70 72 32  y {.  test_expr2
7ac0: 20 65 78 70 72 2d 37 2e 35 35 20 7b 28 28 61 20   expr-7.55 {((a 
7ad0: 69 6e 20 28 31 2c 32 29 20 4f 52 20 30 29 20 49  in (1,2) OR 0) I
7ae0: 53 20 4e 55 4c 4c 20 41 4e 44 20 31 29 20 4f 52  S NULL AND 1) OR
7af0: 20 30 7d 20 7b 7b 7d 7d 0a 20 20 74 65 73 74 5f   0} {{}}.  test_
7b00: 65 78 70 72 32 20 65 78 70 72 2d 37 2e 35 36 20  expr2 expr-7.56 
7b10: 5c 0a 20 20 20 20 20 20 7b 28 28 61 20 6e 6f 74  \.      {((a not
7b20: 20 69 6e 20 28 33 2c 34 2c 35 2c 36 2c 37 2c 38   in (3,4,5,6,7,8
7b30: 2c 39 2c 31 30 29 20 49 53 20 4e 55 4c 4c 20 4f  ,9,10) IS NULL O
7b40: 52 20 30 29 20 41 4e 44 20 31 29 20 4f 52 20 30  R 0) AND 1) OR 0
7b50: 7d 20 7b 7b 7d 7d 0a 7d 0a 74 65 73 74 5f 65 78  } {{}}.}.test_ex
7b60: 70 72 32 20 65 78 70 72 2d 37 2e 35 37 20 7b 28  pr2 expr-7.57 {(
7b70: 28 61 3e 30 20 49 53 20 4e 55 4c 4c 20 4f 52 20  (a>0 IS NULL OR 
7b80: 30 29 20 41 4e 44 20 31 29 20 4f 52 20 30 7d 20  0) AND 1) OR 0} 
7b90: 7b 7b 7d 7d 0a 0a 74 65 73 74 5f 65 78 70 72 32  {{}}..test_expr2
7ba0: 20 65 78 70 72 2d 37 2e 35 38 20 20 7b 28 61 7c   expr-7.58  {(a|
7bb0: 7c 27 27 29 3c 3d 27 31 27 7d 20 20 20 20 20 20  |'')<='1'}      
7bc0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 31 7d 0a              {1}.
7bd0: 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72  .test_expr2 expr
7be0: 2d 37 2e 35 39 20 7b 4c 49 4b 45 28 27 31 30 25  -7.59 {LIKE('10%
7bf0: 27 2c 62 29 7d 20 20 20 20 20 20 20 20 20 20 20  ',b)}           
7c00: 20 20 20 20 20 20 20 7b 31 30 20 32 30 7d 0a 74         {10 20}.t
7c10: 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37  est_expr2 expr-7
7c20: 2e 36 30 20 7b 4c 49 4b 45 28 27 5f 34 27 2c 62  .60 {LIKE('_4',b
7c30: 29 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20  )}              
7c40: 20 20 20 20 20 7b 36 7d 0a 74 65 73 74 5f 65 78       {6}.test_ex
7c50: 70 72 32 20 65 78 70 72 2d 37 2e 36 31 20 7b 47  pr2 expr-7.61 {G
7c60: 4c 4f 42 28 27 31 3f 27 2c 61 29 7d 20 20 20 20  LOB('1?',a)}    
7c70: 20 20 20 20 20 20 20 20 7b 31 30 20 31 31 20 31          {10 11 1
7c80: 32 20 31 33 20 31 34 20 31 35 20 31 36 20 31 37  2 13 14 15 16 17
7c90: 20 31 38 20 31 39 7d 0a 74 65 73 74 5f 65 78 70   18 19}.test_exp
7ca0: 72 32 20 65 78 70 72 2d 37 2e 36 32 20 7b 47 4c  r2 expr-7.62 {GL
7cb0: 4f 42 28 27 31 2a 34 27 2c 62 29 7d 20 20 20 20  OB('1*4',b)}    
7cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 31                {1
7cd0: 30 20 31 34 7d 0a 74 65 73 74 5f 65 78 70 72 32  0 14}.test_expr2
7ce0: 20 65 78 70 72 2d 37 2e 36 33 20 7b 47 4c 4f 42   expr-7.63 {GLOB
7cf0: 28 27 2a 31 5b 34 35 36 5d 27 2c 62 29 7d 20 20  ('*1[456]',b)}  
7d00: 20 20 20 20 20 20 20 20 20 20 20 20 7b 34 7d 0a              {4}.
7d10: 74 65 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d  test_expr2 expr-
7d20: 37 2e 36 34 20 7b 62 20 3d 20 61 62 73 28 2d 32  7.64 {b = abs(-2
7d30: 29 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20  )}              
7d40: 20 20 20 20 20 20 7b 31 7d 0a 74 65 73 74 5f 65        {1}.test_e
7d50: 78 70 72 32 20 65 78 70 72 2d 37 2e 36 35 20 7b  xpr2 expr-7.65 {
7d60: 62 20 3d 20 61 62 73 28 2b 2d 32 29 7d 20 20 20  b = abs(+-2)}   
7d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7d80: 7b 31 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65  {1}.test_expr2 e
7d90: 78 70 72 2d 37 2e 36 36 20 7b 62 20 3d 20 61 62  xpr-7.66 {b = ab
7da0: 73 28 2b 2b 2d 32 29 7d 20 20 20 20 20 20 20 20  s(++-2)}        
7db0: 20 20 20 20 20 20 20 20 20 20 7b 31 7d 0a 74 65            {1}.te
7dc0: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
7dd0: 36 37 20 7b 62 20 3d 20 61 62 73 28 2b 2d 2b 2d  67 {b = abs(+-+-
7de0: 32 29 7d 20 20 20 20 20 20 20 20 20 20 20 20 20  2)}             
7df0: 20 20 20 20 7b 31 7d 0a 74 65 73 74 5f 65 78 70      {1}.test_exp
7e00: 72 32 20 65 78 70 72 2d 37 2e 36 38 20 7b 62 20  r2 expr-7.68 {b 
7e10: 3d 20 61 62 73 28 2b 2d 2b 2b 2d 32 29 7d 20 20  = abs(+-++-2)}  
7e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 31                {1
7e30: 7d 0a 74 65 73 74 5f 65 78 70 72 32 20 65 78 70  }.test_expr2 exp
7e40: 72 2d 37 2e 36 39 20 7b 62 20 3d 20 61 62 73 28  r-7.69 {b = abs(
7e50: 2b 2b 2b 2b 2d 32 29 7d 20 20 20 20 20 20 20 20  ++++-2)}        
7e60: 20 20 20 20 20 20 20 20 7b 31 7d 0a 74 65 73 74          {1}.test
7e70: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 37 30  _expr2 expr-7.70
7e80: 20 7b 62 20 3d 20 35 20 2d 20 61 62 73 28 2b 33   {b = 5 - abs(+3
7e90: 29 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20  )}              
7ea0: 20 20 7b 31 7d 0a 74 65 73 74 5f 65 78 70 72 32    {1}.test_expr2
7eb0: 20 65 78 70 72 2d 37 2e 37 31 20 7b 62 20 3d 20   expr-7.71 {b = 
7ec0: 35 20 2d 20 61 62 73 28 2d 33 29 7d 20 20 20 20  5 - abs(-3)}    
7ed0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 31 7d 0a              {1}.
7ee0: 69 66 63 61 70 61 62 6c 65 20 66 6c 6f 61 74 69  ifcapable floati
7ef0: 6e 67 70 6f 69 6e 74 20 7b 0a 20 20 74 65 73 74  ngpoint {.  test
7f00: 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e 37 32  _expr2 expr-7.72
7f10: 20 7b 62 20 3d 20 61 62 73 28 2d 32 2e 30 29 7d   {b = abs(-2.0)}
7f20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7f30: 20 20 7b 31 7d 0a 7d 0a 74 65 73 74 5f 65 78 70    {1}.}.test_exp
7f40: 72 32 20 65 78 70 72 2d 37 2e 37 33 20 7b 62 20  r2 expr-7.73 {b 
7f50: 3d 20 36 20 2d 20 61 62 73 28 2d 61 29 7d 20 20  = 6 - abs(-a)}  
7f60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 32                {2
7f70: 7d 0a 69 66 63 61 70 61 62 6c 65 20 66 6c 6f 61  }.ifcapable floa
7f80: 74 69 6e 67 70 6f 69 6e 74 20 7b 0a 20 20 74 65  tingpoint {.  te
7f90: 73 74 5f 65 78 70 72 32 20 65 78 70 72 2d 37 2e  st_expr2 expr-7.
7fa0: 37 34 20 7b 62 20 3d 20 61 62 73 28 38 2e 30 29  74 {b = abs(8.0)
7fb0: 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }               
7fc0: 20 20 20 20 7b 33 7d 0a 7d 0a 0a 23 20 54 65 73      {3}.}..# Tes
7fd0: 74 20 74 68 65 20 43 55 52 52 45 4e 54 5f 54 49  t the CURRENT_TI
7fe0: 4d 45 2c 20 43 55 52 52 45 4e 54 5f 44 41 54 45  ME, CURRENT_DATE
7ff0: 2c 20 61 6e 64 20 43 55 52 52 45 4e 54 5f 54 49  , and CURRENT_TI
8000: 4d 45 53 54 41 4d 50 20 65 78 70 72 65 73 73 69  MESTAMP expressi
8010: 6f 6e 73 2e 0a 23 0a 69 66 63 61 70 61 62 6c 65  ons..#.ifcapable
8020: 20 7b 66 6c 6f 61 74 69 6e 67 70 6f 69 6e 74 7d   {floatingpoint}
8030: 20 7b 0a 20 20 73 65 74 20 73 71 6c 69 74 65 5f   {.  set sqlite_
8040: 63 75 72 72 65 6e 74 5f 74 69 6d 65 20 31 31 35  current_time 115
8050: 37 31 32 34 38 34 39 0a 20 20 64 6f 5f 74 65 73  7124849.  do_tes
8060: 74 20 65 78 70 72 2d 38 2e 31 20 7b 0a 20 20 20  t expr-8.1 {.   
8070: 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54   execsql {SELECT
8080: 20 43 55 52 52 45 4e 54 5f 54 49 4d 45 7d 0a 20   CURRENT_TIME}. 
8090: 20 7d 20 7b 31 35 3a 33 34 3a 30 39 7d 0a 20 20   } {15:34:09}.  
80a0: 64 6f 5f 74 65 73 74 20 65 78 70 72 2d 38 2e 32  do_test expr-8.2
80b0: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
80c0: 53 45 4c 45 43 54 20 43 55 52 52 45 4e 54 5f 44  SELECT CURRENT_D
80d0: 41 54 45 7d 0a 20 20 7d 20 7b 32 30 30 36 2d 30  ATE}.  } {2006-0
80e0: 39 2d 30 31 7d 0a 20 20 64 6f 5f 74 65 73 74 20  9-01}.  do_test 
80f0: 65 78 70 72 2d 38 2e 33 20 7b 0a 20 20 20 20 65  expr-8.3 {.    e
8100: 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54 20 43  xecsql {SELECT C
8110: 55 52 52 45 4e 54 5f 54 49 4d 45 53 54 41 4d 50  URRENT_TIMESTAMP
8120: 7d 0a 20 20 7d 20 7b 7b 32 30 30 36 2d 30 39 2d  }.  } {{2006-09-
8130: 30 31 20 31 35 3a 33 34 3a 30 39 7d 7d 0a 7d 0a  01 15:34:09}}.}.
8140: 69 66 63 61 70 61 62 6c 65 20 64 61 74 65 74 69  ifcapable dateti
8150: 6d 65 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 65  me {.  do_test e
8160: 78 70 72 2d 38 2e 34 20 7b 0a 20 20 20 20 65 78  xpr-8.4 {.    ex
8170: 65 63 73 71 6c 20 7b 53 45 4c 45 43 54 20 43 55  ecsql {SELECT CU
8180: 52 52 45 4e 54 5f 54 49 4d 45 3d 3d 74 69 6d 65  RRENT_TIME==time
8190: 28 27 6e 6f 77 27 29 3b 7d 0a 20 20 7d 20 31 0a  ('now');}.  } 1.
81a0: 20 20 64 6f 5f 74 65 73 74 20 65 78 70 72 2d 38    do_test expr-8
81b0: 2e 35 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .5 {.    execsql
81c0: 20 7b 53 45 4c 45 43 54 20 43 55 52 52 45 4e 54   {SELECT CURRENT
81d0: 5f 44 41 54 45 3d 3d 64 61 74 65 28 27 6e 6f 77  _DATE==date('now
81e0: 27 29 3b 7d 0a 20 20 7d 20 31 0a 20 20 64 6f 5f  ');}.  } 1.  do_
81f0: 74 65 73 74 20 65 78 70 72 2d 38 2e 36 20 7b 0a  test expr-8.6 {.
8200: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c      execsql {SEL
8210: 45 43 54 20 43 55 52 52 45 4e 54 5f 54 49 4d 45  ECT CURRENT_TIME
8220: 53 54 41 4d 50 3d 3d 64 61 74 65 74 69 6d 65 28  STAMP==datetime(
8230: 27 6e 6f 77 27 29 3b 7d 0a 20 20 7d 20 31 0a 7d  'now');}.  } 1.}
8240: 0a 73 65 74 20 73 71 6c 69 74 65 5f 63 75 72 72  .set sqlite_curr
8250: 65 6e 74 5f 74 69 6d 65 20 30 0a 0a 69 66 63 61  ent_time 0..ifca
8260: 70 61 62 6c 65 20 66 6c 6f 61 74 69 6e 67 70 6f  pable floatingpo
8270: 69 6e 74 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  int {.  do_test 
8280: 65 78 70 72 2d 39 2e 31 20 7b 0a 20 20 20 20 65  expr-9.1 {.    e
8290: 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54 20 72  xecsql {SELECT r
82a0: 6f 75 6e 64 28 2d 28 27 2d 27 7c 7c 27 31 32 33  ound(-('-'||'123
82b0: 27 29 29 7d 0a 20 20 7d 20 31 32 33 2e 30 0a 7d  '))}.  } 123.0.}
82c0: 0a 0a 23 20 54 65 73 74 20 61 6e 20 65 72 72 6f  ..# Test an erro
82d0: 72 20 6d 65 73 73 61 67 65 20 74 68 61 74 20 63  r message that c
82e0: 61 6e 20 62 65 20 67 65 6e 65 72 61 74 65 64 20  an be generated 
82f0: 62 79 20 74 68 65 20 4c 49 4b 45 20 65 78 70 72  by the LIKE expr
8300: 65 73 73 69 6f 6e 0a 64 6f 5f 74 65 73 74 20 65  ession.do_test e
8310: 78 70 72 2d 31 30 2e 31 20 7b 0a 20 20 63 61 74  xpr-10.1 {.  cat
8320: 63 68 73 71 6c 20 7b 53 45 4c 45 43 54 20 27 61  chsql {SELECT 'a
8330: 62 63 27 20 4c 49 4b 45 20 27 61 62 63 27 20 45  bc' LIKE 'abc' E
8340: 53 43 41 50 45 20 27 27 7d 0a 7d 20 7b 31 20 7b  SCAPE ''}.} {1 {
8350: 45 53 43 41 50 45 20 65 78 70 72 65 73 73 69 6f  ESCAPE expressio
8360: 6e 20 6d 75 73 74 20 62 65 20 61 20 73 69 6e 67  n must be a sing
8370: 6c 65 20 63 68 61 72 61 63 74 65 72 7d 7d 0a 64  le character}}.d
8380: 6f 5f 74 65 73 74 20 65 78 70 72 2d 31 30 2e 32  o_test expr-10.2
8390: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 53   {.  catchsql {S
83a0: 45 4c 45 43 54 20 27 61 62 63 27 20 4c 49 4b 45  ELECT 'abc' LIKE
83b0: 20 27 61 62 63 27 20 45 53 43 41 50 45 20 27 61   'abc' ESCAPE 'a
83c0: 62 27 7d 0a 7d 20 7b 31 20 7b 45 53 43 41 50 45  b'}.} {1 {ESCAPE
83d0: 20 65 78 70 72 65 73 73 69 6f 6e 20 6d 75 73 74   expression must
83e0: 20 62 65 20 61 20 73 69 6e 67 6c 65 20 63 68 61   be a single cha
83f0: 72 61 63 74 65 72 7d 7d 0a 0a 23 20 49 66 20 77  racter}}..# If w
8400: 65 20 73 70 65 63 69 66 79 20 61 6e 20 69 6e 74  e specify an int
8410: 65 67 65 72 20 63 6f 6e 73 74 61 6e 74 20 74 68  eger constant th
8420: 61 74 20 69 73 20 62 69 67 67 65 72 20 74 68 61  at is bigger tha
8430: 6e 20 74 68 65 20 6c 61 72 67 65 73 74 0a 23 20  n the largest.# 
8440: 70 6f 73 73 69 62 6c 65 20 69 6e 74 65 67 65 72  possible integer
8450: 2c 20 63 6f 64 65 20 74 68 65 20 69 6e 74 65 67  , code the integ
8460: 65 72 20 61 73 20 61 20 72 65 61 6c 20 6e 75 6d  er as a real num
8470: 62 65 72 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 65  ber..#.do_test e
8480: 78 70 72 2d 31 31 2e 31 20 7b 0a 20 20 65 78 65  xpr-11.1 {.  exe
8490: 63 73 71 6c 20 7b 53 45 4c 45 43 54 20 74 79 70  csql {SELECT typ
84a0: 65 6f 66 28 39 32 32 33 33 37 32 30 33 36 38 35  eof(922337203685
84b0: 34 37 37 35 38 30 37 29 7d 0a 7d 20 7b 69 6e 74  4775807)}.} {int
84c0: 65 67 65 72 7d 0a 64 6f 5f 74 65 73 74 20 65 78  eger}.do_test ex
84d0: 70 72 2d 31 31 2e 32 20 7b 0a 20 20 65 78 65 63  pr-11.2 {.  exec
84e0: 73 71 6c 20 7b 53 45 4c 45 43 54 20 74 79 70 65  sql {SELECT type
84f0: 6f 66 28 30 30 30 30 30 30 30 39 32 32 33 33 37  of(0000000922337
8500: 32 30 33 36 38 35 34 37 37 35 38 30 37 29 7d 0a  2036854775807)}.
8510: 7d 20 7b 69 6e 74 65 67 65 72 7d 0a 64 6f 5f 74  } {integer}.do_t
8520: 65 73 74 20 65 78 70 72 2d 31 31 2e 33 20 7b 0a  est expr-11.3 {.
8530: 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43    execsql {SELEC
8540: 54 20 74 79 70 65 6f 66 28 2b 39 32 32 33 33 37  T typeof(+922337
8550: 32 30 33 36 38 35 34 37 37 35 38 30 37 29 7d 0a  2036854775807)}.
8560: 7d 20 7b 69 6e 74 65 67 65 72 7d 0a 64 6f 5f 74  } {integer}.do_t
8570: 65 73 74 20 65 78 70 72 2d 31 31 2e 34 20 7b 0a  est expr-11.4 {.
8580: 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43    execsql {SELEC
8590: 54 20 74 79 70 65 6f 66 28 2b 30 30 30 30 30 30  T typeof(+000000
85a0: 30 30 39 32 32 33 33 37 32 30 33 36 38 35 34 37  0092233720368547
85b0: 37 35 38 30 37 29 7d 0a 7d 20 7b 69 6e 74 65 67  75807)}.} {integ
85c0: 65 72 7d 0a 64 6f 5f 74 65 73 74 20 65 78 70 72  er}.do_test expr
85d0: 2d 31 31 2e 35 20 7b 0a 20 20 65 78 65 63 73 71  -11.5 {.  execsq
85e0: 6c 20 7b 53 45 4c 45 43 54 20 74 79 70 65 6f 66  l {SELECT typeof
85f0: 28 39 32 32 33 33 37 32 30 33 36 38 35 34 37 37  (922337203685477
8600: 35 38 30 38 29 7d 0a 7d 20 7b 72 65 61 6c 7d 0a  5808)}.} {real}.
8610: 64 6f 5f 74 65 73 74 20 65 78 70 72 2d 31 31 2e  do_test expr-11.
8620: 36 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 53  6 {.  execsql {S
8630: 45 4c 45 43 54 20 74 79 70 65 6f 66 28 30 30 30  ELECT typeof(000
8640: 30 30 30 30 39 32 32 33 33 37 32 30 33 36 38 35  0000922337203685
8650: 34 37 37 35 38 30 38 29 7d 0a 7d 20 7b 72 65 61  4775808)}.} {rea
8660: 6c 7d 0a 64 6f 5f 74 65 73 74 20 65 78 70 72 2d  l}.do_test expr-
8670: 31 31 2e 37 20 7b 0a 20 20 65 78 65 63 73 71 6c  11.7 {.  execsql
8680: 20 7b 53 45 4c 45 43 54 20 74 79 70 65 6f 66 28   {SELECT typeof(
8690: 2b 39 32 32 33 33 37 32 30 33 36 38 35 34 37 37  +922337203685477
86a0: 35 38 30 38 29 7d 0a 7d 20 7b 72 65 61 6c 7d 0a  5808)}.} {real}.
86b0: 64 6f 5f 74 65 73 74 20 65 78 70 72 2d 31 31 2e  do_test expr-11.
86c0: 38 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 53  8 {.  execsql {S
86d0: 45 4c 45 43 54 20 74 79 70 65 6f 66 28 2b 30 30  ELECT typeof(+00
86e0: 30 30 30 30 39 32 32 33 33 37 32 30 33 36 38 35  0000922337203685
86f0: 34 37 37 35 38 30 38 29 7d 0a 7d 20 7b 72 65 61  4775808)}.} {rea
8700: 6c 7d 0a 64 6f 5f 74 65 73 74 20 65 78 70 72 2d  l}.do_test expr-
8710: 31 31 2e 31 31 20 7b 0a 20 20 65 78 65 63 73 71  11.11 {.  execsq
8720: 6c 20 7b 53 45 4c 45 43 54 20 74 79 70 65 6f 66  l {SELECT typeof
8730: 28 2d 39 32 32 33 33 37 32 30 33 36 38 35 34 37  (-92233720368547
8740: 37 35 38 30 38 29 7d 0a 7d 20 7b 69 6e 74 65 67  75808)}.} {integ
8750: 65 72 7d 0a 64 6f 5f 74 65 73 74 20 65 78 70 72  er}.do_test expr
8760: 2d 31 31 2e 31 32 20 7b 0a 20 20 65 78 65 63 73  -11.12 {.  execs
8770: 71 6c 20 7b 53 45 4c 45 43 54 20 74 79 70 65 6f  ql {SELECT typeo
8780: 66 28 2d 30 30 30 30 30 30 30 39 32 32 33 33 37  f(-0000000922337
8790: 32 30 33 36 38 35 34 37 37 35 38 30 38 29 7d 0a  2036854775808)}.
87a0: 7d 20 7b 69 6e 74 65 67 65 72 7d 0a 69 66 63 61  } {integer}.ifca
87b0: 70 61 62 6c 65 20 66 6c 6f 61 74 69 6e 67 70 6f  pable floatingpo
87c0: 69 6e 74 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  int {.  do_test 
87d0: 65 78 70 72 2d 31 31 2e 31 33 20 7b 0a 20 20 20  expr-11.13 {.   
87e0: 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54   execsql {SELECT
87f0: 20 74 79 70 65 6f 66 28 2d 39 32 32 33 33 37 32   typeof(-9223372
8800: 30 33 36 38 35 34 37 37 35 38 30 39 29 7d 0a 20  036854775809)}. 
8810: 20 7d 20 7b 72 65 61 6c 7d 0a 20 20 64 6f 5f 74   } {real}.  do_t
8820: 65 73 74 20 65 78 70 72 2d 31 31 2e 31 34 20 7b  est expr-11.14 {
8830: 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 53 45  .    execsql {SE
8840: 4c 45 43 54 20 74 79 70 65 6f 66 28 2d 30 30 30  LECT typeof(-000
8850: 30 30 30 30 39 32 32 33 33 37 32 30 33 36 38 35  0000922337203685
8860: 34 37 37 35 38 30 39 29 7d 0a 20 20 7d 20 7b 72  4775809)}.  } {r
8870: 65 61 6c 7d 0a 7d 0a 0a 23 20 54 68 65 73 65 20  eal}.}..# These 
8880: 74 77 6f 20 73 74 61 74 65 6d 65 6e 74 73 20 75  two statements u
8890: 73 65 64 20 74 6f 20 6c 65 61 6b 20 6d 65 6d 6f  sed to leak memo
88a0: 72 79 20 28 62 65 63 61 75 73 65 20 6f 66 20 6d  ry (because of m
88b0: 69 73 73 69 6e 67 20 25 64 65 73 74 72 75 63 74  issing %destruct
88c0: 6f 72 0a 23 20 64 69 72 65 63 74 69 76 65 73 20  or.# directives 
88d0: 69 6e 20 70 61 72 73 65 2e 79 29 2e 0a 64 6f 5f  in parse.y)..do_
88e0: 74 65 73 74 20 65 78 70 72 2d 31 32 2e 31 20 7b  test expr-12.1 {
88f0: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
8900: 20 20 53 45 4c 45 43 54 20 28 43 41 53 45 20 61    SELECT (CASE a
8910: 3e 34 20 54 48 45 4e 20 31 20 45 4c 53 45 20 30  >4 THEN 1 ELSE 0
8920: 20 45 4e 44 29 20 46 52 4f 4d 20 74 65 73 74 31   END) FROM test1
8930: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 65 61 72  ;.  }.} {1 {near
8940: 20 22 54 48 45 4e 22 3a 20 73 79 6e 74 61 78 20   "THEN": syntax 
8950: 65 72 72 6f 72 7d 7d 0a 64 6f 5f 74 65 73 74 20  error}}.do_test 
8960: 65 78 70 72 2d 31 32 2e 32 20 7b 0a 20 20 63 61  expr-12.2 {.  ca
8970: 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  tchsql {.    SEL
8980: 45 43 54 20 28 43 41 53 45 20 57 48 45 4e 20 61  ECT (CASE WHEN a
8990: 3e 34 20 54 48 45 4e 20 31 20 45 4c 53 45 20 30  >4 THEN 1 ELSE 0
89a0: 29 20 46 52 4f 4d 20 74 65 73 74 31 3b 0a 20 20  ) FROM test1;.  
89b0: 7d 0a 7d 20 7b 31 20 7b 6e 65 61 72 20 22 29 22  }.} {1 {near ")"
89c0: 3a 20 73 79 6e 74 61 78 20 65 72 72 6f 72 7d 7d  : syntax error}}
89d0: 0a 0a 69 66 63 61 70 61 62 6c 65 20 66 6c 6f 61  ..ifcapable floa
89e0: 74 69 6e 67 70 6f 69 6e 74 20 7b 0a 20 20 64 6f  tingpoint {.  do
89f0: 5f 74 65 73 74 20 65 78 70 72 2d 31 33 2e 31 20  _test expr-13.1 
8a00: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
8a10: 20 20 20 20 20 20 53 45 4c 45 43 54 20 31 32 33        SELECT 123
8a20: 34 35 36 37 38 39 30 31 32 33 34 35 36 37 38 39  4567890123456789
8a30: 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 2e  0;.    }.  } {1.
8a40: 32 33 34 35 36 37 38 39 30 31 32 33 34 36 65 2b  23456789012346e+
8a50: 31 39 7d 0a 7d 0a 0a 23 20 49 6d 70 6c 69 63 69  19}.}..# Implici
8a60: 74 20 53 74 72 69 6e 67 2d 3e 49 6e 74 65 67 65  t String->Intege
8a70: 72 20 63 6f 6e 76 65 72 73 69 6f 6e 20 69 73 20  r conversion is 
8a80: 75 73 65 64 20 77 68 65 6e 20 70 6f 73 73 69 62  used when possib
8a90: 6c 65 2e 0a 23 0a 69 66 20 7b 5b 77 6f 72 6b 69  le..#.if {[worki
8aa0: 6e 67 5f 36 34 62 69 74 5f 69 6e 74 5d 7d 20 7b  ng_64bit_int]} {
8ab0: 0a 20 20 64 6f 5f 74 65 73 74 20 65 78 70 72 2d  .  do_test expr-
8ac0: 31 33 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73  13.2 {.    execs
8ad0: 71 6c 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43  ql {.      SELEC
8ae0: 54 20 30 2b 27 39 32 32 33 33 37 32 30 33 36 38  T 0+'92233720368
8af0: 35 34 37 37 35 38 30 37 27 0a 20 20 20 20 7d 0a  54775807'.    }.
8b00: 20 20 7d 20 7b 39 32 32 33 33 37 32 30 33 36 38    } {92233720368
8b10: 35 34 37 37 35 38 30 37 7d 0a 20 20 64 6f 5f 74  54775807}.  do_t
8b20: 65 73 74 20 65 78 70 72 2d 31 33 2e 33 20 7b 0a  est expr-13.3 {.
8b30: 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20      execsql {.  
8b40: 20 20 20 20 53 45 4c 45 43 54 20 27 39 32 32 33      SELECT '9223
8b50: 33 37 32 30 33 36 38 35 34 37 37 35 38 30 37 27  372036854775807'
8b60: 2b 30 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 39 32  +0.    }.  } {92
8b70: 32 33 33 37 32 30 33 36 38 35 34 37 37 35 38 30  2337203685477580
8b80: 37 7d 0a 7d 0a 0a 23 20 49 66 20 74 68 65 20 76  7}.}..# If the v
8b90: 61 6c 75 65 20 69 73 20 74 6f 6f 20 6c 61 72 67  alue is too larg
8ba0: 65 2c 20 75 73 65 20 53 74 72 69 6e 67 2d 3e 46  e, use String->F
8bb0: 6c 6f 61 74 20 63 6f 6e 76 65 72 73 69 6f 6e 2e  loat conversion.
8bc0: 0a 23 0a 69 66 63 61 70 61 62 6c 65 20 66 6c 6f  .#.ifcapable flo
8bd0: 61 74 69 6e 67 70 6f 69 6e 74 20 7b 0a 20 20 64  atingpoint {.  d
8be0: 6f 5f 74 65 73 74 20 65 78 70 72 2d 31 33 2e 34  o_test expr-13.4
8bf0: 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b   {.    execsql {
8c00: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 30 2b  .      SELECT 0+
8c10: 27 39 32 32 33 33 37 32 30 33 36 38 35 34 37 37  '922337203685477
8c20: 35 38 30 38 27 0a 20 20 20 20 7d 0a 20 20 7d 20  5808'.    }.  } 
8c30: 7b 39 2e 32 32 33 33 37 32 30 33 36 38 35 34 37  {9.2233720368547
8c40: 38 65 2b 31 38 7d 0a 20 20 64 6f 5f 74 65 73 74  8e+18}.  do_test
8c50: 20 65 78 70 72 2d 31 33 2e 35 20 7b 0a 20 20 20   expr-13.5 {.   
8c60: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20   execsql {.     
8c70: 20 53 45 4c 45 43 54 20 27 39 32 32 33 33 37 32   SELECT '9223372
8c80: 30 33 36 38 35 34 37 37 35 38 30 38 27 2b 30 0a  036854775808'+0.
8c90: 20 20 20 20 7d 0a 20 20 7d 20 7b 39 2e 32 32 33      }.  } {9.223
8ca0: 33 37 32 30 33 36 38 35 34 37 38 65 2b 31 38 7d  37203685478e+18}
8cb0: 0a 7d 0a 0a 23 20 55 73 65 20 53 74 72 69 6e 67  .}..# Use String
8cc0: 2d 3e 66 6c 6f 61 74 20 63 6f 6e 76 65 72 73 69  ->float conversi
8cd0: 6f 6e 20 69 66 20 74 68 65 20 76 61 6c 75 65 20  on if the value 
8ce0: 69 73 20 65 78 70 6c 69 63 69 74 6c 79 20 61 20  is explicitly a 
8cf0: 66 6c 6f 61 74 69 6e 67 0a 23 20 70 6f 69 6e 74  floating.# point
8d00: 20 76 61 6c 75 65 2e 0a 23 0a 64 6f 5f 74 65 73   value..#.do_tes
8d10: 74 20 65 78 70 72 2d 31 33 2e 36 20 7b 0a 20 20  t expr-13.6 {.  
8d20: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
8d30: 4c 45 43 54 20 30 2b 27 39 32 32 33 33 37 32 30  LECT 0+'92233720
8d40: 33 36 38 35 34 37 37 35 38 30 37 2e 30 27 0a 20  36854775807.0'. 
8d50: 20 7d 0a 7d 20 7b 39 2e 32 32 33 33 37 32 30 33   }.} {9.22337203
8d60: 36 38 35 34 37 38 65 2b 31 38 7d 0a 64 6f 5f 74  685478e+18}.do_t
8d70: 65 73 74 20 65 78 70 72 2d 31 33 2e 37 20 7b 0a  est expr-13.7 {.
8d80: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
8d90: 53 45 4c 45 43 54 20 27 39 32 32 33 33 37 32 30  SELECT '92233720
8da0: 33 36 38 35 34 37 37 35 38 30 37 2e 30 27 2b 30  36854775807.0'+0
8db0: 0a 20 20 7d 0a 7d 20 7b 39 2e 32 32 33 33 37 32  .  }.} {9.223372
8dc0: 30 33 36 38 35 34 37 38 65 2b 31 38 7d 0a 0a 0a  03685478e+18}...
8dd0: 66 69 6e 69 73 68 5f 74 65 73 74 0a              finish_test.