System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact b0c90d2a81515a30bcce6f32e86a915a06e5093b:


0000: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0010: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0020: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0030: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0040: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
0050: 0a 23 0d 0a 23 20 74 6b 74 2d 34 37 63 36 66 61  .#..# tkt-47c6fa
0060: 30 34 64 33 2e 65 61 67 6c 65 20 2d 2d 0d 0a 23  04d3.eagle --..#
0070: 0d 0a 23 20 57 72 69 74 74 65 6e 20 62 79 20 4a  ..# Written by J
0080: 6f 65 20 4d 69 73 74 61 63 68 6b 69 6e 2e 0d 0a  oe Mistachkin...
0090: 23 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74 68  # Released to th
00a0: 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c  e public domain,
00b0: 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77 6e   use at your own
00c0: 20 72 69 73 6b 21 0d 0a 23 0d 0a 23 23 23 23 23   risk!..#..#####
00d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
00e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
00f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0100: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0110: 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 70 61  ##########....pa
0120: 63 6b 61 67 65 20 72 65 71 75 69 72 65 20 45 61  ckage require Ea
0130: 67 6c 65 0d 0a 70 61 63 6b 61 67 65 20 72 65 71  gle..package req
0140: 75 69 72 65 20 45 61 67 6c 65 2e 4c 69 62 72 61  uire Eagle.Libra
0150: 72 79 0d 0a 70 61 63 6b 61 67 65 20 72 65 71 75  ry..package requ
0160: 69 72 65 20 45 61 67 6c 65 2e 54 65 73 74 0d 0a  ire Eagle.Test..
0170: 0d 0a 72 75 6e 54 65 73 74 50 72 6f 6c 6f 67 75  ..runTestPrologu
0180: 65 0d 0a 0d 0a 23 23 23 23 23 23 23 23 23 23 23  e....###########
0190: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
01a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
01b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
01c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
01d0: 23 23 23 23 0d 0a 0d 0a 70 61 63 6b 61 67 65 20  ####....package 
01e0: 72 65 71 75 69 72 65 20 53 79 73 74 65 6d 2e 44  require System.D
01f0: 61 74 61 2e 53 51 4c 69 74 65 2e 54 65 73 74 0d  ata.SQLite.Test.
0200: 0a 72 75 6e 53 51 4c 69 74 65 54 65 73 74 50 72  .runSQLiteTestPr
0210: 6f 6c 6f 67 75 65 0d 0a 0d 0a 23 23 23 23 23 23  ologue....######
0220: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0230: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0240: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0250: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0260: 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 72 75 6e  #########....run
0270: 54 65 73 74 20 7b 74 65 73 74 20 74 6b 74 2d 34  Test {test tkt-4
0280: 37 63 36 66 61 30 34 64 33 2d 31 2e 31 20 7b 6c  7c6fa04d3-1.1 {l
0290: 6f 61 64 69 6e 67 20 44 61 74 61 54 61 62 6c 65  oading DataTable
02a0: 20 77 69 74 68 20 4a 4f 49 4e 7d 20 2d 73 65 74   with JOIN} -set
02b0: 75 70 20 7b 0d 0a 20 20 73 65 74 75 70 44 62 20  up {..  setupDb 
02c0: 5b 73 65 74 20 66 69 6c 65 4e 61 6d 65 20 74 6b  [set fileName tk
02d0: 74 2d 34 37 63 36 66 61 30 34 64 33 2d 31 2e 31  t-47c6fa04d3-1.1
02e0: 2e 64 62 5d 0d 0a 7d 20 2d 62 6f 64 79 20 7b 0d  .db]..} -body {.
02f0: 0a 20 20 73 71 6c 20 65 78 65 63 75 74 65 20 24  .  sql execute $
0300: 64 62 20 7b 0d 0a 20 20 20 20 43 52 45 41 54 45  db {..    CREATE
0310: 20 54 41 42 4c 45 20 74 31 28 0d 0a 20 20 20 20   TABLE t1(..    
0320: 20 20 74 31 78 20 49 4e 54 45 47 45 52 20 50 52    t1x INTEGER PR
0330: 49 4d 41 52 59 20 4b 45 59 20 4e 4f 54 20 4e 55  IMARY KEY NOT NU
0340: 4c 4c 2c 0d 0a 20 20 20 20 20 20 74 31 79 20 54  LL,..      t1y T
0350: 45 58 54 20 4e 4f 54 20 4e 55 4c 4c 0d 0a 20 20  EXT NOT NULL..  
0360: 20 20 29 3b 0d 0a 0d 0a 20 20 20 20 49 4e 53 45    );....    INSE
0370: 52 54 20 49 4e 54 4f 20 74 31 20 28 74 31 78 2c  RT INTO t1 (t1x,
0380: 20 74 31 79 29 20 56 41 4c 55 45 53 28 31 2c 20   t1y) VALUES(1, 
0390: 27 6f 6e 65 5f 74 31 27 29 3b 0d 0a 20 20 20 20  'one_t1');..    
03a0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 28  INSERT INTO t1 (
03b0: 74 31 78 2c 20 74 31 79 29 20 56 41 4c 55 45 53  t1x, t1y) VALUES
03c0: 28 32 2c 20 27 74 77 6f 5f 74 31 27 29 3b 0d 0a  (2, 'two_t1');..
03d0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
03e0: 74 31 20 28 74 31 78 2c 20 74 31 79 29 20 56 41  t1 (t1x, t1y) VA
03f0: 4c 55 45 53 28 33 2c 20 27 74 68 72 65 65 5f 74  LUES(3, 'three_t
0400: 31 27 29 3b 0d 0a 0d 0a 20 20 20 20 43 52 45 41  1');....    CREA
0410: 54 45 20 54 41 42 4c 45 20 74 32 28 0d 0a 20 20  TE TABLE t2(..  
0420: 20 20 20 20 74 32 78 20 49 4e 54 45 47 45 52 20      t2x INTEGER 
0430: 50 52 49 4d 41 52 59 20 4b 45 59 20 4e 4f 54 20  PRIMARY KEY NOT 
0440: 4e 55 4c 4c 2c 0d 0a 20 20 20 20 20 20 74 32 74  NULL,..      t2t
0450: 31 78 20 49 4e 54 45 47 45 52 20 4e 4f 54 20 4e  1x INTEGER NOT N
0460: 55 4c 4c 2c 0d 0a 20 20 20 20 20 20 74 32 79 20  ULL,..      t2y 
0470: 54 45 58 54 2c 0d 0a 20 20 20 20 20 20 74 32 7a  TEXT,..      t2z
0480: 20 49 4e 54 45 47 45 52 20 4e 4f 54 20 4e 55 4c   INTEGER NOT NUL
0490: 4c 20 44 45 46 41 55 4c 54 28 30 29 0d 0a 20 20  L DEFAULT(0)..  
04a0: 20 20 29 3b 0d 0a 0d 0a 20 20 20 20 49 4e 53 45    );....    INSE
04b0: 52 54 20 49 4e 54 4f 20 74 32 20 28 74 32 78 2c  RT INTO t2 (t2x,
04c0: 20 74 32 74 31 78 2c 20 74 32 79 2c 20 74 32 7a   t2t1x, t2y, t2z
04d0: 29 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 27  ) VALUES(1, 2, '
04e0: 6f 6e 65 5f 74 32 27 2c 20 31 29 3b 0d 0a 20 20  one_t2', 1);..  
04f0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
0500: 20 28 74 32 78 2c 20 74 32 74 31 78 2c 20 74 32   (t2x, t2t1x, t2
0510: 79 2c 20 74 32 7a 29 20 56 41 4c 55 45 53 28 32  y, t2z) VALUES(2
0520: 2c 20 32 2c 20 27 74 77 6f 5f 74 32 27 2c 20 32  , 2, 'two_t2', 2
0530: 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54 20 49  );..    INSERT I
0540: 4e 54 4f 20 74 32 20 28 74 32 78 2c 20 74 32 74  NTO t2 (t2x, t2t
0550: 31 78 2c 20 74 32 79 2c 20 74 32 7a 29 20 56 41  1x, t2y, t2z) VA
0560: 4c 55 45 53 28 33 2c 20 32 2c 20 27 74 68 72 65  LUES(3, 2, 'thre
0570: 65 5f 74 32 27 2c 20 33 29 3b 0d 0a 0d 0a 20 20  e_t2', 3);....  
0580: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
0590: 33 28 0d 0a 20 20 20 20 20 20 74 33 78 20 49 4e  3(..      t3x IN
05a0: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
05b0: 59 20 4e 4f 54 20 4e 55 4c 4c 2c 0d 0a 20 20 20  Y NOT NULL,..   
05c0: 20 20 20 74 33 79 20 49 4e 54 45 47 45 52 20 4e     t3y INTEGER N
05d0: 4f 54 20 4e 55 4c 4c 2c 0d 0a 20 20 20 20 20 20  OT NULL,..      
05e0: 74 33 7a 20 49 4e 54 45 47 45 52 20 4e 4f 54 20  t3z INTEGER NOT 
05f0: 4e 55 4c 4c 0d 0a 20 20 20 20 29 3b 0d 0a 0d 0a  NULL..    );....
0600: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0610: 74 33 20 28 74 33 78 2c 20 74 33 79 2c 20 74 33  t3 (t3x, t3y, t3
0620: 7a 29 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20  z) VALUES(1, 2, 
0630: 33 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54 20  3);..    INSERT 
0640: 49 4e 54 4f 20 74 33 20 28 74 33 78 2c 20 74 33  INTO t3 (t3x, t3
0650: 79 2c 20 74 33 7a 29 20 56 41 4c 55 45 53 28 32  y, t3z) VALUES(2
0660: 2c 20 31 2c 20 32 29 3b 0d 0a 20 20 7d 0d 0a 0d  , 1, 2);..  }...
0670: 0a 20 20 73 65 74 20 69 64 20 5b 6f 62 6a 65 63  .  set id [objec
0680: 74 20 69 6e 76 6f 6b 65 20 49 6e 74 65 72 70 72  t invoke Interpr
0690: 65 74 65 72 2e 47 65 74 41 63 74 69 76 65 20 4e  eter.GetActive N
06a0: 65 78 74 49 64 5d 0d 0a 20 20 73 65 74 20 64 61  extId]..  set da
06b0: 74 61 53 6f 75 72 63 65 20 5b 66 69 6c 65 20 6a  taSource [file j
06c0: 6f 69 6e 20 5b 67 65 74 44 61 74 61 62 61 73 65  oin [getDatabase
06d0: 44 69 72 65 63 74 6f 72 79 5d 20 24 66 69 6c 65  Directory] $file
06e0: 4e 61 6d 65 5d 0d 0a 0d 0a 20 20 73 65 74 20 73  Name]....  set s
06f0: 71 6c 20 7b 0d 0a 20 20 20 20 53 45 4c 45 43 54  ql {..    SELECT
0700: 20 74 31 2e 74 31 78 20 41 53 20 69 64 2c 20 74   t1.t1x AS id, t
0710: 33 2e 74 33 79 20 41 53 20 6d 69 6e 2c 20 74 33  3.t3y AS min, t3
0720: 2e 74 33 7a 20 41 53 20 6d 61 78 2c 0d 0a 20 20  .t3z AS max,..  
0730: 20 20 20 20 20 20 20 20 20 53 55 4d 28 74 32 2e           SUM(t2.
0740: 74 32 7a 29 20 41 53 20 73 75 6d 0d 0a 20 20 20  t2z) AS sum..   
0750: 20 46 52 4f 4d 20 74 31 20 74 31 20 49 4e 4e 45   FROM t1 t1 INNE
0760: 52 20 4a 4f 49 4e 20 74 33 20 74 33 20 49 4e 4e  R JOIN t3 t3 INN
0770: 45 52 20 4a 4f 49 4e 20 74 32 20 74 32 0d 0a 20  ER JOIN t2 t2.. 
0780: 20 20 20 4f 4e 20 74 32 2e 74 32 74 31 78 20 3d     ON t2.t2t1x =
0790: 20 74 31 2e 74 31 78 20 41 4e 44 20 74 32 2e 74   t1.t1x AND t2.t
07a0: 32 7a 20 42 45 54 57 45 45 4e 20 74 33 2e 74 33  2z BETWEEN t3.t3
07b0: 79 20 41 4e 44 20 74 33 2e 74 33 7a 0d 0a 20 20  y AND t3.t3z..  
07c0: 20 20 47 52 4f 55 50 20 42 59 20 74 31 2e 74 31    GROUP BY t1.t1
07d0: 78 2c 20 74 33 2e 74 33 78 2c 20 74 33 2e 74 33  x, t3.t3x, t3.t3
07e0: 79 2c 20 74 33 2e 74 33 7a 3b 0d 0a 20 20 7d 0d  y, t3.t3z;..  }.
07f0: 0a 0d 0a 20 20 75 6e 73 65 74 20 2d 6e 6f 63 6f  ...  unset -noco
0800: 6d 70 6c 61 69 6e 20 72 65 73 75 6c 74 73 20 65  mplain results e
0810: 72 72 6f 72 73 0d 0a 0d 0a 20 20 73 65 74 20 63  rrors....  set c
0820: 6f 64 65 20 5b 63 6f 6d 70 69 6c 65 43 53 68 61  ode [compileCSha
0830: 72 70 57 69 74 68 20 5b 73 75 62 73 74 20 7b 0d  rpWith [subst {.
0840: 0a 20 20 20 20 75 73 69 6e 67 20 53 79 73 74 65  .    using Syste
0850: 6d 2e 44 61 74 61 3b 0d 0a 20 20 20 20 75 73 69  m.Data;..    usi
0860: 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 53  ng System.Data.S
0870: 51 4c 69 74 65 3b 0d 0a 0d 0a 20 20 20 20 6e 61  QLite;....    na
0880: 6d 65 73 70 61 63 65 20 5f 44 79 6e 61 6d 69 63  mespace _Dynamic
0890: 24 7b 69 64 7d 0d 0a 20 20 20 20 7b 0d 0a 20 20  ${id}..    {..  
08a0: 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69      public stati
08b0: 63 20 63 6c 61 73 73 20 54 65 73 74 24 7b 69 64  c class Test${id
08c0: 7d 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  }..      {..    
08d0: 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69      public stati
08e0: 63 20 44 61 74 61 54 61 62 6c 65 20 47 65 74 44  c DataTable GetD
08f0: 61 74 61 54 61 62 6c 65 28 29 0d 0a 20 20 20 20  ataTable()..    
0900: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
0910: 20 44 61 74 61 54 61 62 6c 65 20 64 61 74 61 54   DataTable dataT
0920: 61 62 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  able;....       
0930: 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65     using (SQLite
0940: 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6f 6e 6e 65  Connection conne
0950: 63 74 69 6f 6e 20 3d 20 6e 65 77 20 53 51 4c 69  ction = new SQLi
0960: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 28 0d 0a 20  teConnection(.. 
0970: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 44 61               "Da
0980: 74 61 20 53 6f 75 72 63 65 3d 24 7b 64 61 74 61  ta Source=${data
0990: 53 6f 75 72 63 65 7d 3b 5b 67 65 74 46 6c 61 67  Source};[getFlag
09a0: 73 50 72 6f 70 65 72 74 79 5d 22 29 29 0d 0a 20  sProperty]")).. 
09b0: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
09c0: 20 20 20 20 20 20 20 20 63 6f 6e 6e 65 63 74 69          connecti
09d0: 6f 6e 2e 4f 70 65 6e 28 29 3b 0d 0a 0d 0a 20 20  on.Open();....  
09e0: 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20            using 
09f0: 28 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63  (SQLiteCommand c
0a00: 6f 6d 6d 61 6e 64 20 3d 20 6e 65 77 20 53 51 4c  ommand = new SQL
0a10: 69 74 65 43 6f 6d 6d 61 6e 64 28 40 22 24 7b 73  iteCommand(@"${s
0a20: 71 6c 7d 22 2c 0d 0a 20 20 20 20 20 20 20 20 20  ql}",..         
0a30: 20 20 20 20 20 20 20 63 6f 6e 6e 65 63 74 69 6f         connectio
0a40: 6e 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  n))..           
0a50: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
0a60: 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65 44    using (SQLiteD
0a70: 61 74 61 52 65 61 64 65 72 20 64 61 74 61 52 65  ataReader dataRe
0a80: 61 64 65 72 20 3d 20 63 6f 6d 6d 61 6e 64 2e 45  ader = command.E
0a90: 78 65 63 75 74 65 52 65 61 64 65 72 28 29 29 0d  xecuteReader()).
0aa0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  .              {
0ab0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0ac0: 20 20 64 61 74 61 54 61 62 6c 65 20 3d 20 6e 65    dataTable = ne
0ad0: 77 20 44 61 74 61 54 61 62 6c 65 28 29 3b 0d 0a  w DataTable();..
0ae0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0af0: 64 61 74 61 54 61 62 6c 65 2e 4c 6f 61 64 28 64  dataTable.Load(d
0b00: 61 74 61 52 65 61 64 65 72 29 3b 0d 0a 0d 0a 20  ataReader);.... 
0b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72                 r
0b20: 65 74 75 72 6e 20 64 61 74 61 54 61 62 6c 65 3b  eturn dataTable;
0b30: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0b40: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  }..            }
0b50: 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20  ..          }.. 
0b60: 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20         }....    
0b70: 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f      ////////////
0b80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0b90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ba0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0bb0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20  ///////////.... 
0bc0: 20 20 20 20 20 20 20 70 75 62 6c 69 63 20 73 74         public st
0bd0: 61 74 69 63 20 76 6f 69 64 20 4d 61 69 6e 28 29  atic void Main()
0be0: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
0bf0: 20 20 20 20 20 20 20 2f 2f 20 64 6f 20 6e 6f 74         // do not
0c00: 68 69 6e 67 2e 0d 0a 20 20 20 20 20 20 20 20 7d  hing...        }
0c10: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
0c20: 0d 0a 20 20 7d 5d 20 74 72 75 65 20 74 72 75 65  ..  }] true true
0c30: 20 74 72 75 65 20 72 65 73 75 6c 74 73 20 65 72   true results er
0c40: 72 6f 72 73 20 53 79 73 74 65 6d 2e 44 61 74 61  rors System.Data
0c50: 2e 53 51 4c 69 74 65 2e 64 6c 6c 5d 0d 0a 0d 0a  .SQLite.dll]....
0c60: 20 20 6c 69 73 74 20 24 63 6f 64 65 20 24 72 65    list $code $re
0c70: 73 75 6c 74 73 20 5c 0d 0a 20 20 20 20 20 20 5b  sults \..      [
0c80: 65 78 70 72 20 7b 5b 69 6e 66 6f 20 65 78 69 73  expr {[info exis
0c90: 74 73 20 65 72 72 6f 72 73 5d 20 3f 20 24 65 72  ts errors] ? $er
0ca0: 72 6f 72 73 20 3a 20 22 22 7d 5d 20 5c 0d 0a 20  rors : ""}] \.. 
0cb0: 20 20 20 20 20 5b 65 78 70 72 20 7b 24 63 6f 64       [expr {$cod
0cc0: 65 20 65 71 20 22 4f 6b 22 20 3f 20 5b 63 61 74  e eq "Ok" ? [cat
0cd0: 63 68 20 7b 0d 0a 20 20 20 20 20 20 20 20 6f 62  ch {..        ob
0ce0: 6a 65 63 74 20 69 6e 76 6f 6b 65 20 2d 61 6c 69  ject invoke -ali
0cf0: 61 73 20 5f 44 79 6e 61 6d 69 63 24 7b 69 64 7d  as _Dynamic${id}
0d00: 2e 54 65 73 74 24 7b 69 64 7d 20 47 65 74 44 61  .Test${id} GetDa
0d10: 74 61 54 61 62 6c 65 0d 0a 20 20 20 20 20 20 7d  taTable..      }
0d20: 20 72 65 73 75 6c 74 5d 20 3a 20 5b 73 65 74 20   result] : [set 
0d30: 72 65 73 75 6c 74 20 22 22 5d 7d 5d 20 24 72 65  result ""]}] $re
0d40: 73 75 6c 74 20 5b 67 65 74 52 6f 77 73 46 72 6f  sult [getRowsFro
0d50: 6d 44 61 74 61 54 61 62 6c 65 20 24 72 65 73 75  mDataTable $resu
0d60: 6c 74 5d 0d 0a 7d 20 2d 63 6c 65 61 6e 75 70 20  lt]..} -cleanup 
0d70: 7b 0d 0a 20 20 63 6c 65 61 6e 75 70 44 62 20 24  {..  cleanupDb $
0d80: 66 69 6c 65 4e 61 6d 65 0d 0a 0d 0a 20 20 75 6e  fileName....  un
0d90: 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20  set -nocomplain 
0da0: 72 65 73 75 6c 74 20 72 65 73 75 6c 74 73 20 65  result results e
0db0: 72 72 6f 72 73 20 63 6f 64 65 20 73 71 6c 20 64  rrors code sql d
0dc0: 61 74 61 53 6f 75 72 63 65 20 69 64 20 64 62 20  ataSource id db 
0dd0: 66 69 6c 65 4e 61 6d 65 0d 0a 7d 20 2d 63 6f 6e  fileName..} -con
0de0: 73 74 72 61 69 6e 74 73 20 7b 65 61 67 6c 65 20  straints {eagle 
0df0: 6d 6f 6e 6f 42 75 67 32 38 20 63 6f 6d 6d 61 6e  monoBug28 comman
0e00: 64 2e 73 71 6c 20 63 6f 6d 70 69 6c 65 2e 44 41  d.sql compile.DA
0e10: 54 41 20 53 51 4c 69 74 65 5c 0d 0a 53 79 73 74  TA SQLite\..Syst
0e20: 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 20 63  em.Data.SQLite c
0e30: 6f 6d 70 69 6c 65 43 53 68 61 72 70 7d 20 2d 6d  ompileCSharp} -m
0e40: 61 74 63 68 20 72 65 67 65 78 70 20 2d 72 65 73  atch regexp -res
0e50: 75 6c 74 20 7b 5e 4f 6b 5c 0d 0a 53 79 73 74 65  ult {^Ok\..Syste
0e60: 6d 23 43 6f 64 65 44 6f 6d 23 43 6f 6d 70 69 6c  m#CodeDom#Compil
0e70: 65 72 23 43 6f 6d 70 69 6c 65 72 52 65 73 75 6c  er#CompilerResul
0e80: 74 73 23 5c 64 2b 20 5c 7b 5c 7d 20 30 20 53 79  ts#\d+ \{\} 0 Sy
0e90: 73 74 65 6d 23 44 61 74 61 23 44 61 74 61 54 61  stem#Data#DataTa
0ea0: 62 6c 65 23 5c 64 2b 5c 0d 0a 5c 7b 5c 7b 5c 7b  ble#\d+\..\{\{\{
0eb0: 69 64 20 32 5c 7d 20 5c 7b 6d 69 6e 20 32 5c 7d  id 2\} \{min 2\}
0ec0: 20 5c 7b 6d 61 78 20 33 5c 7d 20 5c 7b 73 75 6d   \{max 3\} \{sum
0ed0: 20 35 5c 7d 5c 7d 20 5c 7b 5c 7b 69 64 20 32 5c   5\}\} \{\{id 2\
0ee0: 7d 20 5c 7b 6d 69 6e 20 31 5c 7d 20 5c 7b 6d 61  } \{min 1\} \{ma
0ef0: 78 20 32 5c 7d 5c 0d 0a 5c 7b 73 75 6d 20 33 5c  x 2\}\..\{sum 3\
0f00: 7d 5c 7d 5c 7d 24 7d 7d 0d 0a 0d 0a 23 23 23 23  }\}\}$}}....####
0f10: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f20: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f30: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f50: 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 72  ###########....r
0f60: 75 6e 53 51 4c 69 74 65 54 65 73 74 45 70 69 6c  unSQLiteTestEpil
0f70: 6f 67 75 65 0d 0a 72 75 6e 54 65 73 74 45 70 69  ogue..runTestEpi
0f80: 6c 6f 67 75 65 0d 0a                             logue..