System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 4eb5e38b81f87016485df67b031bc69fd5c1bf51:


0000: 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  /***************
0010: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0020: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0030: 2a 2a 2a 2a 2a 2a 2a 2a 2a 0d 0a 20 2a 20 41 44  *********.. * AD
0040: 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74 61 20 50  O.NET 2.0 Data P
0050: 72 6f 76 69 64 65 72 20 66 6f 72 20 53 51 4c 69  rovider for SQLi
0060: 74 65 20 56 65 72 73 69 6f 6e 20 33 2e 58 0d 0a  te Version 3.X..
0070: 20 2a 20 57 72 69 74 74 65 6e 20 62 79 20 52 6f   * Written by Ro
0080: 62 65 72 74 20 53 69 6d 70 73 6f 6e 20 28 72 6f  bert Simpson (ro
0090: 62 65 72 74 40 62 6c 61 63 6b 63 61 73 74 6c 65  bert@blackcastle
00a0: 73 6f 66 74 2e 63 6f 6d 29 0d 0a 20 2a 0d 0a 20  soft.com).. *.. 
00b0: 2a 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74 68  * Released to th
00c0: 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c  e public domain,
00d0: 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77 6e   use at your own
00e0: 20 72 69 73 6b 21 0d 0a 20 2a 2a 2a 2a 2a 2a 2a   risk!.. *******
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 2f 0d 0a 0d 0a 6e 61 6d 65 73 70 61 63 65 20  */....namespace 
0130: 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69  System.Data.SQLi
0140: 74 65 0d 0a 7b 0d 0a 20 20 75 73 69 6e 67 20 53  te..{..  using S
0150: 79 73 74 65 6d 3b 0d 0a 0d 0a 23 69 66 20 21 4e  ystem;....#if !N
0160: 45 54 5f 43 4f 4d 50 41 43 54 5f 32 30 20 26 26  ET_COMPACT_20 &&
0170: 20 54 52 41 43 45 5f 57 41 52 4e 49 4e 47 0d 0a   TRACE_WARNING..
0180: 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44    using System.D
0190: 69 61 67 6e 6f 73 74 69 63 73 3b 0d 0a 23 65 6e  iagnostics;..#en
01a0: 64 69 66 0d 0a 0d 0a 20 20 75 73 69 6e 67 20 53  dif....  using S
01b0: 79 73 74 65 6d 2e 52 75 6e 74 69 6d 65 2e 49 6e  ystem.Runtime.In
01c0: 74 65 72 6f 70 53 65 72 76 69 63 65 73 3b 0d 0a  teropServices;..
01d0: 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 43    using System.C
01e0: 6f 6c 6c 65 63 74 69 6f 6e 73 2e 47 65 6e 65 72  ollections.Gener
01f0: 69 63 3b 0d 0a 20 20 75 73 69 6e 67 20 53 79 73  ic;..  using Sys
0200: 74 65 6d 2e 47 6c 6f 62 61 6c 69 7a 61 74 69 6f  tem.Globalizatio
0210: 6e 3b 0d 0a 20 20 75 73 69 6e 67 20 53 79 73 74  n;..  using Syst
0220: 65 6d 2e 54 65 78 74 3b 0d 0a 0d 0a 20 20 2f 2f  em.Text;....  //
0230: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f  / <summary>..  /
0240: 2f 2f 20 54 68 69 73 20 62 61 73 65 20 63 6c 61  // This base cla
0250: 73 73 20 70 72 6f 76 69 64 65 73 20 64 61 74 61  ss provides data
0260: 74 79 70 65 20 63 6f 6e 76 65 72 73 69 6f 6e 20  type conversion 
0270: 73 65 72 76 69 63 65 73 20 66 6f 72 20 74 68 65  services for the
0280: 20 53 51 4c 69 74 65 20 70 72 6f 76 69 64 65 72   SQLite provider
0290: 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  ...  /// </summa
02a0: 72 79 3e 0d 0a 20 20 70 75 62 6c 69 63 20 61 62  ry>..  public ab
02b0: 73 74 72 61 63 74 20 63 6c 61 73 73 20 53 51 4c  stract class SQL
02c0: 69 74 65 43 6f 6e 76 65 72 74 0d 0a 20 20 7b 0d  iteConvert..  {.
02d0: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
02e0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20  y>..    /// The 
02f0: 76 61 6c 75 65 20 66 6f 72 20 74 68 65 20 55 6e  value for the Un
0300: 69 78 20 65 70 6f 63 68 20 28 65 2e 67 2e 20 4a  ix epoch (e.g. J
0310: 61 6e 75 61 72 79 20 31 2c 20 31 39 37 30 20 61  anuary 1, 1970 a
0320: 74 20 6d 69 64 6e 69 67 68 74 2c 20 69 6e 20 55  t midnight, in U
0330: 54 43 29 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  TC)...    /// </
0340: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72  summary>..    pr
0350: 6f 74 65 63 74 65 64 20 73 74 61 74 69 63 20 72  otected static r
0360: 65 61 64 6f 6e 6c 79 20 44 61 74 65 54 69 6d 65  eadonly DateTime
0370: 20 55 6e 69 78 45 70 6f 63 68 20 3d 0d 0a 20 20   UnixEpoch =..  
0380: 20 20 20 20 20 20 6e 65 77 20 44 61 74 65 54 69        new DateTi
0390: 6d 65 28 31 39 37 30 2c 20 31 2c 20 31 2c 20 30  me(1970, 1, 1, 0
03a0: 2c 20 30 2c 20 30 2c 20 44 61 74 65 54 69 6d 65  , 0, 0, DateTime
03b0: 4b 69 6e 64 2e 55 74 63 29 3b 0d 0a 0d 0a 20 20  Kind.Utc);....  
03c0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
03d0: 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 76 61 6c  .    /// The val
03e0: 75 65 20 6f 66 20 74 68 65 20 4f 4c 45 20 41 75  ue of the OLE Au
03f0: 74 6f 6d 61 74 69 6f 6e 20 65 70 6f 63 68 20 72  tomation epoch r
0400: 65 70 72 65 73 65 6e 74 65 64 20 61 73 20 61 20  epresented as a 
0410: 4a 75 6c 69 61 6e 20 64 61 79 2e 0d 0a 20 20 20  Julian day...   
0420: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
0430: 0a 20 20 20 20 70 72 69 76 61 74 65 20 73 74 61  .    private sta
0440: 74 69 63 20 72 65 61 64 6f 6e 6c 79 20 64 6f 75  tic readonly dou
0450: 62 6c 65 20 4f 6c 65 41 75 74 6f 6d 61 74 69 6f  ble OleAutomatio
0460: 6e 45 70 6f 63 68 41 73 4a 75 6c 69 61 6e 44 61  nEpochAsJulianDa
0470: 79 20 3d 20 32 34 31 35 30 31 38 2e 35 3b 0d 0a  y = 2415018.5;..
0480: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
0490: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65  ry>..    /// The
04a0: 20 66 6f 72 6d 61 74 20 73 74 72 69 6e 67 20 66   format string f
04b0: 6f 72 20 44 61 74 65 54 69 6d 65 20 76 61 6c 75  or DateTime valu
04c0: 65 73 20 77 68 65 6e 20 75 73 69 6e 67 20 74 68  es when using th
04d0: 65 20 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75  e InvariantCultu
04e0: 72 65 20 6f 72 20 43 75 72 72 65 6e 74 43 75 6c  re or CurrentCul
04f0: 74 75 72 65 20 66 6f 72 6d 61 74 73 2e 0d 0a 20  ture formats... 
0500: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
0510: 3e 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20 63  >..    private c
0520: 6f 6e 73 74 20 73 74 72 69 6e 67 20 46 75 6c 6c  onst string Full
0530: 46 6f 72 6d 61 74 20 3d 20 22 79 79 79 79 2d 4d  Format = "yyyy-M
0540: 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73 2e 66 66  M-ddTHH:mm:ss.ff
0550: 66 66 66 66 66 4b 22 3b 0d 0a 0d 0a 20 20 20 20  fffffK";....    
0560: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
0570: 20 20 20 2f 2f 2f 20 41 6e 20 61 72 72 61 79 20     /// An array 
0580: 6f 66 20 49 53 4f 2d 38 36 30 31 20 44 61 74 65  of ISO-8601 Date
0590: 54 69 6d 65 20 66 6f 72 6d 61 74 73 20 74 68 61  Time formats tha
05a0: 74 20 77 65 20 73 75 70 70 6f 72 74 20 70 61 72  t we support par
05b0: 73 69 6e 67 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  sing...    /// <
05c0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70  /summary>..    p
05d0: 72 69 76 61 74 65 20 73 74 61 74 69 63 20 73 74  rivate static st
05e0: 72 69 6e 67 5b 5d 20 5f 64 61 74 65 74 69 6d 65  ring[] _datetime
05f0: 46 6f 72 6d 61 74 73 20 3d 20 6e 65 77 20 73 74  Formats = new st
0600: 72 69 6e 67 5b 5d 20 7b 0d 0a 20 20 20 20 20 20  ring[] {..      
0610: 22 54 48 48 6d 6d 73 73 4b 22 2c 0d 0a 20 20 20  "THHmmssK",..   
0620: 20 20 20 22 54 48 48 6d 6d 4b 22 2c 0d 0a 20 20     "THHmmK",..  
0630: 20 20 20 20 22 48 48 3a 6d 6d 3a 73 73 2e 46 46      "HH:mm:ss.FF
0640: 46 46 46 46 46 4b 22 2c 0d 0a 20 20 20 20 20 20  FFFFFK",..      
0650: 22 48 48 3a 6d 6d 3a 73 73 4b 22 2c 0d 0a 20 20  "HH:mm:ssK",..  
0660: 20 20 20 20 22 48 48 3a 6d 6d 4b 22 2c 0d 0a 20      "HH:mmK",.. 
0670: 20 20 20 20 20 22 79 79 79 79 2d 4d 4d 2d 64 64       "yyyy-MM-dd
0680: 20 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46   HH:mm:ss.FFFFFF
0690: 46 4b 22 2c 20 2f 2a 20 4e 4f 54 45 3a 20 55 54  FK", /* NOTE: UT
06a0: 43 20 64 65 66 61 75 6c 74 20 28 35 29 2e 20 2a  C default (5). *
06b0: 2f 0d 0a 20 20 20 20 20 20 22 79 79 79 79 2d 4d  /..      "yyyy-M
06c0: 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 4b 22 2c  M-dd HH:mm:ssK",
06d0: 0d 0a 20 20 20 20 20 20 22 79 79 79 79 2d 4d 4d  ..      "yyyy-MM
06e0: 2d 64 64 20 48 48 3a 6d 6d 4b 22 2c 0d 0a 20 20  -dd HH:mmK",..  
06f0: 20 20 20 20 22 79 79 79 79 2d 4d 4d 2d 64 64 54      "yyyy-MM-ddT
0700: 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46  HH:mm:ss.FFFFFFF
0710: 4b 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79  K",..      "yyyy
0720: 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 4b 22 2c 0d  -MM-ddTHH:mmK",.
0730: 0a 20 20 20 20 20 20 22 79 79 79 79 2d 4d 4d 2d  .      "yyyy-MM-
0740: 64 64 54 48 48 3a 6d 6d 3a 73 73 4b 22 2c 0d 0a  ddTHH:mm:ssK",..
0750: 20 20 20 20 20 20 22 79 79 79 79 4d 4d 64 64 48        "yyyyMMddH
0760: 48 6d 6d 73 73 4b 22 2c 0d 0a 20 20 20 20 20 20  HmmssK",..      
0770: 22 79 79 79 79 4d 4d 64 64 48 48 6d 6d 4b 22 2c  "yyyyMMddHHmmK",
0780: 0d 0a 20 20 20 20 20 20 22 79 79 79 79 4d 4d 64  ..      "yyyyMMd
0790: 64 54 48 48 6d 6d 73 73 46 46 46 46 46 46 46 4b  dTHHmmssFFFFFFFK
07a0: 22 2c 0d 0a 20 20 20 20 20 20 22 54 48 48 6d 6d  ",..      "THHmm
07b0: 73 73 22 2c 0d 0a 20 20 20 20 20 20 22 54 48 48  ss",..      "THH
07c0: 6d 6d 22 2c 0d 0a 20 20 20 20 20 20 22 48 48 3a  mm",..      "HH:
07d0: 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 22 2c 0d  mm:ss.FFFFFFF",.
07e0: 0a 20 20 20 20 20 20 22 48 48 3a 6d 6d 3a 73 73  .      "HH:mm:ss
07f0: 22 2c 0d 0a 20 20 20 20 20 20 22 48 48 3a 6d 6d  ",..      "HH:mm
0800: 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79 2d  ",..      "yyyy-
0810: 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 2e 46  MM-dd HH:mm:ss.F
0820: 46 46 46 46 46 46 22 2c 20 2f 2a 20 4e 4f 54 45  FFFFFF", /* NOTE
0830: 3a 20 4e 6f 6e 2d 55 54 43 20 64 65 66 61 75 6c  : Non-UTC defaul
0840: 74 20 28 31 39 29 2e 20 2a 2f 0d 0a 20 20 20 20  t (19). */..    
0850: 20 20 22 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48    "yyyy-MM-dd HH
0860: 3a 6d 6d 3a 73 73 22 2c 0d 0a 20 20 20 20 20 20  :mm:ss",..      
0870: 22 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d  "yyyy-MM-dd HH:m
0880: 6d 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79  m",..      "yyyy
0890: 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73 2e  -MM-ddTHH:mm:ss.
08a0: 46 46 46 46 46 46 46 22 2c 0d 0a 20 20 20 20 20  FFFFFFF",..     
08b0: 20 22 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a   "yyyy-MM-ddTHH:
08c0: 6d 6d 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79  mm",..      "yyy
08d0: 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73  y-MM-ddTHH:mm:ss
08e0: 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79 4d  ",..      "yyyyM
08f0: 4d 64 64 48 48 6d 6d 73 73 22 2c 0d 0a 20 20 20  MddHHmmss",..   
0900: 20 20 20 22 79 79 79 79 4d 4d 64 64 48 48 6d 6d     "yyyyMMddHHmm
0910: 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79 4d  ",..      "yyyyM
0920: 4d 64 64 54 48 48 6d 6d 73 73 46 46 46 46 46 46  MddTHHmmssFFFFFF
0930: 46 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79  F",..      "yyyy
0940: 2d 4d 4d 2d 64 64 22 2c 0d 0a 20 20 20 20 20 20  -MM-dd",..      
0950: 22 79 79 79 79 4d 4d 64 64 22 2c 0d 0a 20 20 20  "yyyyMMdd",..   
0960: 20 20 20 22 79 79 2d 4d 4d 2d 64 64 22 0d 0a 20     "yy-MM-dd".. 
0970: 20 20 20 7d 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f     };....    ///
0980: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
0990: 2f 2f 2f 20 54 68 65 20 69 6e 74 65 72 6e 61 6c  /// The internal
09a0: 20 64 65 66 61 75 6c 74 20 66 6f 72 6d 61 74 20   default format 
09b0: 66 6f 72 20 55 54 43 20 44 61 74 65 54 69 6d 65  for UTC DateTime
09c0: 20 76 61 6c 75 65 73 20 77 68 65 6e 20 63 6f 6e   values when con
09d0: 76 65 72 74 69 6e 67 0d 0a 20 20 20 20 2f 2f 2f  verting..    ///
09e0: 20 74 6f 20 61 20 73 74 72 69 6e 67 2e 0d 0a 20   to a string... 
09f0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
0a00: 3e 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20 73  >..    private s
0a10: 74 61 74 69 63 20 72 65 61 64 6f 6e 6c 79 20 73  tatic readonly s
0a20: 74 72 69 6e 67 20 5f 64 61 74 65 74 69 6d 65 46  tring _datetimeF
0a30: 6f 72 6d 61 74 55 74 63 20 3d 20 5f 64 61 74 65  ormatUtc = _date
0a40: 74 69 6d 65 46 6f 72 6d 61 74 73 5b 35 5d 3b 0d  timeFormats[5];.
0a50: 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ...    /// <summ
0a60: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68  ary>..    /// Th
0a70: 65 20 69 6e 74 65 72 6e 61 6c 20 64 65 66 61 75  e internal defau
0a80: 6c 74 20 66 6f 72 6d 61 74 20 66 6f 72 20 6c 6f  lt format for lo
0a90: 63 61 6c 20 44 61 74 65 54 69 6d 65 20 76 61 6c  cal DateTime val
0aa0: 75 65 73 20 77 68 65 6e 20 63 6f 6e 76 65 72 74  ues when convert
0ab0: 69 6e 67 0d 0a 20 20 20 20 2f 2f 2f 20 74 6f 20  ing..    /// to 
0ac0: 61 20 73 74 72 69 6e 67 2e 0d 0a 20 20 20 20 2f  a string...    /
0ad0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
0ae0: 20 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69     private stati
0af0: 63 20 72 65 61 64 6f 6e 6c 79 20 73 74 72 69 6e  c readonly strin
0b00: 67 20 5f 64 61 74 65 74 69 6d 65 46 6f 72 6d 61  g _datetimeForma
0b10: 74 4c 6f 63 61 6c 20 3d 20 5f 64 61 74 65 74 69  tLocal = _dateti
0b20: 6d 65 46 6f 72 6d 61 74 73 5b 31 39 5d 3b 0d 0a  meFormats[19];..
0b30: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
0b40: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 6e 20  ry>..    /// An 
0b50: 55 54 46 2d 38 20 45 6e 63 6f 64 69 6e 67 20 69  UTF-8 Encoding i
0b60: 6e 73 74 61 6e 63 65 2c 20 73 6f 20 77 65 20 63  nstance, so we c
0b70: 61 6e 20 63 6f 6e 76 65 72 74 20 73 74 72 69 6e  an convert strin
0b80: 67 73 20 74 6f 20 61 6e 64 20 66 72 6f 6d 20 55  gs to and from U
0b90: 54 46 2d 38 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  TF-8..    /// </
0ba0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72  summary>..    pr
0bb0: 69 76 61 74 65 20 73 74 61 74 69 63 20 45 6e 63  ivate static Enc
0bc0: 6f 64 69 6e 67 20 5f 75 74 66 38 20 3d 20 6e 65  oding _utf8 = ne
0bd0: 77 20 55 54 46 38 45 6e 63 6f 64 69 6e 67 28 29  w UTF8Encoding()
0be0: 3b 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ;..    /// <summ
0bf0: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68  ary>..    /// Th
0c00: 65 20 64 65 66 61 75 6c 74 20 44 61 74 65 54 69  e default DateTi
0c10: 6d 65 20 66 6f 72 6d 61 74 20 66 6f 72 20 74 68  me format for th
0c20: 69 73 20 69 6e 73 74 61 6e 63 65 0d 0a 20 20 20  is instance..   
0c30: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
0c40: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 53 51  .    internal SQ
0c50: 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73 20  LiteDateFormats 
0c60: 5f 64 61 74 65 74 69 6d 65 46 6f 72 6d 61 74 3b  _datetimeFormat;
0c70: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
0c80: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65  ry>..    /// The
0c90: 20 64 65 66 61 75 6c 74 20 44 61 74 65 54 69 6d   default DateTim
0ca0: 65 4b 69 6e 64 20 66 6f 72 20 74 68 69 73 20 69  eKind for this i
0cb0: 6e 73 74 61 6e 63 65 2e 0d 0a 20 20 20 20 2f 2f  nstance...    //
0cc0: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
0cd0: 20 20 69 6e 74 65 72 6e 61 6c 20 44 61 74 65 54    internal DateT
0ce0: 69 6d 65 4b 69 6e 64 20 5f 64 61 74 65 74 69 6d  imeKind _datetim
0cf0: 65 4b 69 6e 64 3b 0d 0a 20 20 20 20 2f 2f 2f 20  eKind;..    /// 
0d00: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
0d10: 2f 2f 20 49 6e 69 74 69 61 6c 69 7a 65 73 20 74  // Initializes t
0d20: 68 65 20 63 6f 6e 76 65 72 73 69 6f 6e 20 63 6c  he conversion cl
0d30: 61 73 73 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ass..    /// </s
0d40: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
0d50: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 66 6d   <param name="fm
0d60: 74 22 3e 54 68 65 20 64 65 66 61 75 6c 74 20 64  t">The default d
0d70: 61 74 65 2f 74 69 6d 65 20 66 6f 72 6d 61 74 20  ate/time format 
0d80: 74 6f 20 75 73 65 20 66 6f 72 20 74 68 69 73 20  to use for this 
0d90: 69 6e 73 74 61 6e 63 65 3c 2f 70 61 72 61 6d 3e  instance</param>
0da0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  ..    /// <param
0db0: 20 6e 61 6d 65 3d 22 6b 69 6e 64 22 3e 54 68 65   name="kind">The
0dc0: 20 44 61 74 65 54 69 6d 65 4b 69 6e 64 20 74 6f   DateTimeKind to
0dd0: 20 75 73 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20   use.</param>.. 
0de0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69     internal SQLi
0df0: 74 65 43 6f 6e 76 65 72 74 28 53 51 4c 69 74 65  teConvert(SQLite
0e00: 44 61 74 65 46 6f 72 6d 61 74 73 20 66 6d 74 2c  DateFormats fmt,
0e10: 20 44 61 74 65 54 69 6d 65 4b 69 6e 64 20 6b 69   DateTimeKind ki
0e20: 6e 64 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  nd)..    {..    
0e30: 20 20 5f 64 61 74 65 74 69 6d 65 46 6f 72 6d 61    _datetimeForma
0e40: 74 20 3d 20 66 6d 74 3b 0d 0a 20 20 20 20 20 20  t = fmt;..      
0e50: 5f 64 61 74 65 74 69 6d 65 4b 69 6e 64 20 3d 20  _datetimeKind = 
0e60: 6b 69 6e 64 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  kind;..    }....
0e70: 20 20 20 20 23 72 65 67 69 6f 6e 20 55 54 46 2d      #region UTF-
0e80: 38 20 43 6f 6e 76 65 72 73 69 6f 6e 20 46 75 6e  8 Conversion Fun
0e90: 63 74 69 6f 6e 73 0d 0a 20 20 20 20 2f 2f 2f 20  ctions..    /// 
0ea0: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
0eb0: 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20 73 74  // Converts a st
0ec0: 72 69 6e 67 20 74 6f 20 61 20 55 54 46 2d 38 20  ring to a UTF-8 
0ed0: 65 6e 63 6f 64 65 64 20 62 79 74 65 20 61 72 72  encoded byte arr
0ee0: 61 79 20 73 69 7a 65 64 20 74 6f 20 69 6e 63 6c  ay sized to incl
0ef0: 75 64 65 20 61 20 6e 75 6c 6c 2d 74 65 72 6d 69  ude a null-termi
0f00: 6e 61 74 69 6e 67 20 63 68 61 72 61 63 74 65 72  nating character
0f10: 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ...    /// </sum
0f20: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  mary>..    /// <
0f30: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 73 6f 75 72  param name="sour
0f40: 63 65 54 65 78 74 22 3e 54 68 65 20 73 74 72 69  ceText">The stri
0f50: 6e 67 20 74 6f 20 63 6f 6e 76 65 72 74 20 74 6f  ng to convert to
0f60: 20 55 54 46 2d 38 3c 2f 70 61 72 61 6d 3e 0d 0a   UTF-8</param>..
0f70: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
0f80: 3e 41 20 62 79 74 65 20 61 72 72 61 79 20 63 6f  >A byte array co
0f90: 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 63 6f 6e  ntaining the con
0fa0: 76 65 72 74 65 64 20 73 74 72 69 6e 67 20 70 6c  verted string pl
0fb0: 75 73 20 61 6e 20 65 78 74 72 61 20 30 20 74 65  us an extra 0 te
0fc0: 72 6d 69 6e 61 74 69 6e 67 20 62 79 74 65 20 61  rminating byte a
0fd0: 74 20 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65  t the end of the
0fe0: 20 61 72 72 61 79 2e 3c 2f 72 65 74 75 72 6e 73   array.</returns
0ff0: 3e 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 73 74  >..    public st
1000: 61 74 69 63 20 62 79 74 65 5b 5d 20 54 6f 55 54  atic byte[] ToUT
1010: 46 38 28 73 74 72 69 6e 67 20 73 6f 75 72 63 65  F8(string source
1020: 54 65 78 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  Text)..    {..  
1030: 20 20 20 20 42 79 74 65 5b 5d 20 62 79 74 65 41      Byte[] byteA
1040: 72 72 61 79 3b 0d 0a 20 20 20 20 20 20 69 6e 74  rray;..      int
1050: 20 6e 6c 65 6e 20 3d 20 5f 75 74 66 38 2e 47 65   nlen = _utf8.Ge
1060: 74 42 79 74 65 43 6f 75 6e 74 28 73 6f 75 72 63  tByteCount(sourc
1070: 65 54 65 78 74 29 20 2b 20 31 3b 0d 0a 0d 0a 20  eText) + 1;.... 
1080: 20 20 20 20 20 62 79 74 65 41 72 72 61 79 20 3d       byteArray =
1090: 20 6e 65 77 20 62 79 74 65 5b 6e 6c 65 6e 5d 3b   new byte[nlen];
10a0: 0d 0a 20 20 20 20 20 20 6e 6c 65 6e 20 3d 20 5f  ..      nlen = _
10b0: 75 74 66 38 2e 47 65 74 42 79 74 65 73 28 73 6f  utf8.GetBytes(so
10c0: 75 72 63 65 54 65 78 74 2c 20 30 2c 20 73 6f 75  urceText, 0, sou
10d0: 72 63 65 54 65 78 74 2e 4c 65 6e 67 74 68 2c 20  rceText.Length, 
10e0: 62 79 74 65 41 72 72 61 79 2c 20 30 29 3b 0d 0a  byteArray, 0);..
10f0: 20 20 20 20 20 20 62 79 74 65 41 72 72 61 79 5b        byteArray[
1100: 6e 6c 65 6e 5d 20 3d 20 30 3b 0d 0a 0d 0a 20 20  nlen] = 0;....  
1110: 20 20 20 20 72 65 74 75 72 6e 20 62 79 74 65 41      return byteA
1120: 72 72 61 79 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  rray;..    }....
1130: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
1140: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65  >..    /// Conve
1150: 72 74 20 61 20 44 61 74 65 54 69 6d 65 20 74 6f  rt a DateTime to
1160: 20 61 20 55 54 46 2d 38 20 65 6e 63 6f 64 65 64   a UTF-8 encoded
1170: 2c 20 7a 65 72 6f 2d 74 65 72 6d 69 6e 61 74 65  , zero-terminate
1180: 64 20 62 79 74 65 20 61 72 72 61 79 2e 0d 0a 20  d byte array... 
1190: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
11a0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 6d 61  >..    /// <rema
11b0: 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68  rks>..    /// Th
11c0: 69 73 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 61  is function is a
11d0: 20 63 6f 6e 76 65 6e 69 65 6e 63 65 20 66 75 6e   convenience fun
11e0: 63 74 69 6f 6e 2c 20 77 68 69 63 68 20 66 69 72  ction, which fir
11f0: 73 74 20 63 61 6c 6c 73 20 54 6f 53 74 72 69 6e  st calls ToStrin
1200: 67 28 29 20 6f 6e 20 74 68 65 20 44 61 74 65 54  g() on the DateT
1210: 69 6d 65 2c 20 61 6e 64 20 74 68 65 6e 20 63 61  ime, and then ca
1220: 6c 6c 73 20 54 6f 55 54 46 38 28 29 20 77 69 74  lls ToUTF8() wit
1230: 68 20 74 68 65 0d 0a 20 20 20 20 2f 2f 2f 20 73  h the..    /// s
1240: 74 72 69 6e 67 20 72 65 73 75 6c 74 2e 0d 0a 20  tring result... 
1250: 20 20 20 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73     /// </remarks
1260: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
1270: 6d 20 6e 61 6d 65 3d 22 64 61 74 65 54 69 6d 65  m name="dateTime
1280: 56 61 6c 75 65 22 3e 54 68 65 20 44 61 74 65 54  Value">The DateT
1290: 69 6d 65 20 74 6f 20 63 6f 6e 76 65 72 74 2e 3c  ime to convert.<
12a0: 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  /param>..    ///
12b0: 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20 55 54   <returns>The UT
12c0: 46 2d 38 20 65 6e 63 6f 64 65 64 20 73 74 72 69  F-8 encoded stri
12d0: 6e 67 2c 20 69 6e 63 6c 75 64 69 6e 67 20 61 20  ng, including a 
12e0: 30 20 74 65 72 6d 69 6e 61 74 69 6e 67 20 62 79  0 terminating by
12f0: 74 65 20 61 74 20 74 68 65 20 65 6e 64 20 6f 66  te at the end of
1300: 20 74 68 65 20 61 72 72 61 79 2e 3c 2f 72 65 74   the array.</ret
1310: 75 72 6e 73 3e 0d 0a 20 20 20 20 70 75 62 6c 69  urns>..    publi
1320: 63 20 62 79 74 65 5b 5d 20 54 6f 55 54 46 38 28  c byte[] ToUTF8(
1330: 44 61 74 65 54 69 6d 65 20 64 61 74 65 54 69 6d  DateTime dateTim
1340: 65 56 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a  eValue)..    {..
1350: 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 55        return ToU
1360: 54 46 38 28 54 6f 53 74 72 69 6e 67 28 64 61 74  TF8(ToString(dat
1370: 65 54 69 6d 65 56 61 6c 75 65 29 29 3b 0d 0a 20  eTimeValue));.. 
1380: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20     }....    /// 
1390: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
13a0: 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20 55 54  // Converts a UT
13b0: 46 2d 38 20 65 6e 63 6f 64 65 64 20 49 6e 74 50  F-8 encoded IntP
13c0: 74 72 20 6f 66 20 74 68 65 20 73 70 65 63 69 66  tr of the specif
13d0: 69 65 64 20 6c 65 6e 67 74 68 20 69 6e 74 6f 20  ied length into 
13e0: 61 20 2e 4e 45 54 20 73 74 72 69 6e 67 0d 0a 20  a .NET string.. 
13f0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
1400: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
1410: 6d 20 6e 61 6d 65 3d 22 6e 61 74 69 76 65 73 74  m name="nativest
1420: 72 69 6e 67 22 3e 54 68 65 20 70 6f 69 6e 74 65  ring">The pointe
1430: 72 20 74 6f 20 74 68 65 20 6d 65 6d 6f 72 79 20  r to the memory 
1440: 77 68 65 72 65 20 74 68 65 20 55 54 46 2d 38 20  where the UTF-8 
1450: 73 74 72 69 6e 67 20 69 73 20 65 6e 63 6f 64 65  string is encode
1460: 64 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  d</param>..    /
1470: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
1480: 6e 61 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 22  nativestringlen"
1490: 3e 54 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 62  >The number of b
14a0: 79 74 65 73 20 74 6f 20 64 65 63 6f 64 65 3c 2f  ytes to decode</
14b0: 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  param>..    /// 
14c0: 3c 72 65 74 75 72 6e 73 3e 41 20 73 74 72 69 6e  <returns>A strin
14d0: 67 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65  g containing the
14e0: 20 74 72 61 6e 73 6c 61 74 65 64 20 63 68 61 72   translated char
14f0: 61 63 74 65 72 28 73 29 3c 2f 72 65 74 75 72 6e  acter(s)</return
1500: 73 3e 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 76  s>..    public v
1510: 69 72 74 75 61 6c 20 73 74 72 69 6e 67 20 54 6f  irtual string To
1520: 53 74 72 69 6e 67 28 49 6e 74 50 74 72 20 6e 61  String(IntPtr na
1530: 74 69 76 65 73 74 72 69 6e 67 2c 20 69 6e 74 20  tivestring, int 
1540: 6e 61 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 29  nativestringlen)
1550: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72  ..    {..      r
1560: 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69  eturn UTF8ToStri
1570: 6e 67 28 6e 61 74 69 76 65 73 74 72 69 6e 67 2c  ng(nativestring,
1580: 20 6e 61 74 69 76 65 73 74 72 69 6e 67 6c 65 6e   nativestringlen
1590: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
15a0: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
15b0: 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 73      /// Converts
15c0: 20 61 20 55 54 46 2d 38 20 65 6e 63 6f 64 65 64   a UTF-8 encoded
15d0: 20 49 6e 74 50 74 72 20 6f 66 20 74 68 65 20 73   IntPtr of the s
15e0: 70 65 63 69 66 69 65 64 20 6c 65 6e 67 74 68 20  pecified length 
15f0: 69 6e 74 6f 20 61 20 2e 4e 45 54 20 73 74 72 69  into a .NET stri
1600: 6e 67 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ng..    /// </su
1610: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
1620: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6e 61 74  <param name="nat
1630: 69 76 65 73 74 72 69 6e 67 22 3e 54 68 65 20 70  ivestring">The p
1640: 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 6d 65  ointer to the me
1650: 6d 6f 72 79 20 77 68 65 72 65 20 74 68 65 20 55  mory where the U
1660: 54 46 2d 38 20 73 74 72 69 6e 67 20 69 73 20 65  TF-8 string is e
1670: 6e 63 6f 64 65 64 3c 2f 70 61 72 61 6d 3e 0d 0a  ncoded</param>..
1680: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
1690: 61 6d 65 3d 22 6e 61 74 69 76 65 73 74 72 69 6e  ame="nativestrin
16a0: 67 6c 65 6e 22 3e 54 68 65 20 6e 75 6d 62 65 72  glen">The number
16b0: 20 6f 66 20 62 79 74 65 73 20 74 6f 20 64 65 63   of bytes to dec
16c0: 6f 64 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  ode</param>..   
16d0: 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 41 20   /// <returns>A 
16e0: 73 74 72 69 6e 67 20 63 6f 6e 74 61 69 6e 69 6e  string containin
16f0: 67 20 74 68 65 20 74 72 61 6e 73 6c 61 74 65 64  g the translated
1700: 20 63 68 61 72 61 63 74 65 72 28 73 29 3c 2f 72   character(s)</r
1710: 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 70 75 62  eturns>..    pub
1720: 6c 69 63 20 73 74 61 74 69 63 20 73 74 72 69 6e  lic static strin
1730: 67 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 49  g UTF8ToString(I
1740: 6e 74 50 74 72 20 6e 61 74 69 76 65 73 74 72 69  ntPtr nativestri
1750: 6e 67 2c 20 69 6e 74 20 6e 61 74 69 76 65 73 74  ng, int nativest
1760: 72 69 6e 67 6c 65 6e 29 0d 0a 20 20 20 20 7b 0d  ringlen)..    {.
1770: 0a 20 20 20 20 20 20 69 66 20 28 6e 61 74 69 76  .      if (nativ
1780: 65 73 74 72 69 6e 67 20 3d 3d 20 49 6e 74 50 74  estring == IntPt
1790: 72 2e 5a 65 72 6f 20 7c 7c 20 6e 61 74 69 76 65  r.Zero || native
17a0: 73 74 72 69 6e 67 6c 65 6e 20 3d 3d 20 30 29 20  stringlen == 0) 
17b0: 72 65 74 75 72 6e 20 53 74 72 69 6e 67 2e 45 6d  return String.Em
17c0: 70 74 79 3b 0d 0a 20 20 20 20 20 20 69 66 20 28  pty;..      if (
17d0: 6e 61 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 20  nativestringlen 
17e0: 3c 20 30 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20  < 0)..      {.. 
17f0: 20 20 20 20 20 20 20 6e 61 74 69 76 65 73 74 72         nativestr
1800: 69 6e 67 6c 65 6e 20 3d 20 30 3b 0d 0a 0d 0a 20  inglen = 0;.... 
1810: 20 20 20 20 20 20 20 77 68 69 6c 65 20 28 4d 61         while (Ma
1820: 72 73 68 61 6c 2e 52 65 61 64 42 79 74 65 28 6e  rshal.ReadByte(n
1830: 61 74 69 76 65 73 74 72 69 6e 67 2c 20 6e 61 74  ativestring, nat
1840: 69 76 65 73 74 72 69 6e 67 6c 65 6e 29 20 21 3d  ivestringlen) !=
1850: 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20 6e   0)..          n
1860: 61 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 2b 2b  ativestringlen++
1870: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ;....        if 
1880: 28 6e 61 74 69 76 65 73 74 72 69 6e 67 6c 65 6e  (nativestringlen
1890: 20 3d 3d 20 30 29 20 72 65 74 75 72 6e 20 53 74   == 0) return St
18a0: 72 69 6e 67 2e 45 6d 70 74 79 3b 0d 0a 20 20 20  ring.Empty;..   
18b0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 62 79     }....      by
18c0: 74 65 5b 5d 20 62 79 74 65 41 72 72 61 79 20 3d  te[] byteArray =
18d0: 20 6e 65 77 20 62 79 74 65 5b 6e 61 74 69 76 65   new byte[native
18e0: 73 74 72 69 6e 67 6c 65 6e 5d 3b 0d 0a 0d 0a 20  stringlen];.... 
18f0: 20 20 20 20 20 4d 61 72 73 68 61 6c 2e 43 6f 70       Marshal.Cop
1900: 79 28 6e 61 74 69 76 65 73 74 72 69 6e 67 2c 20  y(nativestring, 
1910: 62 79 74 65 41 72 72 61 79 2c 20 30 2c 20 6e 61  byteArray, 0, na
1920: 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 29 3b 0d  tivestringlen);.
1930: 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ...      return 
1940: 5f 75 74 66 38 2e 47 65 74 53 74 72 69 6e 67 28  _utf8.GetString(
1950: 62 79 74 65 41 72 72 61 79 2c 20 30 2c 20 6e 61  byteArray, 0, na
1960: 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 29 3b 0d  tivestringlen);.
1970: 0a 20 20 20 20 7d 0d 0a 0d 0a 0d 0a 20 20 20 20  .    }......    
1980: 23 65 6e 64 72 65 67 69 6f 6e 0d 0a 0d 0a 20 20  #endregion....  
1990: 20 20 23 72 65 67 69 6f 6e 20 44 61 74 65 54 69    #region DateTi
19a0: 6d 65 20 43 6f 6e 76 65 72 73 69 6f 6e 20 46 75  me Conversion Fu
19b0: 6e 63 74 69 6f 6e 73 0d 0a 20 20 20 20 2f 2f 2f  nctions..    ///
19c0: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
19d0: 2f 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20 73  /// Converts a s
19e0: 74 72 69 6e 67 20 69 6e 74 6f 20 61 20 44 61 74  tring into a Dat
19f0: 65 54 69 6d 65 2c 20 75 73 69 6e 67 20 74 68 65  eTime, using the
1a00: 20 63 75 72 72 65 6e 74 20 44 61 74 65 54 69 6d   current DateTim
1a10: 65 46 6f 72 6d 61 74 20 73 70 65 63 69 66 69 65  eFormat specifie
1a20: 64 20 66 6f 72 20 74 68 65 20 63 6f 6e 6e 65 63  d for the connec
1a30: 74 69 6f 6e 20 77 68 65 6e 20 69 74 20 77 61 73  tion when it was
1a40: 20 6f 70 65 6e 65 64 2e 0d 0a 20 20 20 20 2f 2f   opened...    //
1a50: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
1a60: 20 20 2f 2f 2f 20 3c 72 65 6d 61 72 6b 73 3e 0d    /// <remarks>.
1a70: 0a 20 20 20 20 2f 2f 2f 20 41 63 63 65 70 74 61  .    /// Accepta
1a80: 62 6c 65 20 49 53 4f 38 36 30 31 20 44 61 74 65  ble ISO8601 Date
1a90: 54 69 6d 65 20 66 6f 72 6d 61 74 73 20 61 72 65  Time formats are
1aa0: 3a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 6c 69 73 74  :..    /// <list
1ab0: 20 74 79 70 65 3d 22 62 75 6c 6c 65 74 22 3e 0d   type="bullet">.
1ac0: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
1ad0: 64 65 73 63 72 69 70 74 69 6f 6e 3e 54 48 48 6d  description>THHm
1ae0: 6d 73 73 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f  mssK</descriptio
1af0: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
1b00: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
1b10: 70 74 69 6f 6e 3e 54 48 48 6d 6d 4b 3c 2f 64 65  ption>THHmmK</de
1b20: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
1b30: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
1b40: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 48 48  ><description>HH
1b50: 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 4b 3c  :mm:ss.FFFFFFFK<
1b60: 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69  /description></i
1b70: 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69  tem>..    /// <i
1b80: 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e  tem><description
1b90: 3e 48 48 3a 6d 6d 3a 73 73 4b 3c 2f 64 65 73 63  >HH:mm:ssK</desc
1ba0: 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d  ription></item>.
1bb0: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
1bc0: 64 65 73 63 72 69 70 74 69 6f 6e 3e 48 48 3a 6d  description>HH:m
1bd0: 6d 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  mK</description>
1be0: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
1bf0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
1c00: 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 20 48  ion>yyyy-MM-dd H
1c10: 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 4b  H:mm:ss.FFFFFFFK
1c20: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
1c30: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
1c40: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
1c50: 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a  n>yyyy-MM-dd HH:
1c60: 6d 6d 3a 73 73 4b 3c 2f 64 65 73 63 72 69 70 74  mm:ssK</descript
1c70: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
1c80: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
1c90: 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d  ription>yyyy-MM-
1ca0: 64 64 20 48 48 3a 6d 6d 4b 3c 2f 64 65 73 63 72  dd HH:mmK</descr
1cb0: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
1cc0: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
1cd0: 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d  escription>yyyy-
1ce0: 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73 2e 46  MM-ddTHH:mm:ss.F
1cf0: 46 46 46 46 46 46 4b 3c 2f 64 65 73 63 72 69 70  FFFFFFK</descrip
1d00: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
1d10: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
1d20: 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d  cription>yyyy-MM
1d30: 2d 64 64 54 48 48 3a 6d 6d 4b 3c 2f 64 65 73 63  -ddTHH:mmK</desc
1d40: 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d  ription></item>.
1d50: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
1d60: 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79  description>yyyy
1d70: 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73 4b  -MM-ddTHH:mm:ssK
1d80: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
1d90: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
1da0: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
1db0: 6e 3e 79 79 79 79 4d 4d 64 64 48 48 6d 6d 73 73  n>yyyyMMddHHmmss
1dc0: 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  K</description><
1dd0: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
1de0: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
1df0: 6f 6e 3e 79 79 79 79 4d 4d 64 64 48 48 6d 6d 4b  on>yyyyMMddHHmmK
1e00: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
1e10: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
1e20: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
1e30: 6e 3e 79 79 79 79 4d 4d 64 64 54 48 48 6d 6d 73  n>yyyyMMddTHHmms
1e40: 73 46 46 46 46 46 46 46 4b 3c 2f 64 65 73 63 72  sFFFFFFFK</descr
1e50: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
1e60: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
1e70: 65 73 63 72 69 70 74 69 6f 6e 3e 54 48 48 6d 6d  escription>THHmm
1e80: 73 73 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  ss</description>
1e90: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
1ea0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
1eb0: 69 6f 6e 3e 54 48 48 6d 6d 3c 2f 64 65 73 63 72  ion>THHmm</descr
1ec0: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
1ed0: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
1ee0: 65 73 63 72 69 70 74 69 6f 6e 3e 48 48 3a 6d 6d  escription>HH:mm
1ef0: 3a 73 73 2e 46 46 46 46 46 46 46 3c 2f 64 65 73  :ss.FFFFFFF</des
1f00: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
1f10: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
1f20: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 48 48 3a  <description>HH:
1f30: 6d 6d 3a 73 73 3c 2f 64 65 73 63 72 69 70 74 69  mm:ss</descripti
1f40: 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20  on></item>..    
1f50: 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72  /// <item><descr
1f60: 69 70 74 69 6f 6e 3e 48 48 3a 6d 6d 3c 2f 64 65  iption>HH:mm</de
1f70: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
1f80: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
1f90: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79  ><description>yy
1fa0: 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73  yy-MM-dd HH:mm:s
1fb0: 73 2e 46 46 46 46 46 46 46 3c 2f 64 65 73 63 72  s.FFFFFFF</descr
1fc0: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
1fd0: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
1fe0: 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d  escription>yyyy-
1ff0: 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 3c 2f  MM-dd HH:mm:ss</
2000: 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74  description></it
2010: 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74  em>..    /// <it
2020: 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e  em><description>
2030: 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d  yyyy-MM-dd HH:mm
2040: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
2050: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
2060: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
2070: 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a  n>yyyy-MM-ddTHH:
2080: 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 3c 2f 64  mm:ss.FFFFFFF</d
2090: 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65  escription></ite
20a0: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  m>..    /// <ite
20b0: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79  m><description>y
20c0: 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3c  yyy-MM-ddTHH:mm<
20d0: 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69  /description></i
20e0: 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69  tem>..    /// <i
20f0: 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e  tem><description
2100: 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d  >yyyy-MM-ddTHH:m
2110: 6d 3a 73 73 3c 2f 64 65 73 63 72 69 70 74 69 6f  m:ss</descriptio
2120: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
2130: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
2140: 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64 64 48 48  ption>yyyyMMddHH
2150: 6d 6d 73 73 3c 2f 64 65 73 63 72 69 70 74 69 6f  mmss</descriptio
2160: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
2170: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
2180: 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64 64 48 48  ption>yyyyMMddHH
2190: 6d 6d 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  mm</description>
21a0: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
21b0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
21c0: 69 6f 6e 3e 79 79 79 79 4d 4d 64 64 54 48 48 6d  ion>yyyyMMddTHHm
21d0: 6d 73 73 46 46 46 46 46 46 46 3c 2f 64 65 73 63  mssFFFFFFF</desc
21e0: 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d  ription></item>.
21f0: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
2200: 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79  description>yyyy
2210: 2d 4d 4d 2d 64 64 3c 2f 64 65 73 63 72 69 70 74  -MM-dd</descript
2220: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
2230: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
2240: 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64 64  ription>yyyyMMdd
2250: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
2260: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
2270: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
2280: 6e 3e 79 79 2d 4d 4d 2d 64 64 3c 2f 64 65 73 63  n>yy-MM-dd</desc
2290: 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d  ription></item>.
22a0: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 6c 69 73 74 3e  .    /// </list>
22b0: 0d 0a 20 20 20 20 2f 2f 2f 20 49 66 20 74 68 65  ..    /// If the
22c0: 20 73 74 72 69 6e 67 20 63 61 6e 6e 6f 74 20 62   string cannot b
22d0: 65 20 6d 61 74 63 68 65 64 20 74 6f 20 6f 6e 65  e matched to one
22e0: 20 6f 66 20 74 68 65 20 61 62 6f 76 65 20 66 6f   of the above fo
22f0: 72 6d 61 74 73 2c 20 61 6e 20 65 78 63 65 70 74  rmats, an except
2300: 69 6f 6e 20 77 69 6c 6c 20 62 65 20 74 68 72 6f  ion will be thro
2310: 77 6e 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72  wn...    /// </r
2320: 65 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f  emarks>..    ///
2330: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 64 61   <param name="da
2340: 74 65 54 65 78 74 22 3e 54 68 65 20 73 74 72 69  teText">The stri
2350: 6e 67 20 63 6f 6e 74 61 69 6e 69 6e 67 20 65 69  ng containing ei
2360: 74 68 65 72 20 61 20 6c 6f 6e 67 20 69 6e 74 65  ther a long inte
2370: 67 65 72 20 6e 75 6d 62 65 72 20 6f 66 20 31 30  ger number of 10
2380: 30 2d 6e 61 6e 6f 73 65 63 6f 6e 64 20 75 6e 69  0-nanosecond uni
2390: 74 73 20 73 69 6e 63 65 0d 0a 20 20 20 20 2f 2f  ts since..    //
23a0: 2f 20 53 79 73 74 65 6d 2e 44 61 74 65 54 69 6d  / System.DateTim
23b0: 65 2e 4d 69 6e 56 61 6c 75 65 2c 20 61 20 4a 75  e.MinValue, a Ju
23c0: 6c 69 61 6e 20 64 61 79 20 64 6f 75 62 6c 65 2c  lian day double,
23d0: 20 61 6e 20 69 6e 74 65 67 65 72 20 6e 75 6d 62   an integer numb
23e0: 65 72 20 6f 66 20 73 65 63 6f 6e 64 73 20 73 69  er of seconds si
23f0: 6e 63 65 20 74 68 65 20 55 6e 69 78 20 65 70 6f  nce the Unix epo
2400: 63 68 2c 20 61 0d 0a 20 20 20 20 2f 2f 2f 20 63  ch, a..    /// c
2410: 75 6c 74 75 72 65 2d 69 6e 64 65 70 65 6e 64 65  ulture-independe
2420: 6e 74 20 66 6f 72 6d 61 74 74 65 64 20 64 61 74  nt formatted dat
2430: 65 20 61 6e 64 20 74 69 6d 65 20 73 74 72 69 6e  e and time strin
2440: 67 2c 20 61 20 66 6f 72 6d 61 74 74 65 64 20 64  g, a formatted d
2450: 61 74 65 20 61 6e 64 20 74 69 6d 65 20 73 74 72  ate and time str
2460: 69 6e 67 20 69 6e 20 74 68 65 20 63 75 72 72 65  ing in the curre
2470: 6e 74 0d 0a 20 20 20 20 2f 2f 2f 20 63 75 6c 74  nt..    /// cult
2480: 75 72 65 2c 20 6f 72 20 61 6e 20 49 53 4f 38 36  ure, or an ISO86
2490: 30 31 2d 66 6f 72 6d 61 74 20 73 74 72 69 6e 67  01-format string
24a0: 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  .</param>..    /
24b0: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 41 20 44 61  // <returns>A Da
24c0: 74 65 54 69 6d 65 20 76 61 6c 75 65 3c 2f 72 65  teTime value</re
24d0: 74 75 72 6e 73 3e 0d 0a 20 20 20 20 70 75 62 6c  turns>..    publ
24e0: 69 63 20 44 61 74 65 54 69 6d 65 20 54 6f 44 61  ic DateTime ToDa
24f0: 74 65 54 69 6d 65 28 73 74 72 69 6e 67 20 64 61  teTime(string da
2500: 74 65 54 65 78 74 29 0d 0a 20 20 20 20 7b 0d 0a  teText)..    {..
2510: 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 44        return ToD
2520: 61 74 65 54 69 6d 65 28 64 61 74 65 54 65 78 74  ateTime(dateText
2530: 2c 20 5f 64 61 74 65 74 69 6d 65 46 6f 72 6d 61  , _datetimeForma
2540: 74 2c 20 5f 64 61 74 65 74 69 6d 65 4b 69 6e 64  t, _datetimeKind
2550: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
2560: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
2570: 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 73      /// Converts
2580: 20 61 20 73 74 72 69 6e 67 20 69 6e 74 6f 20 61   a string into a
2590: 20 44 61 74 65 54 69 6d 65 2c 20 75 73 69 6e 67   DateTime, using
25a0: 20 74 68 65 20 73 70 65 63 69 66 69 65 64 20 44   the specified D
25b0: 61 74 65 54 69 6d 65 46 6f 72 6d 61 74 20 61 6e  ateTimeFormat an
25c0: 64 20 44 61 74 65 54 69 6d 65 4b 69 6e 64 2e 0d  d DateTimeKind..
25d0: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
25e0: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ry>..    /// <re
25f0: 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20  marks>..    /// 
2600: 41 63 63 65 70 74 61 62 6c 65 20 49 53 4f 38 36  Acceptable ISO86
2610: 30 31 20 44 61 74 65 54 69 6d 65 20 66 6f 72 6d  01 DateTime form
2620: 61 74 73 20 61 72 65 3a 0d 0a 20 20 20 20 2f 2f  ats are:..    //
2630: 2f 20 3c 6c 69 73 74 20 74 79 70 65 3d 22 62 75  / <list type="bu
2640: 6c 6c 65 74 22 3e 0d 0a 20 20 20 20 2f 2f 2f 20  llet">..    /// 
2650: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
2660: 6f 6e 3e 54 48 48 6d 6d 73 73 4b 3c 2f 64 65 73  on>THHmmssK</des
2670: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
2680: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
2690: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 54 48 48  <description>THH
26a0: 6d 6d 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e  mmK</description
26b0: 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f  ></item>..    //
26c0: 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70  / <item><descrip
26d0: 74 69 6f 6e 3e 48 48 3a 6d 6d 3a 73 73 2e 46 46  tion>HH:mm:ss.FF
26e0: 46 46 46 46 46 4b 3c 2f 64 65 73 63 72 69 70 74  FFFFFK</descript
26f0: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
2700: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
2710: 72 69 70 74 69 6f 6e 3e 48 48 3a 6d 6d 3a 73 73  ription>HH:mm:ss
2720: 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  K</description><
2730: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
2740: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
2750: 6f 6e 3e 48 48 3a 6d 6d 4b 3c 2f 64 65 73 63 72  on>HH:mmK</descr
2760: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
2770: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
2780: 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d  escription>yyyy-
2790: 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 2e 46  MM-dd HH:mm:ss.F
27a0: 46 46 46 46 46 46 4b 3c 2f 64 65 73 63 72 69 70  FFFFFFK</descrip
27b0: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
27c0: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
27d0: 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d  cription>yyyy-MM
27e0: 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 4b 3c 2f 64  -dd HH:mm:ssK</d
27f0: 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65  escription></ite
2800: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  m>..    /// <ite
2810: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79  m><description>y
2820: 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 4b  yyy-MM-dd HH:mmK
2830: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
2840: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
2850: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
2860: 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a  n>yyyy-MM-ddTHH:
2870: 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 4b 3c 2f  mm:ss.FFFFFFFK</
2880: 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74  description></it
2890: 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74  em>..    /// <it
28a0: 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e  em><description>
28b0: 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d  yyyy-MM-ddTHH:mm
28c0: 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  K</description><
28d0: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
28e0: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
28f0: 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48  on>yyyy-MM-ddTHH
2900: 3a 6d 6d 3a 73 73 4b 3c 2f 64 65 73 63 72 69 70  :mm:ssK</descrip
2910: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
2920: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
2930: 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64  cription>yyyyMMd
2940: 64 48 48 6d 6d 73 73 4b 3c 2f 64 65 73 63 72 69  dHHmmssK</descri
2950: 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20  ption></item>.. 
2960: 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65     /// <item><de
2970: 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d 4d  scription>yyyyMM
2980: 64 64 48 48 6d 6d 4b 3c 2f 64 65 73 63 72 69 70  ddHHmmK</descrip
2990: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
29a0: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
29b0: 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64  cription>yyyyMMd
29c0: 64 54 48 48 6d 6d 73 73 46 46 46 46 46 46 46 4b  dTHHmmssFFFFFFFK
29d0: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
29e0: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
29f0: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
2a00: 6e 3e 54 48 48 6d 6d 73 73 3c 2f 64 65 73 63 72  n>THHmmss</descr
2a10: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
2a20: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
2a30: 65 73 63 72 69 70 74 69 6f 6e 3e 54 48 48 6d 6d  escription>THHmm
2a40: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
2a50: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
2a60: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
2a70: 6e 3e 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46  n>HH:mm:ss.FFFFF
2a80: 46 46 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  FF</description>
2a90: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
2aa0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
2ab0: 69 6f 6e 3e 48 48 3a 6d 6d 3a 73 73 3c 2f 64 65  ion>HH:mm:ss</de
2ac0: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
2ad0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
2ae0: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 48 48  ><description>HH
2af0: 3a 6d 6d 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e  :mm</description
2b00: 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f  ></item>..    //
2b10: 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70  / <item><descrip
2b20: 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 20  tion>yyyy-MM-dd 
2b30: 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46  HH:mm:ss.FFFFFFF
2b40: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
2b50: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
2b60: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
2b70: 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a  n>yyyy-MM-dd HH:
2b80: 6d 6d 3a 73 73 3c 2f 64 65 73 63 72 69 70 74 69  mm:ss</descripti
2b90: 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20  on></item>..    
2ba0: 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72  /// <item><descr
2bb0: 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64  iption>yyyy-MM-d
2bc0: 64 20 48 48 3a 6d 6d 3c 2f 64 65 73 63 72 69 70  d HH:mm</descrip
2bd0: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
2be0: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
2bf0: 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d  cription>yyyy-MM
2c00: 2d 64 64 54 48 48 3a 6d 6d 3a 73 73 2e 46 46 46  -ddTHH:mm:ss.FFF
2c10: 46 46 46 46 3c 2f 64 65 73 63 72 69 70 74 69 6f  FFFF</descriptio
2c20: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
2c30: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
2c40: 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64  ption>yyyy-MM-dd
2c50: 54 48 48 3a 6d 6d 3c 2f 64 65 73 63 72 69 70 74  THH:mm</descript
2c60: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
2c70: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
2c80: 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d  ription>yyyy-MM-
2c90: 64 64 54 48 48 3a 6d 6d 3a 73 73 3c 2f 64 65 73  ddTHH:mm:ss</des
2ca0: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
2cb0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
2cc0: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
2cd0: 79 4d 4d 64 64 48 48 6d 6d 73 73 3c 2f 64 65 73  yMMddHHmmss</des
2ce0: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
2cf0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
2d00: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
2d10: 79 4d 4d 64 64 48 48 6d 6d 3c 2f 64 65 73 63 72  yMMddHHmm</descr
2d20: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
2d30: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
2d40: 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d  escription>yyyyM
2d50: 4d 64 64 54 48 48 6d 6d 73 73 46 46 46 46 46 46  MddTHHmmssFFFFFF
2d60: 46 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  F</description><
2d70: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
2d80: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
2d90: 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 3c 2f 64  on>yyyy-MM-dd</d
2da0: 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65  escription></ite
2db0: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  m>..    /// <ite
2dc0: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79  m><description>y
2dd0: 79 79 79 4d 4d 64 64 3c 2f 64 65 73 63 72 69 70  yyyMMdd</descrip
2de0: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
2df0: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
2e00: 63 72 69 70 74 69 6f 6e 3e 79 79 2d 4d 4d 2d 64  cription>yy-MM-d
2e10: 64 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  d</description><
2e20: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
2e30: 3c 2f 6c 69 73 74 3e 0d 0a 20 20 20 20 2f 2f 2f  </list>..    ///
2e40: 20 49 66 20 74 68 65 20 73 74 72 69 6e 67 20 63   If the string c
2e50: 61 6e 6e 6f 74 20 62 65 20 6d 61 74 63 68 65 64  annot be matched
2e60: 20 74 6f 20 6f 6e 65 20 6f 66 20 74 68 65 20 61   to one of the a
2e70: 62 6f 76 65 20 66 6f 72 6d 61 74 73 2c 20 61 6e  bove formats, an
2e80: 20 65 78 63 65 70 74 69 6f 6e 20 77 69 6c 6c 20   exception will 
2e90: 62 65 20 74 68 72 6f 77 6e 2e 0d 0a 20 20 20 20  be thrown...    
2ea0: 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73 3e 0d 0a  /// </remarks>..
2eb0: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
2ec0: 61 6d 65 3d 22 64 61 74 65 54 65 78 74 22 3e 54  ame="dateText">T
2ed0: 68 65 20 73 74 72 69 6e 67 20 63 6f 6e 74 61 69  he string contai
2ee0: 6e 69 6e 67 20 65 69 74 68 65 72 20 61 20 6c 6f  ning either a lo
2ef0: 6e 67 20 69 6e 74 65 67 65 72 20 6e 75 6d 62 65  ng integer numbe
2f00: 72 20 6f 66 20 31 30 30 2d 6e 61 6e 6f 73 65 63  r of 100-nanosec
2f10: 6f 6e 64 20 75 6e 69 74 73 20 73 69 6e 63 65 0d  ond units since.
2f20: 0a 20 20 20 20 2f 2f 2f 20 53 79 73 74 65 6d 2e  .    /// System.
2f30: 44 61 74 65 54 69 6d 65 2e 4d 69 6e 56 61 6c 75  DateTime.MinValu
2f40: 65 2c 20 61 20 4a 75 6c 69 61 6e 20 64 61 79 20  e, a Julian day 
2f50: 64 6f 75 62 6c 65 2c 20 61 6e 20 69 6e 74 65 67  double, an integ
2f60: 65 72 20 6e 75 6d 62 65 72 20 6f 66 20 73 65 63  er number of sec
2f70: 6f 6e 64 73 20 73 69 6e 63 65 20 74 68 65 20 55  onds since the U
2f80: 6e 69 78 20 65 70 6f 63 68 2c 20 61 0d 0a 20 20  nix epoch, a..  
2f90: 20 20 2f 2f 2f 20 63 75 6c 74 75 72 65 2d 69 6e    /// culture-in
2fa0: 64 65 70 65 6e 64 65 6e 74 20 66 6f 72 6d 61 74  dependent format
2fb0: 74 65 64 20 64 61 74 65 20 61 6e 64 20 74 69 6d  ted date and tim
2fc0: 65 20 73 74 72 69 6e 67 2c 20 61 20 66 6f 72 6d  e string, a form
2fd0: 61 74 74 65 64 20 64 61 74 65 20 61 6e 64 20 74  atted date and t
2fe0: 69 6d 65 20 73 74 72 69 6e 67 20 69 6e 20 74 68  ime string in th
2ff0: 65 20 63 75 72 72 65 6e 74 0d 0a 20 20 20 20 2f  e current..    /
3000: 2f 2f 20 63 75 6c 74 75 72 65 2c 20 6f 72 20 61  // culture, or a
3010: 6e 20 49 53 4f 38 36 30 31 2d 66 6f 72 6d 61 74  n ISO8601-format
3020: 20 73 74 72 69 6e 67 2e 3c 2f 70 61 72 61 6d 3e   string.</param>
3030: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  ..    /// <param
3040: 20 6e 61 6d 65 3d 22 66 6f 72 6d 61 74 22 3e 54   name="format">T
3050: 68 65 20 53 51 4c 69 74 65 44 61 74 65 46 6f 72  he SQLiteDateFor
3060: 6d 61 74 73 20 74 6f 20 75 73 65 2e 3c 2f 70 61  mats to use.</pa
3070: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ram>..    /// <p
3080: 61 72 61 6d 20 6e 61 6d 65 3d 22 6b 69 6e 64 22  aram name="kind"
3090: 3e 54 68 65 20 44 61 74 65 54 69 6d 65 4b 69 6e  >The DateTimeKin
30a0: 64 20 74 6f 20 75 73 65 2e 3c 2f 70 61 72 61 6d  d to use.</param
30b0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75  >..    /// <retu
30c0: 72 6e 73 3e 41 20 44 61 74 65 54 69 6d 65 20 76  rns>A DateTime v
30d0: 61 6c 75 65 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a  alue</returns>..
30e0: 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69      public stati
30f0: 63 20 44 61 74 65 54 69 6d 65 20 54 6f 44 61 74  c DateTime ToDat
3100: 65 54 69 6d 65 28 73 74 72 69 6e 67 20 64 61 74  eTime(string dat
3110: 65 54 65 78 74 2c 20 53 51 4c 69 74 65 44 61 74  eText, SQLiteDat
3120: 65 46 6f 72 6d 61 74 73 20 66 6f 72 6d 61 74 2c  eFormats format,
3130: 20 44 61 74 65 54 69 6d 65 4b 69 6e 64 20 6b 69   DateTimeKind ki
3140: 6e 64 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  nd)..    {..    
3150: 20 20 20 20 73 77 69 74 63 68 20 28 66 6f 72 6d      switch (form
3160: 61 74 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  at)..        {..
3170: 20 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65              case
3180: 20 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61   SQLiteDateForma
3190: 74 73 2e 54 69 63 6b 73 3a 0d 0a 20 20 20 20 20  ts.Ticks:..     
31a0: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
31b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
31c0: 20 20 72 65 74 75 72 6e 20 6e 65 77 20 44 61 74    return new Dat
31d0: 65 54 69 6d 65 28 43 6f 6e 76 65 72 74 2e 54 6f  eTime(Convert.To
31e0: 49 6e 74 36 34 28 0d 0a 20 20 20 20 20 20 20 20  Int64(..        
31f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3200: 64 61 74 65 54 65 78 74 2c 20 43 75 6c 74 75 72  dateText, Cultur
3210: 65 49 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43  eInfo.InvariantC
3220: 75 6c 74 75 72 65 29 2c 20 6b 69 6e 64 29 3b 0d  ulture), kind);.
3230: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3240: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
3250: 63 61 73 65 20 53 51 4c 69 74 65 44 61 74 65 46  case SQLiteDateF
3260: 6f 72 6d 61 74 73 2e 4a 75 6c 69 61 6e 44 61 79  ormats.JulianDay
3270: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  :..             
3280: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
3290: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
32a0: 20 54 6f 44 61 74 65 54 69 6d 65 28 43 6f 6e 76   ToDateTime(Conv
32b0: 65 72 74 2e 54 6f 44 6f 75 62 6c 65 28 0d 0a 20  ert.ToDouble(.. 
32c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
32d0: 20 20 20 20 20 20 20 64 61 74 65 54 65 78 74 2c         dateText,
32e0: 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76   CultureInfo.Inv
32f0: 61 72 69 61 6e 74 43 75 6c 74 75 72 65 29 2c 20  ariantCulture), 
3300: 6b 69 6e 64 29 3b 0d 0a 20 20 20 20 20 20 20 20  kind);..        
3310: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
3320: 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 69         case SQLi
3330: 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 55 6e  teDateFormats.Un
3340: 69 78 45 70 6f 63 68 3a 0d 0a 20 20 20 20 20 20  ixEpoch:..      
3350: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
3360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3370: 20 72 65 74 75 72 6e 20 44 61 74 65 54 69 6d 65   return DateTime
3380: 2e 53 70 65 63 69 66 79 4b 69 6e 64 28 0d 0a 20  .SpecifyKind(.. 
3390: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
33a0: 20 20 20 20 20 20 20 55 6e 69 78 45 70 6f 63 68         UnixEpoch
33b0: 2e 41 64 64 53 65 63 6f 6e 64 73 28 43 6f 6e 76  .AddSeconds(Conv
33c0: 65 72 74 2e 54 6f 49 6e 74 33 32 28 0d 0a 20 20  ert.ToInt32(..  
33d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
33e0: 20 20 20 20 20 20 64 61 74 65 54 65 78 74 2c 20        dateText, 
33f0: 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61  CultureInfo.Inva
3400: 72 69 61 6e 74 43 75 6c 74 75 72 65 29 29 2c 20  riantCulture)), 
3410: 6b 69 6e 64 29 3b 0d 0a 20 20 20 20 20 20 20 20  kind);..        
3420: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
3430: 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 69         case SQLi
3440: 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 49 6e  teDateFormats.In
3450: 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65 3a 0d  variantCulture:.
3460: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3470: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
3480: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 44          return D
3490: 61 74 65 54 69 6d 65 2e 53 70 65 63 69 66 79 4b  ateTime.SpecifyK
34a0: 69 6e 64 28 44 61 74 65 54 69 6d 65 2e 50 61 72  ind(DateTime.Par
34b0: 73 65 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  se(..           
34c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 64 61 74               dat
34d0: 65 54 65 78 74 2c 20 44 61 74 65 54 69 6d 65 46  eText, DateTimeF
34e0: 6f 72 6d 61 74 49 6e 66 6f 2e 49 6e 76 61 72 69  ormatInfo.Invari
34f0: 61 6e 74 49 6e 66 6f 2c 0d 0a 20 20 20 20 20 20  antInfo,..      
3500: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3510: 20 20 6b 69 6e 64 20 3d 3d 20 44 61 74 65 54 69    kind == DateTi
3520: 6d 65 4b 69 6e 64 2e 55 74 63 20 3f 0d 0a 20 20  meKind.Utc ?..  
3530: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3540: 20 20 20 20 20 20 20 20 20 20 44 61 74 65 54 69            DateTi
3550: 6d 65 53 74 79 6c 65 73 2e 41 64 6a 75 73 74 54  meStyles.AdjustT
3560: 6f 55 6e 69 76 65 72 73 61 6c 20 3a 0d 0a 20 20  oUniversal :..  
3570: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3580: 20 20 20 20 20 20 20 20 20 20 44 61 74 65 54 69            DateTi
3590: 6d 65 53 74 79 6c 65 73 2e 4e 6f 6e 65 29 2c 0d  meStyles.None),.
35a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
35b0: 20 20 20 20 20 20 20 20 20 6b 69 6e 64 29 3b 0d           kind);.
35c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
35d0: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
35e0: 63 61 73 65 20 53 51 4c 69 74 65 44 61 74 65 46  case SQLiteDateF
35f0: 6f 72 6d 61 74 73 2e 43 75 72 72 65 6e 74 43 75  ormats.CurrentCu
3600: 6c 74 75 72 65 3a 0d 0a 20 20 20 20 20 20 20 20  lture:..        
3610: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
3620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72                 r
3630: 65 74 75 72 6e 20 44 61 74 65 54 69 6d 65 2e 53  eturn DateTime.S
3640: 70 65 63 69 66 79 4b 69 6e 64 28 44 61 74 65 54  pecifyKind(DateT
3650: 69 6d 65 2e 50 61 72 73 65 28 0d 0a 20 20 20 20  ime.Parse(..    
3660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3670: 20 20 20 20 64 61 74 65 54 65 78 74 2c 20 44 61      dateText, Da
3680: 74 65 54 69 6d 65 46 6f 72 6d 61 74 49 6e 66 6f  teTimeFormatInfo
3690: 2e 43 75 72 72 65 6e 74 49 6e 66 6f 2c 0d 0a 20  .CurrentInfo,.. 
36a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
36b0: 20 20 20 20 20 20 20 6b 69 6e 64 20 3d 3d 20 44         kind == D
36c0: 61 74 65 54 69 6d 65 4b 69 6e 64 2e 55 74 63 20  ateTimeKind.Utc 
36d0: 3f 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ?..             
36e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 44                 D
36f0: 61 74 65 54 69 6d 65 53 74 79 6c 65 73 2e 41 64  ateTimeStyles.Ad
3700: 6a 75 73 74 54 6f 55 6e 69 76 65 72 73 61 6c 20  justToUniversal 
3710: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  :..             
3720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 44                 D
3730: 61 74 65 54 69 6d 65 53 74 79 6c 65 73 2e 4e 6f  ateTimeStyles.No
3740: 6e 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20  ne),..          
3750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6b 69                ki
3760: 6e 64 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  nd);..          
3770: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
3780: 20 20 20 20 20 64 65 66 61 75 6c 74 3a 20 2f 2a       default: /*
3790: 20 49 53 4f 2d 38 36 30 31 20 2a 2f 0d 0a 20 20   ISO-8601 */..  
37a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d                {.
37b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
37c0: 20 20 20 20 20 72 65 74 75 72 6e 20 44 61 74 65       return Date
37d0: 54 69 6d 65 2e 53 70 65 63 69 66 79 4b 69 6e 64  Time.SpecifyKind
37e0: 28 44 61 74 65 54 69 6d 65 2e 50 61 72 73 65 45  (DateTime.ParseE
37f0: 78 61 63 74 28 0d 0a 20 20 20 20 20 20 20 20 20  xact(..         
3800: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64                 d
3810: 61 74 65 54 65 78 74 2c 20 5f 64 61 74 65 74 69  ateText, _dateti
3820: 6d 65 46 6f 72 6d 61 74 73 2c 0d 0a 20 20 20 20  meFormats,..    
3830: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3840: 20 20 20 20 44 61 74 65 54 69 6d 65 46 6f 72 6d      DateTimeForm
3850: 61 74 49 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74  atInfo.Invariant
3860: 49 6e 66 6f 2c 0d 0a 20 20 20 20 20 20 20 20 20  Info,..         
3870: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6b                 k
3880: 69 6e 64 20 3d 3d 20 44 61 74 65 54 69 6d 65 4b  ind == DateTimeK
3890: 69 6e 64 2e 55 74 63 20 3f 0d 0a 20 20 20 20 20  ind.Utc ?..     
38a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
38b0: 20 20 20 20 20 20 20 44 61 74 65 54 69 6d 65 53         DateTimeS
38c0: 74 79 6c 65 73 2e 41 64 6a 75 73 74 54 6f 55 6e  tyles.AdjustToUn
38d0: 69 76 65 72 73 61 6c 20 3a 0d 0a 20 20 20 20 20  iversal :..     
38e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
38f0: 20 20 20 20 20 20 20 44 61 74 65 54 69 6d 65 53         DateTimeS
3900: 74 79 6c 65 73 2e 4e 6f 6e 65 29 2c 0d 0a 20 20  tyles.None),..  
3910: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3920: 20 20 20 20 20 20 6b 69 6e 64 29 3b 0d 0a 20 20        kind);..  
3930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d                }.
3940: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
3950: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  }....    /// <su
3960: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
3970: 43 6f 6e 76 65 72 74 73 20 61 20 6a 75 6c 69 61  Converts a julia
3980: 6e 64 61 79 20 76 61 6c 75 65 20 69 6e 74 6f 20  nday value into 
3990: 61 20 44 61 74 65 54 69 6d 65 0d 0a 20 20 20 20  a DateTime..    
39a0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
39b0: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
39c0: 61 6d 65 3d 22 6a 75 6c 69 61 6e 44 61 79 22 3e  ame="julianDay">
39d0: 54 68 65 20 76 61 6c 75 65 20 74 6f 20 63 6f 6e  The value to con
39e0: 76 65 72 74 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  vert</param>..  
39f0: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 41    /// <returns>A
3a00: 20 2e 4e 45 54 20 44 61 74 65 54 69 6d 65 3c 2f   .NET DateTime</
3a10: 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 70 75  returns>..    pu
3a20: 62 6c 69 63 20 44 61 74 65 54 69 6d 65 20 54 6f  blic DateTime To
3a30: 44 61 74 65 54 69 6d 65 28 64 6f 75 62 6c 65 20  DateTime(double 
3a40: 6a 75 6c 69 61 6e 44 61 79 29 0d 0a 20 20 20 20  julianDay)..    
3a50: 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  {..      return 
3a60: 54 6f 44 61 74 65 54 69 6d 65 28 6a 75 6c 69 61  ToDateTime(julia
3a70: 6e 44 61 79 2c 20 5f 64 61 74 65 74 69 6d 65 4b  nDay, _datetimeK
3a80: 69 6e 64 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  ind);..    }....
3a90: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
3aa0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65  >..    /// Conve
3ab0: 72 74 73 20 61 20 6a 75 6c 69 61 6e 64 61 79 20  rts a julianday 
3ac0: 76 61 6c 75 65 20 69 6e 74 6f 20 61 20 44 61 74  value into a Dat
3ad0: 65 54 69 6d 65 0d 0a 20 20 20 20 2f 2f 2f 20 3c  eTime..    /// <
3ae0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  /summary>..    /
3af0: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
3b00: 6a 75 6c 69 61 6e 44 61 79 22 3e 54 68 65 20 76  julianDay">The v
3b10: 61 6c 75 65 20 74 6f 20 63 6f 6e 76 65 72 74 3c  alue to convert<
3b20: 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  /param>..    ///
3b30: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6b 69   <param name="ki
3b40: 6e 64 22 3e 54 68 65 20 44 61 74 65 54 69 6d 65  nd">The DateTime
3b50: 4b 69 6e 64 20 74 6f 20 75 73 65 2e 3c 2f 70 61  Kind to use.</pa
3b60: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72  ram>..    /// <r
3b70: 65 74 75 72 6e 73 3e 41 20 2e 4e 45 54 20 44 61  eturns>A .NET Da
3b80: 74 65 54 69 6d 65 3c 2f 72 65 74 75 72 6e 73 3e  teTime</returns>
3b90: 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 73 74 61  ..    public sta
3ba0: 74 69 63 20 44 61 74 65 54 69 6d 65 20 54 6f 44  tic DateTime ToD
3bb0: 61 74 65 54 69 6d 65 28 64 6f 75 62 6c 65 20 6a  ateTime(double j
3bc0: 75 6c 69 61 6e 44 61 79 2c 20 44 61 74 65 54 69  ulianDay, DateTi
3bd0: 6d 65 4b 69 6e 64 20 6b 69 6e 64 29 0d 0a 20 20  meKind kind)..  
3be0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74    {..        ret
3bf0: 75 72 6e 20 44 61 74 65 54 69 6d 65 2e 53 70 65  urn DateTime.Spe
3c00: 63 69 66 79 4b 69 6e 64 28 0d 0a 20 20 20 20 20  cifyKind(..     
3c10: 20 20 20 20 20 20 20 44 61 74 65 54 69 6d 65 2e         DateTime.
3c20: 46 72 6f 6d 4f 41 44 61 74 65 28 6a 75 6c 69 61  FromOADate(julia
3c30: 6e 44 61 79 20 2d 20 4f 6c 65 41 75 74 6f 6d 61  nDay - OleAutoma
3c40: 74 69 6f 6e 45 70 6f 63 68 41 73 4a 75 6c 69 61  tionEpochAsJulia
3c50: 6e 44 61 79 29 2c 20 6b 69 6e 64 29 3b 0d 0a 20  nDay), kind);.. 
3c60: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20     }....    /// 
3c70: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
3c80: 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20 44 61  // Converts a Da
3c90: 74 65 54 69 6d 65 20 73 74 72 75 63 74 20 74 6f  teTime struct to
3ca0: 20 61 20 4a 75 6c 69 61 6e 44 61 79 20 64 6f 75   a JulianDay dou
3cb0: 62 6c 65 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ble..    /// </s
3cc0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
3cd0: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 76 61   <param name="va
3ce0: 6c 75 65 22 3e 54 68 65 20 44 61 74 65 54 69 6d  lue">The DateTim
3cf0: 65 20 74 6f 20 63 6f 6e 76 65 72 74 3c 2f 70 61  e to convert</pa
3d00: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72  ram>..    /// <r
3d10: 65 74 75 72 6e 73 3e 54 68 65 20 4a 75 6c 69 61  eturns>The Julia
3d20: 6e 44 61 79 20 76 61 6c 75 65 20 74 68 65 20 44  nDay value the D
3d30: 61 74 65 74 69 6d 65 20 72 65 70 72 65 73 65 6e  atetime represen
3d40: 74 73 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20  ts</returns>..  
3d50: 20 20 70 75 62 6c 69 63 20 73 74 61 74 69 63 20    public static 
3d60: 64 6f 75 62 6c 65 20 54 6f 4a 75 6c 69 61 6e 44  double ToJulianD
3d70: 61 79 28 44 61 74 65 54 69 6d 65 20 76 61 6c 75  ay(DateTime valu
3d80: 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  e)..    {..     
3d90: 20 72 65 74 75 72 6e 20 76 61 6c 75 65 2e 54 6f   return value.To
3da0: 4f 41 44 61 74 65 28 29 20 2b 20 4f 6c 65 41 75  OADate() + OleAu
3db0: 74 6f 6d 61 74 69 6f 6e 45 70 6f 63 68 41 73 4a  tomationEpochAsJ
3dc0: 75 6c 69 61 6e 44 61 79 3b 0d 0a 20 20 20 20 7d  ulianDay;..    }
3dd0: 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d  ....    /// <sum
3de0: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43  mary>..    /// C
3df0: 6f 6e 76 65 72 74 73 20 61 20 44 61 74 65 54 69  onverts a DateTi
3e00: 6d 65 20 73 74 72 75 63 74 20 74 6f 20 74 68 65  me struct to the
3e10: 20 77 68 6f 6c 65 20 6e 75 6d 62 65 72 20 6f 66   whole number of
3e20: 20 73 65 63 6f 6e 64 73 20 73 69 6e 63 65 20 74   seconds since t
3e30: 68 65 0d 0a 20 20 20 20 2f 2f 2f 20 55 6e 69 78  he..    /// Unix
3e40: 20 65 70 6f 63 68 2e 0d 0a 20 20 20 20 2f 2f 2f   epoch...    ///
3e50: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20   </summary>..   
3e60: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
3e70: 3d 22 76 61 6c 75 65 22 3e 54 68 65 20 44 61 74  ="value">The Dat
3e80: 65 54 69 6d 65 20 74 6f 20 63 6f 6e 76 65 72 74  eTime to convert
3e90: 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f  </param>..    //
3ea0: 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20 77  / <returns>The w
3eb0: 68 6f 6c 65 20 6e 75 6d 62 65 72 20 6f 66 20 73  hole number of s
3ec0: 65 63 6f 6e 64 73 20 73 69 6e 63 65 20 74 68 65  econds since the
3ed0: 20 55 6e 69 78 20 65 70 6f 63 68 3c 2f 72 65 74   Unix epoch</ret
3ee0: 75 72 6e 73 3e 0d 0a 20 20 20 20 70 75 62 6c 69  urns>..    publi
3ef0: 63 20 73 74 61 74 69 63 20 6c 6f 6e 67 20 54 6f  c static long To
3f00: 55 6e 69 78 45 70 6f 63 68 28 44 61 74 65 54 69  UnixEpoch(DateTi
3f10: 6d 65 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b  me value)..    {
3f20: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
3f30: 20 28 76 61 6c 75 65 2e 53 75 62 74 72 61 63 74   (value.Subtract
3f40: 28 55 6e 69 78 45 70 6f 63 68 29 2e 54 69 63 6b  (UnixEpoch).Tick
3f50: 73 20 2f 20 54 69 6d 65 53 70 61 6e 2e 54 69 63  s / TimeSpan.Tic
3f60: 6b 73 50 65 72 53 65 63 6f 6e 64 29 3b 0d 0a 20  ksPerSecond);.. 
3f70: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20     }....    /// 
3f80: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
3f90: 2f 2f 20 52 65 74 75 72 6e 73 20 74 68 65 20 64  // Returns the d
3fa0: 65 66 61 75 6c 74 20 44 61 74 65 54 69 6d 65 20  efault DateTime 
3fb0: 66 6f 72 6d 61 74 20 73 74 72 69 6e 67 20 74 6f  format string to
3fc0: 20 75 73 65 20 66 6f 72 20 74 68 65 20 73 70 65   use for the spe
3fd0: 63 69 66 69 65 64 0d 0a 20 20 20 20 2f 2f 2f 20  cified..    /// 
3fe0: 44 61 74 65 54 69 6d 65 4b 69 6e 64 2e 0d 0a 20  DateTimeKind... 
3ff0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
4000: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
4010: 6d 20 6e 61 6d 65 3d 22 6b 69 6e 64 22 3e 54 68  m name="kind">Th
4020: 65 20 44 61 74 65 54 69 6d 65 4b 69 6e 64 20 74  e DateTimeKind t
4030: 6f 20 75 73 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a  o use.</param>..
4040: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
4050: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 64  >..    /// The d
4060: 65 66 61 75 6c 74 20 44 61 74 65 54 69 6d 65 20  efault DateTime 
4070: 66 6f 72 6d 61 74 20 73 74 72 69 6e 67 20 74 6f  format string to
4080: 20 75 73 65 20 66 6f 72 20 74 68 65 20 73 70 65   use for the spe
4090: 63 69 66 69 65 64 20 44 61 74 65 54 69 6d 65 4b  cified DateTimeK
40a0: 69 6e 64 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ind...    /// </
40b0: 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 70 72  returns>..    pr
40c0: 69 76 61 74 65 20 73 74 61 74 69 63 20 73 74 72  ivate static str
40d0: 69 6e 67 20 47 65 74 44 61 74 65 54 69 6d 65 4b  ing GetDateTimeK
40e0: 69 6e 64 46 6f 72 6d 61 74 28 44 61 74 65 54 69  indFormat(DateTi
40f0: 6d 65 4b 69 6e 64 20 6b 69 6e 64 29 0d 0a 20 20  meKind kind)..  
4100: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74    {..        ret
4110: 75 72 6e 20 28 6b 69 6e 64 20 3d 3d 20 44 61 74  urn (kind == Dat
4120: 65 54 69 6d 65 4b 69 6e 64 2e 55 74 63 29 20 3f  eTimeKind.Utc) ?
4130: 20 5f 64 61 74 65 74 69 6d 65 46 6f 72 6d 61 74   _datetimeFormat
4140: 55 74 63 20 3a 20 5f 64 61 74 65 74 69 6d 65 46  Utc : _datetimeF
4150: 6f 72 6d 61 74 4c 6f 63 61 6c 3b 0d 0a 20 20 20  ormatLocal;..   
4160: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73   }....    /// <s
4170: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
4180: 20 43 6f 6e 76 65 72 74 73 20 61 20 44 61 74 65   Converts a Date
4190: 54 69 6d 65 20 74 6f 20 61 20 73 74 72 69 6e 67  Time to a string
41a0: 20 76 61 6c 75 65 2c 20 75 73 69 6e 67 20 74 68   value, using th
41b0: 65 20 63 75 72 72 65 6e 74 20 44 61 74 65 54 69  e current DateTi
41c0: 6d 65 46 6f 72 6d 61 74 20 73 70 65 63 69 66 69  meFormat specifi
41d0: 65 64 20 66 6f 72 20 74 68 65 20 63 6f 6e 6e 65  ed for the conne
41e0: 63 74 69 6f 6e 20 77 68 65 6e 20 69 74 20 77 61  ction when it wa
41f0: 73 20 6f 70 65 6e 65 64 2e 0d 0a 20 20 20 20 2f  s opened...    /
4200: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
4210: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
4220: 6d 65 3d 22 64 61 74 65 56 61 6c 75 65 22 3e 54  me="dateValue">T
4230: 68 65 20 44 61 74 65 54 69 6d 65 20 76 61 6c 75  he DateTime valu
4240: 65 20 74 6f 20 63 6f 6e 76 65 72 74 3c 2f 70 61  e to convert</pa
4250: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72  ram>..    /// <r
4260: 65 74 75 72 6e 73 3e 45 69 74 68 65 72 20 61 20  eturns>Either a 
4270: 73 74 72 69 6e 67 20 63 6f 6e 74 61 69 6e 69 6e  string containin
4280: 67 20 74 68 65 20 6c 6f 6e 67 20 69 6e 74 65 67  g the long integ
4290: 65 72 20 6e 75 6d 62 65 72 20 6f 66 20 31 30 30  er number of 100
42a0: 2d 6e 61 6e 6f 73 65 63 6f 6e 64 20 75 6e 69 74  -nanosecond unit
42b0: 73 20 73 69 6e 63 65 20 53 79 73 74 65 6d 2e 44  s since System.D
42c0: 61 74 65 54 69 6d 65 2e 4d 69 6e 56 61 6c 75 65  ateTime.MinValue
42d0: 2c 20 61 0d 0a 20 20 20 20 2f 2f 2f 20 4a 75 6c  , a..    /// Jul
42e0: 69 61 6e 20 64 61 79 20 64 6f 75 62 6c 65 2c 20  ian day double, 
42f0: 61 6e 20 69 6e 74 65 67 65 72 20 6e 75 6d 62 65  an integer numbe
4300: 72 20 6f 66 20 73 65 63 6f 6e 64 73 20 73 69 6e  r of seconds sin
4310: 63 65 20 74 68 65 20 55 6e 69 78 20 65 70 6f 63  ce the Unix epoc
4320: 68 2c 20 61 20 63 75 6c 74 75 72 65 2d 69 6e 64  h, a culture-ind
4330: 65 70 65 6e 64 65 6e 74 20 66 6f 72 6d 61 74 74  ependent formatt
4340: 65 64 20 64 61 74 65 20 61 6e 64 20 74 69 6d 65  ed date and time
4350: 0d 0a 20 20 20 20 2f 2f 2f 20 73 74 72 69 6e 67  ..    /// string
4360: 2c 20 61 20 66 6f 72 6d 61 74 74 65 64 20 64 61  , a formatted da
4370: 74 65 20 61 6e 64 20 74 69 6d 65 20 73 74 72 69  te and time stri
4380: 6e 67 20 69 6e 20 74 68 65 20 63 75 72 72 65 6e  ng in the curren
4390: 74 20 63 75 6c 74 75 72 65 2c 20 6f 72 20 61 6e  t culture, or an
43a0: 20 49 53 4f 38 36 30 31 2d 66 6f 72 6d 61 74 20   ISO8601-format 
43b0: 64 61 74 65 2f 74 69 6d 65 20 73 74 72 69 6e 67  date/time string
43c0: 2e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20  .</returns>..   
43d0: 20 70 75 62 6c 69 63 20 73 74 72 69 6e 67 20 54   public string T
43e0: 6f 53 74 72 69 6e 67 28 44 61 74 65 54 69 6d 65  oString(DateTime
43f0: 20 64 61 74 65 56 61 6c 75 65 29 0d 0a 20 20 20   dateValue)..   
4400: 20 7b 0d 0a 20 20 20 20 20 20 20 20 73 77 69 74   {..        swit
4410: 63 68 20 28 5f 64 61 74 65 74 69 6d 65 46 6f 72  ch (_datetimeFor
4420: 6d 61 74 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d  mat)..        {.
4430: 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 61 73  .            cas
4440: 65 20 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d  e SQLiteDateForm
4450: 61 74 73 2e 54 69 63 6b 73 3a 0d 0a 20 20 20 20  ats.Ticks:..    
4460: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
4470: 72 6e 20 64 61 74 65 56 61 6c 75 65 2e 54 69 63  rn dateValue.Tic
4480: 6b 73 2e 54 6f 53 74 72 69 6e 67 28 43 75 6c 74  ks.ToString(Cult
4490: 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72 69 61 6e  ureInfo.Invarian
44a0: 74 43 75 6c 74 75 72 65 29 3b 0d 0a 20 20 20 20  tCulture);..    
44b0: 20 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c          case SQL
44c0: 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 4a  iteDateFormats.J
44d0: 75 6c 69 61 6e 44 61 79 3a 0d 0a 20 20 20 20 20  ulianDay:..     
44e0: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
44f0: 6e 20 54 6f 4a 75 6c 69 61 6e 44 61 79 28 64 61  n ToJulianDay(da
4500: 74 65 56 61 6c 75 65 29 2e 54 6f 53 74 72 69 6e  teValue).ToStrin
4510: 67 28 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e  g(CultureInfo.In
4520: 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65 29 3b  variantCulture);
4530: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 63 61  ..            ca
4540: 73 65 20 53 51 4c 69 74 65 44 61 74 65 46 6f 72  se SQLiteDateFor
4550: 6d 61 74 73 2e 55 6e 69 78 45 70 6f 63 68 3a 0d  mats.UnixEpoch:.
4560: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
4570: 20 72 65 74 75 72 6e 20 28 28 6c 6f 6e 67 29 28   return ((long)(
4580: 64 61 74 65 56 61 6c 75 65 2e 53 75 62 74 72 61  dateValue.Subtra
4590: 63 74 28 55 6e 69 78 45 70 6f 63 68 29 2e 54 69  ct(UnixEpoch).Ti
45a0: 63 6b 73 20 2f 20 54 69 6d 65 53 70 61 6e 2e 54  cks / TimeSpan.T
45b0: 69 63 6b 73 50 65 72 53 65 63 6f 6e 64 29 29 2e  icksPerSecond)).
45c0: 54 6f 53 74 72 69 6e 67 28 29 3b 0d 0a 20 20 20  ToString();..   
45d0: 20 20 20 20 20 20 20 20 20 63 61 73 65 20 53 51           case SQ
45e0: 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e  LiteDateFormats.
45f0: 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65  InvariantCulture
4600: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  :..             
4610: 20 20 20 72 65 74 75 72 6e 20 64 61 74 65 56 61     return dateVa
4620: 6c 75 65 2e 54 6f 53 74 72 69 6e 67 28 46 75 6c  lue.ToString(Ful
4630: 6c 46 6f 72 6d 61 74 2c 20 43 75 6c 74 75 72 65  lFormat, Culture
4640: 49 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75  Info.InvariantCu
4650: 6c 74 75 72 65 29 3b 0d 0a 20 20 20 20 20 20 20  lture);..       
4660: 20 20 20 20 20 63 61 73 65 20 53 51 4c 69 74 65       case SQLite
4670: 44 61 74 65 46 6f 72 6d 61 74 73 2e 43 75 72 72  DateFormats.Curr
4680: 65 6e 74 43 75 6c 74 75 72 65 3a 0d 0a 20 20 20  entCulture:..   
4690: 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74               ret
46a0: 75 72 6e 20 64 61 74 65 56 61 6c 75 65 2e 54 6f  urn dateValue.To
46b0: 53 74 72 69 6e 67 28 46 75 6c 6c 46 6f 72 6d 61  String(FullForma
46c0: 74 2c 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e 43  t, CultureInfo.C
46d0: 75 72 72 65 6e 74 43 75 6c 74 75 72 65 29 3b 0d  urrentCulture);.
46e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 64 65 66  .            def
46f0: 61 75 6c 74 3a 0d 0a 20 20 20 20 20 20 20 20 20  ault:..         
4700: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 28 64         return (d
4710: 61 74 65 56 61 6c 75 65 2e 4b 69 6e 64 20 3d 3d  ateValue.Kind ==
4720: 20 44 61 74 65 54 69 6d 65 4b 69 6e 64 2e 55 6e   DateTimeKind.Un
4730: 73 70 65 63 69 66 69 65 64 29 20 3f 0d 0a 20 20  specified) ?..  
4740: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4750: 20 20 44 61 74 65 54 69 6d 65 2e 53 70 65 63 69    DateTime.Speci
4760: 66 79 4b 69 6e 64 28 64 61 74 65 56 61 6c 75 65  fyKind(dateValue
4770: 2c 20 5f 64 61 74 65 74 69 6d 65 4b 69 6e 64 29  , _datetimeKind)
4780: 2e 54 6f 53 74 72 69 6e 67 28 0d 0a 20 20 20 20  .ToString(..    
4790: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
47a0: 20 20 20 20 47 65 74 44 61 74 65 54 69 6d 65 4b      GetDateTimeK
47b0: 69 6e 64 46 6f 72 6d 61 74 28 5f 64 61 74 65 74  indFormat(_datet
47c0: 69 6d 65 4b 69 6e 64 29 2c 20 43 75 6c 74 75 72  imeKind), Cultur
47d0: 65 49 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43  eInfo.InvariantC
47e0: 75 6c 74 75 72 65 29 20 3a 0d 0a 20 20 20 20 20  ulture) :..     
47f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64                 d
4800: 61 74 65 56 61 6c 75 65 2e 54 6f 53 74 72 69 6e  ateValue.ToStrin
4810: 67 28 47 65 74 44 61 74 65 54 69 6d 65 4b 69 6e  g(GetDateTimeKin
4820: 64 46 6f 72 6d 61 74 28 64 61 74 65 56 61 6c 75  dFormat(dateValu
4830: 65 2e 4b 69 6e 64 29 2c 20 43 75 6c 74 75 72 65  e.Kind), Culture
4840: 49 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75  Info.InvariantCu
4850: 6c 74 75 72 65 29 3b 0d 0a 20 20 20 20 20 20 20  lture);..       
4860: 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20   }..    }....   
4870: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
4880: 20 20 20 20 2f 2f 2f 20 49 6e 74 65 72 6e 61 6c      /// Internal
4890: 20 66 75 6e 63 74 69 6f 6e 20 74 6f 20 63 6f 6e   function to con
48a0: 76 65 72 74 20 61 20 55 54 46 2d 38 20 65 6e 63  vert a UTF-8 enc
48b0: 6f 64 65 64 20 49 6e 74 50 74 72 20 6f 66 20 74  oded IntPtr of t
48c0: 68 65 20 73 70 65 63 69 66 69 65 64 20 6c 65 6e  he specified len
48d0: 67 74 68 20 74 6f 20 61 20 44 61 74 65 54 69 6d  gth to a DateTim
48e0: 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  e...    /// </su
48f0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
4900: 3c 72 65 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f  <remarks>..    /
4910: 2f 2f 20 54 68 69 73 20 69 73 20 61 20 63 6f 6e  // This is a con
4920: 76 65 6e 69 65 6e 63 65 20 66 75 6e 63 74 69 6f  venience functio
4930: 6e 2c 20 77 68 69 63 68 20 66 69 72 73 74 20 63  n, which first c
4940: 61 6c 6c 73 20 54 6f 53 74 72 69 6e 67 28 29 20  alls ToString() 
4950: 6f 6e 20 74 68 65 20 49 6e 74 50 74 72 20 74 6f  on the IntPtr to
4960: 20 63 6f 6e 76 65 72 74 20 69 74 20 74 6f 20 61   convert it to a
4970: 20 73 74 72 69 6e 67 2c 20 74 68 65 6e 20 63 61   string, then ca
4980: 6c 6c 73 0d 0a 20 20 20 20 2f 2f 2f 20 54 6f 44  lls..    /// ToD
4990: 61 74 65 54 69 6d 65 28 29 20 6f 6e 20 74 68 65  ateTime() on the
49a0: 20 73 74 72 69 6e 67 20 74 6f 20 72 65 74 75 72   string to retur
49b0: 6e 20 61 20 44 61 74 65 54 69 6d 65 2e 0d 0a 20  n a DateTime... 
49c0: 20 20 20 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73     /// </remarks
49d0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
49e0: 6d 20 6e 61 6d 65 3d 22 70 74 72 22 3e 41 20 70  m name="ptr">A p
49f0: 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 55 54  ointer to the UT
4a00: 46 2d 38 20 65 6e 63 6f 64 65 64 20 73 74 72 69  F-8 encoded stri
4a10: 6e 67 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  ng</param>..    
4a20: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
4a30: 22 6c 65 6e 22 3e 54 68 65 20 6c 65 6e 67 74 68  "len">The length
4a40: 20 69 6e 20 62 79 74 65 73 20 6f 66 20 74 68 65   in bytes of the
4a50: 20 73 74 72 69 6e 67 3c 2f 70 61 72 61 6d 3e 0d   string</param>.
4a60: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
4a70: 73 3e 54 68 65 20 70 61 72 73 65 64 20 44 61 74  s>The parsed Dat
4a80: 65 54 69 6d 65 20 76 61 6c 75 65 3c 2f 72 65 74  eTime value</ret
4a90: 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72  urns>..    inter
4aa0: 6e 61 6c 20 44 61 74 65 54 69 6d 65 20 54 6f 44  nal DateTime ToD
4ab0: 61 74 65 54 69 6d 65 28 49 6e 74 50 74 72 20 70  ateTime(IntPtr p
4ac0: 74 72 2c 20 69 6e 74 20 6c 65 6e 29 0d 0a 20 20  tr, int len)..  
4ad0: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72    {..      retur
4ae0: 6e 20 54 6f 44 61 74 65 54 69 6d 65 28 54 6f 53  n ToDateTime(ToS
4af0: 74 72 69 6e 67 28 70 74 72 2c 20 6c 65 6e 29 29  tring(ptr, len))
4b00: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
4b10: 23 65 6e 64 72 65 67 69 6f 6e 0d 0a 0d 0a 20 20  #endregion....  
4b20: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
4b30: 0a 20 20 20 20 2f 2f 2f 20 53 6d 61 72 74 20 6d  .    /// Smart m
4b40: 65 74 68 6f 64 20 6f 66 20 73 70 6c 69 74 74 69  ethod of splitti
4b50: 6e 67 20 61 20 73 74 72 69 6e 67 2e 20 20 53 6b  ng a string.  Sk
4b60: 69 70 73 20 71 75 6f 74 65 64 20 65 6c 65 6d 65  ips quoted eleme
4b70: 6e 74 73 2c 20 72 65 6d 6f 76 65 73 20 74 68 65  nts, removes the
4b80: 20 71 75 6f 74 65 73 2e 0d 0a 20 20 20 20 2f 2f   quotes...    //
4b90: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
4ba0: 20 20 2f 2f 2f 20 3c 72 65 6d 61 72 6b 73 3e 0d    /// <remarks>.
4bb0: 0a 20 20 20 20 2f 2f 2f 20 54 68 69 73 20 73 70  .    /// This sp
4bc0: 6c 69 74 20 66 75 6e 63 74 69 6f 6e 20 77 6f 72  lit function wor
4bd0: 6b 73 20 73 6f 6d 65 77 68 61 74 20 6c 69 6b 65  ks somewhat like
4be0: 20 74 68 65 20 53 74 72 69 6e 67 2e 53 70 6c 69   the String.Spli
4bf0: 74 28 29 20 66 75 6e 63 74 69 6f 6e 20 69 6e 20  t() function in 
4c00: 74 68 61 74 20 69 74 20 62 72 65 61 6b 73 20 61  that it breaks a
4c10: 70 61 72 74 20 61 20 73 74 72 69 6e 67 20 69 6e  part a string in
4c20: 74 6f 0d 0a 20 20 20 20 2f 2f 2f 20 70 69 65 63  to..    /// piec
4c30: 65 73 20 61 6e 64 20 72 65 74 75 72 6e 73 20 74  es and returns t
4c40: 68 65 20 70 69 65 63 65 73 20 61 73 20 61 6e 20  he pieces as an 
4c50: 61 72 72 61 79 2e 20 20 54 68 65 20 70 72 69 6d  array.  The prim
4c60: 61 72 79 20 64 69 66 66 65 72 65 6e 63 65 73 20  ary differences 
4c70: 61 72 65 3a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 6c  are:..    /// <l
4c80: 69 73 74 20 74 79 70 65 3d 22 62 75 6c 6c 65 74  ist type="bullet
4c90: 22 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  ">..    /// <ite
4ca0: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 4f  m><description>O
4cb0: 6e 6c 79 20 6f 6e 65 20 63 68 61 72 61 63 74 65  nly one characte
4cc0: 72 20 63 61 6e 20 62 65 20 70 72 6f 76 69 64 65  r can be provide
4cd0: 64 20 61 73 20 61 20 73 65 70 61 72 61 74 6f 72  d as a separator
4ce0: 20 63 68 61 72 61 63 74 65 72 3c 2f 64 65 73 63   character</desc
4cf0: 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d  ription></item>.
4d00: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
4d10: 64 65 73 63 72 69 70 74 69 6f 6e 3e 51 75 6f 74  description>Quot
4d20: 65 64 20 74 65 78 74 20 69 6e 73 69 64 65 20 74  ed text inside t
4d30: 68 65 20 73 74 72 69 6e 67 20 69 73 20 73 6b 69  he string is ski
4d40: 70 70 65 64 20 6f 76 65 72 20 77 68 65 6e 20 73  pped over when s
4d50: 65 61 72 63 68 69 6e 67 20 66 6f 72 20 74 68 65  earching for the
4d60: 20 73 65 70 61 72 61 74 6f 72 2c 20 61 6e 64 20   separator, and 
4d70: 74 68 65 20 71 75 6f 74 65 73 20 61 72 65 20 72  the quotes are r
4d80: 65 6d 6f 76 65 64 2e 3c 2f 64 65 73 63 72 69 70  emoved.</descrip
4d90: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
4da0: 20 20 2f 2f 2f 20 3c 2f 6c 69 73 74 3e 0d 0a 20    /// </list>.. 
4db0: 20 20 20 2f 2f 2f 20 54 68 75 73 2c 20 69 66 20     /// Thus, if 
4dc0: 73 70 6c 69 74 74 69 6e 67 20 74 68 65 20 66 6f  splitting the fo
4dd0: 6c 6c 6f 77 69 6e 67 20 73 74 72 69 6e 67 20 6c  llowing string l
4de0: 6f 6f 6b 69 6e 67 20 66 6f 72 20 61 20 63 6f 6d  ooking for a com
4df0: 6d 61 3a 3c 62 72 2f 3e 0d 0a 20 20 20 20 2f 2f  ma:<br/>..    //
4e00: 2f 20 4f 6e 65 2c 54 77 6f 2c 20 22 54 68 72 65  / One,Two, "Thre
4e10: 65 2c 20 46 6f 75 72 22 2c 20 46 69 76 65 3c 62  e, Four", Five<b
4e20: 72 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 62 72  r/>..    /// <br
4e30: 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20  />..    /// The 
4e40: 72 65 73 75 6c 74 69 6e 67 20 61 72 72 61 79 20  resulting array 
4e50: 77 6f 75 6c 64 20 63 6f 6e 74 61 69 6e 3c 62 72  would contain<br
4e60: 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 5b 30 5d 20  />..    /// [0] 
4e70: 4f 6e 65 3c 62 72 2f 3e 0d 0a 20 20 20 20 2f 2f  One<br/>..    //
4e80: 2f 20 5b 31 5d 20 54 77 6f 3c 62 72 2f 3e 0d 0a  / [1] Two<br/>..
4e90: 20 20 20 20 2f 2f 2f 20 5b 32 5d 20 54 68 72 65      /// [2] Thre
4ea0: 65 2c 20 46 6f 75 72 3c 62 72 2f 3e 0d 0a 20 20  e, Four<br/>..  
4eb0: 20 20 2f 2f 2f 20 5b 33 5d 20 46 69 76 65 3c 62    /// [3] Five<b
4ec0: 72 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 62 72  r/>..    /// <br
4ed0: 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 4e 6f 74 65  />..    /// Note
4ee0: 20 74 68 61 74 20 74 68 65 20 6c 65 61 64 69 6e   that the leadin
4ef0: 67 20 61 6e 64 20 74 72 61 69 6c 69 6e 67 20 73  g and trailing s
4f00: 70 61 63 65 73 20 77 65 72 65 20 72 65 6d 6f 76  paces were remov
4f10: 65 64 20 66 72 6f 6d 20 65 61 63 68 20 69 74 65  ed from each ite
4f20: 6d 20 64 75 72 69 6e 67 20 74 68 65 20 73 70 6c  m during the spl
4f30: 69 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72  it...    /// </r
4f40: 65 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f  emarks>..    ///
4f50: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 73 6f   <param name="so
4f60: 75 72 63 65 22 3e 53 6f 75 72 63 65 20 73 74 72  urce">Source str
4f70: 69 6e 67 20 74 6f 20 73 70 6c 69 74 20 61 70 61  ing to split apa
4f80: 72 74 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  rt</param>..    
4f90: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
4fa0: 22 73 65 70 61 72 61 74 6f 72 22 3e 53 65 70 61  "separator">Sepa
4fb0: 72 61 74 6f 72 20 63 68 61 72 61 63 74 65 72 3c  rator character<
4fc0: 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  /param>..    ///
4fd0: 20 3c 72 65 74 75 72 6e 73 3e 41 20 73 74 72 69   <returns>A stri
4fe0: 6e 67 20 61 72 72 61 79 20 6f 66 20 74 68 65 20  ng array of the 
4ff0: 73 70 6c 69 74 20 75 70 20 65 6c 65 6d 65 6e 74  split up element
5000: 73 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20  s</returns>..   
5010: 20 70 75 62 6c 69 63 20 73 74 61 74 69 63 20 73   public static s
5020: 74 72 69 6e 67 5b 5d 20 53 70 6c 69 74 28 73 74  tring[] Split(st
5030: 72 69 6e 67 20 73 6f 75 72 63 65 2c 20 63 68 61  ring source, cha
5040: 72 20 73 65 70 61 72 61 74 6f 72 29 0d 0a 20 20  r separator)..  
5050: 20 20 7b 0d 0a 20 20 20 20 20 20 63 68 61 72 5b    {..      char[
5060: 5d 20 74 6f 6b 73 20 3d 20 6e 65 77 20 63 68 61  ] toks = new cha
5070: 72 5b 32 5d 20 7b 20 27 5c 22 27 2c 20 73 65 70  r[2] { '\"', sep
5080: 61 72 61 74 6f 72 20 7d 3b 0d 0a 20 20 20 20 20  arator };..     
5090: 20 63 68 61 72 5b 5d 20 71 75 6f 74 20 3d 20 6e   char[] quot = n
50a0: 65 77 20 63 68 61 72 5b 31 5d 20 7b 20 27 5c 22  ew char[1] { '\"
50b0: 27 20 7d 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20  ' };..      int 
50c0: 6e 20 3d 20 30 3b 0d 0a 20 20 20 20 20 20 4c 69  n = 0;..      Li
50d0: 73 74 3c 73 74 72 69 6e 67 3e 20 6c 73 20 3d 20  st<string> ls = 
50e0: 6e 65 77 20 4c 69 73 74 3c 73 74 72 69 6e 67 3e  new List<string>
50f0: 28 29 3b 0d 0a 20 20 20 20 20 20 73 74 72 69 6e  ();..      strin
5100: 67 20 73 3b 0d 0a 0d 0a 20 20 20 20 20 20 77 68  g s;....      wh
5110: 69 6c 65 20 28 73 6f 75 72 63 65 2e 4c 65 6e 67  ile (source.Leng
5120: 74 68 20 3e 20 30 29 0d 0a 20 20 20 20 20 20 7b  th > 0)..      {
5130: 0d 0a 20 20 20 20 20 20 20 20 6e 20 3d 20 73 6f  ..        n = so
5140: 75 72 63 65 2e 49 6e 64 65 78 4f 66 41 6e 79 28  urce.IndexOfAny(
5150: 74 6f 6b 73 2c 20 6e 29 3b 0d 0a 20 20 20 20 20  toks, n);..     
5160: 20 20 20 69 66 20 28 6e 20 3d 3d 20 2d 31 29 20     if (n == -1) 
5170: 62 72 65 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20  break;..        
5180: 69 66 20 28 73 6f 75 72 63 65 5b 6e 5d 20 3d 3d  if (source[n] ==
5190: 20 74 6f 6b 73 5b 30 5d 29 0d 0a 20 20 20 20 20   toks[0])..     
51a0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
51b0: 2f 2f 73 6f 75 72 63 65 20 3d 20 73 6f 75 72 63  //source = sourc
51c0: 65 2e 52 65 6d 6f 76 65 28 6e 2c 20 31 29 3b 0d  e.Remove(n, 1);.
51d0: 0a 20 20 20 20 20 20 20 20 20 20 6e 20 3d 20 73  .          n = s
51e0: 6f 75 72 63 65 2e 49 6e 64 65 78 4f 66 41 6e 79  ource.IndexOfAny
51f0: 28 71 75 6f 74 2c 20 6e 20 2b 20 31 29 3b 0d 0a  (quot, n + 1);..
5200: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 6e 20            if (n 
5210: 3d 3d 20 2d 31 29 0d 0a 20 20 20 20 20 20 20 20  == -1)..        
5220: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
5230: 20 2f 2f 73 6f 75 72 63 65 20 3d 20 22 5c 22 22   //source = "\""
5240: 20 2b 20 73 6f 75 72 63 65 3b 0d 0a 20 20 20 20   + source;..    
5250: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a          break;..
5260: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
5270: 20 20 20 20 20 20 20 6e 2b 2b 3b 0d 0a 20 20 20         n++;..   
5280: 20 20 20 20 20 20 20 2f 2f 73 6f 75 72 63 65 20         //source 
5290: 3d 20 73 6f 75 72 63 65 2e 52 65 6d 6f 76 65 28  = source.Remove(
52a0: 6e 2c 20 31 29 3b 0d 0a 20 20 20 20 20 20 20 20  n, 1);..        
52b0: 7d 0d 0a 20 20 20 20 20 20 20 20 65 6c 73 65 0d  }..        else.
52c0: 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  .        {..    
52d0: 20 20 20 20 20 20 73 20 3d 20 73 6f 75 72 63 65        s = source
52e0: 2e 53 75 62 73 74 72 69 6e 67 28 30 2c 20 6e 29  .Substring(0, n)
52f0: 2e 54 72 69 6d 28 29 3b 0d 0a 20 20 20 20 20 20  .Trim();..      
5300: 20 20 20 20 69 66 20 28 73 2e 4c 65 6e 67 74 68      if (s.Length
5310: 20 3e 20 31 20 26 26 20 73 5b 30 5d 20 3d 3d 20   > 1 && s[0] == 
5320: 71 75 6f 74 5b 30 5d 20 26 26 20 73 5b 73 2e 4c  quot[0] && s[s.L
5330: 65 6e 67 74 68 20 2d 20 31 5d 20 3d 3d 20 73 5b  ength - 1] == s[
5340: 30 5d 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  0])..           
5350: 20 73 20 3d 20 73 2e 53 75 62 73 74 72 69 6e 67   s = s.Substring
5360: 28 31 2c 20 73 2e 4c 65 6e 67 74 68 20 2d 20 32  (1, s.Length - 2
5370: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
5380: 73 6f 75 72 63 65 20 3d 20 73 6f 75 72 63 65 2e  source = source.
5390: 53 75 62 73 74 72 69 6e 67 28 6e 20 2b 20 31 29  Substring(n + 1)
53a0: 2e 54 72 69 6d 28 29 3b 0d 0a 20 20 20 20 20 20  .Trim();..      
53b0: 20 20 20 20 69 66 20 28 73 2e 4c 65 6e 67 74 68      if (s.Length
53c0: 20 3e 20 30 29 20 6c 73 2e 41 64 64 28 73 29 3b   > 0) ls.Add(s);
53d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 6e 20 3d 20  ..          n = 
53e0: 30 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20  0;..        }.. 
53f0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 69 66       }..      if
5400: 20 28 73 6f 75 72 63 65 2e 4c 65 6e 67 74 68 20   (source.Length 
5410: 3e 20 30 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20  > 0)..      {.. 
5420: 20 20 20 20 20 20 20 73 20 3d 20 73 6f 75 72 63         s = sourc
5430: 65 2e 54 72 69 6d 28 29 3b 0d 0a 20 20 20 20 20  e.Trim();..     
5440: 20 20 20 69 66 20 28 73 2e 4c 65 6e 67 74 68 20     if (s.Length 
5450: 3e 20 31 20 26 26 20 73 5b 30 5d 20 3d 3d 20 71  > 1 && s[0] == q
5460: 75 6f 74 5b 30 5d 20 26 26 20 73 5b 73 2e 4c 65  uot[0] && s[s.Le
5470: 6e 67 74 68 20 2d 20 31 5d 20 3d 3d 20 73 5b 30  ngth - 1] == s[0
5480: 5d 29 0d 0a 20 20 20 20 20 20 20 20 20 20 73 20  ])..          s 
5490: 3d 20 73 2e 53 75 62 73 74 72 69 6e 67 28 31 2c  = s.Substring(1,
54a0: 20 73 2e 4c 65 6e 67 74 68 20 2d 20 32 29 3b 0d   s.Length - 2);.
54b0: 0a 20 20 20 20 20 20 20 20 6c 73 2e 41 64 64 28  .        ls.Add(
54c0: 73 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a  s);..      }....
54d0: 20 20 20 20 20 20 73 74 72 69 6e 67 5b 5d 20 61        string[] a
54e0: 72 20 3d 20 6e 65 77 20 73 74 72 69 6e 67 5b 6c  r = new string[l
54f0: 73 2e 43 6f 75 6e 74 5d 3b 0d 0a 20 20 20 20 20  s.Count];..     
5500: 20 6c 73 2e 43 6f 70 79 54 6f 28 61 72 2c 20 30   ls.CopyTo(ar, 0
5510: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75  );....      retu
5520: 72 6e 20 61 72 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  rn ar;..    }...
5530: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
5540: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 53 70 6c 69  y>..    /// Spli
5550: 74 73 20 74 68 65 20 73 70 65 63 69 66 69 65 64  ts the specified
5560: 20 73 74 72 69 6e 67 20 69 6e 74 6f 20 6d 75 6c   string into mul
5570: 74 69 70 6c 65 20 73 74 72 69 6e 67 73 20 62 61  tiple strings ba
5580: 73 65 64 20 6f 6e 20 61 20 73 65 70 61 72 61 74  sed on a separat
5590: 6f 72 0d 0a 20 20 20 20 2f 2f 2f 20 61 6e 64 20  or..    /// and 
55a0: 72 65 74 75 72 6e 73 20 74 68 65 20 72 65 73 75  returns the resu
55b0: 6c 74 20 61 73 20 61 6e 20 61 72 72 61 79 20 6f  lt as an array o
55c0: 66 20 73 74 72 69 6e 67 73 2e 0d 0a 20 20 20 20  f strings...    
55d0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
55e0: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
55f0: 61 6d 65 3d 22 76 61 6c 75 65 22 3e 0d 0a 20 20  ame="value">..  
5600: 20 20 2f 2f 2f 20 54 68 65 20 73 74 72 69 6e 67    /// The string
5610: 20 74 6f 20 73 70 6c 69 74 20 69 6e 74 6f 20 70   to split into p
5620: 69 65 63 65 73 20 62 61 73 65 64 20 6f 6e 20 74  ieces based on t
5630: 68 65 20 73 65 70 61 72 61 74 6f 72 20 63 68 61  he separator cha
5640: 72 61 63 74 65 72 2e 20 20 49 66 0d 0a 20 20 20  racter.  If..   
5650: 20 2f 2f 2f 20 74 68 69 73 20 73 74 72 69 6e 67   /// this string
5660: 20 69 73 20 6e 75 6c 6c 2c 20 6e 75 6c 6c 20 77   is null, null w
5670: 69 6c 6c 20 61 6c 77 61 79 73 20 62 65 20 72 65  ill always be re
5680: 74 75 72 6e 65 64 2e 20 20 49 66 20 74 68 69 73  turned.  If this
5690: 20 73 74 72 69 6e 67 20 69 73 0d 0a 20 20 20 20   string is..    
56a0: 2f 2f 2f 20 65 6d 70 74 79 2c 20 61 6e 20 61 72  /// empty, an ar
56b0: 72 61 79 20 6f 66 20 7a 65 72 6f 20 73 74 72 69  ray of zero stri
56c0: 6e 67 73 20 77 69 6c 6c 20 61 6c 77 61 79 73 20  ngs will always 
56d0: 62 65 20 72 65 74 75 72 6e 65 64 2e 0d 0a 20 20  be returned...  
56e0: 20 20 2f 2f 2f 20 3c 2f 70 61 72 61 6d 3e 0d 0a    /// </param>..
56f0: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
5700: 61 6d 65 3d 22 73 65 70 61 72 61 74 6f 72 22 3e  ame="separator">
5710: 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 63 68  ..    /// The ch
5720: 61 72 61 63 74 65 72 20 75 73 65 64 20 74 6f 20  aracter used to 
5730: 64 69 76 69 64 65 20 74 68 65 20 6f 72 69 67 69  divide the origi
5740: 6e 61 6c 20 73 74 72 69 6e 67 20 69 6e 74 6f 20  nal string into 
5750: 73 75 62 2d 73 74 72 69 6e 67 73 2e 0d 0a 20 20  sub-strings...  
5760: 20 20 2f 2f 2f 20 54 68 69 73 20 63 68 61 72 61    /// This chara
5770: 63 74 65 72 20 63 61 6e 6e 6f 74 20 62 65 20 61  cter cannot be a
5780: 20 62 61 63 6b 73 6c 61 73 68 20 6f 72 20 61 20   backslash or a 
5790: 64 6f 75 62 6c 65 2d 71 75 6f 74 65 3b 20 6f 74  double-quote; ot
57a0: 68 65 72 77 69 73 65 2c 20 6e 6f 0d 0a 20 20 20  herwise, no..   
57b0: 20 2f 2f 2f 20 77 6f 72 6b 20 77 69 6c 6c 20 62   /// work will b
57c0: 65 20 70 65 72 66 6f 72 6d 65 64 20 61 6e 64 20  e performed and 
57d0: 6e 75 6c 6c 20 77 69 6c 6c 20 62 65 20 72 65 74  null will be ret
57e0: 75 72 6e 65 64 2e 0d 0a 20 20 20 20 2f 2f 2f 20  urned...    /// 
57f0: 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f  </param>..    //
5800: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6b  / <param name="k
5810: 65 65 70 51 75 6f 74 65 22 3e 0d 0a 20 20 20 20  eepQuote">..    
5820: 2f 2f 2f 20 49 66 20 74 68 69 73 20 70 61 72 61  /// If this para
5830: 6d 65 74 65 72 20 69 73 20 6e 6f 6e 2d 7a 65 72  meter is non-zer
5840: 6f 2c 20 61 6c 6c 20 64 6f 75 62 6c 65 2d 71 75  o, all double-qu
5850: 6f 74 65 20 63 68 61 72 61 63 74 65 72 73 20 77  ote characters w
5860: 69 6c 6c 20 62 65 0d 0a 20 20 20 20 2f 2f 2f 20  ill be..    /// 
5870: 72 65 74 61 69 6e 65 64 20 69 6e 20 74 68 65 20  retained in the 
5880: 72 65 74 75 72 6e 65 64 20 6c 69 73 74 20 6f 66  returned list of
5890: 20 73 74 72 69 6e 67 73 3b 20 6f 74 68 65 72 77   strings; otherw
58a0: 69 73 65 2c 20 74 68 65 79 20 77 69 6c 6c 20 62  ise, they will b
58b0: 65 0d 0a 20 20 20 20 2f 2f 2f 20 64 72 6f 70 70  e..    /// dropp
58c0: 65 64 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 70  ed...    /// </p
58d0: 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  aram>..    /// <
58e0: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 65 72 72 6f  param name="erro
58f0: 72 22 3e 0d 0a 20 20 20 20 2f 2f 2f 20 55 70 6f  r">..    /// Upo
5900: 6e 20 66 61 69 6c 75 72 65 2c 20 74 68 69 73 20  n failure, this 
5910: 70 61 72 61 6d 65 74 65 72 20 77 69 6c 6c 20 62  parameter will b
5920: 65 20 6d 6f 64 69 66 69 65 64 20 74 6f 20 63 6f  e modified to co
5930: 6e 74 61 69 6e 20 61 6e 20 61 70 70 72 6f 70 72  ntain an appropr
5940: 69 61 74 65 0d 0a 20 20 20 20 2f 2f 2f 20 65 72  iate..    /// er
5950: 72 6f 72 20 6d 65 73 73 61 67 65 2e 0d 0a 20 20  ror message...  
5960: 20 20 2f 2f 2f 20 3c 2f 70 61 72 61 6d 3e 0d 0a    /// </param>..
5970: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
5980: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 6e  >..    /// The n
5990: 65 77 20 61 72 72 61 79 20 6f 66 20 73 74 72 69  ew array of stri
59a0: 6e 67 73 20 6f 72 20 6e 75 6c 6c 20 69 66 20 74  ngs or null if t
59b0: 68 65 20 69 6e 70 75 74 20 73 74 72 69 6e 67 20  he input string 
59c0: 69 73 20 6e 75 6c 6c 20 2d 4f 52 2d 20 74 68 65  is null -OR- the
59d0: 0d 0a 20 20 20 20 2f 2f 2f 20 73 65 70 61 72 61  ..    /// separa
59e0: 74 6f 72 20 63 68 61 72 61 63 74 65 72 20 69 73  tor character is
59f0: 20 61 20 62 61 63 6b 73 6c 61 73 68 20 6f 72 20   a backslash or 
5a00: 61 20 64 6f 75 62 6c 65 2d 71 75 6f 74 65 20 2d  a double-quote -
5a10: 4f 52 2d 20 74 68 65 20 73 74 72 69 6e 67 0d 0a  OR- the string..
5a20: 20 20 20 20 2f 2f 2f 20 63 6f 6e 74 61 69 6e 73      /// contains
5a30: 20 61 6e 20 75 6e 62 61 6c 61 6e 63 65 64 20 62   an unbalanced b
5a40: 61 63 6b 73 6c 61 73 68 20 6f 72 20 64 6f 75 62  ackslash or doub
5a50: 6c 65 2d 71 75 6f 74 65 20 63 68 61 72 61 63 74  le-quote charact
5a60: 65 72 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72  er...    /// </r
5a70: 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74  eturns>..    int
5a80: 65 72 6e 61 6c 20 73 74 61 74 69 63 20 73 74 72  ernal static str
5a90: 69 6e 67 5b 5d 20 4e 65 77 53 70 6c 69 74 28 0d  ing[] NewSplit(.
5aa0: 0a 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 20  .        string 
5ab0: 76 61 6c 75 65 2c 0d 0a 20 20 20 20 20 20 20 20  value,..        
5ac0: 63 68 61 72 20 73 65 70 61 72 61 74 6f 72 2c 0d  char separator,.
5ad0: 0a 20 20 20 20 20 20 20 20 62 6f 6f 6c 20 6b 65  .        bool ke
5ae0: 65 70 51 75 6f 74 65 2c 0d 0a 20 20 20 20 20 20  epQuote,..      
5af0: 20 20 72 65 66 20 73 74 72 69 6e 67 20 65 72 72    ref string err
5b00: 6f 72 0d 0a 20 20 20 20 20 20 20 20 29 0d 0a 20  or..        ).. 
5b10: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 63 6f     {..        co
5b20: 6e 73 74 20 63 68 61 72 20 45 73 63 61 70 65 43  nst char EscapeC
5b30: 68 61 72 20 3d 20 27 5c 5c 27 3b 0d 0a 20 20 20  har = '\\';..   
5b40: 20 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20       const char 
5b50: 51 75 6f 74 65 43 68 61 72 20 3d 20 27 5c 22 27  QuoteChar = '\"'
5b60: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 2f 2f 0d  ;....        //.
5b70: 0a 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45  .        // NOTE
5b80: 3a 20 49 74 20 69 73 20 69 6c 6c 65 67 61 6c 20  : It is illegal 
5b90: 66 6f 72 20 74 68 65 20 73 65 70 61 72 61 74 6f  for the separato
5ba0: 72 20 63 68 61 72 61 63 74 65 72 20 74 6f 20 62  r character to b
5bb0: 65 20 65 69 74 68 65 72 20 61 0d 0a 20 20 20 20  e either a..    
5bc0: 20 20 20 20 2f 2f 20 20 20 20 20 20 20 62 61 63      //       bac
5bd0: 6b 73 6c 61 73 68 20 6f 72 20 61 20 64 6f 75 62  kslash or a doub
5be0: 6c 65 2d 71 75 6f 74 65 20 62 65 63 61 75 73 65  le-quote because
5bf0: 20 62 6f 74 68 20 6f 66 20 74 68 6f 73 65 20 63   both of those c
5c00: 68 61 72 61 63 74 65 72 73 0d 0a 20 20 20 20 20  haracters..     
5c10: 20 20 20 2f 2f 20 20 20 20 20 20 20 61 72 65 20     //       are 
5c20: 75 73 65 64 20 66 6f 72 20 65 73 63 61 70 69 6e  used for escapin
5c30: 67 20 6f 74 68 65 72 20 63 68 61 72 61 63 74 65  g other characte
5c40: 72 73 20 28 65 2e 67 2e 20 74 68 65 20 73 65 70  rs (e.g. the sep
5c50: 61 72 61 74 6f 72 0d 0a 20 20 20 20 20 20 20 20  arator..        
5c60: 2f 2f 20 20 20 20 20 20 20 63 68 61 72 61 63 74  //       charact
5c70: 65 72 29 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f  er)...        //
5c80: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 28 73  ..        if ((s
5c90: 65 70 61 72 61 74 6f 72 20 3d 3d 20 45 73 63 61  eparator == Esca
5ca0: 70 65 43 68 61 72 29 20 7c 7c 20 28 73 65 70 61  peChar) || (sepa
5cb0: 72 61 74 6f 72 20 3d 3d 20 51 75 6f 74 65 43 68  rator == QuoteCh
5cc0: 61 72 29 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d  ar))..        {.
5cd0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 65 72 72  .            err
5ce0: 6f 72 20 3d 20 22 73 65 70 61 72 61 74 6f 72 20  or = "separator 
5cf0: 63 68 61 72 61 63 74 65 72 20 63 61 6e 6e 6f 74  character cannot
5d00: 20 62 65 20 74 68 65 20 65 73 63 61 70 65 20 6f   be the escape o
5d10: 72 20 71 75 6f 74 65 20 63 68 61 72 61 63 74 65  r quote characte
5d20: 72 73 22 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  rs";..          
5d30: 20 20 72 65 74 75 72 6e 20 6e 75 6c 6c 3b 0d 0a    return null;..
5d40: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20          }....   
5d50: 20 20 20 20 20 69 66 20 28 76 61 6c 75 65 20 3d       if (value =
5d60: 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20  = null)..       
5d70: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
5d80: 65 72 72 6f 72 20 3d 20 22 73 74 72 69 6e 67 20  error = "string 
5d90: 76 61 6c 75 65 20 74 6f 20 73 70 6c 69 74 20 63  value to split c
5da0: 61 6e 6e 6f 74 20 62 65 20 6e 75 6c 6c 22 3b 0d  annot be null";.
5db0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74  .            ret
5dc0: 75 72 6e 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20  urn null;..     
5dd0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
5de0: 69 6e 74 20 6c 65 6e 67 74 68 20 3d 20 76 61 6c  int length = val
5df0: 75 65 2e 4c 65 6e 67 74 68 3b 0d 0a 0d 0a 20 20  ue.Length;....  
5e00: 20 20 20 20 20 20 69 66 20 28 6c 65 6e 67 74 68        if (length
5e10: 20 3d 3d 20 30 29 0d 0a 20 20 20 20 20 20 20 20   == 0)..        
5e20: 20 20 20 20 72 65 74 75 72 6e 20 6e 65 77 20 73      return new s
5e30: 74 72 69 6e 67 5b 30 5d 3b 0d 0a 0d 0a 20 20 20  tring[0];....   
5e40: 20 20 20 20 20 4c 69 73 74 3c 73 74 72 69 6e 67       List<string
5e50: 3e 20 6c 69 73 74 20 3d 20 6e 65 77 20 4c 69 73  > list = new Lis
5e60: 74 3c 73 74 72 69 6e 67 3e 28 29 3b 0d 0a 20 20  t<string>();..  
5e70: 20 20 20 20 20 20 53 74 72 69 6e 67 42 75 69 6c        StringBuil
5e80: 64 65 72 20 65 6c 65 6d 65 6e 74 20 3d 20 6e 65  der element = ne
5e90: 77 20 53 74 72 69 6e 67 42 75 69 6c 64 65 72 28  w StringBuilder(
5ea0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20  );..        int 
5eb0: 69 6e 64 65 78 20 3d 20 30 3b 0d 0a 20 20 20 20  index = 0;..    
5ec0: 20 20 20 20 62 6f 6f 6c 20 65 73 63 61 70 65 20      bool escape 
5ed0: 3d 20 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20 20  = false;..      
5ee0: 20 20 62 6f 6f 6c 20 71 75 6f 74 65 20 3d 20 66    bool quote = f
5ef0: 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  alse;....       
5f00: 20 77 68 69 6c 65 20 28 69 6e 64 65 78 20 3c 20   while (index < 
5f10: 6c 65 6e 67 74 68 29 0d 0a 20 20 20 20 20 20 20  length)..       
5f20: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
5f30: 63 68 61 72 20 63 68 61 72 61 63 74 65 72 20 3d  char character =
5f40: 20 76 61 6c 75 65 5b 69 6e 64 65 78 2b 2b 5d 3b   value[index++];
5f50: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
5f60: 69 66 20 28 65 73 63 61 70 65 29 0d 0a 20 20 20  if (escape)..   
5f70: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
5f80: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a              //..
5f90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5fa0: 2f 2f 20 48 41 43 4b 3a 20 4f 6e 6c 79 20 63 6f  // HACK: Only co
5fb0: 6e 73 69 64 65 72 20 74 68 65 20 65 73 63 61 70  nsider the escap
5fc0: 65 20 63 68 61 72 61 63 74 65 72 20 74 6f 20 62  e character to b
5fd0: 65 20 61 6e 20 61 63 74 75 61 6c 0d 0a 20 20 20  e an actual..   
5fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20               // 
5ff0: 20 20 20 20 20 20 22 65 73 63 61 70 65 22 20 69        "escape" i
6000: 66 20 69 74 20 69 73 20 66 6f 6c 6c 6f 77 65 64  f it is followed
6010: 20 62 79 20 61 20 72 65 73 65 72 76 65 64 20 63   by a reserved c
6020: 68 61 72 61 63 74 65 72 3b 0d 0a 20 20 20 20 20  haracter;..     
6030: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 20 20             //   
6040: 20 20 20 20 6f 74 68 65 72 77 69 73 65 2c 20 65      otherwise, e
6050: 6d 69 74 20 74 68 65 20 6f 72 69 67 69 6e 61 6c  mit the original
6060: 20 65 73 63 61 70 65 20 63 68 61 72 61 63 74 65   escape characte
6070: 72 20 61 6e 64 0d 0a 20 20 20 20 20 20 20 20 20  r and..         
6080: 20 20 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20         //       
6090: 74 68 65 20 63 75 72 72 65 6e 74 20 63 68 61 72  the current char
60a0: 61 63 74 65 72 20 69 6e 20 61 6e 20 65 66 66 6f  acter in an effo
60b0: 72 74 20 74 6f 20 68 65 6c 70 20 70 72 65 73 65  rt to help prese
60c0: 72 76 65 0d 0a 20 20 20 20 20 20 20 20 20 20 20  rve..           
60d0: 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 74 68       //       th
60e0: 65 20 6f 72 69 67 69 6e 61 6c 20 73 74 72 69 6e  e original strin
60f0: 67 20 63 6f 6e 74 65 6e 74 2e 0d 0a 20 20 20 20  g content...    
6100: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a              //..
6110: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6120: 69 66 20 28 28 63 68 61 72 61 63 74 65 72 20 21  if ((character !
6130: 3d 20 45 73 63 61 70 65 43 68 61 72 29 20 26 26  = EscapeChar) &&
6140: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6150: 20 20 20 20 20 20 28 63 68 61 72 61 63 74 65 72        (character
6160: 20 21 3d 20 51 75 6f 74 65 43 68 61 72 29 20 26   != QuoteChar) &
6170: 26 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  &..             
6180: 20 20 20 20 20 20 20 28 63 68 61 72 61 63 74 65         (characte
6190: 72 20 21 3d 20 73 65 70 61 72 61 74 6f 72 29 29  r != separator))
61a0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
61b0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
61c0: 20 20 20 20 20 20 20 20 20 65 6c 65 6d 65 6e 74           element
61d0: 2e 41 70 70 65 6e 64 28 45 73 63 61 70 65 43 68  .Append(EscapeCh
61e0: 61 72 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  ar);..          
61f0: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
6200: 20 20 20 20 20 20 20 20 20 20 20 65 6c 65 6d 65             eleme
6210: 6e 74 2e 41 70 70 65 6e 64 28 63 68 61 72 61 63  nt.Append(charac
6220: 74 65 72 29 3b 0d 0a 20 20 20 20 20 20 20 20 20  ter);..         
6230: 20 20 20 20 20 20 20 65 73 63 61 70 65 20 3d 20         escape = 
6240: 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20 20 20 20  false;..        
6250: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20      }..         
6260: 20 20 20 65 6c 73 65 20 69 66 20 28 63 68 61 72     else if (char
6270: 61 63 74 65 72 20 3d 3d 20 45 73 63 61 70 65 43  acter == EscapeC
6280: 68 61 72 29 0d 0a 20 20 20 20 20 20 20 20 20 20  har)..          
6290: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
62a0: 20 20 20 20 20 65 73 63 61 70 65 20 3d 20 74 72       escape = tr
62b0: 75 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ue;..           
62c0: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
62d0: 65 6c 73 65 20 69 66 20 28 63 68 61 72 61 63 74  else if (charact
62e0: 65 72 20 3d 3d 20 51 75 6f 74 65 43 68 61 72 29  er == QuoteChar)
62f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d  ..            {.
6300: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6310: 20 69 66 20 28 6b 65 65 70 51 75 6f 74 65 29 0d   if (keepQuote).
6320: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6330: 20 20 20 20 20 65 6c 65 6d 65 6e 74 2e 41 70 70       element.App
6340: 65 6e 64 28 63 68 61 72 61 63 74 65 72 29 3b 0d  end(character);.
6350: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
6360: 20 20 20 71 75 6f 74 65 20 3d 20 21 71 75 6f 74     quote = !quot
6370: 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  e;..            
6380: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 65  }..            e
6390: 6c 73 65 20 69 66 20 28 63 68 61 72 61 63 74 65  lse if (characte
63a0: 72 20 3d 3d 20 73 65 70 61 72 61 74 6f 72 29 0d  r == separator).
63b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a  .            {..
63c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
63d0: 69 66 20 28 71 75 6f 74 65 29 0d 0a 20 20 20 20  if (quote)..    
63e0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
63f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6400: 20 20 20 65 6c 65 6d 65 6e 74 2e 41 70 70 65 6e     element.Appen
6410: 64 28 63 68 61 72 61 63 74 65 72 29 3b 0d 0a 20  d(character);.. 
6420: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
6430: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6440: 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20    else..        
6450: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
6460: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6c                 l
6470: 69 73 74 2e 41 64 64 28 65 6c 65 6d 65 6e 74 2e  ist.Add(element.
6480: 54 6f 53 74 72 69 6e 67 28 29 29 3b 0d 0a 20 20  ToString());..  
6490: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
64a0: 20 20 65 6c 65 6d 65 6e 74 2e 4c 65 6e 67 74 68    element.Length
64b0: 20 3d 20 30 3b 0d 0a 20 20 20 20 20 20 20 20 20   = 0;..         
64c0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
64d0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
64e0: 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20       else..     
64f0: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
6500: 20 20 20 20 20 20 20 20 20 20 65 6c 65 6d 65 6e            elemen
6510: 74 2e 41 70 70 65 6e 64 28 63 68 61 72 61 63 74  t.Append(charact
6520: 65 72 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  er);..          
6530: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a    }..        }..
6540: 0d 0a 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20  ..        //..  
6550: 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45 3a 20 41        // NOTE: A
6560: 6e 20 75 6e 62 61 6c 61 6e 63 65 64 20 65 73 63  n unbalanced esc
6570: 61 70 65 20 6f 72 20 71 75 6f 74 65 20 63 68 61  ape or quote cha
6580: 72 61 63 74 65 72 20 69 6e 20 74 68 65 20 73 74  racter in the st
6590: 72 69 6e 67 20 69 73 0d 0a 20 20 20 20 20 20 20  ring is..       
65a0: 20 2f 2f 20 20 20 20 20 20 20 63 6f 6e 73 69 64   //       consid
65b0: 65 72 65 64 20 74 6f 20 62 65 20 61 20 66 61 74  ered to be a fat
65c0: 61 6c 20 65 72 72 6f 72 3b 20 74 68 65 72 65 66  al error; theref
65d0: 6f 72 65 2c 20 72 65 74 75 72 6e 20 6e 75 6c 6c  ore, return null
65e0: 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20  ...        //.. 
65f0: 20 20 20 20 20 20 20 69 66 20 28 65 73 63 61 70         if (escap
6600: 65 20 7c 7c 20 71 75 6f 74 65 29 0d 0a 20 20 20  e || quote)..   
6610: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
6620: 20 20 20 20 65 72 72 6f 72 20 3d 20 22 75 6e 62      error = "unb
6630: 61 6c 61 6e 63 65 64 20 65 73 63 61 70 65 20 6f  alanced escape o
6640: 72 20 71 75 6f 74 65 20 63 68 61 72 61 63 74 65  r quote characte
6650: 72 20 66 6f 75 6e 64 22 3b 0d 0a 20 20 20 20 20  r found";..     
6660: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 75         return nu
6670: 6c 6c 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a  ll;..        }..
6680: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 65 6c  ..        if (el
6690: 65 6d 65 6e 74 2e 4c 65 6e 67 74 68 20 3e 20 30  ement.Length > 0
66a0: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6c  )..            l
66b0: 69 73 74 2e 41 64 64 28 65 6c 65 6d 65 6e 74 2e  ist.Add(element.
66c0: 54 6f 53 74 72 69 6e 67 28 29 29 3b 0d 0a 0d 0a  ToString());....
66d0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 6c          return l
66e0: 69 73 74 2e 54 6f 41 72 72 61 79 28 29 3b 0d 0a  ist.ToArray();..
66f0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f      }....    ///
6700: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
6710: 2f 2f 2f 20 43 6f 6e 76 65 72 74 20 61 20 76 61  /// Convert a va
6720: 6c 75 65 20 74 6f 20 74 72 75 65 20 6f 72 20 66  lue to true or f
6730: 61 6c 73 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  alse...    /// <
6740: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  /summary>..    /
6750: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
6760: 73 6f 75 72 63 65 22 3e 41 20 73 74 72 69 6e 67  source">A string
6770: 20 6f 72 20 6e 75 6d 62 65 72 20 72 65 70 72 65   or number repre
6780: 73 65 6e 74 69 6e 67 20 74 72 75 65 20 6f 72 20  senting true or 
6790: 66 61 6c 73 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20  false</param>.. 
67a0: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
67b0: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
67c0: 70 75 62 6c 69 63 20 73 74 61 74 69 63 20 62 6f  public static bo
67d0: 6f 6c 20 54 6f 42 6f 6f 6c 65 61 6e 28 6f 62 6a  ol ToBoolean(obj
67e0: 65 63 74 20 73 6f 75 72 63 65 29 0d 0a 20 20 20  ect source)..   
67f0: 20 7b 0d 0a 20 20 20 20 20 20 69 66 20 28 73 6f   {..      if (so
6800: 75 72 63 65 20 69 73 20 62 6f 6f 6c 29 20 72 65  urce is bool) re
6810: 74 75 72 6e 20 28 62 6f 6f 6c 29 73 6f 75 72 63  turn (bool)sourc
6820: 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75  e;....      retu
6830: 72 6e 20 54 6f 42 6f 6f 6c 65 61 6e 28 73 6f 75  rn ToBoolean(sou
6840: 72 63 65 2e 54 6f 53 74 72 69 6e 67 28 29 29 3b  rce.ToString());
6850: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f  ..    }....    /
6860: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
6870: 20 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 20 61 20    /// Convert a 
6880: 73 74 72 69 6e 67 20 74 6f 20 74 72 75 65 20 6f  string to true o
6890: 72 20 66 61 6c 73 65 2e 0d 0a 20 20 20 20 2f 2f  r false...    //
68a0: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
68b0: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
68c0: 65 3d 22 73 6f 75 72 63 65 22 3e 41 20 73 74 72  e="source">A str
68d0: 69 6e 67 20 72 65 70 72 65 73 65 6e 74 69 6e 67  ing representing
68e0: 20 74 72 75 65 20 6f 72 20 66 61 6c 73 65 3c 2f   true or false</
68f0: 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  param>..    /// 
6900: 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72  <returns></retur
6910: 6e 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ns>..    /// <re
6920: 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20  marks>..    /// 
6930: 22 79 65 73 22 2c 20 22 6e 6f 22 2c 20 22 79 22  "yes", "no", "y"
6940: 2c 20 22 6e 22 2c 20 22 30 22 2c 20 22 31 22 2c  , "n", "0", "1",
6950: 20 22 6f 6e 22 2c 20 22 6f 66 66 22 20 61 73 20   "on", "off" as 
6960: 77 65 6c 6c 20 61 73 20 42 6f 6f 6c 65 61 6e 2e  well as Boolean.
6970: 46 61 6c 73 65 53 74 72 69 6e 67 20 61 6e 64 20  FalseString and 
6980: 42 6f 6f 6c 65 61 6e 2e 54 72 75 65 53 74 72 69  Boolean.TrueStri
6990: 6e 67 20 77 69 6c 6c 20 61 6c 6c 20 62 65 0d 0a  ng will all be..
69a0: 20 20 20 20 2f 2f 2f 20 63 6f 6e 76 65 72 74 65      /// converte
69b0: 64 20 74 6f 20 61 20 70 72 6f 70 65 72 20 62 6f  d to a proper bo
69c0: 6f 6c 65 61 6e 20 76 61 6c 75 65 2e 0d 0a 20 20  olean value...  
69d0: 20 20 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73 3e    /// </remarks>
69e0: 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 73 74 61  ..    public sta
69f0: 74 69 63 20 62 6f 6f 6c 20 54 6f 42 6f 6f 6c 65  tic bool ToBoole
6a00: 61 6e 28 73 74 72 69 6e 67 20 73 6f 75 72 63 65  an(string source
6a10: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
6a20: 69 66 20 28 53 74 72 69 6e 67 2e 43 6f 6d 70 61  if (String.Compa
6a30: 72 65 28 73 6f 75 72 63 65 2c 20 62 6f 6f 6c 2e  re(source, bool.
6a40: 54 72 75 65 53 74 72 69 6e 67 2c 20 53 74 72 69  TrueString, Stri
6a50: 6e 67 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64  ngComparison.Ord
6a60: 69 6e 61 6c 49 67 6e 6f 72 65 43 61 73 65 29 20  inalIgnoreCase) 
6a70: 3d 3d 20 30 29 20 72 65 74 75 72 6e 20 74 72 75  == 0) return tru
6a80: 65 3b 0d 0a 20 20 20 20 20 20 65 6c 73 65 20 69  e;..      else i
6a90: 66 20 28 53 74 72 69 6e 67 2e 43 6f 6d 70 61 72  f (String.Compar
6aa0: 65 28 73 6f 75 72 63 65 2c 20 62 6f 6f 6c 2e 46  e(source, bool.F
6ab0: 61 6c 73 65 53 74 72 69 6e 67 2c 20 53 74 72 69  alseString, Stri
6ac0: 6e 67 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64  ngComparison.Ord
6ad0: 69 6e 61 6c 49 67 6e 6f 72 65 43 61 73 65 29 20  inalIgnoreCase) 
6ae0: 3d 3d 20 30 29 20 72 65 74 75 72 6e 20 66 61 6c  == 0) return fal
6af0: 73 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 73 77 69  se;....      swi
6b00: 74 63 68 28 73 6f 75 72 63 65 2e 54 6f 4c 6f 77  tch(source.ToLow
6b10: 65 72 28 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49  er(CultureInfo.I
6b20: 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65 29  nvariantCulture)
6b30: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  )..      {..    
6b40: 20 20 20 20 63 61 73 65 20 22 79 65 73 22 3a 0d      case "yes":.
6b50: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 22 79  .        case "y
6b60: 22 3a 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65  ":..        case
6b70: 20 22 31 22 3a 0d 0a 20 20 20 20 20 20 20 20 63   "1":..        c
6b80: 61 73 65 20 22 6f 6e 22 3a 0d 0a 20 20 20 20 20  ase "on":..     
6b90: 20 20 20 20 20 72 65 74 75 72 6e 20 74 72 75 65       return true
6ba0: 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  ;..        case 
6bb0: 22 6e 6f 22 3a 0d 0a 20 20 20 20 20 20 20 20 63  "no":..        c
6bc0: 61 73 65 20 22 6e 22 3a 0d 0a 20 20 20 20 20 20  ase "n":..      
6bd0: 20 20 63 61 73 65 20 22 30 22 3a 0d 0a 20 20 20    case "0":..   
6be0: 20 20 20 20 20 63 61 73 65 20 22 6f 66 66 22 3a       case "off":
6bf0: 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75  ..          retu
6c00: 72 6e 20 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20  rn false;..     
6c10: 20 20 20 64 65 66 61 75 6c 74 3a 0d 0a 20 20 20     default:..   
6c20: 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77         throw new
6c30: 20 41 72 67 75 6d 65 6e 74 45 78 63 65 70 74 69   ArgumentExcepti
6c40: 6f 6e 28 22 73 6f 75 72 63 65 22 29 3b 0d 0a 20  on("source");.. 
6c50: 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d       }..    }...
6c60: 0a 20 20 20 20 23 72 65 67 69 6f 6e 20 54 79 70  .    #region Typ
6c70: 65 20 43 6f 6e 76 65 72 73 69 6f 6e 73 0d 0a 20  e Conversions.. 
6c80: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
6c90: 0d 0a 20 20 20 20 2f 2f 2f 20 44 65 74 65 72 6d  ..    /// Determ
6ca0: 69 6e 65 73 20 74 68 65 20 64 61 74 61 20 74 79  ines the data ty
6cb0: 70 65 20 6f 66 20 61 20 63 6f 6c 75 6d 6e 20 69  pe of a column i
6cc0: 6e 20 61 20 73 74 61 74 65 6d 65 6e 74 0d 0a 20  n a statement.. 
6cd0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
6ce0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
6cf0: 6d 20 6e 61 6d 65 3d 22 73 74 6d 74 22 3e 54 68  m name="stmt">Th
6d00: 65 20 73 74 61 74 65 6d 65 6e 74 20 74 6f 20 72  e statement to r
6d10: 65 74 72 69 65 76 65 20 69 6e 66 6f 72 6d 61 74  etrieve informat
6d20: 69 6f 6e 20 66 6f 72 3c 2f 70 61 72 61 6d 3e 0d  ion for</param>.
6d30: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
6d40: 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20 63 6f 6c  name="i">The col
6d50: 75 6d 6e 20 74 6f 20 72 65 74 72 69 65 76 65 20  umn to retrieve 
6d60: 74 79 70 65 20 69 6e 66 6f 72 6d 61 74 69 6f 6e  type information
6d70: 20 6f 6e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20   on</param>..   
6d80: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
6d90: 3d 22 74 79 70 22 3e 54 68 65 20 53 51 4c 69 74  ="typ">The SQLit
6da0: 65 54 79 70 65 20 74 6f 20 72 65 63 65 69 76 65  eType to receive
6db0: 20 74 68 65 20 61 66 66 69 6e 69 74 79 20 66 6f   the affinity fo
6dc0: 72 20 74 68 65 20 67 69 76 65 6e 20 63 6f 6c 75  r the given colu
6dd0: 6d 6e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  mn</param>..    
6de0: 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69 63 20  internal static 
6df0: 76 6f 69 64 20 43 6f 6c 75 6d 6e 54 6f 54 79 70  void ColumnToTyp
6e00: 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  e(SQLiteStatemen
6e10: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 2c 20 53  t stmt, int i, S
6e20: 51 4c 69 74 65 54 79 70 65 20 74 79 70 29 0d 0a  QLiteType typ)..
6e30: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 74 79 70      {..      typ
6e40: 2e 54 79 70 65 20 3d 20 54 79 70 65 4e 61 6d 65  .Type = TypeName
6e50: 54 6f 44 62 54 79 70 65 28 73 74 6d 74 2e 5f 73  ToDbType(stmt._s
6e60: 71 6c 2e 43 6f 6c 75 6d 6e 54 79 70 65 28 73 74  ql.ColumnType(st
6e70: 6d 74 2c 20 69 2c 20 6f 75 74 20 74 79 70 2e 41  mt, i, out typ.A
6e80: 66 66 69 6e 69 74 79 29 29 3b 0d 0a 20 20 20 20  ffinity));..    
6e90: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  }....    /// <su
6ea0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
6eb0: 43 6f 6e 76 65 72 74 73 20 61 20 53 51 4c 69 74  Converts a SQLit
6ec0: 65 54 79 70 65 20 74 6f 20 61 20 2e 4e 45 54 20  eType to a .NET 
6ed0: 54 79 70 65 20 6f 62 6a 65 63 74 0d 0a 20 20 20  Type object..   
6ee0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
6ef0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
6f00: 6e 61 6d 65 3d 22 74 22 3e 54 68 65 20 53 51 4c  name="t">The SQL
6f10: 69 74 65 54 79 70 65 20 74 6f 20 63 6f 6e 76 65  iteType to conve
6f20: 72 74 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  rt</param>..    
6f30: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 52 65 74  /// <returns>Ret
6f40: 75 72 6e 73 20 61 20 2e 4e 45 54 20 54 79 70 65  urns a .NET Type
6f50: 20 6f 62 6a 65 63 74 3c 2f 72 65 74 75 72 6e 73   object</returns
6f60: 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  >..    internal 
6f70: 73 74 61 74 69 63 20 54 79 70 65 20 53 51 4c 69  static Type SQLi
6f80: 74 65 54 79 70 65 54 6f 54 79 70 65 28 53 51 4c  teTypeToType(SQL
6f90: 69 74 65 54 79 70 65 20 74 29 0d 0a 20 20 20 20  iteType t)..    
6fa0: 7b 0d 0a 20 20 20 20 20 20 69 66 20 28 74 2e 54  {..      if (t.T
6fb0: 79 70 65 20 3d 3d 20 44 62 54 79 70 65 2e 4f 62  ype == DbType.Ob
6fc0: 6a 65 63 74 29 0d 0a 20 20 20 20 20 20 20 20 72  ject)..        r
6fd0: 65 74 75 72 6e 20 5f 61 66 66 69 6e 69 74 79 74  eturn _affinityt
6fe0: 6f 74 79 70 65 5b 28 69 6e 74 29 74 2e 41 66 66  otype[(int)t.Aff
6ff0: 69 6e 69 74 79 5d 3b 0d 0a 20 20 20 20 20 20 65  inity];..      e
7000: 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 72 65 74  lse..        ret
7010: 75 72 6e 20 53 51 4c 69 74 65 43 6f 6e 76 65 72  urn SQLiteConver
7020: 74 2e 44 62 54 79 70 65 54 6f 54 79 70 65 28 74  t.DbTypeToType(t
7030: 2e 54 79 70 65 29 3b 0d 0a 20 20 20 20 7d 0d 0a  .Type);..    }..
7040: 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20 73 74  ..    private st
7050: 61 74 69 63 20 54 79 70 65 5b 5d 20 5f 61 66 66  atic Type[] _aff
7060: 69 6e 69 74 79 74 6f 74 79 70 65 20 3d 20 7b 0d  initytotype = {.
7070: 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 6f 62  .      typeof(ob
7080: 6a 65 63 74 29 2c 20 20 20 2f 2f 20 55 6e 69 6e  ject),   // Unin
7090: 69 74 69 61 6c 69 7a 65 64 20 28 30 29 0d 0a 20  itialized (0).. 
70a0: 20 20 20 20 20 74 79 70 65 6f 66 28 49 6e 74 36       typeof(Int6
70b0: 34 29 2c 20 20 20 20 2f 2f 20 49 6e 74 36 34 20  4),    // Int64 
70c0: 28 31 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f  (1)..      typeo
70d0: 66 28 44 6f 75 62 6c 65 29 2c 20 20 20 2f 2f 20  f(Double),   // 
70e0: 44 6f 75 62 6c 65 20 28 32 29 0d 0a 20 20 20 20  Double (2)..    
70f0: 20 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67 29    typeof(string)
7100: 2c 20 20 20 2f 2f 20 54 65 78 74 20 28 33 29 0d  ,   // Text (3).
7110: 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 62 79  .      typeof(by
7120: 74 65 5b 5d 29 2c 20 20 20 2f 2f 20 42 6c 6f 62  te[]),   // Blob
7130: 20 28 34 29 0d 0a 20 20 20 20 20 20 74 79 70 65   (4)..      type
7140: 6f 66 28 6f 62 6a 65 63 74 29 2c 20 20 20 2f 2f  of(object),   //
7150: 20 4e 75 6c 6c 20 28 35 29 0d 0a 20 20 20 20 20   Null (5)..     
7160: 20 74 79 70 65 6f 66 28 44 61 74 65 54 69 6d 65   typeof(DateTime
7170: 29 2c 20 2f 2f 20 44 61 74 65 54 69 6d 65 20 28  ), // DateTime (
7180: 31 30 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f  10)..      typeo
7190: 66 28 6f 62 6a 65 63 74 29 20 20 20 20 2f 2f 20  f(object)    // 
71a0: 4e 6f 6e 65 20 28 31 31 29 0d 0a 20 20 20 20 7d  None (11)..    }
71b0: 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  ;....    /// <su
71c0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
71d0: 46 6f 72 20 61 20 67 69 76 65 6e 20 69 6e 74 72  For a given intr
71e0: 69 6e 73 69 63 20 74 79 70 65 2c 20 72 65 74 75  insic type, retu
71f0: 72 6e 20 61 20 44 62 54 79 70 65 0d 0a 20 20 20  rn a DbType..   
7200: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
7210: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
7220: 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68 65 20 6e  name="typ">The n
7230: 61 74 69 76 65 20 74 79 70 65 20 74 6f 20 63 6f  ative type to co
7240: 6e 76 65 72 74 3c 2f 70 61 72 61 6d 3e 0d 0a 20  nvert</param>.. 
7250: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
7260: 54 68 65 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e  The correspondin
7270: 67 20 28 63 6c 6f 73 65 73 74 20 6d 61 74 63 68  g (closest match
7280: 29 20 44 62 54 79 70 65 3c 2f 72 65 74 75 72 6e  ) DbType</return
7290: 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  s>..    internal
72a0: 20 73 74 61 74 69 63 20 44 62 54 79 70 65 20 54   static DbType T
72b0: 79 70 65 54 6f 44 62 54 79 70 65 28 54 79 70 65  ypeToDbType(Type
72c0: 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d 0a 20 20   typ)..    {..  
72d0: 20 20 20 20 54 79 70 65 43 6f 64 65 20 74 63 20      TypeCode tc 
72e0: 3d 20 54 79 70 65 2e 47 65 74 54 79 70 65 43 6f  = Type.GetTypeCo
72f0: 64 65 28 74 79 70 29 3b 0d 0a 20 20 20 20 20 20  de(typ);..      
7300: 69 66 20 28 74 63 20 3d 3d 20 54 79 70 65 43 6f  if (tc == TypeCo
7310: 64 65 2e 4f 62 6a 65 63 74 29 0d 0a 20 20 20 20  de.Object)..    
7320: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20    {..        if 
7330: 28 74 79 70 20 3d 3d 20 74 79 70 65 6f 66 28 62  (typ == typeof(b
7340: 79 74 65 5b 5d 29 29 20 72 65 74 75 72 6e 20 44  yte[])) return D
7350: 62 54 79 70 65 2e 42 69 6e 61 72 79 3b 0d 0a 20  bType.Binary;.. 
7360: 20 20 20 20 20 20 20 69 66 20 28 74 79 70 20 3d         if (typ =
7370: 3d 20 74 79 70 65 6f 66 28 47 75 69 64 29 29 20  = typeof(Guid)) 
7380: 72 65 74 75 72 6e 20 44 62 54 79 70 65 2e 47 75  return DbType.Gu
7390: 69 64 3b 0d 0a 20 20 20 20 20 20 20 20 72 65 74  id;..        ret
73a0: 75 72 6e 20 44 62 54 79 70 65 2e 53 74 72 69 6e  urn DbType.Strin
73b0: 67 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  g;..      }..   
73c0: 20 20 20 72 65 74 75 72 6e 20 5f 74 79 70 65 74     return _typet
73d0: 6f 64 62 74 79 70 65 5b 28 69 6e 74 29 74 63 5d  odbtype[(int)tc]
73e0: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
73f0: 70 72 69 76 61 74 65 20 73 74 61 74 69 63 20 44  private static D
7400: 62 54 79 70 65 5b 5d 20 5f 74 79 70 65 74 6f 64  bType[] _typetod
7410: 62 74 79 70 65 20 3d 20 7b 0d 0a 20 20 20 20 20  btype = {..     
7420: 20 44 62 54 79 70 65 2e 4f 62 6a 65 63 74 2c 20   DbType.Object, 
7430: 20 20 2f 2f 20 45 6d 70 74 79 20 28 30 29 0d 0a    // Empty (0)..
7440: 20 20 20 20 20 20 44 62 54 79 70 65 2e 42 69 6e        DbType.Bin
7450: 61 72 79 2c 20 20 20 2f 2f 20 4f 62 6a 65 63 74  ary,   // Object
7460: 20 28 31 29 0d 0a 20 20 20 20 20 20 44 62 54 79   (1)..      DbTy
7470: 70 65 2e 4f 62 6a 65 63 74 2c 20 20 20 2f 2f 20  pe.Object,   // 
7480: 44 42 4e 75 6c 6c 20 28 32 29 0d 0a 20 20 20 20  DBNull (2)..    
7490: 20 20 44 62 54 79 70 65 2e 42 6f 6f 6c 65 61 6e    DbType.Boolean
74a0: 2c 20 20 2f 2f 20 42 6f 6f 6c 65 61 6e 20 28 33  ,  // Boolean (3
74b0: 29 0d 0a 20 20 20 20 20 20 44 62 54 79 70 65 2e  )..      DbType.
74c0: 53 42 79 74 65 2c 20 20 20 20 2f 2f 20 43 68 61  SByte,    // Cha
74d0: 72 20 28 34 29 0d 0a 20 20 20 20 20 20 44 62 54  r (4)..      DbT
74e0: 79 70 65 2e 53 42 79 74 65 2c 20 20 20 20 2f 2f  ype.SByte,    //
74f0: 20 53 42 79 74 65 20 28 35 29 0d 0a 20 20 20 20   SByte (5)..    
7500: 20 20 44 62 54 79 70 65 2e 42 79 74 65 2c 20 20    DbType.Byte,  
7510: 20 20 20 2f 2f 20 42 79 74 65 20 28 36 29 0d 0a     // Byte (6)..
7520: 20 20 20 20 20 20 44 62 54 79 70 65 2e 49 6e 74        DbType.Int
7530: 31 36 2c 20 20 20 20 2f 2f 20 49 6e 74 31 36 20  16,    // Int16 
7540: 28 37 29 0d 0a 20 20 20 20 20 20 44 62 54 79 70  (7)..      DbTyp
7550: 65 2e 55 49 6e 74 31 36 2c 20 20 20 2f 2f 20 55  e.UInt16,   // U
7560: 49 6e 74 31 36 20 28 38 29 0d 0a 20 20 20 20 20  Int16 (8)..     
7570: 20 44 62 54 79 70 65 2e 49 6e 74 33 32 2c 20 20   DbType.Int32,  
7580: 20 20 2f 2f 20 49 6e 74 33 32 20 28 39 29 0d 0a    // Int32 (9)..
7590: 20 20 20 20 20 20 44 62 54 79 70 65 2e 55 49 6e        DbType.UIn
75a0: 74 33 32 2c 20 20 20 2f 2f 20 55 49 6e 74 33 32  t32,   // UInt32
75b0: 20 28 31 30 29 0d 0a 20 20 20 20 20 20 44 62 54   (10)..      DbT
75c0: 79 70 65 2e 49 6e 74 36 34 2c 20 20 20 20 2f 2f  ype.Int64,    //
75d0: 20 49 6e 74 36 34 20 28 31 31 29 0d 0a 20 20 20   Int64 (11)..   
75e0: 20 20 20 44 62 54 79 70 65 2e 55 49 6e 74 36 34     DbType.UInt64
75f0: 2c 20 20 20 2f 2f 20 55 49 6e 74 36 34 20 28 31  ,   // UInt64 (1
7600: 32 29 0d 0a 20 20 20 20 20 20 44 62 54 79 70 65  2)..      DbType
7610: 2e 53 69 6e 67 6c 65 2c 20 20 20 2f 2f 20 53 69  .Single,   // Si
7620: 6e 67 6c 65 20 28 31 33 29 0d 0a 20 20 20 20 20  ngle (13)..     
7630: 20 44 62 54 79 70 65 2e 44 6f 75 62 6c 65 2c 20   DbType.Double, 
7640: 20 20 2f 2f 20 44 6f 75 62 6c 65 20 28 31 34 29    // Double (14)
7650: 0d 0a 20 20 20 20 20 20 44 62 54 79 70 65 2e 44  ..      DbType.D
7660: 65 63 69 6d 61 6c 2c 20 20 2f 2f 20 44 65 63 69  ecimal,  // Deci
7670: 6d 61 6c 20 28 31 35 29 0d 0a 20 20 20 20 20 20  mal (15)..      
7680: 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d 65 2c  DbType.DateTime,
7690: 20 2f 2f 20 44 61 74 65 54 69 6d 65 20 28 31 36   // DateTime (16
76a0: 29 0d 0a 20 20 20 20 20 20 44 62 54 79 70 65 2e  )..      DbType.
76b0: 4f 62 6a 65 63 74 2c 20 20 20 2f 2f 20 3f 3f 20  Object,   // ?? 
76c0: 28 31 37 29 0d 0a 20 20 20 20 20 20 44 62 54 79  (17)..      DbTy
76d0: 70 65 2e 53 74 72 69 6e 67 20 20 20 20 2f 2f 20  pe.String    // 
76e0: 53 74 72 69 6e 67 20 28 31 38 29 0d 0a 20 20 20  String (18)..   
76f0: 20 7d 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c   };....    /// <
7700: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
7710: 2f 20 52 65 74 75 72 6e 73 20 74 68 65 20 43 6f  / Returns the Co
7720: 6c 75 6d 6e 53 69 7a 65 20 66 6f 72 20 74 68 65  lumnSize for the
7730: 20 67 69 76 65 6e 20 44 62 54 79 70 65 0d 0a 20   given DbType.. 
7740: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
7750: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
7760: 6d 20 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68 65  m name="typ">The
7770: 20 44 62 54 79 70 65 20 74 6f 20 67 65 74 20 74   DbType to get t
7780: 68 65 20 73 69 7a 65 20 6f 66 3c 2f 70 61 72 61  he size of</para
7790: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74  m>..    /// <ret
77a0: 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73 3e 0d  urns></returns>.
77b0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
77c0: 61 74 69 63 20 69 6e 74 20 44 62 54 79 70 65 54  atic int DbTypeT
77d0: 6f 43 6f 6c 75 6d 6e 53 69 7a 65 28 44 62 54 79  oColumnSize(DbTy
77e0: 70 65 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d 0a  pe typ)..    {..
77f0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 64 62        return _db
7800: 74 79 70 65 74 6f 63 6f 6c 75 6d 6e 73 69 7a 65  typetocolumnsize
7810: 5b 28 69 6e 74 29 74 79 70 5d 3b 0d 0a 20 20 20  [(int)typ];..   
7820: 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69 76 61 74   }....    privat
7830: 65 20 73 74 61 74 69 63 20 69 6e 74 5b 5d 20 5f  e static int[] _
7840: 64 62 74 79 70 65 74 6f 63 6f 6c 75 6d 6e 73 69  dbtypetocolumnsi
7850: 7a 65 20 3d 20 7b 0d 0a 20 20 20 20 20 20 69 6e  ze = {..      in
7860: 74 2e 4d 61 78 56 61 6c 75 65 2c 20 2f 2f 20 41  t.MaxValue, // A
7870: 6e 73 69 53 74 72 69 6e 67 20 28 30 29 0d 0a 20  nsiString (0).. 
7880: 20 20 20 20 20 69 6e 74 2e 4d 61 78 56 61 6c 75       int.MaxValu
7890: 65 2c 20 2f 2f 20 42 69 6e 61 72 79 20 28 31 29  e, // Binary (1)
78a0: 0d 0a 20 20 20 20 20 20 31 2c 20 20 20 20 20 20  ..      1,      
78b0: 20 20 20 20 20 20 2f 2f 20 42 79 74 65 20 28 32        // Byte (2
78c0: 29 0d 0a 20 20 20 20 20 20 31 2c 20 20 20 20 20  )..      1,     
78d0: 20 20 20 20 20 20 20 2f 2f 20 42 6f 6f 6c 65 61         // Boolea
78e0: 6e 20 28 33 29 0d 0a 20 20 20 20 20 20 38 2c 20  n (3)..      8, 
78f0: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 43 75             // Cu
7900: 72 72 65 6e 63 79 20 28 34 29 0d 0a 20 20 20 20  rrency (4)..    
7910: 20 20 38 2c 20 20 20 20 20 20 20 20 20 20 20 20    8,            
7920: 2f 2f 20 44 61 74 65 20 28 35 29 0d 0a 20 20 20  // Date (5)..   
7930: 20 20 20 38 2c 20 20 20 20 20 20 20 20 20 20 20     8,           
7940: 20 2f 2f 20 44 61 74 65 54 69 6d 65 20 28 36 29   // DateTime (6)
7950: 0d 0a 20 20 20 20 20 20 38 2c 20 20 20 20 20 20  ..      8,      
7960: 20 20 20 20 20 20 2f 2f 20 44 65 63 69 6d 61 6c        // Decimal
7970: 20 28 37 29 0d 0a 20 20 20 20 20 20 38 2c 20 20   (7)..      8,  
7980: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 44 6f 75            // Dou
7990: 62 6c 65 20 28 38 29 0d 0a 20 20 20 20 20 20 31  ble (8)..      1
79a0: 36 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20  6,           // 
79b0: 47 75 69 64 20 28 39 29 0d 0a 20 20 20 20 20 20  Guid (9)..      
79c0: 32 2c 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f  2,            //
79d0: 20 49 6e 74 31 36 20 28 31 30 29 0d 0a 20 20 20   Int16 (10)..   
79e0: 20 20 20 34 2c 20 20 20 20 20 20 20 20 20 20 20     4,           
79f0: 20 2f 2f 20 49 6e 74 33 32 20 28 31 31 29 0d 0a   // Int32 (11)..
7a00: 20 20 20 20 20 20 38 2c 20 20 20 20 20 20 20 20        8,        
7a10: 20 20 20 20 2f 2f 20 49 6e 74 36 34 20 28 31 32      // Int64 (12
7a20: 29 0d 0a 20 20 20 20 20 20 69 6e 74 2e 4d 61 78  )..      int.Max
7a30: 56 61 6c 75 65 2c 20 2f 2f 20 4f 62 6a 65 63 74  Value, // Object
7a40: 20 28 31 33 29 0d 0a 20 20 20 20 20 20 31 2c 20   (13)..      1, 
7a50: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 53 42             // SB
7a60: 79 74 65 20 28 31 34 29 0d 0a 20 20 20 20 20 20  yte (14)..      
7a70: 34 2c 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f  4,            //
7a80: 20 53 69 6e 67 6c 65 20 28 31 35 29 0d 0a 20 20   Single (15)..  
7a90: 20 20 20 20 69 6e 74 2e 4d 61 78 56 61 6c 75 65      int.MaxValue
7aa0: 2c 20 2f 2f 20 53 74 72 69 6e 67 20 28 31 36 29  , // String (16)
7ab0: 0d 0a 20 20 20 20 20 20 38 2c 20 20 20 20 20 20  ..      8,      
7ac0: 20 20 20 20 20 20 2f 2f 20 54 69 6d 65 20 28 31        // Time (1
7ad0: 37 29 0d 0a 20 20 20 20 20 20 32 2c 20 20 20 20  7)..      2,    
7ae0: 20 20 20 20 20 20 20 20 2f 2f 20 55 49 6e 74 31          // UInt1
7af0: 36 20 28 31 38 29 0d 0a 20 20 20 20 20 20 34 2c  6 (18)..      4,
7b00: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 55              // U
7b10: 49 6e 74 33 32 20 28 31 39 29 0d 0a 20 20 20 20  Int32 (19)..    
7b20: 20 20 38 2c 20 20 20 20 20 20 20 20 20 20 20 20    8,            
7b30: 2f 2f 20 55 49 6e 74 36 34 20 28 32 30 29 0d 0a  // UInt64 (20)..
7b40: 20 20 20 20 20 20 38 2c 20 20 20 20 20 20 20 20        8,        
7b50: 20 20 20 20 2f 2f 20 56 61 72 4e 75 6d 65 72 69      // VarNumeri
7b60: 63 20 28 32 31 29 0d 0a 20 20 20 20 20 20 69 6e  c (21)..      in
7b70: 74 2e 4d 61 78 56 61 6c 75 65 2c 20 2f 2f 20 41  t.MaxValue, // A
7b80: 6e 73 69 53 74 72 69 6e 67 46 69 78 65 64 4c 65  nsiStringFixedLe
7b90: 6e 67 74 68 20 28 32 32 29 0d 0a 20 20 20 20 20  ngth (22)..     
7ba0: 20 69 6e 74 2e 4d 61 78 56 61 6c 75 65 2c 20 2f   int.MaxValue, /
7bb0: 2f 20 53 74 72 69 6e 67 46 69 78 65 64 4c 65 6e  / StringFixedLen
7bc0: 67 74 68 20 28 32 33 29 0d 0a 20 20 20 20 20 20  gth (23)..      
7bd0: 69 6e 74 2e 4d 61 78 56 61 6c 75 65 2c 20 2f 2f  int.MaxValue, //
7be0: 20 3f 3f 20 28 32 34 29 0d 0a 20 20 20 20 20 20   ?? (24)..      
7bf0: 69 6e 74 2e 4d 61 78 56 61 6c 75 65 20 20 2f 2f  int.MaxValue  //
7c00: 20 58 6d 6c 20 28 32 35 29 0d 0a 20 20 20 20 7d   Xml (25)..    }
7c10: 3b 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  ;....    interna
7c20: 6c 20 73 74 61 74 69 63 20 6f 62 6a 65 63 74 20  l static object 
7c30: 44 62 54 79 70 65 54 6f 4e 75 6d 65 72 69 63 50  DbTypeToNumericP
7c40: 72 65 63 69 73 69 6f 6e 28 44 62 54 79 70 65 20  recision(DbType 
7c50: 74 79 70 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  typ)..    {..   
7c60: 20 20 20 72 65 74 75 72 6e 20 5f 64 62 74 79 70     return _dbtyp
7c70: 65 74 6f 6e 75 6d 65 72 69 63 70 72 65 63 69 73  etonumericprecis
7c80: 69 6f 6e 5b 28 69 6e 74 29 74 79 70 5d 3b 0d 0a  ion[(int)typ];..
7c90: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69      }....    pri
7ca0: 76 61 74 65 20 73 74 61 74 69 63 20 6f 62 6a 65  vate static obje
7cb0: 63 74 5b 5d 20 5f 64 62 74 79 70 65 74 6f 6e 75  ct[] _dbtypetonu
7cc0: 6d 65 72 69 63 70 72 65 63 69 73 69 6f 6e 20 3d  mericprecision =
7cd0: 20 7b 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c   {..      DBNull
7ce0: 2e 56 61 6c 75 65 2c 20 2f 2f 20 41 6e 73 69 53  .Value, // AnsiS
7cf0: 74 72 69 6e 67 20 28 30 29 0d 0a 20 20 20 20 20  tring (0)..     
7d00: 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f   DBNull.Value, /
7d10: 2f 20 42 69 6e 61 72 79 20 28 31 29 0d 0a 20 20  / Binary (1)..  
7d20: 20 20 20 20 33 2c 20 20 20 20 20 20 20 20 20 20      3,          
7d30: 20 20 2f 2f 20 42 79 74 65 20 28 32 29 0d 0a 20    // Byte (2).. 
7d40: 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75       DBNull.Valu
7d50: 65 2c 20 2f 2f 20 42 6f 6f 6c 65 61 6e 20 28 33  e, // Boolean (3
7d60: 29 0d 0a 20 20 20 20 20 20 31 39 2c 20 20 20 20  )..      19,    
7d70: 20 20 20 20 20 20 20 2f 2f 20 43 75 72 72 65 6e         // Curren
7d80: 63 79 20 28 34 29 0d 0a 20 20 20 20 20 20 44 42  cy (4)..      DB
7d90: 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 44  Null.Value, // D
7da0: 61 74 65 20 28 35 29 0d 0a 20 20 20 20 20 20 44  ate (5)..      D
7db0: 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20  BNull.Value, // 
7dc0: 44 61 74 65 54 69 6d 65 20 28 36 29 0d 0a 20 20  DateTime (6)..  
7dd0: 20 20 20 20 35 33 2c 20 20 20 20 20 20 20 20 20      53,         
7de0: 20 20 2f 2f 20 44 65 63 69 6d 61 6c 20 28 37 29    // Decimal (7)
7df0: 0d 0a 20 20 20 20 20 20 35 33 2c 20 20 20 20 20  ..      53,     
7e00: 20 20 20 20 20 20 2f 2f 20 44 6f 75 62 6c 65 20        // Double 
7e10: 28 38 29 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c  (8)..      DBNul
7e20: 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 47 75 69 64  l.Value, // Guid
7e30: 20 28 39 29 0d 0a 20 20 20 20 20 20 35 2c 20 20   (9)..      5,  
7e40: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 49 6e 74            // Int
7e50: 31 36 20 28 31 30 29 0d 0a 20 20 20 20 20 20 31  16 (10)..      1
7e60: 30 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20  0,           // 
7e70: 49 6e 74 33 32 20 28 31 31 29 0d 0a 20 20 20 20  Int32 (11)..    
7e80: 20 20 31 39 2c 20 20 20 20 20 20 20 20 20 20 20    19,           
7e90: 2f 2f 20 49 6e 74 36 34 20 28 31 32 29 0d 0a 20  // Int64 (12).. 
7ea0: 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75       DBNull.Valu
7eb0: 65 2c 20 2f 2f 20 4f 62 6a 65 63 74 20 28 31 33  e, // Object (13
7ec0: 29 0d 0a 20 20 20 20 20 20 33 2c 20 20 20 20 20  )..      3,     
7ed0: 20 20 20 20 20 20 20 2f 2f 20 53 42 79 74 65 20         // SByte 
7ee0: 28 31 34 29 0d 0a 20 20 20 20 20 20 32 34 2c 20  (14)..      24, 
7ef0: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 53 69 6e            // Sin
7f00: 67 6c 65 20 28 31 35 29 0d 0a 20 20 20 20 20 20  gle (15)..      
7f10: 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f  DBNull.Value, //
7f20: 20 53 74 72 69 6e 67 20 28 31 36 29 0d 0a 20 20   String (16)..  
7f30: 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65      DBNull.Value
7f40: 2c 20 2f 2f 20 54 69 6d 65 20 28 31 37 29 0d 0a  , // Time (17)..
7f50: 20 20 20 20 20 20 35 2c 20 20 20 20 20 20 20 20        5,        
7f60: 20 20 20 20 2f 2f 20 55 49 6e 74 31 36 20 28 31      // UInt16 (1
7f70: 38 29 0d 0a 20 20 20 20 20 20 31 30 2c 20 20 20  8)..      10,   
7f80: 20 20 20 20 20 20 20 20 2f 2f 20 55 49 6e 74 33          // UInt3
7f90: 32 20 28 31 39 29 0d 0a 20 20 20 20 20 20 31 39  2 (19)..      19
7fa0: 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 55  ,           // U
7fb0: 49 6e 74 36 34 20 28 32 30 29 0d 0a 20 20 20 20  Int64 (20)..    
7fc0: 20 20 35 33 2c 20 20 20 20 20 20 20 20 20 20 20    53,           
7fd0: 2f 2f 20 56 61 72 4e 75 6d 65 72 69 63 20 28 32  // VarNumeric (2
7fe0: 31 29 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c  1)..      DBNull
7ff0: 2e 56 61 6c 75 65 2c 20 2f 2f 20 41 6e 73 69 53  .Value, // AnsiS
8000: 74 72 69 6e 67 46 69 78 65 64 4c 65 6e 67 74 68  tringFixedLength
8010: 20 28 32 32 29 0d 0a 20 20 20 20 20 20 44 42 4e   (22)..      DBN
8020: 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 53 74  ull.Value, // St
8030: 72 69 6e 67 46 69 78 65 64 4c 65 6e 67 74 68 20  ringFixedLength 
8040: 28 32 33 29 0d 0a 20 20 20 20 20 20 44 42 4e 75  (23)..      DBNu
8050: 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 3f 3f 20  ll.Value, // ?? 
8060: 28 32 34 29 0d 0a 20 20 20 20 20 20 44 42 4e 75  (24)..      DBNu
8070: 6c 6c 2e 56 61 6c 75 65 20 20 2f 2f 20 58 6d 6c  ll.Value  // Xml
8080: 20 28 32 35 29 0d 0a 20 20 20 20 7d 3b 0d 0a 0d   (25)..    };...
8090: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
80a0: 61 74 69 63 20 6f 62 6a 65 63 74 20 44 62 54 79  atic object DbTy
80b0: 70 65 54 6f 4e 75 6d 65 72 69 63 53 63 61 6c 65  peToNumericScale
80c0: 28 44 62 54 79 70 65 20 74 79 70 29 0d 0a 20 20  (DbType typ)..  
80d0: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72    {..      retur
80e0: 6e 20 5f 64 62 74 79 70 65 74 6f 6e 75 6d 65 72  n _dbtypetonumer
80f0: 69 63 73 63 61 6c 65 5b 28 69 6e 74 29 74 79 70  icscale[(int)typ
8100: 5d 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  ];..    }....   
8110: 20 70 72 69 76 61 74 65 20 73 74 61 74 69 63 20   private static 
8120: 6f 62 6a 65 63 74 5b 5d 20 5f 64 62 74 79 70 65  object[] _dbtype
8130: 74 6f 6e 75 6d 65 72 69 63 73 63 61 6c 65 20 3d  tonumericscale =
8140: 20 7b 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c   {..      DBNull
8150: 2e 56 61 6c 75 65 2c 20 2f 2f 20 41 6e 73 69 53  .Value, // AnsiS
8160: 74 72 69 6e 67 20 28 30 29 0d 0a 20 20 20 20 20  tring (0)..     
8170: 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f   DBNull.Value, /
8180: 2f 20 42 69 6e 61 72 79 20 28 31 29 0d 0a 20 20  / Binary (1)..  
8190: 20 20 20 20 30 2c 20 20 20 20 20 20 20 20 20 20      0,          
81a0: 20 20 2f 2f 20 42 79 74 65 20 28 32 29 0d 0a 20    // Byte (2).. 
81b0: 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75       DBNull.Valu
81c0: 65 2c 20 2f 2f 20 42 6f 6f 6c 65 61 6e 20 28 33  e, // Boolean (3
81d0: 29 0d 0a 20 20 20 20 20 20 34 2c 20 20 20 20 20  )..      4,     
81e0: 20 20 20 20 20 20 20 2f 2f 20 43 75 72 72 65 6e         // Curren
81f0: 63 79 20 28 34 29 0d 0a 20 20 20 20 20 20 44 42  cy (4)..      DB
8200: 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 44  Null.Value, // D
8210: 61 74 65 20 28 35 29 0d 0a 20 20 20 20 20 20 44  ate (5)..      D
8220: 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20  BNull.Value, // 
8230: 44 61 74 65 54 69 6d 65 20 28 36 29 0d 0a 20 20  DateTime (6)..  
8240: 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65      DBNull.Value
8250: 2c 20 2f 2f 20 44 65 63 69 6d 61 6c 20 28 37 29  , // Decimal (7)
8260: 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56  ..      DBNull.V
8270: 61 6c 75 65 2c 20 2f 2f 20 44 6f 75 62 6c 65 20  alue, // Double 
8280: 28 38 29 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c  (8)..      DBNul
8290: 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 47 75 69 64  l.Value, // Guid
82a0: 20 28 39 29 0d 0a 20 20 20 20 20 20 30 2c 20 20   (9)..      0,  
82b0: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 49 6e 74            // Int
82c0: 31 36 20 28 31 30 29 0d 0a 20 20 20 20 20 20 30  16 (10)..      0
82d0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20  ,            // 
82e0: 49 6e 74 33 32 20 28 31 31 29 0d 0a 20 20 20 20  Int32 (11)..    
82f0: 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20    0,            
8300: 2f 2f 20 49 6e 74 36 34 20 28 31 32 29 0d 0a 20  // Int64 (12).. 
8310: 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75       DBNull.Valu
8320: 65 2c 20 2f 2f 20 4f 62 6a 65 63 74 20 28 31 33  e, // Object (13
8330: 29 0d 0a 20 20 20 20 20 20 30 2c 20 20 20 20 20  )..      0,     
8340: 20 20 20 20 20 20 20 2f 2f 20 53 42 79 74 65 20         // SByte 
8350: 28 31 34 29 0d 0a 20 20 20 20 20 20 44 42 4e 75  (14)..      DBNu
8360: 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 53 69 6e  ll.Value, // Sin
8370: 67 6c 65 20 28 31 35 29 0d 0a 20 20 20 20 20 20  gle (15)..      
8380: 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f  DBNull.Value, //
8390: 20 53 74 72 69 6e 67 20 28 31 36 29 0d 0a 20 20   String (16)..  
83a0: 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65      DBNull.Value
83b0: 2c 20 2f 2f 20 54 69 6d 65 20 28 31 37 29 0d 0a  , // Time (17)..
83c0: 20 20 20 20 20 20 30 2c 20 20 20 20 20 20 20 20        0,        
83d0: 20 20 20 20 2f 2f 20 55 49 6e 74 31 36 20 28 31      // UInt16 (1
83e0: 38 29 0d 0a 20 20 20 20 20 20 30 2c 20 20 20 20  8)..      0,    
83f0: 20 20 20 20 20 20 20 20 2f 2f 20 55 49 6e 74 33          // UInt3
8400: 32 20 28 31 39 29 0d 0a 20 20 20 20 20 20 30 2c  2 (19)..      0,
8410: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 55              // U
8420: 49 6e 74 36 34 20 28 32 30 29 0d 0a 20 20 20 20  Int64 (20)..    
8430: 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20    0,            
8440: 2f 2f 20 56 61 72 4e 75 6d 65 72 69 63 20 28 32  // VarNumeric (2
8450: 31 29 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c  1)..      DBNull
8460: 2e 56 61 6c 75 65 2c 20 2f 2f 20 41 6e 73 69 53  .Value, // AnsiS
8470: 74 72 69 6e 67 46 69 78 65 64 4c 65 6e 67 74 68  tringFixedLength
8480: 20 28 32 32 29 0d 0a 20 20 20 20 20 20 44 42 4e   (22)..      DBN
8490: 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 53 74  ull.Value, // St
84a0: 72 69 6e 67 46 69 78 65 64 4c 65 6e 67 74 68 20  ringFixedLength 
84b0: 28 32 33 29 0d 0a 20 20 20 20 20 20 44 42 4e 75  (23)..      DBNu
84c0: 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 3f 3f 20  ll.Value, // ?? 
84d0: 28 32 34 29 0d 0a 20 20 20 20 20 20 44 42 4e 75  (24)..      DBNu
84e0: 6c 6c 2e 56 61 6c 75 65 20 20 2f 2f 20 58 6d 6c  ll.Value  // Xml
84f0: 20 28 32 35 29 0d 0a 20 20 20 20 7d 3b 0d 0a 0d   (25)..    };...
8500: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
8510: 61 74 69 63 20 73 74 72 69 6e 67 20 44 62 54 79  atic string DbTy
8520: 70 65 54 6f 54 79 70 65 4e 61 6d 65 28 44 62 54  peToTypeName(DbT
8530: 79 70 65 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d  ype typ)..    {.
8540: 0a 20 20 20 20 20 20 20 20 6c 6f 63 6b 20 28 5f  .        lock (_
8550: 73 79 6e 63 52 6f 6f 74 29 0d 0a 20 20 20 20 20  syncRoot)..     
8560: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
8570: 20 20 69 66 20 28 5f 74 79 70 65 4e 61 6d 65 73    if (_typeNames
8580: 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20   == null)..     
8590: 20 20 20 20 20 20 20 20 20 20 20 5f 74 79 70 65             _type
85a0: 4e 61 6d 65 73 20 3d 20 47 65 74 53 51 4c 69 74  Names = GetSQLit
85b0: 65 44 62 54 79 70 65 4d 61 70 28 29 3b 0d 0a 0d  eDbTypeMap();...
85c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c  .            SQL
85d0: 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67  iteDbTypeMapping
85e0: 20 76 61 6c 75 65 3b 0d 0a 0d 0a 20 20 20 20 20   value;....     
85f0: 20 20 20 20 20 20 20 69 66 20 28 5f 74 79 70 65         if (_type
8600: 4e 61 6d 65 73 2e 54 72 79 47 65 74 56 61 6c 75  Names.TryGetValu
8610: 65 28 74 79 70 2c 20 6f 75 74 20 76 61 6c 75 65  e(typ, out value
8620: 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ))..            
8630: 20 20 20 20 72 65 74 75 72 6e 20 76 61 6c 75 65      return value
8640: 2e 74 79 70 65 4e 61 6d 65 3b 0d 0a 20 20 20 20  .typeName;..    
8650: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20      }....       
8660: 20 73 74 72 69 6e 67 20 64 65 66 61 75 6c 74 54   string defaultT
8670: 79 70 65 4e 61 6d 65 20 3d 20 53 74 72 69 6e 67  ypeName = String
8680: 2e 45 6d 70 74 79 3b 0d 0a 0d 0a 23 69 66 20 21  .Empty;....#if !
8690: 4e 45 54 5f 43 4f 4d 50 41 43 54 5f 32 30 20 26  NET_COMPACT_20 &
86a0: 26 20 54 52 41 43 45 5f 57 41 52 4e 49 4e 47 0d  & TRACE_WARNING.
86b0: 0a 20 20 20 20 20 20 20 20 54 72 61 63 65 2e 57  .        Trace.W
86c0: 72 69 74 65 4c 69 6e 65 28 53 74 72 69 6e 67 2e  riteLine(String.
86d0: 46 6f 72 6d 61 74 28 0d 0a 20 20 20 20 20 20 20  Format(..       
86e0: 20 20 20 20 20 22 57 41 52 4e 49 4e 47 3a 20 54       "WARNING: T
86f0: 79 70 65 20 6d 61 70 70 69 6e 67 20 66 61 69 6c  ype mapping fail
8700: 65 64 2c 20 72 65 74 75 72 6e 69 6e 67 20 64 65  ed, returning de
8710: 66 61 75 6c 74 20 6e 61 6d 65 20 5c 22 7b 30 7d  fault name \"{0}
8720: 5c 22 20 66 6f 72 20 74 79 70 65 20 7b 31 7d 2e  \" for type {1}.
8730: 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ",..            
8740: 64 65 66 61 75 6c 74 54 79 70 65 4e 61 6d 65 2c  defaultTypeName,
8750: 20 74 79 70 29 29 3b 0d 0a 23 65 6e 64 69 66 0d   typ));..#endif.
8760: 0a 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  ...        retur
8770: 6e 20 64 65 66 61 75 6c 74 54 79 70 65 4e 61 6d  n defaultTypeNam
8780: 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  e;..    }....   
8790: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
87a0: 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 20      /// Convert 
87b0: 61 20 44 62 54 79 70 65 20 74 6f 20 61 20 54 79  a DbType to a Ty
87c0: 70 65 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  pe..    /// </su
87d0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
87e0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 74 79 70  <param name="typ
87f0: 22 3e 54 68 65 20 44 62 54 79 70 65 20 74 6f 20  ">The DbType to 
8800: 63 6f 6e 76 65 72 74 20 66 72 6f 6d 3c 2f 70 61  convert from</pa
8810: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72  ram>..    /// <r
8820: 65 74 75 72 6e 73 3e 54 68 65 20 63 6c 6f 73 65  eturns>The close
8830: 73 74 2d 6d 61 74 63 68 20 2e 4e 45 54 20 74 79  st-match .NET ty
8840: 70 65 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20  pe</returns>..  
8850: 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69    internal stati
8860: 63 20 54 79 70 65 20 44 62 54 79 70 65 54 6f 54  c Type DbTypeToT
8870: 79 70 65 28 44 62 54 79 70 65 20 74 79 70 29 0d  ype(DbType typ).
8880: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65  .    {..      re
8890: 74 75 72 6e 20 5f 64 62 74 79 70 65 54 6f 54 79  turn _dbtypeToTy
88a0: 70 65 5b 28 69 6e 74 29 74 79 70 5d 3b 0d 0a 20  pe[(int)typ];.. 
88b0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69 76     }....    priv
88c0: 61 74 65 20 73 74 61 74 69 63 20 54 79 70 65 5b  ate static Type[
88d0: 5d 20 5f 64 62 74 79 70 65 54 6f 54 79 70 65 20  ] _dbtypeToType 
88e0: 3d 20 7b 0d 0a 20 20 20 20 20 20 74 79 70 65 6f  = {..      typeo
88f0: 66 28 73 74 72 69 6e 67 29 2c 20 20 20 2f 2f 20  f(string),   // 
8900: 41 6e 73 69 53 74 72 69 6e 67 20 28 30 29 0d 0a  AnsiString (0)..
8910: 20 20 20 20 20 20 74 79 70 65 6f 66 28 62 79 74        typeof(byt
8920: 65 5b 5d 29 2c 20 20 20 2f 2f 20 42 69 6e 61 72  e[]),   // Binar
8930: 79 20 28 31 29 0d 0a 20 20 20 20 20 20 74 79 70  y (1)..      typ
8940: 65 6f 66 28 62 79 74 65 29 2c 20 20 20 20 20 2f  eof(byte),     /
8950: 2f 20 42 79 74 65 20 28 32 29 0d 0a 20 20 20 20  / Byte (2)..    
8960: 20 20 74 79 70 65 6f 66 28 62 6f 6f 6c 29 2c 20    typeof(bool), 
8970: 20 20 20 20 2f 2f 20 42 6f 6f 6c 65 61 6e 20 28      // Boolean (
8980: 33 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66  3)..      typeof
8990: 28 64 65 63 69 6d 61 6c 29 2c 20 20 2f 2f 20 43  (decimal),  // C
89a0: 75 72 72 65 6e 63 79 20 28 34 29 0d 0a 20 20 20  urrency (4)..   
89b0: 20 20 20 74 79 70 65 6f 66 28 44 61 74 65 54 69     typeof(DateTi
89c0: 6d 65 29 2c 20 2f 2f 20 44 61 74 65 20 28 35 29  me), // Date (5)
89d0: 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 44  ..      typeof(D
89e0: 61 74 65 54 69 6d 65 29 2c 20 2f 2f 20 44 61 74  ateTime), // Dat
89f0: 65 54 69 6d 65 20 28 36 29 0d 0a 20 20 20 20 20  eTime (6)..     
8a00: 20 74 79 70 65 6f 66 28 64 65 63 69 6d 61 6c 29   typeof(decimal)
8a10: 2c 20 20 2f 2f 20 44 65 63 69 6d 61 6c 20 28 37  ,  // Decimal (7
8a20: 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  )..      typeof(
8a30: 64 6f 75 62 6c 65 29 2c 20 20 20 2f 2f 20 44 6f  double),   // Do
8a40: 75 62 6c 65 20 28 38 29 0d 0a 20 20 20 20 20 20  uble (8)..      
8a50: 74 79 70 65 6f 66 28 47 75 69 64 29 2c 20 20 20  typeof(Guid),   
8a60: 20 20 2f 2f 20 47 75 69 64 20 28 39 29 0d 0a 20    // Guid (9).. 
8a70: 20 20 20 20 20 74 79 70 65 6f 66 28 49 6e 74 31       typeof(Int1
8a80: 36 29 2c 20 20 20 20 2f 2f 20 49 6e 74 31 36 20  6),    // Int16 
8a90: 28 31 30 29 0d 0a 20 20 20 20 20 20 74 79 70 65  (10)..      type
8aa0: 6f 66 28 49 6e 74 33 32 29 2c 20 20 20 20 2f 2f  of(Int32),    //
8ab0: 20 49 6e 74 33 32 20 28 31 31 29 0d 0a 20 20 20   Int32 (11)..   
8ac0: 20 20 20 74 79 70 65 6f 66 28 49 6e 74 36 34 29     typeof(Int64)
8ad0: 2c 20 20 20 20 2f 2f 20 49 6e 74 36 34 20 28 31  ,    // Int64 (1
8ae0: 32 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66  2)..      typeof
8af0: 28 6f 62 6a 65 63 74 29 2c 20 20 20 2f 2f 20 4f  (object),   // O
8b00: 62 6a 65 63 74 20 28 31 33 29 0d 0a 20 20 20 20  bject (13)..    
8b10: 20 20 74 79 70 65 6f 66 28 73 62 79 74 65 29 2c    typeof(sbyte),
8b20: 20 20 20 20 2f 2f 20 53 42 79 74 65 20 28 31 34      // SByte (14
8b30: 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  )..      typeof(
8b40: 66 6c 6f 61 74 29 2c 20 20 20 20 2f 2f 20 53 69  float),    // Si
8b50: 6e 67 6c 65 20 28 31 35 29 0d 0a 20 20 20 20 20  ngle (15)..     
8b60: 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67 29 2c   typeof(string),
8b70: 20 20 20 2f 2f 20 53 74 72 69 6e 67 20 28 31 36     // String (16
8b80: 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  )..      typeof(
8b90: 44 61 74 65 54 69 6d 65 29 2c 20 2f 2f 20 54 69  DateTime), // Ti
8ba0: 6d 65 20 28 31 37 29 0d 0a 20 20 20 20 20 20 74  me (17)..      t
8bb0: 79 70 65 6f 66 28 55 49 6e 74 31 36 29 2c 20 20  ypeof(UInt16),  
8bc0: 20 2f 2f 20 55 49 6e 74 31 36 20 28 31 38 29 0d   // UInt16 (18).
8bd0: 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 55 49  .      typeof(UI
8be0: 6e 74 33 32 29 2c 20 20 20 2f 2f 20 55 49 6e 74  nt32),   // UInt
8bf0: 33 32 20 28 31 39 29 0d 0a 20 20 20 20 20 20 74  32 (19)..      t
8c00: 79 70 65 6f 66 28 55 49 6e 74 36 34 29 2c 20 20  ypeof(UInt64),  
8c10: 20 2f 2f 20 55 49 6e 74 36 34 20 28 32 30 29 0d   // UInt64 (20).
8c20: 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 64 6f  .      typeof(do
8c30: 75 62 6c 65 29 2c 20 20 20 2f 2f 20 56 61 72 4e  uble),   // VarN
8c40: 75 6d 65 72 69 63 20 28 32 31 29 0d 0a 20 20 20  umeric (21)..   
8c50: 20 20 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67     typeof(string
8c60: 29 2c 20 20 20 2f 2f 20 41 6e 73 69 53 74 72 69  ),   // AnsiStri
8c70: 6e 67 46 69 78 65 64 4c 65 6e 67 74 68 20 28 32  ngFixedLength (2
8c80: 32 29 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66  2)..      typeof
8c90: 28 73 74 72 69 6e 67 29 2c 20 20 20 2f 2f 20 53  (string),   // S
8ca0: 74 72 69 6e 67 46 69 78 65 64 4c 65 6e 67 74 68  tringFixedLength
8cb0: 20 28 32 33 29 0d 0a 20 20 20 20 20 20 74 79 70   (23)..      typ
8cc0: 65 6f 66 28 73 74 72 69 6e 67 29 2c 20 20 20 2f  eof(string),   /
8cd0: 2f 20 3f 3f 20 28 32 34 29 0d 0a 20 20 20 20 20  / ?? (24)..     
8ce0: 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67 29 2c   typeof(string),
8cf0: 20 20 20 2f 2f 20 58 6d 6c 20 28 32 35 29 0d 0a     // Xml (25)..
8d00: 20 20 20 20 7d 3b 0d 0a 0d 0a 20 20 20 20 2f 2f      };....    //
8d10: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
8d20: 20 2f 2f 2f 20 46 6f 72 20 61 20 67 69 76 65 6e   /// For a given
8d30: 20 74 79 70 65 2c 20 72 65 74 75 72 6e 20 74 68   type, return th
8d40: 65 20 63 6c 6f 73 65 73 74 2d 6d 61 74 63 68 20  e closest-match 
8d50: 53 51 4c 69 74 65 20 54 79 70 65 41 66 66 69 6e  SQLite TypeAffin
8d60: 69 74 79 2c 20 77 68 69 63 68 20 6f 6e 6c 79 20  ity, which only 
8d70: 75 6e 64 65 72 73 74 61 6e 64 73 20 61 20 76 65  understands a ve
8d80: 72 79 20 6c 69 6d 69 74 65 64 20 73 75 62 73 65  ry limited subse
8d90: 74 20 6f 66 20 74 79 70 65 73 2e 0d 0a 20 20 20  t of types...   
8da0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
8db0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
8dc0: 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68 65 20 74  name="typ">The t
8dd0: 79 70 65 20 74 6f 20 65 76 61 6c 75 61 74 65 3c  ype to evaluate<
8de0: 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  /param>..    ///
8df0: 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20 53 51   <returns>The SQ
8e00: 4c 69 74 65 20 74 79 70 65 20 61 66 66 69 6e 69  Lite type affini
8e10: 74 79 20 66 6f 72 20 74 68 61 74 20 74 79 70 65  ty for that type
8e20: 2e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20  .</returns>..   
8e30: 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69 63   internal static
8e40: 20 54 79 70 65 41 66 66 69 6e 69 74 79 20 54 79   TypeAffinity Ty
8e50: 70 65 54 6f 41 66 66 69 6e 69 74 79 28 54 79 70  peToAffinity(Typ
8e60: 65 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d 0a 20  e typ)..    {.. 
8e70: 20 20 20 20 20 54 79 70 65 43 6f 64 65 20 74 63       TypeCode tc
8e80: 20 3d 20 54 79 70 65 2e 47 65 74 54 79 70 65 43   = Type.GetTypeC
8e90: 6f 64 65 28 74 79 70 29 3b 0d 0a 20 20 20 20 20  ode(typ);..     
8ea0: 20 69 66 20 28 74 63 20 3d 3d 20 54 79 70 65 43   if (tc == TypeC
8eb0: 6f 64 65 2e 4f 62 6a 65 63 74 29 0d 0a 20 20 20  ode.Object)..   
8ec0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66     {..        if
8ed0: 20 28 74 79 70 20 3d 3d 20 74 79 70 65 6f 66 28   (typ == typeof(
8ee0: 62 79 74 65 5b 5d 29 20 7c 7c 20 74 79 70 20 3d  byte[]) || typ =
8ef0: 3d 20 74 79 70 65 6f 66 28 47 75 69 64 29 29 0d  = typeof(Guid)).
8f00: 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72  .          retur
8f10: 6e 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 42  n TypeAffinity.B
8f20: 6c 6f 62 3b 0d 0a 20 20 20 20 20 20 20 20 65 6c  lob;..        el
8f30: 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65  se..          re
8f40: 74 75 72 6e 20 54 79 70 65 41 66 66 69 6e 69 74  turn TypeAffinit
8f50: 79 2e 54 65 78 74 3b 0d 0a 20 20 20 20 20 20 7d  y.Text;..      }
8f60: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f  ..      return _
8f70: 74 79 70 65 63 6f 64 65 41 66 66 69 6e 69 74 69  typecodeAffiniti
8f80: 65 73 5b 28 69 6e 74 29 74 63 5d 3b 0d 0a 20 20  es[(int)tc];..  
8f90: 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69 76 61    }....    priva
8fa0: 74 65 20 73 74 61 74 69 63 20 54 79 70 65 41 66  te static TypeAf
8fb0: 66 69 6e 69 74 79 5b 5d 20 5f 74 79 70 65 63 6f  finity[] _typeco
8fc0: 64 65 41 66 66 69 6e 69 74 69 65 73 20 3d 20 7b  deAffinities = {
8fd0: 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66 66 69  ..      TypeAffi
8fe0: 6e 69 74 79 2e 4e 75 6c 6c 2c 20 20 20 20 20 2f  nity.Null,     /
8ff0: 2f 20 45 6d 70 74 79 20 28 30 29 0d 0a 20 20 20  / Empty (0)..   
9000: 20 20 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e     TypeAffinity.
9010: 42 6c 6f 62 2c 20 20 20 20 20 2f 2f 20 4f 62 6a  Blob,     // Obj
9020: 65 63 74 20 28 31 29 0d 0a 20 20 20 20 20 20 54  ect (1)..      T
9030: 79 70 65 41 66 66 69 6e 69 74 79 2e 4e 75 6c 6c  ypeAffinity.Null
9040: 2c 20 20 20 20 20 2f 2f 20 44 42 4e 75 6c 6c 20  ,     // DBNull 
9050: 28 32 29 0d 0a 20 20 20 20 20 20 54 79 70 65 41  (2)..      TypeA
9060: 66 66 69 6e 69 74 79 2e 49 6e 74 36 34 2c 20 20  ffinity.Int64,  
9070: 20 20 2f 2f 20 42 6f 6f 6c 65 61 6e 20 28 33 29    // Boolean (3)
9080: 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66 66 69  ..      TypeAffi
9090: 6e 69 74 79 2e 49 6e 74 36 34 2c 20 20 20 20 2f  nity.Int64,    /
90a0: 2f 20 43 68 61 72 20 28 34 29 0d 0a 20 20 20 20  / Char (4)..    
90b0: 20 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 49    TypeAffinity.I
90c0: 6e 74 36 34 2c 20 20 20 20 2f 2f 20 53 42 79 74  nt64,    // SByt
90d0: 65 20 28 35 29 0d 0a 20 20 20 20 20 20 54 79 70  e (5)..      Typ
90e0: 65 41 66 66 69 6e 69 74 79 2e 49 6e 74 36 34 2c  eAffinity.Int64,
90f0: 20 20 20 20 2f 2f 20 42 79 74 65 20 28 36 29 0d      // Byte (6).
9100: 0a 20 20 20 20 20 20 54 79 70 65 41 66 66 69 6e  .      TypeAffin
9110: 69 74 79 2e 49 6e 74 36 34 2c 20 20 20 20 2f 2f  ity.Int64,    //
9120: 20 49 6e 74 31 36 20 28 37 29 0d 0a 20 20 20 20   Int16 (7)..    
9130: 20 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 49    TypeAffinity.I
9140: 6e 74 36 34 2c 20 20 20 20 2f 2f 20 55 49 6e 74  nt64,    // UInt
9150: 31 36 20 28 38 29 0d 0a 20 20 20 20 20 20 54 79  16 (8)..      Ty
9160: 70 65 41 66 66 69 6e 69 74 79 2e 49 6e 74 36 34  peAffinity.Int64
9170: 2c 20 20 20 20 2f 2f 20 49 6e 74 33 32 20 28 39  ,    // Int32 (9
9180: 29 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66 66  )..      TypeAff
9190: 69 6e 69 74 79 2e 49 6e 74 36 34 2c 20 20 20 20  inity.Int64,    
91a0: 2f 2f 20 55 49 6e 74 33 32 20 28 31 30 29 0d 0a  // UInt32 (10)..
91b0: 20 20 20 20 20 20 54 79 70 65 41 66 66 69 6e 69        TypeAffini
91c0: 74 79 2e 49 6e 74 36 34 2c 20 20 20 20 2f 2f 20  ty.Int64,    // 
91d0: 49 6e 74 36 34 20 28 31 31 29 0d 0a 20 20 20 20  Int64 (11)..    
91e0: 20 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 49    TypeAffinity.I
91f0: 6e 74 36 34 2c 20 20 20 20 2f 2f 20 55 49 6e 74  nt64,    // UInt
9200: 36 34 20 28 31 32 29 0d 0a 20 20 20 20 20 20 54  64 (12)..      T
9210: 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f 75 62  ypeAffinity.Doub
9220: 6c 65 2c 20 20 20 2f 2f 20 53 69 6e 67 6c 65 20  le,   // Single 
9230: 28 31 33 29 0d 0a 20 20 20 20 20 20 54 79 70 65  (13)..      Type
9240: 41 66 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65 2c  Affinity.Double,
9250: 20 20 20 2f 2f 20 44 6f 75 62 6c 65 20 28 31 34     // Double (14
9260: 29 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66 66  )..      TypeAff
9270: 69 6e 69 74 79 2e 44 6f 75 62 6c 65 2c 20 20 20  inity.Double,   
9280: 2f 2f 20 44 65 63 69 6d 61 6c 20 28 31 35 29 0d  // Decimal (15).
9290: 0a 20 20 20 20 20 20 54 79 70 65 41 66 66 69 6e  .      TypeAffin
92a0: 69 74 79 2e 44 61 74 65 54 69 6d 65 2c 20 2f 2f  ity.DateTime, //
92b0: 20 44 61 74 65 54 69 6d 65 20 28 31 36 29 0d 0a   DateTime (16)..
92c0: 20 20 20 20 20 20 54 79 70 65 41 66 66 69 6e 69        TypeAffini
92d0: 74 79 2e 4e 75 6c 6c 2c 20 20 20 20 20 2f 2f 20  ty.Null,     // 
92e0: 3f 3f 20 28 31 37 29 0d 0a 20 20 20 20 20 20 54  ?? (17)..      T
92f0: 79 70 65 41 66 66 69 6e 69 74 79 2e 54 65 78 74  ypeAffinity.Text
9300: 20 20 20 20 20 20 2f 2f 20 53 74 72 69 6e 67 20        // String 
9310: 28 31 38 29 0d 0a 20 20 20 20 7d 3b 0d 0a 0d 0a  (18)..    };....
9320: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
9330: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 42 75 69 6c 64  >..    /// Build
9340: 73 20 61 6e 64 20 72 65 74 75 72 6e 73 20 61 6e  s and returns an
9350: 20 61 72 72 61 79 20 63 6f 6e 74 61 69 6e 69 6e   array containin
9360: 67 20 74 68 65 20 64 61 74 61 62 61 73 65 20 63  g the database c
9370: 6f 6c 75 6d 6e 20 74 79 70 65 73 0d 0a 20 20 20  olumn types..   
9380: 20 2f 2f 2f 20 72 65 63 6f 67 6e 69 7a 65 64 20   /// recognized 
9390: 62 79 20 74 68 69 73 20 70 72 6f 76 69 64 65 72  by this provider
93a0: 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ...    /// </sum
93b0: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  mary>..    /// <
93c0: 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 2f 2f  returns>..    //
93d0: 2f 20 41 6e 20 61 72 72 61 79 20 63 6f 6e 74 61  / An array conta
93e0: 69 6e 69 6e 67 20 74 68 65 20 64 61 74 61 62 61  ining the databa
93f0: 73 65 20 63 6f 6c 75 6d 6e 20 74 79 70 65 73 20  se column types 
9400: 72 65 63 6f 67 6e 69 7a 65 64 20 62 79 20 74 68  recognized by th
9410: 69 73 0d 0a 20 20 20 20 2f 2f 2f 20 70 72 6f 76  is..    /// prov
9420: 69 64 65 72 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  ider...    /// <
9430: 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 70  /returns>..    p
9440: 72 69 76 61 74 65 20 73 74 61 74 69 63 20 53 51  rivate static SQ
9450: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 20 47 65  LiteDbTypeMap Ge
9460: 74 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70  tSQLiteDbTypeMap
9470: 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  ()..    {..     
9480: 20 20 20 72 65 74 75 72 6e 20 6e 65 77 20 53 51     return new SQ
9490: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 28 6e 65  LiteDbTypeMap(ne
94a0: 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61  w SQLiteDbTypeMa
94b0: 70 70 69 6e 67 5b 5d 20 7b 0d 0a 20 20 20 20 20  pping[] {..     
94c0: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
94d0: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
94e0: 42 49 47 49 4e 54 22 2c 20 44 62 54 79 70 65 2e  BIGINT", DbType.
94f0: 49 6e 74 36 34 2c 20 66 61 6c 73 65 29 2c 0d 0a  Int64, false),..
9500: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
9510: 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70  SQLiteDbTypeMapp
9520: 69 6e 67 28 22 42 49 47 55 49 4e 54 22 2c 20 44  ing("BIGUINT", D
9530: 62 54 79 70 65 2e 55 49 6e 74 36 34 2c 20 66 61  bType.UInt64, fa
9540: 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  lse),..         
9550: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
9560: 79 70 65 4d 61 70 70 69 6e 67 28 22 42 49 4e 41  ypeMapping("BINA
9570: 52 59 22 2c 20 44 62 54 79 70 65 2e 42 69 6e 61  RY", DbType.Bina
9580: 72 79 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20  ry, false),..   
9590: 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c           new SQL
95a0: 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67  iteDbTypeMapping
95b0: 28 22 42 49 54 22 2c 20 44 62 54 79 70 65 2e 42  ("BIT", DbType.B
95c0: 6f 6f 6c 65 61 6e 2c 20 74 72 75 65 29 2c 0d 0a  oolean, true),..
95d0: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
95e0: 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70  SQLiteDbTypeMapp
95f0: 69 6e 67 28 22 42 4c 4f 42 22 2c 20 44 62 54 79  ing("BLOB", DbTy
9600: 70 65 2e 42 69 6e 61 72 79 2c 20 74 72 75 65 29  pe.Binary, true)
9610: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
9620: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
9630: 61 70 70 69 6e 67 28 22 42 4f 4f 4c 22 2c 20 44  apping("BOOL", D
9640: 62 54 79 70 65 2e 42 6f 6f 6c 65 61 6e 2c 20 66  bType.Boolean, f
9650: 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20  alse),..        
9660: 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62      new SQLiteDb
9670: 54 79 70 65 4d 61 70 70 69 6e 67 28 22 42 4f 4f  TypeMapping("BOO
9680: 4c 45 41 4e 22 2c 20 44 62 54 79 70 65 2e 42 6f  LEAN", DbType.Bo
9690: 6f 6c 65 61 6e 2c 20 66 61 6c 73 65 29 2c 0d 0a  olean, false),..
96a0: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
96b0: 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70  SQLiteDbTypeMapp
96c0: 69 6e 67 28 22 43 48 41 52 22 2c 20 44 62 54 79  ing("CHAR", DbTy
96d0: 70 65 2e 41 6e 73 69 53 74 72 69 6e 67 46 69 78  pe.AnsiStringFix
96e0: 65 64 4c 65 6e 67 74 68 2c 20 74 72 75 65 29 2c  edLength, true),
96f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65  ..            ne
9700: 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61  w SQLiteDbTypeMa
9710: 70 70 69 6e 67 28 22 43 4f 55 4e 54 45 52 22 2c  pping("COUNTER",
9720: 20 44 62 54 79 70 65 2e 49 6e 74 36 34 2c 20 66   DbType.Int64, f
9730: 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20  alse),..        
9740: 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62      new SQLiteDb
9750: 54 79 70 65 4d 61 70 70 69 6e 67 28 22 43 55 52  TypeMapping("CUR
9760: 52 45 4e 43 59 22 2c 20 44 62 54 79 70 65 2e 44  RENCY", DbType.D
9770: 65 63 69 6d 61 6c 2c 20 66 61 6c 73 65 29 2c 0d  ecimal, false),.
9780: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77  .            new
9790: 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70   SQLiteDbTypeMap
97a0: 70 69 6e 67 28 22 44 41 54 45 22 2c 20 44 62 54  ping("DATE", DbT
97b0: 79 70 65 2e 44 61 74 65 54 69 6d 65 2c 20 66 61  ype.DateTime, fa
97c0: 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  lse),..         
97d0: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
97e0: 79 70 65 4d 61 70 70 69 6e 67 28 22 44 41 54 45  ypeMapping("DATE
97f0: 54 49 4d 45 22 2c 20 44 62 54 79 70 65 2e 44 61  TIME", DbType.Da
9800: 74 65 54 69 6d 65 2c 20 74 72 75 65 29 2c 0d 0a  teTime, true),..
9810: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
9820: 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70  SQLiteDbTypeMapp
9830: 69 6e 67 28 22 44 45 43 49 4d 41 4c 22 2c 20 44  ing("DECIMAL", D
9840: 62 54 79 70 65 2e 44 65 63 69 6d 61 6c 2c 20 74  bType.Decimal, t
9850: 72 75 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  rue),..         
9860: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
9870: 79 70 65 4d 61 70 70 69 6e 67 28 22 44 4f 55 42  ypeMapping("DOUB
9880: 4c 45 22 2c 20 44 62 54 79 70 65 2e 44 6f 75 62  LE", DbType.Doub
9890: 6c 65 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20  le, false),..   
98a0: 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c           new SQL
98b0: 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67  iteDbTypeMapping
98c0: 28 22 46 4c 4f 41 54 22 2c 20 44 62 54 79 70 65  ("FLOAT", DbType
98d0: 2e 44 6f 75 62 6c 65 2c 20 66 61 6c 73 65 29 2c  .Double, false),
98e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65  ..            ne
98f0: 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61  w SQLiteDbTypeMa
9900: 70 70 69 6e 67 28 22 47 45 4e 45 52 41 4c 22 2c  pping("GENERAL",
9910: 20 44 62 54 79 70 65 2e 42 69 6e 61 72 79 2c 20   DbType.Binary, 
9920: 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20  false),..       
9930: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44       new SQLiteD
9940: 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22 47 55  bTypeMapping("GU
9950: 49 44 22 2c 20 44 62 54 79 70 65 2e 47 75 69 64  ID", DbType.Guid
9960: 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20  , false),..     
9970: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
9980: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
9990: 49 44 45 4e 54 49 54 59 22 2c 20 44 62 54 79 70  IDENTITY", DbTyp
99a0: 65 2e 49 6e 74 36 34 2c 20 66 61 6c 73 65 29 2c  e.Int64, false),
99b0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65  ..            ne
99c0: 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61  w SQLiteDbTypeMa
99d0: 70 70 69 6e 67 28 22 49 4d 41 47 45 22 2c 20 44  pping("IMAGE", D
99e0: 62 54 79 70 65 2e 42 69 6e 61 72 79 2c 20 66 61  bType.Binary, fa
99f0: 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  lse),..         
9a00: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
9a10: 79 70 65 4d 61 70 70 69 6e 67 28 22 49 4e 54 22  ypeMapping("INT"
9a20: 2c 20 44 62 54 79 70 65 2e 49 6e 74 33 32 2c 20  , DbType.Int32, 
9a30: 74 72 75 65 29 2c 0d 0a 20 20 20 20 20 20 20 20  true),..        
9a40: 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62      new SQLiteDb
9a50: 54 79 70 65 4d 61 70 70 69 6e 67 28 22 49 4e 54  TypeMapping("INT
9a60: 38 22 2c 20 44 62 54 79 70 65 2e 53 42 79 74 65  8", DbType.SByte
9a70: 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20  , false),..     
9a80: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
9a90: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
9aa0: 49 4e 54 31 36 22 2c 20 44 62 54 79 70 65 2e 49  INT16", DbType.I
9ab0: 6e 74 31 36 2c 20 66 61 6c 73 65 29 2c 0d 0a 20  nt16, false),.. 
9ac0: 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53             new S
9ad0: 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69  QLiteDbTypeMappi
9ae0: 6e 67 28 22 49 4e 54 33 32 22 2c 20 44 62 54 79  ng("INT32", DbTy
9af0: 70 65 2e 49 6e 74 33 32 2c 20 66 61 6c 73 65 29  pe.Int32, false)
9b00: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
9b10: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
9b20: 61 70 70 69 6e 67 28 22 49 4e 54 36 34 22 2c 20  apping("INT64", 
9b30: 44 62 54 79 70 65 2e 49 6e 74 36 34 2c 20 66 61  DbType.Int64, fa
9b40: 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  lse),..         
9b50: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
9b60: 79 70 65 4d 61 70 70 69 6e 67 28 22 49 4e 54 45  ypeMapping("INTE
9b70: 47 45 52 22 2c 20 44 62 54 79 70 65 2e 49 6e 74  GER", DbType.Int
9b80: 36 34 2c 20 74 72 75 65 29 2c 0d 0a 20 20 20 20  64, true),..    
9b90: 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69          new SQLi
9ba0: 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28  teDbTypeMapping(
9bb0: 22 49 4e 54 45 47 45 52 38 22 2c 20 44 62 54 79  "INTEGER8", DbTy
9bc0: 70 65 2e 53 42 79 74 65 2c 20 66 61 6c 73 65 29  pe.SByte, false)
9bd0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
9be0: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
9bf0: 61 70 70 69 6e 67 28 22 49 4e 54 45 47 45 52 31  apping("INTEGER1
9c00: 36 22 2c 20 44 62 54 79 70 65 2e 49 6e 74 31 36  6", DbType.Int16
9c10: 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20  , false),..     
9c20: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
9c30: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
9c40: 49 4e 54 45 47 45 52 33 32 22 2c 20 44 62 54 79  INTEGER32", DbTy
9c50: 70 65 2e 49 6e 74 33 32 2c 20 66 61 6c 73 65 29  pe.Int32, false)
9c60: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
9c70: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
9c80: 61 70 70 69 6e 67 28 22 49 4e 54 45 47 45 52 36  apping("INTEGER6
9c90: 34 22 2c 20 44 62 54 79 70 65 2e 49 6e 74 36 34  4", DbType.Int64
9ca0: 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20  , false),..     
9cb0: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
9cc0: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
9cd0: 4c 4f 47 49 43 41 4c 22 2c 20 44 62 54 79 70 65  LOGICAL", DbType
9ce0: 2e 42 6f 6f 6c 65 61 6e 2c 20 66 61 6c 73 65 29  .Boolean, false)
9cf0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
9d00: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
9d10: 61 70 70 69 6e 67 28 22 4c 4f 4e 47 22 2c 20 44  apping("LONG", D
9d20: 62 54 79 70 65 2e 49 6e 74 36 34 2c 20 66 61 6c  bType.Int64, fal
9d30: 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20  se),..          
9d40: 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54 79    new SQLiteDbTy
9d50: 70 65 4d 61 70 70 69 6e 67 28 22 4c 4f 4e 47 43  peMapping("LONGC
9d60: 48 41 52 22 2c 20 44 62 54 79 70 65 2e 53 74 72  HAR", DbType.Str
9d70: 69 6e 67 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20  ing, false),..  
9d80: 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51            new SQ
9d90: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e  LiteDbTypeMappin
9da0: 67 28 22 4c 4f 4e 47 54 45 58 54 22 2c 20 44 62  g("LONGTEXT", Db
9db0: 54 79 70 65 2e 53 74 72 69 6e 67 2c 20 66 61 6c  Type.String, fal
9dc0: 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20  se),..          
9dd0: 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54 79    new SQLiteDbTy
9de0: 70 65 4d 61 70 70 69 6e 67 28 22 4c 4f 4e 47 56  peMapping("LONGV
9df0: 41 52 43 48 41 52 22 2c 20 44 62 54 79 70 65 2e  ARCHAR", DbType.
9e00: 53 74 72 69 6e 67 2c 20 66 61 6c 73 65 29 2c 0d  String, false),.
9e10: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77  .            new
9e20: 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70   SQLiteDbTypeMap
9e30: 70 69 6e 67 28 22 4d 45 4d 4f 22 2c 20 44 62 54  ping("MEMO", DbT
9e40: 79 70 65 2e 53 74 72 69 6e 67 2c 20 66 61 6c 73  ype.String, fals
9e50: 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  e),..           
9e60: 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54 79 70   new SQLiteDbTyp
9e70: 65 4d 61 70 70 69 6e 67 28 22 4d 4f 4e 45 59 22  eMapping("MONEY"
9e80: 2c 20 44 62 54 79 70 65 2e 44 65 63 69 6d 61 6c  , DbType.Decimal
9e90: 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20  , false),..     
9ea0: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
9eb0: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
9ec0: 4e 43 48 41 52 22 2c 20 44 62 54 79 70 65 2e 53  NCHAR", DbType.S
9ed0: 74 72 69 6e 67 46 69 78 65 64 4c 65 6e 67 74 68  tringFixedLength
9ee0: 2c 20 74 72 75 65 29 2c 0d 0a 20 20 20 20 20 20  , true),..      
9ef0: 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65        new SQLite
9f00: 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22 4e  DbTypeMapping("N
9f10: 4f 54 45 22 2c 20 44 62 54 79 70 65 2e 53 74 72  OTE", DbType.Str
9f20: 69 6e 67 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20  ing, false),..  
9f30: 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51            new SQ
9f40: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e  LiteDbTypeMappin
9f50: 67 28 22 4e 54 45 58 54 22 2c 20 44 62 54 79 70  g("NTEXT", DbTyp
9f60: 65 2e 53 74 72 69 6e 67 2c 20 66 61 6c 73 65 29  e.String, false)
9f70: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
9f80: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
9f90: 61 70 70 69 6e 67 28 22 4e 55 4d 45 52 49 43 22  apping("NUMERIC"
9fa0: 2c 20 44 62 54 79 70 65 2e 44 65 63 69 6d 61 6c  , DbType.Decimal
9fb0: 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20  , false),..     
9fc0: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
9fd0: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
9fe0: 4e 56 41 52 43 48 41 52 22 2c 20 44 62 54 79 70  NVARCHAR", DbTyp
9ff0: 65 2e 53 74 72 69 6e 67 2c 20 74 72 75 65 29 2c  e.String, true),
a000: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65  ..            ne
a010: 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61  w SQLiteDbTypeMa
a020: 70 70 69 6e 67 28 22 4f 4c 45 4f 42 4a 45 43 54  pping("OLEOBJECT
a030: 22 2c 20 44 62 54 79 70 65 2e 42 69 6e 61 72 79  ", DbType.Binary
a040: 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20  , false),..     
a050: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
a060: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
a070: 52 45 41 4c 22 2c 20 44 62 54 79 70 65 2e 44 6f  REAL", DbType.Do
a080: 75 62 6c 65 2c 20 74 72 75 65 29 2c 0d 0a 20 20  uble, true),..  
a090: 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51            new SQ
a0a0: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e  LiteDbTypeMappin
a0b0: 67 28 22 53 49 4e 47 4c 45 22 2c 20 44 62 54 79  g("SINGLE", DbTy
a0c0: 70 65 2e 53 69 6e 67 6c 65 2c 20 74 72 75 65 29  pe.Single, true)
a0d0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
a0e0: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
a0f0: 61 70 70 69 6e 67 28 22 53 4d 41 4c 4c 44 41 54  apping("SMALLDAT
a100: 45 22 2c 20 44 62 54 79 70 65 2e 44 61 74 65 54  E", DbType.DateT
a110: 69 6d 65 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20  ime, false),..  
a120: 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51            new SQ
a130: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e  LiteDbTypeMappin
a140: 67 28 22 53 4d 41 4c 4c 49 4e 54 22 2c 20 44 62  g("SMALLINT", Db
a150: 54 79 70 65 2e 49 6e 74 31 36 2c 20 74 72 75 65  Type.Int16, true
a160: 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ),..            
a170: 6e 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65  new SQLiteDbType
a180: 4d 61 70 70 69 6e 67 28 22 53 4d 41 4c 4c 55 49  Mapping("SMALLUI
a190: 4e 54 22 2c 20 44 62 54 79 70 65 2e 55 49 6e 74  NT", DbType.UInt
a1a0: 31 36 2c 20 74 72 75 65 29 2c 0d 0a 20 20 20 20  16, true),..    
a1b0: 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69          new SQLi
a1c0: 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28  teDbTypeMapping(
a1d0: 22 53 54 52 49 4e 47 22 2c 20 44 62 54 79 70 65  "STRING", DbType
a1e0: 2e 53 74 72 69 6e 67 2c 20 66 61 6c 73 65 29 2c  .String, false),
a1f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65  ..            ne
a200: 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61  w SQLiteDbTypeMa
a210: 70 70 69 6e 67 28 22 54 45 58 54 22 2c 20 44 62  pping("TEXT", Db
a220: 54 79 70 65 2e 53 74 72 69 6e 67 2c 20 66 61 6c  Type.String, fal
a230: 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20  se),..          
a240: 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54 79    new SQLiteDbTy
a250: 70 65 4d 61 70 70 69 6e 67 28 22 54 49 4d 45 22  peMapping("TIME"
a260: 2c 20 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d  , DbType.DateTim
a270: 65 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20  e, false),..    
a280: 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69          new SQLi
a290: 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28  teDbTypeMapping(
a2a0: 22 54 49 4d 45 53 54 41 4d 50 22 2c 20 44 62 54  "TIMESTAMP", DbT
a2b0: 79 70 65 2e 44 61 74 65 54 69 6d 65 2c 20 66 61  ype.DateTime, fa
a2c0: 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  lse),..         
a2d0: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
a2e0: 79 70 65 4d 61 70 70 69 6e 67 28 22 54 49 4e 59  ypeMapping("TINY
a2f0: 49 4e 54 22 2c 20 44 62 54 79 70 65 2e 42 79 74  INT", DbType.Byt
a300: 65 2c 20 74 72 75 65 29 2c 0d 0a 20 20 20 20 20  e, true),..     
a310: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
a320: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
a330: 54 49 4e 59 53 49 4e 54 22 2c 20 44 62 54 79 70  TINYSINT", DbTyp
a340: 65 2e 53 42 79 74 65 2c 20 74 72 75 65 29 2c 0d  e.SByte, true),.
a350: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77  .            new
a360: 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70   SQLiteDbTypeMap
a370: 70 69 6e 67 28 22 55 49 4e 54 22 2c 20 44 62 54  ping("UINT", DbT
a380: 79 70 65 2e 55 49 6e 74 33 32 2c 20 74 72 75 65  ype.UInt32, true
a390: 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ),..            
a3a0: 6e 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65  new SQLiteDbType
a3b0: 4d 61 70 70 69 6e 67 28 22 55 49 4e 54 38 22 2c  Mapping("UINT8",
a3c0: 20 44 62 54 79 70 65 2e 42 79 74 65 2c 20 66 61   DbType.Byte, fa
a3d0: 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  lse),..         
a3e0: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
a3f0: 79 70 65 4d 61 70 70 69 6e 67 28 22 55 49 4e 54  ypeMapping("UINT
a400: 31 36 22 2c 20 44 62 54 79 70 65 2e 55 49 6e 74  16", DbType.UInt
a410: 31 36 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20  16, false),..   
a420: 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c           new SQL
a430: 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67  iteDbTypeMapping
a440: 28 22 55 49 4e 54 33 32 22 2c 20 44 62 54 79 70  ("UINT32", DbTyp
a450: 65 2e 55 49 6e 74 33 32 2c 20 66 61 6c 73 65 29  e.UInt32, false)
a460: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
a470: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
a480: 61 70 70 69 6e 67 28 22 55 49 4e 54 36 34 22 2c  apping("UINT64",
a490: 20 44 62 54 79 70 65 2e 55 49 6e 74 36 34 2c 20   DbType.UInt64, 
a4a0: 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20  false),..       
a4b0: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44       new SQLiteD
a4c0: 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22 55 4c  bTypeMapping("UL
a4d0: 4f 4e 47 22 2c 20 44 62 54 79 70 65 2e 55 49 6e  ONG", DbType.UIn
a4e0: 74 36 34 2c 20 66 61 6c 73 65 29 2c 0d 0a 20 20  t64, false),..  
a4f0: 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51            new SQ
a500: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e  LiteDbTypeMappin
a510: 67 28 22 55 4e 49 51 55 45 49 44 45 4e 54 49 46  g("UNIQUEIDENTIF
a520: 49 45 52 22 2c 20 44 62 54 79 70 65 2e 47 75 69  IER", DbType.Gui
a530: 64 2c 20 74 72 75 65 29 2c 0d 0a 20 20 20 20 20  d, true),..     
a540: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
a550: 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22  eDbTypeMapping("
a560: 55 4e 53 49 47 4e 45 44 49 4e 54 45 47 45 52 22  UNSIGNEDINTEGER"
a570: 2c 20 44 62 54 79 70 65 2e 55 49 6e 74 36 34 2c  , DbType.UInt64,
a580: 20 74 72 75 65 29 2c 0d 0a 20 20 20 20 20 20 20   true),..       
a590: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44       new SQLiteD
a5a0: 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22 55 4e  bTypeMapping("UN
a5b0: 53 49 47 4e 45 44 49 4e 54 45 47 45 52 38 22 2c  SIGNEDINTEGER8",
a5c0: 20 44 62 54 79 70 65 2e 42 79 74 65 2c 20 66 61   DbType.Byte, fa
a5d0: 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  lse),..         
a5e0: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62 54     new SQLiteDbT
a5f0: 79 70 65 4d 61 70 70 69 6e 67 28 22 55 4e 53 49  ypeMapping("UNSI
a600: 47 4e 45 44 49 4e 54 45 47 45 52 31 36 22 2c 20  GNEDINTEGER16", 
a610: 44 62 54 79 70 65 2e 55 49 6e 74 31 36 2c 20 66  DbType.UInt16, f
a620: 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20 20  alse),..        
a630: 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44 62      new SQLiteDb
a640: 54 79 70 65 4d 61 70 70 69 6e 67 28 22 55 4e 53  TypeMapping("UNS
a650: 49 47 4e 45 44 49 4e 54 45 47 45 52 33 32 22 2c  IGNEDINTEGER32",
a660: 20 44 62 54 79 70 65 2e 55 49 6e 74 33 32 2c 20   DbType.UInt32, 
a670: 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20 20  false),..       
a680: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 44       new SQLiteD
a690: 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22 55 4e  bTypeMapping("UN
a6a0: 53 49 47 4e 45 44 49 4e 54 45 47 45 52 36 34 22  SIGNEDINTEGER64"
a6b0: 2c 20 44 62 54 79 70 65 2e 55 49 6e 74 36 34 2c  , DbType.UInt64,
a6c0: 20 66 61 6c 73 65 29 2c 0d 0a 20 20 20 20 20 20   false),..      
a6d0: 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65        new SQLite
a6e0: 44 62 54 79 70 65 4d 61 70 70 69 6e 67 28 22 56  DbTypeMapping("V
a6f0: 41 52 42 49 4e 41 52 59 22 2c 20 44 62 54 79 70  ARBINARY", DbTyp
a700: 65 2e 42 69 6e 61 72 79 2c 20 66 61 6c 73 65 29  e.Binary, false)
a710: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
a720: 65 77 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d  ew SQLiteDbTypeM
a730: 61 70 70 69 6e 67 28 22 56 41 52 43 48 41 52 22  apping("VARCHAR"
a740: 2c 20 44 62 54 79 70 65 2e 41 6e 73 69 53 74 72  , DbType.AnsiStr
a750: 69 6e 67 2c 20 74 72 75 65 29 2c 0d 0a 20 20 20  ing, true),..   
a760: 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c           new SQL
a770: 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67  iteDbTypeMapping
a780: 28 22 59 45 53 4e 4f 22 2c 20 44 62 54 79 70 65  ("YESNO", DbType
a790: 2e 42 6f 6f 6c 65 61 6e 2c 20 66 61 6c 73 65 29  .Boolean, false)
a7a0: 0d 0a 20 20 20 20 20 20 20 20 7d 29 3b 0d 0a 20  ..        });.. 
a7b0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20     }....    /// 
a7c0: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
a7d0: 2f 2f 20 46 6f 72 20 61 20 67 69 76 65 6e 20 74  // For a given t
a7e0: 79 70 65 20 6e 61 6d 65 2c 20 72 65 74 75 72 6e  ype name, return
a7f0: 20 61 20 63 6c 6f 73 65 73 74 2d 6d 61 74 63 68   a closest-match
a800: 20 2e 4e 45 54 20 74 79 70 65 0d 0a 20 20 20 20   .NET type..    
a810: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
a820: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
a830: 61 6d 65 3d 22 4e 61 6d 65 22 3e 54 68 65 20 6e  ame="Name">The n
a840: 61 6d 65 20 6f 66 20 74 68 65 20 74 79 70 65 20  ame of the type 
a850: 74 6f 20 6d 61 74 63 68 3c 2f 70 61 72 61 6d 3e  to match</param>
a860: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  ..    /// <retur
a870: 6e 73 3e 54 68 65 20 2e 4e 45 54 20 44 42 54 79  ns>The .NET DBTy
a880: 70 65 20 74 68 65 20 74 65 78 74 20 65 76 61 6c  pe the text eval
a890: 75 61 74 65 73 20 74 6f 2e 3c 2f 72 65 74 75 72  uates to.</retur
a8a0: 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  ns>..    interna
a8b0: 6c 20 73 74 61 74 69 63 20 44 62 54 79 70 65 20  l static DbType 
a8c0: 54 79 70 65 4e 61 6d 65 54 6f 44 62 54 79 70 65  TypeNameToDbType
a8d0: 28 73 74 72 69 6e 67 20 4e 61 6d 65 29 0d 0a 20  (string Name).. 
a8e0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 6c 6f     {..        lo
a8f0: 63 6b 20 28 5f 73 79 6e 63 52 6f 6f 74 29 0d 0a  ck (_syncRoot)..
a900: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
a910: 20 20 20 20 20 20 20 69 66 20 28 5f 74 79 70 65         if (_type
a920: 4e 61 6d 65 73 20 3d 3d 20 6e 75 6c 6c 29 0d 0a  Names == null)..
a930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
a940: 5f 74 79 70 65 4e 61 6d 65 73 20 3d 20 47 65 74  _typeNames = Get
a950: 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70 28  SQLiteDbTypeMap(
a960: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
a970: 20 20 69 66 20 28 53 74 72 69 6e 67 2e 49 73 4e    if (String.IsN
a980: 75 6c 6c 4f 72 45 6d 70 74 79 28 4e 61 6d 65 29  ullOrEmpty(Name)
a990: 29 20 72 65 74 75 72 6e 20 44 62 54 79 70 65 2e  ) return DbType.
a9a0: 4f 62 6a 65 63 74 3b 0d 0a 0d 0a 20 20 20 20 20  Object;....     
a9b0: 20 20 20 20 20 20 20 53 51 4c 69 74 65 44 62 54         SQLiteDbT
a9c0: 79 70 65 4d 61 70 70 69 6e 67 20 76 61 6c 75 65  ypeMapping value
a9d0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ;....           
a9e0: 20 69 66 20 28 5f 74 79 70 65 4e 61 6d 65 73 2e   if (_typeNames.
a9f0: 54 72 79 47 65 74 56 61 6c 75 65 28 4e 61 6d 65  TryGetValue(Name
aa00: 2c 20 6f 75 74 20 76 61 6c 75 65 29 29 0d 0a 20  , out value)).. 
aa10: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
aa20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65                re
aa30: 74 75 72 6e 20 76 61 6c 75 65 2e 64 61 74 61 54  turn value.dataT
aa40: 79 70 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  ype;..          
aa50: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20    }..           
aa60: 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 20   else..         
aa70: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
aa80: 20 20 20 20 20 20 69 6e 74 20 69 6e 64 65 78 20        int index 
aa90: 3d 20 4e 61 6d 65 2e 49 6e 64 65 78 4f 66 28 27  = Name.IndexOf('
aaa0: 28 27 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  (');....        
aab0: 20 20 20 20 20 20 20 20 69 66 20 28 28 69 6e 64          if ((ind
aac0: 65 78 20 3e 20 30 29 20 26 26 0d 0a 20 20 20 20  ex > 0) &&..    
aad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
aae0: 5f 74 79 70 65 4e 61 6d 65 73 2e 54 72 79 47 65  _typeNames.TryGe
aaf0: 74 56 61 6c 75 65 28 4e 61 6d 65 2e 53 75 62 73  tValue(Name.Subs
ab00: 74 72 69 6e 67 28 30 2c 20 69 6e 64 65 78 29 2e  tring(0, index).
ab10: 54 72 69 6d 45 6e 64 28 29 2c 20 6f 75 74 20 76  TrimEnd(), out v
ab20: 61 6c 75 65 29 29 0d 0a 20 20 20 20 20 20 20 20  alue))..        
ab30: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
ab40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72                 r
ab50: 65 74 75 72 6e 20 76 61 6c 75 65 2e 64 61 74 61  eturn value.data
ab60: 54 79 70 65 3b 0d 0a 20 20 20 20 20 20 20 20 20  Type;..         
ab70: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
ab80: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
ab90: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 44 62   }....        Db
aba0: 54 79 70 65 20 64 65 66 61 75 6c 74 44 62 54 79  Type defaultDbTy
abb0: 70 65 20 3d 20 44 62 54 79 70 65 2e 4f 62 6a 65  pe = DbType.Obje
abc0: 63 74 3b 0d 0a 0d 0a 23 69 66 20 21 4e 45 54 5f  ct;....#if !NET_
abd0: 43 4f 4d 50 41 43 54 5f 32 30 20 26 26 20 54 52  COMPACT_20 && TR
abe0: 41 43 45 5f 57 41 52 4e 49 4e 47 0d 0a 20 20 20  ACE_WARNING..   
abf0: 20 20 20 20 20 54 72 61 63 65 2e 57 72 69 74 65       Trace.Write
ac00: 4c 69 6e 65 28 53 74 72 69 6e 67 2e 46 6f 72 6d  Line(String.Form
ac10: 61 74 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  at(..           
ac20: 20 22 57 41 52 4e 49 4e 47 3a 20 54 79 70 65 20   "WARNING: Type 
ac30: 6d 61 70 70 69 6e 67 20 66 61 69 6c 65 64 2c 20  mapping failed, 
ac40: 72 65 74 75 72 6e 69 6e 67 20 64 65 66 61 75 6c  returning defaul
ac50: 74 20 74 79 70 65 20 7b 30 7d 20 66 6f 72 20 6e  t type {0} for n
ac60: 61 6d 65 20 5c 22 7b 31 7d 5c 22 2e 22 2c 0d 0a  ame \"{1}\".",..
ac70: 20 20 20 20 20 20 20 20 20 20 20 20 64 65 66 61              defa
ac80: 75 6c 74 44 62 54 79 70 65 2c 20 4e 61 6d 65 29  ultDbType, Name)
ac90: 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20  );..#endif....  
aca0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 64 65 66        return def
acb0: 61 75 6c 74 44 62 54 79 70 65 3b 0d 0a 20 20 20  aultDbType;..   
acc0: 20 7d 0d 0a 20 20 20 20 23 65 6e 64 72 65 67 69   }..    #endregi
acd0: 6f 6e 0d 0a 0d 0a 20 20 20 20 70 72 69 76 61 74  on....    privat
ace0: 65 20 73 74 61 74 69 63 20 6f 62 6a 65 63 74 20  e static object 
acf0: 5f 73 79 6e 63 52 6f 6f 74 20 3d 20 6e 65 77 20  _syncRoot = new 
ad00: 6f 62 6a 65 63 74 28 29 3b 0d 0a 20 20 20 20 70  object();..    p
ad10: 72 69 76 61 74 65 20 73 74 61 74 69 63 20 53 51  rivate static SQ
ad20: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 20 5f 74  LiteDbTypeMap _t
ad30: 79 70 65 4e 61 6d 65 73 20 3d 20 6e 75 6c 6c 3b  ypeNames = null;
ad40: 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 2f 2f 2f 20 3c  ..  }....  /// <
ad50: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f 20  summary>..  /// 
ad60: 53 51 4c 69 74 65 20 68 61 73 20 76 65 72 79 20  SQLite has very 
ad70: 6c 69 6d 69 74 65 64 20 74 79 70 65 73 2c 20 61  limited types, a
ad80: 6e 64 20 69 73 20 69 6e 68 65 72 65 6e 74 6c 79  nd is inherently
ad90: 20 74 65 78 74 2d 62 61 73 65 64 2e 20 20 54 68   text-based.  Th
ada0: 65 20 66 69 72 73 74 20 35 20 74 79 70 65 73 20  e first 5 types 
adb0: 62 65 6c 6f 77 20 72 65 70 72 65 73 65 6e 74 20  below represent 
adc0: 74 68 65 20 73 75 6d 20 6f 66 20 61 6c 6c 20 74  the sum of all t
add0: 79 70 65 73 20 53 51 4c 69 74 65 0d 0a 20 20 2f  ypes SQLite..  /
ade0: 2f 2f 20 75 6e 64 65 72 73 74 61 6e 64 73 2e 20  // understands. 
adf0: 20 54 68 65 20 44 61 74 65 54 69 6d 65 20 65 78   The DateTime ex
ae00: 74 65 6e 73 69 6f 6e 20 74 6f 20 74 68 65 20 73  tension to the s
ae10: 70 65 63 20 69 73 20 66 6f 72 20 69 6e 74 65 72  pec is for inter
ae20: 6e 61 6c 20 75 73 65 20 6f 6e 6c 79 2e 0d 0a 20  nal use only... 
ae30: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
ae40: 0a 20 20 70 75 62 6c 69 63 20 65 6e 75 6d 20 54  .  public enum T
ae50: 79 70 65 41 66 66 69 6e 69 74 79 0d 0a 20 20 7b  ypeAffinity..  {
ae60: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
ae70: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 4e 6f 74  ry>..    /// Not
ae80: 20 75 73 65 64 0d 0a 20 20 20 20 2f 2f 2f 20 3c   used..    /// <
ae90: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 55  /summary>..    U
aea0: 6e 69 6e 69 74 69 61 6c 69 7a 65 64 20 3d 20 30  ninitialized = 0
aeb0: 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ,..    /// <summ
aec0: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 6c  ary>..    /// Al
aed0: 6c 20 69 6e 74 65 67 65 72 73 20 69 6e 20 53 51  l integers in SQ
aee0: 4c 69 74 65 20 64 65 66 61 75 6c 74 20 74 6f 20  Lite default to 
aef0: 49 6e 74 36 34 0d 0a 20 20 20 20 2f 2f 2f 20 3c  Int64..    /// <
af00: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 49  /summary>..    I
af10: 6e 74 36 34 20 3d 20 31 2c 0d 0a 20 20 20 20 2f  nt64 = 1,..    /
af20: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
af30: 20 20 2f 2f 2f 20 41 6c 6c 20 66 6c 6f 61 74 69    /// All floati
af40: 6e 67 20 70 6f 69 6e 74 20 6e 75 6d 62 65 72 73  ng point numbers
af50: 20 69 6e 20 53 51 4c 69 74 65 20 64 65 66 61 75   in SQLite defau
af60: 6c 74 20 74 6f 20 64 6f 75 62 6c 65 0d 0a 20 20  lt to double..  
af70: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
af80: 0d 0a 20 20 20 20 44 6f 75 62 6c 65 20 3d 20 32  ..    Double = 2
af90: 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ,..    /// <summ
afa0: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68  ary>..    /// Th
afb0: 65 20 64 65 66 61 75 6c 74 20 64 61 74 61 20 74  e default data t
afc0: 79 70 65 20 6f 66 20 53 51 4c 69 74 65 20 69 73  ype of SQLite is
afd0: 20 74 65 78 74 0d 0a 20 20 20 20 2f 2f 2f 20 3c   text..    /// <
afe0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 54  /summary>..    T
aff0: 65 78 74 20 3d 20 33 2c 0d 0a 20 20 20 20 2f 2f  ext = 3,..    //
b000: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
b010: 20 2f 2f 2f 20 54 79 70 69 63 61 6c 6c 79 20 62   /// Typically b
b020: 6c 6f 62 20 74 79 70 65 73 20 61 72 65 20 6f 6e  lob types are on
b030: 6c 79 20 73 65 65 6e 20 77 68 65 6e 20 72 65 74  ly seen when ret
b040: 75 72 6e 65 64 20 66 72 6f 6d 20 61 20 66 75 6e  urned from a fun
b050: 63 74 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  ction..    /// <
b060: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 42  /summary>..    B
b070: 6c 6f 62 20 3d 20 34 2c 0d 0a 20 20 20 20 2f 2f  lob = 4,..    //
b080: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
b090: 20 2f 2f 2f 20 4e 75 6c 6c 20 74 79 70 65 73 20   /// Null types 
b0a0: 63 61 6e 20 62 65 20 72 65 74 75 72 6e 65 64 20  can be returned 
b0b0: 66 72 6f 6d 20 66 75 6e 63 74 69 6f 6e 73 0d 0a  from functions..
b0c0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
b0d0: 79 3e 0d 0a 20 20 20 20 4e 75 6c 6c 20 3d 20 35  y>..    Null = 5
b0e0: 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ,..    /// <summ
b0f0: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 55 73  ary>..    /// Us
b100: 65 64 20 69 6e 74 65 72 6e 61 6c 6c 79 20 62 79  ed internally by
b110: 20 74 68 69 73 20 70 72 6f 76 69 64 65 72 0d 0a   this provider..
b120: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
b130: 79 3e 0d 0a 20 20 20 20 44 61 74 65 54 69 6d 65  y>..    DateTime
b140: 20 3d 20 31 30 2c 0d 0a 20 20 20 20 2f 2f 2f 20   = 10,..    /// 
b150: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
b160: 2f 2f 20 55 73 65 64 20 69 6e 74 65 72 6e 61 6c  // Used internal
b170: 6c 79 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ly..    /// </su
b180: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 4e 6f 6e 65  mmary>..    None
b190: 20 3d 20 31 31 2c 0d 0a 20 20 7d 0d 0a 0d 0a 20   = 11,..  }.... 
b1a0: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
b1b0: 20 20 2f 2f 2f 20 54 68 65 73 65 20 61 72 65 20    /// These are 
b1c0: 74 68 65 20 65 76 65 6e 74 20 74 79 70 65 73 20  the event types 
b1d0: 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20  associated with 
b1e0: 74 68 65 0d 0a 20 20 2f 2f 2f 20 3c 73 65 65 20  the..  /// <see 
b1f0: 63 72 65 66 3d 22 53 51 4c 69 74 65 43 6f 6e 6e  cref="SQLiteConn
b200: 65 63 74 69 6f 6e 45 76 65 6e 74 48 61 6e 64 6c  ectionEventHandl
b210: 65 72 22 20 2f 3e 0d 0a 20 20 2f 2f 2f 20 64 65  er" />..  /// de
b220: 6c 65 67 61 74 65 20 28 61 6e 64 20 69 74 73 20  legate (and its 
b230: 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 65 76  corresponding ev
b240: 65 6e 74 29 20 61 6e 64 20 74 68 65 0d 0a 20 20  ent) and the..  
b250: 2f 2f 2f 20 3c 73 65 65 20 63 72 65 66 3d 22 43  /// <see cref="C
b260: 6f 6e 6e 65 63 74 69 6f 6e 45 76 65 6e 74 41 72  onnectionEventAr
b270: 67 73 22 20 2f 3e 20 63 6c 61 73 73 2e 0d 0a 20  gs" /> class... 
b280: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
b290: 0a 20 20 70 75 62 6c 69 63 20 65 6e 75 6d 20 53  .  public enum S
b2a0: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 45  QLiteConnectionE
b2b0: 76 65 6e 74 54 79 70 65 0d 0a 20 20 7b 0d 0a 20  ventType..  {.. 
b2c0: 20 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72       /// <summar
b2d0: 79 3e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 4e 6f  y>..      /// No
b2e0: 74 20 75 73 65 64 2e 0d 0a 20 20 20 20 20 20 2f  t used...      /
b2f0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
b300: 20 20 20 20 20 49 6e 76 61 6c 69 64 20 3d 20 2d       Invalid = -
b310: 31 2c 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f 2f 20  1,....      /// 
b320: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20  <summary>..     
b330: 20 2f 2f 2f 20 4e 6f 74 20 75 73 65 64 2e 0d 0a   /// Not used...
b340: 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d        /// </summ
b350: 61 72 79 3e 0d 0a 20 20 20 20 20 20 55 6e 6b 6e  ary>..      Unkn
b360: 6f 77 6e 20 3d 20 30 2c 0d 0a 0d 0a 20 20 20 20  own = 0,....    
b370: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
b380: 0a 20 20 20 20 20 20 2f 2f 2f 20 54 68 65 20 63  .      /// The c
b390: 6f 6e 6e 65 63 74 69 6f 6e 20 69 73 20 62 65 69  onnection is bei
b3a0: 6e 67 20 6f 70 65 6e 65 64 2e 0d 0a 20 20 20 20  ng opened...    
b3b0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
b3c0: 0d 0a 20 20 20 20 20 20 4f 70 65 6e 69 6e 67 20  ..      Opening 
b3d0: 3d 20 31 2c 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f  = 1,....      //
b3e0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
b3f0: 20 20 20 2f 2f 2f 20 54 68 65 20 63 6f 6e 6e 65     /// The conne
b400: 63 74 69 6f 6e 20 73 74 72 69 6e 67 20 68 61 73  ction string has
b410: 20 62 65 65 6e 20 70 61 72 73 65 64 2e 0d 0a 20   been parsed... 
b420: 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61       /// </summa
b430: 72 79 3e 0d 0a 20 20 20 20 20 20 43 6f 6e 6e 65  ry>..      Conne
b440: 63 74 69 6f 6e 53 74 72 69 6e 67 20 3d 20 32 2c  ctionString = 2,
b450: 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 73  ....      /// <s
b460: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 2f  ummary>..      /
b470: 2f 2f 20 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f  // The connectio
b480: 6e 20 77 61 73 20 6f 70 65 6e 65 64 2e 0d 0a 20  n was opened... 
b490: 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61       /// </summa
b4a0: 72 79 3e 0d 0a 20 20 20 20 20 20 4f 70 65 6e 65  ry>..      Opene
b4b0: 64 20 3d 20 33 2c 0d 0a 0d 0a 20 20 20 20 20 20  d = 3,....      
b4c0: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
b4d0: 20 20 20 20 20 2f 2f 2f 20 54 68 65 20 3c 73 65       /// The <se
b4e0: 65 20 63 72 65 66 3d 22 43 68 61 6e 67 65 44 61  e cref="ChangeDa
b4f0: 74 61 62 61 73 65 22 20 2f 3e 20 6d 65 74 68 6f  tabase" /> metho
b500: 64 20 77 61 73 20 63 61 6c 6c 65 64 20 6f 6e 20  d was called on 
b510: 74 68 65 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 63  the..      /// c
b520: 6f 6e 6e 65 63 74 69 6f 6e 2e 0d 0a 20 20 20 20  onnection...    
b530: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
b540: 0d 0a 20 20 20 20 20 20 43 68 61 6e 67 65 44 61  ..      ChangeDa
b550: 74 61 62 61 73 65 20 3d 20 34 2c 0d 0a 0d 0a 20  tabase = 4,.... 
b560: 20 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72       /// <summar
b570: 79 3e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 41 20  y>..      /// A 
b580: 74 72 61 6e 73 61 63 74 69 6f 6e 20 77 61 73 20  transaction was 
b590: 63 72 65 61 74 65 64 20 75 73 69 6e 67 20 74 68  created using th
b5a0: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 0d 0a 20  e connection... 
b5b0: 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61       /// </summa
b5c0: 72 79 3e 0d 0a 20 20 20 20 20 20 4e 65 77 54 72  ry>..      NewTr
b5d0: 61 6e 73 61 63 74 69 6f 6e 20 3d 20 35 2c 0d 0a  ansaction = 5,..
b5e0: 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 73 75 6d  ..      /// <sum
b5f0: 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 2f 2f 2f  mary>..      ///
b600: 20 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20   The connection 
b610: 77 61 73 20 65 6e 6c 69 73 74 65 64 20 69 6e 74  was enlisted int
b620: 6f 20 61 20 74 72 61 6e 73 61 63 74 69 6f 6e 2e  o a transaction.
b630: 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ..      /// </su
b640: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 45 6e  mmary>..      En
b650: 6c 69 73 74 54 72 61 6e 73 61 63 74 69 6f 6e 20  listTransaction 
b660: 3d 20 36 2c 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f  = 6,....      //
b670: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
b680: 20 20 20 2f 2f 2f 20 41 20 63 6f 6d 6d 61 6e 64     /// A command
b690: 20 77 61 73 20 63 72 65 61 74 65 64 20 75 73 69   was created usi
b6a0: 6e 67 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f  ng the connectio
b6b0: 6e 2e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 2f  n...      /// </
b6c0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20  summary>..      
b6d0: 4e 65 77 43 6f 6d 6d 61 6e 64 20 3d 20 37 2c 0d  NewCommand = 7,.
b6e0: 0a 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 73 75  ...      /// <su
b6f0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 2f 2f  mmary>..      //
b700: 2f 20 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  / The connection
b710: 20 69 73 20 62 65 69 6e 67 20 63 6c 6f 73 65 64   is being closed
b720: 2e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73  ...      /// </s
b730: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 43  ummary>..      C
b740: 6c 6f 73 69 6e 67 20 3d 20 38 2c 0d 0a 0d 0a 20  losing = 8,.... 
b750: 20 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72       /// <summar
b760: 79 3e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 54 68  y>..      /// Th
b770: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 77 61 73  e connection was
b780: 20 63 6c 6f 73 65 64 2e 0d 0a 20 20 20 20 20 20   closed...      
b790: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
b7a0: 20 20 20 20 20 20 43 6c 6f 73 65 64 20 3d 20 39        Closed = 9
b7b0: 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 2f 2f 2f 20 3c  ..  }....  /// <
b7c0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f 20  summary>..  /// 
b7d0: 54 68 69 73 20 69 6d 70 6c 65 6d 65 6e 74 61 74  This implementat
b7e0: 69 6f 6e 20 6f 66 20 53 51 4c 69 74 65 20 66 6f  ion of SQLite fo
b7f0: 72 20 41 44 4f 2e 4e 45 54 20 63 61 6e 20 70 72  r ADO.NET can pr
b800: 6f 63 65 73 73 20 64 61 74 65 2f 74 69 6d 65 20  ocess date/time 
b810: 66 69 65 6c 64 73 20 69 6e 20 64 61 74 61 62 61  fields in databa
b820: 73 65 73 20 69 6e 20 6f 6e 6c 79 20 6f 6e 65 20  ses in only one 
b830: 6f 66 20 74 68 72 65 65 20 66 6f 72 6d 61 74 73  of three formats
b840: 2e 20 20 54 69 63 6b 73 2c 20 49 53 4f 38 36 30  .  Ticks, ISO860
b850: 31 0d 0a 20 20 2f 2f 2f 20 61 6e 64 20 4a 75 6c  1..  /// and Jul
b860: 69 61 6e 44 61 79 2e 0d 0a 20 20 2f 2f 2f 20 3c  ianDay...  /// <
b870: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f  /summary>..  ///
b880: 20 3c 72 65 6d 61 72 6b 73 3e 0d 0a 20 20 2f 2f   <remarks>..  //
b890: 2f 20 49 53 4f 38 36 30 31 20 69 73 20 6d 6f 72  / ISO8601 is mor
b8a0: 65 20 63 6f 6d 70 61 74 69 62 6c 65 2c 20 72 65  e compatible, re
b8b0: 61 64 61 62 6c 65 2c 20 66 75 6c 6c 79 2d 70 72  adable, fully-pr
b8c0: 6f 63 65 73 73 61 62 6c 65 2c 20 62 75 74 20 6c  ocessable, but l
b8d0: 65 73 73 20 61 63 63 75 72 61 74 65 20 61 73 20  ess accurate as 
b8e0: 69 74 20 64 6f 65 73 6e 27 74 20 70 72 6f 76 69  it doesn't provi
b8f0: 64 65 20 74 69 6d 65 20 64 6f 77 6e 20 74 6f 20  de time down to 
b900: 66 72 61 63 74 69 6f 6e 73 20 6f 66 20 61 20 73  fractions of a s
b910: 65 63 6f 6e 64 2e 0d 0a 20 20 2f 2f 2f 20 4a 75  econd...  /// Ju
b920: 6c 69 61 6e 44 61 79 20 69 73 20 74 68 65 20 6e  lianDay is the n
b930: 75 6d 65 72 69 63 20 66 6f 72 6d 61 74 20 74 68  umeric format th
b940: 65 20 53 51 4c 69 74 65 20 75 73 65 73 20 69 6e  e SQLite uses in
b950: 74 65 72 6e 61 6c 6c 79 20 61 6e 64 20 69 73 20  ternally and is 
b960: 61 72 67 75 61 62 6c 79 20 74 68 65 20 6d 6f 73  arguably the mos
b970: 74 20 63 6f 6d 70 61 74 69 62 6c 65 20 77 69 74  t compatible wit
b980: 68 20 33 72 64 20 70 61 72 74 79 20 74 6f 6f 6c  h 3rd party tool
b990: 73 2e 20 20 49 74 20 69 73 0d 0a 20 20 2f 2f 2f  s.  It is..  ///
b9a0: 20 6e 6f 74 20 72 65 61 64 61 62 6c 65 20 61 73   not readable as
b9b0: 20 74 65 78 74 20 77 69 74 68 6f 75 74 20 70 6f   text without po
b9c0: 73 74 2d 70 72 6f 63 65 73 73 69 6e 67 2e 0d 0a  st-processing...
b9d0: 20 20 2f 2f 2f 20 54 69 63 6b 73 20 6c 65 73 73    /// Ticks less
b9e0: 20 63 6f 6d 70 61 74 69 62 6c 65 20 77 69 74 68   compatible with
b9f0: 20 33 72 64 20 70 61 72 74 79 20 74 6f 6f 6c 73   3rd party tools
ba00: 20 74 68 61 74 20 71 75 65 72 79 20 74 68 65 20   that query the 
ba10: 64 61 74 61 62 61 73 65 2c 20 61 6e 64 20 72 65  database, and re
ba20: 6e 64 65 72 73 20 74 68 65 20 44 61 74 65 54 69  nders the DateTi
ba30: 6d 65 20 66 69 65 6c 64 20 75 6e 72 65 61 64 61  me field unreada
ba40: 62 6c 65 20 61 73 20 74 65 78 74 20 77 69 74 68  ble as text with
ba50: 6f 75 74 20 70 6f 73 74 2d 70 72 6f 63 65 73 73  out post-process
ba60: 69 6e 67 2e 0d 0a 20 20 2f 2f 2f 0d 0a 20 20 2f  ing...  ///..  /
ba70: 2f 2f 20 54 68 65 20 70 72 65 66 65 72 72 65 64  // The preferred
ba80: 20 6f 72 64 65 72 20 6f 66 20 63 68 6f 6f 73 69   order of choosi
ba90: 6e 67 20 61 20 64 61 74 65 74 69 6d 65 20 66 6f  ng a datetime fo
baa0: 72 6d 61 74 20 69 73 20 4a 75 6c 69 61 6e 44 61  rmat is JulianDa
bab0: 79 2c 20 49 53 4f 38 36 30 31 2c 20 61 6e 64 20  y, ISO8601, and 
bac0: 74 68 65 6e 20 54 69 63 6b 73 2e 20 20 54 69 63  then Ticks.  Tic
bad0: 6b 73 20 69 73 20 6d 61 69 6e 6c 79 20 70 72 65  ks is mainly pre
bae0: 73 65 6e 74 20 66 6f 72 20 6c 65 67 61 63 79 0d  sent for legacy.
baf0: 0a 20 20 2f 2f 2f 20 63 6f 64 65 20 73 75 70 70  .  /// code supp
bb00: 6f 72 74 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 72 65  ort...  /// </re
bb10: 6d 61 72 6b 73 3e 0d 0a 20 20 70 75 62 6c 69 63  marks>..  public
bb20: 20 65 6e 75 6d 20 53 51 4c 69 74 65 44 61 74 65   enum SQLiteDate
bb30: 46 6f 72 6d 61 74 73 0d 0a 20 20 7b 0d 0a 20 20  Formats..  {..  
bb40: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
bb50: 0a 20 20 20 20 2f 2f 2f 20 55 73 65 20 74 68 65  .    /// Use the
bb60: 20 76 61 6c 75 65 20 6f 66 20 44 61 74 65 54 69   value of DateTi
bb70: 6d 65 2e 54 69 63 6b 73 2e 20 20 54 68 69 73 20  me.Ticks.  This 
bb80: 76 61 6c 75 65 20 69 73 20 6e 6f 74 20 72 65 63  value is not rec
bb90: 6f 6d 6d 65 6e 64 65 64 20 61 6e 64 20 69 73 20  ommended and is 
bba0: 6e 6f 74 20 77 65 6c 6c 20 73 75 70 70 6f 72 74  not well support
bbb0: 65 64 20 77 69 74 68 20 4c 49 4e 51 2e 0d 0a 20  ed with LINQ... 
bbc0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
bbd0: 3e 0d 0a 20 20 20 20 54 69 63 6b 73 20 3d 20 30  >..    Ticks = 0
bbe0: 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ,..    /// <summ
bbf0: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 55 73  ary>..    /// Us
bc00: 65 20 74 68 65 20 49 53 4f 2d 38 36 30 31 20 66  e the ISO-8601 f
bc10: 6f 72 6d 61 74 2e 20 20 55 73 65 73 20 74 68 65  ormat.  Uses the
bc20: 20 22 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a   "yyyy-MM-dd HH:
bc30: 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 4b 22 20  mm:ss.FFFFFFFK" 
bc40: 66 6f 72 6d 61 74 20 66 6f 72 20 55 54 43 20 44  format for UTC D
bc50: 61 74 65 54 69 6d 65 20 76 61 6c 75 65 73 20 61  ateTime values a
bc60: 6e 64 0d 0a 20 20 20 20 2f 2f 2f 20 22 79 79 79  nd..    /// "yyy
bc70: 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73  y-MM-dd HH:mm:ss
bc80: 2e 46 46 46 46 46 46 46 22 20 66 6f 72 6d 61 74  .FFFFFFF" format
bc90: 20 66 6f 72 20 6c 6f 63 61 6c 20 44 61 74 65 54   for local DateT
bca0: 69 6d 65 20 76 61 6c 75 65 73 29 2e 0d 0a 20 20  ime values)...  
bcb0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
bcc0: 0d 0a 20 20 20 20 49 53 4f 38 36 30 31 20 3d 20  ..    ISO8601 = 
bcd0: 31 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d  1,..    /// <sum
bce0: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54  mary>..    /// T
bcf0: 68 65 20 69 6e 74 65 72 76 61 6c 20 6f 66 20 74  he interval of t
bd00: 69 6d 65 20 69 6e 20 64 61 79 73 20 61 6e 64 20  ime in days and 
bd10: 66 72 61 63 74 69 6f 6e 73 20 6f 66 20 61 20 64  fractions of a d
bd20: 61 79 20 73 69 6e 63 65 20 4a 61 6e 75 61 72 79  ay since January
bd30: 20 31 2c 20 34 37 31 33 20 42 43 2e 0d 0a 20 20   1, 4713 BC...  
bd40: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
bd50: 0d 0a 20 20 20 20 4a 75 6c 69 61 6e 44 61 79 20  ..    JulianDay 
bd60: 3d 20 32 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73  = 2,..    /// <s
bd70: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
bd80: 20 54 68 65 20 77 68 6f 6c 65 20 6e 75 6d 62 65   The whole numbe
bd90: 72 20 6f 66 20 73 65 63 6f 6e 64 73 20 73 69 6e  r of seconds sin
bda0: 63 65 20 74 68 65 20 55 6e 69 78 20 65 70 6f 63  ce the Unix epoc
bdb0: 68 20 28 4a 61 6e 75 61 72 79 20 31 2c 20 31 39  h (January 1, 19
bdc0: 37 30 29 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  70)...    /// </
bdd0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 55 6e  summary>..    Un
bde0: 69 78 45 70 6f 63 68 20 3d 20 33 2c 0d 0a 20 20  ixEpoch = 3,..  
bdf0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
be00: 0a 20 20 20 20 2f 2f 2f 20 41 6e 79 20 63 75 6c  .    /// Any cul
be10: 74 75 72 65 2d 69 6e 64 65 70 65 6e 64 65 6e 74  ture-independent
be20: 20 73 74 72 69 6e 67 20 76 61 6c 75 65 20 74 68   string value th
be30: 61 74 20 74 68 65 20 2e 4e 45 54 20 46 72 61 6d  at the .NET Fram
be40: 65 77 6f 72 6b 20 63 61 6e 20 69 6e 74 65 72 70  ework can interp
be50: 72 65 74 20 61 73 20 61 20 76 61 6c 69 64 20 44  ret as a valid D
be60: 61 74 65 54 69 6d 65 2e 0d 0a 20 20 20 20 2f 2f  ateTime...    //
be70: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
be80: 20 20 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75    InvariantCultu
be90: 72 65 20 3d 20 34 2c 0d 0a 20 20 20 20 2f 2f 2f  re = 4,..    ///
bea0: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
beb0: 2f 2f 2f 20 41 6e 79 20 73 74 72 69 6e 67 20 76  /// Any string v
bec0: 61 6c 75 65 20 74 68 61 74 20 74 68 65 20 2e 4e  alue that the .N
bed0: 45 54 20 46 72 61 6d 65 77 6f 72 6b 20 63 61 6e  ET Framework can
bee0: 20 69 6e 74 65 72 70 72 65 74 20 61 73 20 61 20   interpret as a 
bef0: 76 61 6c 69 64 20 44 61 74 65 54 69 6d 65 20 75  valid DateTime u
bf00: 73 69 6e 67 20 74 68 65 20 63 75 72 72 65 6e 74  sing the current
bf10: 20 63 75 6c 74 75 72 65 2e 0d 0a 20 20 20 20 2f   culture...    /
bf20: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
bf30: 20 20 20 43 75 72 72 65 6e 74 43 75 6c 74 75 72     CurrentCultur
bf40: 65 20 3d 20 35 2c 0d 0a 20 20 20 20 2f 2f 2f 20  e = 5,..    /// 
bf50: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
bf60: 2f 2f 20 54 68 65 20 64 65 66 61 75 6c 74 20 66  // The default f
bf70: 6f 72 6d 61 74 20 66 6f 72 20 74 68 69 73 20 70  ormat for this p
bf80: 72 6f 76 69 64 65 72 2e 0d 0a 20 20 20 20 2f 2f  rovider...    //
bf90: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
bfa0: 20 20 44 65 66 61 75 6c 74 20 3d 20 49 53 4f 38    Default = ISO8
bfb0: 36 30 31 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 2f 2f  601..  }....  //
bfc0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f  / <summary>..  /
bfd0: 2f 2f 20 54 68 69 73 20 65 6e 75 6d 20 64 65 74  // This enum det
bfe0: 65 72 6d 69 6e 65 73 20 68 6f 77 20 53 51 4c 69  ermines how SQLi
bff0: 74 65 20 74 72 65 61 74 73 20 69 74 73 20 6a 6f  te treats its jo
c000: 75 72 6e 61 6c 20 66 69 6c 65 2e 0d 0a 20 20 2f  urnal file...  /
c010: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
c020: 20 2f 2f 2f 20 3c 72 65 6d 61 72 6b 73 3e 0d 0a   /// <remarks>..
c030: 20 20 2f 2f 2f 20 42 79 20 64 65 66 61 75 6c 74    /// By default
c040: 20 53 51 4c 69 74 65 20 77 69 6c 6c 20 63 72 65   SQLite will cre
c050: 61 74 65 20 61 6e 64 20 64 65 6c 65 74 65 20 74  ate and delete t
c060: 68 65 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20  he journal file 
c070: 77 68 65 6e 20 6e 65 65 64 65 64 20 64 75 72 69  when needed duri
c080: 6e 67 20 61 20 74 72 61 6e 73 61 63 74 69 6f 6e  ng a transaction
c090: 2e 0d 0a 20 20 2f 2f 2f 20 48 6f 77 65 76 65 72  ...  /// However
c0a0: 2c 20 66 6f 72 20 73 6f 6d 65 20 63 6f 6d 70 75  , for some compu
c0b0: 74 65 72 73 20 72 75 6e 6e 69 6e 67 20 63 65 72  ters running cer
c0c0: 74 61 69 6e 20 66 69 6c 65 73 79 73 74 65 6d 20  tain filesystem 
c0d0: 6d 6f 6e 69 74 6f 72 69 6e 67 20 74 6f 6f 6c 73  monitoring tools
c0e0: 2c 20 74 68 65 20 72 61 70 69 64 0d 0a 20 20 2f  , the rapid..  /
c0f0: 2f 2f 20 63 72 65 61 74 69 6f 6e 20 61 6e 64 20  // creation and 
c100: 64 65 6c 65 74 69 6f 6e 20 6f 66 20 74 68 65 20  deletion of the 
c110: 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20 63 61 6e  journal file can
c120: 20 63 61 75 73 65 20 74 68 6f 73 65 20 70 72 6f   cause those pro
c130: 67 72 61 6d 73 20 74 6f 20 66 61 69 6c 2c 20 6f  grams to fail, o
c140: 72 20 74 6f 20 69 6e 74 65 72 66 65 72 65 20 77  r to interfere w
c150: 69 74 68 20 53 51 4c 69 74 65 2e 0d 0a 20 20 2f  ith SQLite...  /
c160: 2f 2f 0d 0a 20 20 2f 2f 2f 20 49 66 20 61 20 70  //..  /// If a p
c170: 72 6f 67 72 61 6d 20 6f 72 20 76 69 72 75 73 20  rogram or virus 
c180: 73 63 61 6e 6e 65 72 20 69 73 20 69 6e 74 65 72  scanner is inter
c190: 66 65 72 69 6e 67 20 77 69 74 68 20 53 51 4c 69  fering with SQLi
c1a0: 74 65 27 73 20 6a 6f 75 72 6e 61 6c 20 66 69 6c  te's journal fil
c1b0: 65 2c 20 79 6f 75 20 6d 61 79 20 72 65 63 65 69  e, you may recei
c1c0: 76 65 20 65 72 72 6f 72 73 20 6c 69 6b 65 20 22  ve errors like "
c1d0: 75 6e 61 62 6c 65 20 74 6f 20 6f 70 65 6e 20 64  unable to open d
c1e0: 61 74 61 62 61 73 65 20 66 69 6c 65 22 0d 0a 20  atabase file".. 
c1f0: 20 2f 2f 2f 20 77 68 65 6e 20 73 74 61 72 74 69   /// when starti
c200: 6e 67 20 61 20 74 72 61 6e 73 61 63 74 69 6f 6e  ng a transaction
c210: 2e 20 20 49 66 20 74 68 69 73 20 69 73 20 68 61  .  If this is ha
c220: 70 70 65 6e 69 6e 67 2c 20 79 6f 75 20 6d 61 79  ppening, you may
c230: 20 77 61 6e 74 20 74 6f 20 63 68 61 6e 67 65 20   want to change 
c240: 74 68 65 20 64 65 66 61 75 6c 74 20 6a 6f 75 72  the default jour
c250: 6e 61 6c 20 6d 6f 64 65 20 74 6f 20 50 65 72 73  nal mode to Pers
c260: 69 73 74 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 72 65  ist...  /// </re
c270: 6d 61 72 6b 73 3e 0d 0a 20 20 70 75 62 6c 69 63  marks>..  public
c280: 20 65 6e 75 6d 20 53 51 4c 69 74 65 4a 6f 75 72   enum SQLiteJour
c290: 6e 61 6c 4d 6f 64 65 45 6e 75 6d 0d 0a 20 20 7b  nalModeEnum..  {
c2a0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
c2b0: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65  ry>..    /// The
c2c0: 20 64 65 66 61 75 6c 74 20 6d 6f 64 65 2c 20 74   default mode, t
c2d0: 68 69 73 20 63 61 75 73 65 73 20 53 51 4c 69 74  his causes SQLit
c2e0: 65 20 74 6f 20 75 73 65 20 74 68 65 20 65 78 69  e to use the exi
c2f0: 73 74 69 6e 67 20 6a 6f 75 72 6e 61 6c 69 6e 67  sting journaling
c300: 20 6d 6f 64 65 20 66 6f 72 20 74 68 65 20 64 61   mode for the da
c310: 74 61 62 61 73 65 2e 0d 0a 20 20 20 20 2f 2f 2f  tabase...    ///
c320: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20   </summary>..   
c330: 20 44 65 66 61 75 6c 74 20 3d 20 2d 31 2c 0d 0a   Default = -1,..
c340: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
c350: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 53 51 4c 69 74  >..    /// SQLit
c360: 65 20 77 69 6c 6c 20 63 72 65 61 74 65 20 61 6e  e will create an
c370: 64 20 64 65 73 74 72 6f 79 20 74 68 65 20 6a 6f  d destroy the jo
c380: 75 72 6e 61 6c 20 66 69 6c 65 20 61 73 2d 6e 65  urnal file as-ne
c390: 65 64 65 64 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  eded...    /// <
c3a0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 44  /summary>..    D
c3b0: 65 6c 65 74 65 20 3d 20 30 2c 0d 0a 20 20 20 20  elete = 0,..    
c3c0: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
c3d0: 20 20 20 2f 2f 2f 20 57 68 65 6e 20 74 68 69 73     /// When this
c3e0: 20 69 73 20 73 65 74 2c 20 53 51 4c 69 74 65 20   is set, SQLite 
c3f0: 77 69 6c 6c 20 6b 65 65 70 20 74 68 65 20 6a 6f  will keep the jo
c400: 75 72 6e 61 6c 20 66 69 6c 65 20 65 76 65 6e 20  urnal file even 
c410: 61 66 74 65 72 20 61 20 74 72 61 6e 73 61 63 74  after a transact
c420: 69 6f 6e 20 68 61 73 20 63 6f 6d 70 6c 65 74 65  ion has complete
c430: 64 2e 20 20 49 74 27 73 20 63 6f 6e 74 65 6e 74  d.  It's content
c440: 73 20 77 69 6c 6c 20 62 65 20 65 72 61 73 65 64  s will be erased
c450: 2c 0d 0a 20 20 20 20 2f 2f 2f 20 61 6e 64 20 74  ,..    /// and t
c460: 68 65 20 6a 6f 75 72 6e 61 6c 20 72 65 2d 75 73  he journal re-us
c470: 65 64 20 61 73 20 6f 66 74 65 6e 20 61 73 20 6e  ed as often as n
c480: 65 65 64 65 64 2e 20 20 49 66 20 69 74 20 69 73  eeded.  If it is
c490: 20 64 65 6c 65 74 65 64 2c 20 69 74 20 77 69 6c   deleted, it wil
c4a0: 6c 20 62 65 20 72 65 63 72 65 61 74 65 64 20 74  l be recreated t
c4b0: 68 65 20 6e 65 78 74 20 74 69 6d 65 20 69 74 20  he next time it 
c4c0: 69 73 20 6e 65 65 64 65 64 2e 0d 0a 20 20 20 20  is needed...    
c4d0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
c4e0: 20 20 20 20 50 65 72 73 69 73 74 20 3d 20 31 2c      Persist = 1,
c4f0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
c500: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 69  ry>..    /// Thi
c510: 73 20 6f 70 74 69 6f 6e 20 64 69 73 61 62 6c 65  s option disable
c520: 73 20 74 68 65 20 72 6f 6c 6c 62 61 63 6b 20 6a  s the rollback j
c530: 6f 75 72 6e 61 6c 20 65 6e 74 69 72 65 6c 79 2e  ournal entirely.
c540: 20 20 49 6e 74 65 72 72 75 70 74 65 64 20 74 72    Interrupted tr
c550: 61 6e 73 61 63 74 69 6f 6e 73 20 6f 72 20 61 20  ansactions or a 
c560: 70 72 6f 67 72 61 6d 20 63 72 61 73 68 20 63 61  program crash ca
c570: 6e 20 63 61 75 73 65 20 64 61 74 61 62 61 73 65  n cause database
c580: 0d 0a 20 20 20 20 2f 2f 2f 20 63 6f 72 72 75 70  ..    /// corrup
c590: 74 69 6f 6e 20 69 6e 20 74 68 69 73 20 6d 6f 64  tion in this mod
c5a0: 65 21 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  e!..    /// </su
c5b0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 4f 66 66 20  mmary>..    Off 
c5c0: 3d 20 32 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73  = 2,..    /// <s
c5d0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
c5e0: 20 53 51 4c 69 74 65 20 77 69 6c 6c 20 74 72 75   SQLite will tru
c5f0: 6e 63 61 74 65 20 74 68 65 20 6a 6f 75 72 6e 61  ncate the journa
c600: 6c 20 66 69 6c 65 20 74 6f 20 7a 65 72 6f 2d 6c  l file to zero-l
c610: 65 6e 67 74 68 20 69 6e 73 74 65 61 64 20 6f 66  ength instead of
c620: 20 64 65 6c 65 74 69 6e 67 20 69 74 2e 0d 0a 20   deleting it... 
c630: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
c640: 3e 0d 0a 20 20 20 20 54 72 75 6e 63 61 74 65 20  >..    Truncate 
c650: 3d 20 33 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73  = 3,..    /// <s
c660: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
c670: 20 53 51 4c 69 74 65 20 77 69 6c 6c 20 73 74 6f   SQLite will sto
c680: 72 65 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20 69  re the journal i
c690: 6e 20 76 6f 6c 61 74 69 6c 65 20 52 41 4d 2e 20  n volatile RAM. 
c6a0: 20 54 68 69 73 20 73 61 76 65 73 20 64 69 73 6b   This saves disk
c6b0: 20 49 2f 4f 20 62 75 74 20 61 74 20 74 68 65 20   I/O but at the 
c6c0: 65 78 70 65 6e 73 65 20 6f 66 20 64 61 74 61 62  expense of datab
c6d0: 61 73 65 20 73 61 66 65 74 79 20 61 6e 64 20 69  ase safety and i
c6e0: 6e 74 65 67 72 69 74 79 2e 0d 0a 20 20 20 20 2f  ntegrity...    /
c6f0: 2f 2f 20 49 66 20 74 68 65 20 61 70 70 6c 69 63  // If the applic
c700: 61 74 69 6f 6e 20 75 73 69 6e 67 20 53 51 4c 69  ation using SQLi
c710: 74 65 20 63 72 61 73 68 65 73 20 69 6e 20 74 68  te crashes in th
c720: 65 20 6d 69 64 64 6c 65 20 6f 66 20 61 20 74 72  e middle of a tr
c730: 61 6e 73 61 63 74 69 6f 6e 20 77 68 65 6e 20 74  ansaction when t
c740: 68 65 20 4d 45 4d 4f 52 59 20 6a 6f 75 72 6e 61  he MEMORY journa
c750: 6c 69 6e 67 20 6d 6f 64 65 20 69 73 20 73 65 74  ling mode is set
c760: 2c 20 74 68 65 6e 20 74 68 65 0d 0a 20 20 20 20  , then the..    
c770: 2f 2f 2f 20 64 61 74 61 62 61 73 65 20 66 69 6c  /// database fil
c780: 65 20 77 69 6c 6c 20 76 65 72 79 20 6c 69 6b 65  e will very like
c790: 6c 79 20 67 6f 20 63 6f 72 72 75 70 74 2e 0d 0a  ly go corrupt...
c7a0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
c7b0: 79 3e 0d 0a 20 20 20 20 4d 65 6d 6f 72 79 20 3d  y>..    Memory =
c7c0: 20 34 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75   4,..    /// <su
c7d0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
c7e0: 53 51 4c 69 74 65 20 75 73 65 73 20 61 20 77 72  SQLite uses a wr
c7f0: 69 74 65 2d 61 68 65 61 64 20 6c 6f 67 20 69 6e  ite-ahead log in
c800: 73 74 65 61 64 20 6f 66 20 61 20 72 6f 6c 6c 62  stead of a rollb
c810: 61 63 6b 20 6a 6f 75 72 6e 61 6c 20 74 6f 20 69  ack journal to i
c820: 6d 70 6c 65 6d 65 6e 74 20 74 72 61 6e 73 61 63  mplement transac
c830: 74 69 6f 6e 73 2e 20 20 54 68 65 20 57 41 4c 20  tions.  The WAL 
c840: 6a 6f 75 72 6e 61 6c 69 6e 67 20 6d 6f 64 65 20  journaling mode 
c850: 69 73 20 70 65 72 73 69 73 74 65 6e 74 3b 0d 0a  is persistent;..
c860: 20 20 20 20 2f 2f 2f 20 61 66 74 65 72 20 62 65      /// after be
c870: 69 6e 67 20 73 65 74 20 69 74 20 73 74 61 79 73  ing set it stays
c880: 20 69 6e 20 65 66 66 65 63 74 20 61 63 72 6f 73   in effect acros
c890: 73 20 6d 75 6c 74 69 70 6c 65 20 64 61 74 61 62  s multiple datab
c8a0: 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 73 20  ase connections 
c8b0: 61 6e 64 20 61 66 74 65 72 20 63 6c 6f 73 69 6e  and after closin
c8c0: 67 20 61 6e 64 20 72 65 6f 70 65 6e 69 6e 67 20  g and reopening 
c8d0: 74 68 65 20 64 61 74 61 62 61 73 65 2e 20 41 20  the database. A 
c8e0: 64 61 74 61 62 61 73 65 0d 0a 20 20 20 20 2f 2f  database..    //
c8f0: 2f 20 69 6e 20 57 41 4c 20 6a 6f 75 72 6e 61 6c  / in WAL journal
c900: 69 6e 67 20 6d 6f 64 65 20 63 61 6e 20 6f 6e 6c  ing mode can onl
c910: 79 20 62 65 20 61 63 63 65 73 73 65 64 20 62 79  y be accessed by
c920: 20 53 51 4c 69 74 65 20 76 65 72 73 69 6f 6e 20   SQLite version 
c930: 33 2e 37 2e 30 20 6f 72 20 6c 61 74 65 72 2e 0d  3.7.0 or later..
c940: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
c950: 72 79 3e 0d 0a 20 20 20 20 57 61 6c 20 3d 20 35  ry>..    Wal = 5
c960: 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 2f 2f 2f 20 3c  ..  }....  /// <
c970: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f 20  summary>..  /// 
c980: 50 6f 73 73 69 62 6c 65 20 76 61 6c 75 65 73 20  Possible values 
c990: 66 6f 72 20 74 68 65 20 22 73 79 6e 63 68 72 6f  for the "synchro
c9a0: 6e 6f 75 73 22 20 64 61 74 61 62 61 73 65 20 73  nous" database s
c9b0: 65 74 74 69 6e 67 2e 20 20 54 68 69 73 20 73 65  etting.  This se
c9c0: 74 74 69 6e 67 20 64 65 74 65 72 6d 69 6e 65 73  tting determines
c9d0: 0d 0a 20 20 2f 2f 2f 20 68 6f 77 20 6f 66 74 65  ..  /// how ofte
c9e0: 6e 20 74 68 65 20 64 61 74 61 62 61 73 65 20 65  n the database e
c9f0: 6e 67 69 6e 65 20 63 61 6c 6c 73 20 74 68 65 20  ngine calls the 
ca00: 78 53 79 6e 63 20 6d 65 74 68 6f 64 20 6f 66 20  xSync method of 
ca10: 74 68 65 20 56 46 53 2e 0d 0a 20 20 2f 2f 2f 20  the VFS...  /// 
ca20: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 69 6e  </summary>..  in
ca30: 74 65 72 6e 61 6c 20 65 6e 75 6d 20 53 51 4c 69  ternal enum SQLi
ca40: 74 65 53 79 6e 63 68 72 6f 6e 6f 75 73 45 6e 75  teSynchronousEnu
ca50: 6d 0d 0a 20 20 7b 0d 0a 20 20 20 20 20 20 2f 2f  m..  {..      //
ca60: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
ca70: 20 20 20 2f 2f 2f 20 55 73 65 20 74 68 65 20 64     /// Use the d
ca80: 65 66 61 75 6c 74 20 22 73 79 6e 63 68 72 6f 6e  efault "synchron
ca90: 6f 75 73 22 20 64 61 74 61 62 61 73 65 20 73 65  ous" database se
caa0: 74 74 69 6e 67 2e 20 20 43 75 72 72 65 6e 74 6c  tting.  Currentl
cab0: 79 2c 20 74 68 69 73 20 73 68 6f 75 6c 64 20 62  y, this should b
cac0: 65 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 74 68 65  e..      /// the
cad0: 20 73 61 6d 65 20 61 73 20 75 73 69 6e 67 20 74   same as using t
cae0: 68 65 20 46 55 4c 4c 20 6d 6f 64 65 2e 0d 0a 20  he FULL mode... 
caf0: 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61       /// </summa
cb00: 72 79 3e 0d 0a 20 20 20 20 20 20 44 65 66 61 75  ry>..      Defau
cb10: 6c 74 20 3d 20 2d 31 2c 0d 0a 0d 0a 20 20 20 20  lt = -1,....    
cb20: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
cb30: 0a 20 20 20 20 20 20 2f 2f 2f 20 54 68 65 20 64  .      /// The d
cb40: 61 74 61 62 61 73 65 20 65 6e 67 69 6e 65 20 63  atabase engine c
cb50: 6f 6e 74 69 6e 75 65 73 20 77 69 74 68 6f 75 74  ontinues without
cb60: 20 73 79 6e 63 69 6e 67 20 61 73 20 73 6f 6f 6e   syncing as soon
cb70: 20 61 73 20 69 74 20 68 61 73 20 68 61 6e 64 65   as it has hande
cb80: 64 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 64 61 74  d..      /// dat
cb90: 61 20 6f 66 66 20 74 6f 20 74 68 65 20 6f 70 65  a off to the ope
cba0: 72 61 74 69 6e 67 20 73 79 73 74 65 6d 2e 20 20  rating system.  
cbb0: 49 66 20 74 68 65 20 61 70 70 6c 69 63 61 74 69  If the applicati
cbc0: 6f 6e 20 72 75 6e 6e 69 6e 67 20 53 51 4c 69 74  on running SQLit
cbd0: 65 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 63 72 61  e..      /// cra
cbe0: 73 68 65 73 2c 20 74 68 65 20 64 61 74 61 20 77  shes, the data w
cbf0: 69 6c 6c 20 62 65 20 73 61 66 65 2c 20 62 75 74  ill be safe, but
cc00: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 6d 69   the database mi
cc10: 67 68 74 20 62 65 63 6f 6d 65 20 63 6f 72 72 75  ght become corru
cc20: 70 74 65 64 0d 0a 20 20 20 20 20 20 2f 2f 2f 20  pted..      /// 
cc30: 69 66 20 74 68 65 20 6f 70 65 72 61 74 69 6e 67  if the operating
cc40: 20 73 79 73 74 65 6d 20 63 72 61 73 68 65 73 20   system crashes 
cc50: 6f 72 20 74 68 65 20 63 6f 6d 70 75 74 65 72 20  or the computer 
cc60: 6c 6f 73 65 73 20 70 6f 77 65 72 20 62 65 66 6f  loses power befo
cc70: 72 65 20 74 68 61 74 0d 0a 20 20 20 20 20 20 2f  re that..      /
cc80: 2f 2f 20 64 61 74 61 20 68 61 73 20 62 65 65 6e  // data has been
cc90: 20 77 72 69 74 74 65 6e 20 74 6f 20 74 68 65 20   written to the 
cca0: 64 69 73 6b 20 73 75 72 66 61 63 65 2e 0d 0a 20  disk surface... 
ccb0: 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61       /// </summa
ccc0: 72 79 3e 0d 0a 20 20 20 20 20 20 4f 66 66 20 3d  ry>..      Off =
ccd0: 20 30 2c 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f 2f   0,....      ///
cce0: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
ccf0: 20 20 2f 2f 2f 20 54 68 65 20 64 61 74 61 62 61    /// The databa
cd00: 73 65 20 65 6e 67 69 6e 65 20 77 69 6c 6c 20 73  se engine will s
cd10: 74 69 6c 6c 20 73 79 6e 63 20 61 74 20 74 68 65  till sync at the
cd20: 20 6d 6f 73 74 20 63 72 69 74 69 63 61 6c 20 6d   most critical m
cd30: 6f 6d 65 6e 74 73 2c 20 62 75 74 0d 0a 20 20 20  oments, but..   
cd40: 20 20 20 2f 2f 2f 20 6c 65 73 73 20 6f 66 74 65     /// less ofte
cd50: 6e 20 74 68 61 6e 20 69 6e 20 46 55 4c 4c 20 6d  n than in FULL m
cd60: 6f 64 65 2e 20 20 54 68 65 72 65 20 69 73 20 61  ode.  There is a
cd70: 20 76 65 72 79 20 73 6d 61 6c 6c 20 28 74 68 6f   very small (tho
cd80: 75 67 68 20 6e 6f 6e 2d 7a 65 72 6f 29 0d 0a 20  ugh non-zero).. 
cd90: 20 20 20 20 20 2f 2f 2f 20 63 68 61 6e 63 65 20       /// chance 
cda0: 74 68 61 74 20 61 20 70 6f 77 65 72 20 66 61 69  that a power fai
cdb0: 6c 75 72 65 20 61 74 20 6a 75 73 74 20 74 68 65  lure at just the
cdc0: 20 77 72 6f 6e 67 20 74 69 6d 65 20 63 6f 75 6c   wrong time coul
cdd0: 64 20 63 6f 72 72 75 70 74 20 74 68 65 0d 0a 20  d corrupt the.. 
cde0: 20 20 20 20 20 2f 2f 2f 20 64 61 74 61 62 61 73       /// databas
cdf0: 65 20 69 6e 20 4e 4f 52 4d 41 4c 20 6d 6f 64 65  e in NORMAL mode
ce00: 2e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73  ...      /// </s
ce10: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 4e  ummary>..      N
ce20: 6f 72 6d 61 6c 20 3d 20 31 2c 0d 0a 0d 0a 20 20  ormal = 1,....  
ce30: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
ce40: 3e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 54 68 65  >..      /// The
ce50: 20 64 61 74 61 62 61 73 65 20 65 6e 67 69 6e 65   database engine
ce60: 20 77 69 6c 6c 20 75 73 65 20 74 68 65 20 78 53   will use the xS
ce70: 79 6e 63 20 6d 65 74 68 6f 64 20 6f 66 20 74 68  ync method of th
ce80: 65 20 56 46 53 20 74 6f 20 65 6e 73 75 72 65 20  e VFS to ensure 
ce90: 74 68 61 74 0d 0a 20 20 20 20 20 20 2f 2f 2f 20  that..      /// 
cea0: 61 6c 6c 20 63 6f 6e 74 65 6e 74 20 69 73 20 73  all content is s
ceb0: 61 66 65 6c 79 20 77 72 69 74 74 65 6e 20 74 6f  afely written to
cec0: 20 74 68 65 20 64 69 73 6b 20 73 75 72 66 61 63   the disk surfac
ced0: 65 20 70 72 69 6f 72 20 74 6f 20 63 6f 6e 74 69  e prior to conti
cee0: 6e 75 69 6e 67 2e 0d 0a 20 20 20 20 20 20 2f 2f  nuing...      //
cef0: 2f 20 54 68 69 73 20 65 6e 73 75 72 65 73 20 74  / This ensures t
cf00: 68 61 74 20 61 6e 20 6f 70 65 72 61 74 69 6e 67  hat an operating
cf10: 20 73 79 73 74 65 6d 20 63 72 61 73 68 20 6f 72   system crash or
cf20: 20 70 6f 77 65 72 20 66 61 69 6c 75 72 65 20 77   power failure w
cf30: 69 6c 6c 20 6e 6f 74 0d 0a 20 20 20 20 20 20 2f  ill not..      /
cf40: 2f 2f 20 63 6f 72 72 75 70 74 20 74 68 65 20 64  // corrupt the d
cf50: 61 74 61 62 61 73 65 2e 20 20 46 55 4c 4c 20 73  atabase.  FULL s
cf60: 79 6e 63 68 72 6f 6e 6f 75 73 20 69 73 20 76 65  ynchronous is ve
cf70: 72 79 20 73 61 66 65 2c 20 62 75 74 20 69 74 20  ry safe, but it 
cf80: 69 73 20 61 6c 73 6f 0d 0a 20 20 20 20 20 20 2f  is also..      /
cf90: 2f 2f 20 73 6c 6f 77 65 72 2e 0d 0a 20 20 20 20  // slower...    
cfa0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
cfb0: 0d 0a 20 20 20 20 20 20 46 75 6c 6c 20 3d 20 32  ..      Full = 2
cfc0: 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 2f 2f 2f 20 3c  ..  }....  /// <
cfd0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f 20  summary>..  /// 
cfe0: 54 68 65 20 72 65 71 75 65 73 74 65 64 20 63 6f  The requested co
cff0: 6d 6d 61 6e 64 20 65 78 65 63 75 74 69 6f 6e 20  mmand execution 
d000: 74 79 70 65 2e 20 20 54 68 69 73 20 63 6f 6e 74  type.  This cont
d010: 72 6f 6c 73 20 77 68 69 63 68 20 6d 65 74 68 6f  rols which metho
d020: 64 20 6f 66 20 74 68 65 0d 0a 20 20 2f 2f 2f 20  d of the..  /// 
d030: 3c 73 65 65 20 63 72 65 66 3d 22 53 51 4c 69 74  <see cref="SQLit
d040: 65 43 6f 6d 6d 61 6e 64 22 20 2f 3e 20 6f 62 6a  eCommand" /> obj
d050: 65 63 74 20 77 69 6c 6c 20 62 65 20 63 61 6c 6c  ect will be call
d060: 65 64 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ed...  /// </sum
d070: 6d 61 72 79 3e 0d 0a 20 20 70 75 62 6c 69 63 20  mary>..  public 
d080: 65 6e 75 6d 20 53 51 4c 69 74 65 45 78 65 63 75  enum SQLiteExecu
d090: 74 65 54 79 70 65 0d 0a 20 20 7b 0d 0a 20 20 20  teType..  {..   
d0a0: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
d0b0: 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 44 6f 20 6e  ..      /// Do n
d0c0: 6f 74 68 69 6e 67 2e 20 20 4e 6f 20 6d 65 74 68  othing.  No meth
d0d0: 6f 64 20 77 69 6c 6c 20 62 65 20 63 61 6c 6c 65  od will be calle
d0e0: 64 2e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 2f  d...      /// </
d0f0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20  summary>..      
d100: 4e 6f 6e 65 20 3d 20 30 2c 0d 0a 0d 0a 20 20 20  None = 0,....   
d110: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
d120: 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 54 68 65 20  ..      /// The 
d130: 63 6f 6d 6d 61 6e 64 20 69 73 20 6e 6f 74 20 65  command is not e
d140: 78 70 65 63 74 65 64 20 74 6f 20 72 65 74 75 72  xpected to retur
d150: 6e 20 61 20 72 65 73 75 6c 74 20 2d 4f 52 2d 20  n a result -OR- 
d160: 74 68 65 20 72 65 73 75 6c 74 20 69 73 20 6e 6f  the result is no
d170: 74 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 6e 65 65  t..      /// nee
d180: 64 65 64 2e 20 20 54 68 65 20 3c 73 65 65 20 63  ded.  The <see c
d190: 72 65 66 3d 22 53 51 4c 69 74 65 43 6f 6d 6d 61  ref="SQLiteComma
d1a0: 6e 64 2e 45 78 65 63 75 74 65 4e 6f 6e 51 75 65  nd.ExecuteNonQue
d1b0: 72 79 22 20 2f 3e 20 6d 65 74 68 6f 64 20 77 69  ry" /> method wi
d1c0: 6c 6c 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 62 65  ll..      /// be
d1d0: 20 63 61 6c 6c 65 64 2e 0d 0a 20 20 20 20 20 20   called...      
d1e0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
d1f0: 20 20 20 20 20 20 4e 6f 6e 51 75 65 72 79 20 3d        NonQuery =
d200: 20 31 2c 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f 2f   1,....      ///
d210: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
d220: 20 20 2f 2f 2f 20 54 68 65 20 63 6f 6d 6d 61 6e    /// The comman
d230: 64 20 69 73 20 65 78 70 65 63 74 65 64 20 74 6f  d is expected to
d240: 20 72 65 74 75 72 6e 20 61 20 73 63 61 6c 61 72   return a scalar
d250: 20 72 65 73 75 6c 74 20 2d 4f 52 2d 20 74 68 65   result -OR- the
d260: 20 72 65 73 75 6c 74 20 73 68 6f 75 6c 64 0d 0a   result should..
d270: 20 20 20 20 20 20 2f 2f 2f 20 62 65 20 6c 69 6d        /// be lim
d280: 69 74 65 64 20 74 6f 20 61 20 73 63 61 6c 61 72  ited to a scalar
d290: 20 72 65 73 75 6c 74 2e 20 20 54 68 65 20 3c 73   result.  The <s
d2a0: 65 65 20 63 72 65 66 3d 22 53 51 4c 69 74 65 43  ee cref="SQLiteC
d2b0: 6f 6d 6d 61 6e 64 2e 45 78 65 63 75 74 65 53 63  ommand.ExecuteSc
d2c0: 61 6c 61 72 22 20 2f 3e 0d 0a 20 20 20 20 20 20  alar" />..      
d2d0: 2f 2f 2f 20 6d 65 74 68 6f 64 20 77 69 6c 6c 20  /// method will 
d2e0: 62 65 20 63 61 6c 6c 65 64 2e 0d 0a 20 20 20 20  be called...    
d2f0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
d300: 0d 0a 20 20 20 20 20 20 53 63 61 6c 61 72 20 3d  ..      Scalar =
d310: 20 32 2c 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f 2f   2,....      ///
d320: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
d330: 20 20 2f 2f 2f 20 54 68 65 20 63 6f 6d 6d 61 6e    /// The comman
d340: 64 20 69 73 20 65 78 70 65 63 74 65 64 20 74 6f  d is expected to
d350: 20 72 65 74 75 72 6e 20 3c 73 65 65 20 63 72 65   return <see cre
d360: 66 3d 22 53 51 4c 69 74 65 44 61 74 61 52 65 61  f="SQLiteDataRea
d370: 64 65 72 22 2f 3e 20 72 65 73 75 6c 74 2e 0d 0a  der"/> result...
d380: 20 20 20 20 20 20 2f 2f 2f 20 54 68 65 20 3c 73        /// The <s
d390: 65 65 20 63 72 65 66 3d 22 53 51 4c 69 74 65 43  ee cref="SQLiteC
d3a0: 6f 6d 6d 61 6e 64 2e 45 78 65 63 75 74 65 52 65  ommand.ExecuteRe
d3b0: 61 64 65 72 28 29 22 20 2f 3e 20 6d 65 74 68 6f  ader()" /> metho
d3c0: 64 20 77 69 6c 6c 20 62 65 20 63 61 6c 6c 65 64  d will be called
d3d0: 2e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73  ...      /// </s
d3e0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 52  ummary>..      R
d3f0: 65 61 64 65 72 20 3d 20 33 2c 0d 0a 0d 0a 20 20  eader = 3,....  
d400: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
d410: 3e 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 55 73 65  >..      /// Use
d420: 20 74 68 65 20 64 65 66 61 75 6c 74 20 63 6f 6d   the default com
d430: 6d 61 6e 64 20 65 78 65 63 75 74 69 6f 6e 20 74  mand execution t
d440: 79 70 65 2e 20 20 55 73 69 6e 67 20 74 68 69 73  ype.  Using this
d450: 20 76 61 6c 75 65 20 69 73 20 74 68 65 20 73 61   value is the sa
d460: 6d 65 0d 0a 20 20 20 20 20 20 2f 2f 2f 20 61 73  me..      /// as
d470: 20 75 73 69 6e 67 20 74 68 65 20 3c 73 65 65 20   using the <see 
d480: 63 72 65 66 3d 22 53 51 4c 69 74 65 45 78 65 63  cref="SQLiteExec
d490: 75 74 65 54 79 70 65 2e 4e 6f 6e 51 75 65 72 79  uteType.NonQuery
d4a0: 22 20 2f 3e 20 76 61 6c 75 65 2e 0d 0a 20 20 20  " /> value...   
d4b0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
d4c0: 3e 0d 0a 20 20 20 20 20 20 44 65 66 61 75 6c 74  >..      Default
d4d0: 20 3d 20 4e 6f 6e 51 75 65 72 79 20 2f 2a 20 54   = NonQuery /* T
d4e0: 4f 44 4f 3a 20 47 6f 6f 64 20 64 65 66 61 75 6c  ODO: Good defaul
d4f0: 74 3f 20 2a 2f 0d 0a 20 20 7d 0d 0a 0d 0a 20 20  t? */..  }....  
d500: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
d510: 20 2f 2f 2f 20 43 6c 61 73 73 20 75 73 65 64 20   /// Class used 
d520: 69 6e 74 65 72 6e 61 6c 6c 79 20 74 6f 20 64 65  internally to de
d530: 74 65 72 6d 69 6e 65 20 74 68 65 20 64 61 74 61  termine the data
d540: 74 79 70 65 20 6f 66 20 61 20 63 6f 6c 75 6d 6e  type of a column
d550: 20 69 6e 20 61 20 72 65 73 75 6c 74 73 65 74 0d   in a resultset.
d560: 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79  .  /// </summary
d570: 3e 0d 0a 20 20 69 6e 74 65 72 6e 61 6c 20 73 65  >..  internal se
d580: 61 6c 65 64 20 63 6c 61 73 73 20 53 51 4c 69 74  aled class SQLit
d590: 65 54 79 70 65 0d 0a 20 20 7b 0d 0a 20 20 20 20  eType..  {..    
d5a0: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
d5b0: 20 20 20 2f 2f 2f 20 54 68 65 20 44 62 54 79 70     /// The DbTyp
d5c0: 65 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 2c  e of the column,
d5d0: 20 6f 72 20 44 62 54 79 70 65 2e 4f 62 6a 65 63   or DbType.Objec
d5e0: 74 20 69 66 20 69 74 20 63 61 6e 6e 6f 74 20 62  t if it cannot b
d5f0: 65 20 64 65 74 65 72 6d 69 6e 65 64 0d 0a 20 20  e determined..  
d600: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
d610: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 44  ..    internal D
d620: 62 54 79 70 65 20 54 79 70 65 3b 0d 0a 20 20 20  bType Type;..   
d630: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
d640: 20 20 20 20 2f 2f 2f 20 54 68 65 20 61 66 66 69      /// The affi
d650: 6e 69 74 79 20 6f 66 20 61 20 63 6f 6c 75 6d 6e  nity of a column
d660: 2c 20 75 73 65 64 20 66 6f 72 20 65 78 70 72 65  , used for expre
d670: 73 73 69 6f 6e 73 20 6f 72 20 77 68 65 6e 20 54  ssions or when T
d680: 79 70 65 20 69 73 20 44 62 54 79 70 65 2e 4f 62  ype is DbType.Ob
d690: 6a 65 63 74 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ject..    /// </
d6a0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 69 6e  summary>..    in
d6b0: 74 65 72 6e 61 6c 20 54 79 70 65 41 66 66 69 6e  ternal TypeAffin
d6c0: 69 74 79 20 41 66 66 69 6e 69 74 79 3b 0d 0a 20  ity Affinity;.. 
d6d0: 20 7d 0d 0a 0d 0a 20 20 2f 2f 2f 2f 2f 2f 2f 2f   }....  ////////
d6e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d6f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d700: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d710: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d720: 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 69 6e 74 65 72  /////....  inter
d730: 6e 61 6c 20 73 65 61 6c 65 64 20 63 6c 61 73 73  nal sealed class
d740: 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70   SQLiteDbTypeMap
d750: 0d 0a 20 20 20 20 20 20 3a 20 44 69 63 74 69 6f  ..      : Dictio
d760: 6e 61 72 79 3c 73 74 72 69 6e 67 2c 20 53 51 4c  nary<string, SQL
d770: 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67  iteDbTypeMapping
d780: 3e 0d 0a 20 20 7b 0d 0a 20 20 20 20 20 20 70 72  >..  {..      pr
d790: 69 76 61 74 65 20 44 69 63 74 69 6f 6e 61 72 79  ivate Dictionary
d7a0: 3c 44 62 54 79 70 65 2c 20 53 51 4c 69 74 65 44  <DbType, SQLiteD
d7b0: 62 54 79 70 65 4d 61 70 70 69 6e 67 3e 20 72 65  bTypeMapping> re
d7c0: 76 65 72 73 65 3b 0d 0a 0d 0a 20 20 20 20 20 20  verse;....      
d7d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d7e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d7f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d800: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d810: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20  /////////....   
d820: 20 20 20 70 72 69 76 61 74 65 20 53 51 4c 69 74     private SQLit
d830: 65 44 62 54 79 70 65 4d 61 70 28 29 0d 0a 20 20  eDbTypeMap()..  
d840: 20 20 20 20 20 20 20 20 3a 20 62 61 73 65 28 6e          : base(n
d850: 65 77 20 54 79 70 65 4e 61 6d 65 53 74 72 69 6e  ew TypeNameStrin
d860: 67 43 6f 6d 70 61 72 65 72 28 29 29 0d 0a 20 20  gComparer())..  
d870: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
d880: 20 72 65 76 65 72 73 65 20 3d 20 6e 65 77 20 44   reverse = new D
d890: 69 63 74 69 6f 6e 61 72 79 3c 44 62 54 79 70 65  ictionary<DbType
d8a0: 2c 20 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61  , SQLiteDbTypeMa
d8b0: 70 70 69 6e 67 3e 28 29 3b 0d 0a 20 20 20 20 20  pping>();..     
d8c0: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 2f 2f 2f 2f   }....      ////
d8d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d8e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d8f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d900: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d910: 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20 70  /////....      p
d920: 75 62 6c 69 63 20 53 51 4c 69 74 65 44 62 54 79  ublic SQLiteDbTy
d930: 70 65 4d 61 70 28 0d 0a 20 20 20 20 20 20 20 20  peMap(..        
d940: 20 20 49 45 6e 75 6d 65 72 61 62 6c 65 3c 53 51    IEnumerable<SQ
d950: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e  LiteDbTypeMappin
d960: 67 3e 20 63 6f 6c 6c 65 63 74 69 6f 6e 0d 0a 20  g> collection.. 
d970: 20 20 20 20 20 20 20 20 20 29 0d 0a 20 20 20 20           )..    
d980: 20 20 20 20 20 20 3a 20 74 68 69 73 28 29 0d 0a        : this()..
d990: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
d9a0: 20 20 20 41 64 64 28 63 6f 6c 6c 65 63 74 69 6f     Add(collectio
d9b0: 6e 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a  n);..      }....
d9c0: 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f        //////////
d9d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d9e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d9f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
da00: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d  ///////////////.
da10: 0a 0d 0a 20 20 20 20 20 20 70 75 62 6c 69 63 20  ...      public 
da20: 76 6f 69 64 20 41 64 64 28 0d 0a 20 20 20 20 20  void Add(..     
da30: 20 20 20 20 20 49 45 6e 75 6d 65 72 61 62 6c 65       IEnumerable
da40: 3c 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70  <SQLiteDbTypeMap
da50: 70 69 6e 67 3e 20 63 6f 6c 6c 65 63 74 69 6f 6e  ping> collection
da60: 0d 0a 20 20 20 20 20 20 20 20 20 20 29 0d 0a 20  ..          ).. 
da70: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
da80: 20 20 69 66 20 28 63 6f 6c 6c 65 63 74 69 6f 6e    if (collection
da90: 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20   == null)..     
daa0: 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e           throw n
dab0: 65 77 20 41 72 67 75 6d 65 6e 74 4e 75 6c 6c 45  ew ArgumentNullE
dac0: 78 63 65 70 74 69 6f 6e 28 22 63 6f 6c 6c 65 63  xception("collec
dad0: 74 69 6f 6e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20  tion");....     
dae0: 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 53 51       foreach (SQ
daf0: 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e  LiteDbTypeMappin
db00: 67 20 69 74 65 6d 20 69 6e 20 63 6f 6c 6c 65 63  g item in collec
db10: 74 69 6f 6e 29 0d 0a 20 20 20 20 20 20 20 20 20  tion)..         
db20: 20 20 20 20 20 41 64 64 28 69 74 65 6d 29 3b 0d       Add(item);.
db30: 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  .      }....    
db40: 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f    //////////////
db50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
db60: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
db70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
db80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20  ///////////.... 
db90: 20 20 20 20 20 70 75 62 6c 69 63 20 6e 65 77 20       public new 
dba0: 76 6f 69 64 20 41 64 64 28 0d 0a 20 20 20 20 20  void Add(..     
dbb0: 20 20 20 20 20 73 74 72 69 6e 67 20 6b 65 79 2c       string key,
dbc0: 20 2f 2a 20 49 47 4e 4f 52 45 44 20 2a 2f 0d 0a   /* IGNORED */..
dbd0: 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65            SQLite
dbe0: 44 62 54 79 70 65 4d 61 70 70 69 6e 67 20 76 61  DbTypeMapping va
dbf0: 6c 75 65 0d 0a 20 20 20 20 20 20 20 20 20 20 29  lue..          )
dc00: 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20  ..      {..     
dc10: 20 20 20 20 20 41 64 64 28 76 61 6c 75 65 29 3b       Add(value);
dc20: 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  ..      }....   
dc30: 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f     /////////////
dc40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
dc50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
dc60: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
dc70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a  ////////////....
dc80: 20 20 20 20 20 20 70 75 62 6c 69 63 20 76 6f 69        public voi
dc90: 64 20 41 64 64 28 53 51 4c 69 74 65 44 62 54 79  d Add(SQLiteDbTy
dca0: 70 65 4d 61 70 70 69 6e 67 20 69 74 65 6d 29 0d  peMapping item).
dcb0: 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  .      {..      
dcc0: 20 20 20 20 69 66 20 28 69 74 65 6d 20 3d 3d 20      if (item == 
dcd0: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
dce0: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41       throw new A
dcf0: 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70  rgumentNullExcep
dd00: 74 69 6f 6e 28 22 69 74 65 6d 22 29 3b 0d 0a 0d  tion("item");...
dd10: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28 69  .          if (i
dd20: 74 65 6d 2e 74 79 70 65 4e 61 6d 65 20 3d 3d 20  tem.typeName == 
dd30: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
dd40: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41       throw new A
dd50: 72 67 75 6d 65 6e 74 45 78 63 65 70 74 69 6f 6e  rgumentException
dd60: 28 22 69 74 65 6d 20 74 79 70 65 20 6e 61 6d 65  ("item type name
dd70: 20 63 61 6e 6e 6f 74 20 62 65 20 6e 75 6c 6c 22   cannot be null"
dd80: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
dd90: 62 61 73 65 2e 41 64 64 28 69 74 65 6d 2e 74 79  base.Add(item.ty
dda0: 70 65 4e 61 6d 65 2c 20 69 74 65 6d 29 3b 0d 0a  peName, item);..
ddb0: 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28  ..          if (
ddc0: 69 74 65 6d 2e 70 72 69 6d 61 72 79 29 0d 0a 20  item.primary).. 
ddd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 76               rev
dde0: 65 72 73 65 2e 41 64 64 28 69 74 65 6d 2e 64 61  erse.Add(item.da
ddf0: 74 61 54 79 70 65 2c 20 69 74 65 6d 29 3b 0d 0a  taType, item);..
de00: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
de10: 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f   ///////////////
de20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
de30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
de40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
de50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20  //////////....  
de60: 20 20 20 20 70 75 62 6c 69 63 20 62 6f 6f 6c 20      public bool 
de70: 54 72 79 47 65 74 56 61 6c 75 65 28 44 62 54 79  TryGetValue(DbTy
de80: 70 65 20 6b 65 79 2c 20 6f 75 74 20 53 51 4c 69  pe key, out SQLi
de90: 74 65 44 62 54 79 70 65 4d 61 70 70 69 6e 67 20  teDbTypeMapping 
dea0: 76 61 6c 75 65 29 0d 0a 20 20 20 20 20 20 7b 0d  value)..      {.
deb0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28 72  .          if (r
dec0: 65 76 65 72 73 65 20 3d 3d 20 6e 75 6c 6c 29 0d  everse == null).
ded0: 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  .          {..  
dee0: 20 20 20 20 20 20 20 20 20 20 20 20 76 61 6c 75              valu
def0: 65 20 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20  e = null;..     
df00: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20           return 
df10: 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20 20 20 20  false;..        
df20: 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20    }....         
df30: 20 72 65 74 75 72 6e 20 72 65 76 65 72 73 65 2e   return reverse.
df40: 54 72 79 47 65 74 56 61 6c 75 65 28 6b 65 79 2c  TryGetValue(key,
df50: 20 6f 75 74 20 76 61 6c 75 65 29 3b 0d 0a 20 20   out value);..  
df60: 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 0d 0a 20 20      }..  }....  
df70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
df80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
df90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
dfa0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
dfb0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d  /////////////...
dfc0: 0a 20 20 69 6e 74 65 72 6e 61 6c 20 73 65 61 6c  .  internal seal
dfd0: 65 64 20 63 6c 61 73 73 20 53 51 4c 69 74 65 44  ed class SQLiteD
dfe0: 62 54 79 70 65 4d 61 70 70 69 6e 67 0d 0a 20 20  bTypeMapping..  
dff0: 7b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  {..    internal 
e000: 53 51 4c 69 74 65 44 62 54 79 70 65 4d 61 70 70  SQLiteDbTypeMapp
e010: 69 6e 67 28 0d 0a 20 20 20 20 20 20 20 20 73 74  ing(..        st
e020: 72 69 6e 67 20 6e 65 77 54 79 70 65 4e 61 6d 65  ring newTypeName
e030: 2c 0d 0a 20 20 20 20 20 20 20 20 44 62 54 79 70  ,..        DbTyp
e040: 65 20 6e 65 77 44 61 74 61 54 79 70 65 2c 0d 0a  e newDataType,..
e050: 20 20 20 20 20 20 20 20 62 6f 6f 6c 20 6e 65 77          bool new
e060: 50 72 69 6d 61 72 79 0d 0a 20 20 20 20 20 20 20  Primary..       
e070: 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20   )..    {..     
e080: 20 74 79 70 65 4e 61 6d 65 20 3d 20 6e 65 77 54   typeName = newT
e090: 79 70 65 4e 61 6d 65 3b 0d 0a 20 20 20 20 20 20  ypeName;..      
e0a0: 64 61 74 61 54 79 70 65 20 3d 20 6e 65 77 44 61  dataType = newDa
e0b0: 74 61 54 79 70 65 3b 0d 0a 20 20 20 20 20 20 70  taType;..      p
e0c0: 72 69 6d 61 72 79 20 3d 20 6e 65 77 50 72 69 6d  rimary = newPrim
e0d0: 61 72 79 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ary;..    }.... 
e0e0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 72 69     internal stri
e0f0: 6e 67 20 74 79 70 65 4e 61 6d 65 3b 0d 0a 20 20  ng typeName;..  
e100: 20 20 69 6e 74 65 72 6e 61 6c 20 44 62 54 79 70    internal DbTyp
e110: 65 20 64 61 74 61 54 79 70 65 3b 0d 0a 20 20 20  e dataType;..   
e120: 20 69 6e 74 65 72 6e 61 6c 20 62 6f 6f 6c 20 70   internal bool p
e130: 72 69 6d 61 72 79 3b 0d 0a 20 20 7d 0d 0a 0d 0a  rimary;..  }....
e140: 20 20 69 6e 74 65 72 6e 61 6c 20 73 65 61 6c 65    internal seale
e150: 64 20 63 6c 61 73 73 20 54 79 70 65 4e 61 6d 65  d class TypeName
e160: 53 74 72 69 6e 67 43 6f 6d 70 61 72 65 72 20 3a  StringComparer :
e170: 20 49 45 71 75 61 6c 69 74 79 43 6f 6d 70 61 72   IEqualityCompar
e180: 65 72 3c 73 74 72 69 6e 67 3e 0d 0a 20 20 7b 0d  er<string>..  {.
e190: 0a 20 20 20 20 23 72 65 67 69 6f 6e 20 49 45 71  .    #region IEq
e1a0: 75 61 6c 69 74 79 43 6f 6d 70 61 72 65 72 3c 73  ualityComparer<s
e1b0: 74 72 69 6e 67 3e 20 4d 65 6d 62 65 72 73 0d 0a  tring> Members..
e1c0: 20 20 20 20 70 75 62 6c 69 63 20 62 6f 6f 6c 20      public bool 
e1d0: 45 71 75 61 6c 73 28 0d 0a 20 20 20 20 20 20 73  Equals(..      s
e1e0: 74 72 69 6e 67 20 6c 65 66 74 2c 0d 0a 20 20 20  tring left,..   
e1f0: 20 20 20 73 74 72 69 6e 67 20 72 69 67 68 74 0d     string right.
e200: 0a 20 20 20 20 20 20 29 0d 0a 20 20 20 20 7b 0d  .      )..    {.
e210: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 74  .      return St
e220: 72 69 6e 67 2e 45 71 75 61 6c 73 28 6c 65 66 74  ring.Equals(left
e230: 2c 20 72 69 67 68 74 2c 20 53 74 72 69 6e 67 43  , right, StringC
e240: 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e 61  omparison.Ordina
e250: 6c 49 67 6e 6f 72 65 43 61 73 65 29 3b 0d 0a 20  lIgnoreCase);.. 
e260: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f     }....    ////
e270: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
e280: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
e290: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
e2a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
e2b0: 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 70  ///////....    p
e2c0: 75 62 6c 69 63 20 69 6e 74 20 47 65 74 48 61 73  ublic int GetHas
e2d0: 68 43 6f 64 65 28 0d 0a 20 20 20 20 20 20 73 74  hCode(..      st
e2e0: 72 69 6e 67 20 76 61 6c 75 65 0d 0a 20 20 20 20  ring value..    
e2f0: 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20    )..    {..    
e300: 20 20 2f 2f 0d 0a 20 20 20 20 20 20 2f 2f 20 4e    //..      // N
e310: 4f 54 45 3a 20 54 68 65 20 6f 6e 6c 79 20 74 68  OTE: The only th
e320: 69 6e 67 20 74 68 61 74 20 77 65 20 6d 75 73 74  ing that we must
e330: 20 67 75 61 72 61 6e 74 65 65 20 68 65 72 65 2c   guarantee here,
e340: 20 61 63 63 6f 72 64 69 6e 67 0d 0a 20 20 20 20   according..    
e350: 20 20 2f 2f 20 20 20 20 20 20 20 74 6f 20 74 68    //       to th
e360: 65 20 4d 53 44 4e 20 64 6f 63 75 6d 65 6e 74 61  e MSDN documenta
e370: 74 69 6f 6e 20 66 6f 72 20 49 45 71 75 61 6c 69  tion for IEquali
e380: 74 79 43 6f 6d 70 61 72 65 72 2c 20 69 73 0d 0a  tyComparer, is..
e390: 20 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 74        //       t
e3a0: 68 61 74 20 66 6f 72 20 74 77 6f 20 67 69 76 65  hat for two give
e3b0: 6e 20 73 74 72 69 6e 67 73 2c 20 69 66 20 45 71  n strings, if Eq
e3c0: 75 61 6c 73 20 72 65 74 75 72 6e 20 74 72 75 65  uals return true
e3d0: 20 74 68 65 6e 0d 0a 20 20 20 20 20 20 2f 2f 20   then..      // 
e3e0: 20 20 20 20 20 20 74 68 65 20 74 77 6f 20 73 74        the two st
e3f0: 72 69 6e 67 73 20 6d 75 73 74 20 68 61 73 68 20  rings must hash 
e400: 74 6f 20 74 68 65 20 73 61 6d 65 20 76 61 6c 75  to the same valu
e410: 65 2e 0d 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20  e...      //..  
e420: 20 20 20 20 69 66 20 28 76 61 6c 75 65 20 21 3d      if (value !=
e430: 20 6e 75 6c 6c 29 0d 0a 23 69 66 20 21 50 4c 41   null)..#if !PLA
e440: 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41  TFORM_COMPACTFRA
e450: 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20  MEWORK..        
e460: 72 65 74 75 72 6e 20 76 61 6c 75 65 2e 54 6f 4c  return value.ToL
e470: 6f 77 65 72 49 6e 76 61 72 69 61 6e 74 28 29 2e  owerInvariant().
e480: 47 65 74 48 61 73 68 43 6f 64 65 28 29 3b 0d 0a  GetHashCode();..
e490: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 72  #else..        r
e4a0: 65 74 75 72 6e 20 76 61 6c 75 65 2e 54 6f 4c 6f  eturn value.ToLo
e4b0: 77 65 72 28 29 2e 47 65 74 48 61 73 68 43 6f 64  wer().GetHashCod
e4c0: 65 28 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20  e();..#endif..  
e4d0: 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20      else..      
e4e0: 20 20 74 68 72 6f 77 20 6e 65 77 20 41 72 67 75    throw new Argu
e4f0: 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f  mentNullExceptio
e500: 6e 28 22 76 61 6c 75 65 22 29 3b 0d 0a 20 20 20  n("value");..   
e510: 20 7d 0d 0a 20 20 20 20 23 65 6e 64 72 65 67 69   }..    #endregi
e520: 6f 6e 0d 0a 20 20 7d 0d 0a 7d 0d 0a              on..  }..}..