System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 6c219723aed100c2a6c8ed9313f32decae8fd79b:


0000: ef bb bf 2f 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 2a 2a 2a 0d 0a 20 2a  ************.. *
0040: 20 41 44 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74   ADO.NET 2.0 Dat
0050: 61 20 50 72 6f 76 69 64 65 72 20 66 6f 72 20 53  a Provider for S
0060: 51 4c 69 74 65 20 56 65 72 73 69 6f 6e 20 33 2e  QLite Version 3.
0070: 58 0d 0a 20 2a 20 57 72 69 74 74 65 6e 20 62 79  X.. * Written by
0080: 20 52 6f 62 65 72 74 20 53 69 6d 70 73 6f 6e 20   Robert Simpson 
0090: 28 72 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73  (robert@blackcas
00a0: 74 6c 65 73 6f 66 74 2e 63 6f 6d 29 0d 0a 20 2a  tlesoft.com).. *
00b0: 20 0d 0a 20 2a 20 52 65 6c 65 61 73 65 64 20 74   .. * Released t
00c0: 6f 20 74 68 65 20 70 75 62 6c 69 63 20 64 6f 6d  o the public dom
00d0: 61 69 6e 2c 20 75 73 65 20 61 74 20 79 6f 75 72  ain, use at your
00e0: 20 6f 77 6e 20 72 69 73 6b 21 0d 0a 20 2a 2a 2a   own 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 2a 2a 2a 2a 2f 0d 0a 0d 0a 6e 61 6d 65 73 70  *****/....namesp
0130: 61 63 65 20 53 79 73 74 65 6d 2e 44 61 74 61 2e  ace System.Data.
0140: 53 51 4c 69 74 65 0d 0a 7b 0d 0a 20 20 75 73 69  SQLite..{..  usi
0150: 6e 67 20 53 79 73 74 65 6d 3b 0d 0a 20 20 75 73  ng System;..  us
0160: 69 6e 67 20 53 79 73 74 65 6d 2e 52 75 6e 74 69  ing System.Runti
0170: 6d 65 2e 49 6e 74 65 72 6f 70 53 65 72 76 69 63  me.InteropServic
0180: 65 73 3b 0d 0a 20 20 75 73 69 6e 67 20 53 79 73  es;..  using Sys
0190: 74 65 6d 2e 43 6f 6c 6c 65 63 74 69 6f 6e 73 2e  tem.Collections.
01a0: 47 65 6e 65 72 69 63 3b 0d 0a 20 20 75 73 69 6e  Generic;..  usin
01b0: 67 20 53 79 73 74 65 6d 2e 47 6c 6f 62 61 6c 69  g System.Globali
01c0: 7a 61 74 69 6f 6e 3b 0d 0a 20 20 75 73 69 6e 67  zation;..  using
01d0: 20 53 79 73 74 65 6d 2e 54 65 78 74 3b 0d 0a 0d   System.Text;...
01e0: 0a 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e  .  /// <summary>
01f0: 0d 0a 20 20 2f 2f 2f 20 54 68 69 73 20 62 61 73  ..  /// This bas
0200: 65 20 63 6c 61 73 73 20 70 72 6f 76 69 64 65 73  e class provides
0210: 20 64 61 74 61 74 79 70 65 20 63 6f 6e 76 65 72   datatype conver
0220: 73 69 6f 6e 20 73 65 72 76 69 63 65 73 20 66 6f  sion services fo
0230: 72 20 74 68 65 20 53 51 4c 69 74 65 20 70 72 6f  r the SQLite pro
0240: 76 69 64 65 72 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f  vider...  /// </
0250: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 70 75 62 6c  summary>..  publ
0260: 69 63 20 61 62 73 74 72 61 63 74 20 63 6c 61 73  ic abstract clas
0270: 73 20 53 51 4c 69 74 65 43 6f 6e 76 65 72 74 0d  s SQLiteConvert.
0280: 0a 20 20 7b 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73  .  {..    /// <s
0290: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
02a0: 20 54 68 65 20 76 61 6c 75 65 20 66 6f 72 20 74   The value for t
02b0: 68 65 20 55 6e 69 78 20 65 70 6f 63 68 20 28 65  he Unix epoch (e
02c0: 2e 67 2e 20 4a 61 6e 75 61 72 79 20 31 2c 20 31  .g. January 1, 1
02d0: 39 37 30 20 61 74 20 6d 69 64 6e 69 67 68 74 2c  970 at midnight,
02e0: 20 69 6e 20 55 54 43 29 2e 0d 0a 20 20 20 20 2f   in UTC)...    /
02f0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
0300: 20 20 20 70 72 6f 74 65 63 74 65 64 20 73 74 61     protected sta
0310: 74 69 63 20 72 65 61 64 6f 6e 6c 79 20 44 61 74  tic readonly Dat
0320: 65 54 69 6d 65 20 55 6e 69 78 45 70 6f 63 68 20  eTime UnixEpoch 
0330: 3d 0d 0a 20 20 20 20 20 20 20 20 6e 65 77 20 44  =..        new D
0340: 61 74 65 54 69 6d 65 28 31 39 37 30 2c 20 31 2c  ateTime(1970, 1,
0350: 20 31 2c 20 30 2c 20 30 2c 20 30 2c 20 44 61 74   1, 0, 0, 0, Dat
0360: 65 54 69 6d 65 4b 69 6e 64 2e 55 74 63 29 3b 0d  eTimeKind.Utc);.
0370: 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ...    /// <summ
0380: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68  ary>..    /// Th
0390: 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65 20 4f  e value of the O
03a0: 4c 45 20 41 75 74 6f 6d 61 74 69 6f 6e 20 65 70  LE Automation ep
03b0: 6f 63 68 20 72 65 70 72 65 73 65 6e 74 65 64 20  och represented 
03c0: 61 73 20 61 20 4a 75 6c 69 61 6e 20 64 61 79 2e  as a Julian day.
03d0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
03e0: 61 72 79 3e 0d 0a 20 20 20 20 70 72 69 76 61 74  ary>..    privat
03f0: 65 20 73 74 61 74 69 63 20 72 65 61 64 6f 6e 6c  e static readonl
0400: 79 20 64 6f 75 62 6c 65 20 4f 6c 65 41 75 74 6f  y double OleAuto
0410: 6d 61 74 69 6f 6e 45 70 6f 63 68 41 73 4a 75 6c  mationEpochAsJul
0420: 69 61 6e 44 61 79 20 3d 20 32 34 31 35 30 31 38  ianDay = 2415018
0430: 2e 35 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c  .5;....    /// <
0440: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
0450: 2f 20 54 68 65 20 66 6f 72 6d 61 74 20 73 74 72  / The format str
0460: 69 6e 67 20 66 6f 72 20 44 61 74 65 54 69 6d 65  ing for DateTime
0470: 20 76 61 6c 75 65 73 20 77 68 65 6e 20 75 73 69   values when usi
0480: 6e 67 20 74 68 65 20 49 6e 76 61 72 69 61 6e 74  ng the Invariant
0490: 43 75 6c 74 75 72 65 20 6f 72 20 43 75 72 72 65  Culture or Curre
04a0: 6e 74 43 75 6c 74 75 72 65 20 66 6f 72 6d 61 74  ntCulture format
04b0: 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  s...    /// </su
04c0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72 69 76  mmary>..    priv
04d0: 61 74 65 20 63 6f 6e 73 74 20 73 74 72 69 6e 67  ate const string
04e0: 20 46 75 6c 6c 46 6f 72 6d 61 74 20 3d 20 22 79   FullFormat = "y
04f0: 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a  yyy-MM-ddTHH:mm:
0500: 73 73 2e 66 66 66 66 66 66 66 4b 22 3b 0d 0a 0d  ss.fffffffK";...
0510: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
0520: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 6e 20 61  y>..    /// An a
0530: 72 72 61 79 20 6f 66 20 49 53 4f 38 36 30 31 20  rray of ISO8601 
0540: 64 61 74 65 74 69 6d 65 20 66 6f 72 6d 61 74 73  datetime formats
0550: 20 77 65 20 73 75 70 70 6f 72 74 20 63 6f 6e 76   we support conv
0560: 65 72 73 69 6f 6e 20 66 72 6f 6d 0d 0a 20 20 20  ersion from..   
0570: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
0580: 0a 20 20 20 20 70 72 69 76 61 74 65 20 73 74 61  .    private sta
0590: 74 69 63 20 73 74 72 69 6e 67 5b 5d 20 5f 64 61  tic string[] _da
05a0: 74 65 74 69 6d 65 46 6f 72 6d 61 74 73 20 3d 20  tetimeFormats = 
05b0: 6e 65 77 20 73 74 72 69 6e 67 5b 5d 20 7b 0d 0a  new string[] {..
05c0: 20 20 20 20 20 20 22 54 48 48 6d 6d 73 73 4b 22        "THHmmssK"
05d0: 2c 0d 0a 20 20 20 20 20 20 22 54 48 48 6d 6d 4b  ,..      "THHmmK
05e0: 22 2c 0d 0a 20 20 20 20 20 20 22 48 48 3a 6d 6d  ",..      "HH:mm
05f0: 3a 73 73 2e 46 46 46 46 46 46 46 4b 22 2c 0d 0a  :ss.FFFFFFFK",..
0600: 20 20 20 20 20 20 22 48 48 3a 6d 6d 3a 73 73 4b        "HH:mm:ssK
0610: 22 2c 0d 0a 20 20 20 20 20 20 22 48 48 3a 6d 6d  ",..      "HH:mm
0620: 4b 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79  K",..      "yyyy
0630: 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 2e  -MM-dd HH:mm:ss.
0640: 46 46 46 46 46 46 46 4b 22 2c 20 2f 2a 20 4e 4f  FFFFFFFK", /* NO
0650: 54 45 3a 20 55 54 43 20 64 65 66 61 75 6c 74 20  TE: UTC default 
0660: 28 35 29 2e 20 2a 2f 0d 0a 20 20 20 20 20 20 22  (5). */..      "
0670: 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d  yyyy-MM-dd HH:mm
0680: 3a 73 73 4b 22 2c 0d 0a 20 20 20 20 20 20 22 79  :ssK",..      "y
0690: 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 4b  yyy-MM-dd HH:mmK
06a0: 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79 2d  ",..      "yyyy-
06b0: 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73 2e 46  MM-ddTHH:mm:ss.F
06c0: 46 46 46 46 46 46 4b 22 2c 0d 0a 20 20 20 20 20  FFFFFFK",..     
06d0: 20 22 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a   "yyyy-MM-ddTHH:
06e0: 6d 6d 4b 22 2c 0d 0a 20 20 20 20 20 20 22 79 79  mmK",..      "yy
06f0: 79 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73  yy-MM-ddTHH:mm:s
0700: 73 4b 22 2c 0d 0a 20 20 20 20 20 20 22 79 79 79  sK",..      "yyy
0710: 79 4d 4d 64 64 48 48 6d 6d 73 73 4b 22 2c 0d 0a  yMMddHHmmssK",..
0720: 20 20 20 20 20 20 22 79 79 79 79 4d 4d 64 64 48        "yyyyMMddH
0730: 48 6d 6d 4b 22 2c 0d 0a 20 20 20 20 20 20 22 79  HmmK",..      "y
0740: 79 79 79 4d 4d 64 64 54 48 48 6d 6d 73 73 46 46  yyyMMddTHHmmssFF
0750: 46 46 46 46 46 4b 22 2c 0d 0a 20 20 20 20 20 20  FFFFFK",..      
0760: 22 54 48 48 6d 6d 73 73 22 2c 0d 0a 20 20 20 20  "THHmmss",..    
0770: 20 20 22 54 48 48 6d 6d 22 2c 0d 0a 20 20 20 20    "THHmm",..    
0780: 20 20 22 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46    "HH:mm:ss.FFFF
0790: 46 46 46 22 2c 0d 0a 20 20 20 20 20 20 22 48 48  FFF",..      "HH
07a0: 3a 6d 6d 3a 73 73 22 2c 0d 0a 20 20 20 20 20 20  :mm:ss",..      
07b0: 22 48 48 3a 6d 6d 22 2c 0d 0a 20 20 20 20 20 20  "HH:mm",..      
07c0: 22 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d  "yyyy-MM-dd HH:m
07d0: 6d 3a 73 73 2e 46 46 46 46 46 46 46 22 2c 20 2f  m:ss.FFFFFFF", /
07e0: 2a 20 4e 4f 54 45 3a 20 4e 6f 6e 2d 55 54 43 20  * NOTE: Non-UTC 
07f0: 64 65 66 61 75 6c 74 20 28 31 39 29 2e 20 2a 2f  default (19). */
0800: 0d 0a 20 20 20 20 20 20 22 79 79 79 79 2d 4d 4d  ..      "yyyy-MM
0810: 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 22 2c 0d 0a  -dd HH:mm:ss",..
0820: 20 20 20 20 20 20 22 79 79 79 79 2d 4d 4d 2d 64        "yyyy-MM-d
0830: 64 20 48 48 3a 6d 6d 22 2c 0d 0a 20 20 20 20 20  d HH:mm",..     
0840: 20 22 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a   "yyyy-MM-ddTHH:
0850: 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 22 2c 0d  mm:ss.FFFFFFF",.
0860: 0a 20 20 20 20 20 20 22 79 79 79 79 2d 4d 4d 2d  .      "yyyy-MM-
0870: 64 64 54 48 48 3a 6d 6d 22 2c 0d 0a 20 20 20 20  ddTHH:mm",..    
0880: 20 20 22 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48    "yyyy-MM-ddTHH
0890: 3a 6d 6d 3a 73 73 22 2c 0d 0a 20 20 20 20 20 20  :mm:ss",..      
08a0: 22 79 79 79 79 4d 4d 64 64 48 48 6d 6d 73 73 22  "yyyyMMddHHmmss"
08b0: 2c 0d 0a 20 20 20 20 20 20 22 79 79 79 79 4d 4d  ,..      "yyyyMM
08c0: 64 64 48 48 6d 6d 22 2c 0d 0a 20 20 20 20 20 20  ddHHmm",..      
08d0: 22 79 79 79 79 4d 4d 64 64 54 48 48 6d 6d 73 73  "yyyyMMddTHHmmss
08e0: 46 46 46 46 46 46 46 22 2c 0d 0a 20 20 20 20 20  FFFFFFF",..     
08f0: 20 22 79 79 79 79 2d 4d 4d 2d 64 64 22 2c 0d 0a   "yyyy-MM-dd",..
0900: 20 20 20 20 20 20 22 79 79 79 79 4d 4d 64 64 22        "yyyyMMdd"
0910: 2c 0d 0a 20 20 20 20 20 20 22 79 79 2d 4d 4d 2d  ,..      "yy-MM-
0920: 64 64 22 0d 0a 20 20 20 20 7d 3b 0d 0a 0d 0a 20  dd"..    };.... 
0930: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
0940: 0d 0a 20 20 20 20 2f 2f 2f 20 41 6e 20 55 54 46  ..    /// An UTF
0950: 2d 38 20 45 6e 63 6f 64 69 6e 67 20 69 6e 73 74  -8 Encoding inst
0960: 61 6e 63 65 2c 20 73 6f 20 77 65 20 63 61 6e 20  ance, so we can 
0970: 63 6f 6e 76 65 72 74 20 73 74 72 69 6e 67 73 20  convert strings 
0980: 74 6f 20 61 6e 64 20 66 72 6f 6d 20 55 54 46 2d  to and from UTF-
0990: 38 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  8..    /// </sum
09a0: 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72 69 76 61  mary>..    priva
09b0: 74 65 20 73 74 61 74 69 63 20 45 6e 63 6f 64 69  te static Encodi
09c0: 6e 67 20 5f 75 74 66 38 20 3d 20 6e 65 77 20 55  ng _utf8 = new U
09d0: 54 46 38 45 6e 63 6f 64 69 6e 67 28 29 3b 0d 0a  TF8Encoding();..
09e0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
09f0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 64  >..    /// The d
0a00: 65 66 61 75 6c 74 20 44 61 74 65 54 69 6d 65 20  efault DateTime 
0a10: 66 6f 72 6d 61 74 20 66 6f 72 20 74 68 69 73 20  format for this 
0a20: 69 6e 73 74 61 6e 63 65 0d 0a 20 20 20 20 2f 2f  instance..    //
0a30: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
0a40: 20 20 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74    internal SQLit
0a50: 65 44 61 74 65 46 6f 72 6d 61 74 73 20 5f 64 61  eDateFormats _da
0a60: 74 65 74 69 6d 65 46 6f 72 6d 61 74 3b 0d 0a 20  tetimeFormat;.. 
0a70: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
0a80: 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 64 65  ..    /// The de
0a90: 66 61 75 6c 74 20 44 61 74 65 54 69 6d 65 4b 69  fault DateTimeKi
0aa0: 6e 64 20 66 6f 72 20 74 68 69 73 20 69 6e 73 74  nd for this inst
0ab0: 61 6e 63 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  ance...    /// <
0ac0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 69  /summary>..    i
0ad0: 6e 74 65 72 6e 61 6c 20 44 61 74 65 54 69 6d 65  nternal DateTime
0ae0: 4b 69 6e 64 20 5f 64 61 74 65 74 69 6d 65 4b 69  Kind _datetimeKi
0af0: 6e 64 3b 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  nd;..    /// <su
0b00: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
0b10: 49 6e 69 74 69 61 6c 69 7a 65 73 20 74 68 65 20  Initializes the 
0b20: 63 6f 6e 76 65 72 73 69 6f 6e 20 63 6c 61 73 73  conversion class
0b30: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
0b40: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ary>..    /// <p
0b50: 61 72 61 6d 20 6e 61 6d 65 3d 22 66 6d 74 22 3e  aram name="fmt">
0b60: 54 68 65 20 64 65 66 61 75 6c 74 20 64 61 74 65  The default date
0b70: 2f 74 69 6d 65 20 66 6f 72 6d 61 74 20 74 6f 20  /time format to 
0b80: 75 73 65 20 66 6f 72 20 74 68 69 73 20 69 6e 73  use for this ins
0b90: 74 61 6e 63 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20  tance</param>.. 
0ba0: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
0bb0: 6d 65 3d 22 6b 69 6e 64 22 3e 54 68 65 20 44 61  me="kind">The Da
0bc0: 74 65 54 69 6d 65 4b 69 6e 64 20 74 6f 20 75 73  teTimeKind to us
0bd0: 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  e.</param>..    
0be0: 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74 65 43  internal SQLiteC
0bf0: 6f 6e 76 65 72 74 28 53 51 4c 69 74 65 44 61 74  onvert(SQLiteDat
0c00: 65 46 6f 72 6d 61 74 73 20 66 6d 74 2c 20 44 61  eFormats fmt, Da
0c10: 74 65 54 69 6d 65 4b 69 6e 64 20 6b 69 6e 64 29  teTimeKind kind)
0c20: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 5f  ..    {..      _
0c30: 64 61 74 65 74 69 6d 65 46 6f 72 6d 61 74 20 3d  datetimeFormat =
0c40: 20 66 6d 74 3b 0d 0a 20 20 20 20 20 20 5f 64 61   fmt;..      _da
0c50: 74 65 74 69 6d 65 4b 69 6e 64 20 3d 20 6b 69 6e  tetimeKind = kin
0c60: 64 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  d;..    }....   
0c70: 20 23 72 65 67 69 6f 6e 20 55 54 46 2d 38 20 43   #region UTF-8 C
0c80: 6f 6e 76 65 72 73 69 6f 6e 20 46 75 6e 63 74 69  onversion Functi
0c90: 6f 6e 73 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  ons..    /// <su
0ca0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
0cb0: 43 6f 6e 76 65 72 74 73 20 61 20 73 74 72 69 6e  Converts a strin
0cc0: 67 20 74 6f 20 61 20 55 54 46 2d 38 20 65 6e 63  g to a UTF-8 enc
0cd0: 6f 64 65 64 20 62 79 74 65 20 61 72 72 61 79 20  oded byte array 
0ce0: 73 69 7a 65 64 20 74 6f 20 69 6e 63 6c 75 64 65  sized to include
0cf0: 20 61 20 6e 75 6c 6c 2d 74 65 72 6d 69 6e 61 74   a null-terminat
0d00: 69 6e 67 20 63 68 61 72 61 63 74 65 72 2e 0d 0a  ing character...
0d10: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
0d20: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  y>..    /// <par
0d30: 61 6d 20 6e 61 6d 65 3d 22 73 6f 75 72 63 65 54  am name="sourceT
0d40: 65 78 74 22 3e 54 68 65 20 73 74 72 69 6e 67 20  ext">The string 
0d50: 74 6f 20 63 6f 6e 76 65 72 74 20 74 6f 20 55 54  to convert to UT
0d60: 46 2d 38 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  F-8</param>..   
0d70: 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 41 20   /// <returns>A 
0d80: 62 79 74 65 20 61 72 72 61 79 20 63 6f 6e 74 61  byte array conta
0d90: 69 6e 69 6e 67 20 74 68 65 20 63 6f 6e 76 65 72  ining the conver
0da0: 74 65 64 20 73 74 72 69 6e 67 20 70 6c 75 73 20  ted string plus 
0db0: 61 6e 20 65 78 74 72 61 20 30 20 74 65 72 6d 69  an extra 0 termi
0dc0: 6e 61 74 69 6e 67 20 62 79 74 65 20 61 74 20 74  nating byte at t
0dd0: 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20 61 72  he end of the ar
0de0: 72 61 79 2e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a  ray.</returns>..
0df0: 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69      public stati
0e00: 63 20 62 79 74 65 5b 5d 20 54 6f 55 54 46 38 28  c byte[] ToUTF8(
0e10: 73 74 72 69 6e 67 20 73 6f 75 72 63 65 54 65 78  string sourceTex
0e20: 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  t)..    {..     
0e30: 20 42 79 74 65 5b 5d 20 62 79 74 65 41 72 72 61   Byte[] byteArra
0e40: 79 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 6c  y;..      int nl
0e50: 65 6e 20 3d 20 5f 75 74 66 38 2e 47 65 74 42 79  en = _utf8.GetBy
0e60: 74 65 43 6f 75 6e 74 28 73 6f 75 72 63 65 54 65  teCount(sourceTe
0e70: 78 74 29 20 2b 20 31 3b 0d 0a 0d 0a 20 20 20 20  xt) + 1;....    
0e80: 20 20 62 79 74 65 41 72 72 61 79 20 3d 20 6e 65    byteArray = ne
0e90: 77 20 62 79 74 65 5b 6e 6c 65 6e 5d 3b 0d 0a 20  w byte[nlen];.. 
0ea0: 20 20 20 20 20 6e 6c 65 6e 20 3d 20 5f 75 74 66       nlen = _utf
0eb0: 38 2e 47 65 74 42 79 74 65 73 28 73 6f 75 72 63  8.GetBytes(sourc
0ec0: 65 54 65 78 74 2c 20 30 2c 20 73 6f 75 72 63 65  eText, 0, source
0ed0: 54 65 78 74 2e 4c 65 6e 67 74 68 2c 20 62 79 74  Text.Length, byt
0ee0: 65 41 72 72 61 79 2c 20 30 29 3b 0d 0a 20 20 20  eArray, 0);..   
0ef0: 20 20 20 62 79 74 65 41 72 72 61 79 5b 6e 6c 65     byteArray[nle
0f00: 6e 5d 20 3d 20 30 3b 0d 0a 0d 0a 20 20 20 20 20  n] = 0;....     
0f10: 20 72 65 74 75 72 6e 20 62 79 74 65 41 72 72 61   return byteArra
0f20: 79 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  y;..    }....   
0f30: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
0f40: 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 20      /// Convert 
0f50: 61 20 44 61 74 65 54 69 6d 65 20 74 6f 20 61 20  a DateTime to a 
0f60: 55 54 46 2d 38 20 65 6e 63 6f 64 65 64 2c 20 7a  UTF-8 encoded, z
0f70: 65 72 6f 2d 74 65 72 6d 69 6e 61 74 65 64 20 62  ero-terminated b
0f80: 79 74 65 20 61 72 72 61 79 2e 0d 0a 20 20 20 20  yte array...    
0f90: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
0fa0: 20 20 20 20 2f 2f 2f 20 3c 72 65 6d 61 72 6b 73      /// <remarks
0fb0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 69 73 20  >..    /// This 
0fc0: 66 75 6e 63 74 69 6f 6e 20 69 73 20 61 20 63 6f  function is a co
0fd0: 6e 76 65 6e 69 65 6e 63 65 20 66 75 6e 63 74 69  nvenience functi
0fe0: 6f 6e 2c 20 77 68 69 63 68 20 66 69 72 73 74 20  on, which first 
0ff0: 63 61 6c 6c 73 20 54 6f 53 74 72 69 6e 67 28 29  calls ToString()
1000: 20 6f 6e 20 74 68 65 20 44 61 74 65 54 69 6d 65   on the DateTime
1010: 2c 20 61 6e 64 20 74 68 65 6e 20 63 61 6c 6c 73  , and then calls
1020: 20 54 6f 55 54 46 38 28 29 20 77 69 74 68 20 74   ToUTF8() with t
1030: 68 65 0d 0a 20 20 20 20 2f 2f 2f 20 73 74 72 69  he..    /// stri
1040: 6e 67 20 72 65 73 75 6c 74 2e 0d 0a 20 20 20 20  ng result...    
1050: 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73 3e 0d 0a  /// </remarks>..
1060: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
1070: 61 6d 65 3d 22 64 61 74 65 54 69 6d 65 56 61 6c  ame="dateTimeVal
1080: 75 65 22 3e 54 68 65 20 44 61 74 65 54 69 6d 65  ue">The DateTime
1090: 20 74 6f 20 63 6f 6e 76 65 72 74 2e 3c 2f 70 61   to convert.</pa
10a0: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72  ram>..    /// <r
10b0: 65 74 75 72 6e 73 3e 54 68 65 20 55 54 46 2d 38  eturns>The UTF-8
10c0: 20 65 6e 63 6f 64 65 64 20 73 74 72 69 6e 67 2c   encoded string,
10d0: 20 69 6e 63 6c 75 64 69 6e 67 20 61 20 30 20 74   including a 0 t
10e0: 65 72 6d 69 6e 61 74 69 6e 67 20 62 79 74 65 20  erminating byte 
10f0: 61 74 20 74 68 65 20 65 6e 64 20 6f 66 20 74 68  at the end of th
1100: 65 20 61 72 72 61 79 2e 3c 2f 72 65 74 75 72 6e  e array.</return
1110: 73 3e 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 62  s>..    public b
1120: 79 74 65 5b 5d 20 54 6f 55 54 46 38 28 44 61 74  yte[] ToUTF8(Dat
1130: 65 54 69 6d 65 20 64 61 74 65 54 69 6d 65 56 61  eTime dateTimeVa
1140: 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  lue)..    {..   
1150: 20 20 20 72 65 74 75 72 6e 20 54 6f 55 54 46 38     return ToUTF8
1160: 28 54 6f 53 74 72 69 6e 67 28 64 61 74 65 54 69  (ToString(dateTi
1170: 6d 65 56 61 6c 75 65 29 29 3b 0d 0a 20 20 20 20  meValue));..    
1180: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  }....    /// <su
1190: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
11a0: 43 6f 6e 76 65 72 74 73 20 61 20 55 54 46 2d 38  Converts a UTF-8
11b0: 20 65 6e 63 6f 64 65 64 20 49 6e 74 50 74 72 20   encoded IntPtr 
11c0: 6f 66 20 74 68 65 20 73 70 65 63 69 66 69 65 64  of the specified
11d0: 20 6c 65 6e 67 74 68 20 69 6e 74 6f 20 61 20 2e   length into a .
11e0: 4e 45 54 20 73 74 72 69 6e 67 0d 0a 20 20 20 20  NET string..    
11f0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
1200: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
1210: 61 6d 65 3d 22 6e 61 74 69 76 65 73 74 72 69 6e  ame="nativestrin
1220: 67 22 3e 54 68 65 20 70 6f 69 6e 74 65 72 20 74  g">The pointer t
1230: 6f 20 74 68 65 20 6d 65 6d 6f 72 79 20 77 68 65  o the memory whe
1240: 72 65 20 74 68 65 20 55 54 46 2d 38 20 73 74 72  re the UTF-8 str
1250: 69 6e 67 20 69 73 20 65 6e 63 6f 64 65 64 3c 2f  ing is encoded</
1260: 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  param>..    /// 
1270: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6e 61 74  <param name="nat
1280: 69 76 65 73 74 72 69 6e 67 6c 65 6e 22 3e 54 68  ivestringlen">Th
1290: 65 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 74 65  e number of byte
12a0: 73 20 74 6f 20 64 65 63 6f 64 65 3c 2f 70 61 72  s to decode</par
12b0: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  am>..    /// <re
12c0: 74 75 72 6e 73 3e 41 20 73 74 72 69 6e 67 20 63  turns>A string c
12d0: 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 74 72  ontaining the tr
12e0: 61 6e 73 6c 61 74 65 64 20 63 68 61 72 61 63 74  anslated charact
12f0: 65 72 28 73 29 3c 2f 72 65 74 75 72 6e 73 3e 0d  er(s)</returns>.
1300: 0a 20 20 20 20 70 75 62 6c 69 63 20 76 69 72 74  .    public virt
1310: 75 61 6c 20 73 74 72 69 6e 67 20 54 6f 53 74 72  ual string ToStr
1320: 69 6e 67 28 49 6e 74 50 74 72 20 6e 61 74 69 76  ing(IntPtr nativ
1330: 65 73 74 72 69 6e 67 2c 20 69 6e 74 20 6e 61 74  estring, int nat
1340: 69 76 65 73 74 72 69 6e 67 6c 65 6e 29 0d 0a 20  ivestringlen).. 
1350: 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75     {..      retu
1360: 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28  rn UTF8ToString(
1370: 6e 61 74 69 76 65 73 74 72 69 6e 67 2c 20 6e 61  nativestring, na
1380: 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 29 3b 0d  tivestringlen);.
1390: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
13a0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
13b0: 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20   /// Converts a 
13c0: 55 54 46 2d 38 20 65 6e 63 6f 64 65 64 20 49 6e  UTF-8 encoded In
13d0: 74 50 74 72 20 6f 66 20 74 68 65 20 73 70 65 63  tPtr of the spec
13e0: 69 66 69 65 64 20 6c 65 6e 67 74 68 20 69 6e 74  ified length int
13f0: 6f 20 61 20 2e 4e 45 54 20 73 74 72 69 6e 67 0d  o a .NET string.
1400: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
1410: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  ry>..    /// <pa
1420: 72 61 6d 20 6e 61 6d 65 3d 22 6e 61 74 69 76 65  ram name="native
1430: 73 74 72 69 6e 67 22 3e 54 68 65 20 70 6f 69 6e  string">The poin
1440: 74 65 72 20 74 6f 20 74 68 65 20 6d 65 6d 6f 72  ter to the memor
1450: 79 20 77 68 65 72 65 20 74 68 65 20 55 54 46 2d  y where the UTF-
1460: 38 20 73 74 72 69 6e 67 20 69 73 20 65 6e 63 6f  8 string is enco
1470: 64 65 64 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  ded</param>..   
1480: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
1490: 3d 22 6e 61 74 69 76 65 73 74 72 69 6e 67 6c 65  ="nativestringle
14a0: 6e 22 3e 54 68 65 20 6e 75 6d 62 65 72 20 6f 66  n">The number of
14b0: 20 62 79 74 65 73 20 74 6f 20 64 65 63 6f 64 65   bytes to decode
14c0: 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f  </param>..    //
14d0: 2f 20 3c 72 65 74 75 72 6e 73 3e 41 20 73 74 72  / <returns>A str
14e0: 69 6e 67 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74  ing containing t
14f0: 68 65 20 74 72 61 6e 73 6c 61 74 65 64 20 63 68  he translated ch
1500: 61 72 61 63 74 65 72 28 73 29 3c 2f 72 65 74 75  aracter(s)</retu
1510: 72 6e 73 3e 0d 0a 20 20 20 20 70 75 62 6c 69 63  rns>..    public
1520: 20 73 74 61 74 69 63 20 73 74 72 69 6e 67 20 55   static string U
1530: 54 46 38 54 6f 53 74 72 69 6e 67 28 49 6e 74 50  TF8ToString(IntP
1540: 74 72 20 6e 61 74 69 76 65 73 74 72 69 6e 67 2c  tr nativestring,
1550: 20 69 6e 74 20 6e 61 74 69 76 65 73 74 72 69 6e   int nativestrin
1560: 67 6c 65 6e 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  glen)..    {..  
1570: 20 20 20 20 69 66 20 28 6e 61 74 69 76 65 73 74      if (nativest
1580: 72 69 6e 67 6c 65 6e 20 3d 3d 20 30 20 7c 7c 20  ringlen == 0 || 
1590: 6e 61 74 69 76 65 73 74 72 69 6e 67 20 3d 3d 20  nativestring == 
15a0: 49 6e 74 50 74 72 2e 5a 65 72 6f 29 20 72 65 74  IntPtr.Zero) ret
15b0: 75 72 6e 20 22 22 3b 0d 0a 20 20 20 20 20 20 69  urn "";..      i
15c0: 66 20 28 6e 61 74 69 76 65 73 74 72 69 6e 67 6c  f (nativestringl
15d0: 65 6e 20 3d 3d 20 2d 31 29 0d 0a 20 20 20 20 20  en == -1)..     
15e0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 64 6f 0d 0a   {..        do..
15f0: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
1600: 20 20 20 20 20 6e 61 74 69 76 65 73 74 72 69 6e       nativestrin
1610: 67 6c 65 6e 2b 2b 3b 0d 0a 20 20 20 20 20 20 20  glen++;..       
1620: 20 7d 20 77 68 69 6c 65 20 28 4d 61 72 73 68 61   } while (Marsha
1630: 6c 2e 52 65 61 64 42 79 74 65 28 6e 61 74 69 76  l.ReadByte(nativ
1640: 65 73 74 72 69 6e 67 2c 20 6e 61 74 69 76 65 73  estring, natives
1650: 74 72 69 6e 67 6c 65 6e 29 20 21 3d 20 30 29 3b  tringlen) != 0);
1660: 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  ..      }....   
1670: 20 20 20 62 79 74 65 5b 5d 20 62 79 74 65 41 72     byte[] byteAr
1680: 72 61 79 20 3d 20 6e 65 77 20 62 79 74 65 5b 6e  ray = new byte[n
1690: 61 74 69 76 65 73 74 72 69 6e 67 6c 65 6e 5d 3b  ativestringlen];
16a0: 0d 0a 20 20 20 20 20 20 0d 0a 20 20 20 20 20 20  ..      ..      
16b0: 4d 61 72 73 68 61 6c 2e 43 6f 70 79 28 6e 61 74  Marshal.Copy(nat
16c0: 69 76 65 73 74 72 69 6e 67 2c 20 62 79 74 65 41  ivestring, byteA
16d0: 72 72 61 79 2c 20 30 2c 20 6e 61 74 69 76 65 73  rray, 0, natives
16e0: 74 72 69 6e 67 6c 65 6e 29 3b 0d 0a 0d 0a 20 20  tringlen);....  
16f0: 20 20 20 20 72 65 74 75 72 6e 20 5f 75 74 66 38      return _utf8
1700: 2e 47 65 74 53 74 72 69 6e 67 28 62 79 74 65 41  .GetString(byteA
1710: 72 72 61 79 2c 20 30 2c 20 6e 61 74 69 76 65 73  rray, 0, natives
1720: 74 72 69 6e 67 6c 65 6e 29 3b 0d 0a 20 20 20 20  tringlen);..    
1730: 7d 0d 0a 0d 0a 0d 0a 20 20 20 20 23 65 6e 64 72  }......    #endr
1740: 65 67 69 6f 6e 0d 0a 0d 0a 20 20 20 20 23 72 65  egion....    #re
1750: 67 69 6f 6e 20 44 61 74 65 54 69 6d 65 20 43 6f  gion DateTime Co
1760: 6e 76 65 72 73 69 6f 6e 20 46 75 6e 63 74 69 6f  nversion Functio
1770: 6e 73 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d  ns..    /// <sum
1780: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43  mary>..    /// C
1790: 6f 6e 76 65 72 74 73 20 61 20 73 74 72 69 6e 67  onverts a string
17a0: 20 69 6e 74 6f 20 61 20 44 61 74 65 54 69 6d 65   into a DateTime
17b0: 2c 20 75 73 69 6e 67 20 74 68 65 20 63 75 72 72  , using the curr
17c0: 65 6e 74 20 44 61 74 65 54 69 6d 65 46 6f 72 6d  ent DateTimeForm
17d0: 61 74 20 73 70 65 63 69 66 69 65 64 20 66 6f 72  at specified for
17e0: 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20   the connection 
17f0: 77 68 65 6e 20 69 74 20 77 61 73 20 6f 70 65 6e  when it was open
1800: 65 64 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ed...    /// </s
1810: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
1820: 20 3c 72 65 6d 61 72 6b 73 3e 0d 0a 20 20 20 20   <remarks>..    
1830: 2f 2f 2f 20 41 63 63 65 70 74 61 62 6c 65 20 49  /// Acceptable I
1840: 53 4f 38 36 30 31 20 44 61 74 65 54 69 6d 65 20  SO8601 DateTime 
1850: 66 6f 72 6d 61 74 73 20 61 72 65 3a 0d 0a 20 20  formats are:..  
1860: 20 20 2f 2f 2f 20 3c 6c 69 73 74 20 74 79 70 65    /// <list type
1870: 3d 22 62 75 6c 6c 65 74 22 3e 0d 0a 20 20 20 20  ="bullet">..    
1880: 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72  /// <item><descr
1890: 69 70 74 69 6f 6e 3e 54 48 48 6d 6d 73 73 4b 3c  iption>THHmmssK<
18a0: 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69  /description></i
18b0: 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69  tem>..    /// <i
18c0: 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e  tem><description
18d0: 3e 54 48 48 6d 6d 4b 3c 2f 64 65 73 63 72 69 70  >THHmmK</descrip
18e0: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
18f0: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
1900: 63 72 69 70 74 69 6f 6e 3e 48 48 3a 6d 6d 3a 73  cription>HH:mm:s
1910: 73 2e 46 46 46 46 46 46 46 4b 3c 2f 64 65 73 63  s.FFFFFFFK</desc
1920: 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d  ription></item>.
1930: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
1940: 64 65 73 63 72 69 70 74 69 6f 6e 3e 48 48 3a 6d  description>HH:m
1950: 6d 3a 73 73 4b 3c 2f 64 65 73 63 72 69 70 74 69  m:ssK</descripti
1960: 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20  on></item>..    
1970: 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72  /// <item><descr
1980: 69 70 74 69 6f 6e 3e 48 48 3a 6d 6d 4b 3c 2f 64  iption>HH:mmK</d
1990: 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65  escription></ite
19a0: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  m>..    /// <ite
19b0: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79  m><description>y
19c0: 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a  yyy-MM-dd HH:mm:
19d0: 73 73 2e 46 46 46 46 46 46 46 4b 3c 2f 64 65 73  ss.FFFFFFFK</des
19e0: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
19f0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
1a00: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
1a10: 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73  y-MM-dd HH:mm:ss
1a20: 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  K</description><
1a30: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
1a40: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
1a50: 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48  on>yyyy-MM-dd HH
1a60: 3a 6d 6d 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f  :mmK</descriptio
1a70: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
1a80: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
1a90: 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64  ption>yyyy-MM-dd
1aa0: 54 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46  THH:mm:ss.FFFFFF
1ab0: 46 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  FK</description>
1ac0: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
1ad0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
1ae0: 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48  ion>yyyy-MM-ddTH
1af0: 48 3a 6d 6d 4b 3c 2f 64 65 73 63 72 69 70 74 69  H:mmK</descripti
1b00: 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20  on></item>..    
1b10: 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72  /// <item><descr
1b20: 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64  iption>yyyy-MM-d
1b30: 64 54 48 48 3a 6d 6d 3a 73 73 4b 3c 2f 64 65 73  dTHH:mm:ssK</des
1b40: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
1b50: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
1b60: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
1b70: 79 4d 4d 64 64 48 48 6d 6d 73 73 4b 3c 2f 64 65  yMMddHHmmssK</de
1b80: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
1b90: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
1ba0: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79  ><description>yy
1bb0: 79 79 4d 4d 64 64 48 48 6d 6d 4b 3c 2f 64 65 73  yyMMddHHmmK</des
1bc0: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
1bd0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
1be0: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
1bf0: 79 4d 4d 64 64 54 48 48 6d 6d 73 73 46 46 46 46  yMMddTHHmmssFFFF
1c00: 46 46 46 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f  FFFK</descriptio
1c10: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
1c20: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
1c30: 70 74 69 6f 6e 3e 54 48 48 6d 6d 73 73 3c 2f 64  ption>THHmmss</d
1c40: 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65  escription></ite
1c50: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  m>..    /// <ite
1c60: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 54  m><description>T
1c70: 48 48 6d 6d 3c 2f 64 65 73 63 72 69 70 74 69 6f  HHmm</descriptio
1c80: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
1c90: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
1ca0: 70 74 69 6f 6e 3e 48 48 3a 6d 6d 3a 73 73 2e 46  ption>HH:mm:ss.F
1cb0: 46 46 46 46 46 46 3c 2f 64 65 73 63 72 69 70 74  FFFFFF</descript
1cc0: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
1cd0: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
1ce0: 72 69 70 74 69 6f 6e 3e 48 48 3a 6d 6d 3a 73 73  ription>HH:mm:ss
1cf0: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
1d00: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
1d10: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
1d20: 6e 3e 48 48 3a 6d 6d 3c 2f 64 65 73 63 72 69 70  n>HH:mm</descrip
1d30: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
1d40: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
1d50: 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d  cription>yyyy-MM
1d60: 2d 64 64 20 48 48 3a 6d 6d 3a 73 73 2e 46 46 46  -dd HH:mm:ss.FFF
1d70: 46 46 46 46 3c 2f 64 65 73 63 72 69 70 74 69 6f  FFFF</descriptio
1d80: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
1d90: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
1da0: 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64  ption>yyyy-MM-dd
1db0: 20 48 48 3a 6d 6d 3a 73 73 3c 2f 64 65 73 63 72   HH:mm:ss</descr
1dc0: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
1dd0: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
1de0: 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d  escription>yyyy-
1df0: 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3c 2f 64 65 73  MM-dd HH:mm</des
1e00: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
1e10: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
1e20: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
1e30: 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73  y-MM-ddTHH:mm:ss
1e40: 2e 46 46 46 46 46 46 46 3c 2f 64 65 73 63 72 69  .FFFFFFF</descri
1e50: 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20  ption></item>.. 
1e60: 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65     /// <item><de
1e70: 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d  scription>yyyy-M
1e80: 4d 2d 64 64 54 48 48 3a 6d 6d 3c 2f 64 65 73 63  M-ddTHH:mm</desc
1e90: 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d  ription></item>.
1ea0: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
1eb0: 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79  description>yyyy
1ec0: 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73 3c  -MM-ddTHH:mm:ss<
1ed0: 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69  /description></i
1ee0: 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69  tem>..    /// <i
1ef0: 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e  tem><description
1f00: 3e 79 79 79 79 4d 4d 64 64 48 48 6d 6d 73 73 3c  >yyyyMMddHHmmss<
1f10: 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69  /description></i
1f20: 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69  tem>..    /// <i
1f30: 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e  tem><description
1f40: 3e 79 79 79 79 4d 4d 64 64 48 48 6d 6d 3c 2f 64  >yyyyMMddHHmm</d
1f50: 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65  escription></ite
1f60: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  m>..    /// <ite
1f70: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79  m><description>y
1f80: 79 79 79 4d 4d 64 64 54 48 48 6d 6d 73 73 46 46  yyyMMddTHHmmssFF
1f90: 46 46 46 46 46 3c 2f 64 65 73 63 72 69 70 74 69  FFFFF</descripti
1fa0: 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20  on></item>..    
1fb0: 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72  /// <item><descr
1fc0: 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64  iption>yyyy-MM-d
1fd0: 64 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  d</description><
1fe0: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
1ff0: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
2000: 6f 6e 3e 79 79 79 79 4d 4d 64 64 3c 2f 64 65 73  on>yyyyMMdd</des
2010: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
2020: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
2030: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 2d  <description>yy-
2040: 4d 4d 2d 64 64 3c 2f 64 65 73 63 72 69 70 74 69  MM-dd</descripti
2050: 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20  on></item>..    
2060: 2f 2f 2f 20 3c 2f 6c 69 73 74 3e 0d 0a 20 20 20  /// </list>..   
2070: 20 2f 2f 2f 20 49 66 20 74 68 65 20 73 74 72 69   /// If the stri
2080: 6e 67 20 63 61 6e 6e 6f 74 20 62 65 20 6d 61 74  ng cannot be mat
2090: 63 68 65 64 20 74 6f 20 6f 6e 65 20 6f 66 20 74  ched to one of t
20a0: 68 65 20 61 62 6f 76 65 20 66 6f 72 6d 61 74 73  he above formats
20b0: 2c 20 61 6e 20 65 78 63 65 70 74 69 6f 6e 20 77  , an exception w
20c0: 69 6c 6c 20 62 65 20 74 68 72 6f 77 6e 2e 0d 0a  ill be thrown...
20d0: 20 20 20 20 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b      /// </remark
20e0: 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  s>..    /// <par
20f0: 61 6d 20 6e 61 6d 65 3d 22 64 61 74 65 54 65 78  am name="dateTex
2100: 74 22 3e 54 68 65 20 73 74 72 69 6e 67 20 63 6f  t">The string co
2110: 6e 74 61 69 6e 69 6e 67 20 65 69 74 68 65 72 20  ntaining either 
2120: 61 20 6c 6f 6e 67 20 69 6e 74 65 67 65 72 20 6e  a long integer n
2130: 75 6d 62 65 72 20 6f 66 20 31 30 30 2d 6e 61 6e  umber of 100-nan
2140: 6f 73 65 63 6f 6e 64 20 75 6e 69 74 73 20 73 69  osecond units si
2150: 6e 63 65 0d 0a 20 20 20 20 2f 2f 2f 20 53 79 73  nce..    /// Sys
2160: 74 65 6d 2e 44 61 74 65 54 69 6d 65 2e 4d 69 6e  tem.DateTime.Min
2170: 56 61 6c 75 65 2c 20 61 20 4a 75 6c 69 61 6e 20  Value, a Julian 
2180: 64 61 79 20 64 6f 75 62 6c 65 2c 20 61 6e 20 69  day double, an i
2190: 6e 74 65 67 65 72 20 6e 75 6d 62 65 72 20 6f 66  nteger number of
21a0: 20 73 65 63 6f 6e 64 73 20 73 69 6e 63 65 20 74   seconds since t
21b0: 68 65 20 55 6e 69 78 20 65 70 6f 63 68 2c 20 61  he Unix epoch, a
21c0: 0d 0a 20 20 20 20 2f 2f 2f 20 63 75 6c 74 75 72  ..    /// cultur
21d0: 65 2d 69 6e 64 65 70 65 6e 64 65 6e 74 20 66 6f  e-independent fo
21e0: 72 6d 61 74 74 65 64 20 64 61 74 65 20 61 6e 64  rmatted date and
21f0: 20 74 69 6d 65 20 73 74 72 69 6e 67 2c 20 61 20   time string, a 
2200: 66 6f 72 6d 61 74 74 65 64 20 64 61 74 65 20 61  formatted date a
2210: 6e 64 20 74 69 6d 65 20 73 74 72 69 6e 67 20 69  nd time string i
2220: 6e 20 74 68 65 20 63 75 72 72 65 6e 74 0d 0a 20  n the current.. 
2230: 20 20 20 2f 2f 2f 20 63 75 6c 74 75 72 65 2c 20     /// culture, 
2240: 6f 72 20 61 6e 20 49 53 4f 38 36 30 31 2d 66 6f  or an ISO8601-fo
2250: 72 6d 61 74 20 73 74 72 69 6e 67 2e 3c 2f 70 61  rmat string.</pa
2260: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72  ram>..    /// <r
2270: 65 74 75 72 6e 73 3e 41 20 44 61 74 65 54 69 6d  eturns>A DateTim
2280: 65 20 76 61 6c 75 65 3c 2f 72 65 74 75 72 6e 73  e value</returns
2290: 3e 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 44 61  >..    public Da
22a0: 74 65 54 69 6d 65 20 54 6f 44 61 74 65 54 69 6d  teTime ToDateTim
22b0: 65 28 73 74 72 69 6e 67 20 64 61 74 65 54 65 78  e(string dateTex
22c0: 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  t)..    {..     
22d0: 20 72 65 74 75 72 6e 20 54 6f 44 61 74 65 54 69   return ToDateTi
22e0: 6d 65 28 64 61 74 65 54 65 78 74 2c 20 5f 64 61  me(dateText, _da
22f0: 74 65 74 69 6d 65 46 6f 72 6d 61 74 2c 20 5f 64  tetimeFormat, _d
2300: 61 74 65 74 69 6d 65 4b 69 6e 64 29 3b 0d 0a 20  atetimeKind);.. 
2310: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20     }....    /// 
2320: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
2330: 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20 73 74  // Converts a st
2340: 72 69 6e 67 20 69 6e 74 6f 20 61 20 44 61 74 65  ring into a Date
2350: 54 69 6d 65 2c 20 75 73 69 6e 67 20 74 68 65 20  Time, using the 
2360: 73 70 65 63 69 66 69 65 64 20 44 61 74 65 54 69  specified DateTi
2370: 6d 65 46 6f 72 6d 61 74 20 61 6e 64 20 44 61 74  meFormat and Dat
2380: 65 54 69 6d 65 4b 69 6e 64 2e 0d 0a 20 20 20 20  eTimeKind...    
2390: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
23a0: 20 20 20 20 2f 2f 2f 20 3c 72 65 6d 61 72 6b 73      /// <remarks
23b0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 63 63 65 70  >..    /// Accep
23c0: 74 61 62 6c 65 20 49 53 4f 38 36 30 31 20 44 61  table ISO8601 Da
23d0: 74 65 54 69 6d 65 20 66 6f 72 6d 61 74 73 20 61  teTime formats a
23e0: 72 65 3a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 6c 69  re:..    /// <li
23f0: 73 74 20 74 79 70 65 3d 22 62 75 6c 6c 65 74 22  st type="bullet"
2400: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
2410: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 54 48  ><description>TH
2420: 48 6d 6d 73 73 4b 3c 2f 64 65 73 63 72 69 70 74  HmmssK</descript
2430: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
2440: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
2450: 72 69 70 74 69 6f 6e 3e 54 48 48 6d 6d 4b 3c 2f  ription>THHmmK</
2460: 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74  description></it
2470: 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74  em>..    /// <it
2480: 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e  em><description>
2490: 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46  HH:mm:ss.FFFFFFF
24a0: 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  K</description><
24b0: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
24c0: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
24d0: 6f 6e 3e 48 48 3a 6d 6d 3a 73 73 4b 3c 2f 64 65  on>HH:mm:ssK</de
24e0: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
24f0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
2500: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 48 48  ><description>HH
2510: 3a 6d 6d 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f  :mmK</descriptio
2520: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
2530: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
2540: 70 74 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64  ption>yyyy-MM-dd
2550: 20 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46   HH:mm:ss.FFFFFF
2560: 46 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  FK</description>
2570: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
2580: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
2590: 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 20 48  ion>yyyy-MM-dd H
25a0: 48 3a 6d 6d 3a 73 73 4b 3c 2f 64 65 73 63 72 69  H:mm:ssK</descri
25b0: 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20  ption></item>.. 
25c0: 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65     /// <item><de
25d0: 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d 4d  scription>yyyy-M
25e0: 4d 2d 64 64 20 48 48 3a 6d 6d 4b 3c 2f 64 65 73  M-dd HH:mmK</des
25f0: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
2600: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
2610: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
2620: 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73  y-MM-ddTHH:mm:ss
2630: 2e 46 46 46 46 46 46 46 4b 3c 2f 64 65 73 63 72  .FFFFFFFK</descr
2640: 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a  iption></item>..
2650: 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64      /// <item><d
2660: 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 2d  escription>yyyy-
2670: 4d 4d 2d 64 64 54 48 48 3a 6d 6d 4b 3c 2f 64 65  MM-ddTHH:mmK</de
2680: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
2690: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
26a0: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79  ><description>yy
26b0: 79 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73  yy-MM-ddTHH:mm:s
26c0: 73 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  sK</description>
26d0: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
26e0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
26f0: 69 6f 6e 3e 79 79 79 79 4d 4d 64 64 48 48 6d 6d  ion>yyyyMMddHHmm
2700: 73 73 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e  ssK</description
2710: 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f  ></item>..    //
2720: 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70  / <item><descrip
2730: 74 69 6f 6e 3e 79 79 79 79 4d 4d 64 64 48 48 6d  tion>yyyyMMddHHm
2740: 6d 4b 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  mK</description>
2750: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
2760: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
2770: 69 6f 6e 3e 79 79 79 79 4d 4d 64 64 54 48 48 6d  ion>yyyyMMddTHHm
2780: 6d 73 73 46 46 46 46 46 46 46 4b 3c 2f 64 65 73  mssFFFFFFFK</des
2790: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
27a0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
27b0: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 54 48 48  <description>THH
27c0: 6d 6d 73 73 3c 2f 64 65 73 63 72 69 70 74 69 6f  mmss</descriptio
27d0: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
27e0: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
27f0: 70 74 69 6f 6e 3e 54 48 48 6d 6d 3c 2f 64 65 73  ption>THHmm</des
2800: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
2810: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
2820: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 48 48 3a  <description>HH:
2830: 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 3c 2f 64  mm:ss.FFFFFFF</d
2840: 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65  escription></ite
2850: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65  m>..    /// <ite
2860: 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 48  m><description>H
2870: 48 3a 6d 6d 3a 73 73 3c 2f 64 65 73 63 72 69 70  H:mm:ss</descrip
2880: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
2890: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
28a0: 63 72 69 70 74 69 6f 6e 3e 48 48 3a 6d 6d 3c 2f  cription>HH:mm</
28b0: 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74  description></it
28c0: 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74  em>..    /// <it
28d0: 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e  em><description>
28e0: 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d  yyyy-MM-dd HH:mm
28f0: 3a 73 73 2e 46 46 46 46 46 46 46 3c 2f 64 65 73  :ss.FFFFFFF</des
2900: 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e  cription></item>
2910: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e  ..    /// <item>
2920: 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79 79  <description>yyy
2930: 79 2d 4d 4d 2d 64 64 20 48 48 3a 6d 6d 3a 73 73  y-MM-dd HH:mm:ss
2940: 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f  </description></
2950: 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  item>..    /// <
2960: 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f  item><descriptio
2970: 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 20 48 48 3a  n>yyyy-MM-dd HH:
2980: 6d 6d 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  mm</description>
2990: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
29a0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
29b0: 69 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48  ion>yyyy-MM-ddTH
29c0: 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46 46 46 3c  H:mm:ss.FFFFFFF<
29d0: 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69  /description></i
29e0: 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69  tem>..    /// <i
29f0: 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e  tem><description
2a00: 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d  >yyyy-MM-ddTHH:m
2a10: 6d 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e 3c  m</description><
2a20: 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  /item>..    /// 
2a30: 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74 69  <item><descripti
2a40: 6f 6e 3e 79 79 79 79 2d 4d 4d 2d 64 64 54 48 48  on>yyyy-MM-ddTHH
2a50: 3a 6d 6d 3a 73 73 3c 2f 64 65 73 63 72 69 70 74  :mm:ss</descript
2a60: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
2a70: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
2a80: 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64 64  ription>yyyyMMdd
2a90: 48 48 6d 6d 73 73 3c 2f 64 65 73 63 72 69 70 74  HHmmss</descript
2aa0: 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20  ion></item>..   
2ab0: 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63   /// <item><desc
2ac0: 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64 64  ription>yyyyMMdd
2ad0: 48 48 6d 6d 3c 2f 64 65 73 63 72 69 70 74 69 6f  HHmm</descriptio
2ae0: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
2af0: 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69  // <item><descri
2b00: 70 74 69 6f 6e 3e 79 79 79 79 4d 4d 64 64 54 48  ption>yyyyMMddTH
2b10: 48 6d 6d 73 73 46 46 46 46 46 46 46 3c 2f 64 65  HmmssFFFFFFF</de
2b20: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
2b30: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d  >..    /// <item
2b40: 3e 3c 64 65 73 63 72 69 70 74 69 6f 6e 3e 79 79  ><description>yy
2b50: 79 79 2d 4d 4d 2d 64 64 3c 2f 64 65 73 63 72 69  yy-MM-dd</descri
2b60: 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20  ption></item>.. 
2b70: 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65     /// <item><de
2b80: 73 63 72 69 70 74 69 6f 6e 3e 79 79 79 79 4d 4d  scription>yyyyMM
2b90: 64 64 3c 2f 64 65 73 63 72 69 70 74 69 6f 6e 3e  dd</description>
2ba0: 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  </item>..    ///
2bb0: 20 3c 69 74 65 6d 3e 3c 64 65 73 63 72 69 70 74   <item><descript
2bc0: 69 6f 6e 3e 79 79 2d 4d 4d 2d 64 64 3c 2f 64 65  ion>yy-MM-dd</de
2bd0: 73 63 72 69 70 74 69 6f 6e 3e 3c 2f 69 74 65 6d  scription></item
2be0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 6c 69 73  >..    /// </lis
2bf0: 74 3e 0d 0a 20 20 20 20 2f 2f 2f 20 49 66 20 74  t>..    /// If t
2c00: 68 65 20 73 74 72 69 6e 67 20 63 61 6e 6e 6f 74  he string cannot
2c10: 20 62 65 20 6d 61 74 63 68 65 64 20 74 6f 20 6f   be matched to o
2c20: 6e 65 20 6f 66 20 74 68 65 20 61 62 6f 76 65 20  ne of the above 
2c30: 66 6f 72 6d 61 74 73 2c 20 61 6e 20 65 78 63 65  formats, an exce
2c40: 70 74 69 6f 6e 20 77 69 6c 6c 20 62 65 20 74 68  ption will be th
2c50: 72 6f 77 6e 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  rown...    /// <
2c60: 2f 72 65 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f  /remarks>..    /
2c70: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
2c80: 64 61 74 65 54 65 78 74 22 3e 54 68 65 20 73 74  dateText">The st
2c90: 72 69 6e 67 20 63 6f 6e 74 61 69 6e 69 6e 67 20  ring containing 
2ca0: 65 69 74 68 65 72 20 61 20 6c 6f 6e 67 20 69 6e  either a long in
2cb0: 74 65 67 65 72 20 6e 75 6d 62 65 72 20 6f 66 20  teger number of 
2cc0: 31 30 30 2d 6e 61 6e 6f 73 65 63 6f 6e 64 20 75  100-nanosecond u
2cd0: 6e 69 74 73 20 73 69 6e 63 65 0d 0a 20 20 20 20  nits since..    
2ce0: 2f 2f 2f 20 53 79 73 74 65 6d 2e 44 61 74 65 54  /// System.DateT
2cf0: 69 6d 65 2e 4d 69 6e 56 61 6c 75 65 2c 20 61 20  ime.MinValue, a 
2d00: 4a 75 6c 69 61 6e 20 64 61 79 20 64 6f 75 62 6c  Julian day doubl
2d10: 65 2c 20 61 6e 20 69 6e 74 65 67 65 72 20 6e 75  e, an integer nu
2d20: 6d 62 65 72 20 6f 66 20 73 65 63 6f 6e 64 73 20  mber of seconds 
2d30: 73 69 6e 63 65 20 74 68 65 20 55 6e 69 78 20 65  since the Unix e
2d40: 70 6f 63 68 2c 20 61 0d 0a 20 20 20 20 2f 2f 2f  poch, a..    ///
2d50: 20 63 75 6c 74 75 72 65 2d 69 6e 64 65 70 65 6e   culture-indepen
2d60: 64 65 6e 74 20 66 6f 72 6d 61 74 74 65 64 20 64  dent formatted d
2d70: 61 74 65 20 61 6e 64 20 74 69 6d 65 20 73 74 72  ate and time str
2d80: 69 6e 67 2c 20 61 20 66 6f 72 6d 61 74 74 65 64  ing, a formatted
2d90: 20 64 61 74 65 20 61 6e 64 20 74 69 6d 65 20 73   date and time s
2da0: 74 72 69 6e 67 20 69 6e 20 74 68 65 20 63 75 72  tring in the cur
2db0: 72 65 6e 74 0d 0a 20 20 20 20 2f 2f 2f 20 63 75  rent..    /// cu
2dc0: 6c 74 75 72 65 2c 20 6f 72 20 61 6e 20 49 53 4f  lture, or an ISO
2dd0: 38 36 30 31 2d 66 6f 72 6d 61 74 20 73 74 72 69  8601-format stri
2de0: 6e 67 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  ng.</param>..   
2df0: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
2e00: 3d 22 66 6f 72 6d 61 74 22 3e 54 68 65 20 53 51  ="format">The SQ
2e10: 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73 20  LiteDateFormats 
2e20: 74 6f 20 75 73 65 2e 3c 2f 70 61 72 61 6d 3e 0d  to use.</param>.
2e30: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
2e40: 6e 61 6d 65 3d 22 6b 69 6e 64 22 3e 54 68 65 20  name="kind">The 
2e50: 44 61 74 65 54 69 6d 65 4b 69 6e 64 20 74 6f 20  DateTimeKind to 
2e60: 75 73 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  use.</param>..  
2e70: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 41    /// <returns>A
2e80: 20 44 61 74 65 54 69 6d 65 20 76 61 6c 75 65 3c   DateTime value<
2e90: 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 70  /returns>..    p
2ea0: 75 62 6c 69 63 20 44 61 74 65 54 69 6d 65 20 54  ublic DateTime T
2eb0: 6f 44 61 74 65 54 69 6d 65 28 73 74 72 69 6e 67  oDateTime(string
2ec0: 20 64 61 74 65 54 65 78 74 2c 20 53 51 4c 69 74   dateText, SQLit
2ed0: 65 44 61 74 65 46 6f 72 6d 61 74 73 20 66 6f 72  eDateFormats for
2ee0: 6d 61 74 2c 20 44 61 74 65 54 69 6d 65 4b 69 6e  mat, DateTimeKin
2ef0: 64 20 6b 69 6e 64 29 0d 0a 20 20 20 20 7b 0d 0a  d kind)..    {..
2f00: 20 20 20 20 20 20 20 20 73 77 69 74 63 68 20 28          switch (
2f10: 66 6f 72 6d 61 74 29 0d 0a 20 20 20 20 20 20 20  format)..       
2f20: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
2f30: 63 61 73 65 20 53 51 4c 69 74 65 44 61 74 65 46  case SQLiteDateF
2f40: 6f 72 6d 61 74 73 2e 54 69 63 6b 73 3a 0d 0a 20  ormats.Ticks:.. 
2f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
2f60: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
2f70: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 65 77        return new
2f80: 20 44 61 74 65 54 69 6d 65 28 43 6f 6e 76 65 72   DateTime(Conver
2f90: 74 2e 54 6f 49 6e 74 36 34 28 0d 0a 20 20 20 20  t.ToInt64(..    
2fa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2fb0: 20 20 20 20 64 61 74 65 54 65 78 74 2c 20 43 75      dateText, Cu
2fc0: 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72 69  ltureInfo.Invari
2fd0: 61 6e 74 43 75 6c 74 75 72 65 29 2c 20 6b 69 6e  antCulture), kin
2fe0: 64 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  d);..           
2ff0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
3000: 20 20 20 20 63 61 73 65 20 53 51 4c 69 74 65 44      case SQLiteD
3010: 61 74 65 46 6f 72 6d 61 74 73 2e 4a 75 6c 69 61  ateFormats.Julia
3020: 6e 44 61 79 3a 0d 0a 20 20 20 20 20 20 20 20 20  nDay:..         
3030: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
3040: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65                re
3050: 74 75 72 6e 20 54 6f 44 61 74 65 54 69 6d 65 28  turn ToDateTime(
3060: 43 6f 6e 76 65 72 74 2e 54 6f 44 6f 75 62 6c 65  Convert.ToDouble
3070: 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  (..             
3080: 20 20 20 20 20 20 20 20 20 20 20 64 61 74 65 54             dateT
3090: 65 78 74 2c 20 43 75 6c 74 75 72 65 49 6e 66 6f  ext, CultureInfo
30a0: 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72  .InvariantCultur
30b0: 65 29 2c 20 6b 69 6e 64 29 3b 0d 0a 20 20 20 20  e), kind);..    
30c0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
30d0: 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20             case 
30e0: 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74  SQLiteDateFormat
30f0: 73 2e 55 6e 69 78 45 70 6f 63 68 3a 0d 0a 20 20  s.UnixEpoch:..  
3100: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d                {.
3110: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3120: 20 20 20 20 20 72 65 74 75 72 6e 20 44 61 74 65       return Date
3130: 54 69 6d 65 2e 53 70 65 63 69 66 79 4b 69 6e 64  Time.SpecifyKind
3140: 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  (..             
3150: 20 20 20 20 20 20 20 20 20 20 20 55 6e 69 78 45             UnixE
3160: 70 6f 63 68 2e 41 64 64 53 65 63 6f 6e 64 73 28  poch.AddSeconds(
3170: 43 6f 6e 76 65 72 74 2e 54 6f 49 6e 74 33 32 28  Convert.ToInt32(
3180: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3190: 20 20 20 20 20 20 20 20 20 20 64 61 74 65 54 65            dateTe
31a0: 78 74 2c 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e  xt, CultureInfo.
31b0: 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65  InvariantCulture
31c0: 29 29 2c 20 6b 69 6e 64 29 3b 0d 0a 20 20 20 20  )), kind);..    
31d0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
31e0: 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20             case 
31f0: 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74  SQLiteDateFormat
3200: 73 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75  s.InvariantCultu
3210: 72 65 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20  re:..           
3220: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
3230: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
3240: 72 6e 20 44 61 74 65 54 69 6d 65 2e 53 70 65 63  rn DateTime.Spec
3250: 69 66 79 4b 69 6e 64 28 44 61 74 65 54 69 6d 65  ifyKind(DateTime
3260: 2e 50 61 72 73 65 28 0d 0a 20 20 20 20 20 20 20  .Parse(..       
3270: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3280: 20 64 61 74 65 54 65 78 74 2c 20 44 61 74 65 54   dateText, DateT
3290: 69 6d 65 46 6f 72 6d 61 74 49 6e 66 6f 2e 49 6e  imeFormatInfo.In
32a0: 76 61 72 69 61 6e 74 49 6e 66 6f 2c 0d 0a 20 20  variantInfo,..  
32b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
32c0: 20 20 20 20 20 20 6b 69 6e 64 20 3d 3d 20 44 61        kind == Da
32d0: 74 65 54 69 6d 65 4b 69 6e 64 2e 55 74 63 20 3f  teTimeKind.Utc ?
32e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
32f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 44 61                Da
3300: 74 65 54 69 6d 65 53 74 79 6c 65 73 2e 41 64 6a  teTimeStyles.Adj
3310: 75 73 74 54 6f 55 6e 69 76 65 72 73 61 6c 20 3a  ustToUniversal :
3320: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3330: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 44 61                Da
3340: 74 65 54 69 6d 65 53 74 79 6c 65 73 2e 4e 6f 6e  teTimeStyles.Non
3350: 65 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  e),..           
3360: 20 20 20 20 20 20 20 20 20 20 20 20 20 6b 69 6e               kin
3370: 64 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  d);..           
3380: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
3390: 20 20 20 20 63 61 73 65 20 53 51 4c 69 74 65 44      case SQLiteD
33a0: 61 74 65 46 6f 72 6d 61 74 73 2e 43 75 72 72 65  ateFormats.Curre
33b0: 6e 74 43 75 6c 74 75 72 65 3a 0d 0a 20 20 20 20  ntCulture:..    
33c0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
33d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
33e0: 20 20 20 72 65 74 75 72 6e 20 44 61 74 65 54 69     return DateTi
33f0: 6d 65 2e 53 70 65 63 69 66 79 4b 69 6e 64 28 44  me.SpecifyKind(D
3400: 61 74 65 54 69 6d 65 2e 50 61 72 73 65 28 0d 0a  ateTime.Parse(..
3410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3420: 20 20 20 20 20 20 20 20 64 61 74 65 54 65 78 74          dateText
3430: 2c 20 44 61 74 65 54 69 6d 65 46 6f 72 6d 61 74  , DateTimeFormat
3440: 49 6e 66 6f 2e 43 75 72 72 65 6e 74 49 6e 66 6f  Info.CurrentInfo
3450: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ,..             
3460: 20 20 20 20 20 20 20 20 20 20 20 6b 69 6e 64 20             kind 
3470: 3d 3d 20 44 61 74 65 54 69 6d 65 4b 69 6e 64 2e  == DateTimeKind.
3480: 55 74 63 20 3f 0d 0a 20 20 20 20 20 20 20 20 20  Utc ?..         
3490: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
34a0: 20 20 20 44 61 74 65 54 69 6d 65 53 74 79 6c 65     DateTimeStyle
34b0: 73 2e 41 64 6a 75 73 74 54 6f 55 6e 69 76 65 72  s.AdjustToUniver
34c0: 73 61 6c 20 3a 0d 0a 20 20 20 20 20 20 20 20 20  sal :..         
34d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
34e0: 20 20 20 44 61 74 65 54 69 6d 65 53 74 79 6c 65     DateTimeStyle
34f0: 73 2e 4e 6f 6e 65 29 2c 0d 0a 20 20 20 20 20 20  s.None),..      
3500: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3510: 20 20 6b 69 6e 64 29 3b 0d 0a 20 20 20 20 20 20    kind);..      
3520: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
3530: 20 20 20 20 20 20 20 20 20 64 65 66 61 75 6c 74           default
3540: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  :..             
3550: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
3560: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
3570: 20 44 61 74 65 54 69 6d 65 2e 53 70 65 63 69 66   DateTime.Specif
3580: 79 4b 69 6e 64 28 44 61 74 65 54 69 6d 65 2e 50  yKind(DateTime.P
3590: 61 72 73 65 45 78 61 63 74 28 0d 0a 20 20 20 20  arseExact(..    
35a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
35b0: 20 20 20 20 64 61 74 65 54 65 78 74 2c 20 5f 64      dateText, _d
35c0: 61 74 65 74 69 6d 65 46 6f 72 6d 61 74 73 2c 0d  atetimeFormats,.
35d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
35e0: 20 20 20 20 20 20 20 20 20 44 61 74 65 54 69 6d           DateTim
35f0: 65 46 6f 72 6d 61 74 49 6e 66 6f 2e 49 6e 76 61  eFormatInfo.Inva
3600: 72 69 61 6e 74 49 6e 66 6f 2c 0d 0a 20 20 20 20  riantInfo,..    
3610: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3620: 20 20 20 20 6b 69 6e 64 20 3d 3d 20 44 61 74 65      kind == Date
3630: 54 69 6d 65 4b 69 6e 64 2e 55 74 63 20 3f 0d 0a  TimeKind.Utc ?..
3640: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3650: 20 20 20 20 20 20 20 20 20 20 20 20 44 61 74 65              Date
3660: 54 69 6d 65 53 74 79 6c 65 73 2e 41 64 6a 75 73  TimeStyles.Adjus
3670: 74 54 6f 55 6e 69 76 65 72 73 61 6c 20 3a 0d 0a  tToUniversal :..
3680: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3690: 20 20 20 20 20 20 20 20 20 20 20 20 44 61 74 65              Date
36a0: 54 69 6d 65 53 74 79 6c 65 73 2e 4e 6f 6e 65 29  TimeStyles.None)
36b0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ,..             
36c0: 20 20 20 20 20 20 20 20 20 20 20 6b 69 6e 64 29             kind)
36d0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
36e0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d     }..        }.
36f0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
3700: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
3710: 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20   /// Converts a 
3720: 6a 75 6c 69 61 6e 64 61 79 20 76 61 6c 75 65 20  julianday value 
3730: 69 6e 74 6f 20 61 20 44 61 74 65 54 69 6d 65 0d  into a DateTime.
3740: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
3750: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  ry>..    /// <pa
3760: 72 61 6d 20 6e 61 6d 65 3d 22 6a 75 6c 69 61 6e  ram name="julian
3770: 44 61 79 22 3e 54 68 65 20 76 61 6c 75 65 20 74  Day">The value t
3780: 6f 20 63 6f 6e 76 65 72 74 3c 2f 70 61 72 61 6d  o convert</param
3790: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75  >..    /// <retu
37a0: 72 6e 73 3e 41 20 2e 4e 45 54 20 44 61 74 65 54  rns>A .NET DateT
37b0: 69 6d 65 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20  ime</returns>.. 
37c0: 20 20 20 70 75 62 6c 69 63 20 44 61 74 65 54 69     public DateTi
37d0: 6d 65 20 54 6f 44 61 74 65 54 69 6d 65 28 64 6f  me ToDateTime(do
37e0: 75 62 6c 65 20 6a 75 6c 69 61 6e 44 61 79 29 0d  uble julianDay).
37f0: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65  .    {..      re
3800: 74 75 72 6e 20 54 6f 44 61 74 65 54 69 6d 65 28  turn ToDateTime(
3810: 6a 75 6c 69 61 6e 44 61 79 2c 20 5f 64 61 74 65  julianDay, _date
3820: 74 69 6d 65 4b 69 6e 64 29 3b 0d 0a 20 20 20 20  timeKind);..    
3830: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  }....    /// <su
3840: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
3850: 43 6f 6e 76 65 72 74 73 20 61 20 6a 75 6c 69 61  Converts a julia
3860: 6e 64 61 79 20 76 61 6c 75 65 20 69 6e 74 6f 20  nday value into 
3870: 61 20 44 61 74 65 54 69 6d 65 0d 0a 20 20 20 20  a DateTime..    
3880: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
3890: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
38a0: 61 6d 65 3d 22 6a 75 6c 69 61 6e 44 61 79 22 3e  ame="julianDay">
38b0: 54 68 65 20 76 61 6c 75 65 20 74 6f 20 63 6f 6e  The value to con
38c0: 76 65 72 74 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  vert</param>..  
38d0: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
38e0: 65 3d 22 6b 69 6e 64 22 3e 54 68 65 20 44 61 74  e="kind">The Dat
38f0: 65 54 69 6d 65 4b 69 6e 64 20 74 6f 20 75 73 65  eTimeKind to use
3900: 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  .</param>..    /
3910: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 41 20 2e 4e  // <returns>A .N
3920: 45 54 20 44 61 74 65 54 69 6d 65 3c 2f 72 65 74  ET DateTime</ret
3930: 75 72 6e 73 3e 0d 0a 20 20 20 20 70 75 62 6c 69  urns>..    publi
3940: 63 20 44 61 74 65 54 69 6d 65 20 54 6f 44 61 74  c DateTime ToDat
3950: 65 54 69 6d 65 28 64 6f 75 62 6c 65 20 6a 75 6c  eTime(double jul
3960: 69 61 6e 44 61 79 2c 20 44 61 74 65 54 69 6d 65  ianDay, DateTime
3970: 4b 69 6e 64 20 6b 69 6e 64 29 0d 0a 20 20 20 20  Kind kind)..    
3980: 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  {..        retur
3990: 6e 20 44 61 74 65 54 69 6d 65 2e 53 70 65 63 69  n DateTime.Speci
39a0: 66 79 4b 69 6e 64 28 0d 0a 20 20 20 20 20 20 20  fyKind(..       
39b0: 20 20 20 20 20 44 61 74 65 54 69 6d 65 2e 46 72       DateTime.Fr
39c0: 6f 6d 4f 41 44 61 74 65 28 6a 75 6c 69 61 6e 44  omOADate(julianD
39d0: 61 79 20 2d 20 4f 6c 65 41 75 74 6f 6d 61 74 69  ay - OleAutomati
39e0: 6f 6e 45 70 6f 63 68 41 73 4a 75 6c 69 61 6e 44  onEpochAsJulianD
39f0: 61 79 29 2c 20 6b 69 6e 64 29 3b 0d 0a 20 20 20  ay), kind);..   
3a00: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73   }....    /// <s
3a10: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
3a20: 20 43 6f 6e 76 65 72 74 73 20 61 20 44 61 74 65   Converts a Date
3a30: 54 69 6d 65 20 73 74 72 75 63 74 20 74 6f 20 61  Time struct to a
3a40: 20 4a 75 6c 69 61 6e 44 61 79 20 64 6f 75 62 6c   JulianDay doubl
3a50: 65 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  e..    /// </sum
3a60: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  mary>..    /// <
3a70: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 76 61 6c 75  param name="valu
3a80: 65 22 3e 54 68 65 20 44 61 74 65 54 69 6d 65 20  e">The DateTime 
3a90: 74 6f 20 63 6f 6e 76 65 72 74 3c 2f 70 61 72 61  to convert</para
3aa0: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74  m>..    /// <ret
3ab0: 75 72 6e 73 3e 54 68 65 20 4a 75 6c 69 61 6e 44  urns>The JulianD
3ac0: 61 79 20 76 61 6c 75 65 20 74 68 65 20 44 61 74  ay value the Dat
3ad0: 65 74 69 6d 65 20 72 65 70 72 65 73 65 6e 74 73  etime represents
3ae0: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
3af0: 70 75 62 6c 69 63 20 64 6f 75 62 6c 65 20 54 6f  public double To
3b00: 4a 75 6c 69 61 6e 44 61 79 28 44 61 74 65 54 69  JulianDay(DateTi
3b10: 6d 65 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b  me value)..    {
3b20: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 76  ..      return v
3b30: 61 6c 75 65 2e 54 6f 4f 41 44 61 74 65 28 29 20  alue.ToOADate() 
3b40: 2b 20 4f 6c 65 41 75 74 6f 6d 61 74 69 6f 6e 45  + OleAutomationE
3b50: 70 6f 63 68 41 73 4a 75 6c 69 61 6e 44 61 79 3b  pochAsJulianDay;
3b60: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f  ..    }....    /
3b70: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
3b80: 20 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61    /// Converts a
3b90: 20 44 61 74 65 54 69 6d 65 20 74 6f 20 61 20 73   DateTime to a s
3ba0: 74 72 69 6e 67 20 76 61 6c 75 65 2c 20 75 73 69  tring value, usi
3bb0: 6e 67 20 74 68 65 20 63 75 72 72 65 6e 74 20 44  ng the current D
3bc0: 61 74 65 54 69 6d 65 46 6f 72 6d 61 74 20 73 70  ateTimeFormat sp
3bd0: 65 63 69 66 69 65 64 20 66 6f 72 20 74 68 65 20  ecified for the 
3be0: 63 6f 6e 6e 65 63 74 69 6f 6e 20 77 68 65 6e 20  connection when 
3bf0: 69 74 20 77 61 73 20 6f 70 65 6e 65 64 2e 0d 0a  it was opened...
3c00: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
3c10: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  y>..    /// <par
3c20: 61 6d 20 6e 61 6d 65 3d 22 64 61 74 65 56 61 6c  am name="dateVal
3c30: 75 65 22 3e 54 68 65 20 44 61 74 65 54 69 6d 65  ue">The DateTime
3c40: 20 76 61 6c 75 65 20 74 6f 20 63 6f 6e 76 65 72   value to conver
3c50: 74 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  t</param>..    /
3c60: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 45 69 74 68  // <returns>Eith
3c70: 65 72 20 61 20 73 74 72 69 6e 67 20 63 6f 6e 74  er a string cont
3c80: 61 69 6e 69 6e 67 20 74 68 65 20 6c 6f 6e 67 20  aining the long 
3c90: 69 6e 74 65 67 65 72 20 6e 75 6d 62 65 72 20 6f  integer number o
3ca0: 66 20 31 30 30 2d 6e 61 6e 6f 73 65 63 6f 6e 64  f 100-nanosecond
3cb0: 20 75 6e 69 74 73 20 73 69 6e 63 65 20 53 79 73   units since Sys
3cc0: 74 65 6d 2e 44 61 74 65 54 69 6d 65 2e 4d 69 6e  tem.DateTime.Min
3cd0: 56 61 6c 75 65 2c 20 61 0d 0a 20 20 20 20 2f 2f  Value, a..    //
3ce0: 2f 20 4a 75 6c 69 61 6e 20 64 61 79 20 64 6f 75  / Julian day dou
3cf0: 62 6c 65 2c 20 61 6e 20 69 6e 74 65 67 65 72 20  ble, an integer 
3d00: 6e 75 6d 62 65 72 20 6f 66 20 73 65 63 6f 6e 64  number of second
3d10: 73 20 73 69 6e 63 65 20 74 68 65 20 55 6e 69 78  s since the Unix
3d20: 20 65 70 6f 63 68 2c 20 61 20 63 75 6c 74 75 72   epoch, a cultur
3d30: 65 2d 69 6e 64 65 70 65 6e 64 65 6e 74 20 66 6f  e-independent fo
3d40: 72 6d 61 74 74 65 64 20 64 61 74 65 20 61 6e 64  rmatted date and
3d50: 20 74 69 6d 65 0d 0a 20 20 20 20 2f 2f 2f 20 73   time..    /// s
3d60: 74 72 69 6e 67 2c 20 61 20 66 6f 72 6d 61 74 74  tring, a formatt
3d70: 65 64 20 64 61 74 65 20 61 6e 64 20 74 69 6d 65  ed date and time
3d80: 20 73 74 72 69 6e 67 20 69 6e 20 74 68 65 20 63   string in the c
3d90: 75 72 72 65 6e 74 20 63 75 6c 74 75 72 65 2c 20  urrent culture, 
3da0: 6f 72 20 61 6e 20 49 53 4f 38 36 30 31 2d 66 6f  or an ISO8601-fo
3db0: 72 6d 61 74 20 64 61 74 65 2f 74 69 6d 65 20 73  rmat date/time s
3dc0: 74 72 69 6e 67 2e 3c 2f 72 65 74 75 72 6e 73 3e  tring.</returns>
3dd0: 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 73 74 72  ..    public str
3de0: 69 6e 67 20 54 6f 53 74 72 69 6e 67 28 44 61 74  ing ToString(Dat
3df0: 65 54 69 6d 65 20 64 61 74 65 56 61 6c 75 65 29  eTime dateValue)
3e00: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 73  ..    {..      s
3e10: 77 69 74 63 68 20 28 5f 64 61 74 65 74 69 6d 65  witch (_datetime
3e20: 46 6f 72 6d 61 74 29 0d 0a 20 20 20 20 20 20 7b  Format)..      {
3e30: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 53  ..        case S
3e40: 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73  QLiteDateFormats
3e50: 2e 54 69 63 6b 73 3a 0d 0a 20 20 20 20 20 20 20  .Ticks:..       
3e60: 20 20 20 72 65 74 75 72 6e 20 64 61 74 65 56 61     return dateVa
3e70: 6c 75 65 2e 54 69 63 6b 73 2e 54 6f 53 74 72 69  lue.Ticks.ToStri
3e80: 6e 67 28 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49  ng(CultureInfo.I
3e90: 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65 29  nvariantCulture)
3ea0: 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  ;..        case 
3eb0: 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74  SQLiteDateFormat
3ec0: 73 2e 4a 75 6c 69 61 6e 44 61 79 3a 0d 0a 20 20  s.JulianDay:..  
3ed0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 54          return T
3ee0: 6f 4a 75 6c 69 61 6e 44 61 79 28 64 61 74 65 56  oJulianDay(dateV
3ef0: 61 6c 75 65 29 2e 54 6f 53 74 72 69 6e 67 28 43  alue).ToString(C
3f00: 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72  ultureInfo.Invar
3f10: 69 61 6e 74 43 75 6c 74 75 72 65 29 3b 0d 0a 20  iantCulture);.. 
3f20: 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 69         case SQLi
3f30: 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 55 6e  teDateFormats.Un
3f40: 69 78 45 70 6f 63 68 3a 0d 0a 20 20 20 20 20 20  ixEpoch:..      
3f50: 20 20 20 20 72 65 74 75 72 6e 20 28 28 6c 6f 6e      return ((lon
3f60: 67 29 28 64 61 74 65 56 61 6c 75 65 2e 53 75 62  g)(dateValue.Sub
3f70: 74 72 61 63 74 28 55 6e 69 78 45 70 6f 63 68 29  tract(UnixEpoch)
3f80: 2e 54 69 63 6b 73 20 2f 20 54 69 6d 65 53 70 61  .Ticks / TimeSpa
3f90: 6e 2e 54 69 63 6b 73 50 65 72 53 65 63 6f 6e 64  n.TicksPerSecond
3fa0: 29 29 2e 54 6f 53 74 72 69 6e 67 28 29 3b 0d 0a  )).ToString();..
3fb0: 20 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c          case SQL
3fc0: 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 49  iteDateFormats.I
3fd0: 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65 3a  nvariantCulture:
3fe0: 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75  ..          retu
3ff0: 72 6e 20 64 61 74 65 56 61 6c 75 65 2e 54 6f 53  rn dateValue.ToS
4000: 74 72 69 6e 67 28 46 75 6c 6c 46 6f 72 6d 61 74  tring(FullFormat
4010: 2c 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e  , CultureInfo.In
4020: 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65 29 3b  variantCulture);
4030: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 53  ..        case S
4040: 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73  QLiteDateFormats
4050: 2e 43 75 72 72 65 6e 74 43 75 6c 74 75 72 65 3a  .CurrentCulture:
4060: 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75  ..          retu
4070: 72 6e 20 64 61 74 65 56 61 6c 75 65 2e 54 6f 53  rn dateValue.ToS
4080: 74 72 69 6e 67 28 46 75 6c 6c 46 6f 72 6d 61 74  tring(FullFormat
4090: 2c 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e 43 75  , CultureInfo.Cu
40a0: 72 72 65 6e 74 43 75 6c 74 75 72 65 29 3b 0d 0a  rrentCulture);..
40b0: 20 20 20 20 20 20 20 20 64 65 66 61 75 6c 74 3a          default:
40c0: 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75  ..          retu
40d0: 72 6e 20 28 64 61 74 65 56 61 6c 75 65 2e 4b 69  rn (dateValue.Ki
40e0: 6e 64 20 3d 3d 20 44 61 74 65 54 69 6d 65 4b 69  nd == DateTimeKi
40f0: 6e 64 2e 55 74 63 29 20 3f 0d 0a 20 20 20 20 20  nd.Utc) ?..     
4100: 20 20 20 20 20 20 20 20 20 64 61 74 65 56 61 6c           dateVal
4110: 75 65 2e 54 6f 53 74 72 69 6e 67 28 5f 64 61 74  ue.ToString(_dat
4120: 65 74 69 6d 65 46 6f 72 6d 61 74 73 5b 35 5d 2c  etimeFormats[5],
4130: 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76   CultureInfo.Inv
4140: 61 72 69 61 6e 74 43 75 6c 74 75 72 65 29 20 3a  ariantCulture) :
4150: 20 2f 2f 20 69 6e 63 6c 75 64 65 20 22 5a 22 0d   // include "Z".
4160: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64  .              d
4170: 61 74 65 56 61 6c 75 65 2e 54 6f 53 74 72 69 6e  ateValue.ToStrin
4180: 67 28 5f 64 61 74 65 74 69 6d 65 46 6f 72 6d 61  g(_datetimeForma
4190: 74 73 5b 31 39 5d 2c 20 43 75 6c 74 75 72 65 49  ts[19], CultureI
41a0: 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c  nfo.InvariantCul
41b0: 74 75 72 65 29 3b 0d 0a 20 20 20 20 20 20 7d 0d  ture);..      }.
41c0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
41d0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
41e0: 20 2f 2f 2f 20 49 6e 74 65 72 6e 61 6c 20 66 75   /// Internal fu
41f0: 6e 63 74 69 6f 6e 20 74 6f 20 63 6f 6e 76 65 72  nction to conver
4200: 74 20 61 20 55 54 46 2d 38 20 65 6e 63 6f 64 65  t a UTF-8 encode
4210: 64 20 49 6e 74 50 74 72 20 6f 66 20 74 68 65 20  d IntPtr of the 
4220: 73 70 65 63 69 66 69 65 64 20 6c 65 6e 67 74 68  specified length
4230: 20 74 6f 20 61 20 44 61 74 65 54 69 6d 65 2e 0d   to a DateTime..
4240: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
4250: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ry>..    /// <re
4260: 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20  marks>..    /// 
4270: 54 68 69 73 20 69 73 20 61 20 63 6f 6e 76 65 6e  This is a conven
4280: 69 65 6e 63 65 20 66 75 6e 63 74 69 6f 6e 2c 20  ience function, 
4290: 77 68 69 63 68 20 66 69 72 73 74 20 63 61 6c 6c  which first call
42a0: 73 20 54 6f 53 74 72 69 6e 67 28 29 20 6f 6e 20  s ToString() on 
42b0: 74 68 65 20 49 6e 74 50 74 72 20 74 6f 20 63 6f  the IntPtr to co
42c0: 6e 76 65 72 74 20 69 74 20 74 6f 20 61 20 73 74  nvert it to a st
42d0: 72 69 6e 67 2c 20 74 68 65 6e 20 63 61 6c 6c 73  ring, then calls
42e0: 0d 0a 20 20 20 20 2f 2f 2f 20 54 6f 44 61 74 65  ..    /// ToDate
42f0: 54 69 6d 65 28 29 20 6f 6e 20 74 68 65 20 73 74  Time() on the st
4300: 72 69 6e 67 20 74 6f 20 72 65 74 75 72 6e 20 61  ring to return a
4310: 20 44 61 74 65 54 69 6d 65 2e 0d 0a 20 20 20 20   DateTime...    
4320: 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73 3e 0d 0a  /// </remarks>..
4330: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
4340: 61 6d 65 3d 22 70 74 72 22 3e 41 20 70 6f 69 6e  ame="ptr">A poin
4350: 74 65 72 20 74 6f 20 74 68 65 20 55 54 46 2d 38  ter to the UTF-8
4360: 20 65 6e 63 6f 64 65 64 20 73 74 72 69 6e 67 3c   encoded string<
4370: 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  /param>..    ///
4380: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6c 65   <param name="le
4390: 6e 22 3e 54 68 65 20 6c 65 6e 67 74 68 20 69 6e  n">The length in
43a0: 20 62 79 74 65 73 20 6f 66 20 74 68 65 20 73 74   bytes of the st
43b0: 72 69 6e 67 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  ring</param>..  
43c0: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54    /// <returns>T
43d0: 68 65 20 70 61 72 73 65 64 20 44 61 74 65 54 69  he parsed DateTi
43e0: 6d 65 20 76 61 6c 75 65 3c 2f 72 65 74 75 72 6e  me value</return
43f0: 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  s>..    internal
4400: 20 44 61 74 65 54 69 6d 65 20 54 6f 44 61 74 65   DateTime ToDate
4410: 54 69 6d 65 28 49 6e 74 50 74 72 20 70 74 72 2c  Time(IntPtr ptr,
4420: 20 69 6e 74 20 6c 65 6e 29 0d 0a 20 20 20 20 7b   int len)..    {
4430: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 54  ..      return T
4440: 6f 44 61 74 65 54 69 6d 65 28 54 6f 53 74 72 69  oDateTime(ToStri
4450: 6e 67 28 70 74 72 2c 20 6c 65 6e 29 29 3b 0d 0a  ng(ptr, len));..
4460: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 23 65 6e      }....    #en
4470: 64 72 65 67 69 6f 6e 0d 0a 0d 0a 20 20 20 20 2f  dregion....    /
4480: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
4490: 20 20 2f 2f 2f 20 53 6d 61 72 74 20 6d 65 74 68    /// Smart meth
44a0: 6f 64 20 6f 66 20 73 70 6c 69 74 74 69 6e 67 20  od of splitting 
44b0: 61 20 73 74 72 69 6e 67 2e 20 20 53 6b 69 70 73  a string.  Skips
44c0: 20 71 75 6f 74 65 64 20 65 6c 65 6d 65 6e 74 73   quoted elements
44d0: 2c 20 72 65 6d 6f 76 65 73 20 74 68 65 20 71 75  , removes the qu
44e0: 6f 74 65 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  otes...    /// <
44f0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  /summary>..    /
4500: 2f 2f 20 3c 72 65 6d 61 72 6b 73 3e 0d 0a 20 20  // <remarks>..  
4510: 20 20 2f 2f 2f 20 54 68 69 73 20 73 70 6c 69 74    /// This split
4520: 20 66 75 6e 63 74 69 6f 6e 20 77 6f 72 6b 73 20   function works 
4530: 73 6f 6d 65 77 68 61 74 20 6c 69 6b 65 20 74 68  somewhat like th
4540: 65 20 53 74 72 69 6e 67 2e 53 70 6c 69 74 28 29  e String.Split()
4550: 20 66 75 6e 63 74 69 6f 6e 20 69 6e 20 74 68 61   function in tha
4560: 74 20 69 74 20 62 72 65 61 6b 73 20 61 70 61 72  t it breaks apar
4570: 74 20 61 20 73 74 72 69 6e 67 20 69 6e 74 6f 0d  t a string into.
4580: 0a 20 20 20 20 2f 2f 2f 20 70 69 65 63 65 73 20  .    /// pieces 
4590: 61 6e 64 20 72 65 74 75 72 6e 73 20 74 68 65 20  and returns the 
45a0: 70 69 65 63 65 73 20 61 73 20 61 6e 20 61 72 72  pieces as an arr
45b0: 61 79 2e 20 20 54 68 65 20 70 72 69 6d 61 72 79  ay.  The primary
45c0: 20 64 69 66 66 65 72 65 6e 63 65 73 20 61 72 65   differences are
45d0: 3a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 6c 69 73 74  :..    /// <list
45e0: 20 74 79 70 65 3d 22 62 75 6c 6c 65 74 22 3e 0d   type="bullet">.
45f0: 0a 20 20 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c  .    /// <item><
4600: 64 65 73 63 72 69 70 74 69 6f 6e 3e 4f 6e 6c 79  description>Only
4610: 20 6f 6e 65 20 63 68 61 72 61 63 74 65 72 20 63   one character c
4620: 61 6e 20 62 65 20 70 72 6f 76 69 64 65 64 20 61  an be provided a
4630: 73 20 61 20 73 65 70 61 72 61 74 6f 72 20 63 68  s a separator ch
4640: 61 72 61 63 74 65 72 3c 2f 64 65 73 63 72 69 70  aracter</descrip
4650: 74 69 6f 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20  tion></item>..  
4660: 20 20 2f 2f 2f 20 3c 69 74 65 6d 3e 3c 64 65 73    /// <item><des
4670: 63 72 69 70 74 69 6f 6e 3e 51 75 6f 74 65 64 20  cription>Quoted 
4680: 74 65 78 74 20 69 6e 73 69 64 65 20 74 68 65 20  text inside the 
4690: 73 74 72 69 6e 67 20 69 73 20 73 6b 69 70 70 65  string is skippe
46a0: 64 20 6f 76 65 72 20 77 68 65 6e 20 73 65 61 72  d over when sear
46b0: 63 68 69 6e 67 20 66 6f 72 20 74 68 65 20 73 65  ching for the se
46c0: 70 61 72 61 74 6f 72 2c 20 61 6e 64 20 74 68 65  parator, and the
46d0: 20 71 75 6f 74 65 73 20 61 72 65 20 72 65 6d 6f   quotes are remo
46e0: 76 65 64 2e 3c 2f 64 65 73 63 72 69 70 74 69 6f  ved.</descriptio
46f0: 6e 3e 3c 2f 69 74 65 6d 3e 0d 0a 20 20 20 20 2f  n></item>..    /
4700: 2f 2f 20 3c 2f 6c 69 73 74 3e 0d 0a 20 20 20 20  // </list>..    
4710: 2f 2f 2f 20 54 68 75 73 2c 20 69 66 20 73 70 6c  /// Thus, if spl
4720: 69 74 74 69 6e 67 20 74 68 65 20 66 6f 6c 6c 6f  itting the follo
4730: 77 69 6e 67 20 73 74 72 69 6e 67 20 6c 6f 6f 6b  wing string look
4740: 69 6e 67 20 66 6f 72 20 61 20 63 6f 6d 6d 61 3a  ing for a comma:
4750: 3c 62 72 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 4f  <br/>..    /// O
4760: 6e 65 2c 54 77 6f 2c 20 22 54 68 72 65 65 2c 20  ne,Two, "Three, 
4770: 46 6f 75 72 22 2c 20 46 69 76 65 3c 62 72 2f 3e  Four", Five<br/>
4780: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 62 72 2f 3e 0d  ..    /// <br/>.
4790: 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 72 65 73  .    /// The res
47a0: 75 6c 74 69 6e 67 20 61 72 72 61 79 20 77 6f 75  ulting array wou
47b0: 6c 64 20 63 6f 6e 74 61 69 6e 3c 62 72 2f 3e 0d  ld contain<br/>.
47c0: 0a 20 20 20 20 2f 2f 2f 20 5b 30 5d 20 4f 6e 65  .    /// [0] One
47d0: 3c 62 72 2f 3e 0d 0a 20 20 20 20 2f 2f 2f 20 5b  <br/>..    /// [
47e0: 31 5d 20 54 77 6f 3c 62 72 2f 3e 0d 0a 20 20 20  1] Two<br/>..   
47f0: 20 2f 2f 2f 20 5b 32 5d 20 54 68 72 65 65 2c 20   /// [2] Three, 
4800: 46 6f 75 72 3c 62 72 2f 3e 0d 0a 20 20 20 20 2f  Four<br/>..    /
4810: 2f 2f 20 5b 33 5d 20 46 69 76 65 3c 62 72 2f 3e  // [3] Five<br/>
4820: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 62 72 2f 3e 0d  ..    /// <br/>.
4830: 0a 20 20 20 20 2f 2f 2f 20 4e 6f 74 65 20 74 68  .    /// Note th
4840: 61 74 20 74 68 65 20 6c 65 61 64 69 6e 67 20 61  at the leading a
4850: 6e 64 20 74 72 61 69 6c 69 6e 67 20 73 70 61 63  nd trailing spac
4860: 65 73 20 77 65 72 65 20 72 65 6d 6f 76 65 64 20  es were removed 
4870: 66 72 6f 6d 20 65 61 63 68 20 69 74 65 6d 20 64  from each item d
4880: 75 72 69 6e 67 20 74 68 65 20 73 70 6c 69 74 2e  uring the split.
4890: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72 65 6d 61  ..    /// </rema
48a0: 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  rks>..    /// <p
48b0: 61 72 61 6d 20 6e 61 6d 65 3d 22 73 6f 75 72 63  aram name="sourc
48c0: 65 22 3e 53 6f 75 72 63 65 20 73 74 72 69 6e 67  e">Source string
48d0: 20 74 6f 20 73 70 6c 69 74 20 61 70 61 72 74 3c   to split apart<
48e0: 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  /param>..    ///
48f0: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 73 65   <param name="se
4900: 70 61 72 61 74 6f 72 22 3e 53 65 70 61 72 61 74  parator">Separat
4910: 6f 72 20 63 68 61 72 61 63 74 65 72 3c 2f 70 61  or character</pa
4920: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72  ram>..    /// <r
4930: 65 74 75 72 6e 73 3e 41 20 73 74 72 69 6e 67 20  eturns>A string 
4940: 61 72 72 61 79 20 6f 66 20 74 68 65 20 73 70 6c  array of the spl
4950: 69 74 20 75 70 20 65 6c 65 6d 65 6e 74 73 3c 2f  it up elements</
4960: 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 70 75  returns>..    pu
4970: 62 6c 69 63 20 73 74 61 74 69 63 20 73 74 72 69  blic static stri
4980: 6e 67 5b 5d 20 53 70 6c 69 74 28 73 74 72 69 6e  ng[] Split(strin
4990: 67 20 73 6f 75 72 63 65 2c 20 63 68 61 72 20 73  g source, char s
49a0: 65 70 61 72 61 74 6f 72 29 0d 0a 20 20 20 20 7b  eparator)..    {
49b0: 0d 0a 20 20 20 20 20 20 63 68 61 72 5b 5d 20 74  ..      char[] t
49c0: 6f 6b 73 20 3d 20 6e 65 77 20 63 68 61 72 5b 32  oks = new char[2
49d0: 5d 20 7b 20 27 5c 22 27 2c 20 73 65 70 61 72 61  ] { '\"', separa
49e0: 74 6f 72 20 7d 3b 0d 0a 20 20 20 20 20 20 63 68  tor };..      ch
49f0: 61 72 5b 5d 20 71 75 6f 74 20 3d 20 6e 65 77 20  ar[] quot = new 
4a00: 63 68 61 72 5b 31 5d 20 7b 20 27 5c 22 27 20 7d  char[1] { '\"' }
4a10: 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  ;..      int n =
4a20: 20 30 3b 0d 0a 20 20 20 20 20 20 4c 69 73 74 3c   0;..      List<
4a30: 73 74 72 69 6e 67 3e 20 6c 73 20 3d 20 6e 65 77  string> ls = new
4a40: 20 4c 69 73 74 3c 73 74 72 69 6e 67 3e 28 29 3b   List<string>();
4a50: 0d 0a 20 20 20 20 20 20 73 74 72 69 6e 67 20 73  ..      string s
4a60: 3b 0d 0a 0d 0a 20 20 20 20 20 20 77 68 69 6c 65  ;....      while
4a70: 20 28 73 6f 75 72 63 65 2e 4c 65 6e 67 74 68 20   (source.Length 
4a80: 3e 20 30 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20  > 0)..      {.. 
4a90: 20 20 20 20 20 20 20 6e 20 3d 20 73 6f 75 72 63         n = sourc
4aa0: 65 2e 49 6e 64 65 78 4f 66 41 6e 79 28 74 6f 6b  e.IndexOfAny(tok
4ab0: 73 2c 20 6e 29 3b 0d 0a 20 20 20 20 20 20 20 20  s, n);..        
4ac0: 69 66 20 28 6e 20 3d 3d 20 2d 31 29 20 62 72 65  if (n == -1) bre
4ad0: 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ak;..        if 
4ae0: 28 73 6f 75 72 63 65 5b 6e 5d 20 3d 3d 20 74 6f  (source[n] == to
4af0: 6b 73 5b 30 5d 29 0d 0a 20 20 20 20 20 20 20 20  ks[0])..        
4b00: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 73  {..          //s
4b10: 6f 75 72 63 65 20 3d 20 73 6f 75 72 63 65 2e 52  ource = source.R
4b20: 65 6d 6f 76 65 28 6e 2c 20 31 29 3b 0d 0a 20 20  emove(n, 1);..  
4b30: 20 20 20 20 20 20 20 20 6e 20 3d 20 73 6f 75 72          n = sour
4b40: 63 65 2e 49 6e 64 65 78 4f 66 41 6e 79 28 71 75  ce.IndexOfAny(qu
4b50: 6f 74 2c 20 6e 20 2b 20 31 29 3b 0d 0a 20 20 20  ot, n + 1);..   
4b60: 20 20 20 20 20 20 20 69 66 20 28 6e 20 3d 3d 20         if (n == 
4b70: 2d 31 29 0d 0a 20 20 20 20 20 20 20 20 20 20 7b  -1)..          {
4b80: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f  ..            //
4b90: 73 6f 75 72 63 65 20 3d 20 22 5c 22 22 20 2b 20  source = "\"" + 
4ba0: 73 6f 75 72 63 65 3b 0d 0a 20 20 20 20 20 20 20  source;..       
4bb0: 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20       break;..   
4bc0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
4bd0: 20 20 20 20 6e 2b 2b 3b 0d 0a 20 20 20 20 20 20      n++;..      
4be0: 20 20 20 20 2f 2f 73 6f 75 72 63 65 20 3d 20 73      //source = s
4bf0: 6f 75 72 63 65 2e 52 65 6d 6f 76 65 28 6e 2c 20  ource.Remove(n, 
4c00: 31 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a  1);..        }..
4c10: 20 20 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20          else..  
4c20: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
4c30: 20 20 20 73 20 3d 20 73 6f 75 72 63 65 2e 53 75     s = source.Su
4c40: 62 73 74 72 69 6e 67 28 30 2c 20 6e 29 2e 54 72  bstring(0, n).Tr
4c50: 69 6d 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20  im();..         
4c60: 20 69 66 20 28 73 2e 4c 65 6e 67 74 68 20 3e 20   if (s.Length > 
4c70: 31 20 26 26 20 73 5b 30 5d 20 3d 3d 20 71 75 6f  1 && s[0] == quo
4c80: 74 5b 30 5d 20 26 26 20 73 5b 73 2e 4c 65 6e 67  t[0] && s[s.Leng
4c90: 74 68 20 2d 20 31 5d 20 3d 3d 20 73 5b 30 5d 29  th - 1] == s[0])
4ca0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 73 20  ..            s 
4cb0: 3d 20 73 2e 53 75 62 73 74 72 69 6e 67 28 31 2c  = s.Substring(1,
4cc0: 20 73 2e 4c 65 6e 67 74 68 20 2d 20 32 29 3b 0d   s.Length - 2);.
4cd0: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 73 6f 75  ...          sou
4ce0: 72 63 65 20 3d 20 73 6f 75 72 63 65 2e 53 75 62  rce = source.Sub
4cf0: 73 74 72 69 6e 67 28 6e 20 2b 20 31 29 2e 54 72  string(n + 1).Tr
4d00: 69 6d 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20  im();..         
4d10: 20 69 66 20 28 73 2e 4c 65 6e 67 74 68 20 3e 20   if (s.Length > 
4d20: 30 29 20 6c 73 2e 41 64 64 28 73 29 3b 0d 0a 20  0) ls.Add(s);.. 
4d30: 20 20 20 20 20 20 20 20 20 6e 20 3d 20 30 3b 0d           n = 0;.
4d40: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
4d50: 20 20 7d 0d 0a 20 20 20 20 20 20 69 66 20 28 73    }..      if (s
4d60: 6f 75 72 63 65 2e 4c 65 6e 67 74 68 20 3e 20 30  ource.Length > 0
4d70: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  )..      {..    
4d80: 20 20 20 20 73 20 3d 20 73 6f 75 72 63 65 2e 54      s = source.T
4d90: 72 69 6d 28 29 3b 0d 0a 20 20 20 20 20 20 20 20  rim();..        
4da0: 69 66 20 28 73 2e 4c 65 6e 67 74 68 20 3e 20 31  if (s.Length > 1
4db0: 20 26 26 20 73 5b 30 5d 20 3d 3d 20 71 75 6f 74   && s[0] == quot
4dc0: 5b 30 5d 20 26 26 20 73 5b 73 2e 4c 65 6e 67 74  [0] && s[s.Lengt
4dd0: 68 20 2d 20 31 5d 20 3d 3d 20 73 5b 30 5d 29 0d  h - 1] == s[0]).
4de0: 0a 20 20 20 20 20 20 20 20 20 20 73 20 3d 20 73  .          s = s
4df0: 2e 53 75 62 73 74 72 69 6e 67 28 31 2c 20 73 2e  .Substring(1, s.
4e00: 4c 65 6e 67 74 68 20 2d 20 32 29 3b 0d 0a 20 20  Length - 2);..  
4e10: 20 20 20 20 20 20 6c 73 2e 41 64 64 28 73 29 3b        ls.Add(s);
4e20: 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  ..      }....   
4e30: 20 20 20 73 74 72 69 6e 67 5b 5d 20 61 72 20 3d     string[] ar =
4e40: 20 6e 65 77 20 73 74 72 69 6e 67 5b 6c 73 2e 43   new string[ls.C
4e50: 6f 75 6e 74 5d 3b 0d 0a 20 20 20 20 20 20 6c 73  ount];..      ls
4e60: 2e 43 6f 70 79 54 6f 28 61 72 2c 20 30 29 3b 0d  .CopyTo(ar, 0);.
4e70: 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ...      return 
4e80: 61 72 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  ar;..    }....  
4e90: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
4ea0: 0a 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65 72 74  .    /// Convert
4eb0: 20 61 20 76 61 6c 75 65 20 74 6f 20 74 72 75 65   a value to true
4ec0: 20 6f 72 20 66 61 6c 73 65 2e 0d 0a 20 20 20 20   or false...    
4ed0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
4ee0: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
4ef0: 61 6d 65 3d 22 73 6f 75 72 63 65 22 3e 41 20 73  ame="source">A s
4f00: 74 72 69 6e 67 20 6f 72 20 6e 75 6d 62 65 72 20  tring or number 
4f10: 72 65 70 72 65 73 65 6e 74 69 6e 67 20 74 72 75  representing tru
4f20: 65 20 6f 72 20 66 61 6c 73 65 3c 2f 70 61 72 61  e or false</para
4f30: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74  m>..    /// <ret
4f40: 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73 3e 0d  urns></returns>.
4f50: 0a 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74  .    public stat
4f60: 69 63 20 62 6f 6f 6c 20 54 6f 42 6f 6f 6c 65 61  ic bool ToBoolea
4f70: 6e 28 6f 62 6a 65 63 74 20 73 6f 75 72 63 65 29  n(object source)
4f80: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69  ..    {..      i
4f90: 66 20 28 73 6f 75 72 63 65 20 69 73 20 62 6f 6f  f (source is boo
4fa0: 6c 29 20 72 65 74 75 72 6e 20 28 62 6f 6f 6c 29  l) return (bool)
4fb0: 73 6f 75 72 63 65 3b 0d 0a 0d 0a 20 20 20 20 20  source;....     
4fc0: 20 72 65 74 75 72 6e 20 54 6f 42 6f 6f 6c 65 61   return ToBoolea
4fd0: 6e 28 73 6f 75 72 63 65 2e 54 6f 53 74 72 69 6e  n(source.ToStrin
4fe0: 67 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  g());..    }....
4ff0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
5000: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43 6f 6e 76 65  >..    /// Conve
5010: 72 74 20 61 20 73 74 72 69 6e 67 20 74 6f 20 74  rt a string to t
5020: 72 75 65 20 6f 72 20 66 61 6c 73 65 2e 0d 0a 20  rue or false... 
5030: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
5040: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
5050: 6d 20 6e 61 6d 65 3d 22 73 6f 75 72 63 65 22 3e  m name="source">
5060: 41 20 73 74 72 69 6e 67 20 72 65 70 72 65 73 65  A string represe
5070: 6e 74 69 6e 67 20 74 72 75 65 20 6f 72 20 66 61  nting true or fa
5080: 6c 73 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  lse</param>..   
5090: 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f   /// <returns></
50a0: 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 2f 2f  returns>..    //
50b0: 2f 20 3c 72 65 6d 61 72 6b 73 3e 0d 0a 20 20 20  / <remarks>..   
50c0: 20 2f 2f 2f 20 22 79 65 73 22 2c 20 22 6e 6f 22   /// "yes", "no"
50d0: 2c 20 22 79 22 2c 20 22 6e 22 2c 20 22 30 22 2c  , "y", "n", "0",
50e0: 20 22 31 22 2c 20 22 6f 6e 22 2c 20 22 6f 66 66   "1", "on", "off
50f0: 22 20 61 73 20 77 65 6c 6c 20 61 73 20 42 6f 6f  " as well as Boo
5100: 6c 65 61 6e 2e 46 61 6c 73 65 53 74 72 69 6e 67  lean.FalseString
5110: 20 61 6e 64 20 42 6f 6f 6c 65 61 6e 2e 54 72 75   and Boolean.Tru
5120: 65 53 74 72 69 6e 67 20 77 69 6c 6c 20 61 6c 6c  eString will all
5130: 20 62 65 0d 0a 20 20 20 20 2f 2f 2f 20 63 6f 6e   be..    /// con
5140: 76 65 72 74 65 64 20 74 6f 20 61 20 70 72 6f 70  verted to a prop
5150: 65 72 20 62 6f 6f 6c 65 61 6e 20 76 61 6c 75 65  er boolean value
5160: 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72 65 6d  ...    /// </rem
5170: 61 72 6b 73 3e 0d 0a 20 20 20 20 70 75 62 6c 69  arks>..    publi
5180: 63 20 73 74 61 74 69 63 20 62 6f 6f 6c 20 54 6f  c static bool To
5190: 42 6f 6f 6c 65 61 6e 28 73 74 72 69 6e 67 20 73  Boolean(string s
51a0: 6f 75 72 63 65 29 0d 0a 20 20 20 20 7b 0d 0a 20  ource)..    {.. 
51b0: 20 20 20 20 20 69 66 20 28 53 74 72 69 6e 67 2e       if (String.
51c0: 43 6f 6d 70 61 72 65 28 73 6f 75 72 63 65 2c 20  Compare(source, 
51d0: 62 6f 6f 6c 2e 54 72 75 65 53 74 72 69 6e 67 2c  bool.TrueString,
51e0: 20 53 74 72 69 6e 67 43 6f 6d 70 61 72 69 73 6f   StringCompariso
51f0: 6e 2e 4f 72 64 69 6e 61 6c 49 67 6e 6f 72 65 43  n.OrdinalIgnoreC
5200: 61 73 65 29 20 3d 3d 20 30 29 20 72 65 74 75 72  ase) == 0) retur
5210: 6e 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 65  n true;..      e
5220: 6c 73 65 20 69 66 20 28 53 74 72 69 6e 67 2e 43  lse if (String.C
5230: 6f 6d 70 61 72 65 28 73 6f 75 72 63 65 2c 20 62  ompare(source, b
5240: 6f 6f 6c 2e 46 61 6c 73 65 53 74 72 69 6e 67 2c  ool.FalseString,
5250: 20 53 74 72 69 6e 67 43 6f 6d 70 61 72 69 73 6f   StringCompariso
5260: 6e 2e 4f 72 64 69 6e 61 6c 49 67 6e 6f 72 65 43  n.OrdinalIgnoreC
5270: 61 73 65 29 20 3d 3d 20 30 29 20 72 65 74 75 72  ase) == 0) retur
5280: 6e 20 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 20  n false;....    
5290: 20 20 73 77 69 74 63 68 28 73 6f 75 72 63 65 2e    switch(source.
52a0: 54 6f 4c 6f 77 65 72 28 43 75 6c 74 75 72 65 49  ToLower(CultureI
52b0: 6e 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c  nfo.InvariantCul
52c0: 74 75 72 65 29 29 0d 0a 20 20 20 20 20 20 7b 0d  ture))..      {.
52d0: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 22 79  .        case "y
52e0: 65 73 22 3a 0d 0a 20 20 20 20 20 20 20 20 63 61  es":..        ca
52f0: 73 65 20 22 79 22 3a 0d 0a 20 20 20 20 20 20 20  se "y":..       
5300: 20 63 61 73 65 20 22 31 22 3a 0d 0a 20 20 20 20   case "1":..    
5310: 20 20 20 20 63 61 73 65 20 22 6f 6e 22 3a 0d 0a      case "on":..
5320: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
5330: 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20 20   true;..        
5340: 63 61 73 65 20 22 6e 6f 22 3a 0d 0a 20 20 20 20  case "no":..    
5350: 20 20 20 20 63 61 73 65 20 22 6e 22 3a 0d 0a 20      case "n":.. 
5360: 20 20 20 20 20 20 20 63 61 73 65 20 22 30 22 3a         case "0":
5370: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 22  ..        case "
5380: 6f 66 66 22 3a 0d 0a 20 20 20 20 20 20 20 20 20  off":..         
5390: 20 72 65 74 75 72 6e 20 66 61 6c 73 65 3b 0d 0a   return false;..
53a0: 20 20 20 20 20 20 20 20 64 65 66 61 75 6c 74 3a          default:
53b0: 0d 0a 20 20 20 20 20 20 20 20 20 20 74 68 72 6f  ..          thro
53c0: 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 45 78  w new ArgumentEx
53d0: 63 65 70 74 69 6f 6e 28 22 73 6f 75 72 63 65 22  ception("source"
53e0: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  );..      }..   
53f0: 20 7d 0d 0a 0d 0a 20 20 20 20 23 72 65 67 69 6f   }....    #regio
5400: 6e 20 54 79 70 65 20 43 6f 6e 76 65 72 73 69 6f  n Type Conversio
5410: 6e 73 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d  ns..    /// <sum
5420: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 44  mary>..    /// D
5430: 65 74 65 72 6d 69 6e 65 73 20 74 68 65 20 64 61  etermines the da
5440: 74 61 20 74 79 70 65 20 6f 66 20 61 20 63 6f 6c  ta type of a col
5450: 75 6d 6e 20 69 6e 20 61 20 73 74 61 74 65 6d 65  umn in a stateme
5460: 6e 74 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  nt..    /// </su
5470: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
5480: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 73 74 6d  <param name="stm
5490: 74 22 3e 54 68 65 20 73 74 61 74 65 6d 65 6e 74  t">The statement
54a0: 20 74 6f 20 72 65 74 72 69 65 76 65 20 69 6e 66   to retrieve inf
54b0: 6f 72 6d 61 74 69 6f 6e 20 66 6f 72 3c 2f 70 61  ormation for</pa
54c0: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ram>..    /// <p
54d0: 61 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54 68  aram name="i">Th
54e0: 65 20 63 6f 6c 75 6d 6e 20 74 6f 20 72 65 74 72  e column to retr
54f0: 69 65 76 65 20 74 79 70 65 20 69 6e 66 6f 72 6d  ieve type inform
5500: 61 74 69 6f 6e 20 6f 6e 3c 2f 70 61 72 61 6d 3e  ation on</param>
5510: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  ..    /// <param
5520: 20 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68 65 20   name="typ">The 
5530: 53 51 4c 69 74 65 54 79 70 65 20 74 6f 20 72 65  SQLiteType to re
5540: 63 65 69 76 65 20 74 68 65 20 61 66 66 69 6e 69  ceive the affini
5550: 74 79 20 66 6f 72 20 74 68 65 20 67 69 76 65 6e  ty for the given
5560: 20 63 6f 6c 75 6d 6e 3c 2f 70 61 72 61 6d 3e 0d   column</param>.
5570: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
5580: 61 74 69 63 20 76 6f 69 64 20 43 6f 6c 75 6d 6e  atic void Column
5590: 54 6f 54 79 70 65 28 53 51 4c 69 74 65 53 74 61  ToType(SQLiteSta
55a0: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
55b0: 20 69 2c 20 53 51 4c 69 74 65 54 79 70 65 20 74   i, SQLiteType t
55c0: 79 70 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  yp)..    {..    
55d0: 20 20 74 79 70 2e 54 79 70 65 20 3d 20 54 79 70    typ.Type = Typ
55e0: 65 4e 61 6d 65 54 6f 44 62 54 79 70 65 28 73 74  eNameToDbType(st
55f0: 6d 74 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e 54 79  mt._sql.ColumnTy
5600: 70 65 28 73 74 6d 74 2c 20 69 2c 20 6f 75 74 20  pe(stmt, i, out 
5610: 74 79 70 2e 41 66 66 69 6e 69 74 79 29 29 3b 0d  typ.Affinity));.
5620: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
5630: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
5640: 20 2f 2f 2f 20 43 6f 6e 76 65 72 74 73 20 61 20   /// Converts a 
5650: 53 51 4c 69 74 65 54 79 70 65 20 74 6f 20 61 20  SQLiteType to a 
5660: 2e 4e 45 54 20 54 79 70 65 20 6f 62 6a 65 63 74  .NET Type object
5670: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
5680: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ary>..    /// <p
5690: 61 72 61 6d 20 6e 61 6d 65 3d 22 74 22 3e 54 68  aram name="t">Th
56a0: 65 20 53 51 4c 69 74 65 54 79 70 65 20 74 6f 20  e SQLiteType to 
56b0: 63 6f 6e 76 65 72 74 3c 2f 70 61 72 61 6d 3e 0d  convert</param>.
56c0: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
56d0: 73 3e 52 65 74 75 72 6e 73 20 61 20 2e 4e 45 54  s>Returns a .NET
56e0: 20 54 79 70 65 20 6f 62 6a 65 63 74 3c 2f 72 65   Type object</re
56f0: 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65  turns>..    inte
5700: 72 6e 61 6c 20 73 74 61 74 69 63 20 54 79 70 65  rnal static Type
5710: 20 53 51 4c 69 74 65 54 79 70 65 54 6f 54 79 70   SQLiteTypeToTyp
5720: 65 28 53 51 4c 69 74 65 54 79 70 65 20 74 29 0d  e(SQLiteType t).
5730: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69 66  .    {..      if
5740: 20 28 74 2e 54 79 70 65 20 3d 3d 20 44 62 54 79   (t.Type == DbTy
5750: 70 65 2e 4f 62 6a 65 63 74 29 0d 0a 20 20 20 20  pe.Object)..    
5760: 20 20 20 20 72 65 74 75 72 6e 20 5f 61 66 66 69      return _affi
5770: 6e 69 74 79 74 6f 74 79 70 65 5b 28 69 6e 74 29  nitytotype[(int)
5780: 74 2e 41 66 66 69 6e 69 74 79 5d 3b 0d 0a 20 20  t.Affinity];..  
5790: 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20      else..      
57a0: 20 20 72 65 74 75 72 6e 20 53 51 4c 69 74 65 43    return SQLiteC
57b0: 6f 6e 76 65 72 74 2e 44 62 54 79 70 65 54 6f 54  onvert.DbTypeToT
57c0: 79 70 65 28 74 2e 54 79 70 65 29 3b 0d 0a 20 20  ype(t.Type);..  
57d0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69 76 61    }....    priva
57e0: 74 65 20 73 74 61 74 69 63 20 54 79 70 65 5b 5d  te static Type[]
57f0: 20 5f 61 66 66 69 6e 69 74 79 74 6f 74 79 70 65   _affinitytotype
5800: 20 3d 20 7b 0d 0a 20 20 20 20 20 20 74 79 70 65   = {..      type
5810: 6f 66 28 6f 62 6a 65 63 74 29 2c 0d 0a 20 20 20  of(object),..   
5820: 20 20 20 74 79 70 65 6f 66 28 49 6e 74 36 34 29     typeof(Int64)
5830: 2c 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  ,..      typeof(
5840: 44 6f 75 62 6c 65 29 2c 0d 0a 20 20 20 20 20 20  Double),..      
5850: 74 79 70 65 6f 66 28 73 74 72 69 6e 67 29 2c 0d  typeof(string),.
5860: 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 62 79  .      typeof(by
5870: 74 65 5b 5d 29 2c 0d 0a 20 20 20 20 20 20 74 79  te[]),..      ty
5880: 70 65 6f 66 28 6f 62 6a 65 63 74 29 2c 0d 0a 20  peof(object),.. 
5890: 20 20 20 20 20 74 79 70 65 6f 66 28 44 61 74 65       typeof(Date
58a0: 54 69 6d 65 29 2c 0d 0a 20 20 20 20 20 20 74 79  Time),..      ty
58b0: 70 65 6f 66 28 6f 62 6a 65 63 74 29 0d 0a 20 20  peof(object)..  
58c0: 20 20 7d 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20    };....    /// 
58d0: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
58e0: 2f 2f 20 46 6f 72 20 61 20 67 69 76 65 6e 20 69  // For a given i
58f0: 6e 74 72 69 6e 73 69 63 20 74 79 70 65 2c 20 72  ntrinsic type, r
5900: 65 74 75 72 6e 20 61 20 44 62 54 79 70 65 0d 0a  eturn a DbType..
5910: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
5920: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  y>..    /// <par
5930: 61 6d 20 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68  am name="typ">Th
5940: 65 20 6e 61 74 69 76 65 20 74 79 70 65 20 74 6f  e native type to
5950: 20 63 6f 6e 76 65 72 74 3c 2f 70 61 72 61 6d 3e   convert</param>
5960: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  ..    /// <retur
5970: 6e 73 3e 54 68 65 20 63 6f 72 72 65 73 70 6f 6e  ns>The correspon
5980: 64 69 6e 67 20 28 63 6c 6f 73 65 73 74 20 6d 61  ding (closest ma
5990: 74 63 68 29 20 44 62 54 79 70 65 3c 2f 72 65 74  tch) DbType</ret
59a0: 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72  urns>..    inter
59b0: 6e 61 6c 20 73 74 61 74 69 63 20 44 62 54 79 70  nal static DbTyp
59c0: 65 20 54 79 70 65 54 6f 44 62 54 79 70 65 28 54  e TypeToDbType(T
59d0: 79 70 65 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d  ype typ)..    {.
59e0: 0a 20 20 20 20 20 20 54 79 70 65 43 6f 64 65 20  .      TypeCode 
59f0: 74 63 20 3d 20 54 79 70 65 2e 47 65 74 54 79 70  tc = Type.GetTyp
5a00: 65 43 6f 64 65 28 74 79 70 29 3b 0d 0a 20 20 20  eCode(typ);..   
5a10: 20 20 20 69 66 20 28 74 63 20 3d 3d 20 54 79 70     if (tc == Typ
5a20: 65 43 6f 64 65 2e 4f 62 6a 65 63 74 29 0d 0a 20  eCode.Object).. 
5a30: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
5a40: 69 66 20 28 74 79 70 20 3d 3d 20 74 79 70 65 6f  if (typ == typeo
5a50: 66 28 62 79 74 65 5b 5d 29 29 20 72 65 74 75 72  f(byte[])) retur
5a60: 6e 20 44 62 54 79 70 65 2e 42 69 6e 61 72 79 3b  n DbType.Binary;
5a70: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 74 79  ..        if (ty
5a80: 70 20 3d 3d 20 74 79 70 65 6f 66 28 47 75 69 64  p == typeof(Guid
5a90: 29 29 20 72 65 74 75 72 6e 20 44 62 54 79 70 65  )) return DbType
5aa0: 2e 47 75 69 64 3b 0d 0a 20 20 20 20 20 20 20 20  .Guid;..        
5ab0: 72 65 74 75 72 6e 20 44 62 54 79 70 65 2e 53 74  return DbType.St
5ac0: 72 69 6e 67 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a  ring;..      }..
5ad0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 74 79        return _ty
5ae0: 70 65 74 6f 64 62 74 79 70 65 5b 28 69 6e 74 29  petodbtype[(int)
5af0: 74 63 5d 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  tc];..    }.... 
5b00: 20 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69     private stati
5b10: 63 20 44 62 54 79 70 65 5b 5d 20 5f 74 79 70 65  c DbType[] _type
5b20: 74 6f 64 62 74 79 70 65 20 3d 20 7b 0d 0a 20 20  todbtype = {..  
5b30: 20 20 20 20 44 62 54 79 70 65 2e 4f 62 6a 65 63      DbType.Objec
5b40: 74 2c 0d 0a 20 20 20 20 20 20 44 62 54 79 70 65  t,..      DbType
5b50: 2e 42 69 6e 61 72 79 2c 0d 0a 20 20 20 20 20 20  .Binary,..      
5b60: 44 62 54 79 70 65 2e 4f 62 6a 65 63 74 2c 0d 0a  DbType.Object,..
5b70: 20 20 20 20 20 20 44 62 54 79 70 65 2e 42 6f 6f        DbType.Boo
5b80: 6c 65 61 6e 2c 0d 0a 20 20 20 20 20 20 44 62 54  lean,..      DbT
5b90: 79 70 65 2e 53 42 79 74 65 2c 0d 0a 20 20 20 20  ype.SByte,..    
5ba0: 20 20 44 62 54 79 70 65 2e 53 42 79 74 65 2c 0d    DbType.SByte,.
5bb0: 0a 20 20 20 20 20 20 44 62 54 79 70 65 2e 42 79  .      DbType.By
5bc0: 74 65 2c 0d 0a 20 20 20 20 20 20 44 62 54 79 70  te,..      DbTyp
5bd0: 65 2e 49 6e 74 31 36 2c 20 2f 2f 20 37 0d 0a 20  e.Int16, // 7.. 
5be0: 20 20 20 20 20 44 62 54 79 70 65 2e 55 49 6e 74       DbType.UInt
5bf0: 31 36 2c 0d 0a 20 20 20 20 20 20 44 62 54 79 70  16,..      DbTyp
5c00: 65 2e 49 6e 74 33 32 2c 0d 0a 20 20 20 20 20 20  e.Int32,..      
5c10: 44 62 54 79 70 65 2e 55 49 6e 74 33 32 2c 0d 0a  DbType.UInt32,..
5c20: 20 20 20 20 20 20 44 62 54 79 70 65 2e 49 6e 74        DbType.Int
5c30: 36 34 2c 20 2f 2f 20 31 31 0d 0a 20 20 20 20 20  64, // 11..     
5c40: 20 44 62 54 79 70 65 2e 55 49 6e 74 36 34 2c 0d   DbType.UInt64,.
5c50: 0a 20 20 20 20 20 20 44 62 54 79 70 65 2e 53 69  .      DbType.Si
5c60: 6e 67 6c 65 2c 0d 0a 20 20 20 20 20 20 44 62 54  ngle,..      DbT
5c70: 79 70 65 2e 44 6f 75 62 6c 65 2c 0d 0a 20 20 20  ype.Double,..   
5c80: 20 20 20 44 62 54 79 70 65 2e 44 65 63 69 6d 61     DbType.Decima
5c90: 6c 2c 0d 0a 20 20 20 20 20 20 44 62 54 79 70 65  l,..      DbType
5ca0: 2e 44 61 74 65 54 69 6d 65 2c 0d 0a 20 20 20 20  .DateTime,..    
5cb0: 20 20 44 62 54 79 70 65 2e 4f 62 6a 65 63 74 2c    DbType.Object,
5cc0: 0d 0a 20 20 20 20 20 20 44 62 54 79 70 65 2e 53  ..      DbType.S
5cd0: 74 72 69 6e 67 2c 0d 0a 20 20 20 20 7d 3b 0d 0a  tring,..    };..
5ce0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
5cf0: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 52 65 74  ry>..    /// Ret
5d00: 75 72 6e 73 20 74 68 65 20 43 6f 6c 75 6d 6e 53  urns the ColumnS
5d10: 69 7a 65 20 66 6f 72 20 74 68 65 20 67 69 76 65  ize for the give
5d20: 6e 20 44 62 54 79 70 65 0d 0a 20 20 20 20 2f 2f  n DbType..    //
5d30: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
5d40: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
5d50: 65 3d 22 74 79 70 22 3e 54 68 65 20 44 62 54 79  e="typ">The DbTy
5d60: 70 65 20 74 6f 20 67 65 74 20 74 68 65 20 73 69  pe to get the si
5d70: 7a 65 20 6f 66 3c 2f 70 61 72 61 6d 3e 0d 0a 20  ze of</param>.. 
5d80: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
5d90: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
5da0: 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69 63 20  internal static 
5db0: 69 6e 74 20 44 62 54 79 70 65 54 6f 43 6f 6c 75  int DbTypeToColu
5dc0: 6d 6e 53 69 7a 65 28 44 62 54 79 70 65 20 74 79  mnSize(DbType ty
5dd0: 70 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  p)..    {..     
5de0: 20 72 65 74 75 72 6e 20 5f 64 62 74 79 70 65 74   return _dbtypet
5df0: 6f 63 6f 6c 75 6d 6e 73 69 7a 65 5b 28 69 6e 74  ocolumnsize[(int
5e00: 29 74 79 70 5d 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  )typ];..    }...
5e10: 0a 20 20 20 20 70 72 69 76 61 74 65 20 73 74 61  .    private sta
5e20: 74 69 63 20 69 6e 74 5b 5d 20 5f 64 62 74 79 70  tic int[] _dbtyp
5e30: 65 74 6f 63 6f 6c 75 6d 6e 73 69 7a 65 20 3d 20  etocolumnsize = 
5e40: 7b 0d 0a 20 20 20 20 20 20 32 31 34 37 34 38 33  {..      2147483
5e50: 36 34 37 2c 20 20 20 2f 2f 20 30 0d 0a 20 20 20  647,   // 0..   
5e60: 20 20 20 32 31 34 37 34 38 33 36 34 37 2c 20 20     2147483647,  
5e70: 20 2f 2f 20 31 0d 0a 20 20 20 20 20 20 31 2c 20   // 1..      1, 
5e80: 20 20 20 20 2f 2f 20 32 0d 0a 20 20 20 20 20 20      // 2..      
5e90: 31 2c 20 20 20 20 20 2f 2f 20 33 0d 0a 20 20 20  1,     // 3..   
5ea0: 20 20 20 38 2c 20 20 2f 2f 20 34 0d 0a 20 20 20     8,  // 4..   
5eb0: 20 20 20 38 2c 20 2f 2f 20 35 0d 0a 20 20 20 20     8, // 5..    
5ec0: 20 20 38 2c 20 2f 2f 20 36 0d 0a 20 20 20 20 20    8, // 6..     
5ed0: 20 38 2c 20 20 2f 2f 20 37 0d 0a 20 20 20 20 20   8,  // 7..     
5ee0: 20 38 2c 20 20 20 2f 2f 20 38 0d 0a 20 20 20 20   8,   // 8..    
5ef0: 20 20 31 36 2c 20 20 20 20 20 2f 2f 20 39 0d 0a    16,     // 9..
5f00: 20 20 20 20 20 20 32 2c 0d 0a 20 20 20 20 20 20        2,..      
5f10: 34 2c 0d 0a 20 20 20 20 20 20 38 2c 0d 0a 20 20  4,..      8,..  
5f20: 20 20 20 20 32 31 34 37 34 38 33 36 34 37 2c 0d      2147483647,.
5f30: 0a 20 20 20 20 20 20 31 2c 0d 0a 20 20 20 20 20  .      1,..     
5f40: 20 34 2c 0d 0a 20 20 20 20 20 20 32 31 34 37 34   4,..      21474
5f50: 38 33 36 34 37 2c 0d 0a 20 20 20 20 20 20 38 2c  83647,..      8,
5f60: 0d 0a 20 20 20 20 20 20 32 2c 0d 0a 20 20 20 20  ..      2,..    
5f70: 20 20 34 2c 0d 0a 20 20 20 20 20 20 38 2c 0d 0a    4,..      8,..
5f80: 20 20 20 20 20 20 38 2c 0d 0a 20 20 20 20 20 20        8,..      
5f90: 32 31 34 37 34 38 33 36 34 37 2c 0d 0a 20 20 20  2147483647,..   
5fa0: 20 20 20 32 31 34 37 34 38 33 36 34 37 2c 0d 0a     2147483647,..
5fb0: 20 20 20 20 20 20 32 31 34 37 34 38 33 36 34 37        2147483647
5fc0: 2c 0d 0a 20 20 20 20 20 20 32 31 34 37 34 38 33  ,..      2147483
5fd0: 36 34 37 2c 20 20 20 2f 2f 20 32 35 20 28 58 6d  647,   // 25 (Xm
5fe0: 6c 29 0d 0a 20 20 20 20 7d 3b 0d 0a 0d 0a 20 20  l)..    };....  
5ff0: 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69    internal stati
6000: 63 20 6f 62 6a 65 63 74 20 44 62 54 79 70 65 54  c object DbTypeT
6010: 6f 4e 75 6d 65 72 69 63 50 72 65 63 69 73 69 6f  oNumericPrecisio
6020: 6e 28 44 62 54 79 70 65 20 74 79 70 29 0d 0a 20  n(DbType typ).. 
6030: 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75     {..      retu
6040: 72 6e 20 5f 64 62 74 79 70 65 74 6f 6e 75 6d 65  rn _dbtypetonume
6050: 72 69 63 70 72 65 63 69 73 69 6f 6e 5b 28 69 6e  ricprecision[(in
6060: 74 29 74 79 70 5d 3b 0d 0a 20 20 20 20 7d 0d 0a  t)typ];..    }..
6070: 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20 73 74  ..    private st
6080: 61 74 69 63 20 6f 62 6a 65 63 74 5b 5d 20 5f 64  atic object[] _d
6090: 62 74 79 70 65 74 6f 6e 75 6d 65 72 69 63 70 72  btypetonumericpr
60a0: 65 63 69 73 69 6f 6e 20 3d 20 7b 0d 0a 20 20 20  ecision = {..   
60b0: 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c     DBNull.Value,
60c0: 20 2f 2f 20 30 0d 0a 20 20 20 20 20 20 44 42 4e   // 0..      DBN
60d0: 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 31 0d  ull.Value, // 1.
60e0: 0a 20 20 20 20 20 20 33 2c 0d 0a 20 20 20 20 20  .      3,..     
60f0: 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 0d 0a   DBNull.Value,..
6100: 20 20 20 20 20 20 31 39 2c 0d 0a 20 20 20 20 20        19,..     
6110: 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f   DBNull.Value, /
6120: 2f 20 35 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c  / 5..      DBNul
6130: 6c 2e 56 61 6c 75 65 2c 20 2f 2f 20 36 0d 0a 20  l.Value, // 6.. 
6140: 20 20 20 20 20 35 33 2c 0d 0a 20 20 20 20 20 20       53,..      
6150: 35 33 2c 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c  53,..      DBNul
6160: 6c 2e 56 61 6c 75 65 2c 0d 0a 20 20 20 20 20 20  l.Value,..      
6170: 35 2c 0d 0a 20 20 20 20 20 20 31 30 2c 0d 0a 20  5,..      10,.. 
6180: 20 20 20 20 20 31 39 2c 0d 0a 20 20 20 20 20 20       19,..      
6190: 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 0d 0a 20  DBNull.Value,.. 
61a0: 20 20 20 20 20 33 2c 0d 0a 20 20 20 20 20 20 32       3,..      2
61b0: 34 2c 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c  4,..      DBNull
61c0: 2e 56 61 6c 75 65 2c 0d 0a 20 20 20 20 20 20 44  .Value,..      D
61d0: 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 0d 0a 20 20  BNull.Value,..  
61e0: 20 20 20 20 35 2c 0d 0a 20 20 20 20 20 20 31 30      5,..      10
61f0: 2c 0d 0a 20 20 20 20 20 20 31 39 2c 0d 0a 20 20  ,..      19,..  
6200: 20 20 20 20 35 33 2c 0d 0a 20 20 20 20 20 20 44      53,..      D
6210: 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 0d 0a 20 20  BNull.Value,..  
6220: 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65      DBNull.Value
6230: 2c 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c 2e  ,..      DBNull.
6240: 56 61 6c 75 65 0d 0a 20 20 20 20 7d 3b 0d 0a 0d  Value..    };...
6250: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
6260: 61 74 69 63 20 6f 62 6a 65 63 74 20 44 62 54 79  atic object DbTy
6270: 70 65 54 6f 4e 75 6d 65 72 69 63 53 63 61 6c 65  peToNumericScale
6280: 28 44 62 54 79 70 65 20 74 79 70 29 0d 0a 20 20  (DbType typ)..  
6290: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72    {..      retur
62a0: 6e 20 5f 64 62 74 79 70 65 74 6f 6e 75 6d 65 72  n _dbtypetonumer
62b0: 69 63 73 63 61 6c 65 5b 28 69 6e 74 29 74 79 70  icscale[(int)typ
62c0: 5d 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  ];..    }....   
62d0: 20 70 72 69 76 61 74 65 20 73 74 61 74 69 63 20   private static 
62e0: 6f 62 6a 65 63 74 5b 5d 20 5f 64 62 74 79 70 65  object[] _dbtype
62f0: 74 6f 6e 75 6d 65 72 69 63 73 63 61 6c 65 20 3d  tonumericscale =
6300: 20 7b 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c   {..      DBNull
6310: 2e 56 61 6c 75 65 2c 20 2f 2f 20 30 0d 0a 20 20  .Value, // 0..  
6320: 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65      DBNull.Value
6330: 2c 20 2f 2f 20 31 0d 0a 20 20 20 20 20 20 30 2c  , // 1..      0,
6340: 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56  ..      DBNull.V
6350: 61 6c 75 65 2c 0d 0a 20 20 20 20 20 20 34 2c 0d  alue,..      4,.
6360: 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61  .      DBNull.Va
6370: 6c 75 65 2c 20 2f 2f 20 35 0d 0a 20 20 20 20 20  lue, // 5..     
6380: 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 20 2f   DBNull.Value, /
6390: 2f 20 36 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c  / 6..      DBNul
63a0: 6c 2e 56 61 6c 75 65 2c 0d 0a 20 20 20 20 20 20  l.Value,..      
63b0: 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 0d 0a 20  DBNull.Value,.. 
63c0: 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75       DBNull.Valu
63d0: 65 2c 0d 0a 20 20 20 20 20 20 30 2c 0d 0a 20 20  e,..      0,..  
63e0: 20 20 20 20 30 2c 0d 0a 20 20 20 20 20 20 30 2c      0,..      0,
63f0: 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56  ..      DBNull.V
6400: 61 6c 75 65 2c 0d 0a 20 20 20 20 20 20 30 2c 0d  alue,..      0,.
6410: 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56 61  .      DBNull.Va
6420: 6c 75 65 2c 0d 0a 20 20 20 20 20 20 44 42 4e 75  lue,..      DBNu
6430: 6c 6c 2e 56 61 6c 75 65 2c 0d 0a 20 20 20 20 20  ll.Value,..     
6440: 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c 0d 0a   DBNull.Value,..
6450: 20 20 20 20 20 20 30 2c 0d 0a 20 20 20 20 20 20        0,..      
6460: 30 2c 0d 0a 20 20 20 20 20 20 30 2c 0d 0a 20 20  0,..      0,..  
6470: 20 20 20 20 30 2c 0d 0a 20 20 20 20 20 20 44 42      0,..      DB
6480: 4e 75 6c 6c 2e 56 61 6c 75 65 2c 0d 0a 20 20 20  Null.Value,..   
6490: 20 20 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 2c     DBNull.Value,
64a0: 0d 0a 20 20 20 20 20 20 44 42 4e 75 6c 6c 2e 56  ..      DBNull.V
64b0: 61 6c 75 65 0d 0a 20 20 20 20 7d 3b 0d 0a 0d 0a  alue..    };....
64c0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61      internal sta
64d0: 74 69 63 20 73 74 72 69 6e 67 20 44 62 54 79 70  tic string DbTyp
64e0: 65 54 6f 54 79 70 65 4e 61 6d 65 28 44 62 54 79  eToTypeName(DbTy
64f0: 70 65 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d 0a  pe typ)..    {..
6500: 20 20 20 20 20 20 66 6f 72 20 28 69 6e 74 20 6e        for (int n
6510: 20 3d 20 30 3b 20 6e 20 3c 20 5f 64 62 74 79 70   = 0; n < _dbtyp
6520: 65 4e 61 6d 65 73 2e 4c 65 6e 67 74 68 3b 20 6e  eNames.Length; n
6530: 2b 2b 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20  ++)..      {..  
6540: 20 20 20 20 20 20 69 66 20 28 5f 64 62 74 79 70        if (_dbtyp
6550: 65 4e 61 6d 65 73 5b 6e 5d 2e 64 61 74 61 54 79  eNames[n].dataTy
6560: 70 65 20 3d 3d 20 74 79 70 29 0d 0a 20 20 20 20  pe == typ)..    
6570: 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 64 62        return _db
6580: 74 79 70 65 4e 61 6d 65 73 5b 6e 5d 2e 74 79 70  typeNames[n].typ
6590: 65 4e 61 6d 65 3b 0d 0a 20 20 20 20 20 20 7d 0d  eName;..      }.
65a0: 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ...      return 
65b0: 53 74 72 69 6e 67 2e 45 6d 70 74 79 3b 0d 0a 20  String.Empty;.. 
65c0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69 76     }....    priv
65d0: 61 74 65 20 73 74 61 74 69 63 20 53 51 4c 69 74  ate static SQLit
65e0: 65 54 79 70 65 4e 61 6d 65 73 5b 5d 20 5f 64 62  eTypeNames[] _db
65f0: 74 79 70 65 4e 61 6d 65 73 20 3d 20 7b 0d 0a 20  typeNames = {.. 
6600: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54       new SQLiteT
6610: 79 70 65 4e 61 6d 65 73 28 22 49 4e 54 45 47 45  ypeNames("INTEGE
6620: 52 22 2c 20 44 62 54 79 70 65 2e 49 6e 74 36 34  R", DbType.Int64
6630: 29 2c 0d 0a 20 20 20 20 20 20 6e 65 77 20 53 51  ),..      new SQ
6640: 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22 54  LiteTypeNames("T
6650: 49 4e 59 49 4e 54 22 2c 20 44 62 54 79 70 65 2e  INYINT", DbType.
6660: 42 79 74 65 29 2c 0d 0a 20 20 20 20 20 20 6e 65  Byte),..      ne
6670: 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65  w SQLiteTypeName
6680: 73 28 22 49 4e 54 22 2c 20 44 62 54 79 70 65 2e  s("INT", DbType.
6690: 49 6e 74 33 32 29 2c 0d 0a 20 20 20 20 20 20 6e  Int32),..      n
66a0: 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d  ew SQLiteTypeNam
66b0: 65 73 28 22 56 41 52 43 48 41 52 22 2c 20 44 62  es("VARCHAR", Db
66c0: 54 79 70 65 2e 41 6e 73 69 53 74 72 69 6e 67 29  Type.AnsiString)
66d0: 2c 0d 0a 20 20 20 20 20 20 6e 65 77 20 53 51 4c  ,..      new SQL
66e0: 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22 4e 56  iteTypeNames("NV
66f0: 41 52 43 48 41 52 22 2c 20 44 62 54 79 70 65 2e  ARCHAR", DbType.
6700: 53 74 72 69 6e 67 29 2c 0d 0a 20 20 20 20 20 20  String),..      
6710: 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61  new SQLiteTypeNa
6720: 6d 65 73 28 22 43 48 41 52 22 2c 20 44 62 54 79  mes("CHAR", DbTy
6730: 70 65 2e 41 6e 73 69 53 74 72 69 6e 67 46 69 78  pe.AnsiStringFix
6740: 65 64 4c 65 6e 67 74 68 29 2c 0d 0a 20 20 20 20  edLength),..    
6750: 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65    new SQLiteType
6760: 4e 61 6d 65 73 28 22 4e 43 48 41 52 22 2c 20 44  Names("NCHAR", D
6770: 62 54 79 70 65 2e 53 74 72 69 6e 67 46 69 78 65  bType.StringFixe
6780: 64 4c 65 6e 67 74 68 29 2c 0d 0a 20 20 20 20 20  dLength),..     
6790: 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e   new SQLiteTypeN
67a0: 61 6d 65 73 28 22 46 4c 4f 41 54 22 2c 20 44 62  ames("FLOAT", Db
67b0: 54 79 70 65 2e 44 6f 75 62 6c 65 29 2c 0d 0a 20  Type.Double),.. 
67c0: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54       new SQLiteT
67d0: 79 70 65 4e 61 6d 65 73 28 22 52 45 41 4c 22 2c  ypeNames("REAL",
67e0: 20 44 62 54 79 70 65 2e 44 6f 75 62 6c 65 29 2c   DbType.Double),
67f0: 0d 0a 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69  ..      new SQLi
6800: 74 65 54 79 70 65 4e 61 6d 65 73 28 22 42 49 54  teTypeNames("BIT
6810: 22 2c 20 44 62 54 79 70 65 2e 42 6f 6f 6c 65 61  ", DbType.Boolea
6820: 6e 29 2c 0d 0a 20 20 20 20 20 20 6e 65 77 20 53  n),..      new S
6830: 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22  QLiteTypeNames("
6840: 44 45 43 49 4d 41 4c 22 2c 20 44 62 54 79 70 65  DECIMAL", DbType
6850: 2e 44 65 63 69 6d 61 6c 29 2c 0d 0a 20 20 20 20  .Decimal),..    
6860: 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65    new SQLiteType
6870: 4e 61 6d 65 73 28 22 44 41 54 45 54 49 4d 45 22  Names("DATETIME"
6880: 2c 20 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d  , DbType.DateTim
6890: 65 29 2c 0d 0a 20 20 20 20 20 20 6e 65 77 20 53  e),..      new S
68a0: 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22  QLiteTypeNames("
68b0: 42 4c 4f 42 22 2c 20 44 62 54 79 70 65 2e 42 69  BLOB", DbType.Bi
68c0: 6e 61 72 79 29 2c 0d 0a 20 20 20 20 20 20 6e 65  nary),..      ne
68d0: 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65  w SQLiteTypeName
68e0: 73 28 22 55 4e 49 51 55 45 49 44 45 4e 54 49 46  s("UNIQUEIDENTIF
68f0: 49 45 52 22 2c 20 44 62 54 79 70 65 2e 47 75 69  IER", DbType.Gui
6900: 64 29 2c 0d 0a 20 20 20 20 20 20 6e 65 77 20 53  d),..      new S
6910: 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22  QLiteTypeNames("
6920: 53 4d 41 4c 4c 49 4e 54 22 2c 20 44 62 54 79 70  SMALLINT", DbTyp
6930: 65 2e 49 6e 74 31 36 29 2c 0d 0a 20 20 20 20 7d  e.Int16),..    }
6940: 3b 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ;..    /// <summ
6950: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43 6f  ary>..    /// Co
6960: 6e 76 65 72 74 20 61 20 44 62 54 79 70 65 20 74  nvert a DbType t
6970: 6f 20 61 20 54 79 70 65 0d 0a 20 20 20 20 2f 2f  o a Type..    //
6980: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
6990: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
69a0: 65 3d 22 74 79 70 22 3e 54 68 65 20 44 62 54 79  e="typ">The DbTy
69b0: 70 65 20 74 6f 20 63 6f 6e 76 65 72 74 20 66 72  pe to convert fr
69c0: 6f 6d 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  om</param>..    
69d0: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65  /// <returns>The
69e0: 20 63 6c 6f 73 65 73 74 2d 6d 61 74 63 68 20 2e   closest-match .
69f0: 4e 45 54 20 74 79 70 65 3c 2f 72 65 74 75 72 6e  NET type</return
6a00: 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  s>..    internal
6a10: 20 73 74 61 74 69 63 20 54 79 70 65 20 44 62 54   static Type DbT
6a20: 79 70 65 54 6f 54 79 70 65 28 44 62 54 79 70 65  ypeToType(DbType
6a30: 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d 0a 20 20   typ)..    {..  
6a40: 20 20 20 20 72 65 74 75 72 6e 20 5f 64 62 74 79      return _dbty
6a50: 70 65 54 6f 54 79 70 65 5b 28 69 6e 74 29 74 79  peToType[(int)ty
6a60: 70 5d 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  p];..    }....  
6a70: 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69 63    private static
6a80: 20 54 79 70 65 5b 5d 20 5f 64 62 74 79 70 65 54   Type[] _dbtypeT
6a90: 6f 54 79 70 65 20 3d 20 7b 0d 0a 20 20 20 20 20  oType = {..     
6aa0: 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67 29 2c   typeof(string),
6ab0: 20 20 20 2f 2f 20 30 0d 0a 20 20 20 20 20 20 74     // 0..      t
6ac0: 79 70 65 6f 66 28 62 79 74 65 5b 5d 29 2c 20 20  ypeof(byte[]),  
6ad0: 20 2f 2f 20 31 0d 0a 20 20 20 20 20 20 74 79 70   // 1..      typ
6ae0: 65 6f 66 28 62 79 74 65 29 2c 20 20 20 20 20 2f  eof(byte),     /
6af0: 2f 20 32 0d 0a 20 20 20 20 20 20 74 79 70 65 6f  / 2..      typeo
6b00: 66 28 62 6f 6f 6c 29 2c 20 20 20 20 20 2f 2f 20  f(bool),     // 
6b10: 33 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  3..      typeof(
6b20: 64 65 63 69 6d 61 6c 29 2c 20 20 2f 2f 20 34 0d  decimal),  // 4.
6b30: 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 44 61  .      typeof(Da
6b40: 74 65 54 69 6d 65 29 2c 20 2f 2f 20 35 0d 0a 20  teTime), // 5.. 
6b50: 20 20 20 20 20 74 79 70 65 6f 66 28 44 61 74 65       typeof(Date
6b60: 54 69 6d 65 29 2c 20 2f 2f 20 36 0d 0a 20 20 20  Time), // 6..   
6b70: 20 20 20 74 79 70 65 6f 66 28 64 65 63 69 6d 61     typeof(decima
6b80: 6c 29 2c 20 20 2f 2f 20 37 0d 0a 20 20 20 20 20  l),  // 7..     
6b90: 20 74 79 70 65 6f 66 28 64 6f 75 62 6c 65 29 2c   typeof(double),
6ba0: 20 20 20 2f 2f 20 38 0d 0a 20 20 20 20 20 20 74     // 8..      t
6bb0: 79 70 65 6f 66 28 47 75 69 64 29 2c 20 20 20 20  ypeof(Guid),    
6bc0: 20 2f 2f 20 39 0d 0a 20 20 20 20 20 20 74 79 70   // 9..      typ
6bd0: 65 6f 66 28 49 6e 74 31 36 29 2c 0d 0a 20 20 20  eof(Int16),..   
6be0: 20 20 20 74 79 70 65 6f 66 28 49 6e 74 33 32 29     typeof(Int32)
6bf0: 2c 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  ,..      typeof(
6c00: 49 6e 74 36 34 29 2c 0d 0a 20 20 20 20 20 20 74  Int64),..      t
6c10: 79 70 65 6f 66 28 6f 62 6a 65 63 74 29 2c 0d 0a  ypeof(object),..
6c20: 20 20 20 20 20 20 74 79 70 65 6f 66 28 73 62 79        typeof(sby
6c30: 74 65 29 2c 0d 0a 20 20 20 20 20 20 74 79 70 65  te),..      type
6c40: 6f 66 28 66 6c 6f 61 74 29 2c 0d 0a 20 20 20 20  of(float),..    
6c50: 20 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67 29    typeof(string)
6c60: 2c 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  ,..      typeof(
6c70: 44 61 74 65 54 69 6d 65 29 2c 0d 0a 20 20 20 20  DateTime),..    
6c80: 20 20 74 79 70 65 6f 66 28 55 49 6e 74 31 36 29    typeof(UInt16)
6c90: 2c 0d 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28  ,..      typeof(
6ca0: 55 49 6e 74 33 32 29 2c 0d 0a 20 20 20 20 20 20  UInt32),..      
6cb0: 74 79 70 65 6f 66 28 55 49 6e 74 36 34 29 2c 0d  typeof(UInt64),.
6cc0: 0a 20 20 20 20 20 20 74 79 70 65 6f 66 28 64 6f  .      typeof(do
6cd0: 75 62 6c 65 29 2c 0d 0a 20 20 20 20 20 20 74 79  uble),..      ty
6ce0: 70 65 6f 66 28 73 74 72 69 6e 67 29 2c 0d 0a 20  peof(string),.. 
6cf0: 20 20 20 20 20 74 79 70 65 6f 66 28 73 74 72 69       typeof(stri
6d00: 6e 67 29 2c 0d 0a 20 20 20 20 20 20 74 79 70 65  ng),..      type
6d10: 6f 66 28 73 74 72 69 6e 67 29 2c 0d 0a 20 20 20  of(string),..   
6d20: 20 20 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67     typeof(string
6d30: 29 2c 20 20 20 2f 2f 20 32 35 20 28 58 6d 6c 29  ),   // 25 (Xml)
6d40: 0d 0a 20 20 20 20 7d 3b 0d 0a 0d 0a 20 20 20 20  ..    };....    
6d50: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
6d60: 20 20 20 2f 2f 2f 20 46 6f 72 20 61 20 67 69 76     /// For a giv
6d70: 65 6e 20 74 79 70 65 2c 20 72 65 74 75 72 6e 20  en type, return 
6d80: 74 68 65 20 63 6c 6f 73 65 73 74 2d 6d 61 74 63  the closest-matc
6d90: 68 20 53 51 4c 69 74 65 20 54 79 70 65 41 66 66  h SQLite TypeAff
6da0: 69 6e 69 74 79 2c 20 77 68 69 63 68 20 6f 6e 6c  inity, which onl
6db0: 79 20 75 6e 64 65 72 73 74 61 6e 64 73 20 61 20  y understands a 
6dc0: 76 65 72 79 20 6c 69 6d 69 74 65 64 20 73 75 62  very limited sub
6dd0: 73 65 74 20 6f 66 20 74 79 70 65 73 2e 0d 0a 20  set of types... 
6de0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
6df0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
6e00: 6d 20 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68 65  m name="typ">The
6e10: 20 74 79 70 65 20 74 6f 20 65 76 61 6c 75 61 74   type to evaluat
6e20: 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  e</param>..    /
6e30: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20  // <returns>The 
6e40: 53 51 4c 69 74 65 20 74 79 70 65 20 61 66 66 69  SQLite type affi
6e50: 6e 69 74 79 20 66 6f 72 20 74 68 61 74 20 74 79  nity for that ty
6e60: 70 65 2e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20  pe.</returns>.. 
6e70: 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74     internal stat
6e80: 69 63 20 54 79 70 65 41 66 66 69 6e 69 74 79 20  ic TypeAffinity 
6e90: 54 79 70 65 54 6f 41 66 66 69 6e 69 74 79 28 54  TypeToAffinity(T
6ea0: 79 70 65 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d  ype typ)..    {.
6eb0: 0a 20 20 20 20 20 20 54 79 70 65 43 6f 64 65 20  .      TypeCode 
6ec0: 74 63 20 3d 20 54 79 70 65 2e 47 65 74 54 79 70  tc = Type.GetTyp
6ed0: 65 43 6f 64 65 28 74 79 70 29 3b 0d 0a 20 20 20  eCode(typ);..   
6ee0: 20 20 20 69 66 20 28 74 63 20 3d 3d 20 54 79 70     if (tc == Typ
6ef0: 65 43 6f 64 65 2e 4f 62 6a 65 63 74 29 0d 0a 20  eCode.Object).. 
6f00: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
6f10: 69 66 20 28 74 79 70 20 3d 3d 20 74 79 70 65 6f  if (typ == typeo
6f20: 66 28 62 79 74 65 5b 5d 29 20 7c 7c 20 74 79 70  f(byte[]) || typ
6f30: 20 3d 3d 20 74 79 70 65 6f 66 28 47 75 69 64 29   == typeof(Guid)
6f40: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65 74  )..          ret
6f50: 75 72 6e 20 54 79 70 65 41 66 66 69 6e 69 74 79  urn TypeAffinity
6f60: 2e 42 6c 6f 62 3b 0d 0a 20 20 20 20 20 20 20 20  .Blob;..        
6f70: 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20  else..          
6f80: 72 65 74 75 72 6e 20 54 79 70 65 41 66 66 69 6e  return TypeAffin
6f90: 69 74 79 2e 54 65 78 74 3b 0d 0a 20 20 20 20 20  ity.Text;..     
6fa0: 20 7d 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e   }..      return
6fb0: 20 5f 74 79 70 65 63 6f 64 65 41 66 66 69 6e 69   _typecodeAffini
6fc0: 74 69 65 73 5b 28 69 6e 74 29 74 63 5d 3b 0d 0a  ties[(int)tc];..
6fd0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69      }....    pri
6fe0: 76 61 74 65 20 73 74 61 74 69 63 20 54 79 70 65  vate static Type
6ff0: 41 66 66 69 6e 69 74 79 5b 5d 20 5f 74 79 70 65  Affinity[] _type
7000: 63 6f 64 65 41 66 66 69 6e 69 74 69 65 73 20 3d  codeAffinities =
7010: 20 7b 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66   {..      TypeAf
7020: 66 69 6e 69 74 79 2e 4e 75 6c 6c 2c 0d 0a 20 20  finity.Null,..  
7030: 20 20 20 20 54 79 70 65 41 66 66 69 6e 69 74 79      TypeAffinity
7040: 2e 42 6c 6f 62 2c 0d 0a 20 20 20 20 20 20 54 79  .Blob,..      Ty
7050: 70 65 41 66 66 69 6e 69 74 79 2e 4e 75 6c 6c 2c  peAffinity.Null,
7060: 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66 66 69  ..      TypeAffi
7070: 6e 69 74 79 2e 49 6e 74 36 34 2c 0d 0a 20 20 20  nity.Int64,..   
7080: 20 20 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e     TypeAffinity.
7090: 49 6e 74 36 34 2c 0d 0a 20 20 20 20 20 20 54 79  Int64,..      Ty
70a0: 70 65 41 66 66 69 6e 69 74 79 2e 49 6e 74 36 34  peAffinity.Int64
70b0: 2c 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66 66  ,..      TypeAff
70c0: 69 6e 69 74 79 2e 49 6e 74 36 34 2c 0d 0a 20 20  inity.Int64,..  
70d0: 20 20 20 20 54 79 70 65 41 66 66 69 6e 69 74 79      TypeAffinity
70e0: 2e 49 6e 74 36 34 2c 20 2f 2f 20 37 0d 0a 20 20  .Int64, // 7..  
70f0: 20 20 20 20 54 79 70 65 41 66 66 69 6e 69 74 79      TypeAffinity
7100: 2e 49 6e 74 36 34 2c 0d 0a 20 20 20 20 20 20 54  .Int64,..      T
7110: 79 70 65 41 66 66 69 6e 69 74 79 2e 49 6e 74 36  ypeAffinity.Int6
7120: 34 2c 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66  4,..      TypeAf
7130: 66 69 6e 69 74 79 2e 49 6e 74 36 34 2c 0d 0a 20  finity.Int64,.. 
7140: 20 20 20 20 20 54 79 70 65 41 66 66 69 6e 69 74       TypeAffinit
7150: 79 2e 49 6e 74 36 34 2c 20 2f 2f 20 31 31 0d 0a  y.Int64, // 11..
7160: 20 20 20 20 20 20 54 79 70 65 41 66 66 69 6e 69        TypeAffini
7170: 74 79 2e 49 6e 74 36 34 2c 0d 0a 20 20 20 20 20  ty.Int64,..     
7180: 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f   TypeAffinity.Do
7190: 75 62 6c 65 2c 0d 0a 20 20 20 20 20 20 54 79 70  uble,..      Typ
71a0: 65 41 66 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65  eAffinity.Double
71b0: 2c 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66 66  ,..      TypeAff
71c0: 69 6e 69 74 79 2e 44 6f 75 62 6c 65 2c 0d 0a 20  inity.Double,.. 
71d0: 20 20 20 20 20 54 79 70 65 41 66 66 69 6e 69 74       TypeAffinit
71e0: 79 2e 44 61 74 65 54 69 6d 65 2c 0d 0a 20 20 20  y.DateTime,..   
71f0: 20 20 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e     TypeAffinity.
7200: 4e 75 6c 6c 2c 0d 0a 20 20 20 20 20 20 54 79 70  Null,..      Typ
7210: 65 41 66 66 69 6e 69 74 79 2e 54 65 78 74 2c 0d  eAffinity.Text,.
7220: 0a 20 20 20 20 7d 3b 0d 0a 0d 0a 20 20 20 20 2f  .    };....    /
7230: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
7240: 20 20 2f 2f 2f 20 46 6f 72 20 61 20 67 69 76 65    /// For a give
7250: 6e 20 74 79 70 65 20 6e 61 6d 65 2c 20 72 65 74  n type name, ret
7260: 75 72 6e 20 61 20 63 6c 6f 73 65 73 74 2d 6d 61  urn a closest-ma
7270: 74 63 68 20 2e 4e 45 54 20 74 79 70 65 0d 0a 20  tch .NET type.. 
7280: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
7290: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
72a0: 6d 20 6e 61 6d 65 3d 22 4e 61 6d 65 22 3e 54 68  m name="Name">Th
72b0: 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 74 79  e name of the ty
72c0: 70 65 20 74 6f 20 6d 61 74 63 68 3c 2f 70 61 72  pe to match</par
72d0: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  am>..    /// <re
72e0: 74 75 72 6e 73 3e 54 68 65 20 2e 4e 45 54 20 44  turns>The .NET D
72f0: 42 54 79 70 65 20 74 68 65 20 74 65 78 74 20 65  BType the text e
7300: 76 61 6c 75 61 74 65 73 20 74 6f 2e 3c 2f 72 65  valuates to.</re
7310: 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65  turns>..    inte
7320: 72 6e 61 6c 20 73 74 61 74 69 63 20 44 62 54 79  rnal static DbTy
7330: 70 65 20 54 79 70 65 4e 61 6d 65 54 6f 44 62 54  pe TypeNameToDbT
7340: 79 70 65 28 73 74 72 69 6e 67 20 4e 61 6d 65 29  ype(string Name)
7350: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69  ..    {..      i
7360: 66 20 28 53 74 72 69 6e 67 2e 49 73 4e 75 6c 6c  f (String.IsNull
7370: 4f 72 45 6d 70 74 79 28 4e 61 6d 65 29 29 20 72  OrEmpty(Name)) r
7380: 65 74 75 72 6e 20 44 62 54 79 70 65 2e 4f 62 6a  eturn DbType.Obj
7390: 65 63 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66  ect;....      if
73a0: 20 28 5f 74 79 70 65 4e 61 6d 65 73 20 3d 3d 20   (_typeNames == 
73b0: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 7b 0d 0a  null)..      {..
73c0: 20 20 20 20 20 20 20 20 5f 74 79 70 65 4e 61 6d          _typeNam
73d0: 65 73 20 3d 20 6e 65 77 20 44 69 63 74 69 6f 6e  es = new Diction
73e0: 61 72 79 3c 73 74 72 69 6e 67 2c 20 53 51 4c 69  ary<string, SQLi
73f0: 74 65 54 79 70 65 4e 61 6d 65 73 3e 28 6e 65 77  teTypeNames>(new
7400: 20 54 79 70 65 4e 61 6d 65 53 74 72 69 6e 67 43   TypeNameStringC
7410: 6f 6d 70 61 72 65 72 28 29 29 3b 0d 0a 0d 0a 20  omparer());.... 
7420: 20 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 28         foreach (
7430: 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 20  SQLiteTypeNames 
7440: 74 79 70 65 4e 61 6d 65 20 69 6e 20 6e 65 77 20  typeName in new 
7450: 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 5b  SQLiteTypeNames[
7460: 5d 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ] {..           
7470: 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e   new SQLiteTypeN
7480: 61 6d 65 73 28 22 43 4f 55 4e 54 45 52 22 2c 20  ames("COUNTER", 
7490: 44 62 54 79 70 65 2e 49 6e 74 36 34 29 2c 0d 0a  DbType.Int64),..
74a0: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
74b0: 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28  SQLiteTypeNames(
74c0: 22 41 55 54 4f 49 4e 43 52 45 4d 45 4e 54 22 2c  "AUTOINCREMENT",
74d0: 20 44 62 54 79 70 65 2e 49 6e 74 36 34 29 2c 0d   DbType.Int64),.
74e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77  .            new
74f0: 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73   SQLiteTypeNames
7500: 28 22 49 44 45 4e 54 49 54 59 22 2c 20 44 62 54  ("IDENTITY", DbT
7510: 79 70 65 2e 49 6e 74 36 34 29 2c 0d 0a 20 20 20  ype.Int64),..   
7520: 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c           new SQL
7530: 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22 4c 4f  iteTypeNames("LO
7540: 4e 47 54 45 58 54 22 2c 20 44 62 54 79 70 65 2e  NGTEXT", DbType.
7550: 53 74 72 69 6e 67 29 2c 0d 0a 20 20 20 20 20 20  String),..      
7560: 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65        new SQLite
7570: 54 79 70 65 4e 61 6d 65 73 28 22 4c 4f 4e 47 43  TypeNames("LONGC
7580: 48 41 52 22 2c 20 44 62 54 79 70 65 2e 53 74 72  HAR", DbType.Str
7590: 69 6e 67 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  ing),..         
75a0: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70     new SQLiteTyp
75b0: 65 4e 61 6d 65 73 28 22 4c 4f 4e 47 56 41 52 43  eNames("LONGVARC
75c0: 48 41 52 22 2c 20 44 62 54 79 70 65 2e 53 74 72  HAR", DbType.Str
75d0: 69 6e 67 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  ing),..         
75e0: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70     new SQLiteTyp
75f0: 65 4e 61 6d 65 73 28 22 4c 4f 4e 47 22 2c 20 44  eNames("LONG", D
7600: 62 54 79 70 65 2e 49 6e 74 36 34 29 2c 0d 0a 20  bType.Int64),.. 
7610: 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53             new S
7620: 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22  QLiteTypeNames("
7630: 54 49 4e 59 49 4e 54 22 2c 20 44 62 54 79 70 65  TINYINT", DbType
7640: 2e 42 79 74 65 29 2c 0d 0a 20 20 20 20 20 20 20  .Byte),..       
7650: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54       new SQLiteT
7660: 79 70 65 4e 61 6d 65 73 28 22 49 4e 54 45 47 45  ypeNames("INTEGE
7670: 52 22 2c 20 44 62 54 79 70 65 2e 49 6e 74 36 34  R", DbType.Int64
7680: 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ),..            
7690: 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61  new SQLiteTypeNa
76a0: 6d 65 73 28 22 49 4e 54 22 2c 20 44 62 54 79 70  mes("INT", DbTyp
76b0: 65 2e 49 6e 74 33 32 29 2c 0d 0a 20 20 20 20 20  e.Int32),..     
76c0: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
76d0: 65 54 79 70 65 4e 61 6d 65 73 28 22 56 41 52 43  eTypeNames("VARC
76e0: 48 41 52 22 2c 20 44 62 54 79 70 65 2e 53 74 72  HAR", DbType.Str
76f0: 69 6e 67 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  ing),..         
7700: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70     new SQLiteTyp
7710: 65 4e 61 6d 65 73 28 22 4e 56 41 52 43 48 41 52  eNames("NVARCHAR
7720: 22 2c 20 44 62 54 79 70 65 2e 53 74 72 69 6e 67  ", DbType.String
7730: 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ),..            
7740: 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61  new SQLiteTypeNa
7750: 6d 65 73 28 22 43 48 41 52 22 2c 20 44 62 54 79  mes("CHAR", DbTy
7760: 70 65 2e 53 74 72 69 6e 67 29 2c 0d 0a 20 20 20  pe.String),..   
7770: 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c           new SQL
7780: 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22 4e 43  iteTypeNames("NC
7790: 48 41 52 22 2c 20 44 62 54 79 70 65 2e 53 74 72  HAR", DbType.Str
77a0: 69 6e 67 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  ing),..         
77b0: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70     new SQLiteTyp
77c0: 65 4e 61 6d 65 73 28 22 54 45 58 54 22 2c 20 44  eNames("TEXT", D
77d0: 62 54 79 70 65 2e 53 74 72 69 6e 67 29 2c 0d 0a  bType.String),..
77e0: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
77f0: 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28  SQLiteTypeNames(
7800: 22 4e 54 45 58 54 22 2c 20 44 62 54 79 70 65 2e  "NTEXT", DbType.
7810: 53 74 72 69 6e 67 29 2c 0d 0a 20 20 20 20 20 20  String),..      
7820: 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65        new SQLite
7830: 54 79 70 65 4e 61 6d 65 73 28 22 53 54 52 49 4e  TypeNames("STRIN
7840: 47 22 2c 20 44 62 54 79 70 65 2e 53 74 72 69 6e  G", DbType.Strin
7850: 67 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  g),..           
7860: 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e   new SQLiteTypeN
7870: 61 6d 65 73 28 22 44 4f 55 42 4c 45 22 2c 20 44  ames("DOUBLE", D
7880: 62 54 79 70 65 2e 44 6f 75 62 6c 65 29 2c 0d 0a  bType.Double),..
7890: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
78a0: 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28  SQLiteTypeNames(
78b0: 22 46 4c 4f 41 54 22 2c 20 44 62 54 79 70 65 2e  "FLOAT", DbType.
78c0: 44 6f 75 62 6c 65 29 2c 0d 0a 20 20 20 20 20 20  Double),..      
78d0: 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65        new SQLite
78e0: 54 79 70 65 4e 61 6d 65 73 28 22 52 45 41 4c 22  TypeNames("REAL"
78f0: 2c 20 44 62 54 79 70 65 2e 44 6f 75 62 6c 65 29  , DbType.Double)
7900: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
7910: 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d  ew SQLiteTypeNam
7920: 65 73 28 22 42 49 54 22 2c 20 44 62 54 79 70 65  es("BIT", DbType
7930: 2e 42 6f 6f 6c 65 61 6e 29 2c 0d 0a 20 20 20 20  .Boolean),..    
7940: 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69          new SQLi
7950: 74 65 54 79 70 65 4e 61 6d 65 73 28 22 59 45 53  teTypeNames("YES
7960: 4e 4f 22 2c 20 44 62 54 79 70 65 2e 42 6f 6f 6c  NO", DbType.Bool
7970: 65 61 6e 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  ean),..         
7980: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70     new SQLiteTyp
7990: 65 4e 61 6d 65 73 28 22 4c 4f 47 49 43 41 4c 22  eNames("LOGICAL"
79a0: 2c 20 44 62 54 79 70 65 2e 42 6f 6f 6c 65 61 6e  , DbType.Boolean
79b0: 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ),..            
79c0: 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61  new SQLiteTypeNa
79d0: 6d 65 73 28 22 42 4f 4f 4c 22 2c 20 44 62 54 79  mes("BOOL", DbTy
79e0: 70 65 2e 42 6f 6f 6c 65 61 6e 29 2c 0d 0a 20 20  pe.Boolean),..  
79f0: 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51            new SQ
7a00: 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22 42  LiteTypeNames("B
7a10: 4f 4f 4c 45 41 4e 22 2c 20 44 62 54 79 70 65 2e  OOLEAN", DbType.
7a20: 42 6f 6f 6c 65 61 6e 29 2c 0d 0a 20 20 20 20 20  Boolean),..     
7a30: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
7a40: 65 54 79 70 65 4e 61 6d 65 73 28 22 4e 55 4d 45  eTypeNames("NUME
7a50: 52 49 43 22 2c 20 44 62 54 79 70 65 2e 44 65 63  RIC", DbType.Dec
7a60: 69 6d 61 6c 29 2c 0d 0a 20 20 20 20 20 20 20 20  imal),..        
7a70: 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79      new SQLiteTy
7a80: 70 65 4e 61 6d 65 73 28 22 44 45 43 49 4d 41 4c  peNames("DECIMAL
7a90: 22 2c 20 44 62 54 79 70 65 2e 44 65 63 69 6d 61  ", DbType.Decima
7aa0: 6c 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  l),..           
7ab0: 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e   new SQLiteTypeN
7ac0: 61 6d 65 73 28 22 4d 4f 4e 45 59 22 2c 20 44 62  ames("MONEY", Db
7ad0: 54 79 70 65 2e 44 65 63 69 6d 61 6c 29 2c 0d 0a  Type.Decimal),..
7ae0: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
7af0: 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28  SQLiteTypeNames(
7b00: 22 43 55 52 52 45 4e 43 59 22 2c 20 44 62 54 79  "CURRENCY", DbTy
7b10: 70 65 2e 44 65 63 69 6d 61 6c 29 2c 0d 0a 20 20  pe.Decimal),..  
7b20: 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53 51            new SQ
7b30: 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22 54  LiteTypeNames("T
7b40: 49 4d 45 22 2c 20 44 62 54 79 70 65 2e 44 61 74  IME", DbType.Dat
7b50: 65 54 69 6d 65 29 2c 0d 0a 20 20 20 20 20 20 20  eTime),..       
7b60: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54       new SQLiteT
7b70: 79 70 65 4e 61 6d 65 73 28 22 44 41 54 45 22 2c  ypeNames("DATE",
7b80: 20 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d 65   DbType.DateTime
7b90: 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ),..            
7ba0: 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61  new SQLiteTypeNa
7bb0: 6d 65 73 28 22 44 41 54 45 54 49 4d 45 22 2c 20  mes("DATETIME", 
7bc0: 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d 65 29  DbType.DateTime)
7bd0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
7be0: 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d  ew SQLiteTypeNam
7bf0: 65 73 28 22 53 4d 41 4c 4c 44 41 54 45 22 2c 20  es("SMALLDATE", 
7c00: 44 62 54 79 70 65 2e 44 61 74 65 54 69 6d 65 29  DbType.DateTime)
7c10: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
7c20: 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d  ew SQLiteTypeNam
7c30: 65 73 28 22 42 4c 4f 42 22 2c 20 44 62 54 79 70  es("BLOB", DbTyp
7c40: 65 2e 42 69 6e 61 72 79 29 2c 0d 0a 20 20 20 20  e.Binary),..    
7c50: 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69          new SQLi
7c60: 74 65 54 79 70 65 4e 61 6d 65 73 28 22 42 49 4e  teTypeNames("BIN
7c70: 41 52 59 22 2c 20 44 62 54 79 70 65 2e 42 69 6e  ARY", DbType.Bin
7c80: 61 72 79 29 2c 0d 0a 20 20 20 20 20 20 20 20 20  ary),..         
7c90: 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70     new SQLiteTyp
7ca0: 65 4e 61 6d 65 73 28 22 56 41 52 42 49 4e 41 52  eNames("VARBINAR
7cb0: 59 22 2c 20 44 62 54 79 70 65 2e 42 69 6e 61 72  Y", DbType.Binar
7cc0: 79 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  y),..           
7cd0: 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e   new SQLiteTypeN
7ce0: 61 6d 65 73 28 22 49 4d 41 47 45 22 2c 20 44 62  ames("IMAGE", Db
7cf0: 54 79 70 65 2e 42 69 6e 61 72 79 29 2c 0d 0a 20  Type.Binary),.. 
7d00: 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20 53             new S
7d10: 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28 22  QLiteTypeNames("
7d20: 47 45 4e 45 52 41 4c 22 2c 20 44 62 54 79 70 65  GENERAL", DbType
7d30: 2e 42 69 6e 61 72 79 29 2c 0d 0a 20 20 20 20 20  .Binary),..     
7d40: 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74         new SQLit
7d50: 65 54 79 70 65 4e 61 6d 65 73 28 22 4f 4c 45 4f  eTypeNames("OLEO
7d60: 42 4a 45 43 54 22 2c 20 44 62 54 79 70 65 2e 42  BJECT", DbType.B
7d70: 69 6e 61 72 79 29 2c 0d 0a 20 20 20 20 20 20 20  inary),..       
7d80: 20 20 20 20 20 6e 65 77 20 53 51 4c 69 74 65 54       new SQLiteT
7d90: 79 70 65 4e 61 6d 65 73 28 22 47 55 49 44 22 2c  ypeNames("GUID",
7da0: 20 44 62 54 79 70 65 2e 47 75 69 64 29 2c 0d 0a   DbType.Guid),..
7db0: 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77 20              new 
7dc0: 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73 28  SQLiteTypeNames(
7dd0: 22 55 4e 49 51 55 45 49 44 45 4e 54 49 46 49 45  "UNIQUEIDENTIFIE
7de0: 52 22 2c 20 44 62 54 79 70 65 2e 47 75 69 64 29  R", DbType.Guid)
7df0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e  ,..            n
7e00: 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d  ew SQLiteTypeNam
7e10: 65 73 28 22 4d 45 4d 4f 22 2c 20 44 62 54 79 70  es("MEMO", DbTyp
7e20: 65 2e 53 74 72 69 6e 67 29 2c 0d 0a 20 20 20 20  e.String),..    
7e30: 20 20 20 20 20 20 20 20 6e 65 77 20 53 51 4c 69          new SQLi
7e40: 74 65 54 79 70 65 4e 61 6d 65 73 28 22 4e 4f 54  teTypeNames("NOT
7e50: 45 22 2c 20 44 62 54 79 70 65 2e 53 74 72 69 6e  E", DbType.Strin
7e60: 67 29 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  g),..           
7e70: 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70 65 4e   new SQLiteTypeN
7e80: 61 6d 65 73 28 22 53 4d 41 4c 4c 49 4e 54 22 2c  ames("SMALLINT",
7e90: 20 44 62 54 79 70 65 2e 49 6e 74 31 36 29 2c 0d   DbType.Int16),.
7ea0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 65 77  .            new
7eb0: 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73   SQLiteTypeNames
7ec0: 28 22 42 49 47 49 4e 54 22 2c 20 44 62 54 79 70  ("BIGINT", DbTyp
7ed0: 65 2e 49 6e 74 36 34 29 0d 0a 20 20 20 20 20 20  e.Int64)..      
7ee0: 20 20 20 20 7d 29 0d 0a 20 20 20 20 20 20 20 20      })..        
7ef0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
7f00: 20 5f 74 79 70 65 4e 61 6d 65 73 2e 41 64 64 28   _typeNames.Add(
7f10: 74 79 70 65 4e 61 6d 65 2e 74 79 70 65 4e 61 6d  typeName.typeNam
7f20: 65 2c 20 74 79 70 65 4e 61 6d 65 29 3b 0d 0a 20  e, typeName);.. 
7f30: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20           }..    
7f40: 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 53 51 4c    }....      SQL
7f50: 69 74 65 54 79 70 65 4e 61 6d 65 73 20 76 61 6c  iteTypeNames val
7f60: 75 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  ue;....      if 
7f70: 28 5f 74 79 70 65 4e 61 6d 65 73 2e 54 72 79 47  (_typeNames.TryG
7f80: 65 74 56 61 6c 75 65 28 4e 61 6d 65 2c 20 6f 75  etValue(Name, ou
7f90: 74 20 76 61 6c 75 65 29 29 0d 0a 20 20 20 20 20  t value))..     
7fa0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75   {..        retu
7fb0: 72 6e 20 76 61 6c 75 65 2e 64 61 74 61 54 79 70  rn value.dataTyp
7fc0: 65 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  e;..      }..   
7fd0: 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 7b     else..      {
7fe0: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 6e  ..        int in
7ff0: 64 65 78 20 3d 20 4e 61 6d 65 2e 49 6e 64 65 78  dex = Name.Index
8000: 4f 66 28 27 28 27 29 3b 0d 0a 0d 0a 20 20 20 20  Of('(');....    
8010: 20 20 20 20 69 66 20 28 28 69 6e 64 65 78 20 3e      if ((index >
8020: 20 30 29 20 26 26 0d 0a 20 20 20 20 20 20 20 20   0) &&..        
8030: 20 20 20 20 5f 74 79 70 65 4e 61 6d 65 73 2e 54      _typeNames.T
8040: 72 79 47 65 74 56 61 6c 75 65 28 4e 61 6d 65 2e  ryGetValue(Name.
8050: 53 75 62 73 74 72 69 6e 67 28 30 2c 20 69 6e 64  Substring(0, ind
8060: 65 78 29 2c 20 6f 75 74 20 76 61 6c 75 65 29 29  ex), out value))
8070: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
8080: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 76 61         return va
8090: 6c 75 65 2e 64 61 74 61 54 79 70 65 3b 0d 0a 20  lue.dataType;.. 
80a0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
80b0: 7d 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72  }....      retur
80c0: 6e 20 44 62 54 79 70 65 2e 4f 62 6a 65 63 74 3b  n DbType.Object;
80d0: 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20 23 65 6e  ..    }..    #en
80e0: 64 72 65 67 69 6f 6e 0d 0a 0d 0a 20 20 20 20 70  dregion....    p
80f0: 72 69 76 61 74 65 20 73 74 61 74 69 63 20 44 69  rivate static Di
8100: 63 74 69 6f 6e 61 72 79 3c 73 74 72 69 6e 67 2c  ctionary<string,
8110: 20 53 51 4c 69 74 65 54 79 70 65 4e 61 6d 65 73   SQLiteTypeNames
8120: 3e 20 5f 74 79 70 65 4e 61 6d 65 73 20 3d 20 6e  > _typeNames = n
8130: 75 6c 6c 3b 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 2f  ull;..  }....  /
8140: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
8150: 2f 2f 2f 20 53 51 4c 69 74 65 20 68 61 73 20 76  /// SQLite has v
8160: 65 72 79 20 6c 69 6d 69 74 65 64 20 74 79 70 65  ery limited type
8170: 73 2c 20 61 6e 64 20 69 73 20 69 6e 68 65 72 65  s, and is inhere
8180: 6e 74 6c 79 20 74 65 78 74 2d 62 61 73 65 64 2e  ntly text-based.
8190: 20 20 54 68 65 20 66 69 72 73 74 20 35 20 74 79    The first 5 ty
81a0: 70 65 73 20 62 65 6c 6f 77 20 72 65 70 72 65 73  pes below repres
81b0: 65 6e 74 20 74 68 65 20 73 75 6d 20 6f 66 20 61  ent the sum of a
81c0: 6c 6c 20 74 79 70 65 73 20 53 51 4c 69 74 65 0d  ll types SQLite.
81d0: 0a 20 20 2f 2f 2f 20 75 6e 64 65 72 73 74 61 6e  .  /// understan
81e0: 64 73 2e 20 20 54 68 65 20 44 61 74 65 54 69 6d  ds.  The DateTim
81f0: 65 20 65 78 74 65 6e 73 69 6f 6e 20 74 6f 20 74  e extension to t
8200: 68 65 20 73 70 65 63 20 69 73 20 66 6f 72 20 69  he spec is for i
8210: 6e 74 65 72 6e 61 6c 20 75 73 65 20 6f 6e 6c 79  nternal use only
8220: 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  ...  /// </summa
8230: 72 79 3e 0d 0a 20 20 70 75 62 6c 69 63 20 65 6e  ry>..  public en
8240: 75 6d 20 54 79 70 65 41 66 66 69 6e 69 74 79 0d  um TypeAffinity.
8250: 0a 20 20 7b 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73  .  {..    /// <s
8260: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
8270: 20 4e 6f 74 20 75 73 65 64 0d 0a 20 20 20 20 2f   Not used..    /
8280: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
8290: 20 20 20 55 6e 69 6e 69 74 69 61 6c 69 7a 65 64     Uninitialized
82a0: 20 3d 20 30 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c   = 0,..    /// <
82b0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
82c0: 2f 20 41 6c 6c 20 69 6e 74 65 67 65 72 73 20 69  / All integers i
82d0: 6e 20 53 51 4c 69 74 65 20 64 65 66 61 75 6c 74  n SQLite default
82e0: 20 74 6f 20 49 6e 74 36 34 0d 0a 20 20 20 20 2f   to Int64..    /
82f0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
8300: 20 20 20 49 6e 74 36 34 20 3d 20 31 2c 0d 0a 20     Int64 = 1,.. 
8310: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
8320: 0d 0a 20 20 20 20 2f 2f 2f 20 41 6c 6c 20 66 6c  ..    /// All fl
8330: 6f 61 74 69 6e 67 20 70 6f 69 6e 74 20 6e 75 6d  oating point num
8340: 62 65 72 73 20 69 6e 20 53 51 4c 69 74 65 20 64  bers in SQLite d
8350: 65 66 61 75 6c 74 20 74 6f 20 64 6f 75 62 6c 65  efault to double
8360: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
8370: 61 72 79 3e 0d 0a 20 20 20 20 44 6f 75 62 6c 65  ary>..    Double
8380: 20 3d 20 32 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c   = 2,..    /// <
8390: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
83a0: 2f 20 54 68 65 20 64 65 66 61 75 6c 74 20 64 61  / The default da
83b0: 74 61 20 74 79 70 65 20 6f 66 20 53 51 4c 69 74  ta type of SQLit
83c0: 65 20 69 73 20 74 65 78 74 0d 0a 20 20 20 20 2f  e is text..    /
83d0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
83e0: 20 20 20 54 65 78 74 20 3d 20 33 2c 0d 0a 20 20     Text = 3,..  
83f0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
8400: 0a 20 20 20 20 2f 2f 2f 20 54 79 70 69 63 61 6c  .    /// Typical
8410: 6c 79 20 62 6c 6f 62 20 74 79 70 65 73 20 61 72  ly blob types ar
8420: 65 20 6f 6e 6c 79 20 73 65 65 6e 20 77 68 65 6e  e only seen when
8430: 20 72 65 74 75 72 6e 65 64 20 66 72 6f 6d 20 61   returned from a
8440: 20 66 75 6e 63 74 69 6f 6e 0d 0a 20 20 20 20 2f   function..    /
8450: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
8460: 20 20 20 42 6c 6f 62 20 3d 20 34 2c 0d 0a 20 20     Blob = 4,..  
8470: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
8480: 0a 20 20 20 20 2f 2f 2f 20 4e 75 6c 6c 20 74 79  .    /// Null ty
8490: 70 65 73 20 63 61 6e 20 62 65 20 72 65 74 75 72  pes can be retur
84a0: 6e 65 64 20 66 72 6f 6d 20 66 75 6e 63 74 69 6f  ned from functio
84b0: 6e 73 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ns..    /// </su
84c0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 4e 75 6c 6c  mmary>..    Null
84d0: 20 3d 20 35 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c   = 5,..    /// <
84e0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
84f0: 2f 20 55 73 65 64 20 69 6e 74 65 72 6e 61 6c 6c  / Used internall
8500: 79 20 62 79 20 74 68 69 73 20 70 72 6f 76 69 64  y by this provid
8510: 65 72 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  er..    /// </su
8520: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 44 61 74 65  mmary>..    Date
8530: 54 69 6d 65 20 3d 20 31 30 2c 0d 0a 20 20 20 20  Time = 10,..    
8540: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
8550: 20 20 20 2f 2f 2f 20 55 73 65 64 20 69 6e 74 65     /// Used inte
8560: 72 6e 61 6c 6c 79 0d 0a 20 20 20 20 2f 2f 2f 20  rnally..    /// 
8570: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
8580: 4e 6f 6e 65 20 3d 20 31 31 2c 0d 0a 20 20 7d 0d  None = 11,..  }.
8590: 0a 0d 0a 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  ...  /// <summar
85a0: 79 3e 0d 0a 20 20 2f 2f 2f 20 54 68 69 73 20 69  y>..  /// This i
85b0: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66  mplementation of
85c0: 20 53 51 4c 69 74 65 20 66 6f 72 20 41 44 4f 2e   SQLite for ADO.
85d0: 4e 45 54 20 63 61 6e 20 70 72 6f 63 65 73 73 20  NET can process 
85e0: 64 61 74 65 2f 74 69 6d 65 20 66 69 65 6c 64 73  date/time fields
85f0: 20 69 6e 20 64 61 74 61 62 61 73 65 73 20 69 6e   in databases in
8600: 20 6f 6e 6c 79 20 6f 6e 65 20 6f 66 20 74 68 72   only one of thr
8610: 65 65 20 66 6f 72 6d 61 74 73 2e 20 20 54 69 63  ee formats.  Tic
8620: 6b 73 2c 20 49 53 4f 38 36 30 31 0d 0a 20 20 2f  ks, ISO8601..  /
8630: 2f 2f 20 61 6e 64 20 4a 75 6c 69 61 6e 44 61 79  // and JulianDay
8640: 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  ...  /// </summa
8650: 72 79 3e 0d 0a 20 20 2f 2f 2f 20 3c 72 65 6d 61  ry>..  /// <rema
8660: 72 6b 73 3e 0d 0a 20 20 2f 2f 2f 20 49 53 4f 38  rks>..  /// ISO8
8670: 36 30 31 20 69 73 20 6d 6f 72 65 20 63 6f 6d 70  601 is more comp
8680: 61 74 69 62 6c 65 2c 20 72 65 61 64 61 62 6c 65  atible, readable
8690: 2c 20 66 75 6c 6c 79 2d 70 72 6f 63 65 73 73 61  , fully-processa
86a0: 62 6c 65 2c 20 62 75 74 20 6c 65 73 73 20 61 63  ble, but less ac
86b0: 63 75 72 61 74 65 20 61 73 20 69 74 20 64 6f 65  curate as it doe
86c0: 73 6e 27 74 20 70 72 6f 76 69 64 65 20 74 69 6d  sn't provide tim
86d0: 65 20 64 6f 77 6e 20 74 6f 20 66 72 61 63 74 69  e down to fracti
86e0: 6f 6e 73 20 6f 66 20 61 20 73 65 63 6f 6e 64 2e  ons of a second.
86f0: 0d 0a 20 20 2f 2f 2f 20 4a 75 6c 69 61 6e 44 61  ..  /// JulianDa
8700: 79 20 69 73 20 74 68 65 20 6e 75 6d 65 72 69 63  y is the numeric
8710: 20 66 6f 72 6d 61 74 20 74 68 65 20 53 51 4c 69   format the SQLi
8720: 74 65 20 75 73 65 73 20 69 6e 74 65 72 6e 61 6c  te uses internal
8730: 6c 79 20 61 6e 64 20 69 73 20 61 72 67 75 61 62  ly and is arguab
8740: 6c 79 20 74 68 65 20 6d 6f 73 74 20 63 6f 6d 70  ly the most comp
8750: 61 74 69 62 6c 65 20 77 69 74 68 20 33 72 64 20  atible with 3rd 
8760: 70 61 72 74 79 20 74 6f 6f 6c 73 2e 20 20 49 74  party tools.  It
8770: 20 69 73 0d 0a 20 20 2f 2f 2f 20 6e 6f 74 20 72   is..  /// not r
8780: 65 61 64 61 62 6c 65 20 61 73 20 74 65 78 74 20  eadable as text 
8790: 77 69 74 68 6f 75 74 20 70 6f 73 74 2d 70 72 6f  without post-pro
87a0: 63 65 73 73 69 6e 67 2e 0d 0a 20 20 2f 2f 2f 20  cessing...  /// 
87b0: 54 69 63 6b 73 20 6c 65 73 73 20 63 6f 6d 70 61  Ticks less compa
87c0: 74 69 62 6c 65 20 77 69 74 68 20 33 72 64 20 70  tible with 3rd p
87d0: 61 72 74 79 20 74 6f 6f 6c 73 20 74 68 61 74 20  arty tools that 
87e0: 71 75 65 72 79 20 74 68 65 20 64 61 74 61 62 61  query the databa
87f0: 73 65 2c 20 61 6e 64 20 72 65 6e 64 65 72 73 20  se, and renders 
8800: 74 68 65 20 44 61 74 65 54 69 6d 65 20 66 69 65  the DateTime fie
8810: 6c 64 20 75 6e 72 65 61 64 61 62 6c 65 20 61 73  ld unreadable as
8820: 20 74 65 78 74 20 77 69 74 68 6f 75 74 20 70 6f   text without po
8830: 73 74 2d 70 72 6f 63 65 73 73 69 6e 67 2e 0d 0a  st-processing...
8840: 20 20 2f 2f 2f 20 0d 0a 20 20 2f 2f 2f 20 54 68    /// ..  /// Th
8850: 65 20 70 72 65 66 65 72 72 65 64 20 6f 72 64 65  e preferred orde
8860: 72 20 6f 66 20 63 68 6f 6f 73 69 6e 67 20 61 20  r of choosing a 
8870: 64 61 74 65 74 69 6d 65 20 66 6f 72 6d 61 74 20  datetime format 
8880: 69 73 20 4a 75 6c 69 61 6e 44 61 79 2c 20 49 53  is JulianDay, IS
8890: 4f 38 36 30 31 2c 20 61 6e 64 20 74 68 65 6e 20  O8601, and then 
88a0: 54 69 63 6b 73 2e 20 20 54 69 63 6b 73 20 69 73  Ticks.  Ticks is
88b0: 20 6d 61 69 6e 6c 79 20 70 72 65 73 65 6e 74 20   mainly present 
88c0: 66 6f 72 20 6c 65 67 61 63 79 20 0d 0a 20 20 2f  for legacy ..  /
88d0: 2f 2f 20 63 6f 64 65 20 73 75 70 70 6f 72 74 2e  // code support.
88e0: 0d 0a 20 20 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b  ..  /// </remark
88f0: 73 3e 0d 0a 20 20 70 75 62 6c 69 63 20 65 6e 75  s>..  public enu
8900: 6d 20 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d  m SQLiteDateForm
8910: 61 74 73 0d 0a 20 20 7b 0d 0a 20 20 20 20 2f 2f  ats..  {..    //
8920: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
8930: 20 2f 2f 2f 20 55 73 69 6e 67 20 74 69 63 6b 73   /// Using ticks
8940: 20 69 73 20 6e 6f 74 20 72 65 63 6f 6d 6d 65 6e   is not recommen
8950: 64 65 64 20 61 6e 64 20 69 73 20 6e 6f 74 20 77  ded and is not w
8960: 65 6c 6c 20 73 75 70 70 6f 72 74 65 64 20 77 69  ell supported wi
8970: 74 68 20 4c 49 4e 51 2e 0d 0a 20 20 20 20 2f 2f  th LINQ...    //
8980: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
8990: 20 20 54 69 63 6b 73 20 3d 20 30 2c 0d 0a 20 20    Ticks = 0,..  
89a0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
89b0: 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 49 53 4f  .    /// The ISO
89c0: 38 36 30 31 20 66 6f 72 6d 61 74 0d 0a 20 20 20  8601 format..   
89d0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
89e0: 0a 20 20 20 20 49 53 4f 38 36 30 31 20 3d 20 31  .    ISO8601 = 1
89f0: 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ,..    /// <summ
8a00: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 4a 75  ary>..    /// Ju
8a10: 6c 69 61 6e 44 61 79 20 66 6f 72 6d 61 74 2c 20  lianDay format, 
8a20: 77 68 69 63 68 20 69 73 20 77 68 61 74 20 53 51  which is what SQ
8a30: 4c 69 74 65 20 75 73 65 73 20 69 6e 74 65 72 6e  Lite uses intern
8a40: 61 6c 6c 79 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ally..    /// </
8a50: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 4a 75  summary>..    Ju
8a60: 6c 69 61 6e 44 61 79 20 3d 20 32 2c 0d 0a 20 20  lianDay = 2,..  
8a70: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
8a80: 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 77 68 6f  .    /// The who
8a90: 6c 65 20 6e 75 6d 62 65 72 20 6f 66 20 73 65 63  le number of sec
8aa0: 6f 6e 64 73 20 73 69 6e 63 65 20 74 68 65 20 55  onds since the U
8ab0: 6e 69 78 20 65 70 6f 63 68 20 28 4a 61 6e 75 61  nix epoch (Janua
8ac0: 72 79 20 31 2c 20 31 39 37 30 29 2e 0d 0a 20 20  ry 1, 1970)...  
8ad0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
8ae0: 0d 0a 20 20 20 20 55 6e 69 78 45 70 6f 63 68 20  ..    UnixEpoch 
8af0: 3d 20 33 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73  = 3,..    /// <s
8b00: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
8b10: 20 41 6e 79 20 63 75 6c 74 75 72 65 2d 69 6e 64   Any culture-ind
8b20: 65 70 65 6e 64 65 6e 74 20 73 74 72 69 6e 67 20  ependent string 
8b30: 76 61 6c 75 65 20 74 68 61 74 20 74 68 65 20 2e  value that the .
8b40: 4e 45 54 20 46 72 61 6d 65 77 6f 72 6b 20 63 61  NET Framework ca
8b50: 6e 20 69 6e 74 65 72 70 72 65 74 20 61 73 20 61  n interpret as a
8b60: 20 76 61 6c 69 64 20 44 61 74 65 54 69 6d 65 2e   valid DateTime.
8b70: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
8b80: 61 72 79 3e 0d 0a 20 20 20 20 49 6e 76 61 72 69  ary>..    Invari
8b90: 61 6e 74 43 75 6c 74 75 72 65 20 3d 20 34 2c 0d  antCulture = 4,.
8ba0: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
8bb0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 6e 79 20  y>..    /// Any 
8bc0: 73 74 72 69 6e 67 20 76 61 6c 75 65 20 74 68 61  string value tha
8bd0: 74 20 74 68 65 20 2e 4e 45 54 20 46 72 61 6d 65  t the .NET Frame
8be0: 77 6f 72 6b 20 63 61 6e 20 69 6e 74 65 72 70 72  work can interpr
8bf0: 65 74 20 61 73 20 61 20 76 61 6c 69 64 20 44 61  et as a valid Da
8c00: 74 65 54 69 6d 65 20 75 73 69 6e 67 20 74 68 65  teTime using the
8c10: 20 63 75 72 72 65 6e 74 20 63 75 6c 74 75 72 65   current culture
8c20: 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ...    /// </sum
8c30: 6d 61 72 79 3e 0d 0a 20 20 20 20 43 75 72 72 65  mary>..    Curre
8c40: 6e 74 43 75 6c 74 75 72 65 20 3d 20 35 2c 0d 0a  ntCulture = 5,..
8c50: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
8c60: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 64  >..    /// The d
8c70: 65 66 61 75 6c 74 20 66 6f 72 6d 61 74 20 66 6f  efault format fo
8c80: 72 20 74 68 69 73 20 70 72 6f 76 69 64 65 72 2e  r this provider.
8c90: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
8ca0: 61 72 79 3e 0d 0a 20 20 20 20 44 65 66 61 75 6c  ary>..    Defaul
8cb0: 74 20 3d 20 49 53 4f 38 36 30 31 0d 0a 20 20 7d  t = ISO8601..  }
8cc0: 0d 0a 0d 0a 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ....  /// <summa
8cd0: 72 79 3e 0d 0a 20 20 2f 2f 2f 20 54 68 69 73 20  ry>..  /// This 
8ce0: 65 6e 75 6d 20 64 65 74 65 72 6d 69 6e 65 73 20  enum determines 
8cf0: 68 6f 77 20 53 51 4c 69 74 65 20 74 72 65 61 74  how SQLite treat
8d00: 73 20 69 74 73 20 6a 6f 75 72 6e 61 6c 20 66 69  s its journal fi
8d10: 6c 65 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f 73 75 6d  le...  /// </sum
8d20: 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f 20 3c 72 65  mary>..  /// <re
8d30: 6d 61 72 6b 73 3e 0d 0a 20 20 2f 2f 2f 20 42 79  marks>..  /// By
8d40: 20 64 65 66 61 75 6c 74 20 53 51 4c 69 74 65 20   default SQLite 
8d50: 77 69 6c 6c 20 63 72 65 61 74 65 20 61 6e 64 20  will create and 
8d60: 64 65 6c 65 74 65 20 74 68 65 20 6a 6f 75 72 6e  delete the journ
8d70: 61 6c 20 66 69 6c 65 20 77 68 65 6e 20 6e 65 65  al file when nee
8d80: 64 65 64 20 64 75 72 69 6e 67 20 61 20 74 72 61  ded during a tra
8d90: 6e 73 61 63 74 69 6f 6e 2e 0d 0a 20 20 2f 2f 2f  nsaction...  ///
8da0: 20 48 6f 77 65 76 65 72 2c 20 66 6f 72 20 73 6f   However, for so
8db0: 6d 65 20 63 6f 6d 70 75 74 65 72 73 20 72 75 6e  me computers run
8dc0: 6e 69 6e 67 20 63 65 72 74 61 69 6e 20 66 69 6c  ning certain fil
8dd0: 65 73 79 73 74 65 6d 20 6d 6f 6e 69 74 6f 72 69  esystem monitori
8de0: 6e 67 20 74 6f 6f 6c 73 2c 20 74 68 65 20 72 61  ng tools, the ra
8df0: 70 69 64 0d 0a 20 20 2f 2f 2f 20 63 72 65 61 74  pid..  /// creat
8e00: 69 6f 6e 20 61 6e 64 20 64 65 6c 65 74 69 6f 6e  ion and deletion
8e10: 20 6f 66 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20   of the journal 
8e20: 66 69 6c 65 20 63 61 6e 20 63 61 75 73 65 20 74  file can cause t
8e30: 68 6f 73 65 20 70 72 6f 67 72 61 6d 73 20 74 6f  hose programs to
8e40: 20 66 61 69 6c 2c 20 6f 72 20 74 6f 20 69 6e 74   fail, or to int
8e50: 65 72 66 65 72 65 20 77 69 74 68 20 53 51 4c 69  erfere with SQLi
8e60: 74 65 2e 0d 0a 20 20 2f 2f 2f 20 0d 0a 20 20 2f  te...  /// ..  /
8e70: 2f 2f 20 49 66 20 61 20 70 72 6f 67 72 61 6d 20  // If a program 
8e80: 6f 72 20 76 69 72 75 73 20 73 63 61 6e 6e 65 72  or virus scanner
8e90: 20 69 73 20 69 6e 74 65 72 66 65 72 69 6e 67 20   is interfering 
8ea0: 77 69 74 68 20 53 51 4c 69 74 65 27 73 20 6a 6f  with SQLite's jo
8eb0: 75 72 6e 61 6c 20 66 69 6c 65 2c 20 79 6f 75 20  urnal file, you 
8ec0: 6d 61 79 20 72 65 63 65 69 76 65 20 65 72 72 6f  may receive erro
8ed0: 72 73 20 6c 69 6b 65 20 22 75 6e 61 62 6c 65 20  rs like "unable 
8ee0: 74 6f 20 6f 70 65 6e 20 64 61 74 61 62 61 73 65  to open database
8ef0: 20 66 69 6c 65 22 0d 0a 20 20 2f 2f 2f 20 77 68   file"..  /// wh
8f00: 65 6e 20 73 74 61 72 74 69 6e 67 20 61 20 74 72  en starting a tr
8f10: 61 6e 73 61 63 74 69 6f 6e 2e 20 20 49 66 20 74  ansaction.  If t
8f20: 68 69 73 20 69 73 20 68 61 70 70 65 6e 69 6e 67  his is happening
8f30: 2c 20 79 6f 75 20 6d 61 79 20 77 61 6e 74 20 74  , you may want t
8f40: 6f 20 63 68 61 6e 67 65 20 74 68 65 20 64 65 66  o change the def
8f50: 61 75 6c 74 20 6a 6f 75 72 6e 61 6c 20 6d 6f 64  ault journal mod
8f60: 65 20 74 6f 20 50 65 72 73 69 73 74 2e 0d 0a 20  e to Persist... 
8f70: 20 2f 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73 3e 0d   /// </remarks>.
8f80: 0a 20 20 70 75 62 6c 69 63 20 65 6e 75 6d 20 53  .  public enum S
8f90: 51 4c 69 74 65 4a 6f 75 72 6e 61 6c 4d 6f 64 65  QLiteJournalMode
8fa0: 45 6e 75 6d 0d 0a 20 20 7b 0d 0a 20 20 20 20 2f  Enum..  {..    /
8fb0: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
8fc0: 20 20 2f 2f 2f 20 54 68 65 20 64 65 66 61 75 6c    /// The defaul
8fd0: 74 20 6d 6f 64 65 2c 20 74 68 69 73 20 63 61 75  t mode, this cau
8fe0: 73 65 73 20 53 51 4c 69 74 65 20 74 6f 20 75 73  ses SQLite to us
8ff0: 65 20 74 68 65 20 65 78 69 73 74 69 6e 67 20 6a  e the existing j
9000: 6f 75 72 6e 61 6c 69 6e 67 20 6d 6f 64 65 20 66  ournaling mode f
9010: 6f 72 20 74 68 65 20 64 61 74 61 62 61 73 65 2e  or the database.
9020: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
9030: 61 72 79 3e 0d 0a 20 20 20 20 44 65 66 61 75 6c  ary>..    Defaul
9040: 74 20 3d 20 2d 31 2c 0d 0a 20 20 20 20 2f 2f 2f  t = -1,..    ///
9050: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
9060: 2f 2f 2f 20 53 51 4c 69 74 65 20 77 69 6c 6c 20  /// SQLite will 
9070: 63 72 65 61 74 65 20 61 6e 64 20 64 65 73 74 72  create and destr
9080: 6f 79 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20 66  oy the journal f
9090: 69 6c 65 20 61 73 2d 6e 65 65 64 65 64 2e 0d 0a  ile as-needed...
90a0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
90b0: 79 3e 0d 0a 20 20 20 20 44 65 6c 65 74 65 20 3d  y>..    Delete =
90c0: 20 30 2c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75   0,..    /// <su
90d0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
90e0: 57 68 65 6e 20 74 68 69 73 20 69 73 20 73 65 74  When this is set
90f0: 2c 20 53 51 4c 69 74 65 20 77 69 6c 6c 20 6b 65  , SQLite will ke
9100: 65 70 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20 66  ep the journal f
9110: 69 6c 65 20 65 76 65 6e 20 61 66 74 65 72 20 61  ile even after a
9120: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 68 61 73   transaction has
9130: 20 63 6f 6d 70 6c 65 74 65 64 2e 20 20 49 74 27   completed.  It'
9140: 73 20 63 6f 6e 74 65 6e 74 73 20 77 69 6c 6c 20  s contents will 
9150: 62 65 20 65 72 61 73 65 64 2c 0d 0a 20 20 20 20  be erased,..    
9160: 2f 2f 2f 20 61 6e 64 20 74 68 65 20 6a 6f 75 72  /// and the jour
9170: 6e 61 6c 20 72 65 2d 75 73 65 64 20 61 73 20 6f  nal re-used as o
9180: 66 74 65 6e 20 61 73 20 6e 65 65 64 65 64 2e 20  ften as needed. 
9190: 20 49 66 20 69 74 20 69 73 20 64 65 6c 65 74 65   If it is delete
91a0: 64 2c 20 69 74 20 77 69 6c 6c 20 62 65 20 72 65  d, it will be re
91b0: 63 72 65 61 74 65 64 20 74 68 65 20 6e 65 78 74  created the next
91c0: 20 74 69 6d 65 20 69 74 20 69 73 20 6e 65 65 64   time it is need
91d0: 65 64 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ed...    /// </s
91e0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 50 65 72  ummary>..    Per
91f0: 73 69 73 74 20 3d 20 31 2c 0d 0a 20 20 20 20 2f  sist = 1,..    /
9200: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
9210: 20 20 2f 2f 2f 20 54 68 69 73 20 6f 70 74 69 6f    /// This optio
9220: 6e 20 64 69 73 61 62 6c 65 73 20 74 68 65 20 72  n disables the r
9230: 6f 6c 6c 62 61 63 6b 20 6a 6f 75 72 6e 61 6c 20  ollback journal 
9240: 65 6e 74 69 72 65 6c 79 2e 20 20 49 6e 74 65 72  entirely.  Inter
9250: 72 75 70 74 65 64 20 74 72 61 6e 73 61 63 74 69  rupted transacti
9260: 6f 6e 73 20 6f 72 20 61 20 70 72 6f 67 72 61 6d  ons or a program
9270: 20 63 72 61 73 68 20 63 61 6e 20 63 61 75 73 65   crash can cause
9280: 20 64 61 74 61 62 61 73 65 0d 0a 20 20 20 20 2f   database..    /
9290: 2f 2f 20 63 6f 72 72 75 70 74 69 6f 6e 20 69 6e  // corruption in
92a0: 20 74 68 69 73 20 6d 6f 64 65 21 0d 0a 20 20 20   this mode!..   
92b0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
92c0: 0a 20 20 20 20 4f 66 66 20 3d 20 32 2c 0d 0a 20  .    Off = 2,.. 
92d0: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
92e0: 0d 0a 20 20 20 20 2f 2f 2f 20 53 51 4c 69 74 65  ..    /// SQLite
92f0: 20 77 69 6c 6c 20 74 72 75 6e 63 61 74 65 20 74   will truncate t
9300: 68 65 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20  he journal file 
9310: 74 6f 20 7a 65 72 6f 2d 6c 65 6e 67 74 68 20 69  to zero-length i
9320: 6e 73 74 65 61 64 20 6f 66 20 64 65 6c 65 74 69  nstead of deleti
9330: 6e 67 20 69 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20  ng it...    /// 
9340: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
9350: 54 72 75 6e 63 61 74 65 20 3d 20 33 2c 0d 0a 20  Truncate = 3,.. 
9360: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
9370: 0d 0a 20 20 20 20 2f 2f 2f 20 53 51 4c 69 74 65  ..    /// SQLite
9380: 20 77 69 6c 6c 20 73 74 6f 72 65 20 74 68 65 20   will store the 
9390: 6a 6f 75 72 6e 61 6c 20 69 6e 20 76 6f 6c 61 74  journal in volat
93a0: 69 6c 65 20 52 41 4d 2e 20 20 54 68 69 73 20 73  ile RAM.  This s
93b0: 61 76 65 73 20 64 69 73 6b 20 49 2f 4f 20 62 75  aves disk I/O bu
93c0: 74 20 61 74 20 74 68 65 20 65 78 70 65 6e 73 65  t at the expense
93d0: 20 6f 66 20 64 61 74 61 62 61 73 65 20 73 61 66   of database saf
93e0: 65 74 79 20 61 6e 64 20 69 6e 74 65 67 72 69 74  ety and integrit
93f0: 79 2e 0d 0a 20 20 20 20 2f 2f 2f 20 49 66 20 74  y...    /// If t
9400: 68 65 20 61 70 70 6c 69 63 61 74 69 6f 6e 20 75  he application u
9410: 73 69 6e 67 20 53 51 4c 69 74 65 20 63 72 61 73  sing SQLite cras
9420: 68 65 73 20 69 6e 20 74 68 65 20 6d 69 64 64 6c  hes in the middl
9430: 65 20 6f 66 20 61 20 74 72 61 6e 73 61 63 74 69  e of a transacti
9440: 6f 6e 20 77 68 65 6e 20 74 68 65 20 4d 45 4d 4f  on when the MEMO
9450: 52 59 20 6a 6f 75 72 6e 61 6c 69 6e 67 20 6d 6f  RY journaling mo
9460: 64 65 20 69 73 20 73 65 74 2c 20 74 68 65 6e 20  de is set, then 
9470: 74 68 65 0d 0a 20 20 20 20 2f 2f 2f 20 64 61 74  the..    /// dat
9480: 61 62 61 73 65 20 66 69 6c 65 20 77 69 6c 6c 20  abase file will 
9490: 76 65 72 79 20 6c 69 6b 65 6c 79 20 67 6f 20 63  very likely go c
94a0: 6f 72 72 75 70 74 2e 0d 0a 20 20 20 20 2f 2f 2f  orrupt...    ///
94b0: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20   </summary>..   
94c0: 20 4d 65 6d 6f 72 79 20 3d 20 34 2c 0d 0a 20 20   Memory = 4,..  
94d0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
94e0: 0a 20 20 20 20 2f 2f 2f 20 53 51 4c 69 74 65 20  .    /// SQLite 
94f0: 75 73 65 73 20 61 20 77 72 69 74 65 2d 61 68 65  uses a write-ahe
9500: 61 64 20 6c 6f 67 20 69 6e 73 74 65 61 64 20 6f  ad log instead o
9510: 66 20 61 20 72 6f 6c 6c 62 61 63 6b 20 6a 6f 75  f a rollback jou
9520: 72 6e 61 6c 20 74 6f 20 69 6d 70 6c 65 6d 65 6e  rnal to implemen
9530: 74 20 74 72 61 6e 73 61 63 74 69 6f 6e 73 2e 20  t transactions. 
9540: 20 54 68 65 20 57 41 4c 20 6a 6f 75 72 6e 61 6c   The WAL journal
9550: 69 6e 67 20 6d 6f 64 65 20 69 73 20 70 65 72 73  ing mode is pers
9560: 69 73 74 65 6e 74 3b 0d 0a 20 20 20 20 2f 2f 2f  istent;..    ///
9570: 20 61 66 74 65 72 20 62 65 69 6e 67 20 73 65 74   after being set
9580: 20 69 74 20 73 74 61 79 73 20 69 6e 20 65 66 66   it stays in eff
9590: 65 63 74 20 61 63 72 6f 73 73 20 6d 75 6c 74 69  ect across multi
95a0: 70 6c 65 20 64 61 74 61 62 61 73 65 20 63 6f 6e  ple database con
95b0: 6e 65 63 74 69 6f 6e 73 20 61 6e 64 20 61 66 74  nections and aft
95c0: 65 72 20 63 6c 6f 73 69 6e 67 20 61 6e 64 20 72  er closing and r
95d0: 65 6f 70 65 6e 69 6e 67 20 74 68 65 20 64 61 74  eopening the dat
95e0: 61 62 61 73 65 2e 20 41 20 64 61 74 61 62 61 73  abase. A databas
95f0: 65 0d 0a 20 20 20 20 2f 2f 2f 20 69 6e 20 57 41  e..    /// in WA
9600: 4c 20 6a 6f 75 72 6e 61 6c 69 6e 67 20 6d 6f 64  L journaling mod
9610: 65 20 63 61 6e 20 6f 6e 6c 79 20 62 65 20 61 63  e can only be ac
9620: 63 65 73 73 65 64 20 62 79 20 53 51 4c 69 74 65  cessed by SQLite
9630: 20 76 65 72 73 69 6f 6e 20 33 2e 37 2e 30 20 6f   version 3.7.0 o
9640: 72 20 6c 61 74 65 72 2e 0d 0a 20 20 20 20 2f 2f  r later...    //
9650: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
9660: 20 20 57 61 6c 20 3d 20 35 0d 0a 20 20 7d 0d 0a    Wal = 5..  }..
9670: 0d 0a 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79  ..  /// <summary
9680: 3e 0d 0a 20 20 2f 2f 2f 20 53 74 72 75 63 74 20  >..  /// Struct 
9690: 75 73 65 64 20 69 6e 74 65 72 6e 61 6c 6c 79 20  used internally 
96a0: 74 6f 20 64 65 74 65 72 6d 69 6e 65 20 74 68 65  to determine the
96b0: 20 64 61 74 61 74 79 70 65 20 6f 66 20 61 20 63   datatype of a c
96c0: 6f 6c 75 6d 6e 20 69 6e 20 61 20 72 65 73 75 6c  olumn in a resul
96d0: 74 73 65 74 0d 0a 20 20 2f 2f 2f 20 3c 2f 73 75  tset..  /// </su
96e0: 6d 6d 61 72 79 3e 0d 0a 20 20 69 6e 74 65 72 6e  mmary>..  intern
96f0: 61 6c 20 63 6c 61 73 73 20 53 51 4c 69 74 65 54  al class SQLiteT
9700: 79 70 65 0d 0a 20 20 7b 0d 0a 20 20 20 20 2f 2f  ype..  {..    //
9710: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
9720: 20 2f 2f 2f 20 54 68 65 20 44 62 54 79 70 65 20   /// The DbType 
9730: 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 2c 20 6f  of the column, o
9740: 72 20 44 62 54 79 70 65 2e 4f 62 6a 65 63 74 20  r DbType.Object 
9750: 69 66 20 69 74 20 63 61 6e 6e 6f 74 20 62 65 20  if it cannot be 
9760: 64 65 74 65 72 6d 69 6e 65 64 0d 0a 20 20 20 20  determined..    
9770: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
9780: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 44 62 54      internal DbT
9790: 79 70 65 20 54 79 70 65 3b 0d 0a 20 20 20 20 2f  ype Type;..    /
97a0: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
97b0: 20 20 2f 2f 2f 20 54 68 65 20 61 66 66 69 6e 69    /// The affini
97c0: 74 79 20 6f 66 20 61 20 63 6f 6c 75 6d 6e 2c 20  ty of a column, 
97d0: 75 73 65 64 20 66 6f 72 20 65 78 70 72 65 73 73  used for express
97e0: 69 6f 6e 73 20 6f 72 20 77 68 65 6e 20 54 79 70  ions or when Typ
97f0: 65 20 69 73 20 44 62 54 79 70 65 2e 4f 62 6a 65  e is DbType.Obje
9800: 63 74 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ct..    /// </su
9810: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 69 6e 74 65  mmary>..    inte
9820: 72 6e 61 6c 20 54 79 70 65 41 66 66 69 6e 69 74  rnal TypeAffinit
9830: 79 20 41 66 66 69 6e 69 74 79 3b 0d 0a 20 20 7d  y Affinity;..  }
9840: 0d 0a 0d 0a 20 20 69 6e 74 65 72 6e 61 6c 20 73  ....  internal s
9850: 74 72 75 63 74 20 53 51 4c 69 74 65 54 79 70 65  truct SQLiteType
9860: 4e 61 6d 65 73 0d 0a 20 20 7b 0d 0a 20 20 20 20  Names..  {..    
9870: 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74 65 54  internal SQLiteT
9880: 79 70 65 4e 61 6d 65 73 28 73 74 72 69 6e 67 20  ypeNames(string 
9890: 6e 65 77 74 79 70 65 4e 61 6d 65 2c 20 44 62 54  newtypeName, DbT
98a0: 79 70 65 20 6e 65 77 64 61 74 61 54 79 70 65 29  ype newdataType)
98b0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 74  ..    {..      t
98c0: 79 70 65 4e 61 6d 65 20 3d 20 6e 65 77 74 79 70  ypeName = newtyp
98d0: 65 4e 61 6d 65 3b 0d 0a 20 20 20 20 20 20 64 61  eName;..      da
98e0: 74 61 54 79 70 65 20 3d 20 6e 65 77 64 61 74 61  taType = newdata
98f0: 54 79 70 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  Type;..    }....
9900: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 72      internal str
9910: 69 6e 67 20 74 79 70 65 4e 61 6d 65 3b 0d 0a 20  ing typeName;.. 
9920: 20 20 20 69 6e 74 65 72 6e 61 6c 20 44 62 54 79     internal DbTy
9930: 70 65 20 64 61 74 61 54 79 70 65 3b 0d 0a 20 20  pe dataType;..  
9940: 7d 0d 0a 0d 0a 20 20 69 6e 74 65 72 6e 61 6c 20  }....  internal 
9950: 63 6c 61 73 73 20 54 79 70 65 4e 61 6d 65 53 74  class TypeNameSt
9960: 72 69 6e 67 43 6f 6d 70 61 72 65 72 20 3a 20 49  ringComparer : I
9970: 45 71 75 61 6c 69 74 79 43 6f 6d 70 61 72 65 72  EqualityComparer
9980: 3c 73 74 72 69 6e 67 3e 0d 0a 20 20 7b 0d 0a 20  <string>..  {.. 
9990: 20 20 20 23 72 65 67 69 6f 6e 20 49 45 71 75 61     #region IEqua
99a0: 6c 69 74 79 43 6f 6d 70 61 72 65 72 3c 73 74 72  lityComparer<str
99b0: 69 6e 67 3e 20 4d 65 6d 62 65 72 73 0d 0a 20 20  ing> Members..  
99c0: 20 20 70 75 62 6c 69 63 20 62 6f 6f 6c 20 45 71    public bool Eq
99d0: 75 61 6c 73 28 0d 0a 20 20 20 20 20 20 73 74 72  uals(..      str
99e0: 69 6e 67 20 6c 65 66 74 2c 0d 0a 20 20 20 20 20  ing left,..     
99f0: 20 73 74 72 69 6e 67 20 72 69 67 68 74 0d 0a 20   string right.. 
9a00: 20 20 20 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20       )..    {.. 
9a10: 20 20 20 20 20 72 65 74 75 72 6e 20 53 74 72 69       return Stri
9a20: 6e 67 2e 45 71 75 61 6c 73 28 6c 65 66 74 2c 20  ng.Equals(left, 
9a30: 72 69 67 68 74 2c 20 53 74 72 69 6e 67 43 6f 6d  right, StringCom
9a40: 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e 61 6c 49  parison.OrdinalI
9a50: 67 6e 6f 72 65 43 61 73 65 29 3b 0d 0a 20 20 20  gnoreCase);..   
9a60: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f 2f 2f   }....    //////
9a70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
9a80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
9a90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
9aa0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
9ab0: 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 70 75 62  /////....    pub
9ac0: 6c 69 63 20 69 6e 74 20 47 65 74 48 61 73 68 43  lic int GetHashC
9ad0: 6f 64 65 28 0d 0a 20 20 20 20 20 20 73 74 72 69  ode(..      stri
9ae0: 6e 67 20 76 61 6c 75 65 0d 0a 20 20 20 20 20 20  ng value..      
9af0: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
9b00: 2f 2f 0d 0a 20 20 20 20 20 20 2f 2f 20 4e 4f 54  //..      // NOT
9b10: 45 3a 20 54 68 65 20 6f 6e 6c 79 20 74 68 69 6e  E: The only thin
9b20: 67 20 74 68 61 74 20 77 65 20 6d 75 73 74 20 67  g that we must g
9b30: 75 61 72 61 6e 74 65 65 20 68 65 72 65 2c 20 61  uarantee here, a
9b40: 63 63 6f 72 64 69 6e 67 0d 0a 20 20 20 20 20 20  ccording..      
9b50: 2f 2f 20 20 20 20 20 20 20 74 6f 20 74 68 65 20  //       to the 
9b60: 4d 53 44 4e 20 64 6f 63 75 6d 65 6e 74 61 74 69  MSDN documentati
9b70: 6f 6e 20 66 6f 72 20 49 45 71 75 61 6c 69 74 79  on for IEquality
9b80: 43 6f 6d 70 61 72 65 72 2c 20 69 73 20 0d 0a 20  Comparer, is .. 
9b90: 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 74 68       //       th
9ba0: 61 74 20 66 6f 72 20 74 77 6f 20 67 69 76 65 6e  at for two given
9bb0: 20 73 74 72 69 6e 67 73 2c 20 69 66 20 45 71 75   strings, if Equ
9bc0: 61 6c 73 20 72 65 74 75 72 6e 20 74 72 75 65 20  als return true 
9bd0: 74 68 65 6e 20 0d 0a 20 20 20 20 20 20 2f 2f 20  then ..      // 
9be0: 20 20 20 20 20 20 74 68 65 20 74 77 6f 20 73 74        the two st
9bf0: 72 69 6e 67 73 20 6d 75 73 74 20 68 61 73 68 20  rings must hash 
9c00: 74 6f 20 74 68 65 20 73 61 6d 65 20 76 61 6c 75  to the same valu
9c10: 65 2e 0d 0a 20 20 20 20 20 20 2f 2f 0d 0a 20 20  e...      //..  
9c20: 20 20 20 20 69 66 20 28 76 61 6c 75 65 20 21 3d      if (value !=
9c30: 20 6e 75 6c 6c 29 0d 0a 23 69 66 20 21 50 4c 41   null)..#if !PLA
9c40: 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41  TFORM_COMPACTFRA
9c50: 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20  MEWORK..        
9c60: 72 65 74 75 72 6e 20 76 61 6c 75 65 2e 54 6f 4c  return value.ToL
9c70: 6f 77 65 72 49 6e 76 61 72 69 61 6e 74 28 29 2e  owerInvariant().
9c80: 47 65 74 48 61 73 68 43 6f 64 65 28 29 3b 0d 0a  GetHashCode();..
9c90: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 72  #else..        r
9ca0: 65 74 75 72 6e 20 76 61 6c 75 65 2e 54 6f 4c 6f  eturn value.ToLo
9cb0: 77 65 72 28 29 2e 47 65 74 48 61 73 68 43 6f 64  wer().GetHashCod
9cc0: 65 28 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20  e();..#endif..  
9cd0: 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20      else..      
9ce0: 20 20 74 68 72 6f 77 20 6e 65 77 20 41 72 67 75    throw new Argu
9cf0: 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f  mentNullExceptio
9d00: 6e 28 22 76 61 6c 75 65 22 29 3b 0d 0a 20 20 20  n("value");..   
9d10: 20 7d 0d 0a 20 20 20 20 23 65 6e 64 72 65 67 69   }..    #endregi
9d20: 6f 6e 0d 0a 20 20 7d 0d 0a 7d 0d 0a              on..  }..}..