System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact b60b57194e57d0d816af300626c23177ce007cfe:


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 0a 20 2a 20  ************. * 
0040: 41 44 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74 61  ADO.NET 2.0 Data
0050: 20 50 72 6f 76 69 64 65 72 20 66 6f 72 20 53 51   Provider for SQ
0060: 4c 69 74 65 20 56 65 72 73 69 6f 6e 20 33 2e 58  Lite Version 3.X
0070: 0a 20 2a 20 57 72 69 74 74 65 6e 20 62 79 20 52  . * Written by R
0080: 6f 62 65 72 74 20 53 69 6d 70 73 6f 6e 20 28 72  obert Simpson (r
0090: 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73 74 6c  obert@blackcastl
00a0: 65 73 6f 66 74 2e 63 6f 6d 29 0a 20 2a 20 0a 20  esoft.com). * . 
00b0: 2a 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74 68  * Released to th
00c0: 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c  e public domain,
00d0: 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77 6e   use at your own
00e0: 20 72 69 73 6b 21 0a 20 2a 2a 2a 2a 2a 2a 2a 2a   risk!. ********
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2f 0a 0a 6e 61 6d 65 73 70 61 63 65 20 53 79 73  /..namespace Sys
0130: 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 0a  tem.Data.SQLite.
0140: 7b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d  {.  using System
0150: 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d  ;.  using System
0160: 2e 44 61 74 61 3b 0a 20 20 75 73 69 6e 67 20 53  .Data;.  using S
0170: 79 73 74 65 6d 2e 44 61 74 61 2e 43 6f 6d 6d 6f  ystem.Data.Commo
0180: 6e 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65  n;.  using Syste
0190: 6d 2e 43 6f 6c 6c 65 63 74 69 6f 6e 73 2e 47 65  m.Collections.Ge
01a0: 6e 65 72 69 63 3b 0a 20 20 75 73 69 6e 67 20 53  neric;.  using S
01b0: 79 73 74 65 6d 2e 47 6c 6f 62 61 6c 69 7a 61 74  ystem.Globalizat
01c0: 69 6f 6e 3b 0a 20 20 75 73 69 6e 67 20 53 79 73  ion;.  using Sys
01d0: 74 65 6d 2e 52 65 66 6c 65 63 74 69 6f 6e 3b 0a  tem.Reflection;.
01e0: 0a 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e  .  /// <summary>
01f0: 0a 20 20 2f 2f 2f 20 53 51 4c 69 74 65 20 69 6d  .  /// SQLite im
0200: 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66 20  plementation of 
0210: 44 62 44 61 74 61 52 65 61 64 65 72 2e 0a 20 20  DbDataReader..  
0220: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
0230: 20 70 75 62 6c 69 63 20 73 65 61 6c 65 64 20 63   public sealed c
0240: 6c 61 73 73 20 53 51 4c 69 74 65 44 61 74 61 52  lass SQLiteDataR
0250: 65 61 64 65 72 20 3a 20 44 62 44 61 74 61 52 65  eader : DbDataRe
0260: 61 64 65 72 0a 20 20 7b 0a 20 20 20 20 2f 2f 2f  ader.  {.    ///
0270: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
0280: 2f 2f 20 55 6e 64 65 72 6c 79 69 6e 67 20 63 6f  // Underlying co
0290: 6d 6d 61 6e 64 20 74 68 69 73 20 72 65 61 64 65  mmand this reade
02a0: 72 20 69 73 20 61 74 74 61 63 68 65 64 20 74 6f  r is attached to
02b0: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
02c0: 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74 65 20  ry>.    private 
02d0: 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 5f 63  SQLiteCommand _c
02e0: 6f 6d 6d 61 6e 64 3b 0a 20 20 20 20 2f 2f 2f 20  ommand;.    /// 
02f0: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
0300: 2f 20 49 6e 64 65 78 20 6f 66 20 74 68 65 20 63  / Index of the c
0310: 75 72 72 65 6e 74 20 73 74 61 74 65 6d 65 6e 74  urrent statement
0320: 20 69 6e 20 74 68 65 20 63 6f 6d 6d 61 6e 64 20   in the command 
0330: 62 65 69 6e 67 20 70 72 6f 63 65 73 73 65 64 0a  being processed.
0340: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
0350: 79 3e 0a 20 20 20 20 70 72 69 76 61 74 65 20 69  y>.    private i
0360: 6e 74 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d  nt _activeStatem
0370: 65 6e 74 49 6e 64 65 78 3b 0a 20 20 20 20 2f 2f  entIndex;.    //
0380: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20  / <summary>.    
0390: 2f 2f 2f 20 43 75 72 72 65 6e 74 20 73 74 61 74  /// Current stat
03a0: 65 6d 65 6e 74 20 62 65 69 6e 67 20 52 65 61 64  ement being Read
03b0: 28 29 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ().    /// </sum
03c0: 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74  mary>.    privat
03d0: 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  e SQLiteStatemen
03e0: 74 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65  t _activeStateme
03f0: 6e 74 3b 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d  nt;.    /// <sum
0400: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 53 74  mary>.    /// St
0410: 61 74 65 20 6f 66 20 74 68 65 20 63 75 72 72 65  ate of the curre
0420: 6e 74 20 73 74 61 74 65 6d 65 6e 74 20 62 65 69  nt statement bei
0430: 6e 67 20 70 72 6f 63 65 73 73 65 64 2e 0a 20 20  ng processed..  
0440: 20 20 2f 2f 2f 20 2d 31 20 3d 20 46 69 72 73 74    /// -1 = First
0450: 20 53 74 65 70 28 29 20 65 78 65 63 75 74 65 64   Step() executed
0460: 2c 20 73 6f 20 74 68 65 20 66 69 72 73 74 20 52  , so the first R
0470: 65 61 64 28 29 20 77 69 6c 6c 20 62 65 20 69 67  ead() will be ig
0480: 6e 6f 72 65 64 0a 20 20 20 20 2f 2f 2f 20 20 30  nored.    ///  0
0490: 20 3d 20 41 63 74 69 76 65 6c 79 20 72 65 61 64   = Actively read
04a0: 69 6e 67 0a 20 20 20 20 2f 2f 2f 20 20 31 20 3d  ing.    ///  1 =
04b0: 20 46 69 6e 69 73 68 65 64 20 72 65 61 64 69 6e   Finished readin
04c0: 67 0a 20 20 20 20 2f 2f 2f 20 20 32 20 3d 20 4e  g.    ///  2 = N
04d0: 6f 6e 2d 72 6f 77 2d 72 65 74 75 72 6e 69 6e 67  on-row-returning
04e0: 20 73 74 61 74 65 6d 65 6e 74 2c 20 6e 6f 20 72   statement, no r
04f0: 65 63 6f 72 64 73 0a 20 20 20 20 2f 2f 2f 20 3c  ecords.    /// <
0500: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72  /summary>.    pr
0510: 69 76 61 74 65 20 69 6e 74 20 5f 72 65 61 64 69  ivate int _readi
0520: 6e 67 53 74 61 74 65 3b 0a 20 20 20 20 2f 2f 2f  ngState;.    ///
0530: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
0540: 2f 2f 20 4e 75 6d 62 65 72 20 6f 66 20 72 65 63  // Number of rec
0550: 6f 72 64 73 20 61 66 66 65 63 74 65 64 20 62 79  ords affected by
0560: 20 74 68 65 20 69 6e 73 65 72 74 2f 75 70 64 61   the insert/upda
0570: 74 65 20 73 74 61 74 65 6d 65 6e 74 73 20 65 78  te statements ex
0580: 65 63 75 74 65 64 20 6f 6e 20 74 68 65 20 63 6f  ecuted on the co
0590: 6d 6d 61 6e 64 0a 20 20 20 20 2f 2f 2f 20 3c 2f  mmand.    /// </
05a0: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 69  summary>.    pri
05b0: 76 61 74 65 20 69 6e 74 20 5f 72 6f 77 73 41 66  vate int _rowsAf
05c0: 66 65 63 74 65 64 3b 0a 20 20 20 20 2f 2f 2f 20  fected;.    /// 
05d0: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
05e0: 2f 20 43 6f 75 6e 74 20 6f 66 20 66 69 65 6c 64  / Count of field
05f0: 73 20 28 63 6f 6c 75 6d 6e 73 29 20 69 6e 20 74  s (columns) in t
0600: 68 65 20 72 6f 77 2d 72 65 74 75 72 6e 69 6e 67  he row-returning
0610: 20 73 74 61 74 65 6d 65 6e 74 20 63 75 72 72 65   statement curre
0620: 6e 74 6c 79 20 62 65 69 6e 67 20 70 72 6f 63 65  ntly being proce
0630: 73 73 65 64 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ssed.    /// </s
0640: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76  ummary>.    priv
0650: 61 74 65 20 69 6e 74 20 5f 66 69 65 6c 64 43 6f  ate int _fieldCo
0660: 75 6e 74 3b 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  unt;.    /// <su
0670: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 44  mmary>.    /// D
0680: 61 74 61 74 79 70 65 73 20 6f 66 20 61 63 74 69  atatypes of acti
0690: 76 65 20 66 69 65 6c 64 73 20 28 63 6f 6c 75 6d  ve fields (colum
06a0: 6e 73 29 20 69 6e 20 74 68 65 20 63 75 72 72 65  ns) in the curre
06b0: 6e 74 20 73 74 61 74 65 6d 65 6e 74 2c 20 75 73  nt statement, us
06c0: 65 64 20 66 6f 72 20 74 79 70 65 2d 72 65 73 74  ed for type-rest
06d0: 72 69 63 74 69 6e 67 20 64 61 74 61 0a 20 20 20  ricting data.   
06e0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
06f0: 20 20 20 20 70 72 69 76 61 74 65 20 53 51 4c 69      private SQLi
0700: 74 65 54 79 70 65 5b 5d 20 5f 66 69 65 6c 64 54  teType[] _fieldT
0710: 79 70 65 41 72 72 61 79 3b 0a 0a 20 20 20 20 2f  ypeArray;..    /
0720: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20  // <summary>.   
0730: 20 2f 2f 2f 20 54 68 65 20 62 65 68 61 76 69 6f   /// The behavio
0740: 72 20 6f 66 20 74 68 65 20 64 61 74 61 72 65 61  r of the datarea
0750: 64 65 72 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  der.    /// </su
0760: 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61  mmary>.    priva
0770: 74 65 20 43 6f 6d 6d 61 6e 64 42 65 68 61 76 69  te CommandBehavi
0780: 6f 72 20 5f 63 6f 6d 6d 61 6e 64 42 65 68 61 76  or _commandBehav
0790: 69 6f 72 3b 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73  ior;..    /// <s
07a0: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
07b0: 49 66 20 73 65 74 2c 20 74 68 65 6e 20 64 69 73  If set, then dis
07c0: 70 6f 73 65 20 6f 66 20 74 68 65 20 63 6f 6d 6d  pose of the comm
07d0: 61 6e 64 20 6f 62 6a 65 63 74 20 77 68 65 6e 20  and object when 
07e0: 74 68 65 20 72 65 61 64 65 72 20 69 73 20 66 69  the reader is fi
07f0: 6e 69 73 68 65 64 0a 20 20 20 20 2f 2f 2f 20 3c  nished.    /// <
0800: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 69 6e  /summary>.    in
0810: 74 65 72 6e 61 6c 20 62 6f 6f 6c 20 5f 64 69 73  ternal bool _dis
0820: 70 6f 73 65 43 6f 6d 6d 61 6e 64 3b 0a 0a 20 20  poseCommand;..  
0830: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
0840: 20 20 20 20 2f 2f 2f 20 41 6e 20 61 72 72 61 79      /// An array
0850: 20 6f 66 20 72 6f 77 69 64 27 73 20 66 6f 72 20   of rowid's for 
0860: 74 68 65 20 61 63 74 69 76 65 20 73 74 61 74 65  the active state
0870: 6d 65 6e 74 20 69 66 20 43 6f 6d 6d 61 6e 64 42  ment if CommandB
0880: 65 68 61 76 69 6f 72 2e 4b 65 79 49 6e 66 6f 20  ehavior.KeyInfo 
0890: 69 73 20 73 70 65 63 69 66 69 65 64 0a 20 20 20  is specified.   
08a0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
08b0: 20 20 20 20 70 72 69 76 61 74 65 20 53 51 4c 69      private SQLi
08c0: 74 65 4b 65 79 52 65 61 64 65 72 20 5f 6b 65 79  teKeyReader _key
08d0: 49 6e 66 6f 3b 0a 0a 20 20 20 20 69 6e 74 65 72  Info;..    inter
08e0: 6e 61 6c 20 6c 6f 6e 67 20 5f 76 65 72 73 69 6f  nal long _versio
08f0: 6e 3b 20 2f 2f 20 4d 61 74 63 68 65 73 20 74 68  n; // Matches th
0900: 65 20 76 65 72 73 69 6f 6e 20 6f 66 20 74 68 65  e version of the
0910: 20 63 6f 6e 6e 65 63 74 69 6f 6e 0a 0a 20 20 20   connection..   
0920: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
0930: 20 20 20 2f 2f 2f 20 49 6e 74 65 72 6e 61 6c 20     /// Internal 
0940: 63 6f 6e 73 74 72 75 63 74 6f 72 2c 20 69 6e 69  constructor, ini
0950: 74 69 61 6c 69 7a 65 73 20 74 68 65 20 64 61 74  tializes the dat
0960: 61 72 65 61 64 65 72 20 61 6e 64 20 73 65 74 73  areader and sets
0970: 20 75 70 20 74 6f 20 62 65 67 69 6e 20 65 78 65   up to begin exe
0980: 63 75 74 69 6e 67 20 73 74 61 74 65 6d 65 6e 74  cuting statement
0990: 73 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  s.    /// </summ
09a0: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  ary>.    /// <pa
09b0: 72 61 6d 20 6e 61 6d 65 3d 22 63 6d 64 22 3e 54  ram name="cmd">T
09c0: 68 65 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64  he SQLiteCommand
09d0: 20 74 68 69 73 20 64 61 74 61 20 72 65 61 64 65   this data reade
09e0: 72 20 69 73 20 66 6f 72 3c 2f 70 61 72 61 6d 3e  r is for</param>
09f0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
0a00: 6e 61 6d 65 3d 22 62 65 68 61 76 65 22 3e 54 68  name="behave">Th
0a10: 65 20 65 78 70 65 63 74 65 64 20 62 65 68 61 76  e expected behav
0a20: 69 6f 72 20 6f 66 20 74 68 65 20 64 61 74 61 20  ior of the data 
0a30: 72 65 61 64 65 72 3c 2f 70 61 72 61 6d 3e 0a 20  reader</param>. 
0a40: 20 20 20 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69     internal SQLi
0a50: 74 65 44 61 74 61 52 65 61 64 65 72 28 53 51 4c  teDataReader(SQL
0a60: 69 74 65 43 6f 6d 6d 61 6e 64 20 63 6d 64 2c 20  iteCommand cmd, 
0a70: 43 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72 20  CommandBehavior 
0a80: 62 65 68 61 76 65 29 0a 20 20 20 20 7b 0a 20 20  behave).    {.  
0a90: 20 20 20 20 5f 63 6f 6d 6d 61 6e 64 20 3d 20 63      _command = c
0aa0: 6d 64 3b 0a 20 20 20 20 20 20 5f 76 65 72 73 69  md;.      _versi
0ab0: 6f 6e 20 3d 20 5f 63 6f 6d 6d 61 6e 64 2e 43 6f  on = _command.Co
0ac0: 6e 6e 65 63 74 69 6f 6e 2e 5f 76 65 72 73 69 6f  nnection._versio
0ad0: 6e 3b 0a 0a 20 20 20 20 20 20 5f 63 6f 6d 6d 61  n;..      _comma
0ae0: 6e 64 42 65 68 61 76 69 6f 72 20 3d 20 62 65 68  ndBehavior = beh
0af0: 61 76 65 3b 0a 20 20 20 20 20 20 5f 61 63 74 69  ave;.      _acti
0b00: 76 65 53 74 61 74 65 6d 65 6e 74 49 6e 64 65 78  veStatementIndex
0b10: 20 3d 20 2d 31 3b 0a 20 20 20 20 20 20 5f 72 6f   = -1;.      _ro
0b20: 77 73 41 66 66 65 63 74 65 64 20 3d 20 2d 31 3b  wsAffected = -1;
0b30: 0a 0a 20 20 20 20 20 20 69 66 20 28 5f 63 6f 6d  ..      if (_com
0b40: 6d 61 6e 64 20 21 3d 20 6e 75 6c 6c 29 0a 20 20  mand != null).  
0b50: 20 20 20 20 20 20 4e 65 78 74 52 65 73 75 6c 74        NextResult
0b60: 28 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  ();.    }..    i
0b70: 6e 74 65 72 6e 61 6c 20 76 6f 69 64 20 43 61 6e  nternal void Can
0b80: 63 65 6c 28 29 0a 20 20 20 20 7b 0a 20 20 20 20  cel().    {.    
0b90: 20 20 5f 76 65 72 73 69 6f 6e 20 3d 20 30 3b 0a    _version = 0;.
0ba0: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c      }..    /// <
0bb0: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
0bc0: 20 43 6c 6f 73 65 73 20 74 68 65 20 64 61 74 61   Closes the data
0bd0: 72 65 61 64 65 72 2c 20 70 6f 74 65 6e 74 69 61  reader, potentia
0be0: 6c 6c 79 20 63 6c 6f 73 69 6e 67 20 74 68 65 20  lly closing the 
0bf0: 63 6f 6e 6e 65 63 74 69 6f 6e 20 61 73 20 77 65  connection as we
0c00: 6c 6c 20 69 66 20 43 6f 6d 6d 61 6e 64 42 65 68  ll if CommandBeh
0c10: 61 76 69 6f 72 2e 43 6c 6f 73 65 43 6f 6e 6e 65  avior.CloseConne
0c20: 63 74 69 6f 6e 20 77 61 73 20 73 70 65 63 69 66  ction was specif
0c30: 69 65 64 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ied..    /// </s
0c40: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 75 62 6c  ummary>.    publ
0c50: 69 63 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  ic override void
0c60: 20 43 6c 6f 73 65 28 29 0a 20 20 20 20 7b 0a 20   Close().    {. 
0c70: 20 20 20 20 20 74 72 79 0a 20 20 20 20 20 20 7b       try.      {
0c80: 0a 20 20 20 20 20 20 20 20 69 66 20 28 5f 63 6f  .        if (_co
0c90: 6d 6d 61 6e 64 20 21 3d 20 6e 75 6c 6c 29 0a 20  mmand != null). 
0ca0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
0cb0: 20 20 20 74 72 79 0a 20 20 20 20 20 20 20 20 20     try.         
0cc0: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 74   {.            t
0cd0: 72 79 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  ry.            {
0ce0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  .              /
0cf0: 2f 20 4d 61 6b 65 20 73 75 72 65 20 77 65 27 76  / Make sure we'v
0d00: 65 20 6e 6f 74 20 62 65 65 6e 20 63 61 6e 63 65  e not been cance
0d10: 6c 65 64 0a 20 20 20 20 20 20 20 20 20 20 20 20  led.            
0d20: 20 20 69 66 20 28 5f 76 65 72 73 69 6f 6e 20 21    if (_version !
0d30: 3d 20 30 29 0a 20 20 20 20 20 20 20 20 20 20 20  = 0).           
0d40: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
0d50: 20 20 20 20 20 74 72 79 0a 20 20 20 20 20 20 20       try.       
0d60: 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20           {.     
0d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 77 68 69               whi
0d80: 6c 65 20 28 4e 65 78 74 52 65 73 75 6c 74 28 29  le (NextResult()
0d90: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ).              
0da0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
0db0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
0dc0: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
0dd0: 20 20 20 20 20 20 20 20 20 20 20 20 63 61 74 63              catc
0de0: 68 28 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  h(SQLiteExceptio
0df0: 6e 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  n).             
0e00: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
0e10: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
0e20: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
0e30: 20 20 20 20 20 5f 63 6f 6d 6d 61 6e 64 2e 43 6c       _command.Cl
0e40: 65 61 72 44 61 74 61 52 65 61 64 65 72 28 29 3b  earDataReader();
0e50: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20  .            }. 
0e60: 20 20 20 20 20 20 20 20 20 20 20 66 69 6e 61 6c             final
0e70: 6c 79 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  ly.            {
0e80: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  .              /
0e90: 2f 20 49 66 20 74 68 65 20 64 61 74 61 72 65 61  / If the datarea
0ea0: 64 65 72 27 73 20 62 65 68 61 76 69 6f 72 20 69  der's behavior i
0eb0: 6e 63 6c 75 64 65 73 20 63 6c 6f 73 69 6e 67 20  ncludes closing 
0ec0: 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 2c 20  the connection, 
0ed0: 74 68 65 6e 20 64 6f 20 73 6f 20 68 65 72 65 2e  then do so here.
0ee0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69  .              i
0ef0: 66 20 28 28 5f 63 6f 6d 6d 61 6e 64 42 65 68 61  f ((_commandBeha
0f00: 76 69 6f 72 20 26 20 43 6f 6d 6d 61 6e 64 42 65  vior & CommandBe
0f10: 68 61 76 69 6f 72 2e 43 6c 6f 73 65 43 6f 6e 6e  havior.CloseConn
0f20: 65 63 74 69 6f 6e 29 20 21 3d 20 30 20 26 26 20  ection) != 0 && 
0f30: 5f 63 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74  _command.Connect
0f40: 69 6f 6e 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20  ion != null).   
0f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 5f 63 6f               _co
0f60: 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f 6e  mmand.Connection
0f70: 2e 43 6c 6f 73 65 28 29 3b 0a 20 20 20 20 20 20  .Close();.      
0f80: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
0f90: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 66 69    }.          fi
0fa0: 6e 61 6c 6c 79 0a 20 20 20 20 20 20 20 20 20 20  nally.          
0fb0: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66  {.            if
0fc0: 20 28 5f 64 69 73 70 6f 73 65 43 6f 6d 6d 61 6e   (_disposeComman
0fd0: 64 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  d).             
0fe0: 20 5f 63 6f 6d 6d 61 6e 64 2e 44 69 73 70 6f 73   _command.Dispos
0ff0: 65 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  e();.          }
1000: 0a 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20  .        }..    
1010: 20 20 20 20 5f 63 6f 6d 6d 61 6e 64 20 3d 20 6e      _command = n
1020: 75 6c 6c 3b 0a 20 20 20 20 20 20 20 20 5f 61 63  ull;.        _ac
1030: 74 69 76 65 53 74 61 74 65 6d 65 6e 74 20 3d 20  tiveStatement = 
1040: 6e 75 6c 6c 3b 0a 20 20 20 20 20 20 20 20 5f 66  null;.        _f
1050: 69 65 6c 64 54 79 70 65 41 72 72 61 79 20 3d 20  ieldTypeArray = 
1060: 6e 75 6c 6c 3b 0a 20 20 20 20 20 20 7d 0a 20 20  null;.      }.  
1070: 20 20 20 20 66 69 6e 61 6c 6c 79 0a 20 20 20 20      finally.    
1080: 20 20 7b 0a 20 20 20 20 20 20 20 20 69 66 20 28    {.        if (
1090: 5f 6b 65 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c  _keyInfo != null
10a0: 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20  ).        {.    
10b0: 20 20 20 20 20 20 5f 6b 65 79 49 6e 66 6f 2e 44        _keyInfo.D
10c0: 69 73 70 6f 73 65 28 29 3b 0a 20 20 20 20 20 20  ispose();.      
10d0: 20 20 20 20 5f 6b 65 79 49 6e 66 6f 20 3d 20 6e      _keyInfo = n
10e0: 75 6c 6c 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  ull;.        }. 
10f0: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20       }.    }..  
1100: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
1110: 20 20 20 20 2f 2f 2f 20 54 68 72 6f 77 20 61 6e      /// Throw an
1120: 20 65 72 72 6f 72 20 69 66 20 74 68 65 20 64 61   error if the da
1130: 74 61 72 65 61 64 65 72 20 69 73 20 63 6c 6f 73  tareader is clos
1140: 65 64 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ed.    /// </sum
1150: 6d 61 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74  mary>.    privat
1160: 65 20 76 6f 69 64 20 43 68 65 63 6b 43 6c 6f 73  e void CheckClos
1170: 65 64 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  ed().    {.     
1180: 20 69 66 20 28 5f 63 6f 6d 6d 61 6e 64 20 3d 3d   if (_command ==
1190: 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20 20 74   null).        t
11a0: 68 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64  hrow new Invalid
11b0: 4f 70 65 72 61 74 69 6f 6e 45 78 63 65 70 74 69  OperationExcepti
11c0: 6f 6e 28 22 44 61 74 61 52 65 61 64 65 72 20 68  on("DataReader h
11d0: 61 73 20 62 65 65 6e 20 63 6c 6f 73 65 64 22 29  as been closed")
11e0: 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 5f 76 65  ;..      if (_ve
11f0: 72 73 69 6f 6e 20 3d 3d 20 30 29 0a 20 20 20 20  rsion == 0).    
1200: 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53 51      throw new SQ
1210: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 28 69  LiteException((i
1220: 6e 74 29 53 51 4c 69 74 65 45 72 72 6f 72 43 6f  nt)SQLiteErrorCo
1230: 64 65 2e 41 62 6f 72 74 2c 20 22 45 78 65 63 75  de.Abort, "Execu
1240: 74 69 6f 6e 20 77 61 73 20 61 62 6f 72 74 65 64  tion was aborted
1250: 20 62 79 20 74 68 65 20 75 73 65 72 22 29 3b 0a   by the user");.
1260: 0a 20 20 20 20 20 20 69 66 20 28 5f 63 6f 6d 6d  .      if (_comm
1270: 61 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f 6e 2e 53  and.Connection.S
1280: 74 61 74 65 20 21 3d 20 43 6f 6e 6e 65 63 74 69  tate != Connecti
1290: 6f 6e 53 74 61 74 65 2e 4f 70 65 6e 20 7c 7c 20  onState.Open || 
12a0: 5f 63 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74  _command.Connect
12b0: 69 6f 6e 2e 5f 76 65 72 73 69 6f 6e 20 21 3d 20  ion._version != 
12c0: 5f 76 65 72 73 69 6f 6e 29 0a 20 20 20 20 20 20  _version).      
12d0: 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76 61    throw new Inva
12e0: 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63 65  lidOperationExce
12f0: 70 74 69 6f 6e 28 22 43 6f 6e 6e 65 63 74 69 6f  ption("Connectio
1300: 6e 20 77 61 73 20 63 6c 6f 73 65 64 2c 20 73 74  n was closed, st
1310: 61 74 65 6d 65 6e 74 20 77 61 73 20 74 65 72 6d  atement was term
1320: 69 6e 61 74 65 64 22 29 3b 0a 20 20 20 20 7d 0a  inated");.    }.
1330: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
1340: 79 3e 0a 20 20 20 20 2f 2f 2f 20 54 68 72 6f 77  y>.    /// Throw
1350: 20 61 6e 20 65 72 72 6f 72 20 69 66 20 61 20 72   an error if a r
1360: 6f 77 20 69 73 20 6e 6f 74 20 6c 6f 61 64 65 64  ow is not loaded
1370: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
1380: 72 79 3e 0a 20 20 20 20 70 72 69 76 61 74 65 20  ry>.    private 
1390: 76 6f 69 64 20 43 68 65 63 6b 56 61 6c 69 64 52  void CheckValidR
13a0: 6f 77 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  ow().    {.     
13b0: 20 69 66 20 28 5f 72 65 61 64 69 6e 67 53 74 61   if (_readingSta
13c0: 74 65 20 21 3d 20 30 29 0a 20 20 20 20 20 20 20  te != 0).       
13d0: 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c   throw new Inval
13e0: 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63 65 70  idOperationExcep
13f0: 74 69 6f 6e 28 22 4e 6f 20 63 75 72 72 65 6e 74  tion("No current
1400: 20 72 6f 77 22 29 3b 0a 20 20 20 20 7d 0a 0a 20   row");.    }.. 
1410: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
1420: 0a 20 20 20 20 2f 2f 2f 20 45 6e 75 6d 65 72 61  .    /// Enumera
1430: 74 6f 72 20 73 75 70 70 6f 72 74 0a 20 20 20 20  tor support.    
1440: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
1450: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
1460: 52 65 74 75 72 6e 73 20 61 20 44 62 45 6e 75 6d  Returns a DbEnum
1470: 65 72 61 74 6f 72 20 6f 62 6a 65 63 74 2e 3c 2f  erator object.</
1480: 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62  returns>.    pub
1490: 6c 69 63 20 6f 76 65 72 72 69 64 65 20 43 6f 6c  lic override Col
14a0: 6c 65 63 74 69 6f 6e 73 2e 49 45 6e 75 6d 65 72  lections.IEnumer
14b0: 61 74 6f 72 20 47 65 74 45 6e 75 6d 65 72 61 74  ator GetEnumerat
14c0: 6f 72 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  or().    {.     
14d0: 20 72 65 74 75 72 6e 20 6e 65 77 20 44 62 45 6e   return new DbEn
14e0: 75 6d 65 72 61 74 6f 72 28 74 68 69 73 2c 20 28  umerator(this, (
14f0: 28 5f 63 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f  (_commandBehavio
1500: 72 20 26 20 43 6f 6d 6d 61 6e 64 42 65 68 61 76  r & CommandBehav
1510: 69 6f 72 2e 43 6c 6f 73 65 43 6f 6e 6e 65 63 74  ior.CloseConnect
1520: 69 6f 6e 29 20 3d 3d 20 43 6f 6d 6d 61 6e 64 42  ion) == CommandB
1530: 65 68 61 76 69 6f 72 2e 43 6c 6f 73 65 43 6f 6e  ehavior.CloseCon
1540: 6e 65 63 74 69 6f 6e 29 29 3b 0a 20 20 20 20 7d  nection));.    }
1550: 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
1560: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 4e 6f 74 20  ry>.    /// Not 
1570: 69 6d 70 6c 65 6d 65 6e 74 65 64 2e 20 20 52 65  implemented.  Re
1580: 74 75 72 6e 73 20 30 0a 20 20 20 20 2f 2f 2f 20  turns 0.    /// 
1590: 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70  </summary>.    p
15a0: 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 69  ublic override i
15b0: 6e 74 20 44 65 70 74 68 0a 20 20 20 20 7b 0a 20  nt Depth.    {. 
15c0: 20 20 20 20 20 67 65 74 0a 20 20 20 20 20 20 7b       get.      {
15d0: 0a 20 20 20 20 20 20 20 20 43 68 65 63 6b 43 6c  .        CheckCl
15e0: 6f 73 65 64 28 29 3b 0a 20 20 20 20 20 20 20 20  osed();.        
15f0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20 20  return 0;.      
1600: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f  }.    }..    ///
1610: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
1620: 2f 2f 20 52 65 74 75 72 6e 73 20 74 68 65 20 6e  // Returns the n
1630: 75 6d 62 65 72 20 6f 66 20 63 6f 6c 75 6d 6e 73  umber of columns
1640: 20 69 6e 20 74 68 65 20 63 75 72 72 65 6e 74 20   in the current 
1650: 72 65 73 75 6c 74 73 65 74 0a 20 20 20 20 2f 2f  resultset.    //
1660: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20  / </summary>.   
1670: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
1680: 20 69 6e 74 20 46 69 65 6c 64 43 6f 75 6e 74 0a   int FieldCount.
1690: 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65 74 0a      {.      get.
16a0: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
16b0: 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a 20  CheckClosed();. 
16c0: 20 20 20 20 20 20 20 69 66 20 28 5f 6b 65 79 49         if (_keyI
16d0: 6e 66 6f 20 3d 3d 20 6e 75 6c 6c 29 0a 20 20 20  nfo == null).   
16e0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 66         return _f
16f0: 69 65 6c 64 43 6f 75 6e 74 3b 0a 0a 20 20 20 20  ieldCount;..    
1700: 20 20 20 20 72 65 74 75 72 6e 20 5f 66 69 65 6c      return _fiel
1710: 64 43 6f 75 6e 74 20 2b 20 5f 6b 65 79 49 6e 66  dCount + _keyInf
1720: 6f 2e 43 6f 75 6e 74 3b 0a 20 20 20 20 20 20 7d  o.Count;.      }
1730: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
1740: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
1750: 2f 20 52 65 74 75 72 6e 73 20 74 68 65 20 6e 75  / Returns the nu
1760: 6d 62 65 72 20 6f 66 20 76 69 73 69 62 6c 65 20  mber of visible 
1770: 66 69 65 6c 73 64 20 69 6e 20 74 68 65 20 63 75  fielsd in the cu
1780: 72 72 65 6e 74 20 72 65 73 75 6c 74 73 65 74 0a  rrent resultset.
1790: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
17a0: 79 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76  y>.    public ov
17b0: 65 72 72 69 64 65 20 69 6e 74 20 56 69 73 69 62  erride int Visib
17c0: 6c 65 46 69 65 6c 64 43 6f 75 6e 74 0a 20 20 20  leFieldCount.   
17d0: 20 7b 0a 20 20 20 20 20 20 67 65 74 0a 20 20 20   {.      get.   
17e0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 43 68 65     {.        Che
17f0: 63 6b 43 6c 6f 73 65 64 28 29 3b 0a 20 20 20 20  ckClosed();.    
1800: 20 20 20 20 72 65 74 75 72 6e 20 5f 66 69 65 6c      return _fiel
1810: 64 43 6f 75 6e 74 3b 0a 20 20 20 20 20 20 7d 0a  dCount;.      }.
1820: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c      }..    /// <
1830: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
1840: 20 53 51 4c 69 74 65 20 69 73 20 69 6e 68 65 72   SQLite is inher
1850: 65 6e 74 6c 79 20 75 6e 2d 74 79 70 65 64 2e 20  ently un-typed. 
1860: 20 41 6c 6c 20 64 61 74 61 74 79 70 65 73 20 69   All datatypes i
1870: 6e 20 53 51 4c 69 74 65 20 61 72 65 20 6e 61 74  n SQLite are nat
1880: 69 76 65 6c 79 20 73 74 72 69 6e 67 73 2e 20 20  ively strings.  
1890: 54 68 65 20 64 65 66 69 6e 69 74 69 6f 6e 20 6f  The definition o
18a0: 66 20 74 68 65 20 63 6f 6c 75 6d 6e 73 20 6f 66  f the columns of
18b0: 20 61 20 74 61 62 6c 65 0a 20 20 20 20 2f 2f 2f   a table.    ///
18c0: 20 61 6e 64 20 74 68 65 20 61 66 66 69 6e 69 74   and the affinit
18d0: 79 20 6f 66 20 72 65 74 75 72 6e 65 64 20 74 79  y of returned ty
18e0: 70 65 73 20 61 72 65 20 61 6c 6c 20 77 65 20 68  pes are all we h
18f0: 61 76 65 20 74 6f 20 67 6f 20 6f 6e 20 74 6f 20  ave to go on to 
1900: 74 79 70 65 2d 72 65 73 74 72 69 63 74 20 64 61  type-restrict da
1910: 74 61 20 69 6e 20 74 68 65 20 72 65 61 64 65 72  ta in the reader
1920: 2e 0a 20 20 20 20 2f 2f 2f 20 0a 20 20 20 20 2f  ..    /// .    /
1930: 2f 2f 20 54 68 69 73 20 66 75 6e 63 74 69 6f 6e  // This function
1940: 20 61 74 74 65 6d 70 74 73 20 74 6f 20 76 65 72   attempts to ver
1950: 69 66 79 20 74 68 61 74 20 74 68 65 20 74 79 70  ify that the typ
1960: 65 20 6f 66 20 64 61 74 61 20 62 65 69 6e 67 20  e of data being 
1970: 72 65 71 75 65 73 74 65 64 20 6f 66 20 61 20 63  requested of a c
1980: 6f 6c 75 6d 6e 20 6d 61 74 63 68 65 73 20 74 68  olumn matches th
1990: 65 20 64 61 74 61 74 79 70 65 20 6f 66 20 74 68  e datatype of th
19a0: 65 20 63 6f 6c 75 6d 6e 2e 20 20 49 6e 0a 20 20  e column.  In.  
19b0: 20 20 2f 2f 2f 20 74 68 65 20 63 61 73 65 20 6f    /// the case o
19c0: 66 20 63 6f 6c 75 6d 6e 73 20 74 68 61 74 20 61  f columns that a
19d0: 72 65 20 6e 6f 74 20 62 61 63 6b 65 64 20 69 6e  re not backed in
19e0: 74 6f 20 61 20 74 61 62 6c 65 20 64 65 66 69 6e  to a table defin
19f0: 69 74 69 6f 6e 2c 20 77 65 20 61 74 74 65 6d 70  ition, we attemp
1a00: 74 20 74 6f 20 6d 61 74 63 68 20 75 70 20 74 68  t to match up th
1a10: 65 20 61 66 66 69 6e 69 74 79 20 6f 66 20 61 20  e affinity of a 
1a20: 63 6f 6c 75 6d 6e 20 28 69 6e 74 2c 20 64 6f 75  column (int, dou
1a30: 62 6c 65 2c 20 73 74 72 69 6e 67 20 6f 72 20 62  ble, string or b
1a40: 6c 6f 62 29 0a 20 20 20 20 2f 2f 2f 20 74 6f 20  lob).    /// to 
1a50: 61 20 73 65 74 20 6f 66 20 6b 6e 6f 77 6e 20 74  a set of known t
1a60: 79 70 65 73 20 74 68 61 74 20 63 6c 6f 73 65 6c  ypes that closel
1a70: 79 20 6d 61 74 63 68 20 74 68 61 74 20 61 66 66  y match that aff
1a80: 69 6e 69 74 79 2e 20 20 49 74 27 73 20 6e 6f 74  inity.  It's not
1a90: 20 61 6e 20 65 78 61 63 74 20 73 63 69 65 6e 63   an exact scienc
1aa0: 65 2c 20 62 75 74 20 69 74 73 20 74 68 65 20 62  e, but its the b
1ab0: 65 73 74 20 77 65 20 63 61 6e 20 64 6f 2e 0a 20  est we can do.. 
1ac0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
1ad0: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  >.    /// <retur
1ae0: 6e 73 3e 0a 20 20 20 20 2f 2f 2f 20 54 68 69 73  ns>.    /// This
1af0: 20 66 75 6e 63 74 69 6f 6e 20 74 68 72 6f 77 73   function throws
1b00: 20 61 6e 20 49 6e 76 61 6c 69 64 54 79 70 65 43   an InvalidTypeC
1b10: 61 73 74 28 29 20 65 78 63 65 70 74 69 6f 6e 20  ast() exception 
1b20: 69 66 20 74 68 65 20 72 65 71 75 65 73 74 65 64  if the requested
1b30: 20 74 79 70 65 20 64 6f 65 73 6e 27 74 20 6d 61   type doesn't ma
1b40: 74 63 68 20 74 68 65 20 63 6f 6c 75 6d 6e 27 73  tch the column's
1b50: 20 64 65 66 69 6e 69 74 69 6f 6e 20 6f 72 20 61   definition or a
1b60: 66 66 69 6e 69 74 79 2e 0a 20 20 20 20 2f 2f 2f  ffinity..    ///
1b70: 20 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20   </returns>.    
1b80: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
1b90: 22 69 22 3e 54 68 65 20 69 6e 64 65 78 20 6f 66  "i">The index of
1ba0: 20 74 68 65 20 63 6f 6c 75 6d 6e 20 74 6f 20 74   the column to t
1bb0: 79 70 65 2d 63 68 65 63 6b 3c 2f 70 61 72 61 6d  ype-check</param
1bc0: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
1bd0: 20 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68 65 20   name="typ">The 
1be0: 74 79 70 65 20 77 65 20 77 61 6e 74 20 74 6f 20  type we want to 
1bf0: 67 65 74 20 6f 75 74 20 6f 66 20 74 68 65 20 63  get out of the c
1c00: 6f 6c 75 6d 6e 3c 2f 70 61 72 61 6d 3e 0a 20 20  olumn</param>.  
1c10: 20 20 70 72 69 76 61 74 65 20 54 79 70 65 41 66    private TypeAf
1c20: 66 69 6e 69 74 79 20 56 65 72 69 66 79 54 79 70  finity VerifyTyp
1c30: 65 28 69 6e 74 20 69 2c 20 44 62 54 79 70 65 20  e(int i, DbType 
1c40: 74 79 70 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  typ).    {.     
1c50: 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a   CheckClosed();.
1c60: 20 20 20 20 20 20 43 68 65 63 6b 56 61 6c 69 64        CheckValid
1c70: 52 6f 77 28 29 3b 0a 20 20 20 20 20 20 54 79 70  Row();.      Typ
1c80: 65 41 66 66 69 6e 69 74 79 20 61 66 66 69 6e 69  eAffinity affini
1c90: 74 79 20 3d 20 47 65 74 53 51 4c 69 74 65 54 79  ty = GetSQLiteTy
1ca0: 70 65 28 69 29 2e 41 66 66 69 6e 69 74 79 3b 0a  pe(i).Affinity;.
1cb0: 0a 20 20 20 20 20 20 73 77 69 74 63 68 20 28 61  .      switch (a
1cc0: 66 66 69 6e 69 74 79 29 0a 20 20 20 20 20 20 7b  ffinity).      {
1cd0: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 54 79  .        case Ty
1ce0: 70 65 41 66 66 69 6e 69 74 79 2e 49 6e 74 36 34  peAffinity.Int64
1cf0: 3a 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28  :.          if (
1d00: 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e 49 6e  typ == DbType.In
1d10: 74 31 36 29 20 72 65 74 75 72 6e 20 61 66 66 69  t16) return affi
1d20: 6e 69 74 79 3b 0a 20 20 20 20 20 20 20 20 20 20  nity;.          
1d30: 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70  if (typ == DbTyp
1d40: 65 2e 49 6e 74 33 32 29 20 72 65 74 75 72 6e 20  e.Int32) return 
1d50: 61 66 66 69 6e 69 74 79 3b 0a 20 20 20 20 20 20  affinity;.      
1d60: 20 20 20 20 69 66 20 28 74 79 70 20 3d 3d 20 44      if (typ == D
1d70: 62 54 79 70 65 2e 49 6e 74 36 34 29 20 72 65 74  bType.Int64) ret
1d80: 75 72 6e 20 61 66 66 69 6e 69 74 79 3b 0a 20 20  urn affinity;.  
1d90: 20 20 20 20 20 20 20 20 69 66 20 28 74 79 70 20          if (typ 
1da0: 3d 3d 20 44 62 54 79 70 65 2e 42 6f 6f 6c 65 61  == DbType.Boolea
1db0: 6e 29 20 72 65 74 75 72 6e 20 61 66 66 69 6e 69  n) return affini
1dc0: 74 79 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66  ty;.          if
1dd0: 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e   (typ == DbType.
1de0: 42 79 74 65 29 20 72 65 74 75 72 6e 20 61 66 66  Byte) return aff
1df0: 69 6e 69 74 79 3b 0a 20 20 20 20 20 20 20 20 20  inity;.         
1e00: 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79   if (typ == DbTy
1e10: 70 65 2e 44 61 74 65 54 69 6d 65 29 20 72 65 74  pe.DateTime) ret
1e20: 75 72 6e 20 61 66 66 69 6e 69 74 79 3b 0a 20 20  urn affinity;.  
1e30: 20 20 20 20 20 20 20 20 69 66 20 28 74 79 70 20          if (typ 
1e40: 3d 3d 20 44 62 54 79 70 65 2e 53 69 6e 67 6c 65  == DbType.Single
1e50: 29 20 72 65 74 75 72 6e 20 61 66 66 69 6e 69 74  ) return affinit
1e60: 79 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 20  y;.          if 
1e70: 28 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e 44  (typ == DbType.D
1e80: 6f 75 62 6c 65 29 20 72 65 74 75 72 6e 20 61 66  ouble) return af
1e90: 66 69 6e 69 74 79 3b 0a 20 20 20 20 20 20 20 20  finity;.        
1ea0: 20 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54    if (typ == DbT
1eb0: 79 70 65 2e 44 65 63 69 6d 61 6c 29 20 72 65 74  ype.Decimal) ret
1ec0: 75 72 6e 20 61 66 66 69 6e 69 74 79 3b 0a 20 20  urn affinity;.  
1ed0: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
1ee0: 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65         case Type
1ef0: 41 66 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65 3a  Affinity.Double:
1f00: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74  .          if (t
1f10: 79 70 20 3d 3d 20 44 62 54 79 70 65 2e 53 69 6e  yp == DbType.Sin
1f20: 67 6c 65 29 20 72 65 74 75 72 6e 20 61 66 66 69  gle) return affi
1f30: 6e 69 74 79 3b 0a 20 20 20 20 20 20 20 20 20 20  nity;.          
1f40: 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70  if (typ == DbTyp
1f50: 65 2e 44 6f 75 62 6c 65 29 20 72 65 74 75 72 6e  e.Double) return
1f60: 20 61 66 66 69 6e 69 74 79 3b 0a 20 20 20 20 20   affinity;.     
1f70: 20 20 20 20 20 69 66 20 28 74 79 70 20 3d 3d 20       if (typ == 
1f80: 44 62 54 79 70 65 2e 44 65 63 69 6d 61 6c 29 20  DbType.Decimal) 
1f90: 72 65 74 75 72 6e 20 61 66 66 69 6e 69 74 79 3b  return affinity;
1fa0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74  .          if (t
1fb0: 79 70 20 3d 3d 20 44 62 54 79 70 65 2e 44 61 74  yp == DbType.Dat
1fc0: 65 54 69 6d 65 29 20 72 65 74 75 72 6e 20 61 66  eTime) return af
1fd0: 66 69 6e 69 74 79 3b 0a 20 20 20 20 20 20 20 20  finity;.        
1fe0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20    break;.       
1ff0: 20 63 61 73 65 20 54 79 70 65 41 66 66 69 6e 69   case TypeAffini
2000: 74 79 2e 54 65 78 74 3a 0a 20 20 20 20 20 20 20  ty.Text:.       
2010: 20 20 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62     if (typ == Db
2020: 54 79 70 65 2e 53 42 79 74 65 29 20 72 65 74 75  Type.SByte) retu
2030: 72 6e 20 61 66 66 69 6e 69 74 79 3b 0a 20 20 20  rn affinity;.   
2040: 20 20 20 20 20 20 20 69 66 20 28 74 79 70 20 3d         if (typ =
2050: 3d 20 44 62 54 79 70 65 2e 53 74 72 69 6e 67 29  = DbType.String)
2060: 20 72 65 74 75 72 6e 20 61 66 66 69 6e 69 74 79   return affinity
2070: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28  ;.          if (
2080: 74 79 70 20 3d 3d 20 44 62 54 79 70 65 2e 53 42  typ == DbType.SB
2090: 79 74 65 29 20 72 65 74 75 72 6e 20 61 66 66 69  yte) return affi
20a0: 6e 69 74 79 3b 0a 20 20 20 20 20 20 20 20 20 20  nity;.          
20b0: 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79 70  if (typ == DbTyp
20c0: 65 2e 47 75 69 64 29 20 72 65 74 75 72 6e 20 61  e.Guid) return a
20d0: 66 66 69 6e 69 74 79 3b 0a 20 20 20 20 20 20 20  ffinity;.       
20e0: 20 20 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62     if (typ == Db
20f0: 54 79 70 65 2e 44 61 74 65 54 69 6d 65 29 20 72  Type.DateTime) r
2100: 65 74 75 72 6e 20 61 66 66 69 6e 69 74 79 3b 0a  eturn affinity;.
2110: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74 79            if (ty
2120: 70 20 3d 3d 20 44 62 54 79 70 65 2e 44 65 63 69  p == DbType.Deci
2130: 6d 61 6c 29 20 72 65 74 75 72 6e 20 61 66 66 69  mal) return affi
2140: 6e 69 74 79 3b 0a 20 20 20 20 20 20 20 20 20 20  nity;.          
2150: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 63  break;.        c
2160: 61 73 65 20 54 79 70 65 41 66 66 69 6e 69 74 79  ase TypeAffinity
2170: 2e 42 6c 6f 62 3a 0a 20 20 20 20 20 20 20 20 20  .Blob:.         
2180: 20 69 66 20 28 74 79 70 20 3d 3d 20 44 62 54 79   if (typ == DbTy
2190: 70 65 2e 47 75 69 64 29 20 72 65 74 75 72 6e 20  pe.Guid) return 
21a0: 61 66 66 69 6e 69 74 79 3b 0a 20 20 20 20 20 20  affinity;.      
21b0: 20 20 20 20 69 66 20 28 74 79 70 20 3d 3d 20 44      if (typ == D
21c0: 62 54 79 70 65 2e 53 74 72 69 6e 67 29 20 72 65  bType.String) re
21d0: 74 75 72 6e 20 61 66 66 69 6e 69 74 79 3b 0a 20  turn affinity;. 
21e0: 20 20 20 20 20 20 20 20 20 69 66 20 28 74 79 70           if (typ
21f0: 20 3d 3d 20 44 62 54 79 70 65 2e 42 69 6e 61 72   == DbType.Binar
2200: 79 29 20 72 65 74 75 72 6e 20 61 66 66 69 6e 69  y) return affini
2210: 74 79 3b 0a 20 20 20 20 20 20 20 20 20 20 62 72  ty;.          br
2220: 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20  eak;.      }..  
2230: 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e      throw new In
2240: 76 61 6c 69 64 43 61 73 74 45 78 63 65 70 74 69  validCastExcepti
2250: 6f 6e 28 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  on();.    }..   
2260: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
2270: 20 20 20 2f 2f 2f 20 52 65 74 72 69 65 76 65 73     /// Retrieves
2280: 20 74 68 65 20 63 6f 6c 75 6d 6e 20 61 73 20 61   the column as a
2290: 20 62 6f 6f 6c 65 61 6e 20 76 61 6c 75 65 0a 20   boolean value. 
22a0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
22b0: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
22c0: 20 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e   name="i">The in
22d0: 64 65 78 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d  dex of the colum
22e0: 6e 20 74 6f 20 72 65 74 72 69 65 76 65 3c 2f 70  n to retrieve</p
22f0: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72  aram>.    /// <r
2300: 65 74 75 72 6e 73 3e 62 6f 6f 6c 3c 2f 72 65 74  eturns>bool</ret
2310: 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63  urns>.    public
2320: 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20 47   override bool G
2330: 65 74 42 6f 6f 6c 65 61 6e 28 69 6e 74 20 69 29  etBoolean(int i)
2340: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 66 20  .    {.      if 
2350: 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46 69 65  (i >= VisibleFie
2360: 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65 79 49  ldCount && _keyI
2370: 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20  nfo != null).   
2380: 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b 65 79       return _key
2390: 49 6e 66 6f 2e 47 65 74 42 6f 6f 6c 65 61 6e 28  Info.GetBoolean(
23a0: 69 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64  i - VisibleField
23b0: 43 6f 75 6e 74 29 3b 0a 0a 20 20 20 20 20 20 56  Count);..      V
23c0: 65 72 69 66 79 54 79 70 65 28 69 2c 20 44 62 54  erifyType(i, DbT
23d0: 79 70 65 2e 42 6f 6f 6c 65 61 6e 29 3b 0a 20 20  ype.Boolean);.  
23e0: 20 20 20 20 72 65 74 75 72 6e 20 43 6f 6e 76 65      return Conve
23f0: 72 74 2e 54 6f 42 6f 6f 6c 65 61 6e 28 47 65 74  rt.ToBoolean(Get
2400: 56 61 6c 75 65 28 69 29 2c 20 43 75 6c 74 75 72  Value(i), Cultur
2410: 65 49 6e 66 6f 2e 43 75 72 72 65 6e 74 43 75 6c  eInfo.CurrentCul
2420: 74 75 72 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  ture);.    }..  
2430: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
2440: 20 20 20 20 2f 2f 2f 20 52 65 74 72 69 65 76 65      /// Retrieve
2450: 73 20 74 68 65 20 63 6f 6c 75 6d 6e 20 61 73 20  s the column as 
2460: 61 20 73 69 6e 67 6c 65 20 62 79 74 65 20 76 61  a single byte va
2470: 6c 75 65 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  lue.    /// </su
2480: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c  mmary>.    /// <
2490: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54  param name="i">T
24a0: 68 65 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20  he index of the 
24b0: 63 6f 6c 75 6d 6e 20 74 6f 20 72 65 74 72 69 65  column to retrie
24c0: 76 65 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  ve</param>.    /
24d0: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 62 79 74 65  // <returns>byte
24e0: 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70  </returns>.    p
24f0: 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 62  ublic override b
2500: 79 74 65 20 47 65 74 42 79 74 65 28 69 6e 74 20  yte GetByte(int 
2510: 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  i).    {.      i
2520: 66 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46  f (i >= VisibleF
2530: 69 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65  ieldCount && _ke
2540: 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20  yInfo != null). 
2550: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b         return _k
2560: 65 79 49 6e 66 6f 2e 47 65 74 42 79 74 65 28 69  eyInfo.GetByte(i
2570: 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64 43   - VisibleFieldC
2580: 6f 75 6e 74 29 3b 0a 0a 20 20 20 20 20 20 56 65  ount);..      Ve
2590: 72 69 66 79 54 79 70 65 28 69 2c 20 44 62 54 79  rifyType(i, DbTy
25a0: 70 65 2e 42 79 74 65 29 3b 0a 20 20 20 20 20 20  pe.Byte);.      
25b0: 72 65 74 75 72 6e 20 43 6f 6e 76 65 72 74 2e 54  return Convert.T
25c0: 6f 42 79 74 65 28 5f 61 63 74 69 76 65 53 74 61  oByte(_activeSta
25d0: 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 49  tement._sql.GetI
25e0: 6e 74 33 32 28 5f 61 63 74 69 76 65 53 74 61 74  nt32(_activeStat
25f0: 65 6d 65 6e 74 2c 20 69 29 29 3b 0a 20 20 20 20  ement, i));.    
2600: 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  }..    /// <summ
2610: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74  ary>.    /// Ret
2620: 72 69 65 76 65 73 20 61 20 63 6f 6c 75 6d 6e 20  rieves a column 
2630: 61 73 20 61 6e 20 61 72 72 61 79 20 6f 66 20 62  as an array of b
2640: 79 74 65 73 20 28 62 6c 6f 62 29 0a 20 20 20 20  ytes (blob).    
2650: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
2660: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
2670: 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e 64 65 78  me="i">The index
2680: 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 20 74   of the column t
2690: 6f 20 72 65 74 72 69 65 76 65 3c 2f 70 61 72 61  o retrieve</para
26a0: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  m>.    /// <para
26b0: 6d 20 6e 61 6d 65 3d 22 66 69 65 6c 64 4f 66 66  m name="fieldOff
26c0: 73 65 74 22 3e 54 68 65 20 7a 65 72 6f 2d 62 61  set">The zero-ba
26d0: 73 65 64 20 69 6e 64 65 78 20 6f 66 20 77 68 65  sed index of whe
26e0: 72 65 20 74 6f 20 62 65 67 69 6e 20 72 65 61 64  re to begin read
26f0: 69 6e 67 20 74 68 65 20 64 61 74 61 3c 2f 70 61  ing the data</pa
2700: 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  ram>.    /// <pa
2710: 72 61 6d 20 6e 61 6d 65 3d 22 62 75 66 66 65 72  ram name="buffer
2720: 22 3e 54 68 65 20 62 75 66 66 65 72 20 74 6f 20  ">The buffer to 
2730: 77 72 69 74 65 20 74 68 65 20 62 79 74 65 73 20  write the bytes 
2740: 69 6e 74 6f 3c 2f 70 61 72 61 6d 3e 0a 20 20 20  into</param>.   
2750: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
2760: 3d 22 62 75 66 66 65 72 6f 66 66 73 65 74 22 3e  ="bufferoffset">
2770: 54 68 65 20 7a 65 72 6f 2d 62 61 73 65 64 20 69  The zero-based i
2780: 6e 64 65 78 20 6f 66 20 77 68 65 72 65 20 74 6f  ndex of where to
2790: 20 62 65 67 69 6e 20 77 72 69 74 69 6e 67 20 69   begin writing i
27a0: 6e 74 6f 20 74 68 65 20 61 72 72 61 79 3c 2f 70  nto the array</p
27b0: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  aram>.    /// <p
27c0: 61 72 61 6d 20 6e 61 6d 65 3d 22 6c 65 6e 67 74  aram name="lengt
27d0: 68 22 3e 54 68 65 20 6e 75 6d 62 65 72 20 6f 66  h">The number of
27e0: 20 62 79 74 65 73 20 74 6f 20 72 65 74 72 69 65   bytes to retrie
27f0: 76 65 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  ve</param>.    /
2800: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20  // <returns>The 
2810: 61 63 74 75 61 6c 20 6e 75 6d 62 65 72 20 6f 66  actual number of
2820: 20 62 79 74 65 73 20 77 72 69 74 74 65 6e 20 69   bytes written i
2830: 6e 74 6f 20 74 68 65 20 61 72 72 61 79 3c 2f 72  nto the array</r
2840: 65 74 75 72 6e 73 3e 0a 20 20 20 20 2f 2f 2f 20  eturns>.    /// 
2850: 3c 72 65 6d 61 72 6b 73 3e 0a 20 20 20 20 2f 2f  <remarks>.    //
2860: 2f 20 54 6f 20 64 65 74 65 72 6d 69 6e 65 20 74  / To determine t
2870: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 74  he number of byt
2880: 65 73 20 69 6e 20 74 68 65 20 63 6f 6c 75 6d 6e  es in the column
2890: 2c 20 70 61 73 73 20 61 20 6e 75 6c 6c 20 76 61  , pass a null va
28a0: 6c 75 65 20 66 6f 72 20 74 68 65 20 62 75 66 66  lue for the buff
28b0: 65 72 2e 20 20 54 68 65 20 74 6f 74 61 6c 20 6c  er.  The total l
28c0: 65 6e 67 74 68 20 77 69 6c 6c 20 62 65 20 72 65  ength will be re
28d0: 74 75 72 6e 65 64 2e 0a 20 20 20 20 2f 2f 2f 20  turned..    /// 
28e0: 3c 2f 72 65 6d 61 72 6b 73 3e 0a 20 20 20 20 70  </remarks>.    p
28f0: 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 6c  ublic override l
2900: 6f 6e 67 20 47 65 74 42 79 74 65 73 28 69 6e 74  ong GetBytes(int
2910: 20 69 2c 20 6c 6f 6e 67 20 66 69 65 6c 64 4f 66   i, long fieldOf
2920: 66 73 65 74 2c 20 62 79 74 65 5b 5d 20 62 75 66  fset, byte[] buf
2930: 66 65 72 2c 20 69 6e 74 20 62 75 66 66 65 72 6f  fer, int buffero
2940: 66 66 73 65 74 2c 20 69 6e 74 20 6c 65 6e 67 74  ffset, int lengt
2950: 68 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  h).    {.      i
2960: 66 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46  f (i >= VisibleF
2970: 69 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65  ieldCount && _ke
2980: 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20  yInfo != null). 
2990: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b         return _k
29a0: 65 79 49 6e 66 6f 2e 47 65 74 42 79 74 65 73 28  eyInfo.GetBytes(
29b0: 69 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64  i - VisibleField
29c0: 43 6f 75 6e 74 2c 20 66 69 65 6c 64 4f 66 66 73  Count, fieldOffs
29d0: 65 74 2c 20 62 75 66 66 65 72 2c 20 62 75 66 66  et, buffer, buff
29e0: 65 72 6f 66 66 73 65 74 2c 20 6c 65 6e 67 74 68  eroffset, length
29f0: 29 3b 0a 0a 20 20 20 20 20 20 56 65 72 69 66 79  );..      Verify
2a00: 54 79 70 65 28 69 2c 20 44 62 54 79 70 65 2e 42  Type(i, DbType.B
2a10: 69 6e 61 72 79 29 3b 0a 20 20 20 20 20 20 72 65  inary);.      re
2a20: 74 75 72 6e 20 5f 61 63 74 69 76 65 53 74 61 74  turn _activeStat
2a30: 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 42 79  ement._sql.GetBy
2a40: 74 65 73 28 5f 61 63 74 69 76 65 53 74 61 74 65  tes(_activeState
2a50: 6d 65 6e 74 2c 20 69 2c 20 28 69 6e 74 29 66 69  ment, i, (int)fi
2a60: 65 6c 64 4f 66 66 73 65 74 2c 20 62 75 66 66 65  eldOffset, buffe
2a70: 72 2c 20 62 75 66 66 65 72 6f 66 66 73 65 74 2c  r, bufferoffset,
2a80: 20 6c 65 6e 67 74 68 29 3b 0a 20 20 20 20 7d 0a   length);.    }.
2a90: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
2aa0: 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74 75 72  y>.    /// Retur
2ab0: 6e 73 20 74 68 65 20 63 6f 6c 75 6d 6e 20 61 73  ns the column as
2ac0: 20 61 20 73 69 6e 67 6c 65 20 63 68 61 72 61 63   a single charac
2ad0: 74 65 72 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ter.    /// </su
2ae0: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c  mmary>.    /// <
2af0: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54  param name="i">T
2b00: 68 65 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20  he index of the 
2b10: 63 6f 6c 75 6d 6e 20 74 6f 20 72 65 74 72 69 65  column to retrie
2b20: 76 65 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  ve</param>.    /
2b30: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 63 68 61 72  // <returns>char
2b40: 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70  </returns>.    p
2b50: 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 63  ublic override c
2b60: 68 61 72 20 47 65 74 43 68 61 72 28 69 6e 74 20  har GetChar(int 
2b70: 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  i).    {.      i
2b80: 66 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46  f (i >= VisibleF
2b90: 69 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65  ieldCount && _ke
2ba0: 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20  yInfo != null). 
2bb0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b         return _k
2bc0: 65 79 49 6e 66 6f 2e 47 65 74 43 68 61 72 28 69  eyInfo.GetChar(i
2bd0: 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64 43   - VisibleFieldC
2be0: 6f 75 6e 74 29 3b 0a 0a 20 20 20 20 20 20 56 65  ount);..      Ve
2bf0: 72 69 66 79 54 79 70 65 28 69 2c 20 44 62 54 79  rifyType(i, DbTy
2c00: 70 65 2e 53 42 79 74 65 29 3b 0a 20 20 20 20 20  pe.SByte);.     
2c10: 20 72 65 74 75 72 6e 20 43 6f 6e 76 65 72 74 2e   return Convert.
2c20: 54 6f 43 68 61 72 28 5f 61 63 74 69 76 65 53 74  ToChar(_activeSt
2c30: 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74  atement._sql.Get
2c40: 49 6e 74 33 32 28 5f 61 63 74 69 76 65 53 74 61  Int32(_activeSta
2c50: 74 65 6d 65 6e 74 2c 20 69 29 29 3b 0a 20 20 20  tement, i));.   
2c60: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
2c70: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65  mary>.    /// Re
2c80: 74 72 69 65 76 65 73 20 61 20 63 6f 6c 75 6d 6e  trieves a column
2c90: 20 61 73 20 61 6e 20 61 72 72 61 79 20 6f 66 20   as an array of 
2ca0: 63 68 61 72 73 20 28 62 6c 6f 62 29 0a 20 20 20  chars (blob).   
2cb0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
2cc0: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
2cd0: 61 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e 64 65  ame="i">The inde
2ce0: 78 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 20  x of the column 
2cf0: 74 6f 20 72 65 74 72 69 65 76 65 3c 2f 70 61 72  to retrieve</par
2d00: 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  am>.    /// <par
2d10: 61 6d 20 6e 61 6d 65 3d 22 66 69 65 6c 64 6f 66  am name="fieldof
2d20: 66 73 65 74 22 3e 54 68 65 20 7a 65 72 6f 2d 62  fset">The zero-b
2d30: 61 73 65 64 20 69 6e 64 65 78 20 6f 66 20 77 68  ased index of wh
2d40: 65 72 65 20 74 6f 20 62 65 67 69 6e 20 72 65 61  ere to begin rea
2d50: 64 69 6e 67 20 74 68 65 20 64 61 74 61 3c 2f 70  ding the data</p
2d60: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  aram>.    /// <p
2d70: 61 72 61 6d 20 6e 61 6d 65 3d 22 62 75 66 66 65  aram name="buffe
2d80: 72 22 3e 54 68 65 20 62 75 66 66 65 72 20 74 6f  r">The buffer to
2d90: 20 77 72 69 74 65 20 74 68 65 20 63 68 61 72 61   write the chara
2da0: 63 74 65 72 73 20 69 6e 74 6f 3c 2f 70 61 72 61  cters into</para
2db0: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  m>.    /// <para
2dc0: 6d 20 6e 61 6d 65 3d 22 62 75 66 66 65 72 6f 66  m name="bufferof
2dd0: 66 73 65 74 22 3e 54 68 65 20 7a 65 72 6f 2d 62  fset">The zero-b
2de0: 61 73 65 64 20 69 6e 64 65 78 20 6f 66 20 77 68  ased index of wh
2df0: 65 72 65 20 74 6f 20 62 65 67 69 6e 20 77 72 69  ere to begin wri
2e00: 74 69 6e 67 20 69 6e 74 6f 20 74 68 65 20 61 72  ting into the ar
2e10: 72 61 79 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20  ray</param>.    
2e20: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
2e30: 22 6c 65 6e 67 74 68 22 3e 54 68 65 20 6e 75 6d  "length">The num
2e40: 62 65 72 20 6f 66 20 62 79 74 65 73 20 74 6f 20  ber of bytes to 
2e50: 72 65 74 72 69 65 76 65 3c 2f 70 61 72 61 6d 3e  retrieve</param>
2e60: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
2e70: 73 3e 54 68 65 20 61 63 74 75 61 6c 20 6e 75 6d  s>The actual num
2e80: 62 65 72 20 6f 66 20 63 68 61 72 61 63 74 65 72  ber of character
2e90: 73 20 77 72 69 74 74 65 6e 20 69 6e 74 6f 20 74  s written into t
2ea0: 68 65 20 61 72 72 61 79 3c 2f 72 65 74 75 72 6e  he array</return
2eb0: 73 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 6d 61  s>.    /// <rema
2ec0: 72 6b 73 3e 0a 20 20 20 20 2f 2f 2f 20 54 6f 20  rks>.    /// To 
2ed0: 64 65 74 65 72 6d 69 6e 65 20 74 68 65 20 6e 75  determine the nu
2ee0: 6d 62 65 72 20 6f 66 20 63 68 61 72 61 63 74 65  mber of characte
2ef0: 72 73 20 69 6e 20 74 68 65 20 63 6f 6c 75 6d 6e  rs in the column
2f00: 2c 20 70 61 73 73 20 61 20 6e 75 6c 6c 20 76 61  , pass a null va
2f10: 6c 75 65 20 66 6f 72 20 74 68 65 20 62 75 66 66  lue for the buff
2f20: 65 72 2e 20 20 54 68 65 20 74 6f 74 61 6c 20 6c  er.  The total l
2f30: 65 6e 67 74 68 20 77 69 6c 6c 20 62 65 20 72 65  ength will be re
2f40: 74 75 72 6e 65 64 2e 0a 20 20 20 20 2f 2f 2f 20  turned..    /// 
2f50: 3c 2f 72 65 6d 61 72 6b 73 3e 0a 20 20 20 20 70  </remarks>.    p
2f60: 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 6c  ublic override l
2f70: 6f 6e 67 20 47 65 74 43 68 61 72 73 28 69 6e 74  ong GetChars(int
2f80: 20 69 2c 20 6c 6f 6e 67 20 66 69 65 6c 64 6f 66   i, long fieldof
2f90: 66 73 65 74 2c 20 63 68 61 72 5b 5d 20 62 75 66  fset, char[] buf
2fa0: 66 65 72 2c 20 69 6e 74 20 62 75 66 66 65 72 6f  fer, int buffero
2fb0: 66 66 73 65 74 2c 20 69 6e 74 20 6c 65 6e 67 74  ffset, int lengt
2fc0: 68 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  h).    {.      i
2fd0: 66 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46  f (i >= VisibleF
2fe0: 69 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65  ieldCount && _ke
2ff0: 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20  yInfo != null). 
3000: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b         return _k
3010: 65 79 49 6e 66 6f 2e 47 65 74 43 68 61 72 73 28  eyInfo.GetChars(
3020: 69 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64  i - VisibleField
3030: 43 6f 75 6e 74 2c 20 66 69 65 6c 64 6f 66 66 73  Count, fieldoffs
3040: 65 74 2c 20 62 75 66 66 65 72 2c 20 62 75 66 66  et, buffer, buff
3050: 65 72 6f 66 66 73 65 74 2c 20 6c 65 6e 67 74 68  eroffset, length
3060: 29 3b 0a 0a 20 20 20 20 20 20 56 65 72 69 66 79  );..      Verify
3070: 54 79 70 65 28 69 2c 20 44 62 54 79 70 65 2e 53  Type(i, DbType.S
3080: 74 72 69 6e 67 29 3b 0a 20 20 20 20 20 20 72 65  tring);.      re
3090: 74 75 72 6e 20 5f 61 63 74 69 76 65 53 74 61 74  turn _activeStat
30a0: 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 43 68  ement._sql.GetCh
30b0: 61 72 73 28 5f 61 63 74 69 76 65 53 74 61 74 65  ars(_activeState
30c0: 6d 65 6e 74 2c 20 69 2c 20 28 69 6e 74 29 66 69  ment, i, (int)fi
30d0: 65 6c 64 6f 66 66 73 65 74 2c 20 62 75 66 66 65  eldoffset, buffe
30e0: 72 2c 20 62 75 66 66 65 72 6f 66 66 73 65 74 2c  r, bufferoffset,
30f0: 20 6c 65 6e 67 74 68 29 3b 0a 20 20 20 20 7d 0a   length);.    }.
3100: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
3110: 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74 72 69  y>.    /// Retri
3120: 65 76 65 73 20 74 68 65 20 6e 61 6d 65 20 6f 66  eves the name of
3130: 20 74 68 65 20 62 61 63 6b 2d 65 6e 64 20 64 61   the back-end da
3140: 74 61 74 79 70 65 20 6f 66 20 74 68 65 20 63 6f  tatype of the co
3150: 6c 75 6d 6e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  lumn.    /// </s
3160: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
3170: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e  <param name="i">
3180: 54 68 65 20 69 6e 64 65 78 20 6f 66 20 74 68 65  The index of the
3190: 20 63 6f 6c 75 6d 6e 20 74 6f 20 72 65 74 72 69   column to retri
31a0: 65 76 65 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20  eve</param>.    
31b0: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 73 74 72  /// <returns>str
31c0: 69 6e 67 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20  ing</returns>.  
31d0: 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64    public overrid
31e0: 65 20 73 74 72 69 6e 67 20 47 65 74 44 61 74 61  e string GetData
31f0: 54 79 70 65 4e 61 6d 65 28 69 6e 74 20 69 29 0a  TypeName(int i).
3200: 20 20 20 20 7b 0a 20 20 20 20 20 20 69 66 20 28      {.      if (
3210: 69 20 3e 3d 20 56 69 73 69 62 6c 65 46 69 65 6c  i >= VisibleFiel
3220: 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65 79 49 6e  dCount && _keyIn
3230: 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20  fo != null).    
3240: 20 20 20 20 72 65 74 75 72 6e 20 5f 6b 65 79 49      return _keyI
3250: 6e 66 6f 2e 47 65 74 44 61 74 61 54 79 70 65 4e  nfo.GetDataTypeN
3260: 61 6d 65 28 69 20 2d 20 56 69 73 69 62 6c 65 46  ame(i - VisibleF
3270: 69 65 6c 64 43 6f 75 6e 74 29 3b 0a 0a 20 20 20  ieldCount);..   
3280: 20 20 20 53 51 4c 69 74 65 54 79 70 65 20 74 79     SQLiteType ty
3290: 70 20 3d 20 47 65 74 53 51 4c 69 74 65 54 79 70  p = GetSQLiteTyp
32a0: 65 28 69 29 3b 0a 20 20 20 20 20 20 69 66 20 28  e(i);.      if (
32b0: 74 79 70 2e 54 79 70 65 20 3d 3d 20 44 62 54 79  typ.Type == DbTy
32c0: 70 65 2e 4f 62 6a 65 63 74 29 20 72 65 74 75 72  pe.Object) retur
32d0: 6e 20 53 51 4c 69 74 65 43 6f 6e 76 65 72 74 2e  n SQLiteConvert.
32e0: 53 51 4c 69 74 65 54 79 70 65 54 6f 54 79 70 65  SQLiteTypeToType
32f0: 28 74 79 70 29 2e 4e 61 6d 65 3b 0a 20 20 20 20  (typ).Name;.    
3300: 20 20 72 65 74 75 72 6e 20 5f 61 63 74 69 76 65    return _active
3310: 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 43  Statement._sql.C
3320: 6f 6c 75 6d 6e 54 79 70 65 28 5f 61 63 74 69 76  olumnType(_activ
3330: 65 53 74 61 74 65 6d 65 6e 74 2c 20 69 2c 20 6f  eStatement, i, o
3340: 75 74 20 74 79 70 2e 41 66 66 69 6e 69 74 79 29  ut typ.Affinity)
3350: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f  ;.    }..    ///
3360: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
3370: 2f 2f 20 52 65 74 72 69 65 76 65 20 74 68 65 20  // Retrieve the 
3380: 63 6f 6c 75 6d 6e 20 61 73 20 61 20 64 61 74 65  column as a date
3390: 2f 74 69 6d 65 20 76 61 6c 75 65 0a 20 20 20 20  /time value.    
33a0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
33b0: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
33c0: 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e 64 65 78  me="i">The index
33d0: 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 20 74   of the column t
33e0: 6f 20 72 65 74 72 69 65 76 65 3c 2f 70 61 72 61  o retrieve</para
33f0: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75  m>.    /// <retu
3400: 72 6e 73 3e 44 61 74 65 54 69 6d 65 3c 2f 72 65  rns>DateTime</re
3410: 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69  turns>.    publi
3420: 63 20 6f 76 65 72 72 69 64 65 20 44 61 74 65 54  c override DateT
3430: 69 6d 65 20 47 65 74 44 61 74 65 54 69 6d 65 28  ime GetDateTime(
3440: 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a 20 20 20  int i).    {.   
3450: 20 20 20 69 66 20 28 69 20 3e 3d 20 56 69 73 69     if (i >= Visi
3460: 62 6c 65 46 69 65 6c 64 43 6f 75 6e 74 20 26 26  bleFieldCount &&
3470: 20 5f 6b 65 79 49 6e 66 6f 20 21 3d 20 6e 75 6c   _keyInfo != nul
3480: 6c 29 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  l).        retur
3490: 6e 20 5f 6b 65 79 49 6e 66 6f 2e 47 65 74 44 61  n _keyInfo.GetDa
34a0: 74 65 54 69 6d 65 28 69 20 2d 20 56 69 73 69 62  teTime(i - Visib
34b0: 6c 65 46 69 65 6c 64 43 6f 75 6e 74 29 3b 0a 0a  leFieldCount);..
34c0: 20 20 20 20 20 20 56 65 72 69 66 79 54 79 70 65        VerifyType
34d0: 28 69 2c 20 44 62 54 79 70 65 2e 44 61 74 65 54  (i, DbType.DateT
34e0: 69 6d 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75  ime);.      retu
34f0: 72 6e 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d  rn _activeStatem
3500: 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 44 61 74 65  ent._sql.GetDate
3510: 54 69 6d 65 28 5f 61 63 74 69 76 65 53 74 61 74  Time(_activeStat
3520: 65 6d 65 6e 74 2c 20 69 29 3b 0a 20 20 20 20 7d  ement, i);.    }
3530: 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
3540: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74 72  ry>.    /// Retr
3550: 69 65 76 65 20 74 68 65 20 63 6f 6c 75 6d 6e 20  ieve the column 
3560: 61 73 20 61 20 64 65 63 69 6d 61 6c 20 76 61 6c  as a decimal val
3570: 75 65 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ue.    /// </sum
3580: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  mary>.    /// <p
3590: 61 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54 68  aram name="i">Th
35a0: 65 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20 63  e index of the c
35b0: 6f 6c 75 6d 6e 20 74 6f 20 72 65 74 72 69 65 76  olumn to retriev
35c0: 65 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f  e</param>.    //
35d0: 2f 20 3c 72 65 74 75 72 6e 73 3e 64 65 63 69 6d  / <returns>decim
35e0: 61 6c 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20  al</returns>.   
35f0: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
3600: 20 64 65 63 69 6d 61 6c 20 47 65 74 44 65 63 69   decimal GetDeci
3610: 6d 61 6c 28 69 6e 74 20 69 29 0a 20 20 20 20 7b  mal(int i).    {
3620: 0a 20 20 20 20 20 20 69 66 20 28 69 20 3e 3d 20  .      if (i >= 
3630: 56 69 73 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e  VisibleFieldCoun
3640: 74 20 26 26 20 5f 6b 65 79 49 6e 66 6f 20 21 3d  t && _keyInfo !=
3650: 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20 20 72   null).        r
3660: 65 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f 2e 47  eturn _keyInfo.G
3670: 65 74 44 65 63 69 6d 61 6c 28 69 20 2d 20 56 69  etDecimal(i - Vi
3680: 73 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e 74 29  sibleFieldCount)
3690: 3b 0a 0a 20 20 20 20 20 20 56 65 72 69 66 79 54  ;..      VerifyT
36a0: 79 70 65 28 69 2c 20 44 62 54 79 70 65 2e 44 65  ype(i, DbType.De
36b0: 63 69 6d 61 6c 29 3b 0a 20 20 20 20 20 20 72 65  cimal);.      re
36c0: 74 75 72 6e 20 44 65 63 69 6d 61 6c 2e 50 61 72  turn Decimal.Par
36d0: 73 65 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d  se(_activeStatem
36e0: 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 54 65 78 74  ent._sql.GetText
36f0: 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e  (_activeStatemen
3700: 74 2c 20 69 29 2c 20 4e 75 6d 62 65 72 53 74 79  t, i), NumberSty
3710: 6c 65 73 2e 41 6c 6c 6f 77 44 65 63 69 6d 61 6c  les.AllowDecimal
3720: 50 6f 69 6e 74 20 7c 20 4e 75 6d 62 65 72 53 74  Point | NumberSt
3730: 79 6c 65 73 2e 41 6c 6c 6f 77 45 78 70 6f 6e 65  yles.AllowExpone
3740: 6e 74 20 7c 20 4e 75 6d 62 65 72 53 74 79 6c 65  nt | NumberStyle
3750: 73 2e 41 6c 6c 6f 77 4c 65 61 64 69 6e 67 53 69  s.AllowLeadingSi
3760: 67 6e 2c 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e  gn, CultureInfo.
3770: 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65  InvariantCulture
3780: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f  );.    }..    //
3790: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20  / <summary>.    
37a0: 2f 2f 2f 20 52 65 74 75 72 6e 73 20 74 68 65 20  /// Returns the 
37b0: 63 6f 6c 75 6d 6e 20 61 73 20 61 20 64 6f 75 62  column as a doub
37c0: 6c 65 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  le.    /// </sum
37d0: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  mary>.    /// <p
37e0: 61 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54 68  aram name="i">Th
37f0: 65 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20 63  e index of the c
3800: 6f 6c 75 6d 6e 20 74 6f 20 72 65 74 72 69 65 76  olumn to retriev
3810: 65 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f  e</param>.    //
3820: 2f 20 3c 72 65 74 75 72 6e 73 3e 64 6f 75 62 6c  / <returns>doubl
3830: 65 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20  e</returns>.    
3840: 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20  public override 
3850: 64 6f 75 62 6c 65 20 47 65 74 44 6f 75 62 6c 65  double GetDouble
3860: 28 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a 20 20  (int i).    {.  
3870: 20 20 20 20 69 66 20 28 69 20 3e 3d 20 56 69 73      if (i >= Vis
3880: 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e 74 20 26  ibleFieldCount &
3890: 26 20 5f 6b 65 79 49 6e 66 6f 20 21 3d 20 6e 75  & _keyInfo != nu
38a0: 6c 6c 29 0a 20 20 20 20 20 20 20 20 72 65 74 75  ll).        retu
38b0: 72 6e 20 5f 6b 65 79 49 6e 66 6f 2e 47 65 74 44  rn _keyInfo.GetD
38c0: 6f 75 62 6c 65 28 69 20 2d 20 56 69 73 69 62 6c  ouble(i - Visibl
38d0: 65 46 69 65 6c 64 43 6f 75 6e 74 29 3b 0a 0a 20  eFieldCount);.. 
38e0: 20 20 20 20 20 56 65 72 69 66 79 54 79 70 65 28       VerifyType(
38f0: 69 2c 20 44 62 54 79 70 65 2e 44 6f 75 62 6c 65  i, DbType.Double
3900: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  );.      return 
3910: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
3920: 2e 5f 73 71 6c 2e 47 65 74 44 6f 75 62 6c 65 28  ._sql.GetDouble(
3930: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
3940: 2c 20 69 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  , i);.    }..   
3950: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
3960: 20 20 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20 74     /// Returns t
3970: 68 65 20 2e 4e 45 54 20 74 79 70 65 20 6f 66 20  he .NET type of 
3980: 61 20 67 69 76 65 6e 20 63 6f 6c 75 6d 6e 0a 20  a given column. 
3990: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
39a0: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
39b0: 20 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e   name="i">The in
39c0: 64 65 78 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d  dex of the colum
39d0: 6e 20 74 6f 20 72 65 74 72 69 65 76 65 3c 2f 70  n to retrieve</p
39e0: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72  aram>.    /// <r
39f0: 65 74 75 72 6e 73 3e 54 79 70 65 3c 2f 72 65 74  eturns>Type</ret
3a00: 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63  urns>.    public
3a10: 20 6f 76 65 72 72 69 64 65 20 54 79 70 65 20 47   override Type G
3a20: 65 74 46 69 65 6c 64 54 79 70 65 28 69 6e 74 20  etFieldType(int 
3a30: 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  i).    {.      i
3a40: 66 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46  f (i >= VisibleF
3a50: 69 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65  ieldCount && _ke
3a60: 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20  yInfo != null). 
3a70: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b         return _k
3a80: 65 79 49 6e 66 6f 2e 47 65 74 46 69 65 6c 64 54  eyInfo.GetFieldT
3a90: 79 70 65 28 69 20 2d 20 56 69 73 69 62 6c 65 46  ype(i - VisibleF
3aa0: 69 65 6c 64 43 6f 75 6e 74 29 3b 0a 0a 20 20 20  ieldCount);..   
3ab0: 20 20 20 72 65 74 75 72 6e 20 53 51 4c 69 74 65     return SQLite
3ac0: 43 6f 6e 76 65 72 74 2e 53 51 4c 69 74 65 54 79  Convert.SQLiteTy
3ad0: 70 65 54 6f 54 79 70 65 28 47 65 74 53 51 4c 69  peToType(GetSQLi
3ae0: 74 65 54 79 70 65 28 69 29 29 3b 0a 20 20 20 20  teType(i));.    
3af0: 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  }..    /// <summ
3b00: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74  ary>.    /// Ret
3b10: 75 72 6e 73 20 61 20 63 6f 6c 75 6d 6e 20 61 73  urns a column as
3b20: 20 61 20 66 6c 6f 61 74 20 76 61 6c 75 65 0a 20   a float value. 
3b30: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
3b40: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
3b50: 20 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e   name="i">The in
3b60: 64 65 78 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d  dex of the colum
3b70: 6e 20 74 6f 20 72 65 74 72 69 65 76 65 3c 2f 70  n to retrieve</p
3b80: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72  aram>.    /// <r
3b90: 65 74 75 72 6e 73 3e 66 6c 6f 61 74 3c 2f 72 65  eturns>float</re
3ba0: 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69  turns>.    publi
3bb0: 63 20 6f 76 65 72 72 69 64 65 20 66 6c 6f 61 74  c override float
3bc0: 20 47 65 74 46 6c 6f 61 74 28 69 6e 74 20 69 29   GetFloat(int i)
3bd0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 66 20  .    {.      if 
3be0: 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46 69 65  (i >= VisibleFie
3bf0: 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65 79 49  ldCount && _keyI
3c00: 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20  nfo != null).   
3c10: 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b 65 79       return _key
3c20: 49 6e 66 6f 2e 47 65 74 46 6c 6f 61 74 28 69 20  Info.GetFloat(i 
3c30: 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64 43 6f  - VisibleFieldCo
3c40: 75 6e 74 29 3b 0a 0a 20 20 20 20 20 20 56 65 72  unt);..      Ver
3c50: 69 66 79 54 79 70 65 28 69 2c 20 44 62 54 79 70  ifyType(i, DbTyp
3c60: 65 2e 53 69 6e 67 6c 65 29 3b 0a 20 20 20 20 20  e.Single);.     
3c70: 20 72 65 74 75 72 6e 20 43 6f 6e 76 65 72 74 2e   return Convert.
3c80: 54 6f 53 69 6e 67 6c 65 28 5f 61 63 74 69 76 65  ToSingle(_active
3c90: 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47  Statement._sql.G
3ca0: 65 74 44 6f 75 62 6c 65 28 5f 61 63 74 69 76 65  etDouble(_active
3cb0: 53 74 61 74 65 6d 65 6e 74 2c 20 69 29 29 3b 0a  Statement, i));.
3cc0: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c      }..    /// <
3cd0: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
3ce0: 20 52 65 74 75 72 6e 73 20 74 68 65 20 63 6f 6c   Returns the col
3cf0: 75 6d 6e 20 61 73 20 61 20 47 75 69 64 0a 20 20  umn as a Guid.  
3d00: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
3d10: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
3d20: 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e 64  name="i">The ind
3d30: 65 78 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e  ex of the column
3d40: 20 74 6f 20 72 65 74 72 69 65 76 65 3c 2f 70 61   to retrieve</pa
3d50: 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ram>.    /// <re
3d60: 74 75 72 6e 73 3e 47 75 69 64 3c 2f 72 65 74 75  turns>Guid</retu
3d70: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
3d80: 6f 76 65 72 72 69 64 65 20 47 75 69 64 20 47 65  override Guid Ge
3d90: 74 47 75 69 64 28 69 6e 74 20 69 29 0a 20 20 20  tGuid(int i).   
3da0: 20 7b 0a 20 20 20 20 20 20 69 66 20 28 69 20 3e   {.      if (i >
3db0: 3d 20 56 69 73 69 62 6c 65 46 69 65 6c 64 43 6f  = VisibleFieldCo
3dc0: 75 6e 74 20 26 26 20 5f 6b 65 79 49 6e 66 6f 20  unt && _keyInfo 
3dd0: 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20  != null).       
3de0: 20 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e 66 6f   return _keyInfo
3df0: 2e 47 65 74 47 75 69 64 28 69 20 2d 20 56 69 73  .GetGuid(i - Vis
3e00: 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e 74 29 3b  ibleFieldCount);
3e10: 0a 0a 20 20 20 20 20 20 54 79 70 65 41 66 66 69  ..      TypeAffi
3e20: 6e 69 74 79 20 61 66 66 69 6e 69 74 79 20 3d 20  nity affinity = 
3e30: 56 65 72 69 66 79 54 79 70 65 28 69 2c 20 44 62  VerifyType(i, Db
3e40: 54 79 70 65 2e 47 75 69 64 29 3b 0a 20 20 20 20  Type.Guid);.    
3e50: 20 20 69 66 20 28 61 66 66 69 6e 69 74 79 20 3d    if (affinity =
3e60: 3d 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 42  = TypeAffinity.B
3e70: 6c 6f 62 29 0a 20 20 20 20 20 20 7b 0a 20 20 20  lob).      {.   
3e80: 20 20 20 20 20 62 79 74 65 5b 5d 20 62 75 66 66       byte[] buff
3e90: 65 72 20 3d 20 6e 65 77 20 62 79 74 65 5b 31 36  er = new byte[16
3ea0: 5d 3b 0a 20 20 20 20 20 20 20 20 5f 61 63 74 69  ];.        _acti
3eb0: 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c  veStatement._sql
3ec0: 2e 47 65 74 42 79 74 65 73 28 5f 61 63 74 69 76  .GetBytes(_activ
3ed0: 65 53 74 61 74 65 6d 65 6e 74 2c 20 69 2c 20 30  eStatement, i, 0
3ee0: 2c 20 62 75 66 66 65 72 2c 20 30 2c 20 31 36 29  , buffer, 0, 16)
3ef0: 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ;.        return
3f00: 20 6e 65 77 20 47 75 69 64 28 62 75 66 66 65 72   new Guid(buffer
3f10: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  );.      }.     
3f20: 20 65 6c 73 65 0a 20 20 20 20 20 20 20 20 72 65   else.        re
3f30: 74 75 72 6e 20 6e 65 77 20 47 75 69 64 28 5f 61  turn new Guid(_a
3f40: 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f  ctiveStatement._
3f50: 73 71 6c 2e 47 65 74 54 65 78 74 28 5f 61 63 74  sql.GetText(_act
3f60: 69 76 65 53 74 61 74 65 6d 65 6e 74 2c 20 69 29  iveStatement, i)
3f70: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f  );.    }..    //
3f80: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20  / <summary>.    
3f90: 2f 2f 2f 20 52 65 74 75 72 6e 73 20 74 68 65 20  /// Returns the 
3fa0: 63 6f 6c 75 6d 6e 20 61 73 20 61 20 73 68 6f 72  column as a shor
3fb0: 74 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  t.    /// </summ
3fc0: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  ary>.    /// <pa
3fd0: 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54 68 65  ram name="i">The
3fe0: 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20 63 6f   index of the co
3ff0: 6c 75 6d 6e 20 74 6f 20 72 65 74 72 69 65 76 65  lumn to retrieve
4000: 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f  </param>.    ///
4010: 20 3c 72 65 74 75 72 6e 73 3e 49 6e 74 31 36 3c   <returns>Int16<
4020: 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75  /returns>.    pu
4030: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 49 6e  blic override In
4040: 74 31 36 20 47 65 74 49 6e 74 31 36 28 69 6e 74  t16 GetInt16(int
4050: 20 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20   i).    {.      
4060: 69 66 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65  if (i >= Visible
4070: 46 69 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b  FieldCount && _k
4080: 65 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a  eyInfo != null).
4090: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f          return _
40a0: 6b 65 79 49 6e 66 6f 2e 47 65 74 49 6e 74 31 36  keyInfo.GetInt16
40b0: 28 69 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c  (i - VisibleFiel
40c0: 64 43 6f 75 6e 74 29 3b 0a 0a 20 20 20 20 20 20  dCount);..      
40d0: 56 65 72 69 66 79 54 79 70 65 28 69 2c 20 44 62  VerifyType(i, Db
40e0: 54 79 70 65 2e 49 6e 74 31 36 29 3b 0a 20 20 20  Type.Int16);.   
40f0: 20 20 20 72 65 74 75 72 6e 20 43 6f 6e 76 65 72     return Conver
4100: 74 2e 54 6f 49 6e 74 31 36 28 5f 61 63 74 69 76  t.ToInt16(_activ
4110: 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e  eStatement._sql.
4120: 47 65 74 49 6e 74 33 32 28 5f 61 63 74 69 76 65  GetInt32(_active
4130: 53 74 61 74 65 6d 65 6e 74 2c 20 69 29 29 3b 0a  Statement, i));.
4140: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c      }..    /// <
4150: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
4160: 20 52 65 74 72 69 65 76 65 73 20 74 68 65 20 63   Retrieves the c
4170: 6f 6c 75 6d 6e 20 61 73 20 61 6e 20 69 6e 74 0a  olumn as an int.
4180: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
4190: 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  y>.    /// <para
41a0: 6d 20 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20 69  m name="i">The i
41b0: 6e 64 65 78 20 6f 66 20 74 68 65 20 63 6f 6c 75  ndex of the colu
41c0: 6d 6e 20 74 6f 20 72 65 74 72 69 65 76 65 3c 2f  mn to retrieve</
41d0: 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c  param>.    /// <
41e0: 72 65 74 75 72 6e 73 3e 49 6e 74 33 32 3c 2f 72  returns>Int32</r
41f0: 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c  eturns>.    publ
4200: 69 63 20 6f 76 65 72 72 69 64 65 20 49 6e 74 33  ic override Int3
4210: 32 20 47 65 74 49 6e 74 33 32 28 69 6e 74 20 69  2 GetInt32(int i
4220: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 66  ).    {.      if
4230: 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46 69   (i >= VisibleFi
4240: 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65 79  eldCount && _key
4250: 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20  Info != null).  
4260: 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b 65        return _ke
4270: 79 49 6e 66 6f 2e 47 65 74 49 6e 74 33 32 28 69  yInfo.GetInt32(i
4280: 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64 43   - VisibleFieldC
4290: 6f 75 6e 74 29 3b 0a 0a 20 20 20 20 20 20 56 65  ount);..      Ve
42a0: 72 69 66 79 54 79 70 65 28 69 2c 20 44 62 54 79  rifyType(i, DbTy
42b0: 70 65 2e 49 6e 74 33 32 29 3b 0a 20 20 20 20 20  pe.Int32);.     
42c0: 20 72 65 74 75 72 6e 20 5f 61 63 74 69 76 65 53   return _activeS
42d0: 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65  tatement._sql.Ge
42e0: 74 49 6e 74 33 32 28 5f 61 63 74 69 76 65 53 74  tInt32(_activeSt
42f0: 61 74 65 6d 65 6e 74 2c 20 69 29 3b 0a 20 20 20  atement, i);.   
4300: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
4310: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65  mary>.    /// Re
4320: 74 72 69 65 76 65 73 20 74 68 65 20 63 6f 6c 75  trieves the colu
4330: 6d 6e 20 61 73 20 61 20 6c 6f 6e 67 0a 20 20 20  mn as a long.   
4340: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
4350: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
4360: 61 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e 64 65  ame="i">The inde
4370: 78 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 20  x of the column 
4380: 74 6f 20 72 65 74 72 69 65 76 65 3c 2f 70 61 72  to retrieve</par
4390: 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74  am>.    /// <ret
43a0: 75 72 6e 73 3e 49 6e 74 36 34 3c 2f 72 65 74 75  urns>Int64</retu
43b0: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
43c0: 6f 76 65 72 72 69 64 65 20 49 6e 74 36 34 20 47  override Int64 G
43d0: 65 74 49 6e 74 36 34 28 69 6e 74 20 69 29 0a 20  etInt64(int i). 
43e0: 20 20 20 7b 0a 20 20 20 20 20 20 69 66 20 28 69     {.      if (i
43f0: 20 3e 3d 20 56 69 73 69 62 6c 65 46 69 65 6c 64   >= VisibleField
4400: 43 6f 75 6e 74 20 26 26 20 5f 6b 65 79 49 6e 66  Count && _keyInf
4410: 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20 20  o != null).     
4420: 20 20 20 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e     return _keyIn
4430: 66 6f 2e 47 65 74 49 6e 74 36 34 28 69 20 2d 20  fo.GetInt64(i - 
4440: 56 69 73 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e  VisibleFieldCoun
4450: 74 29 3b 0a 0a 20 20 20 20 20 20 56 65 72 69 66  t);..      Verif
4460: 79 54 79 70 65 28 69 2c 20 44 62 54 79 70 65 2e  yType(i, DbType.
4470: 49 6e 74 36 34 29 3b 0a 20 20 20 20 20 20 72 65  Int64);.      re
4480: 74 75 72 6e 20 5f 61 63 74 69 76 65 53 74 61 74  turn _activeStat
4490: 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 49 6e  ement._sql.GetIn
44a0: 74 36 34 28 5f 61 63 74 69 76 65 53 74 61 74 65  t64(_activeState
44b0: 6d 65 6e 74 2c 20 69 29 3b 0a 20 20 20 20 7d 0a  ment, i);.    }.
44c0: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
44d0: 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74 72 69  y>.    /// Retri
44e0: 65 76 65 73 20 74 68 65 20 6e 61 6d 65 20 6f 66  eves the name of
44f0: 20 74 68 65 20 63 6f 6c 75 6d 6e 0a 20 20 20 20   the column.    
4500: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
4510: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
4520: 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e 64 65 78  me="i">The index
4530: 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 20 74   of the column t
4540: 6f 20 72 65 74 72 69 65 76 65 3c 2f 70 61 72 61  o retrieve</para
4550: 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75  m>.    /// <retu
4560: 72 6e 73 3e 73 74 72 69 6e 67 3c 2f 72 65 74 75  rns>string</retu
4570: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
4580: 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67 20  override string 
4590: 47 65 74 4e 61 6d 65 28 69 6e 74 20 69 29 0a 20  GetName(int i). 
45a0: 20 20 20 7b 0a 20 20 20 20 20 20 69 66 20 28 69     {.      if (i
45b0: 20 3e 3d 20 56 69 73 69 62 6c 65 46 69 65 6c 64   >= VisibleField
45c0: 43 6f 75 6e 74 20 26 26 20 5f 6b 65 79 49 6e 66  Count && _keyInf
45d0: 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20 20  o != null).     
45e0: 20 20 20 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e     return _keyIn
45f0: 66 6f 2e 47 65 74 4e 61 6d 65 28 69 20 2d 20 56  fo.GetName(i - V
4600: 69 73 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e 74  isibleFieldCount
4610: 29 3b 0a 0a 20 20 20 20 20 20 72 65 74 75 72 6e  );..      return
4620: 20 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e   _activeStatemen
4630: 74 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e 4e 61 6d  t._sql.ColumnNam
4640: 65 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65  e(_activeStateme
4650: 6e 74 2c 20 69 29 3b 0a 20 20 20 20 7d 0a 0a 20  nt, i);.    }.. 
4660: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
4670: 0a 20 20 20 20 2f 2f 2f 20 52 65 74 72 69 65 76  .    /// Retriev
4680: 65 73 20 74 68 65 20 69 20 6f 66 20 61 20 63 6f  es the i of a co
4690: 6c 75 6d 6e 2c 20 67 69 76 65 6e 20 69 74 73 20  lumn, given its 
46a0: 6e 61 6d 65 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  name.    /// </s
46b0: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
46c0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6e 61 6d  <param name="nam
46d0: 65 22 3e 54 68 65 20 6e 61 6d 65 20 6f 66 20 74  e">The name of t
46e0: 68 65 20 63 6f 6c 75 6d 6e 20 74 6f 20 72 65 74  he column to ret
46f0: 72 69 65 76 65 3c 2f 70 61 72 61 6d 3e 0a 20 20  rieve</param>.  
4700: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54    /// <returns>T
4710: 68 65 20 69 6e 74 20 69 20 6f 66 20 74 68 65 20  he int i of the 
4720: 63 6f 6c 75 6d 6e 3c 2f 72 65 74 75 72 6e 73 3e  column</returns>
4730: 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72  .    public over
4740: 72 69 64 65 20 69 6e 74 20 47 65 74 4f 72 64 69  ride int GetOrdi
4750: 6e 61 6c 28 73 74 72 69 6e 67 20 6e 61 6d 65 29  nal(string name)
4760: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 43 68 65  .    {.      Che
4770: 63 6b 43 6c 6f 73 65 64 28 29 3b 0a 20 20 20 20  ckClosed();.    
4780: 20 20 69 6e 74 20 72 20 3d 20 5f 61 63 74 69 76    int r = _activ
4790: 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e  eStatement._sql.
47a0: 43 6f 6c 75 6d 6e 49 6e 64 65 78 28 5f 61 63 74  ColumnIndex(_act
47b0: 69 76 65 53 74 61 74 65 6d 65 6e 74 2c 20 6e 61  iveStatement, na
47c0: 6d 65 29 3b 0a 20 20 20 20 20 20 69 66 20 28 72  me);.      if (r
47d0: 20 3d 3d 20 2d 31 20 26 26 20 5f 6b 65 79 49 6e   == -1 && _keyIn
47e0: 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20  fo != null).    
47f0: 20 20 7b 0a 20 20 20 20 20 20 20 20 72 20 3d 20    {.        r = 
4800: 5f 6b 65 79 49 6e 66 6f 2e 47 65 74 4f 72 64 69  _keyInfo.GetOrdi
4810: 6e 61 6c 28 6e 61 6d 65 29 3b 0a 20 20 20 20 20  nal(name);.     
4820: 20 20 20 69 66 20 28 72 20 3e 20 2d 31 29 20 72     if (r > -1) r
4830: 20 2b 3d 20 56 69 73 69 62 6c 65 46 69 65 6c 64   += VisibleField
4840: 43 6f 75 6e 74 3b 0a 20 20 20 20 20 20 7d 0a 0a  Count;.      }..
4850: 20 20 20 20 20 20 72 65 74 75 72 6e 20 72 3b 0a        return r;.
4860: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c      }..    /// <
4870: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
4880: 20 53 63 68 65 6d 61 20 69 6e 66 6f 72 6d 61 74   Schema informat
4890: 69 6f 6e 20 69 6e 20 53 51 4c 69 74 65 20 69 73  ion in SQLite is
48a0: 20 64 69 66 66 69 63 75 6c 74 20 74 6f 20 6d 61   difficult to ma
48b0: 70 20 69 6e 74 6f 20 2e 4e 45 54 20 63 6f 6e 76  p into .NET conv
48c0: 65 6e 74 69 6f 6e 73 2c 20 73 6f 20 61 20 6c 6f  entions, so a lo
48d0: 74 20 6f 66 20 77 6f 72 6b 20 6d 75 73 74 20 62  t of work must b
48e0: 65 20 64 6f 6e 65 0a 20 20 20 20 2f 2f 2f 20 74  e done.    /// t
48f0: 6f 20 67 61 74 68 65 72 20 74 68 65 20 6e 65 63  o gather the nec
4900: 65 73 73 61 72 79 20 69 6e 66 6f 72 6d 61 74 69  essary informati
4910: 6f 6e 20 73 6f 20 69 74 20 63 61 6e 20 62 65 20  on so it can be 
4920: 72 65 70 72 65 73 65 6e 74 65 64 20 69 6e 20 61  represented in a
4930: 6e 20 41 44 4f 2e 4e 45 54 20 6d 61 6e 6e 65 72  n ADO.NET manner
4940: 2e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
4950: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ary>.    /// <re
4960: 74 75 72 6e 73 3e 52 65 74 75 72 6e 73 20 61 20  turns>Returns a 
4970: 44 61 74 61 54 61 62 6c 65 20 63 6f 6e 74 61 69  DataTable contai
4980: 6e 69 6e 67 20 74 68 65 20 73 63 68 65 6d 61 20  ning the schema 
4990: 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 66 6f 72 20  information for 
49a0: 74 68 65 20 61 63 74 69 76 65 20 53 45 4c 45 43  the active SELEC
49b0: 54 20 73 74 61 74 65 6d 65 6e 74 20 62 65 69 6e  T statement bein
49c0: 67 20 70 72 6f 63 65 73 73 65 64 2e 3c 2f 72 65  g processed.</re
49d0: 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69  turns>.    publi
49e0: 63 20 6f 76 65 72 72 69 64 65 20 44 61 74 61 54  c override DataT
49f0: 61 62 6c 65 20 47 65 74 53 63 68 65 6d 61 54 61  able GetSchemaTa
4a00: 62 6c 65 28 29 0a 20 20 20 20 7b 0a 20 20 20 20  ble().    {.    
4a10: 20 20 72 65 74 75 72 6e 20 47 65 74 53 63 68 65    return GetSche
4a20: 6d 61 54 61 62 6c 65 28 74 72 75 65 2c 20 66 61  maTable(true, fa
4a30: 6c 73 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  lse);.    }..   
4a40: 20 69 6e 74 65 72 6e 61 6c 20 44 61 74 61 54 61   internal DataTa
4a50: 62 6c 65 20 47 65 74 53 63 68 65 6d 61 54 61 62  ble GetSchemaTab
4a60: 6c 65 28 62 6f 6f 6c 20 77 61 6e 74 55 6e 69 71  le(bool wantUniq
4a70: 75 65 49 6e 66 6f 2c 20 62 6f 6f 6c 20 77 61 6e  ueInfo, bool wan
4a80: 74 44 65 66 61 75 6c 74 56 61 6c 75 65 29 0a 20  tDefaultValue). 
4a90: 20 20 20 7b 0a 20 20 20 20 20 20 43 68 65 63 6b     {.      Check
4aa0: 43 6c 6f 73 65 64 28 29 3b 0a 0a 20 20 20 20 20  Closed();..     
4ab0: 20 44 61 74 61 54 61 62 6c 65 20 74 62 6c 20 3d   DataTable tbl =
4ac0: 20 6e 65 77 20 44 61 74 61 54 61 62 6c 65 28 22   new DataTable("
4ad0: 53 63 68 65 6d 61 54 61 62 6c 65 22 29 3b 0a 20  SchemaTable");. 
4ae0: 20 20 20 20 20 44 61 74 61 54 61 62 6c 65 20 74       DataTable t
4af0: 62 6c 49 6e 64 65 78 65 73 20 3d 20 6e 75 6c 6c  blIndexes = null
4b00: 3b 0a 20 20 20 20 20 20 44 61 74 61 54 61 62 6c  ;.      DataTabl
4b10: 65 20 74 62 6c 49 6e 64 65 78 43 6f 6c 75 6d 6e  e tblIndexColumn
4b20: 73 3b 0a 20 20 20 20 20 20 44 61 74 61 52 6f 77  s;.      DataRow
4b30: 20 72 6f 77 3b 0a 20 20 20 20 20 20 73 74 72 69   row;.      stri
4b40: 6e 67 20 74 65 6d 70 3b 0a 20 20 20 20 20 20 73  ng temp;.      s
4b50: 74 72 69 6e 67 20 73 74 72 43 61 74 61 6c 6f 67  tring strCatalog
4b60: 20 3d 20 22 22 3b 0a 20 20 20 20 20 20 73 74 72   = "";.      str
4b70: 69 6e 67 20 73 74 72 54 61 62 6c 65 20 3d 20 22  ing strTable = "
4b80: 22 3b 0a 20 20 20 20 20 20 73 74 72 69 6e 67 20  ";.      string 
4b90: 73 74 72 43 6f 6c 75 6d 6e 20 3d 20 22 22 3b 0a  strColumn = "";.
4ba0: 0a 20 20 20 20 20 20 74 62 6c 2e 4c 6f 63 61 6c  .      tbl.Local
4bb0: 65 20 3d 20 43 75 6c 74 75 72 65 49 6e 66 6f 2e  e = CultureInfo.
4bc0: 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65  InvariantCulture
4bd0: 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75  ;.      tbl.Colu
4be0: 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61  mns.Add(SchemaTa
4bf0: 62 6c 65 43 6f 6c 75 6d 6e 2e 43 6f 6c 75 6d 6e  bleColumn.Column
4c00: 4e 61 6d 65 2c 20 74 79 70 65 6f 66 28 53 74 72  Name, typeof(Str
4c10: 69 6e 67 29 29 3b 0a 20 20 20 20 20 20 74 62 6c  ing));.      tbl
4c20: 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63 68  .Columns.Add(Sch
4c30: 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 43  emaTableColumn.C
4c40: 6f 6c 75 6d 6e 4f 72 64 69 6e 61 6c 2c 20 74 79  olumnOrdinal, ty
4c50: 70 65 6f 66 28 69 6e 74 29 29 3b 0a 20 20 20 20  peof(int));.    
4c60: 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64    tbl.Columns.Ad
4c70: 64 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  d(SchemaTableCol
4c80: 75 6d 6e 2e 43 6f 6c 75 6d 6e 53 69 7a 65 2c 20  umn.ColumnSize, 
4c90: 74 79 70 65 6f 66 28 69 6e 74 29 29 3b 0a 20 20  typeof(int));.  
4ca0: 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e      tbl.Columns.
4cb0: 41 64 64 28 53 63 68 65 6d 61 54 61 62 6c 65 43  Add(SchemaTableC
4cc0: 6f 6c 75 6d 6e 2e 4e 75 6d 65 72 69 63 50 72 65  olumn.NumericPre
4cd0: 63 69 73 69 6f 6e 2c 20 74 79 70 65 6f 66 28 73  cision, typeof(s
4ce0: 68 6f 72 74 29 29 3b 0a 20 20 20 20 20 20 74 62  hort));.      tb
4cf0: 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63  l.Columns.Add(Sc
4d00: 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e  hemaTableColumn.
4d10: 4e 75 6d 65 72 69 63 53 63 61 6c 65 2c 20 74 79  NumericScale, ty
4d20: 70 65 6f 66 28 73 68 6f 72 74 29 29 3b 0a 20 20  peof(short));.  
4d30: 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e      tbl.Columns.
4d40: 41 64 64 28 53 63 68 65 6d 61 54 61 62 6c 65 43  Add(SchemaTableC
4d50: 6f 6c 75 6d 6e 2e 49 73 55 6e 69 71 75 65 2c 20  olumn.IsUnique, 
4d60: 74 79 70 65 6f 66 28 42 6f 6f 6c 65 61 6e 29 29  typeof(Boolean))
4d70: 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75  ;.      tbl.Colu
4d80: 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61  mns.Add(SchemaTa
4d90: 62 6c 65 43 6f 6c 75 6d 6e 2e 49 73 4b 65 79 2c  bleColumn.IsKey,
4da0: 20 74 79 70 65 6f 66 28 42 6f 6f 6c 65 61 6e 29   typeof(Boolean)
4db0: 29 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c  );.      tbl.Col
4dc0: 75 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54  umns.Add(SchemaT
4dd0: 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75  ableOptionalColu
4de0: 6d 6e 2e 42 61 73 65 53 65 72 76 65 72 4e 61 6d  mn.BaseServerNam
4df0: 65 2c 20 74 79 70 65 6f 66 28 73 74 72 69 6e 67  e, typeof(string
4e00: 29 29 3b 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f  ));.      tbl.Co
4e10: 6c 75 6d 6e 73 2e 41 64 64 28 53 63 68 65 6d 61  lumns.Add(Schema
4e20: 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c  TableOptionalCol
4e30: 75 6d 6e 2e 42 61 73 65 43 61 74 61 6c 6f 67 4e  umn.BaseCatalogN
4e40: 61 6d 65 2c 20 74 79 70 65 6f 66 28 53 74 72 69  ame, typeof(Stri
4e50: 6e 67 29 29 3b 0a 20 20 20 20 20 20 74 62 6c 2e  ng));.      tbl.
4e60: 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63 68 65  Columns.Add(Sche
4e70: 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61  maTableColumn.Ba
4e80: 73 65 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 74 79  seColumnName, ty
4e90: 70 65 6f 66 28 53 74 72 69 6e 67 29 29 3b 0a 20  peof(String));. 
4ea0: 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73       tbl.Columns
4eb0: 2e 41 64 64 28 53 63 68 65 6d 61 54 61 62 6c 65  .Add(SchemaTable
4ec0: 43 6f 6c 75 6d 6e 2e 42 61 73 65 53 63 68 65 6d  Column.BaseSchem
4ed0: 61 4e 61 6d 65 2c 20 74 79 70 65 6f 66 28 53 74  aName, typeof(St
4ee0: 72 69 6e 67 29 29 3b 0a 20 20 20 20 20 20 74 62  ring));.      tb
4ef0: 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63  l.Columns.Add(Sc
4f00: 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e  hemaTableColumn.
4f10: 42 61 73 65 54 61 62 6c 65 4e 61 6d 65 2c 20 74  BaseTableName, t
4f20: 79 70 65 6f 66 28 53 74 72 69 6e 67 29 29 3b 0a  ypeof(String));.
4f30: 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e        tbl.Column
4f40: 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61 62 6c  s.Add(SchemaTabl
4f50: 65 43 6f 6c 75 6d 6e 2e 44 61 74 61 54 79 70 65  eColumn.DataType
4f60: 2c 20 74 79 70 65 6f 66 28 54 79 70 65 29 29 3b  , typeof(Type));
4f70: 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d  .      tbl.Colum
4f80: 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61 62  ns.Add(SchemaTab
4f90: 6c 65 43 6f 6c 75 6d 6e 2e 41 6c 6c 6f 77 44 42  leColumn.AllowDB
4fa0: 4e 75 6c 6c 2c 20 74 79 70 65 6f 66 28 42 6f 6f  Null, typeof(Boo
4fb0: 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20 20 74 62  lean));.      tb
4fc0: 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63  l.Columns.Add(Sc
4fd0: 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e  hemaTableColumn.
4fe0: 50 72 6f 76 69 64 65 72 54 79 70 65 2c 20 74 79  ProviderType, ty
4ff0: 70 65 6f 66 28 69 6e 74 29 29 3b 0a 20 20 20 20  peof(int));.    
5000: 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64    tbl.Columns.Ad
5010: 64 28 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  d(SchemaTableCol
5020: 75 6d 6e 2e 49 73 41 6c 69 61 73 65 64 2c 20 74  umn.IsAliased, t
5030: 79 70 65 6f 66 28 42 6f 6f 6c 65 61 6e 29 29 3b  ypeof(Boolean));
5040: 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d  .      tbl.Colum
5050: 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61 62  ns.Add(SchemaTab
5060: 6c 65 43 6f 6c 75 6d 6e 2e 49 73 45 78 70 72 65  leColumn.IsExpre
5070: 73 73 69 6f 6e 2c 20 74 79 70 65 6f 66 28 42 6f  ssion, typeof(Bo
5080: 6f 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20 20 74  olean));.      t
5090: 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53  bl.Columns.Add(S
50a0: 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e  chemaTableOption
50b0: 61 6c 43 6f 6c 75 6d 6e 2e 49 73 41 75 74 6f 49  alColumn.IsAutoI
50c0: 6e 63 72 65 6d 65 6e 74 2c 20 74 79 70 65 6f 66  ncrement, typeof
50d0: 28 42 6f 6f 6c 65 61 6e 29 29 3b 0a 20 20 20 20  (Boolean));.    
50e0: 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64    tbl.Columns.Ad
50f0: 64 28 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74  d(SchemaTableOpt
5100: 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 52 6f  ionalColumn.IsRo
5110: 77 56 65 72 73 69 6f 6e 2c 20 74 79 70 65 6f 66  wVersion, typeof
5120: 28 42 6f 6f 6c 65 61 6e 29 29 3b 0a 20 20 20 20  (Boolean));.    
5130: 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64    tbl.Columns.Ad
5140: 64 28 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74  d(SchemaTableOpt
5150: 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 48 69  ionalColumn.IsHi
5160: 64 64 65 6e 2c 20 74 79 70 65 6f 66 28 42 6f 6f  dden, typeof(Boo
5170: 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20 20 74 62  lean));.      tb
5180: 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63  l.Columns.Add(Sc
5190: 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e  hemaTableColumn.
51a0: 49 73 4c 6f 6e 67 2c 20 74 79 70 65 6f 66 28 42  IsLong, typeof(B
51b0: 6f 6f 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20 20  oolean));.      
51c0: 74 62 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28  tbl.Columns.Add(
51d0: 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f  SchemaTableOptio
51e0: 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 52 65 61 64  nalColumn.IsRead
51f0: 4f 6e 6c 79 2c 20 74 79 70 65 6f 66 28 42 6f 6f  Only, typeof(Boo
5200: 6c 65 61 6e 29 29 3b 0a 20 20 20 20 20 20 74 62  lean));.      tb
5210: 6c 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 53 63  l.Columns.Add(Sc
5220: 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61  hemaTableOptiona
5230: 6c 43 6f 6c 75 6d 6e 2e 50 72 6f 76 69 64 65 72  lColumn.Provider
5240: 53 70 65 63 69 66 69 63 44 61 74 61 54 79 70 65  SpecificDataType
5250: 2c 20 74 79 70 65 6f 66 28 54 79 70 65 29 29 3b  , typeof(Type));
5260: 0a 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d  .      tbl.Colum
5270: 6e 73 2e 41 64 64 28 53 63 68 65 6d 61 54 61 62  ns.Add(SchemaTab
5280: 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e  leOptionalColumn
5290: 2e 44 65 66 61 75 6c 74 56 61 6c 75 65 2c 20 74  .DefaultValue, t
52a0: 79 70 65 6f 66 28 6f 62 6a 65 63 74 29 29 3b 0a  ypeof(object));.
52b0: 20 20 20 20 20 20 74 62 6c 2e 43 6f 6c 75 6d 6e        tbl.Column
52c0: 73 2e 41 64 64 28 22 44 61 74 61 54 79 70 65 4e  s.Add("DataTypeN
52d0: 61 6d 65 22 2c 20 74 79 70 65 6f 66 28 73 74 72  ame", typeof(str
52e0: 69 6e 67 29 29 3b 0a 20 20 20 20 20 20 74 62 6c  ing));.      tbl
52f0: 2e 43 6f 6c 75 6d 6e 73 2e 41 64 64 28 22 43 6f  .Columns.Add("Co
5300: 6c 6c 61 74 69 6f 6e 54 79 70 65 22 2c 20 74 79  llationType", ty
5310: 70 65 6f 66 28 73 74 72 69 6e 67 29 29 3b 0a 20  peof(string));. 
5320: 20 20 20 20 20 74 62 6c 2e 42 65 67 69 6e 4c 6f       tbl.BeginLo
5330: 61 64 44 61 74 61 28 29 3b 0a 0a 20 20 20 20 20  adData();..     
5340: 20 66 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b   for (int n = 0;
5350: 20 6e 20 3c 20 5f 66 69 65 6c 64 43 6f 75 6e 74   n < _fieldCount
5360: 3b 20 6e 2b 2b 29 0a 20 20 20 20 20 20 7b 0a 20  ; n++).      {. 
5370: 20 20 20 20 20 20 20 72 6f 77 20 3d 20 74 62 6c         row = tbl
5380: 2e 4e 65 77 52 6f 77 28 29 3b 0a 0a 20 20 20 20  .NewRow();..    
5390: 20 20 20 20 44 62 54 79 70 65 20 74 79 70 20 3d      DbType typ =
53a0: 20 47 65 74 53 51 4c 69 74 65 54 79 70 65 28 6e   GetSQLiteType(n
53b0: 29 2e 54 79 70 65 3b 0a 0a 20 20 20 20 20 20 20  ).Type;..       
53c0: 20 2f 2f 20 44 65 66 61 75 6c 74 20 73 65 74 74   // Default sett
53d0: 69 6e 67 73 20 66 6f 72 20 74 68 65 20 63 6f 6c  ings for the col
53e0: 75 6d 6e 0a 20 20 20 20 20 20 20 20 72 6f 77 5b  umn.        row[
53f0: 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d  SchemaTableColum
5400: 6e 2e 43 6f 6c 75 6d 6e 4e 61 6d 65 5d 20 3d 20  n.ColumnName] = 
5410: 47 65 74 4e 61 6d 65 28 6e 29 3b 0a 20 20 20 20  GetName(n);.    
5420: 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61      row[SchemaTa
5430: 62 6c 65 43 6f 6c 75 6d 6e 2e 43 6f 6c 75 6d 6e  bleColumn.Column
5440: 4f 72 64 69 6e 61 6c 5d 20 3d 20 6e 3b 0a 20 20  Ordinal] = n;.  
5450: 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61        row[Schema
5460: 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 43 6f 6c 75  TableColumn.Colu
5470: 6d 6e 53 69 7a 65 5d 20 3d 20 53 51 4c 69 74 65  mnSize] = SQLite
5480: 43 6f 6e 76 65 72 74 2e 44 62 54 79 70 65 54 6f  Convert.DbTypeTo
5490: 43 6f 6c 75 6d 6e 53 69 7a 65 28 74 79 70 29 3b  ColumnSize(typ);
54a0: 0a 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68  .        row[Sch
54b0: 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 4e  emaTableColumn.N
54c0: 75 6d 65 72 69 63 50 72 65 63 69 73 69 6f 6e 5d  umericPrecision]
54d0: 20 3d 20 53 51 4c 69 74 65 43 6f 6e 76 65 72 74   = SQLiteConvert
54e0: 2e 44 62 54 79 70 65 54 6f 4e 75 6d 65 72 69 63  .DbTypeToNumeric
54f0: 50 72 65 63 69 73 69 6f 6e 28 74 79 70 29 3b 0a  Precision(typ);.
5500: 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65          row[Sche
5510: 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 4e 75  maTableColumn.Nu
5520: 6d 65 72 69 63 53 63 61 6c 65 5d 20 3d 20 53 51  mericScale] = SQ
5530: 4c 69 74 65 43 6f 6e 76 65 72 74 2e 44 62 54 79  LiteConvert.DbTy
5540: 70 65 54 6f 4e 75 6d 65 72 69 63 53 63 61 6c 65  peToNumericScale
5550: 28 74 79 70 29 3b 0a 20 20 20 20 20 20 20 20 72  (typ);.        r
5560: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  ow[SchemaTableCo
5570: 6c 75 6d 6e 2e 50 72 6f 76 69 64 65 72 54 79 70  lumn.ProviderTyp
5580: 65 5d 20 3d 20 47 65 74 53 51 4c 69 74 65 54 79  e] = GetSQLiteTy
5590: 70 65 28 6e 29 2e 54 79 70 65 3b 0a 20 20 20 20  pe(n).Type;.    
55a0: 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61      row[SchemaTa
55b0: 62 6c 65 43 6f 6c 75 6d 6e 2e 49 73 4c 6f 6e 67  bleColumn.IsLong
55c0: 5d 20 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20  ] = false;.     
55d0: 20 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62     row[SchemaTab
55e0: 6c 65 43 6f 6c 75 6d 6e 2e 41 6c 6c 6f 77 44 42  leColumn.AllowDB
55f0: 4e 75 6c 6c 5d 20 3d 20 74 72 75 65 3b 0a 20 20  Null] = true;.  
5600: 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65 6d 61        row[Schema
5610: 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c  TableOptionalCol
5620: 75 6d 6e 2e 49 73 52 65 61 64 4f 6e 6c 79 5d 20  umn.IsReadOnly] 
5630: 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 20  = false;.       
5640: 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65   row[SchemaTable
5650: 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49  OptionalColumn.I
5660: 73 52 6f 77 56 65 72 73 69 6f 6e 5d 20 3d 20 66  sRowVersion] = f
5670: 61 6c 73 65 3b 0a 20 20 20 20 20 20 20 20 72 6f  alse;.        ro
5680: 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  w[SchemaTableCol
5690: 75 6d 6e 2e 49 73 55 6e 69 71 75 65 5d 20 3d 20  umn.IsUnique] = 
56a0: 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 20 20 72  false;.        r
56b0: 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f  ow[SchemaTableCo
56c0: 6c 75 6d 6e 2e 49 73 4b 65 79 5d 20 3d 20 66 61  lumn.IsKey] = fa
56d0: 6c 73 65 3b 0a 20 20 20 20 20 20 20 20 72 6f 77  lse;.        row
56e0: 5b 53 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69  [SchemaTableOpti
56f0: 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 49 73 41 75 74  onalColumn.IsAut
5700: 6f 49 6e 63 72 65 6d 65 6e 74 5d 20 3d 20 66 61  oIncrement] = fa
5710: 6c 73 65 3b 0a 20 20 20 20 20 20 20 20 72 6f 77  lse;.        row
5720: 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75  [SchemaTableColu
5730: 6d 6e 2e 44 61 74 61 54 79 70 65 5d 20 3d 20 47  mn.DataType] = G
5740: 65 74 46 69 65 6c 64 54 79 70 65 28 6e 29 3b 0a  etFieldType(n);.
5750: 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65          row[Sche
5760: 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43  maTableOptionalC
5770: 6f 6c 75 6d 6e 2e 49 73 48 69 64 64 65 6e 5d 20  olumn.IsHidden] 
5780: 3d 20 66 61 6c 73 65 3b 0a 0a 20 20 20 20 20 20  = false;..      
5790: 20 20 73 74 72 43 6f 6c 75 6d 6e 20 3d 20 5f 63    strColumn = _c
57a0: 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f  ommand.Connectio
57b0: 6e 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e 4f 72 69  n._sql.ColumnOri
57c0: 67 69 6e 61 6c 4e 61 6d 65 28 5f 61 63 74 69 76  ginalName(_activ
57d0: 65 53 74 61 74 65 6d 65 6e 74 2c 20 6e 29 3b 0a  eStatement, n);.
57e0: 20 20 20 20 20 20 20 20 69 66 20 28 53 74 72 69          if (Stri
57f0: 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70 74 79  ng.IsNullOrEmpty
5800: 28 73 74 72 43 6f 6c 75 6d 6e 29 20 3d 3d 20 66  (strColumn) == f
5810: 61 6c 73 65 29 20 72 6f 77 5b 53 63 68 65 6d 61  alse) row[Schema
5820: 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65  TableColumn.Base
5830: 43 6f 6c 75 6d 6e 4e 61 6d 65 5d 20 3d 20 73 74  ColumnName] = st
5840: 72 43 6f 6c 75 6d 6e 3b 0a 0a 20 20 20 20 20 20  rColumn;..      
5850: 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c    row[SchemaTabl
5860: 65 43 6f 6c 75 6d 6e 2e 49 73 45 78 70 72 65 73  eColumn.IsExpres
5870: 73 69 6f 6e 5d 20 3d 20 53 74 72 69 6e 67 2e 49  sion] = String.I
5880: 73 4e 75 6c 6c 4f 72 45 6d 70 74 79 28 73 74 72  sNullOrEmpty(str
5890: 43 6f 6c 75 6d 6e 29 3b 0a 20 20 20 20 20 20 20  Column);.       
58a0: 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65   row[SchemaTable
58b0: 43 6f 6c 75 6d 6e 2e 49 73 41 6c 69 61 73 65 64  Column.IsAliased
58c0: 5d 20 3d 20 28 53 74 72 69 6e 67 2e 43 6f 6d 70  ] = (String.Comp
58d0: 61 72 65 28 47 65 74 4e 61 6d 65 28 6e 29 2c 20  are(GetName(n), 
58e0: 73 74 72 43 6f 6c 75 6d 6e 2c 20 53 74 72 69 6e  strColumn, Strin
58f0: 67 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69  gComparison.Ordi
5900: 6e 61 6c 49 67 6e 6f 72 65 43 61 73 65 29 20 21  nalIgnoreCase) !
5910: 3d 20 30 29 3b 0a 0a 20 20 20 20 20 20 20 20 74  = 0);..        t
5920: 65 6d 70 20 3d 20 5f 63 6f 6d 6d 61 6e 64 2e 43  emp = _command.C
5930: 6f 6e 6e 65 63 74 69 6f 6e 2e 5f 73 71 6c 2e 43  onnection._sql.C
5940: 6f 6c 75 6d 6e 54 61 62 6c 65 4e 61 6d 65 28 5f  olumnTableName(_
5950: 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2c  activeStatement,
5960: 20 6e 29 3b 0a 20 20 20 20 20 20 20 20 69 66 20   n);.        if 
5970: 28 53 74 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72  (String.IsNullOr
5980: 45 6d 70 74 79 28 74 65 6d 70 29 20 3d 3d 20 66  Empty(temp) == f
5990: 61 6c 73 65 29 20 72 6f 77 5b 53 63 68 65 6d 61  alse) row[Schema
59a0: 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65  TableColumn.Base
59b0: 54 61 62 6c 65 4e 61 6d 65 5d 20 3d 20 74 65 6d  TableName] = tem
59c0: 70 3b 0a 0a 20 20 20 20 20 20 20 20 74 65 6d 70  p;..        temp
59d0: 20 3d 20 5f 63 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e   = _command.Conn
59e0: 65 63 74 69 6f 6e 2e 5f 73 71 6c 2e 43 6f 6c 75  ection._sql.Colu
59f0: 6d 6e 44 61 74 61 62 61 73 65 4e 61 6d 65 28 5f  mnDatabaseName(_
5a00: 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2c  activeStatement,
5a10: 20 6e 29 3b 0a 20 20 20 20 20 20 20 20 69 66 20   n);.        if 
5a20: 28 53 74 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72  (String.IsNullOr
5a30: 45 6d 70 74 79 28 74 65 6d 70 29 20 3d 3d 20 66  Empty(temp) == f
5a40: 61 6c 73 65 29 20 72 6f 77 5b 53 63 68 65 6d 61  alse) row[Schema
5a50: 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c  TableOptionalCol
5a60: 75 6d 6e 2e 42 61 73 65 43 61 74 61 6c 6f 67 4e  umn.BaseCatalogN
5a70: 61 6d 65 5d 20 3d 20 74 65 6d 70 3b 0a 0a 20 20  ame] = temp;..  
5a80: 20 20 20 20 20 20 73 74 72 69 6e 67 20 64 61 74        string dat
5a90: 61 54 79 70 65 20 3d 20 6e 75 6c 6c 3b 0a 20 20  aType = null;.  
5aa0: 20 20 20 20 20 20 2f 2f 20 49 66 20 77 65 20 68        // If we h
5ab0: 61 76 65 20 61 20 74 61 62 6c 65 2d 62 6f 75 6e  ave a table-boun
5ac0: 64 20 63 6f 6c 75 6d 6e 2c 20 65 78 74 72 61 63  d column, extrac
5ad0: 74 20 74 68 65 20 65 78 74 72 61 20 69 6e 66 6f  t the extra info
5ae0: 72 6d 61 74 69 6f 6e 20 66 72 6f 6d 20 69 74 0a  rmation from it.
5af0: 20 20 20 20 20 20 20 20 69 66 20 28 53 74 72 69          if (Stri
5b00: 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70 74 79  ng.IsNullOrEmpty
5b10: 28 73 74 72 43 6f 6c 75 6d 6e 29 20 3d 3d 20 66  (strColumn) == f
5b20: 61 6c 73 65 29 0a 20 20 20 20 20 20 20 20 7b 0a  alse).        {.
5b30: 20 20 20 20 20 20 20 20 20 20 73 74 72 69 6e 67            string
5b40: 20 63 6f 6c 6c 53 65 71 3b 0a 20 20 20 20 20 20   collSeq;.      
5b50: 20 20 20 20 62 6f 6f 6c 20 62 4e 6f 74 4e 75 6c      bool bNotNul
5b60: 6c 3b 0a 20 20 20 20 20 20 20 20 20 20 62 6f 6f  l;.          boo
5b70: 6c 20 62 50 72 69 6d 61 72 79 4b 65 79 3b 0a 20  l bPrimaryKey;. 
5b80: 20 20 20 20 20 20 20 20 20 62 6f 6f 6c 20 62 41           bool bA
5b90: 75 74 6f 49 6e 63 72 65 6d 65 6e 74 3b 0a 20 20  utoIncrement;.  
5ba0: 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 5b 5d          string[]
5bb0: 20 61 72 53 69 7a 65 3b 0a 0a 20 20 20 20 20 20   arSize;..      
5bc0: 20 20 20 20 2f 2f 20 47 65 74 20 74 68 65 20 63      // Get the c
5bd0: 6f 6c 75 6d 6e 20 6d 65 74 61 20 64 61 74 61 0a  olumn meta data.
5be0: 20 20 20 20 20 20 20 20 20 20 5f 63 6f 6d 6d 61            _comma
5bf0: 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f 6e 2e 5f 73  nd.Connection._s
5c00: 71 6c 2e 43 6f 6c 75 6d 6e 4d 65 74 61 44 61 74  ql.ColumnMetaDat
5c10: 61 28 0a 20 20 20 20 20 20 20 20 20 20 20 20 28  a(.            (
5c20: 73 74 72 69 6e 67 29 72 6f 77 5b 53 63 68 65 6d  string)row[Schem
5c30: 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f  aTableOptionalCo
5c40: 6c 75 6d 6e 2e 42 61 73 65 43 61 74 61 6c 6f 67  lumn.BaseCatalog
5c50: 4e 61 6d 65 5d 2c 0a 20 20 20 20 20 20 20 20 20  Name],.         
5c60: 20 20 20 28 73 74 72 69 6e 67 29 72 6f 77 5b 53     (string)row[S
5c70: 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e  chemaTableColumn
5c80: 2e 42 61 73 65 54 61 62 6c 65 4e 61 6d 65 5d 2c  .BaseTableName],
5c90: 0a 20 20 20 20 20 20 20 20 20 20 20 20 73 74 72  .            str
5ca0: 43 6f 6c 75 6d 6e 2c 0a 20 20 20 20 20 20 20 20  Column,.        
5cb0: 20 20 20 20 6f 75 74 20 64 61 74 61 54 79 70 65      out dataType
5cc0: 2c 20 6f 75 74 20 63 6f 6c 6c 53 65 71 2c 20 6f  , out collSeq, o
5cd0: 75 74 20 62 4e 6f 74 4e 75 6c 6c 2c 20 6f 75 74  ut bNotNull, out
5ce0: 20 62 50 72 69 6d 61 72 79 4b 65 79 2c 20 6f 75   bPrimaryKey, ou
5cf0: 74 20 62 41 75 74 6f 49 6e 63 72 65 6d 65 6e 74  t bAutoIncrement
5d00: 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 69 66  );..          if
5d10: 20 28 62 4e 6f 74 4e 75 6c 6c 20 7c 7c 20 62 50   (bNotNull || bP
5d20: 72 69 6d 61 72 79 4b 65 79 29 20 72 6f 77 5b 53  rimaryKey) row[S
5d30: 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e  chemaTableColumn
5d40: 2e 41 6c 6c 6f 77 44 42 4e 75 6c 6c 5d 20 3d 20  .AllowDBNull] = 
5d50: 66 61 6c 73 65 3b 0a 0a 20 20 20 20 20 20 20 20  false;..        
5d60: 20 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c    row[SchemaTabl
5d70: 65 43 6f 6c 75 6d 6e 2e 49 73 4b 65 79 5d 20 3d  eColumn.IsKey] =
5d80: 20 62 50 72 69 6d 61 72 79 4b 65 79 3b 0a 20 20   bPrimaryKey;.  
5d90: 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65          row[Sche
5da0: 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43  maTableOptionalC
5db0: 6f 6c 75 6d 6e 2e 49 73 41 75 74 6f 49 6e 63 72  olumn.IsAutoIncr
5dc0: 65 6d 65 6e 74 5d 20 3d 20 62 41 75 74 6f 49 6e  ement] = bAutoIn
5dd0: 63 72 65 6d 65 6e 74 3b 0a 20 20 20 20 20 20 20  crement;.       
5de0: 20 20 20 72 6f 77 5b 22 43 6f 6c 6c 61 74 69 6f     row["Collatio
5df0: 6e 54 79 70 65 22 5d 20 3d 20 63 6f 6c 6c 53 65  nType"] = collSe
5e00: 71 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f 2f  q;..          //
5e10: 20 46 6f 72 20 74 79 70 65 73 20 6c 69 6b 65 20   For types like 
5e20: 76 61 72 63 68 61 72 28 35 30 29 20 61 6e 64 20  varchar(50) and 
5e30: 73 75 63 68 2c 20 65 78 74 72 61 63 74 20 74 68  such, extract th
5e40: 65 20 73 69 7a 65 0a 20 20 20 20 20 20 20 20 20  e size.         
5e50: 20 61 72 53 69 7a 65 20 3d 20 64 61 74 61 54 79   arSize = dataTy
5e60: 70 65 2e 53 70 6c 69 74 28 27 28 27 29 3b 0a 20  pe.Split('(');. 
5e70: 20 20 20 20 20 20 20 20 20 69 66 20 28 61 72 53           if (arS
5e80: 69 7a 65 2e 4c 65 6e 67 74 68 20 3e 20 31 29 0a  ize.Length > 1).
5e90: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
5ea0: 20 20 20 20 20 20 20 20 64 61 74 61 54 79 70 65          dataType
5eb0: 20 3d 20 61 72 53 69 7a 65 5b 30 5d 3b 0a 20 20   = arSize[0];.  
5ec0: 20 20 20 20 20 20 20 20 20 20 61 72 53 69 7a 65            arSize
5ed0: 20 3d 20 61 72 53 69 7a 65 5b 31 5d 2e 53 70 6c   = arSize[1].Spl
5ee0: 69 74 28 27 29 27 29 3b 0a 20 20 20 20 20 20 20  it(')');.       
5ef0: 20 20 20 20 20 69 66 20 28 61 72 53 69 7a 65 2e       if (arSize.
5f00: 4c 65 6e 67 74 68 20 3e 20 31 29 0a 20 20 20 20  Length > 1).    
5f10: 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20          {.      
5f20: 20 20 20 20 20 20 20 20 61 72 53 69 7a 65 20 3d          arSize =
5f30: 20 61 72 53 69 7a 65 5b 30 5d 2e 53 70 6c 69 74   arSize[0].Split
5f40: 28 27 2c 27 2c 20 27 2e 27 29 3b 0a 20 20 20 20  (',', '.');.    
5f50: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 47 65            if (Ge
5f60: 74 53 51 4c 69 74 65 54 79 70 65 28 6e 29 2e 54  tSQLiteType(n).T
5f70: 79 70 65 20 3d 3d 20 44 62 54 79 70 65 2e 53 74  ype == DbType.St
5f80: 72 69 6e 67 20 7c 7c 20 47 65 74 53 51 4c 69 74  ring || GetSQLit
5f90: 65 54 79 70 65 28 6e 29 2e 54 79 70 65 20 3d 3d  eType(n).Type ==
5fa0: 20 44 62 54 79 70 65 2e 42 69 6e 61 72 79 29 0a   DbType.Binary).
5fb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a                {.
5fc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5fd0: 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43  row[SchemaTableC
5fe0: 6f 6c 75 6d 6e 2e 43 6f 6c 75 6d 6e 53 69 7a 65  olumn.ColumnSize
5ff0: 5d 20 3d 20 43 6f 6e 76 65 72 74 2e 54 6f 49 6e  ] = Convert.ToIn
6000: 74 33 32 28 61 72 53 69 7a 65 5b 30 5d 2c 20 43  t32(arSize[0], C
6010: 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72  ultureInfo.Invar
6020: 69 61 6e 74 43 75 6c 74 75 72 65 29 3b 0a 20 20  iantCulture);.  
6030: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
6040: 20 20 20 20 20 20 20 20 20 20 20 20 65 6c 73 65              else
6050: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  .              {
6060: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6070: 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65   row[SchemaTable
6080: 43 6f 6c 75 6d 6e 2e 4e 75 6d 65 72 69 63 50 72  Column.NumericPr
6090: 65 63 69 73 69 6f 6e 5d 20 3d 20 43 6f 6e 76 65  ecision] = Conve
60a0: 72 74 2e 54 6f 49 6e 74 33 32 28 61 72 53 69 7a  rt.ToInt32(arSiz
60b0: 65 5b 30 5d 2c 20 43 75 6c 74 75 72 65 49 6e 66  e[0], CultureInf
60c0: 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c 74 75  o.InvariantCultu
60d0: 72 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  re);.           
60e0: 20 20 20 20 20 69 66 20 28 61 72 53 69 7a 65 2e       if (arSize.
60f0: 4c 65 6e 67 74 68 20 3e 20 31 29 0a 20 20 20 20  Length > 1).    
6100: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 6f                ro
6110: 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43 6f 6c  w[SchemaTableCol
6120: 75 6d 6e 2e 4e 75 6d 65 72 69 63 53 63 61 6c 65  umn.NumericScale
6130: 5d 20 3d 20 43 6f 6e 76 65 72 74 2e 54 6f 49 6e  ] = Convert.ToIn
6140: 74 33 32 28 61 72 53 69 7a 65 5b 31 5d 2c 20 43  t32(arSize[1], C
6150: 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72  ultureInfo.Invar
6160: 69 61 6e 74 43 75 6c 74 75 72 65 29 3b 0a 20 20  iantCulture);.  
6170: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
6180: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
6190: 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20        }..       
61a0: 20 20 20 69 66 20 28 77 61 6e 74 44 65 66 61 75     if (wantDefau
61b0: 6c 74 56 61 6c 75 65 29 0a 20 20 20 20 20 20 20  ltValue).       
61c0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
61d0: 20 2f 2f 20 44 65 74 65 72 6d 69 6e 65 20 74 68   // Determine th
61e0: 65 20 64 65 66 61 75 6c 74 20 76 61 6c 75 65 20  e default value 
61f0: 66 6f 72 20 74 68 65 20 63 6f 6c 75 6d 6e 2c 20  for the column, 
6200: 77 68 69 63 68 20 73 75 63 6b 73 20 62 65 63 61  which sucks beca
6210: 75 73 65 20 77 65 20 68 61 76 65 20 74 6f 20 71  use we have to q
6220: 75 65 72 79 20 74 68 65 20 73 63 68 65 6d 61 20  uery the schema 
6230: 66 6f 72 20 65 61 63 68 20 63 6f 6c 75 6d 6e 0a  for each column.
6240: 20 20 20 20 20 20 20 20 20 20 20 20 75 73 69 6e              usin
6250: 67 20 28 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64  g (SQLiteCommand
6260: 20 63 6d 64 54 61 62 6c 65 20 3d 20 6e 65 77 20   cmdTable = new 
6270: 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 28 53 74  SQLiteCommand(St
6280: 72 69 6e 67 2e 46 6f 72 6d 61 74 28 43 75 6c 74  ring.Format(Cult
6290: 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72 69 61 6e  ureInfo.Invarian
62a0: 74 43 75 6c 74 75 72 65 2c 20 22 50 52 41 47 4d  tCulture, "PRAGM
62b0: 41 20 5b 7b 30 7d 5d 2e 54 41 42 4c 45 5f 49 4e  A [{0}].TABLE_IN
62c0: 46 4f 28 5b 7b 31 7d 5d 29 22 2c 0a 20 20 20 20  FO([{1}])",.    
62d0: 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63            row[Sc
62e0: 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61  hemaTableOptiona
62f0: 6c 43 6f 6c 75 6d 6e 2e 42 61 73 65 43 61 74 61  lColumn.BaseCata
6300: 6c 6f 67 4e 61 6d 65 5d 2c 0a 20 20 20 20 20 20  logName],.      
6310: 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68 65          row[Sche
6320: 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61  maTableColumn.Ba
6330: 73 65 54 61 62 6c 65 4e 61 6d 65 5d 0a 20 20 20  seTableName].   
6340: 20 20 20 20 20 20 20 20 20 20 20 29 2c 20 5f 63             ), _c
6350: 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f  ommand.Connectio
6360: 6e 29 29 0a 20 20 20 20 20 20 20 20 20 20 20 20  n)).            
6370: 75 73 69 6e 67 20 28 44 62 44 61 74 61 52 65 61  using (DbDataRea
6380: 64 65 72 20 72 64 54 61 62 6c 65 20 3d 20 63 6d  der rdTable = cm
6390: 64 54 61 62 6c 65 2e 45 78 65 63 75 74 65 52 65  dTable.ExecuteRe
63a0: 61 64 65 72 28 29 29 0a 20 20 20 20 20 20 20 20  ader()).        
63b0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20      {.          
63c0: 20 20 20 20 2f 2f 20 46 69 6e 64 20 74 68 65 20      // Find the 
63d0: 6d 61 74 63 68 69 6e 67 20 63 6f 6c 75 6d 6e 0a  matching column.
63e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 77 68                wh
63f0: 69 6c 65 20 28 72 64 54 61 62 6c 65 2e 52 65 61  ile (rdTable.Rea
6400: 64 28 29 29 0a 20 20 20 20 20 20 20 20 20 20 20  d()).           
6410: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
6420: 20 20 20 20 20 69 66 20 28 53 74 72 69 6e 67 2e       if (String.
6430: 43 6f 6d 70 61 72 65 28 28 73 74 72 69 6e 67 29  Compare((string)
6440: 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43  row[SchemaTableC
6450: 6f 6c 75 6d 6e 2e 42 61 73 65 43 6f 6c 75 6d 6e  olumn.BaseColumn
6460: 4e 61 6d 65 5d 2c 20 72 64 54 61 62 6c 65 2e 47  Name], rdTable.G
6470: 65 74 53 74 72 69 6e 67 28 31 29 2c 20 53 74 72  etString(1), Str
6480: 69 6e 67 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72  ingComparison.Or
6490: 64 69 6e 61 6c 49 67 6e 6f 72 65 43 61 73 65 29  dinalIgnoreCase)
64a0: 20 3d 3d 20 30 29 0a 20 20 20 20 20 20 20 20 20   == 0).         
64b0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
64c0: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 72             if (r
64d0: 64 54 61 62 6c 65 2e 49 73 44 42 4e 75 6c 6c 28  dTable.IsDBNull(
64e0: 34 29 20 3d 3d 20 66 61 6c 73 65 29 0a 20 20 20  4) == false).   
64f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6500: 20 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65   row[SchemaTable
6510: 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e 44  OptionalColumn.D
6520: 65 66 61 75 6c 74 56 61 6c 75 65 5d 20 3d 20 72  efaultValue] = r
6530: 64 54 61 62 6c 65 5b 34 5d 3b 0a 0a 20 20 20 20  dTable[4];..    
6540: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62 72                br
6550: 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 20  eak;.           
6560: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
6570: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
6580: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 7d     }.          }
6590: 0a 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20 44  ..          // D
65a0: 65 74 65 72 6d 69 6e 65 20 49 73 55 6e 69 71 75  etermine IsUniqu
65b0: 65 20 70 72 6f 70 65 72 6c 79 2c 20 77 68 69 63  e properly, whic
65c0: 68 20 69 73 20 61 20 70 61 69 6e 20 69 6e 20 74  h is a pain in t
65d0: 68 65 20 62 75 74 74 21 0a 20 20 20 20 20 20 20  he butt!.       
65e0: 20 20 20 69 66 20 28 77 61 6e 74 55 6e 69 71 75     if (wantUniqu
65f0: 65 49 6e 66 6f 29 0a 20 20 20 20 20 20 20 20 20  eInfo).         
6600: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69   {.            i
6610: 66 20 28 28 73 74 72 69 6e 67 29 72 6f 77 5b 53  f ((string)row[S
6620: 63 68 65 6d 61 54 61 62 6c 65 4f 70 74 69 6f 6e  chemaTableOption
6630: 61 6c 43 6f 6c 75 6d 6e 2e 42 61 73 65 43 61 74  alColumn.BaseCat
6640: 61 6c 6f 67 4e 61 6d 65 5d 20 21 3d 20 73 74 72  alogName] != str
6650: 43 61 74 61 6c 6f 67 0a 20 20 20 20 20 20 20 20  Catalog.        
6660: 20 20 20 20 20 20 7c 7c 20 28 73 74 72 69 6e 67        || (string
6670: 29 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65  )row[SchemaTable
6680: 43 6f 6c 75 6d 6e 2e 42 61 73 65 54 61 62 6c 65  Column.BaseTable
6690: 4e 61 6d 65 5d 20 21 3d 20 73 74 72 54 61 62 6c  Name] != strTabl
66a0: 65 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  e).            {
66b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73  .              s
66c0: 74 72 43 61 74 61 6c 6f 67 20 3d 20 28 73 74 72  trCatalog = (str
66d0: 69 6e 67 29 72 6f 77 5b 53 63 68 65 6d 61 54 61  ing)row[SchemaTa
66e0: 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d  bleOptionalColum
66f0: 6e 2e 42 61 73 65 43 61 74 61 6c 6f 67 4e 61 6d  n.BaseCatalogNam
6700: 65 5d 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  e];.            
6710: 20 20 73 74 72 54 61 62 6c 65 20 3d 20 28 73 74    strTable = (st
6720: 72 69 6e 67 29 72 6f 77 5b 53 63 68 65 6d 61 54  ring)row[SchemaT
6730: 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65 54  ableColumn.BaseT
6740: 61 62 6c 65 4e 61 6d 65 5d 3b 0a 0a 20 20 20 20  ableName];..    
6750: 20 20 20 20 20 20 20 20 20 20 74 62 6c 49 6e 64            tblInd
6760: 65 78 65 73 20 3d 20 5f 63 6f 6d 6d 61 6e 64 2e  exes = _command.
6770: 43 6f 6e 6e 65 63 74 69 6f 6e 2e 47 65 74 53 63  Connection.GetSc
6780: 68 65 6d 61 28 22 49 6e 64 65 78 65 73 22 2c 20  hema("Indexes", 
6790: 6e 65 77 20 73 74 72 69 6e 67 5b 5d 20 7b 0a 20  new string[] {. 
67a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28                 (
67b0: 73 74 72 69 6e 67 29 72 6f 77 5b 53 63 68 65 6d  string)row[Schem
67c0: 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f  aTableOptionalCo
67d0: 6c 75 6d 6e 2e 42 61 73 65 43 61 74 61 6c 6f 67  lumn.BaseCatalog
67e0: 4e 61 6d 65 5d 2c 0a 20 20 20 20 20 20 20 20 20  Name],.         
67f0: 20 20 20 20 20 20 20 6e 75 6c 6c 2c 0a 20 20 20         null,.   
6800: 20 20 20 20 20 20 20 20 20 20 20 20 20 28 73 74               (st
6810: 72 69 6e 67 29 72 6f 77 5b 53 63 68 65 6d 61 54  ring)row[SchemaT
6820: 61 62 6c 65 43 6f 6c 75 6d 6e 2e 42 61 73 65 54  ableColumn.BaseT
6830: 61 62 6c 65 4e 61 6d 65 5d 2c 0a 20 20 20 20 20  ableName],.     
6840: 20 20 20 20 20 20 20 20 20 20 20 6e 75 6c 6c 20             null 
6850: 7d 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  });.            
6860: 7d 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 66  }..            f
6870: 6f 72 65 61 63 68 20 28 44 61 74 61 52 6f 77 20  oreach (DataRow 
6880: 72 6f 77 49 6e 64 65 78 65 73 20 69 6e 20 74 62  rowIndexes in tb
6890: 6c 49 6e 64 65 78 65 73 2e 52 6f 77 73 29 0a 20  lIndexes.Rows). 
68a0: 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20             {.   
68b0: 20 20 20 20 20 20 20 20 20 20 20 74 62 6c 49 6e             tblIn
68c0: 64 65 78 43 6f 6c 75 6d 6e 73 20 3d 20 5f 63 6f  dexColumns = _co
68d0: 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f 6e  mmand.Connection
68e0: 2e 47 65 74 53 63 68 65 6d 61 28 22 49 6e 64 65  .GetSchema("Inde
68f0: 78 43 6f 6c 75 6d 6e 73 22 2c 20 6e 65 77 20 73  xColumns", new s
6900: 74 72 69 6e 67 5b 5d 20 7b 0a 20 20 20 20 20 20  tring[] {.      
6910: 20 20 20 20 20 20 20 20 20 20 28 73 74 72 69 6e            (strin
6920: 67 29 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c  g)row[SchemaTabl
6930: 65 4f 70 74 69 6f 6e 61 6c 43 6f 6c 75 6d 6e 2e  eOptionalColumn.
6940: 42 61 73 65 43 61 74 61 6c 6f 67 4e 61 6d 65 5d  BaseCatalogName]
6950: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
6960: 20 20 6e 75 6c 6c 2c 0a 20 20 20 20 20 20 20 20    null,.        
6970: 20 20 20 20 20 20 20 20 28 73 74 72 69 6e 67 29          (string)
6980: 72 6f 77 5b 53 63 68 65 6d 61 54 61 62 6c 65 43  row[SchemaTableC
6990: 6f 6c 75 6d 6e 2e 42 61 73 65 54 61 62 6c 65 4e  olumn.BaseTableN
69a0: 61 6d 65 5d 2c 0a 20 20 20 20 20 20 20 20 20 20  ame],.          
69b0: 20 20 20 20 20 20 28 73 74 72 69 6e 67 29 72 6f        (string)ro
69c0: 77 49 6e 64 65 78 65 73 5b 22 49 4e 44 45 58 5f  wIndexes["INDEX_
69d0: 4e 41 4d 45 22 5d 2c 0a 20 20 20 20 20 20 20 20  NAME"],.        
69e0: 20 20 20 20 20 20 20 20 6e 75 6c 6c 0a 20 20 20          null.   
69f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 29 3b               });
6a00: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66  .              f
6a10: 6f 72 65 61 63 68 20 28 44 61 74 61 52 6f 77 20  oreach (DataRow 
6a20: 72 6f 77 43 6f 6c 75 6d 6e 49 6e 64 65 78 20 69  rowColumnIndex i
6a30: 6e 20 74 62 6c 49 6e 64 65 78 43 6f 6c 75 6d 6e  n tblIndexColumn
6a40: 73 2e 52 6f 77 73 29 0a 20 20 20 20 20 20 20 20  s.Rows).        
6a50: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
6a60: 20 20 20 20 20 20 20 20 69 66 20 28 53 74 72 69          if (Stri
6a70: 6e 67 2e 43 6f 6d 70 61 72 65 28 28 73 74 72 69  ng.Compare((stri
6a80: 6e 67 29 72 6f 77 43 6f 6c 75 6d 6e 49 6e 64 65  ng)rowColumnInde
6a90: 78 5b 22 43 4f 4c 55 4d 4e 5f 4e 41 4d 45 22 5d  x["COLUMN_NAME"]
6aa0: 2c 20 73 74 72 43 6f 6c 75 6d 6e 2c 20 53 74 72  , strColumn, Str
6ab0: 69 6e 67 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72  ingComparison.Or
6ac0: 64 69 6e 61 6c 49 67 6e 6f 72 65 43 61 73 65 29  dinalIgnoreCase)
6ad0: 20 3d 3d 20 30 29 0a 20 20 20 20 20 20 20 20 20   == 0).         
6ae0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
6af0: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74             if (t
6b00: 62 6c 49 6e 64 65 78 43 6f 6c 75 6d 6e 73 2e 52  blIndexColumns.R
6b10: 6f 77 73 2e 43 6f 75 6e 74 20 3d 3d 20 31 20 26  ows.Count == 1 &
6b20: 26 20 28 62 6f 6f 6c 29 72 6f 77 5b 53 63 68 65  & (bool)row[Sche
6b30: 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 41 6c  maTableColumn.Al
6b40: 6c 6f 77 44 42 4e 75 6c 6c 5d 20 3d 3d 20 66 61  lowDBNull] == fa
6b50: 6c 73 65 29 0a 20 20 20 20 20 20 20 20 20 20 20  lse).           
6b60: 20 20 20 20 20 20 20 20 20 72 6f 77 5b 53 63 68           row[Sch
6b70: 65 6d 61 54 61 62 6c 65 43 6f 6c 75 6d 6e 2e 49  emaTableColumn.I
6b80: 73 55 6e 69 71 75 65 5d 20 3d 20 72 6f 77 49 6e  sUnique] = rowIn
6b90: 64 65 78 65 73 5b 22 55 4e 49 51 55 45 22 5d 3b  dexes["UNIQUE"];
6ba0: 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6bb0: 20 20 20 20 2f 2f 20 49 66 20 69 74 73 20 61 6e      // If its an
6bc0: 20 69 6e 74 65 67 65 72 20 70 72 69 6d 61 72 79   integer primary
6bd0: 20 6b 65 79 20 61 6e 64 20 74 68 65 20 6f 6e 6c   key and the onl
6be0: 79 20 70 72 69 6d 61 72 79 20 6b 65 79 20 69 6e  y primary key in
6bf0: 20 74 68 65 20 74 61 62 6c 65 2c 20 74 68 65 6e   the table, then
6c00: 20 69 74 73 20 61 20 72 6f 77 69 64 20 61 6c 69   its a rowid ali
6c10: 61 73 20 61 6e 64 20 69 73 20 61 75 74 6f 69 6e  as and is autoin
6c20: 63 72 65 6d 65 6e 74 0a 20 20 20 20 20 20 20 20  crement.        
6c30: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54            // NOT
6c40: 45 3a 20 20 43 75 72 72 65 6e 74 6c 79 20 63 6f  E:  Currently co
6c50: 6d 6d 65 6e 74 65 64 20 6f 75 74 20 62 65 63 61  mmented out beca
6c60: 75 73 65 20 74 68 69 73 20 69 73 20 6e 6f 74 20  use this is not 
6c70: 61 6c 77 61 79 73 20 74 68 65 20 64 65 73 69 72  always the desir
6c80: 65 64 20 62 65 68 61 76 69 6f 72 2e 20 20 46 6f  ed behavior.  Fo
6c90: 72 20 65 78 61 6d 70 6c 65 2c 20 61 20 31 3a 31  r example, a 1:1
6ca0: 20 72 65 6c 61 74 69 6f 6e 73 68 69 70 20 77 69   relationship wi
6cb0: 74 68 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  th.             
6cc0: 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 20 61       //        a
6cd0: 6e 6f 74 68 65 72 20 74 61 62 6c 65 2c 20 77 68  nother table, wh
6ce0: 65 72 65 20 74 68 65 20 6f 74 68 65 72 20 74 61  ere the other ta
6cf0: 62 6c 65 20 69 73 20 61 75 74 6f 69 6e 63 72 65  ble is autoincre
6d00: 6d 65 6e 74 2c 20 62 75 74 20 74 68 69 73 20 6f  ment, but this o
6d10: 6e 65 20 69 73 20 6e 6f 74 2c 20 61 6e 64 20 75  ne is not, and u
6d20: 73 65 73 20 74 68 65 20 72 6f 77 69 64 20 66 72  ses the rowid fr
6d30: 6f 6d 20 74 68 65 20 6f 74 68 65 72 2e 0a 20 20  om the other..  
6d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6d50: 2f 2f 20 20 20 20 20 20 20 20 49 74 20 69 73 20  //        It is 
6d60: 73 61 66 65 72 20 74 6f 20 6f 6e 6c 79 20 73 65  safer to only se
6d70: 74 20 41 75 74 6f 69 6e 63 72 65 6d 65 6e 74 20  t Autoincrement 
6d80: 6f 6e 20 74 61 62 6c 65 73 20 77 68 65 72 65 20  on tables where 
6d90: 77 65 27 72 65 20 53 55 52 45 20 74 68 65 20 75  we're SURE the u
6da0: 73 65 72 20 73 70 65 63 69 66 69 65 64 20 41 55  ser specified AU
6db0: 54 4f 49 4e 43 52 45 4d 45 4e 54 2c 20 65 76 65  TOINCREMENT, eve
6dc0: 6e 20 69 66 20 69 74 73 20 61 20 72 6f 77 69 64  n if its a rowid
6dd0: 20 63 6f 6c 75 6d 6e 2e 0a 0a 20 20 20 20 20 20   column...      
6de0: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
6df0: 74 62 6c 49 6e 64 65 78 43 6f 6c 75 6d 6e 73 2e  tblIndexColumns.
6e00: 52 6f 77 73 2e 43 6f 75 6e 74 20 3d 3d 20 31 20  Rows.Count == 1 
6e10: 26 26 20 28 62 6f 6f 6c 29 72 6f 77 49 6e 64 65  && (bool)rowInde
6e20: 78 65 73 5b 22 50 52 49 4d 41 52 59 5f 4b 45 59  xes["PRIMARY_KEY
6e30: 22 5d 20 3d 3d 20 74 72 75 65 20 26 26 20 53 74  "] == true && St
6e40: 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70  ring.IsNullOrEmp
6e50: 74 79 28 64 61 74 61 54 79 70 65 29 20 3d 3d 20  ty(dataType) == 
6e60: 66 61 6c 73 65 20 26 26 0a 20 20 20 20 20 20 20  false &&.       
6e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 53 74 72               Str
6e80: 69 6e 67 2e 43 6f 6d 70 61 72 65 28 64 61 74 61  ing.Compare(data
6e90: 54 79 70 65 2c 20 22 69 6e 74 65 67 65 72 22 2c  Type, "integer",
6ea0: 20 53 74 72 69 6e 67 43 6f 6d 70 61 72 69 73 6f   StringCompariso
6eb0: 6e 2e 4f 72 64 69 6e 61 6c 49 67 6e 6f 72 65 43  n.OrdinalIgnoreC
6ec0: 61 73 65 29 20 3d 3d 20 30 29 0a 20 20 20 20 20  ase) == 0).     
6ed0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0a 20               {. 
6ee0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6ef0: 20 20 20 2f 2f 20 20 72 6f 77 5b 53 63 68 65 6d     //  row[Schem
6f00: 61 54 61 62 6c 65 4f 70 74 69 6f 6e 61 6c 43 6f  aTableOptionalCo
6f10: 6c 75 6d 6e 2e 49 73 41 75 74 6f 49 6e 63 72 65  lumn.IsAutoIncre
6f20: 6d 65 6e 74 5d 20 3d 20 74 72 75 65 3b 0a 20 20  ment] = true;.  
6f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6f40: 7d 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  }..             
6f50: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
6f60: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
6f70: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
6f80: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
6f90: 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20        }..       
6fa0: 20 20 20 69 66 20 28 53 74 72 69 6e 67 2e 49 73     if (String.Is
6fb0: 4e 75 6c 6c 4f 72 45 6d 70 74 79 28 64 61 74 61  NullOrEmpty(data
6fc0: 54 79 70 65 29 29 0a 20 20 20 20 20 20 20 20 20  Type)).         
6fd0: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 54   {.            T
6fe0: 79 70 65 41 66 66 69 6e 69 74 79 20 61 66 66 69  ypeAffinity affi
6ff0: 6e 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 64  n;.            d
7000: 61 74 61 54 79 70 65 20 3d 20 5f 61 63 74 69 76  ataType = _activ
7010: 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e  eStatement._sql.
7020: 43 6f 6c 75 6d 6e 54 79 70 65 28 5f 61 63 74 69  ColumnType(_acti
7030: 76 65 53 74 61 74 65 6d 65 6e 74 2c 20 6e 2c 20  veStatement, n, 
7040: 6f 75 74 20 61 66 66 69 6e 29 3b 0a 20 20 20 20  out affin);.    
7050: 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20        }..       
7060: 20 20 20 69 66 20 28 53 74 72 69 6e 67 2e 49 73     if (String.Is
7070: 4e 75 6c 6c 4f 72 45 6d 70 74 79 28 64 61 74 61  NullOrEmpty(data
7080: 54 79 70 65 29 20 3d 3d 20 66 61 6c 73 65 29 0a  Type) == false).
7090: 20 20 20 20 20 20 20 20 20 20 20 20 72 6f 77 5b              row[
70a0: 22 44 61 74 61 54 79 70 65 4e 61 6d 65 22 5d 20  "DataTypeName"] 
70b0: 3d 20 64 61 74 61 54 79 70 65 3b 0a 20 20 20 20  = dataType;.    
70c0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 74 62      }.        tb
70d0: 6c 2e 52 6f 77 73 2e 41 64 64 28 72 6f 77 29 3b  l.Rows.Add(row);
70e0: 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20  .      }..      
70f0: 69 66 20 28 5f 6b 65 79 49 6e 66 6f 20 21 3d 20  if (_keyInfo != 
7100: 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20 20 5f 6b  null).        _k
7110: 65 79 49 6e 66 6f 2e 41 70 70 65 6e 64 53 63 68  eyInfo.AppendSch
7120: 65 6d 61 54 61 62 6c 65 28 74 62 6c 29 3b 0a 0a  emaTable(tbl);..
7130: 20 20 20 20 20 20 74 62 6c 2e 41 63 63 65 70 74        tbl.Accept
7140: 43 68 61 6e 67 65 73 28 29 3b 0a 20 20 20 20 20  Changes();.     
7150: 20 74 62 6c 2e 45 6e 64 4c 6f 61 64 44 61 74 61   tbl.EndLoadData
7160: 28 29 3b 0a 0a 20 20 20 20 20 20 72 65 74 75 72  ();..      retur
7170: 6e 20 74 62 6c 3b 0a 20 20 20 20 7d 0a 0a 20 20  n tbl;.    }..  
7180: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a    /// <summary>.
7190: 20 20 20 20 2f 2f 2f 20 52 65 74 72 69 65 76 65      /// Retrieve
71a0: 73 20 74 68 65 20 63 6f 6c 75 6d 6e 20 61 73 20  s the column as 
71b0: 61 20 73 74 72 69 6e 67 0a 20 20 20 20 2f 2f 2f  a string.    ///
71c0: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20   </summary>.    
71d0: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
71e0: 22 69 22 3e 54 68 65 20 69 6e 64 65 78 20 6f 66  "i">The index of
71f0: 20 74 68 65 20 63 6f 6c 75 6d 6e 20 74 6f 20 72   the column to r
7200: 65 74 72 69 65 76 65 3c 2f 70 61 72 61 6d 3e 0a  etrieve</param>.
7210: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
7220: 3e 73 74 72 69 6e 67 3c 2f 72 65 74 75 72 6e 73  >string</returns
7230: 3e 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65  >.    public ove
7240: 72 72 69 64 65 20 73 74 72 69 6e 67 20 47 65 74  rride string Get
7250: 53 74 72 69 6e 67 28 69 6e 74 20 69 29 0a 20 20  String(int i).  
7260: 20 20 7b 0a 20 20 20 20 20 20 69 66 20 28 69 20    {.      if (i 
7270: 3e 3d 20 56 69 73 69 62 6c 65 46 69 65 6c 64 43  >= VisibleFieldC
7280: 6f 75 6e 74 20 26 26 20 5f 6b 65 79 49 6e 66 6f  ount && _keyInfo
7290: 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20   != null).      
72a0: 20 20 72 65 74 75 72 6e 20 5f 6b 65 79 49 6e 66    return _keyInf
72b0: 6f 2e 47 65 74 53 74 72 69 6e 67 28 69 20 2d 20  o.GetString(i - 
72c0: 56 69 73 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e  VisibleFieldCoun
72d0: 74 29 3b 0a 0a 20 20 20 20 20 20 56 65 72 69 66  t);..      Verif
72e0: 79 54 79 70 65 28 69 2c 20 44 62 54 79 70 65 2e  yType(i, DbType.
72f0: 53 74 72 69 6e 67 29 3b 0a 20 20 20 20 20 20 72  String);.      r
7300: 65 74 75 72 6e 20 5f 61 63 74 69 76 65 53 74 61  eturn _activeSta
7310: 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 54  tement._sql.GetT
7320: 65 78 74 28 5f 61 63 74 69 76 65 53 74 61 74 65  ext(_activeState
7330: 6d 65 6e 74 2c 20 69 29 3b 0a 20 20 20 20 7d 0a  ment, i);.    }.
7340: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
7350: 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74 72 69  y>.    /// Retri
7360: 65 76 65 73 20 74 68 65 20 63 6f 6c 75 6d 6e 20  eves the column 
7370: 61 73 20 61 6e 20 6f 62 6a 65 63 74 20 63 6f 72  as an object cor
7380: 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 74 68  responding to th
7390: 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 64 61 74  e underlying dat
73a0: 61 74 79 70 65 20 6f 66 20 74 68 65 20 63 6f 6c  atype of the col
73b0: 75 6d 6e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  umn.    /// </su
73c0: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c  mmary>.    /// <
73d0: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54  param name="i">T
73e0: 68 65 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20  he index of the 
73f0: 63 6f 6c 75 6d 6e 20 74 6f 20 72 65 74 72 69 65  column to retrie
7400: 76 65 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  ve</param>.    /
7410: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 6f 62 6a 65  // <returns>obje
7420: 63 74 3c 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20  ct</returns>.   
7430: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
7440: 20 6f 62 6a 65 63 74 20 47 65 74 56 61 6c 75 65   object GetValue
7450: 28 69 6e 74 20 69 29 0a 20 20 20 20 7b 0a 20 20  (int i).    {.  
7460: 20 20 20 20 69 66 20 28 69 20 3e 3d 20 56 69 73      if (i >= Vis
7470: 69 62 6c 65 46 69 65 6c 64 43 6f 75 6e 74 20 26  ibleFieldCount &
7480: 26 20 5f 6b 65 79 49 6e 66 6f 20 21 3d 20 6e 75  & _keyInfo != nu
7490: 6c 6c 29 0a 20 20 20 20 20 20 20 20 72 65 74 75  ll).        retu
74a0: 72 6e 20 5f 6b 65 79 49 6e 66 6f 2e 47 65 74 56  rn _keyInfo.GetV
74b0: 61 6c 75 65 28 69 20 2d 20 56 69 73 69 62 6c 65  alue(i - Visible
74c0: 46 69 65 6c 64 43 6f 75 6e 74 29 3b 0a 0a 20 20  FieldCount);..  
74d0: 20 20 20 20 53 51 4c 69 74 65 54 79 70 65 20 74      SQLiteType t
74e0: 79 70 20 3d 20 47 65 74 53 51 4c 69 74 65 54 79  yp = GetSQLiteTy
74f0: 70 65 28 69 29 3b 0a 0a 20 20 20 20 20 20 72 65  pe(i);..      re
7500: 74 75 72 6e 20 5f 61 63 74 69 76 65 53 74 61 74  turn _activeStat
7510: 65 6d 65 6e 74 2e 5f 73 71 6c 2e 47 65 74 56 61  ement._sql.GetVa
7520: 6c 75 65 28 5f 61 63 74 69 76 65 53 74 61 74 65  lue(_activeState
7530: 6d 65 6e 74 2c 20 69 2c 20 74 79 70 29 3b 0a 20  ment, i, typ);. 
7540: 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73     }..    /// <s
7550: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20  ummary>.    /// 
7560: 52 65 74 72 65 69 76 65 73 20 74 68 65 20 76 61  Retreives the va
7570: 6c 75 65 73 20 6f 66 20 6d 75 6c 74 69 70 6c 65  lues of multiple
7580: 20 63 6f 6c 75 6d 6e 73 2c 20 75 70 20 74 6f 20   columns, up to 
7590: 74 68 65 20 73 69 7a 65 20 6f 66 20 74 68 65 20  the size of the 
75a0: 73 75 70 70 6c 69 65 64 20 61 72 72 61 79 0a 20  supplied array. 
75b0: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
75c0: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
75d0: 20 6e 61 6d 65 3d 22 76 61 6c 75 65 73 22 3e 54   name="values">T
75e0: 68 65 20 61 72 72 61 79 20 74 6f 20 66 69 6c 6c  he array to fill
75f0: 20 77 69 74 68 20 76 61 6c 75 65 73 20 66 72 6f   with values fro
7600: 6d 20 74 68 65 20 63 6f 6c 75 6d 6e 73 20 69 6e  m the columns in
7610: 20 74 68 65 20 63 75 72 72 65 6e 74 20 72 65 73   the current res
7620: 75 6c 74 73 65 74 3c 2f 70 61 72 61 6d 3e 0a 20  ultset</param>. 
7630: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
7640: 54 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 63 6f  The number of co
7650: 6c 75 6d 6e 73 20 72 65 74 72 69 65 76 65 64 3c  lumns retrieved<
7660: 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75  /returns>.    pu
7670: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 69 6e  blic override in
7680: 74 20 47 65 74 56 61 6c 75 65 73 28 6f 62 6a 65  t GetValues(obje
7690: 63 74 5b 5d 20 76 61 6c 75 65 73 29 0a 20 20 20  ct[] values).   
76a0: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 4d 61   {.      int nMa
76b0: 78 20 3d 20 46 69 65 6c 64 43 6f 75 6e 74 3b 0a  x = FieldCount;.
76c0: 20 20 20 20 20 20 69 66 20 28 76 61 6c 75 65 73        if (values
76d0: 2e 4c 65 6e 67 74 68 20 3c 20 6e 4d 61 78 29 20  .Length < nMax) 
76e0: 6e 4d 61 78 20 3d 20 76 61 6c 75 65 73 2e 4c 65  nMax = values.Le
76f0: 6e 67 74 68 3b 0a 0a 20 20 20 20 20 20 66 6f 72  ngth;..      for
7700: 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20 6e 20 3c   (int n = 0; n <
7710: 20 6e 4d 61 78 3b 20 6e 2b 2b 29 0a 20 20 20 20   nMax; n++).    
7720: 20 20 7b 0a 20 20 20 20 20 20 20 20 76 61 6c 75    {.        valu
7730: 65 73 5b 6e 5d 20 3d 20 47 65 74 56 61 6c 75 65  es[n] = GetValue
7740: 28 6e 29 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20  (n);.      }..  
7750: 20 20 20 20 72 65 74 75 72 6e 20 6e 4d 61 78 3b      return nMax;
7760: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20  .    }..    /// 
7770: 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  <summary>.    //
7780: 2f 20 52 65 74 75 72 6e 73 20 54 72 75 65 20 69  / Returns True i
7790: 66 20 74 68 65 20 72 65 73 75 6c 74 73 65 74 20  f the resultset 
77a0: 68 61 73 20 72 6f 77 73 20 74 68 61 74 20 63 61  has rows that ca
77b0: 6e 20 62 65 20 66 65 74 63 68 65 64 0a 20 20 20  n be fetched.   
77c0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
77d0: 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72      public overr
77e0: 69 64 65 20 62 6f 6f 6c 20 48 61 73 52 6f 77 73  ide bool HasRows
77f0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65 74  .    {.      get
7800: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
7810: 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a   CheckClosed();.
7820: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 28          return (
7830: 5f 72 65 61 64 69 6e 67 53 74 61 74 65 20 21 3d  _readingState !=
7840: 20 31 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20   1);.      }.   
7850: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
7860: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65  mary>.    /// Re
7870: 74 75 72 6e 73 20 54 72 75 65 20 69 66 20 74 68  turns True if th
7880: 65 20 64 61 74 61 20 72 65 61 64 65 72 20 69 73  e data reader is
7890: 20 63 6c 6f 73 65 64 0a 20 20 20 20 2f 2f 2f 20   closed.    /// 
78a0: 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70  </summary>.    p
78b0: 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 62  ublic override b
78c0: 6f 6f 6c 20 49 73 43 6c 6f 73 65 64 0a 20 20 20  ool IsClosed.   
78d0: 20 7b 0a 20 20 20 20 20 20 67 65 74 20 7b 20 72   {.      get { r
78e0: 65 74 75 72 6e 20 28 5f 63 6f 6d 6d 61 6e 64 20  eturn (_command 
78f0: 3d 3d 20 6e 75 6c 6c 29 3b 20 7d 0a 20 20 20 20  == null); }.    
7900: 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  }..    /// <summ
7910: 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 74  ary>.    /// Ret
7920: 75 72 6e 73 20 54 72 75 65 20 69 66 20 74 68 65  urns True if the
7930: 20 73 70 65 63 69 66 69 65 64 20 63 6f 6c 75 6d   specified colum
7940: 6e 20 69 73 20 6e 75 6c 6c 0a 20 20 20 20 2f 2f  n is null.    //
7950: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20  / </summary>.   
7960: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
7970: 3d 22 69 22 3e 54 68 65 20 69 6e 64 65 78 20 6f  ="i">The index o
7980: 66 20 74 68 65 20 63 6f 6c 75 6d 6e 20 74 6f 20  f the column to 
7990: 72 65 74 72 69 65 76 65 3c 2f 70 61 72 61 6d 3e  retrieve</param>
79a0: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
79b0: 73 3e 54 72 75 65 20 6f 72 20 46 61 6c 73 65 3c  s>True or False<
79c0: 2f 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75  /returns>.    pu
79d0: 62 6c 69 63 20 6f 76 65 72 72 69 64 65 20 62 6f  blic override bo
79e0: 6f 6c 20 49 73 44 42 4e 75 6c 6c 28 69 6e 74 20  ol IsDBNull(int 
79f0: 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  i).    {.      i
7a00: 66 20 28 69 20 3e 3d 20 56 69 73 69 62 6c 65 46  f (i >= VisibleF
7a10: 69 65 6c 64 43 6f 75 6e 74 20 26 26 20 5f 6b 65  ieldCount && _ke
7a20: 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20  yInfo != null). 
7a30: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 5f 6b         return _k
7a40: 65 79 49 6e 66 6f 2e 49 73 44 42 4e 75 6c 6c 28  eyInfo.IsDBNull(
7a50: 69 20 2d 20 56 69 73 69 62 6c 65 46 69 65 6c 64  i - VisibleField
7a60: 43 6f 75 6e 74 29 3b 0a 0a 20 20 20 20 20 20 72  Count);..      r
7a70: 65 74 75 72 6e 20 5f 61 63 74 69 76 65 53 74 61  eturn _activeSta
7a80: 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 49 73 4e 75  tement._sql.IsNu
7a90: 6c 6c 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d  ll(_activeStatem
7aa0: 65 6e 74 2c 20 69 29 3b 0a 20 20 20 20 7d 0a 0a  ent, i);.    }..
7ab0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
7ac0: 3e 0a 20 20 20 20 2f 2f 2f 20 4d 6f 76 65 73 20  >.    /// Moves 
7ad0: 74 6f 20 74 68 65 20 6e 65 78 74 20 72 65 73 75  to the next resu
7ae0: 6c 74 73 65 74 20 69 6e 20 6d 75 6c 74 69 70 6c  ltset in multipl
7af0: 65 20 72 6f 77 2d 72 65 74 75 72 6e 69 6e 67 20  e row-returning 
7b00: 53 51 4c 20 63 6f 6d 6d 61 6e 64 2e 0a 20 20 20  SQL command..   
7b10: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a   /// </summary>.
7b20: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
7b30: 3e 54 72 75 65 20 69 66 20 74 68 65 20 63 6f 6d  >True if the com
7b40: 6d 61 6e 64 20 77 61 73 20 73 75 63 63 65 73 73  mand was success
7b50: 66 75 6c 20 61 6e 64 20 61 20 6e 65 77 20 72 65  ful and a new re
7b60: 73 75 6c 74 73 65 74 20 69 73 20 61 76 61 69 6c  sultset is avail
7b70: 61 62 6c 65 2c 20 46 61 6c 73 65 20 6f 74 68 65  able, False othe
7b80: 72 77 69 73 65 2e 3c 2f 72 65 74 75 72 6e 73 3e  rwise.</returns>
7b90: 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72  .    public over
7ba0: 72 69 64 65 20 62 6f 6f 6c 20 4e 65 78 74 52 65  ride bool NextRe
7bb0: 73 75 6c 74 28 29 0a 20 20 20 20 7b 0a 20 20 20  sult().    {.   
7bc0: 20 20 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29     CheckClosed()
7bd0: 3b 0a 0a 20 20 20 20 20 20 53 51 4c 69 74 65 53  ;..      SQLiteS
7be0: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 20 3d 20  tatement stmt = 
7bf0: 6e 75 6c 6c 3b 0a 20 20 20 20 20 20 69 6e 74 20  null;.      int 
7c00: 66 69 65 6c 64 43 6f 75 6e 74 3b 0a 0a 20 20 20  fieldCount;..   
7c10: 20 20 20 77 68 69 6c 65 20 28 74 72 75 65 29 0a     while (true).
7c20: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
7c30: 69 66 20 28 5f 61 63 74 69 76 65 53 74 61 74 65  if (_activeState
7c40: 6d 65 6e 74 20 21 3d 20 6e 75 6c 6c 20 26 26 20  ment != null && 
7c50: 73 74 6d 74 20 3d 3d 20 6e 75 6c 6c 29 0a 20 20  stmt == null).  
7c60: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
7c70: 20 20 2f 2f 20 52 65 73 65 74 20 74 68 65 20 70    // Reset the p
7c80: 72 65 76 69 6f 75 73 6c 79 2d 65 78 65 63 75 74  reviously-execut
7c90: 65 64 20 73 74 61 74 65 6d 65 6e 74 0a 20 20 20  ed statement.   
7ca0: 20 20 20 20 20 20 20 5f 61 63 74 69 76 65 53 74         _activeSt
7cb0: 61 74 65 6d 65 6e 74 2e 5f 73 71 6c 2e 52 65 73  atement._sql.Res
7cc0: 65 74 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d  et(_activeStatem
7cd0: 65 6e 74 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  ent);..         
7ce0: 20 2f 2f 20 49 66 20 77 65 27 72 65 20 6f 6e 6c   // If we're onl
7cf0: 79 20 73 75 70 70 6f 73 65 64 20 74 6f 20 72 65  y supposed to re
7d00: 74 75 72 6e 20 61 20 73 69 6e 67 6c 65 20 72 6f  turn a single ro
7d10: 77 73 65 74 2c 20 73 74 65 70 20 74 68 72 6f 75  wset, step throu
7d20: 67 68 20 61 6c 6c 20 72 65 6d 61 69 6e 69 6e 67  gh all remaining
7d30: 20 73 74 61 74 65 6d 65 6e 74 73 20 6f 6e 63 65   statements once
7d40: 20 75 6e 74 69 6c 0a 20 20 20 20 20 20 20 20 20   until.         
7d50: 20 2f 2f 20 74 68 65 79 20 61 72 65 20 61 6c 6c   // they are all
7d60: 20 64 6f 6e 65 20 61 6e 64 20 72 65 74 75 72 6e   done and return
7d70: 20 66 61 6c 73 65 20 74 6f 20 69 6e 64 69 63 61   false to indica
7d80: 74 65 20 6e 6f 20 6d 6f 72 65 20 72 65 73 75 6c  te no more resul
7d90: 74 73 65 74 73 20 65 78 69 73 74 2e 0a 20 20 20  tsets exist..   
7da0: 20 20 20 20 20 20 20 69 66 20 28 28 5f 63 6f 6d         if ((_com
7db0: 6d 61 6e 64 42 65 68 61 76 69 6f 72 20 26 20 43  mandBehavior & C
7dc0: 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72 2e 53  ommandBehavior.S
7dd0: 69 6e 67 6c 65 52 65 73 75 6c 74 29 20 21 3d 20  ingleResult) != 
7de0: 30 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20  0).          {. 
7df0: 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 20 28             for (
7e00: 3b 20 3b 20 29 0a 20 20 20 20 20 20 20 20 20 20  ; ; ).          
7e10: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20    {.            
7e20: 20 20 73 74 6d 74 20 3d 20 5f 63 6f 6d 6d 61 6e    stmt = _comman
7e30: 64 2e 47 65 74 53 74 61 74 65 6d 65 6e 74 28 5f  d.GetStatement(_
7e40: 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 49  activeStatementI
7e50: 6e 64 65 78 20 2b 20 31 29 3b 0a 20 20 20 20 20  ndex + 1);.     
7e60: 20 20 20 20 20 20 20 20 20 69 66 20 28 73 74 6d           if (stm
7e70: 74 20 3d 3d 20 6e 75 6c 6c 29 20 62 72 65 61 6b  t == null) break
7e80: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
7e90: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
7ea0: 49 6e 64 65 78 2b 2b 3b 0a 0a 20 20 20 20 20 20  Index++;..      
7eb0: 20 20 20 20 20 20 20 20 73 74 6d 74 2e 5f 73 71          stmt._sq
7ec0: 6c 2e 53 74 65 70 28 73 74 6d 74 29 3b 0a 20 20  l.Step(stmt);.  
7ed0: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
7ee0: 73 74 6d 74 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e  stmt._sql.Column
7ef0: 43 6f 75 6e 74 28 73 74 6d 74 29 20 3d 3d 20 30  Count(stmt) == 0
7f00: 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ).              
7f10: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
7f20: 20 20 69 66 20 28 5f 72 6f 77 73 41 66 66 65 63    if (_rowsAffec
7f30: 74 65 64 20 3d 3d 20 2d 31 29 20 5f 72 6f 77 73  ted == -1) _rows
7f40: 41 66 66 65 63 74 65 64 20 3d 20 30 3b 0a 20 20  Affected = 0;.  
7f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5f 72                _r
7f60: 6f 77 73 41 66 66 65 63 74 65 64 20 2b 3d 20 73  owsAffected += s
7f70: 74 6d 74 2e 5f 73 71 6c 2e 43 68 61 6e 67 65 73  tmt._sql.Changes
7f80: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
7f90: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  }.              
7fa0: 73 74 6d 74 2e 5f 73 71 6c 2e 52 65 73 65 74 28  stmt._sql.Reset(
7fb0: 73 74 6d 74 29 3b 20 2f 2f 20 47 6f 74 74 61 20  stmt); // Gotta 
7fc0: 72 65 73 65 74 20 61 66 74 65 72 20 65 76 65 72  reset after ever
7fd0: 79 20 73 74 65 70 20 74 6f 20 72 65 6c 65 61 73  y step to releas
7fe0: 65 20 61 6e 79 20 6c 6f 63 6b 73 20 61 6e 64 20  e any locks and 
7ff0: 73 75 63 68 21 0a 20 20 20 20 20 20 20 20 20 20  such!.          
8000: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20    }.            
8010: 72 65 74 75 72 6e 20 66 61 6c 73 65 3b 0a 20 20  return false;.  
8020: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
8030: 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20    }..        // 
8040: 47 65 74 20 74 68 65 20 6e 65 78 74 20 73 74 61  Get the next sta
8050: 74 65 6d 65 6e 74 20 74 6f 20 65 78 65 63 75 74  tement to execut
8060: 65 0a 20 20 20 20 20 20 20 20 73 74 6d 74 20 3d  e.        stmt =
8070: 20 5f 63 6f 6d 6d 61 6e 64 2e 47 65 74 53 74 61   _command.GetSta
8080: 74 65 6d 65 6e 74 28 5f 61 63 74 69 76 65 53 74  tement(_activeSt
8090: 61 74 65 6d 65 6e 74 49 6e 64 65 78 20 2b 20 31  atementIndex + 1
80a0: 29 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20 49  );..        // I
80b0: 66 20 77 65 27 76 65 20 72 65 61 63 68 65 64 20  f we've reached 
80c0: 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20 73  the end of the s
80d0: 74 61 74 65 6d 65 6e 74 73 2c 20 72 65 74 75 72  tatements, retur
80e0: 6e 20 66 61 6c 73 65 2c 20 6e 6f 20 6d 6f 72 65  n false, no more
80f0: 20 72 65 73 75 6c 74 73 65 74 73 0a 20 20 20 20   resultsets.    
8100: 20 20 20 20 69 66 20 28 73 74 6d 74 20 3d 3d 20      if (stmt == 
8110: 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20 20 20 20  null).          
8120: 72 65 74 75 72 6e 20 66 61 6c 73 65 3b 0a 0a 20  return false;.. 
8130: 20 20 20 20 20 20 20 2f 2f 20 49 66 20 77 65 20         // If we 
8140: 77 65 72 65 20 6f 6e 20 61 20 63 75 72 72 65 6e  were on a curren
8150: 74 20 72 65 73 75 6c 74 73 65 74 2c 20 73 65 74  t resultset, set
8160: 20 74 68 65 20 73 74 61 74 65 20 74 6f 20 22 64   the state to "d
8170: 6f 6e 65 20 72 65 61 64 69 6e 67 22 20 66 6f 72  one reading" for
8180: 20 69 74 0a 20 20 20 20 20 20 20 20 69 66 20 28   it.        if (
8190: 5f 72 65 61 64 69 6e 67 53 74 61 74 65 20 3c 20  _readingState < 
81a0: 31 29 0a 20 20 20 20 20 20 20 20 20 20 5f 72 65  1).          _re
81b0: 61 64 69 6e 67 53 74 61 74 65 20 3d 20 31 3b 0a  adingState = 1;.
81c0: 0a 20 20 20 20 20 20 20 20 5f 61 63 74 69 76 65  .        _active
81d0: 53 74 61 74 65 6d 65 6e 74 49 6e 64 65 78 2b 2b  StatementIndex++
81e0: 3b 0a 0a 20 20 20 20 20 20 20 20 66 69 65 6c 64  ;..        field
81f0: 43 6f 75 6e 74 20 3d 20 73 74 6d 74 2e 5f 73 71  Count = stmt._sq
8200: 6c 2e 43 6f 6c 75 6d 6e 43 6f 75 6e 74 28 73 74  l.ColumnCount(st
8210: 6d 74 29 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f  mt);..        //
8220: 20 49 66 20 74 68 65 20 73 74 61 74 65 6d 65 6e   If the statemen
8230: 74 20 69 73 20 6e 6f 74 20 61 20 73 65 6c 65 63  t is not a selec
8240: 74 20 73 74 61 74 65 6d 65 6e 74 20 6f 72 20 77  t statement or w
8250: 65 27 72 65 20 6e 6f 74 20 72 65 74 72 69 65 76  e're not retriev
8260: 69 6e 67 20 73 63 68 65 6d 61 20 6f 6e 6c 79 2c  ing schema only,
8270: 20 74 68 65 6e 20 70 65 72 66 6f 72 6d 20 74 68   then perform th
8280: 65 20 69 6e 69 74 69 61 6c 20 73 74 65 70 0a 20  e initial step. 
8290: 20 20 20 20 20 20 20 69 66 20 28 28 5f 63 6f 6d         if ((_com
82a0: 6d 61 6e 64 42 65 68 61 76 69 6f 72 20 26 20 43  mandBehavior & C
82b0: 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f 72 2e 53  ommandBehavior.S
82c0: 63 68 65 6d 61 4f 6e 6c 79 29 20 3d 3d 20 30 20  chemaOnly) == 0 
82d0: 7c 7c 20 66 69 65 6c 64 43 6f 75 6e 74 20 3d 3d  || fieldCount ==
82e0: 20 30 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20   0).        {.  
82f0: 20 20 20 20 20 20 20 20 69 66 20 28 73 74 6d 74          if (stmt
8300: 2e 5f 73 71 6c 2e 53 74 65 70 28 73 74 6d 74 29  ._sql.Step(stmt)
8310: 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20  ).          {.  
8320: 20 20 20 20 20 20 20 20 20 20 5f 72 65 61 64 69            _readi
8330: 6e 67 53 74 61 74 65 20 3d 20 2d 31 3b 0a 20 20  ngState = -1;.  
8340: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
8350: 20 20 20 20 65 6c 73 65 20 69 66 20 28 66 69 65      else if (fie
8360: 6c 64 43 6f 75 6e 74 20 3d 3d 20 30 29 20 2f 2f  ldCount == 0) //
8370: 20 4e 6f 20 72 6f 77 73 20 72 65 74 75 72 6e 65   No rows returne
8380: 64 2c 20 69 66 20 66 69 65 6c 64 43 6f 75 6e 74  d, if fieldCount
8390: 20 69 73 20 7a 65 72 6f 2c 20 73 6b 69 70 20 74   is zero, skip t
83a0: 6f 20 74 68 65 20 6e 65 78 74 20 73 74 61 74 65  o the next state
83b0: 6d 65 6e 74 0a 20 20 20 20 20 20 20 20 20 20 7b  ment.          {
83c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20  .            if 
83d0: 28 5f 72 6f 77 73 41 66 66 65 63 74 65 64 20 3d  (_rowsAffected =
83e0: 3d 20 2d 31 29 20 5f 72 6f 77 73 41 66 66 65 63  = -1) _rowsAffec
83f0: 74 65 64 20 3d 20 30 3b 0a 20 20 20 20 20 20 20  ted = 0;.       
8400: 20 20 20 20 20 5f 72 6f 77 73 41 66 66 65 63 74       _rowsAffect
8410: 65 64 20 2b 3d 20 73 74 6d 74 2e 5f 73 71 6c 2e  ed += stmt._sql.
8420: 43 68 61 6e 67 65 73 3b 0a 20 20 20 20 20 20 20  Changes;.       
8430: 20 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c 2e 52       stmt._sql.R
8440: 65 73 65 74 28 73 74 6d 74 29 3b 0a 20 20 20 20  eset(stmt);.    
8450: 20 20 20 20 20 20 20 20 63 6f 6e 74 69 6e 75 65          continue
8460: 3b 20 2f 2f 20 53 6b 69 70 20 74 68 69 73 20 63  ; // Skip this c
8470: 6f 6d 6d 61 6e 64 20 61 6e 64 20 6d 6f 76 65 20  ommand and move 
8480: 74 6f 20 74 68 65 20 6e 65 78 74 2c 20 69 74 20  to the next, it 
8490: 77 61 73 20 6e 6f 74 20 61 20 72 6f 77 2d 72 65  was not a row-re
84a0: 74 75 72 6e 69 6e 67 20 72 65 73 75 6c 74 73 65  turning resultse
84b0: 74 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20  t.          }.  
84c0: 20 20 20 20 20 20 20 20 65 6c 73 65 20 2f 2f 20          else // 
84d0: 4e 6f 20 72 6f 77 73 2c 20 66 69 65 6c 64 43 6f  No rows, fieldCo
84e0: 75 6e 74 20 69 73 20 6e 6f 6e 2d 7a 65 72 6f 20  unt is non-zero 
84f0: 73 6f 20 73 74 6f 70 20 68 65 72 65 0a 20 20 20  so stop here.   
8500: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
8510: 20 20 20 20 20 5f 72 65 61 64 69 6e 67 53 74 61       _readingSta
8520: 74 65 20 3d 20 31 3b 20 2f 2f 20 54 68 69 73 20  te = 1; // This 
8530: 63 6f 6d 6d 61 6e 64 20 72 65 74 75 72 6e 65 64  command returned
8540: 20 63 6f 6c 75 6d 6e 73 20 62 75 74 20 6e 6f 20   columns but no 
8550: 72 6f 77 73 2c 20 73 6f 20 72 65 74 75 72 6e 20  rows, so return 
8560: 74 72 75 65 2c 20 62 75 74 20 48 61 73 52 6f 77  true, but HasRow
8570: 73 20 3d 20 66 61 6c 73 65 20 61 6e 64 20 52 65  s = false and Re
8580: 61 64 28 29 20 72 65 74 75 72 6e 73 20 66 61 6c  ad() returns fal
8590: 73 65 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  se.          }. 
85a0: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20         }..      
85b0: 20 20 2f 2f 20 41 68 68 2c 20 77 65 20 66 6f 75    // Ahh, we fou
85c0: 6e 64 20 61 20 72 6f 77 2d 72 65 74 75 72 6e 69  nd a row-returni
85d0: 6e 67 20 72 65 73 75 6c 74 73 65 74 20 65 6c 69  ng resultset eli
85e0: 67 69 62 6c 65 20 74 6f 20 62 65 20 72 65 74 75  gible to be retu
85f0: 72 6e 65 64 21 0a 20 20 20 20 20 20 20 20 5f 61  rned!.        _a
8600: 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74 20 3d  ctiveStatement =
8610: 20 73 74 6d 74 3b 0a 20 20 20 20 20 20 20 20 5f   stmt;.        _
8620: 66 69 65 6c 64 43 6f 75 6e 74 20 3d 20 66 69 65  fieldCount = fie
8630: 6c 64 43 6f 75 6e 74 3b 0a 20 20 20 20 20 20 20  ldCount;.       
8640: 20 5f 66 69 65 6c 64 54 79 70 65 41 72 72 61 79   _fieldTypeArray
8650: 20 3d 20 6e 75 6c 6c 3b 0a 0a 20 20 20 20 20 20   = null;..      
8660: 20 20 69 66 20 28 28 5f 63 6f 6d 6d 61 6e 64 42    if ((_commandB
8670: 65 68 61 76 69 6f 72 20 26 20 43 6f 6d 6d 61 6e  ehavior & Comman
8680: 64 42 65 68 61 76 69 6f 72 2e 4b 65 79 49 6e 66  dBehavior.KeyInf
8690: 6f 29 20 21 3d 20 30 29 0a 20 20 20 20 20 20 20  o) != 0).       
86a0: 20 20 20 4c 6f 61 64 4b 65 79 49 6e 66 6f 28 29     LoadKeyInfo()
86b0: 3b 0a 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  ;..        retur
86c0: 6e 20 74 72 75 65 3b 0a 20 20 20 20 20 20 7d 0a  n true;.      }.
86d0: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c      }..    /// <
86e0: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
86f0: 20 52 65 74 72 69 65 76 65 73 20 74 68 65 20 53   Retrieves the S
8700: 51 4c 69 74 65 54 79 70 65 20 66 6f 72 20 61 20  QLiteType for a 
8710: 67 69 76 65 6e 20 63 6f 6c 75 6d 6e 2c 20 61 6e  given column, an
8720: 64 20 63 61 63 68 65 73 20 69 74 20 74 6f 20 61  d caches it to a
8730: 76 6f 69 64 20 72 65 70 65 74 65 74 69 76 65 20  void repetetive 
8740: 69 6e 74 65 72 6f 70 20 63 61 6c 6c 73 2e 0a 20  interop calls.. 
8750: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
8760: 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  >.    /// <param
8770: 20 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20 69 6e   name="i">The in
8780: 64 65 78 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d  dex of the colum
8790: 6e 20 74 6f 20 72 65 74 72 69 65 76 65 3c 2f 70  n to retrieve</p
87a0: 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72  aram>.    /// <r
87b0: 65 74 75 72 6e 73 3e 41 20 53 51 4c 69 74 65 54  eturns>A SQLiteT
87c0: 79 70 65 20 73 74 72 75 63 74 75 72 65 3c 2f 72  ype structure</r
87d0: 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 72 69 76  eturns>.    priv
87e0: 61 74 65 20 53 51 4c 69 74 65 54 79 70 65 20 47  ate SQLiteType G
87f0: 65 74 53 51 4c 69 74 65 54 79 70 65 28 69 6e 74  etSQLiteType(int
8800: 20 69 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20   i).    {.      
8810: 53 51 4c 69 74 65 54 79 70 65 20 74 79 70 3b 0a  SQLiteType typ;.
8820: 0a 20 20 20 20 20 20 2f 2f 20 49 6e 69 74 69 61  .      // Initia
8830: 6c 69 7a 65 20 74 68 65 20 66 69 65 6c 64 20 74  lize the field t
8840: 79 70 65 73 20 61 72 72 61 79 20 69 66 20 6e 6f  ypes array if no
8850: 74 20 61 6c 72 65 61 64 79 20 69 6e 69 74 69 61  t already initia
8860: 6c 69 7a 65 64 0a 20 20 20 20 20 20 69 66 20 28  lized.      if (
8870: 5f 66 69 65 6c 64 54 79 70 65 41 72 72 61 79 20  _fieldTypeArray 
8880: 3d 3d 20 6e 75 6c 6c 29 0a 20 20 20 20 20 20 20  == null).       
8890: 20 5f 66 69 65 6c 64 54 79 70 65 41 72 72 61 79   _fieldTypeArray
88a0: 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 54 79 70   = new SQLiteTyp
88b0: 65 5b 56 69 73 69 62 6c 65 46 69 65 6c 64 43 6f  e[VisibleFieldCo
88c0: 75 6e 74 5d 3b 0a 0a 20 20 20 20 20 20 2f 2f 20  unt];..      // 
88d0: 49 6e 69 74 69 61 6c 69 7a 65 20 74 68 69 73 20  Initialize this 
88e0: 63 6f 6c 75 6d 6e 27 73 20 66 69 65 6c 64 20 74  column's field t
88f0: 79 70 65 20 69 6e 73 74 61 6e 63 65 0a 20 20 20  ype instance.   
8900: 20 20 20 69 66 20 28 5f 66 69 65 6c 64 54 79 70     if (_fieldTyp
8910: 65 41 72 72 61 79 5b 69 5d 20 3d 3d 20 6e 75 6c  eArray[i] == nul
8920: 6c 29 20 5f 66 69 65 6c 64 54 79 70 65 41 72 72  l) _fieldTypeArr
8930: 61 79 5b 69 5d 20 3d 20 6e 65 77 20 53 51 4c 69  ay[i] = new SQLi
8940: 74 65 54 79 70 65 28 29 3b 0a 0a 20 20 20 20 20  teType();..     
8950: 20 74 79 70 20 3d 20 5f 66 69 65 6c 64 54 79 70   typ = _fieldTyp
8960: 65 41 72 72 61 79 5b 69 5d 3b 0a 0a 20 20 20 20  eArray[i];..    
8970: 20 20 2f 2f 20 49 66 20 6e 6f 74 20 69 6e 69 74    // If not init
8980: 69 61 6c 69 7a 65 64 2c 20 74 68 65 6e 20 66 65  ialized, then fe
8990: 74 63 68 20 74 68 65 20 64 65 63 6c 61 72 65 64  tch the declared
89a0: 20 63 6f 6c 75 6d 6e 20 64 61 74 61 74 79 70 65   column datatype
89b0: 20 61 6e 64 20 61 74 74 65 6d 70 74 20 74 6f 20   and attempt to 
89c0: 63 6f 6e 76 65 72 74 20 69 74 20 0a 20 20 20 20  convert it .    
89d0: 20 20 2f 2f 20 74 6f 20 61 20 6b 6e 6f 77 6e 20    // to a known 
89e0: 44 62 54 79 70 65 2e 0a 20 20 20 20 20 20 69 66  DbType..      if
89f0: 20 28 74 79 70 2e 41 66 66 69 6e 69 74 79 20 3d   (typ.Affinity =
8a00: 3d 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 55  = TypeAffinity.U
8a10: 6e 69 6e 69 74 69 61 6c 69 7a 65 64 29 0a 20 20  ninitialized).  
8a20: 20 20 20 20 20 20 74 79 70 2e 54 79 70 65 20 3d        typ.Type =
8a30: 20 53 51 4c 69 74 65 43 6f 6e 76 65 72 74 2e 54   SQLiteConvert.T
8a40: 79 70 65 4e 61 6d 65 54 6f 44 62 54 79 70 65 28  ypeNameToDbType(
8a50: 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e 74  _activeStatement
8a60: 2e 5f 73 71 6c 2e 43 6f 6c 75 6d 6e 54 79 70 65  ._sql.ColumnType
8a70: 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e  (_activeStatemen
8a80: 74 2c 20 69 2c 20 6f 75 74 20 74 79 70 2e 41 66  t, i, out typ.Af
8a90: 66 69 6e 69 74 79 29 29 3b 0a 20 20 20 20 20 20  finity));.      
8aa0: 65 6c 73 65 0a 20 20 20 20 20 20 20 20 74 79 70  else.        typ
8ab0: 2e 41 66 66 69 6e 69 74 79 20 3d 20 5f 61 63 74  .Affinity = _act
8ac0: 69 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73 71  iveStatement._sq
8ad0: 6c 2e 43 6f 6c 75 6d 6e 41 66 66 69 6e 69 74 79  l.ColumnAffinity
8ae0: 28 5f 61 63 74 69 76 65 53 74 61 74 65 6d 65 6e  (_activeStatemen
8af0: 74 2c 20 69 29 3b 0a 0a 20 20 20 20 20 20 72 65  t, i);..      re
8b00: 74 75 72 6e 20 74 79 70 3b 0a 20 20 20 20 7d 0a  turn typ;.    }.
8b10: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
8b20: 79 3e 0a 20 20 20 20 2f 2f 2f 20 52 65 61 64 73  y>.    /// Reads
8b30: 20 74 68 65 20 6e 65 78 74 20 72 6f 77 20 66 72   the next row fr
8b40: 6f 6d 20 74 68 65 20 72 65 73 75 6c 74 73 65 74  om the resultset
8b50: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
8b60: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74  ry>.    /// <ret
8b70: 75 72 6e 73 3e 54 72 75 65 20 69 66 20 61 20 6e  urns>True if a n
8b80: 65 77 20 72 6f 77 20 77 61 73 20 73 75 63 63 65  ew row was succe
8b90: 73 73 66 75 6c 6c 79 20 6c 6f 61 64 65 64 20 61  ssfully loaded a
8ba0: 6e 64 20 69 73 20 72 65 61 64 79 20 66 6f 72 20  nd is ready for 
8bb0: 70 72 6f 63 65 73 73 69 6e 67 3c 2f 72 65 74 75  processing</retu
8bc0: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
8bd0: 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20 52 65  override bool Re
8be0: 61 64 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  ad().    {.     
8bf0: 20 43 68 65 63 6b 43 6c 6f 73 65 64 28 29 3b 0a   CheckClosed();.
8c00: 0a 20 20 20 20 20 20 69 66 20 28 5f 72 65 61 64  .      if (_read
8c10: 69 6e 67 53 74 61 74 65 20 3d 3d 20 2d 31 29 20  ingState == -1) 
8c20: 2f 2f 20 46 69 72 73 74 20 73 74 65 70 20 77 61  // First step wa
8c30: 73 20 61 6c 72 65 61 64 79 20 64 6f 6e 65 20 61  s already done a
8c40: 74 20 74 68 65 20 4e 65 78 74 52 65 73 75 6c 74  t the NextResult
8c50: 28 29 20 6c 65 76 65 6c 2c 20 73 6f 20 64 6f 6e  () level, so don
8c60: 27 74 20 73 74 65 70 20 61 67 61 69 6e 2c 20 6a  't step again, j
8c70: 75 73 74 20 72 65 74 75 72 6e 20 74 72 75 65 2e  ust return true.
8c80: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
8c90: 20 5f 72 65 61 64 69 6e 67 53 74 61 74 65 20 3d   _readingState =
8ca0: 20 30 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75   0;.        retu
8cb0: 72 6e 20 74 72 75 65 3b 0a 20 20 20 20 20 20 7d  rn true;.      }
8cc0: 0a 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28  .      else if (
8cd0: 5f 72 65 61 64 69 6e 67 53 74 61 74 65 20 3d 3d  _readingState ==
8ce0: 20 30 29 20 2f 2f 20 41 63 74 69 76 65 6c 79 20   0) // Actively 
8cf0: 72 65 61 64 69 6e 67 20 72 6f 77 73 0a 20 20 20  reading rows.   
8d00: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 2f 2f 20     {.        // 
8d10: 44 6f 6e 27 74 20 72 65 61 64 20 61 20 6e 65 77  Don't read a new
8d20: 20 72 6f 77 20 69 66 20 74 68 65 20 63 6f 6d 6d   row if the comm
8d30: 61 6e 64 20 62 65 68 61 76 69 6f 72 20 64 69 63  and behavior dic
8d40: 74 61 74 65 73 20 53 69 6e 67 6c 65 52 6f 77 2e  tates SingleRow.
8d50: 20 20 57 65 27 76 65 20 61 6c 72 65 61 64 79 20    We've already 
8d60: 72 65 61 64 20 74 68 65 20 66 69 72 73 74 20 72  read the first r
8d70: 6f 77 2e 0a 20 20 20 20 20 20 20 20 69 66 20 28  ow..        if (
8d80: 28 5f 63 6f 6d 6d 61 6e 64 42 65 68 61 76 69 6f  (_commandBehavio
8d90: 72 20 26 20 43 6f 6d 6d 61 6e 64 42 65 68 61 76  r & CommandBehav
8da0: 69 6f 72 2e 53 69 6e 67 6c 65 52 6f 77 29 20 3d  ior.SingleRow) =
8db0: 3d 20 30 29 0a 20 20 20 20 20 20 20 20 7b 0a 20  = 0).        {. 
8dc0: 20 20 20 20 20 20 20 20 20 69 66 20 28 5f 61 63           if (_ac
8dd0: 74 69 76 65 53 74 61 74 65 6d 65 6e 74 2e 5f 73  tiveStatement._s
8de0: 71 6c 2e 53 74 65 70 28 5f 61 63 74 69 76 65 53  ql.Step(_activeS
8df0: 74 61 74 65 6d 65 6e 74 29 20 3d 3d 20 74 72 75  tatement) == tru
8e00: 65 29 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20  e).          {. 
8e10: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 5f             if (_
8e20: 6b 65 79 49 6e 66 6f 20 21 3d 20 6e 75 6c 6c 29  keyInfo != null)
8e30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5f  .              _
8e40: 6b 65 79 49 6e 66 6f 2e 52 65 73 65 74 28 29 3b  keyInfo.Reset();
8e50: 0a 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65  ..            re
8e60: 74 75 72 6e 20 74 72 75 65 3b 0a 20 20 20 20 20  turn true;.     
8e70: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d       }.        }
8e80: 0a 0a 20 20 20 20 20 20 20 20 5f 72 65 61 64 69  ..        _readi
8e90: 6e 67 53 74 61 74 65 20 3d 20 31 3b 20 2f 2f 20  ngState = 1; // 
8ea0: 46 69 6e 69 73 68 65 64 20 72 65 61 64 69 6e 67  Finished reading
8eb0: 20 72 6f 77 73 0a 20 20 20 20 20 20 7d 0a 0a 20   rows.      }.. 
8ec0: 20 20 20 20 20 72 65 74 75 72 6e 20 66 61 6c 73       return fals
8ed0: 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f  e;.    }..    //
8ee0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20  / <summary>.    
8ef0: 2f 2f 2f 20 52 65 74 72 69 65 76 65 20 74 68 65  /// Retrieve the
8f00: 20 63 6f 75 6e 74 20 6f 66 20 72 65 63 6f 72 64   count of record
8f10: 73 20 61 66 66 65 63 74 65 64 20 62 79 20 61 6e  s affected by an
8f20: 20 75 70 64 61 74 65 2f 69 6e 73 65 72 74 20 63   update/insert c
8f30: 6f 6d 6d 61 6e 64 2e 20 20 4f 6e 6c 79 20 76 61  ommand.  Only va
8f40: 6c 69 64 20 6f 6e 63 65 20 74 68 65 20 64 61 74  lid once the dat
8f50: 61 20 72 65 61 64 65 72 20 69 73 20 63 6c 6f 73  a reader is clos
8f60: 65 64 21 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ed!.    /// </su
8f70: 6d 6d 61 72 79 3e 0a 20 20 20 20 70 75 62 6c 69  mmary>.    publi
8f80: 63 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 52  c override int R
8f90: 65 63 6f 72 64 73 41 66 66 65 63 74 65 64 0a 20  ecordsAffected. 
8fa0: 20 20 20 7b 0a 20 20 20 20 20 20 67 65 74 20 7b     {.      get {
8fb0: 20 72 65 74 75 72 6e 20 28 5f 72 6f 77 73 41 66   return (_rowsAf
8fc0: 66 65 63 74 65 64 20 3c 20 30 29 20 3f 20 30 20  fected < 0) ? 0 
8fd0: 3a 20 5f 72 6f 77 73 41 66 66 65 63 74 65 64 3b  : _rowsAffected;
8fe0: 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f   }.    }..    //
8ff0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20  / <summary>.    
9000: 2f 2f 2f 20 49 6e 64 65 78 65 72 20 74 6f 20 72  /// Indexer to r
9010: 65 74 72 69 65 76 65 20 64 61 74 61 20 66 72 6f  etrieve data fro
9020: 6d 20 61 20 63 6f 6c 75 6d 6e 20 67 69 76 65 6e  m a column given
9030: 20 69 74 73 20 6e 61 6d 65 0a 20 20 20 20 2f 2f   its name.    //
9040: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20  / </summary>.   
9050: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
9060: 3d 22 6e 61 6d 65 22 3e 54 68 65 20 6e 61 6d 65  ="name">The name
9070: 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d 6e 20 74   of the column t
9080: 6f 20 72 65 74 72 69 65 76 65 20 64 61 74 61 20  o retrieve data 
9090: 66 6f 72 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20  for</param>.    
90a0: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65  /// <returns>The
90b0: 20 76 61 6c 75 65 20 63 6f 6e 74 61 69 6e 65 64   value contained
90c0: 20 69 6e 20 74 68 65 20 63 6f 6c 75 6d 6e 3c 2f   in the column</
90d0: 72 65 74 75 72 6e 73 3e 0a 20 20 20 20 70 75 62  returns>.    pub
90e0: 6c 69 63 20 6f 76 65 72 72 69 64 65 20 6f 62 6a  lic override obj
90f0: 65 63 74 20 74 68 69 73 5b 73 74 72 69 6e 67 20  ect this[string 
9100: 6e 61 6d 65 5d 0a 20 20 20 20 7b 0a 20 20 20 20  name].    {.    
9110: 20 20 67 65 74 20 7b 20 72 65 74 75 72 6e 20 47    get { return G
9120: 65 74 56 61 6c 75 65 28 47 65 74 4f 72 64 69 6e  etValue(GetOrdin
9130: 61 6c 28 6e 61 6d 65 29 29 3b 20 7d 0a 20 20 20  al(name)); }.   
9140: 20 7d 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d   }..    /// <sum
9150: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 49 6e  mary>.    /// In
9160: 64 65 78 65 72 20 74 6f 20 72 65 74 72 69 65 76  dexer to retriev
9170: 65 20 64 61 74 61 20 66 72 6f 6d 20 61 20 63 6f  e data from a co
9180: 6c 75 6d 6e 20 67 69 76 65 6e 20 69 74 73 20 69  lumn given its i
9190: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
91a0: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  ry>.    /// <par
91b0: 61 6d 20 6e 61 6d 65 3d 22 69 22 3e 54 68 65 20  am name="i">The 
91c0: 69 6e 64 65 78 20 6f 66 20 74 68 65 20 63 6f 6c  index of the col
91d0: 75 6d 6e 20 74 6f 20 72 65 74 72 69 65 76 65 3c  umn to retrieve<
91e0: 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f 2f 2f 20  /param>.    /// 
91f0: 3c 72 65 74 75 72 6e 73 3e 54 68 65 20 76 61 6c  <returns>The val
9200: 75 65 20 63 6f 6e 74 61 69 6e 65 64 20 69 6e 20  ue contained in 
9210: 74 68 65 20 63 6f 6c 75 6d 6e 3c 2f 72 65 74 75  the column</retu
9220: 72 6e 73 3e 0a 20 20 20 20 70 75 62 6c 69 63 20  rns>.    public 
9230: 6f 76 65 72 72 69 64 65 20 6f 62 6a 65 63 74 20  override object 
9240: 74 68 69 73 5b 69 6e 74 20 69 5d 0a 20 20 20 20  this[int i].    
9250: 7b 0a 20 20 20 20 20 20 67 65 74 20 7b 20 72 65  {.      get { re
9260: 74 75 72 6e 20 47 65 74 56 61 6c 75 65 28 69 29  turn GetValue(i)
9270: 3b 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70  ; }.    }..    p
9280: 72 69 76 61 74 65 20 76 6f 69 64 20 4c 6f 61 64  rivate void Load
9290: 4b 65 79 49 6e 66 6f 28 29 0a 20 20 20 20 7b 0a  KeyInfo().    {.
92a0: 20 20 20 20 20 20 69 66 20 28 5f 6b 65 79 49 6e        if (_keyIn
92b0: 66 6f 20 21 3d 20 6e 75 6c 6c 29 0a 20 20 20 20  fo != null).    
92c0: 20 20 20 20 5f 6b 65 79 49 6e 66 6f 2e 44 69 73      _keyInfo.Dis
92d0: 70 6f 73 65 28 29 3b 0a 0a 20 20 20 20 20 20 5f  pose();..      _
92e0: 6b 65 79 49 6e 66 6f 20 3d 20 6e 65 77 20 53 51  keyInfo = new SQ
92f0: 4c 69 74 65 4b 65 79 52 65 61 64 65 72 28 5f 63  LiteKeyReader(_c
9300: 6f 6d 6d 61 6e 64 2e 43 6f 6e 6e 65 63 74 69 6f  ommand.Connectio
9310: 6e 2c 20 74 68 69 73 2c 20 5f 61 63 74 69 76 65  n, this, _active
9320: 53 74 61 74 65 6d 65 6e 74 29 3b 0a 20 20 20 20  Statement);.    
9330: 7d 0a 20 20 7d 0a 7d 0a                          }.  }.}.