System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 9468ec27449c5cd81e59515d43790b7e1603d585:


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 65 33 30 62 38 32  .#..# tkt-e30b82
0060: 30 32 34 38 2e 65 61 67 6c 65 20 2d 2d 0d 0a 23  0248.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 73 65 74  #########....set
0270: 20 6d 65 6d 6f 72 79 5f 75 73 65 64 20 5b 72 65   memory_used [re
0280: 70 6f 72 74 53 51 4c 69 74 65 52 65 73 6f 75 72  portSQLiteResour
0290: 63 65 73 20 24 74 65 73 74 5f 63 68 61 6e 6e 65  ces $test_channe
02a0: 6c 20 74 72 75 65 5d 0d 0a 0d 0a 23 23 23 23 23  l true]....#####
02b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
02c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
02d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
02e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
02f0: 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 72 75  ##########....ru
0300: 6e 54 65 73 74 20 7b 74 65 73 74 20 74 6b 74 2d  nTest {test tkt-
0310: 65 33 30 62 38 32 30 32 34 38 2d 31 2e 31 20 7b  e30b820248-1.1 {
0320: 64 69 73 70 6f 73 61 6c 20 6f 72 64 65 72 69 6e  disposal orderin
0330: 67 7d 20 2d 73 65 74 75 70 20 7b 0d 0a 20 20 73  g} -setup {..  s
0340: 65 74 20 66 69 6c 65 4e 61 6d 65 20 74 6b 74 2d  et fileName tkt-
0350: 65 33 30 62 38 32 30 32 34 38 2d 31 2e 31 2e 64  e30b820248-1.1.d
0360: 62 0d 0a 7d 20 2d 62 6f 64 79 20 7b 0d 0a 20 20  b..} -body {..  
0370: 73 65 74 20 69 64 20 5b 6f 62 6a 65 63 74 20 69  set id [object i
0380: 6e 76 6f 6b 65 20 49 6e 74 65 72 70 72 65 74 65  nvoke Interprete
0390: 72 2e 47 65 74 41 63 74 69 76 65 20 4e 65 78 74  r.GetActive Next
03a0: 49 64 5d 0d 0a 20 20 73 65 74 20 64 61 74 61 53  Id]..  set dataS
03b0: 6f 75 72 63 65 20 5b 66 69 6c 65 20 6a 6f 69 6e  ource [file join
03c0: 20 5b 67 65 74 44 61 74 61 62 61 73 65 44 69 72   [getDatabaseDir
03d0: 65 63 74 6f 72 79 5d 20 24 66 69 6c 65 4e 61 6d  ectory] $fileNam
03e0: 65 5d 0d 0a 20 20 73 65 74 20 6e 61 6d 65 20 5b  e]..  set name [
03f0: 66 69 6c 65 20 72 6f 6f 74 6e 61 6d 65 20 5b 66  file rootname [f
0400: 69 6c 65 20 74 61 69 6c 20 24 66 69 6c 65 4e 61  ile tail $fileNa
0410: 6d 65 5d 5d 0d 0a 0d 0a 20 20 73 65 74 20 73 71  me]]....  set sq
0420: 6c 20 7b 20 5c 0d 0a 20 20 20 20 43 52 45 41 54  l { \..    CREAT
0430: 45 20 54 41 42 4c 45 20 74 31 20 28 69 64 31 20  E TABLE t1 (id1 
0440: 49 4e 54 45 47 45 52 29 3b 20 5c 0d 0a 20 20 20  INTEGER); \..   
0450: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0460: 28 69 64 31 29 20 56 41 4c 55 45 53 20 28 31 29  (id1) VALUES (1)
0470: 3b 20 5c 0d 0a 20 20 20 20 49 4e 53 45 52 54 20  ; \..    INSERT 
0480: 49 4e 54 4f 20 74 31 20 28 69 64 31 29 20 56 41  INTO t1 (id1) VA
0490: 4c 55 45 53 20 28 32 29 3b 20 5c 0d 0a 20 20 20  LUES (2); \..   
04a0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
04b0: 28 69 64 31 29 20 56 41 4c 55 45 53 20 28 3f 29  (id1) VALUES (?)
04c0: 3b 20 5c 0d 0a 20 20 20 20 49 4e 53 45 52 54 20  ; \..    INSERT 
04d0: 49 4e 54 4f 20 74 31 20 28 69 64 31 29 20 56 41  INTO t1 (id1) VA
04e0: 4c 55 45 53 20 28 3f 29 3b 20 5c 0d 0a 20 20 20  LUES (?); \..   
04f0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0500: 28 69 64 31 29 20 56 41 4c 55 45 53 20 28 3f 29  (id1) VALUES (?)
0510: 3b 20 5c 0d 0a 20 20 20 20 53 45 4c 45 43 54 20  ; \..    SELECT 
0520: 69 64 31 20 46 52 4f 4d 20 74 31 20 4f 52 44 45  id1 FROM t1 ORDE
0530: 52 20 42 59 20 69 64 31 3b 20 5c 0d 0a 20 20 7d  R BY id1; \..  }
0540: 0d 0a 0d 0a 20 20 75 6e 73 65 74 20 2d 6e 6f 63  ....  unset -noc
0550: 6f 6d 70 6c 61 69 6e 20 72 65 73 75 6c 74 73 20  omplain results 
0560: 65 72 72 6f 72 73 0d 0a 0d 0a 20 20 73 65 74 20  errors....  set 
0570: 63 6f 64 65 20 5b 63 6f 6d 70 69 6c 65 43 53 68  code [compileCSh
0580: 61 72 70 57 69 74 68 20 5b 73 75 62 73 74 20 7b  arpWith [subst {
0590: 0d 0a 20 20 20 20 75 73 69 6e 67 20 53 79 73 74  ..    using Syst
05a0: 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 3b 0d  em.Data.SQLite;.
05b0: 0a 20 20 20 20 75 73 69 6e 67 20 53 79 73 74 65  .    using Syste
05c0: 6d 2e 44 69 61 67 6e 6f 73 74 69 63 73 3b 0d 0a  m.Diagnostics;..
05d0: 20 20 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d      using System
05e0: 2e 49 4f 3b 0d 0a 0d 0a 20 20 20 20 6e 61 6d 65  .IO;....    name
05f0: 73 70 61 63 65 20 5f 44 79 6e 61 6d 69 63 24 7b  space _Dynamic${
0600: 69 64 7d 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  id}..    {..    
0610: 20 20 70 75 62 6c 69 63 20 73 74 61 74 69 63 20    public static 
0620: 63 6c 61 73 73 20 54 65 73 74 24 7b 69 64 7d 0d  class Test${id}.
0630: 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  .      {..      
0640: 20 20 70 75 62 6c 69 63 20 73 74 61 74 69 63 20    public static 
0650: 76 6f 69 64 20 4d 61 69 6e 28 29 0d 0a 20 20 20  void Main()..   
0660: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
0670: 20 20 75 73 69 6e 67 20 28 54 72 61 63 65 4c 69    using (TraceLi
0680: 73 74 65 6e 65 72 20 6c 69 73 74 65 6e 65 72 20  stener listener 
0690: 3d 20 6e 65 77 20 54 65 78 74 57 72 69 74 65 72  = new TextWriter
06a0: 54 72 61 63 65 4c 69 73 74 65 6e 65 72 28 0d 0a  TraceListener(..
06b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6e 65                ne
06c0: 77 20 46 69 6c 65 53 74 72 65 61 6d 28 22 24 7b  w FileStream("${
06d0: 74 65 73 74 5f 6c 6f 67 7d 22 2c 20 46 69 6c 65  test_log}", File
06e0: 4d 6f 64 65 2e 41 70 70 65 6e 64 2c 0d 0a 20 20  Mode.Append,..  
06f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0700: 46 69 6c 65 41 63 63 65 73 73 2e 57 72 69 74 65  FileAccess.Write
0710: 2c 20 46 69 6c 65 53 68 61 72 65 2e 52 65 61 64  , FileShare.Read
0720: 57 72 69 74 65 29 2c 20 22 24 7b 6e 61 6d 65 7d  Write), "${name}
0730: 22 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b  "))..          {
0740: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 54 72  ..            Tr
0750: 61 63 65 2e 4c 69 73 74 65 6e 65 72 73 2e 41 64  ace.Listeners.Ad
0760: 64 28 6c 69 73 74 65 6e 65 72 29 3b 0d 0a 20 20  d(listener);..  
0770: 20 20 20 20 20 20 20 20 20 20 54 72 61 63 65 2e            Trace.
0780: 57 72 69 74 65 4c 69 6e 65 28 22 2d 2d 2d 2d 20  WriteLine("---- 
0790: 53 54 41 52 54 20 54 52 41 43 45 20 5c 5c 22 24  START TRACE \\"$
07a0: 7b 6e 61 6d 65 7d 5c 5c 22 22 29 3b 0d 0a 0d 0a  {name}\\"");....
07b0: 20 20 20 20 20 20 20 20 20 20 20 20 75 73 69 6e              usin
07c0: 67 20 28 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74  g (SQLiteConnect
07d0: 69 6f 6e 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 3d  ion connection =
07e0: 20 6e 65 77 20 53 51 4c 69 74 65 43 6f 6e 6e 65   new SQLiteConne
07f0: 63 74 69 6f 6e 28 0d 0a 20 20 20 20 20 20 20 20  ction(..        
0800: 20 20 20 20 20 20 20 20 22 44 61 74 61 20 53 6f          "Data So
0810: 75 72 63 65 3d 24 7b 64 61 74 61 53 6f 75 72 63  urce=${dataSourc
0820: 65 7d 3b 5b 67 65 74 46 6c 61 67 73 50 72 6f 70  e};[getFlagsProp
0830: 65 72 74 79 5d 22 29 29 0d 0a 20 20 20 20 20 20  erty]"))..      
0840: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
0850: 20 20 20 20 20 20 20 63 6f 6e 6e 65 63 74 69 6f         connectio
0860: 6e 2e 4f 70 65 6e 28 29 3b 0d 0a 20 20 20 20 20  n.Open();..     
0870: 20 20 20 20 20 20 20 20 20 63 6f 6e 6e 65 63 74           connect
0880: 69 6f 6e 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30  ion.LogMessage(0
0890: 2c 20 22 43 6f 6e 6e 65 63 74 69 6f 6e 20 6f 70  , "Connection op
08a0: 65 6e 65 64 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20  ened.");....    
08b0: 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20            using 
08c0: 28 53 51 4c 69 74 65 54 72 61 6e 73 61 63 74 69  (SQLiteTransacti
08d0: 6f 6e 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 3d  on transaction =
08e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
08f0: 20 20 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 42      connection.B
0900: 65 67 69 6e 54 72 61 6e 73 61 63 74 69 6f 6e 28  eginTransaction(
0910: 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ))..            
0920: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
0930: 20 20 20 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e       connection.
0940: 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 22 54  LogMessage(0, "T
0950: 72 61 6e 73 61 63 74 69 6f 6e 20 73 74 61 72 74  ransaction start
0960: 65 64 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  ed.");....      
0970: 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20            using 
0980: 28 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63  (SQLiteCommand c
0990: 6f 6d 6d 61 6e 64 20 3d 20 63 6f 6e 6e 65 63 74  ommand = connect
09a0: 69 6f 6e 2e 43 72 65 61 74 65 43 6f 6d 6d 61 6e  ion.CreateComman
09b0: 64 28 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20  d())..          
09c0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
09d0: 20 20 20 20 20 20 20 20 20 20 20 63 6f 6d 6d 61             comma
09e0: 6e 64 2e 54 72 61 6e 73 61 63 74 69 6f 6e 20 3d  nd.Transaction =
09f0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 3b 0d 0a 20   transaction;.. 
0a00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a10: 20 63 6f 6d 6d 61 6e 64 2e 43 6f 6d 6d 61 6e 64   command.Command
0a20: 54 65 78 74 20 3d 20 22 24 7b 73 71 6c 7d 22 3b  Text = "${sql}";
0a30: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
0a40: 20 20 20 20 20 20 63 6f 6d 6d 61 6e 64 2e 50 61        command.Pa
0a50: 72 61 6d 65 74 65 72 73 2e 41 64 64 57 69 74 68  rameters.AddWith
0a60: 56 61 6c 75 65 28 22 78 22 2c 20 33 29 3b 0d 0a  Value("x", 3);..
0a70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a80: 20 20 63 6f 6d 6d 61 6e 64 2e 50 61 72 61 6d 65    command.Parame
0a90: 74 65 72 73 2e 41 64 64 57 69 74 68 56 61 6c 75  ters.AddWithValu
0aa0: 65 28 22 79 22 2c 20 34 29 3b 0d 0a 20 20 20 20  e("y", 4);..    
0ab0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f                co
0ac0: 6d 6d 61 6e 64 2e 50 61 72 61 6d 65 74 65 72 73  mmand.Parameters
0ad0: 2e 41 64 64 57 69 74 68 56 61 6c 75 65 28 22 7a  .AddWithValue("z
0ae0: 22 2c 20 35 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  ", 5);....      
0af0: 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6d 6d              comm
0b00: 61 6e 64 2e 45 78 65 63 75 74 65 4e 6f 6e 51 75  and.ExecuteNonQu
0b10: 65 72 79 28 29 3b 0d 0a 20 20 20 20 20 20 20 20  ery();..        
0b20: 20 20 20 20 20 20 20 20 20 20 63 6f 6e 6e 65 63            connec
0b30: 74 69 6f 6e 2e 4c 6f 67 4d 65 73 73 61 67 65 28  tion.LogMessage(
0b40: 30 2c 20 22 43 6f 6d 6d 61 6e 64 20 65 78 65 63  0, "Command exec
0b50: 75 74 65 64 2e 22 29 3b 0d 0a 20 20 20 20 20 20  uted.");..      
0b60: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20            }.... 
0b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74                 t
0b80: 72 61 6e 73 61 63 74 69 6f 6e 2e 43 6f 6d 6d 69  ransaction.Commi
0b90: 74 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  t();..          
0ba0: 20 20 20 20 20 20 63 6f 6e 6e 65 63 74 69 6f 6e        connection
0bb0: 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 22  .LogMessage(0, "
0bc0: 54 72 61 6e 73 61 63 74 69 6f 6e 20 63 6f 6d 6d  Transaction comm
0bd0: 69 74 74 65 64 2e 22 29 3b 0d 0a 20 20 20 20 20  itted.");..     
0be0: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20           }..    
0bf0: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20          }....   
0c00: 20 20 20 20 20 20 20 20 20 54 72 61 63 65 2e 57           Trace.W
0c10: 72 69 74 65 4c 69 6e 65 28 22 2d 2d 2d 2d 20 45  riteLine("---- E
0c20: 4e 44 20 54 52 41 43 45 20 5c 5c 22 24 7b 6e 61  ND TRACE \\"${na
0c30: 6d 65 7d 5c 5c 22 22 29 3b 0d 0a 20 20 20 20 20  me}\\"");..     
0c40: 20 20 20 20 20 20 20 54 72 61 63 65 2e 4c 69 73         Trace.Lis
0c50: 74 65 6e 65 72 73 2e 52 65 6d 6f 76 65 28 6c 69  teners.Remove(li
0c60: 73 74 65 6e 65 72 29 3b 0d 0a 20 20 20 20 20 20  stener);..      
0c70: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d      }..        }
0c80: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
0c90: 0d 0a 20 20 7d 5d 20 74 72 75 65 20 74 72 75 65  ..  }] true true
0ca0: 20 74 72 75 65 20 72 65 73 75 6c 74 73 20 65 72   true results er
0cb0: 72 6f 72 73 20 53 79 73 74 65 6d 2e 44 61 74 61  rors System.Data
0cc0: 2e 53 51 4c 69 74 65 2e 64 6c 6c 5d 0d 0a 0d 0a  .SQLite.dll]....
0cd0: 20 20 6c 69 73 74 20 24 63 6f 64 65 20 24 72 65    list $code $re
0ce0: 73 75 6c 74 73 20 5c 0d 0a 20 20 20 20 20 20 5b  sults \..      [
0cf0: 65 78 70 72 20 7b 5b 69 6e 66 6f 20 65 78 69 73  expr {[info exis
0d00: 74 73 20 65 72 72 6f 72 73 5d 20 3f 20 24 65 72  ts errors] ? $er
0d10: 72 6f 72 73 20 3a 20 22 22 7d 5d 20 5c 0d 0a 20  rors : ""}] \.. 
0d20: 20 20 20 20 20 5b 65 78 70 72 20 7b 24 63 6f 64       [expr {$cod
0d30: 65 20 65 71 20 22 4f 6b 22 20 3f 20 5b 63 61 74  e eq "Ok" ? [cat
0d40: 63 68 20 7b 0d 0a 20 20 20 20 20 20 20 20 6f 62  ch {..        ob
0d50: 6a 65 63 74 20 69 6e 76 6f 6b 65 20 5f 44 79 6e  ject invoke _Dyn
0d60: 61 6d 69 63 24 7b 69 64 7d 2e 54 65 73 74 24 7b  amic${id}.Test${
0d70: 69 64 7d 20 4d 61 69 6e 0d 0a 20 20 20 20 20 20  id} Main..      
0d80: 7d 20 72 65 73 75 6c 74 5d 20 3a 20 5b 73 65 74  } result] : [set
0d90: 20 72 65 73 75 6c 74 20 22 22 5d 7d 5d 20 24 72   result ""]}] $r
0da0: 65 73 75 6c 74 20 5c 0d 0a 20 20 20 20 20 20 5b  esult \..      [
0db0: 72 65 70 6f 72 74 53 51 4c 69 74 65 52 65 73 6f  reportSQLiteReso
0dc0: 75 72 63 65 73 20 24 74 65 73 74 5f 63 68 61 6e  urces $test_chan
0dd0: 6e 65 6c 20 74 72 75 65 5d 0d 0a 7d 20 2d 63 6c  nel true]..} -cl
0de0: 65 61 6e 75 70 20 7b 0d 0a 20 20 63 6c 65 61 6e  eanup {..  clean
0df0: 75 70 44 62 20 24 66 69 6c 65 4e 61 6d 65 0d 0a  upDb $fileName..
0e00: 0d 0a 20 20 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d  ..  unset -nocom
0e10: 70 6c 61 69 6e 20 72 65 73 75 6c 74 20 63 6f 64  plain result cod
0e20: 65 20 72 65 73 75 6c 74 73 20 65 72 72 6f 72 73  e results errors
0e30: 20 73 71 6c 20 6e 61 6d 65 20 64 61 74 61 53 6f   sql name dataSo
0e40: 75 72 63 65 20 69 64 20 66 69 6c 65 4e 61 6d 65  urce id fileName
0e50: 0d 0a 7d 20 2d 63 6f 6e 73 74 72 61 69 6e 74 73  ..} -constraints
0e60: 20 7b 65 61 67 6c 65 20 6c 6f 67 46 69 6c 65 20   {eagle logFile 
0e70: 6d 6f 6e 6f 42 75 67 32 38 20 63 6f 6d 6d 61 6e  monoBug28 comman
0e80: 64 2e 73 71 6c 20 63 6f 6d 70 69 6c 65 2e 44 41  d.sql compile.DA
0e90: 54 41 20 53 51 4c 69 74 65 5c 0d 0a 53 79 73 74  TA SQLite\..Syst
0ea0: 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 20 63  em.Data.SQLite c
0eb0: 6f 6d 70 69 6c 65 43 53 68 61 72 70 7d 20 2d 6d  ompileCSharp} -m
0ec0: 61 74 63 68 20 72 65 67 65 78 70 20 2d 72 65 73  atch regexp -res
0ed0: 75 6c 74 20 5b 61 70 70 65 6e 64 41 72 67 73 20  ult [appendArgs 
0ee0: 22 5e 4f 6b 5c 0d 0a 53 79 73 74 65 6d 23 43 6f  "^Ok\..System#Co
0ef0: 64 65 44 6f 6d 23 43 6f 6d 70 69 6c 65 72 23 43  deDom#Compiler#C
0f00: 6f 6d 70 69 6c 65 72 52 65 73 75 6c 74 73 23 5c  ompilerResults#\
0f10: 5c 64 2b 20 5c 5c 7b 5c 5c 7d 20 30 20 5c 5c 7b  \d+ \\{\\} 0 \\{
0f20: 5c 5c 7d 20 22 20 24 6d 65 6d 6f 72 79 5f 75 73  \\} " $memory_us
0f30: 65 64 20 5c 24 5d 7d 0d 0a 0d 0a 23 23 23 23 23  ed \$]}....#####
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 23 23 23 23 23  ################
0f60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f80: 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 66 6f  ##########....fo
0f90: 72 20 7b 73 65 74 20 69 20 32 7d 20 7b 24 69 20  r {set i 2} {$i 
0fa0: 3c 20 35 7d 20 7b 69 6e 63 72 20 69 7d 20 7b 0d  < 5} {incr i} {.
0fb0: 0a 20 20 73 65 74 20 6d 65 6d 6f 72 79 5f 75 73  .  set memory_us
0fc0: 65 64 20 5b 72 65 70 6f 72 74 53 51 4c 69 74 65  ed [reportSQLite
0fd0: 52 65 73 6f 75 72 63 65 73 20 24 74 65 73 74 5f  Resources $test_
0fe0: 63 68 61 6e 6e 65 6c 20 74 72 75 65 5d 0d 0a 0d  channel true]...
0ff0: 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23  .  #############
1000: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1010: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1020: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1030: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1040: 0d 0a 0d 0a 20 20 72 75 6e 54 65 73 74 20 7b 74  ....  runTest {t
1050: 65 73 74 20 5b 61 70 70 65 6e 64 41 72 67 73 20  est [appendArgs 
1060: 74 6b 74 2d 65 33 30 62 38 32 30 32 34 38 2d 31  tkt-e30b820248-1
1070: 2e 20 24 69 5d 20 7b 64 69 73 70 6f 73 61 6c 20  . $i] {disposal 
1080: 6f 72 64 65 72 69 6e 67 7d 20 2d 73 65 74 75 70  ordering} -setup
1090: 20 7b 0d 0a 20 20 20 20 73 65 74 20 66 69 6c 65   {..    set file
10a0: 4e 61 6d 65 20 5b 61 70 70 65 6e 64 41 72 67 73  Name [appendArgs
10b0: 20 74 6b 74 2d 65 33 30 62 38 32 30 32 34 38 2d   tkt-e30b820248-
10c0: 31 2e 20 24 69 20 2e 64 62 5d 0d 0a 20 20 7d 20  1. $i .db]..  } 
10d0: 2d 62 6f 64 79 20 7b 0d 0a 20 20 20 20 73 65 74  -body {..    set
10e0: 20 69 64 20 5b 6f 62 6a 65 63 74 20 69 6e 76 6f   id [object invo
10f0: 6b 65 20 49 6e 74 65 72 70 72 65 74 65 72 2e 47  ke Interpreter.G
1100: 65 74 41 63 74 69 76 65 20 4e 65 78 74 49 64 5d  etActive NextId]
1110: 0d 0a 20 20 20 20 73 65 74 20 64 61 74 61 53 6f  ..    set dataSo
1120: 75 72 63 65 20 5b 66 69 6c 65 20 6a 6f 69 6e 20  urce [file join 
1130: 5b 67 65 74 44 61 74 61 62 61 73 65 44 69 72 65  [getDatabaseDire
1140: 63 74 6f 72 79 5d 20 24 66 69 6c 65 4e 61 6d 65  ctory] $fileName
1150: 5d 0d 0a 20 20 20 20 73 65 74 20 6e 61 6d 65 20  ]..    set name 
1160: 5b 66 69 6c 65 20 72 6f 6f 74 6e 61 6d 65 20 5b  [file rootname [
1170: 66 69 6c 65 20 74 61 69 6c 20 24 66 69 6c 65 4e  file tail $fileN
1180: 61 6d 65 5d 5d 0d 0a 0d 0a 20 20 20 20 73 65 74  ame]]....    set
1190: 20 73 71 6c 20 7b 20 5c 0d 0a 20 20 20 20 20 20   sql { \..      
11a0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 20  CREATE TABLE t1 
11b0: 28 69 64 31 20 49 4e 54 45 47 45 52 29 3b 20 5c  (id1 INTEGER); \
11c0: 0d 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49  ..      INSERT I
11d0: 4e 54 4f 20 74 31 20 28 69 64 31 29 20 56 41 4c  NTO t1 (id1) VAL
11e0: 55 45 53 20 28 31 29 3b 20 5c 0d 0a 20 20 20 20  UES (1); \..    
11f0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
1200: 20 28 69 64 31 29 20 56 41 4c 55 45 53 20 28 32   (id1) VALUES (2
1210: 29 3b 20 5c 0d 0a 20 20 20 20 20 20 49 4e 53 45  ); \..      INSE
1220: 52 54 20 49 4e 54 4f 20 74 31 20 28 69 64 31 29  RT INTO t1 (id1)
1230: 20 56 41 4c 55 45 53 20 28 33 29 3b 20 5c 0d 0a   VALUES (3); \..
1240: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
1250: 4f 20 74 31 20 28 69 64 31 29 20 56 41 4c 55 45  O t1 (id1) VALUE
1260: 53 20 28 34 29 3b 20 5c 0d 0a 20 20 20 20 20 20  S (4); \..      
1270: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 28  INSERT INTO t1 (
1280: 69 64 31 29 20 56 41 4c 55 45 53 20 28 35 29 3b  id1) VALUES (5);
1290: 20 5c 0d 0a 20 20 20 20 20 20 53 45 4c 45 43 54   \..      SELECT
12a0: 20 69 64 31 20 46 52 4f 4d 20 74 31 20 4f 52 44   id1 FROM t1 ORD
12b0: 45 52 20 42 59 20 69 64 31 3b 20 5c 0d 0a 20 20  ER BY id1; \..  
12c0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 75 6e 73 65 74    }....    unset
12d0: 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20 72 65 73   -nocomplain res
12e0: 75 6c 74 73 20 65 72 72 6f 72 73 0d 0a 0d 0a 20  ults errors.... 
12f0: 20 20 20 73 65 74 20 63 6f 64 65 20 5b 63 6f 6d     set code [com
1300: 70 69 6c 65 43 53 68 61 72 70 57 69 74 68 20 5b  pileCSharpWith [
1310: 73 75 62 73 74 20 7b 0d 0a 20 20 20 20 20 20 75  subst {..      u
1320: 73 69 6e 67 20 53 79 73 74 65 6d 3b 0d 0a 20 20  sing System;..  
1330: 20 20 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d      using System
1340: 2e 44 61 74 61 2e 53 51 4c 69 74 65 3b 0d 0a 20  .Data.SQLite;.. 
1350: 20 20 20 20 20 75 73 69 6e 67 20 53 79 73 74 65       using Syste
1360: 6d 2e 44 69 61 67 6e 6f 73 74 69 63 73 3b 0d 0a  m.Diagnostics;..
1370: 20 20 20 20 20 20 75 73 69 6e 67 20 53 79 73 74        using Syst
1380: 65 6d 2e 49 4f 3b 0d 0a 0d 0a 20 20 20 20 20 20  em.IO;....      
1390: 6e 61 6d 65 73 70 61 63 65 20 5f 44 79 6e 61 6d  namespace _Dynam
13a0: 69 63 24 7b 69 64 7d 0d 0a 20 20 20 20 20 20 7b  ic${id}..      {
13b0: 0d 0a 20 20 20 20 20 20 20 20 70 75 62 6c 69 63  ..        public
13c0: 20 73 74 61 74 69 63 20 63 6c 61 73 73 20 54 65   static class Te
13d0: 73 74 24 7b 69 64 7d 0d 0a 20 20 20 20 20 20 20  st${id}..       
13e0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 23 72   {..          #r
13f0: 65 67 69 6f 6e 20 50 72 69 76 61 74 65 20 53 74  egion Private St
1400: 61 74 69 63 20 44 61 74 61 0d 0a 20 20 20 20 20  atic Data..     
1410: 20 20 20 20 20 70 72 69 76 61 74 65 20 73 74 61       private sta
1420: 74 69 63 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63  tic SQLiteConnec
1430: 74 69 6f 6e 20 63 6f 6e 6e 65 63 74 69 6f 6e 3b  tion connection;
1440: 0d 0a 20 20 20 20 20 20 20 20 20 20 23 65 6e 64  ..          #end
1450: 72 65 67 69 6f 6e 0d 0a 0d 0a 20 20 20 20 20 20  region....      
1460: 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f      ////////////
1470: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1480: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1490: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
14a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20  /////////....   
14b0: 20 20 20 20 20 20 20 23 72 65 67 69 6f 6e 20 50         #region P
14c0: 75 62 6c 69 63 20 53 74 61 74 69 63 20 4d 65 74  ublic Static Met
14d0: 68 6f 64 73 0d 0a 20 20 20 20 20 20 20 20 20 20  hods..          
14e0: 70 75 62 6c 69 63 20 73 74 61 74 69 63 20 76 6f  public static vo
14f0: 69 64 20 4f 70 65 6e 43 6f 6e 6e 65 63 74 69 6f  id OpenConnectio
1500: 6e 28 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b  n()..          {
1510: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6f  ..            co
1520: 6e 6e 65 63 74 69 6f 6e 20 3d 20 6e 65 77 20 53  nnection = new S
1530: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 28  QLiteConnection(
1540: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1550: 20 20 22 44 61 74 61 20 53 6f 75 72 63 65 3d 24    "Data Source=$
1560: 7b 64 61 74 61 53 6f 75 72 63 65 7d 3b 5b 67 65  {dataSource};[ge
1570: 74 46 6c 61 67 73 50 72 6f 70 65 72 74 79 5d 22  tFlagsProperty]"
1580: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
1590: 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 4f 70 65    connection.Ope
15a0: 6e 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  n();..          
15b0: 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 4c 6f 67    connection.Log
15c0: 4d 65 73 73 61 67 65 28 30 2c 20 22 43 6f 6e 6e  Message(0, "Conn
15d0: 65 63 74 69 6f 6e 20 6f 70 65 6e 65 64 2e 22 29  ection opened.")
15e0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  ;..          }..
15f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 2f 2f  ..          ////
1600: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1610: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1620: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1630: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1640: 2f 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 70  /....          p
1650: 75 62 6c 69 63 20 73 74 61 74 69 63 20 53 51 4c  ublic static SQL
1660: 69 74 65 43 6f 6d 6d 61 6e 64 20 43 72 65 61 74  iteCommand Creat
1670: 65 43 6f 6d 6d 61 6e 64 28 0d 0a 20 20 20 20 20  eCommand(..     
1680: 20 20 20 20 20 20 20 73 74 72 69 6e 67 20 73 71         string sq
1690: 6c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 29  l..            )
16a0: 0d 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20  ..          {.. 
16b0: 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74             SQLit
16c0: 65 43 6f 6d 6d 61 6e 64 20 63 6f 6d 6d 61 6e 64  eCommand command
16d0: 20 3d 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 43 72   = connection.Cr
16e0: 65 61 74 65 43 6f 6d 6d 61 6e 64 28 29 3b 0d 0a  eateCommand();..
16f0: 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6d 6d              comm
1700: 61 6e 64 2e 43 6f 6d 6d 61 6e 64 54 65 78 74 20  and.CommandText 
1710: 3d 20 73 71 6c 3b 0d 0a 20 20 20 20 20 20 20 20  = sql;..        
1720: 20 20 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 4c      connection.L
1730: 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 22 43 6f  ogMessage(0, "Co
1740: 6d 6d 61 6e 64 20 63 72 65 61 74 65 64 2e 22 29  mmand created.")
1750: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  ;..            r
1760: 65 74 75 72 6e 20 63 6f 6d 6d 61 6e 64 3b 0d 0a  eturn command;..
1770: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20            }.... 
1780: 20 20 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f           ///////
1790: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
17a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
17b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
17c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a  //////////////..
17d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 70 75 62 6c  ..          publ
17e0: 69 63 20 73 74 61 74 69 63 20 53 51 4c 69 74 65  ic static SQLite
17f0: 44 61 74 61 52 65 61 64 65 72 20 45 78 65 63 75  DataReader Execu
1800: 74 65 52 65 61 64 65 72 28 0d 0a 20 20 20 20 20  teReader(..     
1810: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6d         SQLiteCom
1820: 6d 61 6e 64 20 63 6f 6d 6d 61 6e 64 0d 0a 20 20  mand command..  
1830: 20 20 20 20 20 20 20 20 20 20 29 0d 0a 20 20 20            )..   
1840: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
1850: 20 20 20 20 20 20 53 51 4c 69 74 65 44 61 74 61        SQLiteData
1860: 52 65 61 64 65 72 20 64 61 74 61 52 65 61 64 65  Reader dataReade
1870: 72 20 3d 20 63 6f 6d 6d 61 6e 64 2e 45 78 65 63  r = command.Exec
1880: 75 74 65 52 65 61 64 65 72 28 29 3b 0d 0a 20 20  uteReader();..  
1890: 20 20 20 20 20 20 20 20 20 20 63 6f 6e 6e 65 63            connec
18a0: 74 69 6f 6e 2e 4c 6f 67 4d 65 73 73 61 67 65 28  tion.LogMessage(
18b0: 30 2c 20 22 43 6f 6d 6d 61 6e 64 20 65 78 65 63  0, "Command exec
18c0: 75 74 65 64 2e 22 29 3b 0d 0a 20 20 20 20 20 20  uted.");..      
18d0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 64 61 74        return dat
18e0: 61 52 65 61 64 65 72 3b 0d 0a 20 20 20 20 20 20  aReader;..      
18f0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20      }....       
1900: 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f     /////////////
1910: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1920: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1930: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1940: 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20  ////////....    
1950: 20 20 20 20 20 20 70 75 62 6c 69 63 20 73 74 61        public sta
1960: 74 69 63 20 53 51 4c 69 74 65 44 61 74 61 52 65  tic SQLiteDataRe
1970: 61 64 65 72 20 45 78 65 63 75 74 65 52 65 61 64  ader ExecuteRead
1980: 65 72 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  er(..           
1990: 20 73 74 72 69 6e 67 20 73 71 6c 0d 0a 20 20 20   string sql..   
19a0: 20 20 20 20 20 20 20 20 20 29 0d 0a 20 20 20 20           )..    
19b0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
19c0: 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6d 6d 61       SQLiteComma
19d0: 6e 64 20 63 6f 6d 6d 61 6e 64 20 3d 20 43 72 65  nd command = Cre
19e0: 61 74 65 43 6f 6d 6d 61 6e 64 28 73 71 6c 29 3b  ateCommand(sql);
19f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 53 51  ..            SQ
1a00: 4c 69 74 65 44 61 74 61 52 65 61 64 65 72 20 64  LiteDataReader d
1a10: 61 74 61 52 65 61 64 65 72 20 3d 20 63 6f 6d 6d  ataReader = comm
1a20: 61 6e 64 2e 45 78 65 63 75 74 65 52 65 61 64 65  and.ExecuteReade
1a30: 72 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  r();..          
1a40: 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 4c 6f 67    connection.Log
1a50: 4d 65 73 73 61 67 65 28 30 2c 20 22 43 6f 6d 6d  Message(0, "Comm
1a60: 61 6e 64 20 65 78 65 63 75 74 65 64 2e 22 29 3b  and executed.");
1a70: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65  ..            re
1a80: 74 75 72 6e 20 64 61 74 61 52 65 61 64 65 72 3b  turn dataReader;
1a90: 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d  ..          }...
1aa0: 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 2f 2f 2f  .          /////
1ab0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1ac0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1ad0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1ae0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1af0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 70 75  ....          pu
1b00: 62 6c 69 63 20 73 74 61 74 69 63 20 76 6f 69 64  blic static void
1b10: 20 43 6c 6f 73 65 43 6f 6e 6e 65 63 74 69 6f 6e   CloseConnection
1b20: 28 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b 0d  ()..          {.
1b30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e  .            con
1b40: 6e 65 63 74 69 6f 6e 2e 4c 6f 67 4d 65 73 73 61  nection.LogMessa
1b50: 67 65 28 30 2c 20 22 43 6c 6f 73 69 6e 67 20 63  ge(0, "Closing c
1b60: 6f 6e 6e 65 63 74 69 6f 6e 2e 2e 2e 22 29 3b 0d  onnection...");.
1b70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e  .            con
1b80: 6e 65 63 74 69 6f 6e 2e 43 6c 6f 73 65 28 29 3b  nection.Close();
1b90: 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20  ..          }.. 
1ba0: 20 20 20 20 20 20 20 20 20 23 65 6e 64 72 65 67           #endreg
1bb0: 69 6f 6e 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20  ion....         
1bc0: 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f   ///////////////
1bd0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1be0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1bf0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1c00: 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20  //////....      
1c10: 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69      public stati
1c20: 63 20 76 6f 69 64 20 4d 61 69 6e 28 29 0d 0a 20  c void Main().. 
1c30: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
1c40: 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 54          using (T
1c50: 72 61 63 65 4c 69 73 74 65 6e 65 72 20 6c 69 73  raceListener lis
1c60: 74 65 6e 65 72 20 3d 20 6e 65 77 20 54 65 78 74  tener = new Text
1c70: 57 72 69 74 65 72 54 72 61 63 65 4c 69 73 74 65  WriterTraceListe
1c80: 6e 65 72 28 0d 0a 20 20 20 20 20 20 20 20 20 20  ner(..          
1c90: 20 20 20 20 20 20 6e 65 77 20 46 69 6c 65 53 74        new FileSt
1ca0: 72 65 61 6d 28 22 24 7b 74 65 73 74 5f 6c 6f 67  ream("${test_log
1cb0: 7d 22 2c 20 46 69 6c 65 4d 6f 64 65 2e 41 70 70  }", FileMode.App
1cc0: 65 6e 64 2c 0d 0a 20 20 20 20 20 20 20 20 20 20  end,..          
1cd0: 20 20 20 20 20 20 20 20 20 20 46 69 6c 65 41 63            FileAc
1ce0: 63 65 73 73 2e 57 72 69 74 65 2c 20 46 69 6c 65  cess.Write, File
1cf0: 53 68 61 72 65 2e 52 65 61 64 57 72 69 74 65 29  Share.ReadWrite)
1d00: 2c 20 22 24 7b 6e 61 6d 65 7d 22 29 29 0d 0a 20  , "${name}")).. 
1d10: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
1d20: 20 20 20 20 20 20 20 20 20 20 20 20 54 72 61 63              Trac
1d30: 65 2e 4c 69 73 74 65 6e 65 72 73 2e 41 64 64 28  e.Listeners.Add(
1d40: 6c 69 73 74 65 6e 65 72 29 3b 0d 0a 20 20 20 20  listener);..    
1d50: 20 20 20 20 20 20 20 20 20 20 54 72 61 63 65 2e            Trace.
1d60: 57 72 69 74 65 4c 69 6e 65 28 22 2d 2d 2d 2d 20  WriteLine("---- 
1d70: 53 54 41 52 54 20 54 52 41 43 45 20 5c 5c 22 24  START TRACE \\"$
1d80: 7b 6e 61 6d 65 7d 5c 5c 22 22 29 3b 0d 0a 0d 0a  {name}\\"");....
1d90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 4f 70                Op
1da0: 65 6e 43 6f 6e 6e 65 63 74 69 6f 6e 28 29 3b 0d  enConnection();.
1db0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53  .              S
1dc0: 51 4c 69 74 65 44 61 74 61 52 65 61 64 65 72 20  QLiteDataReader 
1dd0: 64 61 74 61 52 65 61 64 65 72 20 3d 20 45 78 65  dataReader = Exe
1de0: 63 75 74 65 52 65 61 64 65 72 28 22 24 7b 73 71  cuteReader("${sq
1df0: 6c 7d 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  l}");....       
1e00: 20 20 20 20 20 20 20 5b 65 78 70 72 20 7b 24 69         [expr {$i
1e10: 20 3c 3d 20 32 20 3f 20 7b 0d 0a 20 20 20 20 20   <= 2 ? {..     
1e20: 20 20 20 20 20 20 20 20 20 20 20 47 43 2e 43 6f             GC.Co
1e30: 6c 6c 65 63 74 28 29 3b 0d 0a 20 20 20 20 20 20  llect();..      
1e40: 20 20 20 20 20 20 20 20 20 20 47 43 2e 57 61 69            GC.Wai
1e50: 74 46 6f 72 50 65 6e 64 69 6e 67 46 69 6e 61 6c  tForPendingFinal
1e60: 69 7a 65 72 73 28 29 3b 0d 0a 20 20 20 20 20 20  izers();..      
1e70: 20 20 20 20 20 20 20 20 20 20 47 43 2e 43 6f 6c            GC.Col
1e80: 6c 65 63 74 28 29 3b 0d 0a 20 20 20 20 20 20 20  lect();..       
1e90: 20 20 20 20 20 20 20 7d 20 3a 20 22 22 7d 5d 0d         } : ""}].
1ea0: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
1eb0: 20 64 61 74 61 52 65 61 64 65 72 2e 43 6c 6f 73   dataReader.Clos
1ec0: 65 28 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  e();....        
1ed0: 20 20 20 20 20 20 5b 65 78 70 72 20 7b 24 69 20        [expr {$i 
1ee0: 3c 3d 20 33 20 3f 20 7b 0d 0a 20 20 20 20 20 20  <= 3 ? {..      
1ef0: 20 20 20 20 20 20 20 20 20 20 47 43 2e 43 6f 6c            GC.Col
1f00: 6c 65 63 74 28 29 3b 0d 0a 20 20 20 20 20 20 20  lect();..       
1f10: 20 20 20 20 20 20 20 20 20 47 43 2e 57 61 69 74           GC.Wait
1f20: 46 6f 72 50 65 6e 64 69 6e 67 46 69 6e 61 6c 69  ForPendingFinali
1f30: 7a 65 72 73 28 29 3b 0d 0a 20 20 20 20 20 20 20  zers();..       
1f40: 20 20 20 20 20 20 20 20 20 47 43 2e 43 6f 6c 6c           GC.Coll
1f50: 65 63 74 28 29 3b 0d 0a 20 20 20 20 20 20 20 20  ect();..        
1f60: 20 20 20 20 20 20 7d 20 3a 20 22 22 7d 5d 0d 0a        } : ""}]..
1f70: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1f80: 43 6c 6f 73 65 43 6f 6e 6e 65 63 74 69 6f 6e 28  CloseConnection(
1f90: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
1fa0: 20 20 20 20 5b 65 78 70 72 20 7b 24 69 20 3c 3d      [expr {$i <=
1fb0: 20 34 20 3f 20 7b 0d 0a 20 20 20 20 20 20 20 20   4 ? {..        
1fc0: 20 20 20 20 20 20 20 20 47 43 2e 43 6f 6c 6c 65          GC.Colle
1fd0: 63 74 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20  ct();..         
1fe0: 20 20 20 20 20 20 20 47 43 2e 57 61 69 74 46 6f         GC.WaitFo
1ff0: 72 50 65 6e 64 69 6e 67 46 69 6e 61 6c 69 7a 65  rPendingFinalize
2000: 72 73 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20  rs();..         
2010: 20 20 20 20 20 20 20 47 43 2e 43 6f 6c 6c 65 63         GC.Collec
2020: 74 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  t();..          
2030: 20 20 20 20 7d 20 3a 20 22 22 7d 5d 0d 0a 0d 0a      } : ""}]....
2040: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 54 72                Tr
2050: 61 63 65 2e 57 72 69 74 65 4c 69 6e 65 28 22 2d  ace.WriteLine("-
2060: 2d 2d 2d 20 45 4e 44 20 54 52 41 43 45 20 5c 5c  --- END TRACE \\
2070: 22 24 7b 6e 61 6d 65 7d 5c 5c 22 22 29 3b 0d 0a  "${name}\\"");..
2080: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 54 72                Tr
2090: 61 63 65 2e 4c 69 73 74 65 6e 65 72 73 2e 52 65  ace.Listeners.Re
20a0: 6d 6f 76 65 28 6c 69 73 74 65 6e 65 72 29 3b 0d  move(listener);.
20b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  .            }..
20c0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
20d0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d 0d       }..      }.
20e0: 0a 20 20 20 20 7d 5d 20 74 72 75 65 20 74 72 75  .    }] true tru
20f0: 65 20 74 72 75 65 20 72 65 73 75 6c 74 73 20 65  e true results e
2100: 72 72 6f 72 73 20 53 79 73 74 65 6d 2e 44 61 74  rrors System.Dat
2110: 61 2e 53 51 4c 69 74 65 2e 64 6c 6c 5d 0d 0a 0d  a.SQLite.dll]...
2120: 0a 20 20 20 20 6c 69 73 74 20 24 63 6f 64 65 20  .    list $code 
2130: 24 72 65 73 75 6c 74 73 20 5c 0d 0a 20 20 20 20  $results \..    
2140: 20 20 20 20 5b 65 78 70 72 20 7b 5b 69 6e 66 6f      [expr {[info
2150: 20 65 78 69 73 74 73 20 65 72 72 6f 72 73 5d 20   exists errors] 
2160: 3f 20 24 65 72 72 6f 72 73 20 3a 20 22 22 7d 5d  ? $errors : ""}]
2170: 20 5c 0d 0a 20 20 20 20 20 20 20 20 5b 65 78 70   \..        [exp
2180: 72 20 7b 24 63 6f 64 65 20 65 71 20 22 4f 6b 22  r {$code eq "Ok"
2190: 20 3f 20 5b 63 61 74 63 68 20 7b 0d 0a 20 20 20   ? [catch {..   
21a0: 20 20 20 20 20 20 20 6f 62 6a 65 63 74 20 69 6e         object in
21b0: 76 6f 6b 65 20 5f 44 79 6e 61 6d 69 63 24 7b 69  voke _Dynamic${i
21c0: 64 7d 2e 54 65 73 74 24 7b 69 64 7d 20 4d 61 69  d}.Test${id} Mai
21d0: 6e 0d 0a 20 20 20 20 20 20 20 20 7d 20 72 65 73  n..        } res
21e0: 75 6c 74 5d 20 3a 20 5b 73 65 74 20 72 65 73 75  ult] : [set resu
21f0: 6c 74 20 22 22 5d 7d 5d 20 24 72 65 73 75 6c 74  lt ""]}] $result
2200: 20 5c 0d 0a 20 20 20 20 20 20 20 20 5b 72 65 70   \..        [rep
2210: 6f 72 74 53 51 4c 69 74 65 52 65 73 6f 75 72 63  ortSQLiteResourc
2220: 65 73 20 24 74 65 73 74 5f 63 68 61 6e 6e 65 6c  es $test_channel
2230: 20 74 72 75 65 5d 0d 0a 20 20 7d 20 2d 63 6c 65   true]..  } -cle
2240: 61 6e 75 70 20 7b 0d 0a 20 20 20 20 63 6c 65 61  anup {..    clea
2250: 6e 75 70 44 62 20 24 66 69 6c 65 4e 61 6d 65 0d  nupDb $fileName.
2260: 0a 0d 0a 20 20 20 20 75 6e 73 65 74 20 2d 6e 6f  ...    unset -no
2270: 63 6f 6d 70 6c 61 69 6e 20 72 65 73 75 6c 74 20  complain result 
2280: 63 6f 64 65 20 72 65 73 75 6c 74 73 20 65 72 72  code results err
2290: 6f 72 73 20 73 71 6c 20 6e 61 6d 65 20 64 61 74  ors sql name dat
22a0: 61 53 6f 75 72 63 65 20 69 64 20 5c 0d 0a 20 20  aSource id \..  
22b0: 20 20 20 20 20 20 66 69 6c 65 4e 61 6d 65 0d 0a        fileName..
22c0: 20 20 7d 20 2d 63 6f 6e 73 74 72 61 69 6e 74 73    } -constraints
22d0: 20 7b 65 61 67 6c 65 20 6c 6f 67 46 69 6c 65 20   {eagle logFile 
22e0: 6d 6f 6e 6f 42 75 67 32 38 20 63 6f 6d 6d 61 6e  monoBug28 comman
22f0: 64 2e 73 71 6c 20 63 6f 6d 70 69 6c 65 2e 44 41  d.sql compile.DA
2300: 54 41 20 53 51 4c 69 74 65 5c 0d 0a 53 79 73 74  TA SQLite\..Syst
2310: 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 20 63  em.Data.SQLite c
2320: 6f 6d 70 69 6c 65 43 53 68 61 72 70 7d 20 2d 6d  ompileCSharp} -m
2330: 61 74 63 68 20 72 65 67 65 78 70 20 2d 72 65 73  atch regexp -res
2340: 75 6c 74 20 5b 61 70 70 65 6e 64 41 72 67 73 20  ult [appendArgs 
2350: 22 5e 4f 6b 5c 0d 0a 53 79 73 74 65 6d 23 43 6f  "^Ok\..System#Co
2360: 64 65 44 6f 6d 23 43 6f 6d 70 69 6c 65 72 23 43  deDom#Compiler#C
2370: 6f 6d 70 69 6c 65 72 52 65 73 75 6c 74 73 23 5c  ompilerResults#\
2380: 5c 64 2b 20 5c 5c 7b 5c 5c 7d 20 30 20 5c 5c 7b  \d+ \\{\\} 0 \\{
2390: 5c 5c 7d 20 22 20 24 6d 65 6d 6f 72 79 5f 75 73  \\} " $memory_us
23a0: 65 64 20 5c 24 5d 7d 0d 0a 7d 0d 0a 0d 0a 23 23  ed \$]}..}....##
23b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
23c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
23d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
23e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
23f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d  #############...
2400: 0a 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61  .unset -nocompla
2410: 69 6e 20 69 0d 0a 0d 0a 23 23 23 23 23 23 23 23  in i....########
2420: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2430: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2440: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2450: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2460: 23 23 23 23 23 23 23 0d 0a 0d 0a 75 6e 73 65 74  #######....unset
2470: 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20 6d 65 6d   -nocomplain mem
2480: 6f 72 79 5f 75 73 65 64 0d 0a 0d 0a 23 23 23 23  ory_used....####
2490: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
24a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
24b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
24c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
24d0: 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 72  ###########....r
24e0: 75 6e 53 51 4c 69 74 65 54 65 73 74 45 70 69 6c  unSQLiteTestEpil
24f0: 6f 67 75 65 0d 0a 72 75 6e 54 65 73 74 45 70 69  ogue..runTestEpi
2500: 6c 6f 67 75 65 0d 0a                             logue..