System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 87e6b58562d3deec1f9ae4aa97931eddd541a478:


0000: ef bb bf 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .../************
0010: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0020: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0030: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0d 0a 20 2a  ************.. *
0040: 20 41 44 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74   ADO.NET 2.0 Dat
0050: 61 20 50 72 6f 76 69 64 65 72 20 66 6f 72 20 53  a Provider for S
0060: 51 4c 69 74 65 20 56 65 72 73 69 6f 6e 20 33 2e  QLite Version 3.
0070: 58 0d 0a 20 2a 20 57 72 69 74 74 65 6e 20 62 79  X.. * Written by
0080: 20 52 6f 62 65 72 74 20 53 69 6d 70 73 6f 6e 20   Robert Simpson 
0090: 28 72 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73  (robert@blackcas
00a0: 74 6c 65 73 6f 66 74 2e 63 6f 6d 29 0d 0a 20 2a  tlesoft.com).. *
00b0: 20 0d 0a 20 2a 20 52 65 6c 65 61 73 65 64 20 74   .. * Released t
00c0: 6f 20 74 68 65 20 70 75 62 6c 69 63 20 64 6f 6d  o the public dom
00d0: 61 69 6e 2c 20 75 73 65 20 61 74 20 79 6f 75 72  ain, use at your
00e0: 20 6f 77 6e 20 72 69 73 6b 21 0d 0a 20 2a 2a 2a   own risk!.. ***
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 2a 2a 2a 2a 2f 0d 0a 0d 0a 6e 61 6d 65 73 70  *****/....namesp
0130: 61 63 65 20 53 79 73 74 65 6d 2e 44 61 74 61 2e  ace System.Data.
0140: 53 51 4c 69 74 65 0d 0a 7b 0d 0a 20 20 75 73 69  SQLite..{..  usi
0150: 6e 67 20 53 79 73 74 65 6d 3b 0d 0a 0d 0a 20 20  ng System;....  
0160: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
0170: 20 2f 2f 2f 20 54 68 69 73 20 69 6e 74 65 72 6e   /// This intern
0180: 61 6c 20 63 6c 61 73 73 20 70 72 6f 76 69 64 65  al class provide
0190: 73 20 74 68 65 20 66 6f 75 6e 64 61 74 69 6f 6e  s the foundation
01a0: 20 6f 66 20 53 51 4c 69 74 65 20 73 75 70 70 6f   of SQLite suppo
01b0: 72 74 2e 20 20 49 74 20 64 65 66 69 6e 65 73 20  rt.  It defines 
01c0: 61 6c 6c 20 74 68 65 20 61 62 73 74 72 61 63 74  all the abstract
01d0: 20 6d 65 6d 62 65 72 73 20 6e 65 65 64 65 64 20   members needed 
01e0: 74 6f 20 69 6d 70 6c 65 6d 65 6e 74 0d 0a 20 20  to implement..  
01f0: 2f 2f 2f 20 61 20 53 51 4c 69 74 65 20 64 61 74  /// a SQLite dat
0200: 61 20 70 72 6f 76 69 64 65 72 2c 20 61 6e 64 20  a provider, and 
0210: 69 6e 68 65 72 69 74 73 20 66 72 6f 6d 20 53 51  inherits from SQ
0220: 4c 69 74 65 43 6f 6e 76 65 72 74 20 77 68 69 63  LiteConvert whic
0230: 68 20 61 6c 6c 6f 77 73 20 66 6f 72 20 73 69 6d  h allows for sim
0240: 70 6c 65 20 74 72 61 6e 73 6c 61 74 69 6f 6e 73  ple translations
0250: 20 6f 66 20 73 74 72 69 6e 67 20 74 6f 20 61 6e   of string to an
0260: 64 20 66 72 6f 6d 20 53 51 4c 69 74 65 2e 0d 0a  d from SQLite...
0270: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
0280: 0d 0a 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73  ..  internal abs
0290: 74 72 61 63 74 20 63 6c 61 73 73 20 53 51 4c 69  tract class SQLi
02a0: 74 65 42 61 73 65 20 3a 20 53 51 4c 69 74 65 43  teBase : SQLiteC
02b0: 6f 6e 76 65 72 74 2c 20 49 44 69 73 70 6f 73 61  onvert, IDisposa
02c0: 62 6c 65 0d 0a 20 20 7b 0d 0a 20 20 20 20 69 6e  ble..  {..    in
02d0: 74 65 72 6e 61 6c 20 53 51 4c 69 74 65 42 61 73  ternal SQLiteBas
02e0: 65 28 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d  e(SQLiteDateForm
02f0: 61 74 73 20 66 6d 74 29 0d 0a 20 20 20 20 20 20  ats fmt)..      
0300: 3a 20 62 61 73 65 28 66 6d 74 29 20 7b 20 7d 0d  : base(fmt) { }.
0310: 0a 0d 0a 20 20 20 20 73 74 61 74 69 63 20 69 6e  ...    static in
0320: 74 65 72 6e 61 6c 20 6f 62 6a 65 63 74 20 5f 6c  ternal object _l
0330: 6f 63 6b 20 3d 20 6e 65 77 20 6f 62 6a 65 63 74  ock = new object
0340: 28 29 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c  ();....    /// <
0350: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
0360: 2f 20 52 65 74 75 72 6e 73 20 61 20 73 74 72 69  / Returns a stri
0370: 6e 67 20 72 65 70 72 65 73 65 6e 74 69 6e 67 20  ng representing 
0380: 74 68 65 20 61 63 74 69 76 65 20 76 65 72 73 69  the active versi
0390: 6f 6e 20 6f 66 20 53 51 4c 69 74 65 0d 0a 20 20  on of SQLite..  
03a0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
03b0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61  ..    internal a
03c0: 62 73 74 72 61 63 74 20 73 74 72 69 6e 67 20 56  bstract string V
03d0: 65 72 73 69 6f 6e 20 7b 20 67 65 74 3b 20 7d 0d  ersion { get; }.
03e0: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
03f0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 52 65 74 75  y>..    /// Retu
0400: 72 6e 73 20 74 68 65 20 72 6f 77 69 64 20 6f 66  rns the rowid of
0410: 20 74 68 65 20 6d 6f 73 74 20 72 65 63 65 6e 74   the most recent
0420: 20 73 75 63 63 65 73 73 66 75 6c 20 49 4e 53 45   successful INSE
0430: 52 54 20 69 6e 74 6f 20 74 68 65 20 64 61 74 61  RT into the data
0440: 62 61 73 65 20 66 72 6f 6d 20 74 68 69 73 20 63  base from this c
0450: 6f 6e 6e 65 63 74 69 6f 6e 2e 0d 0a 20 20 20 20  onnection...    
0460: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
0470: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73      internal abs
0480: 74 72 61 63 74 20 6c 6f 6e 67 20 4c 61 73 74 49  tract long LastI
0490: 6e 73 65 72 74 52 6f 77 49 64 20 7b 20 67 65 74  nsertRowId { get
04a0: 3b 20 7d 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  ; }..    /// <su
04b0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
04c0: 52 65 74 75 72 6e 73 20 74 68 65 20 6e 75 6d 62  Returns the numb
04d0: 65 72 20 6f 66 20 63 68 61 6e 67 65 73 20 74 68  er of changes th
04e0: 65 20 6c 61 73 74 20 65 78 65 63 75 74 69 6e 67  e last executing
04f0: 20 69 6e 73 65 72 74 2f 75 70 64 61 74 65 20 63   insert/update c
0500: 61 75 73 65 64 2e 0d 0a 20 20 20 20 2f 2f 2f 20  aused...    /// 
0510: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
0520: 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63  internal abstrac
0530: 74 20 69 6e 74 20 43 68 61 6e 67 65 73 20 7b 20  t int Changes { 
0540: 67 65 74 3b 20 7d 0d 0a 20 20 20 20 2f 2f 2f 20  get; }..    /// 
0550: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
0560: 2f 2f 20 53 68 75 74 64 6f 77 6e 20 74 68 65 20  // Shutdown the 
0570: 53 51 4c 69 74 65 20 65 6e 67 69 6e 65 20 73 6f  SQLite engine so
0580: 20 74 68 61 74 20 69 74 20 63 61 6e 20 62 65 20   that it can be 
0590: 72 65 73 74 61 72 74 65 64 20 77 69 74 68 20 64  restarted with d
05a0: 69 66 66 65 72 65 6e 74 20 63 6f 6e 66 69 67 20  ifferent config 
05b0: 6f 70 74 69 6f 6e 73 2e 0d 0a 20 20 20 20 2f 2f  options...    //
05c0: 2f 20 57 65 20 64 65 70 65 6e 64 20 6f 6e 20 61  / We depend on a
05d0: 75 74 6f 20 69 6e 69 74 69 61 6c 69 7a 61 74 69  uto initializati
05e0: 6f 6e 20 74 6f 20 72 65 63 6f 76 65 72 2e 0d 0a  on to recover...
05f0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
0600: 79 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  y>..    internal
0610: 20 61 62 73 74 72 61 63 74 20 69 6e 74 20 53 68   abstract int Sh
0620: 75 74 64 6f 77 6e 28 29 3b 0d 0a 20 20 20 20 2f  utdown();..    /
0630: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
0640: 20 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20 6e 6f    /// Returns no
0650: 6e 2d 7a 65 72 6f 20 69 66 20 61 20 64 61 74 61  n-zero if a data
0660: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20  base connection 
0670: 69 73 20 6f 70 65 6e 2e 0d 0a 20 20 20 20 2f 2f  is open...    //
0680: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
0690: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c    /// <returns><
06a0: 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69  /returns>..    i
06b0: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
06c0: 20 62 6f 6f 6c 20 49 73 4f 70 65 6e 28 29 3b 0d   bool IsOpen();.
06d0: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
06e0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 4f 70 65 6e  y>..    /// Open
06f0: 73 20 61 20 64 61 74 61 62 61 73 65 2e 0d 0a 20  s a database... 
0700: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
0710: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 6d 61  >..    /// <rema
0720: 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20 49 6d  rks>..    /// Im
0730: 70 6c 65 6d 65 6e 74 65 72 73 20 73 68 6f 75 6c  plementers shoul
0740: 64 20 63 61 6c 6c 20 53 51 4c 69 74 65 46 75 6e  d call SQLiteFun
0750: 63 74 69 6f 6e 2e 42 69 6e 64 46 75 6e 63 74 69  ction.BindFuncti
0760: 6f 6e 73 28 29 20 61 6e 64 20 73 61 76 65 20 74  ons() and save t
0770: 68 65 20 61 72 72 61 79 20 61 66 74 65 72 20 6f  he array after o
0780: 70 65 6e 69 6e 67 20 61 20 63 6f 6e 6e 65 63 74  pening a connect
0790: 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20 74 6f 20  ion..    /// to 
07a0: 62 69 6e 64 20 61 6c 6c 20 61 74 74 72 69 62 75  bind all attribu
07b0: 74 65 64 20 75 73 65 72 2d 64 65 66 69 6e 65 64  ted user-defined
07c0: 20 66 75 6e 63 74 69 6f 6e 73 20 61 6e 64 20 63   functions and c
07d0: 6f 6c 6c 61 74 69 6e 67 20 73 65 71 75 65 6e 63  ollating sequenc
07e0: 65 73 20 74 6f 20 74 68 65 20 6e 65 77 20 63 6f  es to the new co
07f0: 6e 6e 65 63 74 69 6f 6e 2e 0d 0a 20 20 20 20 2f  nnection...    /
0800: 2f 2f 20 3c 2f 72 65 6d 61 72 6b 73 3e 0d 0a 20  // </remarks>.. 
0810: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
0820: 6d 65 3d 22 73 74 72 46 69 6c 65 6e 61 6d 65 22  me="strFilename"
0830: 3e 54 68 65 20 66 69 6c 65 6e 61 6d 65 20 6f 66  >The filename of
0840: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 74 6f   the database to
0850: 20 6f 70 65 6e 2e 20 20 53 51 4c 69 74 65 20 61   open.  SQLite a
0860: 75 74 6f 6d 61 74 69 63 61 6c 6c 79 20 63 72 65  utomatically cre
0870: 61 74 65 73 20 69 74 20 69 66 20 69 74 20 64 6f  ates it if it do
0880: 65 73 6e 27 74 20 65 78 69 73 74 2e 3c 2f 70 61  esn't exist.</pa
0890: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ram>..    /// <p
08a0: 61 72 61 6d 20 6e 61 6d 65 3d 22 66 6c 61 67 73  aram name="flags
08b0: 22 3e 54 68 65 20 6f 70 65 6e 20 66 6c 61 67 73  ">The open flags
08c0: 20 74 6f 20 75 73 65 20 77 68 65 6e 20 63 72 65   to use when cre
08d0: 61 74 69 6e 67 20 74 68 65 20 63 6f 6e 6e 65 63  ating the connec
08e0: 74 69 6f 6e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  tion</param>..  
08f0: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
0900: 65 3d 22 6d 61 78 50 6f 6f 6c 53 69 7a 65 22 3e  e="maxPoolSize">
0910: 54 68 65 20 6d 61 78 69 6d 75 6d 20 73 69 7a 65  The maximum size
0920: 20 6f 66 20 74 68 65 20 70 6f 6f 6c 20 66 6f 72   of the pool for
0930: 20 74 68 65 20 67 69 76 65 6e 20 66 69 6c 65 6e   the given filen
0940: 61 6d 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  ame</param>..   
0950: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
0960: 3d 22 75 73 65 50 6f 6f 6c 22 3e 49 66 20 74 72  ="usePool">If tr
0970: 75 65 2c 20 74 68 65 20 63 6f 6e 6e 65 63 74 69  ue, the connecti
0980: 6f 6e 20 63 61 6e 20 62 65 20 70 75 6c 6c 65 64  on can be pulled
0990: 20 66 72 6f 6d 20 74 68 65 20 63 6f 6e 6e 65 63   from the connec
09a0: 74 69 6f 6e 20 70 6f 6f 6c 3c 2f 70 61 72 61 6d  tion pool</param
09b0: 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  >..    internal 
09c0: 61 62 73 74 72 61 63 74 20 76 6f 69 64 20 4f 70  abstract void Op
09d0: 65 6e 28 73 74 72 69 6e 67 20 73 74 72 46 69 6c  en(string strFil
09e0: 65 6e 61 6d 65 2c 20 53 51 4c 69 74 65 4f 70 65  ename, SQLiteOpe
09f0: 6e 46 6c 61 67 73 45 6e 75 6d 20 66 6c 61 67 73  nFlagsEnum flags
0a00: 2c 20 69 6e 74 20 6d 61 78 50 6f 6f 6c 53 69 7a  , int maxPoolSiz
0a10: 65 2c 20 62 6f 6f 6c 20 75 73 65 50 6f 6f 6c 29  e, bool usePool)
0a20: 3b 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ;..    /// <summ
0a30: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43 6c  ary>..    /// Cl
0a40: 6f 73 65 73 20 74 68 65 20 63 75 72 72 65 6e 74  oses the current
0a50: 6c 79 2d 6f 70 65 6e 20 64 61 74 61 62 61 73 65  ly-open database
0a60: 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ...    /// </sum
0a70: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  mary>..    /// <
0a80: 72 65 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 2f 2f  remarks>..    //
0a90: 2f 20 41 66 74 65 72 20 74 68 65 20 64 61 74 61  / After the data
0aa0: 62 61 73 65 20 68 61 73 20 62 65 65 6e 20 63 6c  base has been cl
0ab0: 6f 73 65 64 20 69 6d 70 6c 65 6d 65 74 65 72 73  osed implemeters
0ac0: 20 73 68 6f 75 6c 64 20 63 61 6c 6c 20 53 51 4c   should call SQL
0ad0: 69 74 65 46 75 6e 63 74 69 6f 6e 2e 55 6e 62 69  iteFunction.Unbi
0ae0: 6e 64 46 75 6e 63 74 69 6f 6e 73 28 29 20 74 6f  ndFunctions() to
0af0: 20 64 65 61 6c 6c 6f 63 61 74 65 20 61 6c 6c 20   deallocate all 
0b00: 69 6e 74 65 72 6f 70 20 61 6c 6c 6f 63 61 74 65  interop allocate
0b10: 64 0d 0a 20 20 20 20 2f 2f 2f 20 6d 65 6d 6f 72  d..    /// memor
0b20: 79 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74  y associated wit
0b30: 68 20 74 68 65 20 75 73 65 72 2d 64 65 66 69 6e  h the user-defin
0b40: 65 64 20 66 75 6e 63 74 69 6f 6e 73 20 61 6e 64  ed functions and
0b50: 20 63 6f 6c 6c 61 74 69 6e 67 20 73 65 71 75 65   collating seque
0b60: 6e 63 65 73 20 74 69 65 64 20 74 6f 20 74 68 65  nces tied to the
0b70: 20 63 6c 6f 73 65 64 20 63 6f 6e 6e 65 63 74 69   closed connecti
0b80: 6f 6e 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72  on...    /// </r
0b90: 65 6d 61 72 6b 73 3e 0d 0a 20 20 20 20 69 6e 74  emarks>..    int
0ba0: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 76  ernal abstract v
0bb0: 6f 69 64 20 43 6c 6f 73 65 28 29 3b 0d 0a 20 20  oid Close();..  
0bc0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
0bd0: 0a 20 20 20 20 2f 2f 2f 20 53 65 74 73 20 74 68  .    /// Sets th
0be0: 65 20 62 75 73 79 20 74 69 6d 65 6f 75 74 20 6f  e busy timeout o
0bf0: 6e 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  n the connection
0c00: 2e 20 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64  .  SQLiteCommand
0c10: 20 77 69 6c 6c 20 63 61 6c 6c 20 74 68 69 73 20   will call this 
0c20: 62 65 66 6f 72 65 20 65 78 65 63 75 74 69 6e 67  before executing
0c30: 20 61 6e 79 20 63 6f 6d 6d 61 6e 64 2e 0d 0a 20   any command... 
0c40: 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79     /// </summary
0c50: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
0c60: 6d 20 6e 61 6d 65 3d 22 6e 54 69 6d 65 6f 75 74  m name="nTimeout
0c70: 4d 53 22 3e 54 68 65 20 6e 75 6d 62 65 72 20 6f  MS">The number o
0c80: 66 20 6d 69 6c 6c 69 73 65 63 6f 6e 64 73 20 74  f milliseconds t
0c90: 6f 20 77 61 69 74 20 62 65 66 6f 72 65 20 72 65  o wait before re
0ca0: 74 75 72 6e 69 6e 67 20 53 51 4c 49 54 45 5f 42  turning SQLITE_B
0cb0: 55 53 59 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  USY</param>..   
0cc0: 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61   internal abstra
0cd0: 63 74 20 76 6f 69 64 20 53 65 74 54 69 6d 65 6f  ct void SetTimeo
0ce0: 75 74 28 69 6e 74 20 6e 54 69 6d 65 6f 75 74 4d  ut(int nTimeoutM
0cf0: 53 29 3b 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  S);..    /// <su
0d00: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
0d10: 52 65 74 75 72 6e 73 20 74 68 65 20 74 65 78 74  Returns the text
0d20: 20 6f 66 20 74 68 65 20 6c 61 73 74 20 65 72 72   of the last err
0d30: 6f 72 20 69 73 73 75 65 64 20 62 79 20 53 51 4c  or issued by SQL
0d40: 69 74 65 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ite..    /// </s
0d50: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
0d60: 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72 65 74 75   <returns></retu
0d70: 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e  rns>..    intern
0d80: 61 6c 20 61 62 73 74 72 61 63 74 20 73 74 72 69  al abstract stri
0d90: 6e 67 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72  ng SQLiteLastErr
0da0: 6f 72 28 29 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f  or();....    ///
0db0: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
0dc0: 2f 2f 2f 20 57 68 65 6e 20 70 6f 6f 6c 69 6e 67  /// When pooling
0dd0: 20 69 73 20 65 6e 61 62 6c 65 64 2c 20 66 6f 72   is enabled, for
0de0: 63 65 20 74 68 69 73 20 63 6f 6e 6e 65 63 74 69  ce this connecti
0df0: 6f 6e 20 74 6f 20 62 65 20 64 69 73 70 6f 73 65  on to be dispose
0e00: 64 20 72 61 74 68 65 72 20 74 68 61 6e 20 72 65  d rather than re
0e10: 74 75 72 6e 65 64 20 74 6f 20 74 68 65 20 70 6f  turned to the po
0e20: 6f 6c 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  ol..    /// </su
0e30: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 69 6e 74 65  mmary>..    inte
0e40: 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 76 6f  rnal abstract vo
0e50: 69 64 20 43 6c 65 61 72 50 6f 6f 6c 28 29 3b 0d  id ClearPool();.
0e60: 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ...    /// <summ
0e70: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 50 72  ary>..    /// Pr
0e80: 65 70 61 72 65 73 20 61 20 53 51 4c 20 73 74 61  epares a SQL sta
0e90: 74 65 6d 65 6e 74 20 66 6f 72 20 65 78 65 63 75  tement for execu
0ea0: 74 69 6f 6e 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  tion...    /// <
0eb0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  /summary>..    /
0ec0: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
0ed0: 63 6e 6e 22 3e 54 68 65 20 73 6f 75 72 63 65 20  cnn">The source 
0ee0: 63 6f 6e 6e 65 63 74 69 6f 6e 20 70 72 65 70 61  connection prepa
0ef0: 72 69 6e 67 20 74 68 65 20 63 6f 6d 6d 61 6e 64  ring the command
0f00: 2e 20 20 43 61 6e 20 62 65 20 6e 75 6c 6c 20 66  .  Can be null f
0f10: 6f 72 20 61 6e 79 20 63 61 6c 6c 65 72 20 65 78  or any caller ex
0f20: 63 65 70 74 20 4c 49 4e 51 3c 2f 70 61 72 61 6d  cept LINQ</param
0f30: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
0f40: 6d 20 6e 61 6d 65 3d 22 73 74 72 53 71 6c 22 3e  m name="strSql">
0f50: 54 68 65 20 53 51 4c 20 63 6f 6d 6d 61 6e 64 20  The SQL command 
0f60: 74 65 78 74 20 74 6f 20 70 72 65 70 61 72 65 3c  text to prepare<
0f70: 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f  /param>..    ///
0f80: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 70 72   <param name="pr
0f90: 65 76 69 6f 75 73 22 3e 54 68 65 20 70 72 65 76  evious">The prev
0fa0: 69 6f 75 73 20 73 74 61 74 65 6d 65 6e 74 20 69  ious statement i
0fb0: 6e 20 61 20 6d 75 6c 74 69 2d 73 74 61 74 65 6d  n a multi-statem
0fc0: 65 6e 74 20 63 6f 6d 6d 61 6e 64 2c 20 6f 72 20  ent command, or 
0fd0: 6e 75 6c 6c 20 69 66 20 6e 6f 20 70 72 65 76 69  null if no previ
0fe0: 6f 75 73 20 73 74 61 74 65 6d 65 6e 74 20 65 78  ous statement ex
0ff0: 69 73 74 73 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  ists</param>..  
1000: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
1010: 65 3d 22 74 69 6d 65 6f 75 74 4d 53 22 3e 54 68  e="timeoutMS">Th
1020: 65 20 74 69 6d 65 6f 75 74 20 74 6f 20 77 61 69  e timeout to wai
1030: 74 20 62 65 66 6f 72 65 20 61 62 6f 72 74 69 6e  t before abortin
1040: 67 20 74 68 65 20 70 72 65 70 61 72 65 3c 2f 70  g the prepare</p
1050: 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  aram>..    /// <
1060: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 73 74 72 52  param name="strR
1070: 65 6d 61 69 6e 22 3e 54 68 65 20 72 65 6d 61 69  emain">The remai
1080: 6e 64 65 72 20 6f 66 20 74 68 65 20 73 74 61 74  nder of the stat
1090: 65 6d 65 6e 74 20 74 68 61 74 20 77 61 73 20 6e  ement that was n
10a0: 6f 74 20 70 72 6f 63 65 73 73 65 64 2e 20 20 45  ot processed.  E
10b0: 61 63 68 20 63 61 6c 6c 20 74 6f 20 70 72 65 70  ach call to prep
10c0: 61 72 65 20 70 61 72 73 65 73 20 74 68 65 0d 0a  are parses the..
10d0: 20 20 20 20 2f 2f 2f 20 53 51 4c 20 75 70 20 74      /// SQL up t
10e0: 6f 20 74 6f 20 65 69 74 68 65 72 20 74 68 65 20  o to either the 
10f0: 65 6e 64 20 6f 66 20 74 68 65 20 74 65 78 74 20  end of the text 
1100: 6f 72 20 74 6f 20 74 68 65 20 66 69 72 73 74 20  or to the first 
1110: 73 65 6d 69 2d 63 6f 6c 6f 6e 20 64 65 6c 69 6d  semi-colon delim
1120: 69 74 65 72 2e 20 20 54 68 65 20 72 65 6d 61 69  iter.  The remai
1130: 6e 69 6e 67 20 74 65 78 74 20 69 73 20 72 65 74  ning text is ret
1140: 75 72 6e 65 64 0d 0a 20 20 20 20 2f 2f 2f 20 68  urned..    /// h
1150: 65 72 65 20 66 6f 72 20 61 20 73 75 62 73 65 71  ere for a subseq
1160: 75 65 6e 74 20 63 61 6c 6c 20 74 6f 20 50 72 65  uent call to Pre
1170: 70 61 72 65 28 29 20 75 6e 74 69 6c 20 61 6c 6c  pare() until all
1180: 20 74 68 65 20 74 65 78 74 20 68 61 73 20 62 65   the text has be
1190: 65 6e 20 70 72 6f 63 65 73 73 65 64 2e 3c 2f 70  en processed.</p
11a0: 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  aram>..    /// <
11b0: 72 65 74 75 72 6e 73 3e 52 65 74 75 72 6e 73 20  returns>Returns 
11c0: 61 6e 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 53  an initialized S
11d0: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 2e 3c  QLiteStatement.<
11e0: 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69  /returns>..    i
11f0: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
1200: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
1210: 20 50 72 65 70 61 72 65 28 53 51 4c 69 74 65 43   Prepare(SQLiteC
1220: 6f 6e 6e 65 63 74 69 6f 6e 20 63 6e 6e 2c 20 73  onnection cnn, s
1230: 74 72 69 6e 67 20 73 74 72 53 71 6c 2c 20 53 51  tring strSql, SQ
1240: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 70 72  LiteStatement pr
1250: 65 76 69 6f 75 73 2c 20 75 69 6e 74 20 74 69 6d  evious, uint tim
1260: 65 6f 75 74 4d 53 2c 20 6f 75 74 20 73 74 72 69  eoutMS, out stri
1270: 6e 67 20 73 74 72 52 65 6d 61 69 6e 29 3b 0d 0a  ng strRemain);..
1280: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
1290: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 53 74 65 70 73  >..    /// Steps
12a0: 20 74 68 72 6f 75 67 68 20 61 20 70 72 65 70 61   through a prepa
12b0: 72 65 64 20 73 74 61 74 65 6d 65 6e 74 2e 0d 0a  red statement...
12c0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
12d0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  y>..    /// <par
12e0: 61 6d 20 6e 61 6d 65 3d 22 73 74 6d 74 22 3e 54  am name="stmt">T
12f0: 68 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65  he SQLiteStateme
1300: 6e 74 20 74 6f 20 73 74 65 70 20 74 68 72 6f 75  nt to step throu
1310: 67 68 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  gh</param>..    
1320: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 72 75  /// <returns>Tru
1330: 65 20 69 66 20 61 20 72 6f 77 20 77 61 73 20 72  e if a row was r
1340: 65 74 75 72 6e 65 64 2c 20 46 61 6c 73 65 20 69  eturned, False i
1350: 66 20 6e 6f 74 2e 3c 2f 72 65 74 75 72 6e 73 3e  f not.</returns>
1360: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61  ..    internal a
1370: 62 73 74 72 61 63 74 20 62 6f 6f 6c 20 53 74 65  bstract bool Ste
1380: 70 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  p(SQLiteStatemen
1390: 74 20 73 74 6d 74 29 3b 0d 0a 20 20 20 20 2f 2f  t stmt);..    //
13a0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
13b0: 20 2f 2f 2f 20 52 65 73 65 74 73 20 61 20 70 72   /// Resets a pr
13c0: 65 70 61 72 65 64 20 73 74 61 74 65 6d 65 6e 74  epared statement
13d0: 20 73 6f 20 69 74 20 63 61 6e 20 62 65 20 65 78   so it can be ex
13e0: 65 63 75 74 65 64 20 61 67 61 69 6e 2e 20 20 49  ecuted again.  I
13f0: 66 20 74 68 65 20 65 72 72 6f 72 20 72 65 74 75  f the error retu
1400: 72 6e 65 64 20 69 73 20 53 51 4c 49 54 45 5f 53  rned is SQLITE_S
1410: 43 48 45 4d 41 2c 20 0d 0a 20 20 20 20 2f 2f 2f  CHEMA, ..    ///
1420: 20 74 72 61 6e 73 70 61 72 65 6e 74 6c 79 20 61   transparently a
1430: 74 74 65 6d 70 74 20 74 6f 20 72 65 62 75 69 6c  ttempt to rebuil
1440: 64 20 74 68 65 20 53 51 4c 20 73 74 61 74 65 6d  d the SQL statem
1450: 65 6e 74 20 61 6e 64 20 74 68 72 6f 77 20 61 6e  ent and throw an
1460: 20 65 72 72 6f 72 20 69 66 20 74 68 61 74 20 77   error if that w
1470: 61 73 20 6e 6f 74 20 70 6f 73 73 69 62 6c 65 2e  as not possible.
1480: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
1490: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ary>..    /// <p
14a0: 61 72 61 6d 20 6e 61 6d 65 3d 22 73 74 6d 74 22  aram name="stmt"
14b0: 3e 54 68 65 20 73 74 61 74 65 6d 65 6e 74 20 74  >The statement t
14c0: 6f 20 72 65 73 65 74 3c 2f 70 61 72 61 6d 3e 0d  o reset</param>.
14d0: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
14e0: 73 3e 52 65 74 75 72 6e 73 20 2d 31 20 69 66 20  s>Returns -1 if 
14f0: 74 68 65 20 73 63 68 65 6d 61 20 63 68 61 6e 67  the schema chang
1500: 65 64 20 77 68 69 6c 65 20 72 65 73 65 74 74 69  ed while resetti
1510: 6e 67 2c 20 30 20 69 66 20 74 68 65 20 72 65 73  ng, 0 if the res
1520: 65 74 20 77 61 73 20 73 75 63 65 73 73 66 75 6c  et was sucessful
1530: 20 6f 72 20 36 20 28 53 51 4c 49 54 45 5f 4c 4f   or 6 (SQLITE_LO
1540: 43 4b 45 44 29 20 69 66 20 74 68 65 20 72 65 73  CKED) if the res
1550: 65 74 20 66 61 69 6c 65 64 20 64 75 65 20 74 6f  et failed due to
1560: 20 61 20 6c 6f 63 6b 3c 2f 72 65 74 75 72 6e 73   a lock</returns
1570: 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  >..    internal 
1580: 61 62 73 74 72 61 63 74 20 69 6e 74 20 52 65 73  abstract int Res
1590: 65 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  et(SQLiteStateme
15a0: 6e 74 20 73 74 6d 74 29 3b 0d 0a 20 20 20 20 69  nt stmt);..    i
15b0: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
15c0: 20 76 6f 69 64 20 43 61 6e 63 65 6c 28 29 3b 0d   void Cancel();.
15d0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
15e0: 61 62 73 74 72 61 63 74 20 76 6f 69 64 20 42 69  abstract void Bi
15f0: 6e 64 5f 44 6f 75 62 6c 65 28 53 51 4c 69 74 65  nd_Double(SQLite
1600: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
1610: 69 6e 74 20 69 6e 64 65 78 2c 20 64 6f 75 62 6c  int index, doubl
1620: 65 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 69  e value);..    i
1630: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
1640: 20 76 6f 69 64 20 42 69 6e 64 5f 49 6e 74 33 32   void Bind_Int32
1650: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
1660: 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78   stmt, int index
1670: 2c 20 49 6e 74 33 32 20 76 61 6c 75 65 29 3b 0d  , Int32 value);.
1680: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62  .    internal ab
1690: 73 74 72 61 63 74 20 76 6f 69 64 20 42 69 6e 64  stract void Bind
16a0: 5f 49 6e 74 36 34 28 53 51 4c 69 74 65 53 74 61  _Int64(SQLiteSta
16b0: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
16c0: 20 69 6e 64 65 78 2c 20 49 6e 74 36 34 20 76 61   index, Int64 va
16d0: 6c 75 65 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72  lue);..    inter
16e0: 6e 61 6c 20 61 62 73 74 72 61 63 74 20 76 6f 69  nal abstract voi
16f0: 64 20 42 69 6e 64 5f 54 65 78 74 28 53 51 4c 69  d Bind_Text(SQLi
1700: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
1710: 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 73 74 72  , int index, str
1720: 69 6e 67 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20  ing value);..   
1730: 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61   internal abstra
1740: 63 74 20 76 6f 69 64 20 42 69 6e 64 5f 42 6c 6f  ct void Bind_Blo
1750: 62 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  b(SQLiteStatemen
1760: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
1770: 78 2c 20 62 79 74 65 5b 5d 20 62 6c 6f 62 44 61  x, byte[] blobDa
1780: 74 61 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e  ta);..    intern
1790: 61 6c 20 61 62 73 74 72 61 63 74 20 76 6f 69 64  al abstract void
17a0: 20 42 69 6e 64 5f 44 61 74 65 54 69 6d 65 28 53   Bind_DateTime(S
17b0: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73  QLiteStatement s
17c0: 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20  tmt, int index, 
17d0: 44 61 74 65 54 69 6d 65 20 64 74 29 3b 0d 0a 20  DateTime dt);.. 
17e0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74     internal abst
17f0: 72 61 63 74 20 76 6f 69 64 20 42 69 6e 64 5f 4e  ract void Bind_N
1800: 75 6c 6c 28 53 51 4c 69 74 65 53 74 61 74 65 6d  ull(SQLiteStatem
1810: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
1820: 64 65 78 29 3b 0d 0a 0d 0a 20 20 20 20 69 6e 74  dex);....    int
1830: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 69  ernal abstract i
1840: 6e 74 20 42 69 6e 64 5f 50 61 72 61 6d 43 6f 75  nt Bind_ParamCou
1850: 6e 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  nt(SQLiteStateme
1860: 6e 74 20 73 74 6d 74 29 3b 0d 0a 20 20 20 20 69  nt stmt);..    i
1870: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
1880: 20 73 74 72 69 6e 67 20 42 69 6e 64 5f 50 61 72   string Bind_Par
1890: 61 6d 4e 61 6d 65 28 53 51 4c 69 74 65 53 74 61  amName(SQLiteSta
18a0: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
18b0: 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20 69 6e   index);..    in
18c0: 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20  ternal abstract 
18d0: 69 6e 74 20 42 69 6e 64 5f 50 61 72 61 6d 49 6e  int Bind_ParamIn
18e0: 64 65 78 28 53 51 4c 69 74 65 53 74 61 74 65 6d  dex(SQLiteStatem
18f0: 65 6e 74 20 73 74 6d 74 2c 20 73 74 72 69 6e 67  ent stmt, string
1900: 20 70 61 72 61 6d 4e 61 6d 65 29 3b 0d 0a 0d 0a   paramName);....
1910: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73      internal abs
1920: 74 72 61 63 74 20 69 6e 74 20 43 6f 6c 75 6d 6e  tract int Column
1930: 43 6f 75 6e 74 28 53 51 4c 69 74 65 53 74 61 74  Count(SQLiteStat
1940: 65 6d 65 6e 74 20 73 74 6d 74 29 3b 0d 0a 20 20  ement stmt);..  
1950: 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72    internal abstr
1960: 61 63 74 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d  act string Colum
1970: 6e 4e 61 6d 65 28 53 51 4c 69 74 65 53 74 61 74  nName(SQLiteStat
1980: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
1990: 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20 69 6e 74  index);..    int
19a0: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 54  ernal abstract T
19b0: 79 70 65 41 66 66 69 6e 69 74 79 20 43 6f 6c 75  ypeAffinity Colu
19c0: 6d 6e 41 66 66 69 6e 69 74 79 28 53 51 4c 69 74  mnAffinity(SQLit
19d0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
19e0: 20 69 6e 74 20 69 6e 64 65 78 29 3b 0d 0a 20 20   int index);..  
19f0: 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72    internal abstr
1a00: 61 63 74 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d  act string Colum
1a10: 6e 54 79 70 65 28 53 51 4c 69 74 65 53 74 61 74  nType(SQLiteStat
1a20: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
1a30: 69 6e 64 65 78 2c 20 6f 75 74 20 54 79 70 65 41  index, out TypeA
1a40: 66 66 69 6e 69 74 79 20 6e 41 66 66 69 6e 69 74  ffinity nAffinit
1a50: 79 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  y);..    interna
1a60: 6c 20 61 62 73 74 72 61 63 74 20 69 6e 74 20 43  l abstract int C
1a70: 6f 6c 75 6d 6e 49 6e 64 65 78 28 53 51 4c 69 74  olumnIndex(SQLit
1a80: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
1a90: 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e 4e 61   string columnNa
1aa0: 6d 65 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e  me);..    intern
1ab0: 61 6c 20 61 62 73 74 72 61 63 74 20 73 74 72 69  al abstract stri
1ac0: 6e 67 20 43 6f 6c 75 6d 6e 4f 72 69 67 69 6e 61  ng ColumnOrigina
1ad0: 6c 4e 61 6d 65 28 53 51 4c 69 74 65 53 74 61 74  lName(SQLiteStat
1ae0: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
1af0: 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20 69 6e 74  index);..    int
1b00: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 73  ernal abstract s
1b10: 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 44 61 74 61  tring ColumnData
1b20: 62 61 73 65 4e 61 6d 65 28 53 51 4c 69 74 65 53  baseName(SQLiteS
1b30: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
1b40: 6e 74 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20  nt index);..    
1b50: 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63  internal abstrac
1b60: 74 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 54  t string ColumnT
1b70: 61 62 6c 65 4e 61 6d 65 28 53 51 4c 69 74 65 53  ableName(SQLiteS
1b80: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
1b90: 6e 74 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20  nt index);..    
1ba0: 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63  internal abstrac
1bb0: 74 20 76 6f 69 64 20 43 6f 6c 75 6d 6e 4d 65 74  t void ColumnMet
1bc0: 61 44 61 74 61 28 73 74 72 69 6e 67 20 64 61 74  aData(string dat
1bd0: 61 42 61 73 65 2c 20 73 74 72 69 6e 67 20 74 61  aBase, string ta
1be0: 62 6c 65 2c 20 73 74 72 69 6e 67 20 63 6f 6c 75  ble, string colu
1bf0: 6d 6e 2c 20 6f 75 74 20 73 74 72 69 6e 67 20 64  mn, out string d
1c00: 61 74 61 54 79 70 65 2c 20 6f 75 74 20 73 74 72  ataType, out str
1c10: 69 6e 67 20 63 6f 6c 6c 61 74 65 53 65 71 75 65  ing collateSeque
1c20: 6e 63 65 2c 20 6f 75 74 20 62 6f 6f 6c 20 6e 6f  nce, out bool no
1c30: 74 4e 75 6c 6c 2c 20 6f 75 74 20 62 6f 6f 6c 20  tNull, out bool 
1c40: 70 72 69 6d 61 72 79 4b 65 79 2c 20 6f 75 74 20  primaryKey, out 
1c50: 62 6f 6f 6c 20 61 75 74 6f 49 6e 63 72 65 6d 65  bool autoIncreme
1c60: 6e 74 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e  nt);..    intern
1c70: 61 6c 20 61 62 73 74 72 61 63 74 20 76 6f 69 64  al abstract void
1c80: 20 47 65 74 49 6e 64 65 78 43 6f 6c 75 6d 6e 45   GetIndexColumnE
1c90: 78 74 65 6e 64 65 64 49 6e 66 6f 28 73 74 72 69  xtendedInfo(stri
1ca0: 6e 67 20 64 61 74 61 62 61 73 65 2c 20 73 74 72  ng database, str
1cb0: 69 6e 67 20 69 6e 64 65 78 2c 20 73 74 72 69 6e  ing index, strin
1cc0: 67 20 63 6f 6c 75 6d 6e 2c 20 6f 75 74 20 69 6e  g column, out in
1cd0: 74 20 73 6f 72 74 4d 6f 64 65 2c 20 6f 75 74 20  t sortMode, out 
1ce0: 69 6e 74 20 6f 6e 45 72 72 6f 72 2c 20 6f 75 74  int onError, out
1cf0: 20 73 74 72 69 6e 67 20 63 6f 6c 6c 61 74 69 6f   string collatio
1d00: 6e 53 65 71 75 65 6e 63 65 29 3b 0d 0a 0d 0a 20  nSequence);.... 
1d10: 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74     internal abst
1d20: 72 61 63 74 20 64 6f 75 62 6c 65 20 47 65 74 44  ract double GetD
1d30: 6f 75 62 6c 65 28 53 51 4c 69 74 65 53 74 61 74  ouble(SQLiteStat
1d40: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
1d50: 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20 69 6e 74  index);..    int
1d60: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 49  ernal abstract I
1d70: 6e 74 33 32 20 47 65 74 49 6e 74 33 32 28 53 51  nt32 GetInt32(SQ
1d80: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
1d90: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 3b 0d  mt, int index);.
1da0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62  .    internal ab
1db0: 73 74 72 61 63 74 20 49 6e 74 36 34 20 47 65 74  stract Int64 Get
1dc0: 49 6e 74 36 34 28 53 51 4c 69 74 65 53 74 61 74  Int64(SQLiteStat
1dd0: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
1de0: 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20 69 6e 74  index);..    int
1df0: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 73  ernal abstract s
1e00: 74 72 69 6e 67 20 47 65 74 54 65 78 74 28 53 51  tring GetText(SQ
1e10: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
1e20: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 3b 0d  mt, int index);.
1e30: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62  .    internal ab
1e40: 73 74 72 61 63 74 20 6c 6f 6e 67 20 47 65 74 42  stract long GetB
1e50: 79 74 65 73 28 53 51 4c 69 74 65 53 74 61 74 65  ytes(SQLiteState
1e60: 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69  ment stmt, int i
1e70: 6e 64 65 78 2c 20 69 6e 74 20 6e 44 61 74 61 6f  ndex, int nDatao
1e80: 66 66 73 65 74 2c 20 62 79 74 65 5b 5d 20 62 44  ffset, byte[] bD
1e90: 65 73 74 2c 20 69 6e 74 20 6e 53 74 61 72 74 2c  est, int nStart,
1ea0: 20 69 6e 74 20 6e 4c 65 6e 67 74 68 29 3b 0d 0a   int nLength);..
1eb0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73      internal abs
1ec0: 74 72 61 63 74 20 6c 6f 6e 67 20 47 65 74 43 68  tract long GetCh
1ed0: 61 72 73 28 53 51 4c 69 74 65 53 74 61 74 65 6d  ars(SQLiteStatem
1ee0: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
1ef0: 64 65 78 2c 20 69 6e 74 20 6e 44 61 74 61 6f 66  dex, int nDataof
1f00: 66 73 65 74 2c 20 63 68 61 72 5b 5d 20 62 44 65  fset, char[] bDe
1f10: 73 74 2c 20 69 6e 74 20 6e 53 74 61 72 74 2c 20  st, int nStart, 
1f20: 69 6e 74 20 6e 4c 65 6e 67 74 68 29 3b 0d 0a 20  int nLength);.. 
1f30: 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74     internal abst
1f40: 72 61 63 74 20 44 61 74 65 54 69 6d 65 20 47 65  ract DateTime Ge
1f50: 74 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74 65  tDateTime(SQLite
1f60: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
1f70: 69 6e 74 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20  int index);..   
1f80: 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61   internal abstra
1f90: 63 74 20 62 6f 6f 6c 20 49 73 4e 75 6c 6c 28 53  ct bool IsNull(S
1fa0: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73  QLiteStatement s
1fb0: 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 3b  tmt, int index);
1fc0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
1fd0: 20 61 62 73 74 72 61 63 74 20 76 6f 69 64 20 43   abstract void C
1fe0: 72 65 61 74 65 43 6f 6c 6c 61 74 69 6f 6e 28 73  reateCollation(s
1ff0: 74 72 69 6e 67 20 73 74 72 43 6f 6c 6c 61 74 69  tring strCollati
2000: 6f 6e 2c 20 53 51 4c 69 74 65 43 6f 6c 6c 61 74  on, SQLiteCollat
2010: 69 6f 6e 20 66 75 6e 63 2c 20 53 51 4c 69 74 65  ion func, SQLite
2020: 43 6f 6c 6c 61 74 69 6f 6e 20 66 75 6e 63 31 36  Collation func16
2030: 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  );..    internal
2040: 20 61 62 73 74 72 61 63 74 20 76 6f 69 64 20 43   abstract void C
2050: 72 65 61 74 65 46 75 6e 63 74 69 6f 6e 28 73 74  reateFunction(st
2060: 72 69 6e 67 20 73 74 72 46 75 6e 63 74 69 6f 6e  ring strFunction
2070: 2c 20 69 6e 74 20 6e 41 72 67 73 2c 20 62 6f 6f  , int nArgs, boo
2080: 6c 20 6e 65 65 64 43 6f 6c 6c 53 65 71 2c 20 53  l needCollSeq, S
2090: 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b 20 66 75  QLiteCallback fu
20a0: 6e 63 2c 20 53 51 4c 69 74 65 43 61 6c 6c 62 61  nc, SQLiteCallba
20b0: 63 6b 20 66 75 6e 63 73 74 65 70 2c 20 53 51 4c  ck funcstep, SQL
20c0: 69 74 65 46 69 6e 61 6c 43 61 6c 6c 62 61 63 6b  iteFinalCallback
20d0: 20 66 75 6e 63 66 69 6e 61 6c 29 3b 0d 0a 20 20   funcfinal);..  
20e0: 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72    internal abstr
20f0: 61 63 74 20 43 6f 6c 6c 61 74 69 6f 6e 53 65 71  act CollationSeq
2100: 75 65 6e 63 65 20 47 65 74 43 6f 6c 6c 61 74 69  uence GetCollati
2110: 6f 6e 53 65 71 75 65 6e 63 65 28 53 51 4c 69 74  onSequence(SQLit
2120: 65 46 75 6e 63 74 69 6f 6e 20 66 75 6e 63 2c 20  eFunction func, 
2130: 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 29 3b  IntPtr context);
2140: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61  ..    internal a
2150: 62 73 74 72 61 63 74 20 69 6e 74 20 43 6f 6e 74  bstract int Cont
2160: 65 78 74 43 6f 6c 6c 61 74 65 43 6f 6d 70 61 72  extCollateCompar
2170: 65 28 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64  e(CollationEncod
2180: 69 6e 67 45 6e 75 6d 20 65 6e 63 2c 20 49 6e 74  ingEnum enc, Int
2190: 50 74 72 20 63 6f 6e 74 65 78 74 2c 20 73 74 72  Ptr context, str
21a0: 69 6e 67 20 73 31 2c 20 73 74 72 69 6e 67 20 73  ing s1, string s
21b0: 32 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  2);..    interna
21c0: 6c 20 61 62 73 74 72 61 63 74 20 69 6e 74 20 43  l abstract int C
21d0: 6f 6e 74 65 78 74 43 6f 6c 6c 61 74 65 43 6f 6d  ontextCollateCom
21e0: 70 61 72 65 28 43 6f 6c 6c 61 74 69 6f 6e 45 6e  pare(CollationEn
21f0: 63 6f 64 69 6e 67 45 6e 75 6d 20 65 6e 63 2c 20  codingEnum enc, 
2200: 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20  IntPtr context, 
2210: 63 68 61 72 5b 5d 20 63 31 2c 20 63 68 61 72 5b  char[] c1, char[
2220: 5d 20 63 32 29 3b 0d 0a 0d 0a 20 20 20 20 69 6e  ] c2);....    in
2230: 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20  ternal abstract 
2240: 69 6e 74 20 41 67 67 72 65 67 61 74 65 43 6f 75  int AggregateCou
2250: 6e 74 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78  nt(IntPtr contex
2260: 74 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  t);..    interna
2270: 6c 20 61 62 73 74 72 61 63 74 20 49 6e 74 50 74  l abstract IntPt
2280: 72 20 41 67 67 72 65 67 61 74 65 43 6f 6e 74 65  r AggregateConte
2290: 78 74 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78  xt(IntPtr contex
22a0: 74 29 3b 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72  t);....    inter
22b0: 6e 61 6c 20 61 62 73 74 72 61 63 74 20 6c 6f 6e  nal abstract lon
22c0: 67 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 42  g GetParamValueB
22d0: 79 74 65 73 28 49 6e 74 50 74 72 20 70 74 72 2c  ytes(IntPtr ptr,
22e0: 20 69 6e 74 20 6e 44 61 74 61 4f 66 66 73 65 74   int nDataOffset
22f0: 2c 20 62 79 74 65 5b 5d 20 62 44 65 73 74 2c 20  , byte[] bDest, 
2300: 69 6e 74 20 6e 53 74 61 72 74 2c 20 69 6e 74 20  int nStart, int 
2310: 6e 4c 65 6e 67 74 68 29 3b 0d 0a 20 20 20 20 69  nLength);..    i
2320: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
2330: 20 64 6f 75 62 6c 65 20 47 65 74 50 61 72 61 6d   double GetParam
2340: 56 61 6c 75 65 44 6f 75 62 6c 65 28 49 6e 74 50  ValueDouble(IntP
2350: 74 72 20 70 74 72 29 3b 0d 0a 20 20 20 20 69 6e  tr ptr);..    in
2360: 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20  ternal abstract 
2370: 69 6e 74 20 47 65 74 50 61 72 61 6d 56 61 6c 75  int GetParamValu
2380: 65 49 6e 74 33 32 28 49 6e 74 50 74 72 20 70 74  eInt32(IntPtr pt
2390: 72 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  r);..    interna
23a0: 6c 20 61 62 73 74 72 61 63 74 20 49 6e 74 36 34  l abstract Int64
23b0: 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 49 6e   GetParamValueIn
23c0: 74 36 34 28 49 6e 74 50 74 72 20 70 74 72 29 3b  t64(IntPtr ptr);
23d0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61  ..    internal a
23e0: 62 73 74 72 61 63 74 20 73 74 72 69 6e 67 20 47  bstract string G
23f0: 65 74 50 61 72 61 6d 56 61 6c 75 65 54 65 78 74  etParamValueText
2400: 28 49 6e 74 50 74 72 20 70 74 72 29 3b 0d 0a 20  (IntPtr ptr);.. 
2410: 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74     internal abst
2420: 72 61 63 74 20 54 79 70 65 41 66 66 69 6e 69 74  ract TypeAffinit
2430: 79 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 54  y GetParamValueT
2440: 79 70 65 28 49 6e 74 50 74 72 20 70 74 72 29 3b  ype(IntPtr ptr);
2450: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
2460: 20 61 62 73 74 72 61 63 74 20 76 6f 69 64 20 52   abstract void R
2470: 65 74 75 72 6e 42 6c 6f 62 28 49 6e 74 50 74 72  eturnBlob(IntPtr
2480: 20 63 6f 6e 74 65 78 74 2c 20 62 79 74 65 5b 5d   context, byte[]
2490: 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 69 6e   value);..    in
24a0: 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20  ternal abstract 
24b0: 76 6f 69 64 20 52 65 74 75 72 6e 44 6f 75 62 6c  void ReturnDoubl
24c0: 65 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74  e(IntPtr context
24d0: 2c 20 64 6f 75 62 6c 65 20 76 61 6c 75 65 29 3b  , double value);
24e0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61  ..    internal a
24f0: 62 73 74 72 61 63 74 20 76 6f 69 64 20 52 65 74  bstract void Ret
2500: 75 72 6e 45 72 72 6f 72 28 49 6e 74 50 74 72 20  urnError(IntPtr 
2510: 63 6f 6e 74 65 78 74 2c 20 73 74 72 69 6e 67 20  context, string 
2520: 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 69 6e 74  value);..    int
2530: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 76  ernal abstract v
2540: 6f 69 64 20 52 65 74 75 72 6e 49 6e 74 33 32 28  oid ReturnInt32(
2550: 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20  IntPtr context, 
2560: 49 6e 74 33 32 20 76 61 6c 75 65 29 3b 0d 0a 20  Int32 value);.. 
2570: 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74     internal abst
2580: 72 61 63 74 20 76 6f 69 64 20 52 65 74 75 72 6e  ract void Return
2590: 49 6e 74 36 34 28 49 6e 74 50 74 72 20 63 6f 6e  Int64(IntPtr con
25a0: 74 65 78 74 2c 20 49 6e 74 36 34 20 76 61 6c 75  text, Int64 valu
25b0: 65 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  e);..    interna
25c0: 6c 20 61 62 73 74 72 61 63 74 20 76 6f 69 64 20  l abstract void 
25d0: 52 65 74 75 72 6e 4e 75 6c 6c 28 49 6e 74 50 74  ReturnNull(IntPt
25e0: 72 20 63 6f 6e 74 65 78 74 29 3b 0d 0a 20 20 20  r context);..   
25f0: 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61   internal abstra
2600: 63 74 20 76 6f 69 64 20 52 65 74 75 72 6e 54 65  ct void ReturnTe
2610: 78 74 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78  xt(IntPtr contex
2620: 74 2c 20 73 74 72 69 6e 67 20 76 61 6c 75 65 29  t, string value)
2630: 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  ;....    /// <su
2640: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
2650: 45 6e 61 62 6c 65 73 20 6f 72 20 64 69 73 61 62  Enables or disab
2660: 6c 65 64 20 65 78 74 65 6e 65 64 20 72 65 73 75  led extened resu
2670: 6c 74 20 63 6f 64 65 73 20 72 65 74 75 72 6e 65  lt codes returne
2680: 64 20 62 79 20 53 51 4c 69 74 65 0d 0a 20 20 20  d by SQLite..   
2690: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
26a0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
26b0: 6e 61 6d 65 3d 22 62 4f 6e 4f 66 66 22 3e 74 72  name="bOnOff">tr
26c0: 75 65 20 74 6f 20 65 6e 61 62 6c 65 20 65 78 74  ue to enable ext
26d0: 65 6e 64 65 64 20 72 65 73 75 6c 74 20 63 6f 64  ended result cod
26e0: 65 73 2c 20 66 61 6c 73 65 20 74 6f 20 64 69 73  es, false to dis
26f0: 61 62 6c 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20  able.</param>.. 
2700: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
2710: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
2720: 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63  internal abstrac
2730: 74 20 76 6f 69 64 20 53 65 74 45 78 74 65 6e 64  t void SetExtend
2740: 65 64 52 65 73 75 6c 74 43 6f 64 65 73 28 62 6f  edResultCodes(bo
2750: 6f 6c 20 62 4f 6e 4f 66 66 29 3b 0d 0a 20 20 20  ol bOnOff);..   
2760: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
2770: 20 20 20 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20      /// Returns 
2780: 74 68 65 20 6e 75 6d 65 72 69 63 20 72 65 73 75  the numeric resu
2790: 6c 74 20 63 6f 64 65 20 66 6f 72 20 74 68 65 20  lt code for the 
27a0: 6d 6f 73 74 20 72 65 63 65 6e 74 20 66 61 69 6c  most recent fail
27b0: 65 64 20 53 51 4c 69 74 65 20 41 50 49 20 63 61  ed SQLite API ca
27c0: 6c 6c 20 0d 0a 20 20 20 20 2f 2f 2f 20 61 73 73  ll ..    /// ass
27d0: 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68 65  ociated with the
27e0: 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63   database connec
27f0: 74 69 6f 6e 2e 20 0d 0a 20 20 20 20 2f 2f 2f 20  tion. ..    /// 
2800: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
2810: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 52 65 73  /// <returns>Res
2820: 75 6c 74 20 63 6f 64 65 3c 2f 72 65 74 75 72 6e  ult code</return
2830: 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  s>..    internal
2840: 20 61 62 73 74 72 61 63 74 20 69 6e 74 20 52 65   abstract int Re
2850: 73 75 6c 74 43 6f 64 65 28 29 3b 0d 0a 20 20 20  sultCode();..   
2860: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
2870: 20 20 20 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20      /// Returns 
2880: 74 68 65 20 65 78 74 65 6e 64 65 64 20 6e 75 6d  the extended num
2890: 65 72 69 63 20 72 65 73 75 6c 74 20 63 6f 64 65  eric result code
28a0: 20 66 6f 72 20 74 68 65 20 6d 6f 73 74 20 72 65   for the most re
28b0: 63 65 6e 74 20 66 61 69 6c 65 64 20 53 51 4c 69  cent failed SQLi
28c0: 74 65 20 41 50 49 20 63 61 6c 6c 20 0d 0a 20 20  te API call ..  
28d0: 20 20 2f 2f 2f 20 61 73 73 6f 63 69 61 74 65 64    /// associated
28e0: 20 77 69 74 68 20 74 68 65 20 64 61 74 61 62 61   with the databa
28f0: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 20 0d  se connection. .
2900: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
2910: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  ry>..    /// <re
2920: 74 75 72 6e 73 3e 45 78 74 65 6e 64 65 64 20 72  turns>Extended r
2930: 65 73 75 6c 74 20 63 6f 64 65 3c 2f 72 65 74 75  esult code</retu
2940: 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e  rns>..    intern
2950: 61 6c 20 61 62 73 74 72 61 63 74 20 69 6e 74 20  al abstract int 
2960: 45 78 74 65 6e 64 65 64 52 65 73 75 6c 74 43 6f  ExtendedResultCo
2970: 64 65 28 29 3b 0d 0a 0d 0a 20 20 20 20 2f 2f 2f  de();....    ///
2980: 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20   <summary>..    
2990: 2f 2f 2f 20 41 64 64 20 61 20 6c 6f 67 20 6d 65  /// Add a log me
29a0: 73 73 61 67 65 20 76 69 61 20 74 68 65 20 53 51  ssage via the SQ
29b0: 4c 69 74 65 20 73 71 6c 69 74 65 33 5f 6c 6f 67  Lite sqlite3_log
29c0: 20 69 6e 74 65 72 66 61 63 65 2e 0d 0a 20 20 20   interface...   
29d0: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
29e0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
29f0: 6e 61 6d 65 3d 22 69 45 72 72 43 6f 64 65 22 3e  name="iErrCode">
2a00: 45 72 72 6f 72 20 63 6f 64 65 20 74 6f 20 62 65  Error code to be
2a10: 20 6c 6f 67 67 65 64 20 77 69 74 68 20 74 68 65   logged with the
2a20: 20 6d 65 73 73 61 67 65 2e 3c 2f 70 61 72 61 6d   message.</param
2a30: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61  >..    /// <para
2a40: 6d 20 6e 61 6d 65 3d 22 7a 4d 65 73 73 61 67 65  m name="zMessage
2a50: 22 3e 53 74 72 69 6e 67 20 74 6f 20 62 65 20 6c  ">String to be l
2a60: 6f 67 67 65 64 2e 20 20 55 6e 6c 69 6b 65 20 74  ogged.  Unlike t
2a70: 68 65 20 53 51 4c 69 74 65 20 73 71 6c 69 74 65  he SQLite sqlite
2a80: 33 5f 6c 6f 67 28 29 20 0d 0a 20 20 20 20 2f 2f  3_log() ..    //
2a90: 2f 20 69 6e 74 65 72 66 61 63 65 2c 20 74 68 69  / interface, thi
2aa0: 73 20 73 68 6f 75 6c 64 20 62 65 20 70 72 65 2d  s should be pre-
2ab0: 66 6f 72 6d 61 74 74 65 64 2e 20 20 43 6f 6e 73  formatted.  Cons
2ac0: 69 64 65 72 20 75 73 69 6e 67 20 74 68 65 20 0d  ider using the .
2ad0: 0a 20 20 20 20 2f 2f 2f 20 53 74 72 69 6e 67 2e  .    /// String.
2ae0: 46 6f 72 6d 61 74 28 29 20 66 75 6e 63 74 69 6f  Format() functio
2af0: 6e 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  n.</param>..    
2b00: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 3c 2f 72  /// <returns></r
2b10: 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74  eturns>..    int
2b20: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 76  ernal abstract v
2b30: 6f 69 64 20 4c 6f 67 4d 65 73 73 61 67 65 28 69  oid LogMessage(i
2b40: 6e 74 20 69 45 72 72 43 6f 64 65 2c 20 73 74 72  nt iErrCode, str
2b50: 69 6e 67 20 7a 4d 65 73 73 61 67 65 29 3b 0d 0a  ing zMessage);..
2b60: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61  ..    internal a
2b70: 62 73 74 72 61 63 74 20 76 6f 69 64 20 53 65 74  bstract void Set
2b80: 50 61 73 73 77 6f 72 64 28 62 79 74 65 5b 5d 20  Password(byte[] 
2b90: 70 61 73 73 77 6f 72 64 42 79 74 65 73 29 3b 0d  passwordBytes);.
2ba0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 61 62  .    internal ab
2bb0: 73 74 72 61 63 74 20 76 6f 69 64 20 43 68 61 6e  stract void Chan
2bc0: 67 65 50 61 73 73 77 6f 72 64 28 62 79 74 65 5b  gePassword(byte[
2bd0: 5d 20 6e 65 77 50 61 73 73 77 6f 72 64 42 79 74  ] newPasswordByt
2be0: 65 73 29 3b 0d 0a 0d 0a 20 20 20 20 69 6e 74 65  es);....    inte
2bf0: 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 76 6f  rnal abstract vo
2c00: 69 64 20 53 65 74 55 70 64 61 74 65 48 6f 6f 6b  id SetUpdateHook
2c10: 28 53 51 4c 69 74 65 55 70 64 61 74 65 43 61 6c  (SQLiteUpdateCal
2c20: 6c 62 61 63 6b 20 66 75 6e 63 29 3b 0d 0a 20 20  lback func);..  
2c30: 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72    internal abstr
2c40: 61 63 74 20 76 6f 69 64 20 53 65 74 43 6f 6d 6d  act void SetComm
2c50: 69 74 48 6f 6f 6b 28 53 51 4c 69 74 65 43 6f 6d  itHook(SQLiteCom
2c60: 6d 69 74 43 61 6c 6c 62 61 63 6b 20 66 75 6e 63  mitCallback func
2c70: 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  );..    internal
2c80: 20 61 62 73 74 72 61 63 74 20 76 6f 69 64 20 53   abstract void S
2c90: 65 74 54 72 61 63 65 43 61 6c 6c 62 61 63 6b 28  etTraceCallback(
2ca0: 53 51 4c 69 74 65 54 72 61 63 65 43 61 6c 6c 62  SQLiteTraceCallb
2cb0: 61 63 6b 20 66 75 6e 63 29 3b 0d 0a 20 20 20 20  ack func);..    
2cc0: 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63  internal abstrac
2cd0: 74 20 76 6f 69 64 20 53 65 74 52 6f 6c 6c 62 61  t void SetRollba
2ce0: 63 6b 48 6f 6f 6b 28 53 51 4c 69 74 65 52 6f 6c  ckHook(SQLiteRol
2cf0: 6c 62 61 63 6b 43 61 6c 6c 62 61 63 6b 20 66 75  lbackCallback fu
2d00: 6e 63 29 3b 0d 0a 20 20 20 20 69 6e 74 65 72 6e  nc);..    intern
2d10: 61 6c 20 61 62 73 74 72 61 63 74 20 69 6e 74 20  al abstract int 
2d20: 53 65 74 4c 6f 67 43 61 6c 6c 62 61 63 6b 28 53  SetLogCallback(S
2d30: 51 4c 69 74 65 4c 6f 67 43 61 6c 6c 62 61 63 6b  QLiteLogCallback
2d40: 20 66 75 6e 63 29 3b 0d 0a 0d 0a 20 20 20 20 69   func);....    i
2d50: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
2d60: 20 69 6e 74 20 47 65 74 43 75 72 73 6f 72 46 6f   int GetCursorFo
2d70: 72 54 61 62 6c 65 28 53 51 4c 69 74 65 53 74 61  rTable(SQLiteSta
2d80: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
2d90: 20 64 61 74 61 62 61 73 65 2c 20 69 6e 74 20 72   database, int r
2da0: 6f 6f 74 50 61 67 65 29 3b 0d 0a 20 20 20 20 69  ootPage);..    i
2db0: 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74  nternal abstract
2dc0: 20 6c 6f 6e 67 20 47 65 74 52 6f 77 49 64 46 6f   long GetRowIdFo
2dd0: 72 43 75 72 73 6f 72 28 53 51 4c 69 74 65 53 74  rCursor(SQLiteSt
2de0: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
2df0: 74 20 63 75 72 73 6f 72 29 3b 0d 0a 0d 0a 20 20  t cursor);....  
2e00: 20 20 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72    internal abstr
2e10: 61 63 74 20 6f 62 6a 65 63 74 20 47 65 74 56 61  act object GetVa
2e20: 6c 75 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d  lue(SQLiteStatem
2e30: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
2e40: 64 65 78 2c 20 53 51 4c 69 74 65 54 79 70 65 20  dex, SQLiteType 
2e50: 74 79 70 29 3b 0d 0a 0d 0a 20 20 20 20 69 6e 74  typ);....    int
2e60: 65 72 6e 61 6c 20 61 62 73 74 72 61 63 74 20 62  ernal abstract b
2e70: 6f 6f 6c 20 41 75 74 6f 43 6f 6d 6d 69 74 0d 0a  ool AutoCommit..
2e80: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 67 65 74      {..      get
2e90: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
2ea0: 69 6e 74 65 72 6e 61 6c 20 61 62 73 74 72 61 63  internal abstrac
2eb0: 74 20 69 6e 74 20 46 69 6c 65 43 6f 6e 74 72 6f  t int FileContro
2ec0: 6c 28 73 74 72 69 6e 67 20 7a 44 62 4e 61 6d 65  l(string zDbName
2ed0: 2c 20 69 6e 74 20 6f 70 2c 20 49 6e 74 50 74 72  , int op, IntPtr
2ee0: 20 70 41 72 67 29 3b 0d 0a 0d 0a 20 20 20 20 70   pArg);....    p
2ef0: 72 6f 74 65 63 74 65 64 20 76 69 72 74 75 61 6c  rotected virtual
2f00: 20 76 6f 69 64 20 44 69 73 70 6f 73 65 28 62 6f   void Dispose(bo
2f10: 6f 6c 20 62 44 69 73 70 6f 73 69 6e 67 29 0d 0a  ol bDisposing)..
2f20: 20 20 20 20 7b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a      {..    }....
2f30: 20 20 20 20 70 75 62 6c 69 63 20 76 6f 69 64 20      public void 
2f40: 44 69 73 70 6f 73 65 28 29 0d 0a 20 20 20 20 7b  Dispose()..    {
2f50: 0d 0a 20 20 20 20 20 20 44 69 73 70 6f 73 65 28  ..      Dispose(
2f60: 74 72 75 65 29 3b 0d 0a 20 20 20 20 20 20 47 43  true);..      GC
2f70: 2e 53 75 70 70 72 65 73 73 46 69 6e 61 6c 69 7a  .SuppressFinaliz
2f80: 65 28 74 68 69 73 29 3b 0d 0a 20 20 20 20 7d 0d  e(this);..    }.
2f90: 0a 0d 0a 20 20 20 20 2f 2f 20 54 68 65 73 65 20  ...    // These 
2fa0: 73 74 61 74 69 63 73 20 61 72 65 20 68 65 72 65  statics are here
2fb0: 20 66 6f 72 20 6c 61 63 6b 20 6f 66 20 61 20 62   for lack of a b
2fc0: 65 74 74 65 72 20 70 6c 61 63 65 20 74 6f 20 70  etter place to p
2fd0: 75 74 20 74 68 65 6d 2e 0d 0a 20 20 20 20 2f 2f  ut them...    //
2fe0: 20 54 68 65 79 20 65 78 69 73 74 20 68 65 72 65   They exist here
2ff0: 20 62 65 63 61 75 73 65 20 74 68 65 79 20 61 72   because they ar
3000: 65 20 63 61 6c 6c 65 64 20 64 75 72 69 6e 67 20  e called during 
3010: 74 68 65 20 66 69 6e 61 6c 69 7a 61 74 69 6f 6e  the finalization
3020: 20 6f 66 0d 0a 20 20 20 20 2f 2f 20 61 20 53 51   of..    // a SQ
3030: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61 6e  LiteStatementHan
3040: 64 6c 65 2c 20 53 51 4c 69 74 65 43 6f 6e 6e 65  dle, SQLiteConne
3050: 63 74 69 6f 6e 48 61 6e 64 6c 65 2c 20 61 6e 64  ctionHandle, and
3060: 20 53 51 4c 69 74 65 46 75 6e 63 74 69 6f 6e 43   SQLiteFunctionC
3070: 6f 6f 6b 69 65 48 61 6e 64 6c 65 2e 0d 0a 20 20  ookieHandle...  
3080: 20 20 2f 2f 20 54 68 65 72 65 66 6f 72 65 20 74    // Therefore t
3090: 68 65 73 65 20 66 75 6e 63 74 69 6f 6e 73 20 68  hese functions h
30a0: 61 76 65 20 74 6f 20 62 65 20 73 74 61 74 69 63  ave to be static
30b0: 2c 20 61 6e 64 20 68 61 76 65 20 74 6f 20 62 65  , and have to be
30c0: 20 6c 6f 77 2d 6c 65 76 65 6c 2e 0d 0a 0d 0a 20   low-level..... 
30d0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74     internal stat
30e0: 69 63 20 73 74 72 69 6e 67 20 53 51 4c 69 74 65  ic string SQLite
30f0: 4c 61 73 74 45 72 72 6f 72 28 53 51 4c 69 74 65  LastError(SQLite
3100: 43 6f 6e 6e 65 63 74 69 6f 6e 48 61 6e 64 6c 65  ConnectionHandle
3110: 20 64 62 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66   db)..    {..#if
3120: 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52   !SQLITE_STANDAR
3130: 44 0d 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e  D..      int len
3140: 3b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ;..      return 
3150: 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55 6e 73  UTF8ToString(Uns
3160: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
3170: 2e 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 5f  .sqlite3_errmsg_
3180: 69 6e 74 65 72 6f 70 28 64 62 2c 20 6f 75 74 20  interop(db, out 
3190: 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23 65 6c  len), len);..#el
31a0: 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e  se..      return
31b0: 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55 6e   UTF8ToString(Un
31c0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
31d0: 73 2e 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67  s.sqlite3_errmsg
31e0: 28 64 62 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64  (db), -1);..#end
31f0: 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  if..    }....   
3200: 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69 63   internal static
3210: 20 76 6f 69 64 20 46 69 6e 61 6c 69 7a 65 53 74   void FinalizeSt
3220: 61 74 65 6d 65 6e 74 28 53 51 4c 69 74 65 53 74  atement(SQLiteSt
3230: 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20 73 74  atementHandle st
3240: 6d 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  mt)..    {..    
3250: 20 20 6c 6f 63 6b 20 28 5f 6c 6f 63 6b 29 0d 0a    lock (_lock)..
3260: 20 20 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51        {..#if !SQ
3270: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
3280: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55         int n = U
3290: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
32a0: 64 73 2e 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c  ds.sqlite3_final
32b0: 69 7a 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74  ize_interop(stmt
32c0: 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20  );..#else..     
32d0: 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e   int n = UnsafeN
32e0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
32f0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 73 74  ite3_finalize(st
3300: 6d 74 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20  mt);..#endif..  
3310: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
3320: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
3330: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 6e 75  eException(n, nu
3340: 6c 6c 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20  ll);..      }.. 
3350: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
3360: 72 6e 61 6c 20 73 74 61 74 69 63 20 76 6f 69 64  rnal static void
3370: 20 43 6c 6f 73 65 43 6f 6e 6e 65 63 74 69 6f 6e   CloseConnection
3380: 28 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f  (SQLiteConnectio
3390: 6e 48 61 6e 64 6c 65 20 64 62 29 0d 0a 20 20 20  nHandle db)..   
33a0: 20 7b 0d 0a 20 20 20 20 20 20 6c 6f 63 6b 20 28   {..      lock (
33b0: 5f 6c 6f 63 6b 29 0d 0a 20 20 20 20 20 20 7b 0d  _lock)..      {.
33c0: 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41  .#if !SQLITE_STA
33d0: 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 20 20 69  NDARD..        i
33e0: 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74  nt n = UnsafeNat
33f0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
3400: 65 33 5f 63 6c 6f 73 65 5f 69 6e 74 65 72 6f 70  e3_close_interop
3410: 28 64 62 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20  (db);..#else..  
3420: 20 20 20 20 52 65 73 65 74 43 6f 6e 6e 65 63 74      ResetConnect
3430: 69 6f 6e 28 64 62 29 3b 0d 0a 20 20 20 20 20 20  ion(db);..      
3440: 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61  int n = UnsafeNa
3450: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
3460: 74 65 33 5f 63 6c 6f 73 65 28 64 62 29 3b 0d 0a  te3_close(db);..
3470: 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20  #endif..        
3480: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
3490: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
34a0: 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61  tion(n, SQLiteLa
34b0: 73 74 45 72 72 6f 72 28 64 62 29 29 3b 0d 0a 20  stError(db));.. 
34c0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d       }..    }...
34d0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
34e0: 61 74 69 63 20 76 6f 69 64 20 52 65 73 65 74 43  atic void ResetC
34f0: 6f 6e 6e 65 63 74 69 6f 6e 28 53 51 4c 69 74 65  onnection(SQLite
3500: 43 6f 6e 6e 65 63 74 69 6f 6e 48 61 6e 64 6c 65  ConnectionHandle
3510: 20 64 62 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20   db)..    {..   
3520: 20 20 20 6c 6f 63 6b 20 28 5f 6c 6f 63 6b 29 0d     lock (_lock).
3530: 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  .      {..      
3540: 20 20 49 6e 74 50 74 72 20 73 74 6d 74 20 3d 20    IntPtr stmt = 
3550: 49 6e 74 50 74 72 2e 5a 65 72 6f 3b 0d 0a 20 20  IntPtr.Zero;..  
3560: 20 20 20 20 20 20 69 6e 74 20 6e 3b 0d 0a 20 20        int n;..  
3570: 20 20 20 20 20 20 64 6f 0d 0a 20 20 20 20 20 20        do..      
3580: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 73    {..          s
3590: 74 6d 74 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  tmt = UnsafeNati
35a0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
35b0: 33 5f 6e 65 78 74 5f 73 74 6d 74 28 64 62 2c 20  3_next_stmt(db, 
35c0: 73 74 6d 74 29 3b 0d 0a 20 20 20 20 20 20 20 20  stmt);..        
35d0: 20 20 69 66 20 28 73 74 6d 74 20 21 3d 20 49 6e    if (stmt != In
35e0: 74 50 74 72 2e 5a 65 72 6f 29 0d 0a 20 20 20 20  tPtr.Zero)..    
35f0: 20 20 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51        {..#if !SQ
3600: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
3610: 20 20 20 20 20 20 20 20 20 20 20 6e 20 3d 20 55             n = U
3620: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
3630: 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 65 74  ds.sqlite3_reset
3640: 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 29 3b 0d  _interop(stmt);.
3650: 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20  .#else..        
3660: 20 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61      n = UnsafeNa
3670: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
3680: 74 65 33 5f 72 65 73 65 74 28 73 74 6d 74 29 3b  te3_reset(stmt);
3690: 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20  ..#endif..      
36a0: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d      }..        }
36b0: 20 77 68 69 6c 65 20 28 73 74 6d 74 20 21 3d 20   while (stmt != 
36c0: 49 6e 74 50 74 72 2e 5a 65 72 6f 29 3b 0d 0a 0d  IntPtr.Zero);...
36d0: 0a 20 20 20 20 20 20 20 20 69 66 20 28 49 73 41  .        if (IsA
36e0: 75 74 6f 63 6f 6d 6d 69 74 28 64 62 29 20 3d 3d  utocommit(db) ==
36f0: 20 66 61 6c 73 65 29 20 2f 2f 20 61 20 74 72 61   false) // a tra
3700: 6e 73 61 63 74 69 6f 6e 20 69 73 20 70 65 6e 64  nsaction is pend
3710: 69 6e 67 20 6f 6e 20 74 68 65 20 63 6f 6e 6e 65  ing on the conne
3720: 63 74 69 6f 6e 0d 0a 20 20 20 20 20 20 20 20 7b  ction..        {
3730: 0d 0a 20 20 20 20 20 20 20 20 20 20 6e 20 3d 20  ..          n = 
3740: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3750: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 65 78 65 63  ods.sqlite3_exec
3760: 28 64 62 2c 20 54 6f 55 54 46 38 28 22 52 4f 4c  (db, ToUTF8("ROL
3770: 4c 42 41 43 4b 22 29 2c 20 49 6e 74 50 74 72 2e  LBACK"), IntPtr.
3780: 5a 65 72 6f 2c 20 49 6e 74 50 74 72 2e 5a 65 72  Zero, IntPtr.Zer
3790: 6f 2c 20 6f 75 74 20 73 74 6d 74 29 3b 0d 0a 20  o, out stmt);.. 
37a0: 20 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e           if (n >
37b0: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
37c0: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
37d0: 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72   SQLiteLastError
37e0: 28 64 62 29 29 3b 0d 0a 20 20 20 20 20 20 20 20  (db));..        
37f0: 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  }..      }..    
3800: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
3810: 6c 20 73 74 61 74 69 63 20 62 6f 6f 6c 20 49 73  l static bool Is
3820: 41 75 74 6f 63 6f 6d 6d 69 74 28 53 51 4c 69 74  Autocommit(SQLit
3830: 65 43 6f 6e 6e 65 63 74 69 6f 6e 48 61 6e 64 6c  eConnectionHandl
3840: 65 20 68 64 6c 29 0d 0a 20 20 20 20 7b 0d 0a 20  e hdl)..    {.. 
3850: 20 20 20 20 20 72 65 74 75 72 6e 20 28 55 6e 73       return (Uns
3860: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
3870: 2e 73 71 6c 69 74 65 33 5f 67 65 74 5f 61 75 74  .sqlite3_get_aut
3880: 6f 63 6f 6d 6d 69 74 28 68 64 6c 29 20 3d 3d 20  ocommit(hdl) == 
3890: 31 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  1);..    }....  
38a0: 7d 0d 0a 0d 0a 20 20 69 6e 74 65 72 6e 61 6c 20  }....  internal 
38b0: 69 6e 74 65 72 66 61 63 65 20 49 53 51 4c 69 74  interface ISQLit
38c0: 65 53 63 68 65 6d 61 45 78 74 65 6e 73 69 6f 6e  eSchemaExtension
38d0: 73 0d 0a 20 20 7b 0d 0a 20 20 20 20 76 6f 69 64  s..  {..    void
38e0: 20 42 75 69 6c 64 54 65 6d 70 53 63 68 65 6d 61   BuildTempSchema
38f0: 28 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f  (SQLiteConnectio
3900: 6e 20 63 6e 6e 29 3b 0d 0a 20 20 7d 0d 0a 0d 0a  n cnn);..  }....
3910: 20 20 5b 46 6c 61 67 73 5d 0d 0a 20 20 69 6e 74    [Flags]..  int
3920: 65 72 6e 61 6c 20 65 6e 75 6d 20 53 51 4c 69 74  ernal enum SQLit
3930: 65 4f 70 65 6e 46 6c 61 67 73 45 6e 75 6d 0d 0a  eOpenFlagsEnum..
3940: 20 20 7b 0d 0a 20 20 20 20 4e 6f 6e 65 20 3d 20    {..    None = 
3950: 30 2c 0d 0a 20 20 20 20 52 65 61 64 4f 6e 6c 79  0,..    ReadOnly
3960: 20 3d 20 30 78 30 31 2c 0d 0a 20 20 20 20 52 65   = 0x01,..    Re
3970: 61 64 57 72 69 74 65 20 3d 20 30 78 30 32 2c 0d  adWrite = 0x02,.
3980: 0a 20 20 20 20 43 72 65 61 74 65 20 3d 20 30 78  .    Create = 0x
3990: 30 34 2c 0d 0a 20 20 20 20 53 68 61 72 65 64 43  04,..    SharedC
39a0: 61 63 68 65 20 3d 20 30 78 30 31 30 30 30 30 30  ache = 0x0100000
39b0: 30 2c 0d 0a 20 20 20 20 44 65 66 61 75 6c 74 20  0,..    Default 
39c0: 3d 20 30 78 30 36 2c 0d 0a 20 20 7d 0d 0a 0d 0a  = 0x06,..  }....
39d0: 20 20 2f 2f 20 54 68 65 73 65 20 61 72 65 20 74    // These are t
39e0: 68 65 20 6f 70 74 69 6f 6e 73 20 74 6f 20 74 68  he options to th
39f0: 65 20 69 6e 74 65 72 6e 61 6c 20 73 71 6c 69 74  e internal sqlit
3a00: 65 33 5f 63 6f 6e 66 69 67 20 63 61 6c 6c 2e 0d  e3_config call..
3a10: 0a 20 20 69 6e 74 65 72 6e 61 6c 20 65 6e 75 6d  .  internal enum
3a20: 20 53 51 4c 69 74 65 43 6f 6e 66 69 67 4f 70 73   SQLiteConfigOps
3a30: 45 6e 75 6d 0d 0a 20 20 7b 0d 0a 20 20 20 20 53  Enum..  {..    S
3a40: 51 4c 49 54 45 5f 43 4f 4e 46 49 47 5f 53 49 4e  QLITE_CONFIG_SIN
3a50: 47 4c 45 54 48 52 45 41 44 20 3d 20 31 2c 20 2f  GLETHREAD = 1, /
3a60: 2f 20 6e 69 6c 20 0d 0a 20 20 20 20 53 51 4c 49  / nil ..    SQLI
3a70: 54 45 5f 43 4f 4e 46 49 47 5f 4d 55 4c 54 49 54  TE_CONFIG_MULTIT
3a80: 48 52 45 41 44 20 3d 20 32 2c 20 2f 2f 20 6e 69  HREAD = 2, // ni
3a90: 6c 20 0d 0a 20 20 20 20 53 51 4c 49 54 45 5f 43  l ..    SQLITE_C
3aa0: 4f 4e 46 49 47 5f 53 45 52 49 41 4c 49 5a 45 44  ONFIG_SERIALIZED
3ab0: 20 3d 20 33 2c 20 2f 2f 20 6e 69 6c 20 0d 0a 20   = 3, // nil .. 
3ac0: 20 20 20 53 51 4c 49 54 45 5f 43 4f 4e 46 49 47     SQLITE_CONFIG
3ad0: 5f 4d 41 4c 4c 4f 43 20 3d 20 34 2c 20 2f 2f 20  _MALLOC = 4, // 
3ae0: 73 71 6c 69 74 65 33 5f 6d 65 6d 5f 6d 65 74 68  sqlite3_mem_meth
3af0: 6f 64 73 2a 20 0d 0a 20 20 20 20 53 51 4c 49 54  ods* ..    SQLIT
3b00: 45 5f 43 4f 4e 46 49 47 5f 47 45 54 4d 41 4c 4c  E_CONFIG_GETMALL
3b10: 4f 43 20 3d 20 35 2c 20 2f 2f 20 73 71 6c 69 74  OC = 5, // sqlit
3b20: 65 33 5f 6d 65 6d 5f 6d 65 74 68 6f 64 73 2a 20  e3_mem_methods* 
3b30: 0d 0a 20 20 20 20 53 51 4c 49 54 45 5f 43 4f 4e  ..    SQLITE_CON
3b40: 46 49 47 5f 53 43 52 41 54 43 48 20 3d 20 36 2c  FIG_SCRATCH = 6,
3b50: 20 2f 2f 20 76 6f 69 64 2a 2c 20 69 6e 74 20 73   // void*, int s
3b60: 7a 2c 20 69 6e 74 20 4e 20 0d 0a 20 20 20 20 53  z, int N ..    S
3b70: 51 4c 49 54 45 5f 43 4f 4e 46 49 47 5f 50 41 47  QLITE_CONFIG_PAG
3b80: 45 43 41 43 48 45 20 3d 20 37 2c 20 2f 2f 20 76  ECACHE = 7, // v
3b90: 6f 69 64 2a 2c 20 69 6e 74 20 73 7a 2c 20 69 6e  oid*, int sz, in
3ba0: 74 20 4e 20 0d 0a 20 20 20 20 53 51 4c 49 54 45  t N ..    SQLITE
3bb0: 5f 43 4f 4e 46 49 47 5f 48 45 41 50 20 3d 20 38  _CONFIG_HEAP = 8
3bc0: 2c 20 2f 2f 20 76 6f 69 64 2a 2c 20 69 6e 74 20  , // void*, int 
3bd0: 6e 42 79 74 65 2c 20 69 6e 74 20 6d 69 6e 20 0d  nByte, int min .
3be0: 0a 20 20 20 20 53 51 4c 49 54 45 5f 43 4f 4e 46  .    SQLITE_CONF
3bf0: 49 47 5f 4d 45 4d 53 54 41 54 55 53 20 3d 20 39  IG_MEMSTATUS = 9
3c00: 2c 20 2f 2f 20 62 6f 6f 6c 65 61 6e 20 0d 0a 20  , // boolean .. 
3c10: 20 20 20 53 51 4c 49 54 45 5f 43 4f 4e 46 49 47     SQLITE_CONFIG
3c20: 5f 4d 55 54 45 58 20 3d 20 31 30 2c 20 2f 2f 20  _MUTEX = 10, // 
3c30: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6d 65  sqlite3_mutex_me
3c40: 74 68 6f 64 73 2a 20 0d 0a 20 20 20 20 53 51 4c  thods* ..    SQL
3c50: 49 54 45 5f 43 4f 4e 46 49 47 5f 47 45 54 4d 55  ITE_CONFIG_GETMU
3c60: 54 45 58 20 3d 20 31 31 2c 20 2f 2f 20 73 71 6c  TEX = 11, // sql
3c70: 69 74 65 33 5f 6d 75 74 65 78 5f 6d 65 74 68 6f  ite3_mutex_metho
3c80: 64 73 2a 20 0d 0a 20 20 20 20 2f 2f 20 70 72 65  ds* ..    // pre
3c90: 76 69 6f 75 73 6c 79 20 53 51 4c 49 54 45 5f 43  viously SQLITE_C
3ca0: 4f 4e 46 49 47 5f 43 48 55 4e 4b 41 4c 4c 4f 43  ONFIG_CHUNKALLOC
3cb0: 20 31 32 20 77 68 69 63 68 20 69 73 20 6e 6f 77   12 which is now
3cc0: 20 75 6e 75 73 65 64 0d 0a 20 20 20 20 53 51 4c   unused..    SQL
3cd0: 49 54 45 5f 43 4f 4e 46 49 47 5f 4c 4f 4f 4b 41  ITE_CONFIG_LOOKA
3ce0: 53 49 44 45 20 3d 20 31 33 2c 20 2f 2f 20 69 6e  SIDE = 13, // in
3cf0: 74 20 69 6e 74 20 0d 0a 20 20 20 20 53 51 4c 49  t int ..    SQLI
3d00: 54 45 5f 43 4f 4e 46 49 47 5f 50 43 41 43 48 45  TE_CONFIG_PCACHE
3d10: 20 3d 20 31 34 2c 20 2f 2f 20 73 71 6c 69 74 65   = 14, // sqlite
3d20: 33 5f 70 63 61 63 68 65 5f 6d 65 74 68 6f 64 73  3_pcache_methods
3d30: 2a 20 0d 0a 20 20 20 20 53 51 4c 49 54 45 5f 43  * ..    SQLITE_C
3d40: 4f 4e 46 49 47 5f 47 45 54 50 43 41 43 48 45 20  ONFIG_GETPCACHE 
3d50: 3d 20 31 35 2c 20 2f 2f 20 73 71 6c 69 74 65 33  = 15, // sqlite3
3d60: 5f 70 63 61 63 68 65 5f 6d 65 74 68 6f 64 73 2a  _pcache_methods*
3d70: 20 0d 0a 20 20 20 20 53 51 4c 49 54 45 5f 43 4f   ..    SQLITE_CO
3d80: 4e 46 49 47 5f 4c 4f 47 20 3d 20 31 36 2c 20 2f  NFIG_LOG = 16, /
3d90: 2f 20 78 46 75 6e 63 2c 20 76 6f 69 64 2a 20 0d  / xFunc, void* .
3da0: 0a 20 20 7d 0d 0a 0d 0a 7d 0d 0a                 .  }....}..