System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 465d2854b94cf84cba19c804a34760fe1d9316e4:


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 52 75 6e 74 69 6d 65 2e 49 6e 74 65 72 6f 70  .Runtime.Interop
0170: 53 65 72 76 69 63 65 73 3b 0a 20 20 75 73 69 6e  Services;.  usin
0180: 67 20 53 79 73 74 65 6d 2e 43 6f 6c 6c 65 63 74  g System.Collect
0190: 69 6f 6e 73 2e 47 65 6e 65 72 69 63 3b 0a 0a 20  ions.Generic;.. 
01a0: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
01b0: 20 2f 2f 2f 20 54 68 69 73 20 63 6c 61 73 73 20   /// This class 
01c0: 69 6d 70 6c 65 6d 65 6e 74 73 20 53 51 4c 69 74  implements SQLit
01d0: 65 42 61 73 65 20 63 6f 6d 70 6c 65 74 65 6c 79  eBase completely
01e0: 2c 20 61 6e 64 20 69 73 20 74 68 65 20 67 75 74  , and is the gut
01f0: 73 20 6f 66 20 74 68 65 20 63 6f 64 65 20 74 68  s of the code th
0200: 61 74 20 69 6e 74 65 72 6f 70 27 73 20 53 51 4c  at interop's SQL
0210: 69 74 65 20 77 69 74 68 20 2e 4e 45 54 0a 20 20  ite with .NET.  
0220: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
0230: 20 69 6e 74 65 72 6e 61 6c 20 63 6c 61 73 73 20   internal class 
0240: 53 51 4c 69 74 65 33 20 3a 20 53 51 4c 69 74 65  SQLite3 : SQLite
0250: 42 61 73 65 0a 20 20 7b 0a 20 20 20 20 2f 2f 2f  Base.  {.    ///
0260: 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f   <summary>.    /
0270: 2f 2f 20 54 68 65 20 6f 70 61 71 75 65 20 70 6f  // The opaque po
0280: 69 6e 74 65 72 20 72 65 74 75 72 6e 65 64 20 74  inter returned t
0290: 6f 20 75 73 20 62 79 20 74 68 65 20 73 71 6c 69  o us by the sqli
02a0: 74 65 20 70 72 6f 76 69 64 65 72 0a 20 20 20 20  te provider.    
02b0: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20  /// </summary>. 
02c0: 20 20 20 70 72 6f 74 65 63 74 65 64 20 69 6e 74     protected int
02d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5f 73                _s
02e0: 71 6c 3b 0a 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  ql;..    /// <su
02f0: 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 54  mmary>.    /// T
0300: 68 65 20 75 73 65 72 2d 64 65 66 69 6e 65 64 20  he user-defined 
0310: 66 75 6e 63 74 69 6f 6e 73 20 72 65 67 69 73 74  functions regist
0320: 65 72 65 64 20 6f 6e 20 74 68 69 73 20 63 6f 6e  ered on this con
0330: 6e 65 63 74 69 6f 6e 0a 20 20 20 20 2f 2f 2f 20  nection.    /// 
0340: 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70  </summary>.    p
0350: 72 6f 74 65 63 74 65 64 20 53 51 4c 69 74 65 46  rotected SQLiteF
0360: 75 6e 63 74 69 6f 6e 5b 5d 20 5f 66 75 6e 63 74  unction[] _funct
0370: 69 6f 6e 73 41 72 72 61 79 3b 0a 0a 20 20 20 20  ionsArray;..    
0380: 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74 65 33  internal SQLite3
0390: 28 44 61 74 65 54 69 6d 65 46 6f 72 6d 61 74 20  (DateTimeFormat 
03a0: 66 6d 74 29 0a 20 20 20 20 20 20 3a 20 62 61 73  fmt).      : bas
03b0: 65 28 66 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20  e(fmt).    {.   
03c0: 20 20 20 5f 73 71 6c 20 3d 20 30 3b 0a 20 20 20     _sql = 0;.   
03d0: 20 20 20 5f 66 75 6e 63 74 69 6f 6e 73 41 72 72     _functionsArr
03e0: 61 79 20 3d 20 6e 75 6c 6c 3b 0a 20 20 20 20 7d  ay = null;.    }
03f0: 0a 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64 20  ..    protected 
0400: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 44 69  override void Di
0410: 73 70 6f 73 65 28 62 6f 6f 6c 20 62 44 69 73 70  spose(bool bDisp
0420: 6f 73 69 6e 67 29 0a 20 20 20 20 7b 0a 20 20 20  osing).    {.   
0430: 20 20 20 43 6c 6f 73 65 28 29 3b 0a 20 20 20 20     Close();.    
0440: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
0450: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 43 6c  override void Cl
0460: 6f 73 65 28 29 0a 20 20 20 20 7b 0a 20 20 20 20  ose().    {.    
0470: 20 20 69 66 20 28 5f 73 71 6c 20 21 3d 20 30 29    if (_sql != 0)
0480: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
0490: 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e   int n = UnsafeN
04a0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
04b0: 69 74 65 33 5f 63 6c 6f 73 65 5f 69 6e 74 65 72  ite3_close_inter
04c0: 6f 70 28 5f 73 71 6c 29 3b 0a 20 20 20 20 20 20  op(_sql);.      
04d0: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
04e0: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
04f0: 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65  eption(n, SQLite
0500: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a 20 20  LastError());.  
0510: 20 20 20 20 20 20 53 51 4c 69 74 65 46 75 6e 63        SQLiteFunc
0520: 74 69 6f 6e 2e 55 6e 62 69 6e 64 46 75 6e 63 74  tion.UnbindFunct
0530: 69 6f 6e 73 28 74 68 69 73 2c 20 5f 66 75 6e 63  ions(this, _func
0540: 74 69 6f 6e 73 41 72 72 61 79 29 3b 0a 20 20 20  tionsArray);.   
0550: 20 20 20 7d 0a 20 20 20 20 20 20 5f 73 71 6c 20     }.      _sql 
0560: 3d 20 30 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  = 0;.    }..    
0570: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
0580: 65 20 76 6f 69 64 20 43 61 6e 63 65 6c 28 29 0a  e void Cancel().
0590: 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61      {.      Unsa
05a0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
05b0: 73 71 6c 69 74 65 33 5f 69 6e 74 65 72 72 75 70  sqlite3_interrup
05c0: 74 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 29 3b  t_interop(_sql);
05d0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
05e0: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74  rnal override st
05f0: 72 69 6e 67 20 56 65 72 73 69 6f 6e 0a 20 20 20  ring Version.   
0600: 20 7b 0a 20 20 20 20 20 20 67 65 74 0a 20 20 20   {.      get.   
0610: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69 6e 74     {.        int
0620: 20 6c 65 6e 3b 0a 20 20 20 20 20 20 20 20 72 65   len;.        re
0630: 74 75 72 6e 20 54 6f 53 74 72 69 6e 67 28 55 6e  turn ToString(Un
0640: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
0650: 73 2e 73 71 6c 69 74 65 33 5f 6c 69 62 76 65 72  s.sqlite3_libver
0660: 73 69 6f 6e 5f 69 6e 74 65 72 6f 70 28 6f 75 74  sion_interop(out
0670: 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0a 20 20 20   len), len);.   
0680: 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20     }.    }..    
0690: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
06a0: 65 20 69 6e 74 20 43 68 61 6e 67 65 73 0a 20 20  e int Changes.  
06b0: 20 20 7b 0a 20 20 20 20 20 20 67 65 74 0a 20 20    {.      get.  
06c0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 72 65      {.        re
06d0: 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76  turn UnsafeNativ
06e0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
06f0: 5f 63 68 61 6e 67 65 73 5f 69 6e 74 65 72 6f 70  _changes_interop
0700: 28 5f 73 71 6c 29 3b 0a 20 20 20 20 20 20 7d 0a  (_sql);.      }.
0710: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
0720: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
0730: 64 20 4f 70 65 6e 28 73 74 72 69 6e 67 20 73 74  d Open(string st
0740: 72 46 69 6c 65 6e 61 6d 65 29 0a 20 20 20 20 7b  rFilename).    {
0750: 0a 20 20 20 20 20 20 69 66 20 28 5f 73 71 6c 20  .      if (_sql 
0760: 21 3d 20 30 29 20 72 65 74 75 72 6e 3b 0a 20 20  != 0) return;.  
0770: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
0780: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
0790: 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f 69 6e 74  sqlite3_open_int
07a0: 65 72 6f 70 28 54 6f 55 54 46 38 28 73 74 72 46  erop(ToUTF8(strF
07b0: 69 6c 65 6e 61 6d 65 29 2c 20 6f 75 74 20 5f 73  ilename), out _s
07c0: 71 6c 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e  ql);.      if (n
07d0: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
07e0: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
07f0: 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72  n, SQLiteLastErr
0800: 6f 72 28 29 29 3b 0a 0a 20 20 20 20 20 20 5f 66  or());..      _f
0810: 75 6e 63 74 69 6f 6e 73 41 72 72 61 79 20 3d 20  unctionsArray = 
0820: 53 51 4c 69 74 65 46 75 6e 63 74 69 6f 6e 2e 42  SQLiteFunction.B
0830: 69 6e 64 46 75 6e 63 74 69 6f 6e 73 28 74 68 69  indFunctions(thi
0840: 73 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  s);.    }..    i
0850: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
0860: 20 76 6f 69 64 20 53 65 74 54 69 6d 65 6f 75 74   void SetTimeout
0870: 28 69 6e 74 20 6e 54 69 6d 65 6f 75 74 4d 53 29  (int nTimeoutMS)
0880: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74  .    {.      int
0890: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
08a0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
08b0: 5f 62 75 73 79 5f 74 69 6d 65 6f 75 74 5f 69 6e  _busy_timeout_in
08c0: 74 65 72 6f 70 28 5f 73 71 6c 2c 20 6e 54 69 6d  terop(_sql, nTim
08d0: 65 6f 75 74 4d 53 29 3b 0a 20 20 20 20 20 20 69  eoutMS);.      i
08e0: 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20  f (n > 0) throw 
08f0: 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74  new SQLiteExcept
0900: 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73  ion(n, SQLiteLas
0910: 74 45 72 72 6f 72 28 29 29 3b 0a 20 20 20 20 7d  tError());.    }
0920: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
0930: 76 65 72 72 69 64 65 20 76 6f 69 64 20 45 78 65  verride void Exe
0940: 63 75 74 65 28 73 74 72 69 6e 67 20 73 74 72 53  cute(string strS
0950: 71 6c 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  ql).    {.      
0960: 49 6e 74 50 74 72 20 70 3b 0a 20 20 20 20 20 20  IntPtr p;.      
0970: 73 74 72 69 6e 67 20 73 74 72 20 3d 20 73 74 72  string str = str
0980: 53 71 6c 3b 0a 20 20 20 20 20 20 69 6e 74 20 6c  Sql;.      int l
0990: 65 6e 3b 0a 0a 20 20 20 20 20 20 69 6e 74 20 6e  en;..      int n
09a0: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
09b0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 65  ethods.sqlite3_e
09c0: 78 65 63 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c  xec_interop(_sql
09d0: 2c 20 54 6f 55 54 46 38 28 73 74 72 53 71 6c 29  , ToUTF8(strSql)
09e0: 2c 20 30 2c 20 30 2c 20 6f 75 74 20 70 2c 20 6f  , 0, 0, out p, o
09f0: 75 74 20 6c 65 6e 29 3b 0a 20 20 20 20 20 20 69  ut len);.      i
0a00: 66 20 28 70 20 21 3d 20 49 6e 74 50 74 72 2e 5a  f (p != IntPtr.Z
0a10: 65 72 6f 29 0a 20 20 20 20 20 20 7b 0a 20 20 20  ero).      {.   
0a20: 20 20 20 20 20 73 74 72 20 3d 20 54 6f 53 74 72       str = ToStr
0a30: 69 6e 67 28 70 2c 20 6c 65 6e 29 3b 0a 20 20 20  ing(p, len);.   
0a40: 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76       UnsafeNativ
0a50: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
0a60: 5f 66 72 65 65 5f 69 6e 74 65 72 6f 70 28 70 29  _free_interop(p)
0a70: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
0a80: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
0a90: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
0aa0: 74 69 6f 6e 28 6e 2c 20 73 74 72 29 3b 0a 20 20  tion(n, str);.  
0ab0: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
0ac0: 6c 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20  l override bool 
0ad0: 53 74 65 70 28 53 51 4c 69 74 65 53 74 61 74 65  Step(SQLiteState
0ae0: 6d 65 6e 74 20 73 74 6d 74 29 0a 20 20 20 20 7b  ment stmt).    {
0af0: 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b 0a 0a 20  .      int n;.. 
0b00: 20 20 20 20 20 77 68 69 6c 65 20 28 74 72 75 65       while (true
0b10: 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  ).      {.      
0b20: 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69    n = UnsafeNati
0b30: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
0b40: 33 5f 73 74 65 70 5f 69 6e 74 65 72 6f 70 28 73  3_step_interop(s
0b50: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
0b60: 29 3b 0a 0a 20 20 20 20 20 20 20 20 69 66 20 28  );..        if (
0b70: 6e 20 3d 3d 20 31 30 30 29 20 72 65 74 75 72 6e  n == 100) return
0b80: 20 74 72 75 65 3b 0a 20 20 20 20 20 20 20 20 69   true;.        i
0b90: 66 20 28 6e 20 3d 3d 20 31 30 31 29 20 72 65 74  f (n == 101) ret
0ba0: 75 72 6e 20 66 61 6c 73 65 3b 0a 0a 20 20 20 20  urn false;..    
0bb0: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 0a 20      if (n > 0). 
0bc0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
0bd0: 20 20 20 2f 2f 20 41 6e 20 65 72 72 6f 72 20 6f     // An error o
0be0: 63 63 75 72 72 65 64 2c 20 61 74 74 65 6d 70 74  ccurred, attempt
0bf0: 20 74 6f 20 72 65 73 65 74 20 74 68 65 20 73 74   to reset the st
0c00: 61 74 65 6d 65 6e 74 2e 20 20 49 66 20 74 68 65  atement.  If the
0c10: 20 72 65 73 65 74 20 77 6f 72 6b 65 64 20 62 65   reset worked be
0c20: 63 61 75 73 65 20 74 68 65 0a 20 20 20 20 20 20  cause the.      
0c30: 20 20 20 20 2f 2f 20 73 63 68 65 6d 61 20 68 61      // schema ha
0c40: 73 20 63 68 61 6e 67 65 64 2c 20 72 65 2d 74 72  s changed, re-tr
0c50: 79 20 74 68 65 20 73 74 65 70 20 61 67 61 69 6e  y the step again
0c60: 2e 20 20 4f 74 68 65 72 77 69 73 65 20 74 68 72  .  Otherwise thr
0c70: 6f 77 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20  ow the original 
0c80: 65 72 72 6f 72 2e 0a 20 20 20 20 20 20 20 20 20  error..         
0c90: 20 73 74 72 69 6e 67 20 73 74 72 20 3d 20 53 51   string str = SQ
0ca0: 4c 69 74 65 4c 61 73 74 45 72 72 6f 72 28 29 3b  LiteLastError();
0cb0: 0a 20 20 20 20 20 20 20 20 20 20 0a 20 20 20 20  .          .    
0cc0: 20 20 20 20 20 20 69 66 20 28 52 65 73 65 74 28        if (Reset(
0cd0: 73 74 6d 74 29 20 3d 3d 20 66 61 6c 73 65 29 0a  stmt) == false).
0ce0: 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72 6f              thro
0cf0: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
0d00: 70 74 69 6f 6e 28 6e 2c 20 73 74 72 29 3b 0a 20  ption(n, str);. 
0d10: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
0d20: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
0d30: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f  rnal override vo
0d40: 69 64 20 46 69 6e 61 6c 69 7a 65 28 53 51 4c 69  id Finalize(SQLi
0d50: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
0d60: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 66  ).    {.      if
0d70: 20 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73   (stmt._sqlite_s
0d80: 74 6d 74 20 3e 20 30 29 0a 20 20 20 20 20 20 7b  tmt > 0).      {
0d90: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  .        int n =
0da0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
0db0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 66 69 6e  hods.sqlite3_fin
0dc0: 61 6c 69 7a 65 5f 69 6e 74 65 72 6f 70 28 73 74  alize_interop(st
0dd0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29  mt._sqlite_stmt)
0de0: 3b 0a 20 20 20 20 20 20 20 20 69 66 20 28 6e 20  ;.        if (n 
0df0: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
0e00: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
0e10: 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f  , SQLiteLastErro
0e20: 72 28 29 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  r());.      }.  
0e30: 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65      stmt._sqlite
0e40: 5f 73 74 6d 74 20 3d 20 30 3b 0a 20 20 20 20 7d  _stmt = 0;.    }
0e50: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
0e60: 76 65 72 72 69 64 65 20 62 6f 6f 6c 20 52 65 73  verride bool Res
0e70: 65 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  et(SQLiteStateme
0e80: 6e 74 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20  nt stmt).    {. 
0e90: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73       int n = Uns
0ea0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
0eb0: 2e 73 71 6c 69 74 65 33 5f 72 65 73 65 74 5f 69  .sqlite3_reset_i
0ec0: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
0ed0: 69 74 65 5f 73 74 6d 74 29 3b 0a 0a 20 20 20 20  ite_stmt);..    
0ee0: 20 20 2f 2f 20 49 66 20 74 68 65 20 73 63 68 65    // If the sche
0ef0: 6d 61 20 63 68 61 6e 67 65 64 2c 20 74 72 79 20  ma changed, try 
0f00: 61 6e 64 20 72 65 2d 70 72 65 70 61 72 65 20 69  and re-prepare i
0f10: 74 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3d 3d  t.      if (n ==
0f20: 20 31 37 29 20 2f 2f 20 53 51 4c 49 54 45 5f 53   17) // SQLITE_S
0f30: 43 48 45 4d 41 0a 20 20 20 20 20 20 7b 0a 20 20  CHEMA.      {.  
0f40: 20 20 20 20 20 20 2f 2f 20 52 65 63 72 65 61 74        // Recreat
0f50: 65 20 61 20 64 75 6d 6d 79 20 73 74 61 74 65 6d  e a dummy statem
0f60: 65 6e 74 0a 20 20 20 20 20 20 20 20 69 6e 74 20  ent.        int 
0f70: 6e 63 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  nc = 0;.        
0f80: 73 74 72 69 6e 67 20 73 74 72 3b 0a 20 20 20 20  string str;.    
0f90: 20 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74      using (SQLit
0fa0: 65 53 74 61 74 65 6d 65 6e 74 20 74 6d 70 20 3d  eStatement tmp =
0fb0: 20 50 72 65 70 61 72 65 28 73 74 6d 74 2e 5f 73   Prepare(stmt._s
0fc0: 71 6c 53 74 61 74 65 6d 65 6e 74 2c 20 72 65 66  qlStatement, ref
0fd0: 20 6e 63 2c 20 6f 75 74 20 73 74 72 29 29 0a 20   nc, out str)). 
0fe0: 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20         {.       
0ff0: 20 20 20 2f 2f 20 46 69 6e 61 6c 69 7a 65 20 74     // Finalize t
1000: 68 65 20 65 78 69 73 74 69 6e 67 20 73 74 61 74  he existing stat
1010: 65 6d 65 6e 74 0a 20 20 20 20 20 20 20 20 20 20  ement.          
1020: 46 69 6e 61 6c 69 7a 65 28 73 74 6d 74 29 3b 0a  Finalize(stmt);.
1030: 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20 52 65  .          // Re
1040: 61 73 73 69 67 6e 20 61 20 6e 65 77 20 73 74 61  assign a new sta
1050: 74 65 6d 65 6e 74 20 70 6f 69 6e 74 65 72 20 74  tement pointer t
1060: 6f 20 74 68 65 20 6f 6c 64 20 73 74 61 74 65 6d  o the old statem
1070: 65 6e 74 20 61 6e 64 20 63 6c 65 61 72 20 74 68  ent and clear th
1080: 65 20 74 65 6d 70 6f 72 61 72 79 20 6f 6e 65 0a  e temporary one.
1090: 20 20 20 20 20 20 20 20 20 20 73 74 6d 74 2e 5f            stmt._
10a0: 73 71 6c 69 74 65 5f 73 74 6d 74 20 3d 20 74 6d  sqlite_stmt = tm
10b0: 70 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 3b 0a  p._sqlite_stmt;.
10c0: 20 20 20 20 20 20 20 20 20 20 74 6d 70 2e 5f 73            tmp._s
10d0: 71 6c 69 74 65 5f 73 74 6d 74 20 3d 20 30 3b 0a  qlite_stmt = 0;.
10e0: 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20 52 65  .          // Re
10f0: 61 70 70 6c 79 20 70 61 72 61 6d 65 74 65 72 73  apply parameters
1100: 0a 20 20 20 20 20 20 20 20 20 20 73 74 6d 74 2e  .          stmt.
1110: 42 69 6e 64 50 61 72 61 6d 65 74 65 72 73 28 29  BindParameters()
1120: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
1130: 20 20 20 20 72 65 74 75 72 6e 20 74 72 75 65 3b      return true;
1140: 20 2f 2f 20 52 65 73 65 74 20 77 61 73 20 4f 4b   // Reset was OK
1150: 2c 20 77 69 74 68 20 73 63 68 65 6d 61 20 63 68  , with schema ch
1160: 61 6e 67 65 0a 20 20 20 20 20 20 7d 0a 0a 20 20  ange.      }..  
1170: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 0a 20      if (n > 0). 
1180: 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77         throw new
1190: 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e   SQLiteException
11a0: 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72  (n, SQLiteLastEr
11b0: 72 6f 72 28 29 29 3b 0a 0a 20 20 20 20 20 20 72  ror());..      r
11c0: 65 74 75 72 6e 20 66 61 6c 73 65 3b 20 2f 2f 20  eturn false; // 
11d0: 57 65 20 72 65 73 65 74 20 4f 4b 2c 20 6e 6f 20  We reset OK, no 
11e0: 73 63 68 65 6d 61 20 63 68 61 6e 67 65 73 0a 20  schema changes. 
11f0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
1200: 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72 69  al override stri
1210: 6e 67 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72  ng SQLiteLastErr
1220: 6f 72 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  or().    {.     
1230: 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20   int len;.      
1240: 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e 67 28  return ToString(
1250: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
1260: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 65 72 72 6d  ods.sqlite3_errm
1270: 73 67 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c  sg_interop(_sql,
1280: 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b   out len), len);
1290: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
12a0: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 53 51  rnal override SQ
12b0: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 50 72  LiteStatement Pr
12c0: 65 70 61 72 65 28 73 74 72 69 6e 67 20 73 74 72  epare(string str
12d0: 53 71 6c 2c 20 72 65 66 20 69 6e 74 20 6e 50 61  Sql, ref int nPa
12e0: 72 61 6d 53 74 61 72 74 2c 20 6f 75 74 20 73 74  ramStart, out st
12f0: 72 69 6e 67 20 73 74 72 52 65 6d 61 69 6e 29 0a  ring strRemain).
1300: 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20      {.      int 
1310: 73 74 6d 74 3b 0a 20 20 20 20 20 20 49 6e 74 50  stmt;.      IntP
1320: 74 72 20 70 74 72 3b 0a 20 20 20 20 20 20 69 6e  tr ptr;.      in
1330: 74 20 6c 65 6e 3b 0a 0a 20 20 20 20 20 20 62 79  t len;..      by
1340: 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54 46 38 28  te[] b = ToUTF8(
1350: 73 74 72 53 71 6c 29 3b 0a 0a 20 20 20 20 20 20  strSql);..      
1360: 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61  int n = UnsafeNa
1370: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
1380: 74 65 33 5f 70 72 65 70 61 72 65 5f 69 6e 74 65  te3_prepare_inte
1390: 72 6f 70 28 5f 73 71 6c 2c 20 62 2c 20 62 2e 4c  rop(_sql, b, b.L
13a0: 65 6e 67 74 68 20 2d 20 31 2c 20 6f 75 74 20 73  ength - 1, out s
13b0: 74 6d 74 2c 20 6f 75 74 20 70 74 72 2c 20 6f 75  tmt, out ptr, ou
13c0: 74 20 6c 65 6e 29 3b 0a 20 20 20 20 20 20 69 66  t len);.      if
13d0: 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e   (n > 0) throw n
13e0: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
13f0: 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74  on(n, SQLiteLast
1400: 45 72 72 6f 72 28 29 29 3b 0a 0a 20 20 20 20 20  Error());..     
1410: 20 73 74 72 52 65 6d 61 69 6e 20 3d 20 54 6f 53   strRemain = ToS
1420: 74 72 69 6e 67 28 70 74 72 2c 20 6c 65 6e 29 3b  tring(ptr, len);
1430: 0a 0a 20 20 20 20 20 20 53 51 4c 69 74 65 53 74  ..      SQLiteSt
1440: 61 74 65 6d 65 6e 74 20 63 6d 64 20 3d 20 6e 75  atement cmd = nu
1450: 6c 6c 3b 0a 20 20 20 20 20 20 69 66 20 28 73 74  ll;.      if (st
1460: 6d 74 20 3e 20 30 29 20 63 6d 64 20 3d 20 6e 65  mt > 0) cmd = ne
1470: 77 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  w SQLiteStatemen
1480: 74 28 74 68 69 73 2c 20 73 74 6d 74 2c 20 73 74  t(this, stmt, st
1490: 72 53 71 6c 2e 53 75 62 73 74 72 69 6e 67 28 30  rSql.Substring(0
14a0: 2c 20 73 74 72 53 71 6c 2e 4c 65 6e 67 74 68 20  , strSql.Length 
14b0: 2d 20 73 74 72 52 65 6d 61 69 6e 2e 4c 65 6e 67  - strRemain.Leng
14c0: 74 68 29 2c 20 72 65 66 20 6e 50 61 72 61 6d 53  th), ref nParamS
14d0: 74 61 72 74 29 3b 0a 0a 20 20 20 20 20 20 72 65  tart);..      re
14e0: 74 75 72 6e 20 63 6d 64 3b 0a 20 20 20 20 7d 0a  turn cmd;.    }.
14f0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
1500: 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64  erride void Bind
1510: 5f 44 6f 75 62 6c 65 28 53 51 4c 69 74 65 53 74  _Double(SQLiteSt
1520: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
1530: 74 20 69 6e 64 65 78 2c 20 64 6f 75 62 6c 65 20  t index, double 
1540: 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20  value).    {.   
1550: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
1560: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
1570: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62  qlite3_bind_doub
1580: 6c 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  le_interop(stmt.
1590: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e  _sqlite_stmt, in
15a0: 64 65 78 2c 20 72 65 66 20 76 61 6c 75 65 29 3b  dex, ref value);
15b0: 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30  .      if (n > 0
15c0: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
15d0: 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53  teException(n, S
15e0: 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72 28 29  QLiteLastError()
15f0: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
1600: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
1610: 76 6f 69 64 20 42 69 6e 64 5f 49 6e 74 33 32 28  void Bind_Int32(
1620: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
1630: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c  stmt, int index,
1640: 20 69 6e 74 20 76 61 6c 75 65 29 0a 20 20 20 20   int value).    
1650: 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  {.      int n = 
1660: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
1670: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
1680: 5f 69 6e 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d  _int_interop(stm
1690: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
16a0: 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0a 20  index, value);. 
16b0: 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20       if (n > 0) 
16c0: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
16d0: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c  Exception(n, SQL
16e0: 69 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b  iteLastError());
16f0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
1700: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f  rnal override vo
1710: 69 64 20 42 69 6e 64 5f 49 6e 74 36 34 28 53 51  id Bind_Int64(SQ
1720: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
1730: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 6c  mt, int index, l
1740: 6f 6e 67 20 76 61 6c 75 65 29 0a 20 20 20 20 7b  ong value).    {
1750: 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55  .      int n = U
1760: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
1770: 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  ds.sqlite3_bind_
1780: 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 73 74  int64_interop(st
1790: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
17a0: 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c 75   index, ref valu
17b0: 65 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20  e);.      if (n 
17c0: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
17d0: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
17e0: 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f  , SQLiteLastErro
17f0: 72 28 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  r());.    }..   
1800: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
1810: 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 54 65 78  de void Bind_Tex
1820: 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  t(SQLiteStatemen
1830: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
1840: 78 2c 20 73 74 72 69 6e 67 20 76 61 6c 75 65 29  x, string value)
1850: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 62 79 74  .    {.      byt
1860: 65 5b 5d 20 62 20 3d 20 54 6f 55 54 46 38 28 76  e[] b = ToUTF8(v
1870: 61 6c 75 65 29 3b 0a 20 20 20 20 20 20 69 6e 74  alue);.      int
1880: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
1890: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
18a0: 5f 62 69 6e 64 5f 74 65 78 74 5f 69 6e 74 65 72  _bind_text_inter
18b0: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
18c0: 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 62 2c 20  stmt, index, b, 
18d0: 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20 2d 31  b.Length - 1, -1
18e0: 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e  );.      if (n >
18f0: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
1900: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
1910: 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72   SQLiteLastError
1920: 28 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ());.    }..    
1930: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
1940: 65 20 76 6f 69 64 20 42 69 6e 64 5f 44 61 74 65  e void Bind_Date
1950: 54 69 6d 65 28 53 51 4c 69 74 65 53 74 61 74 65  Time(SQLiteState
1960: 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69  ment stmt, int i
1970: 6e 64 65 78 2c 20 44 61 74 65 54 69 6d 65 20 64  ndex, DateTime d
1980: 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 62  t).    {.      b
1990: 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54 46 38  yte[] b = ToUTF8
19a0: 28 64 74 29 3b 0a 20 20 20 20 20 20 69 6e 74 20  (dt);.      int 
19b0: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
19c0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
19d0: 62 69 6e 64 5f 74 65 78 74 5f 69 6e 74 65 72 6f  bind_text_intero
19e0: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
19f0: 74 6d 74 2c 20 69 6e 64 65 78 2c 20 62 2c 20 62  tmt, index, b, b
1a00: 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20 2d 31 29  .Length - 1, -1)
1a10: 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20  ;.      if (n > 
1a20: 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c  0) throw new SQL
1a30: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
1a40: 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72 28  SQLiteLastError(
1a50: 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  ));.    }..    i
1a60: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1a70: 20 76 6f 69 64 20 42 69 6e 64 5f 42 6c 6f 62 28   void Bind_Blob(
1a80: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
1a90: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c  stmt, int index,
1aa0: 20 62 79 74 65 5b 5d 20 62 6c 6f 62 44 61 74 61   byte[] blobData
1ab0: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e  ).    {.      in
1ac0: 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  t n = UnsafeNati
1ad0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1ae0: 33 5f 62 69 6e 64 5f 62 6c 6f 62 5f 69 6e 74 65  3_bind_blob_inte
1af0: 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  rop(stmt._sqlite
1b00: 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 62 6c  _stmt, index, bl
1b10: 6f 62 44 61 74 61 2c 20 62 6c 6f 62 44 61 74 61  obData, blobData
1b20: 2e 4c 65 6e 67 74 68 2c 20 2d 31 29 3b 0a 20 20  .Length, -1);.  
1b30: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
1b40: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
1b50: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69  xception(n, SQLi
1b60: 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a  teLastError());.
1b70: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
1b80: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
1b90: 64 20 42 69 6e 64 5f 4e 75 6c 6c 28 53 51 4c 69  d Bind_Null(SQLi
1ba0: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
1bb0: 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20  , int index).   
1bc0: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d   {.      int n =
1bd0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
1be0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
1bf0: 64 5f 6e 75 6c 6c 5f 69 6e 74 65 72 6f 70 28 73  d_null_interop(s
1c00: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
1c10: 2c 20 69 6e 64 65 78 29 3b 0a 20 20 20 20 20 20  , index);.      
1c20: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
1c30: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
1c40: 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61  tion(n, SQLiteLa
1c50: 73 74 45 72 72 6f 72 28 29 29 3b 0a 20 20 20 20  stError());.    
1c60: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
1c70: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 42 69 6e  override int Bin
1c80: 64 5f 50 61 72 61 6d 43 6f 75 6e 74 28 53 51 4c  d_ParamCount(SQL
1c90: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
1ca0: 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  t).    {.      r
1cb0: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
1cc0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1cd0: 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72  3_bind_parameter
1ce0: 5f 63 6f 75 6e 74 5f 69 6e 74 65 72 6f 70 28 73  _count_interop(s
1cf0: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
1d00: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
1d10: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
1d20: 73 74 72 69 6e 67 20 42 69 6e 64 5f 50 61 72 61  string Bind_Para
1d30: 6d 4e 61 6d 65 28 53 51 4c 69 74 65 53 74 61 74  mName(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 0a 20 20 20 20 7b 0a 20 20 20  index).    {.   
1d60: 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20     int len;.    
1d70: 20 20 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e    return ToStrin
1d80: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
1d90: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69  thods.sqlite3_bi
1da0: 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f 6e 61 6d  nd_parameter_nam
1db0: 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  e_interop(stmt._
1dc0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
1dd0: 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65  ex, out len), le
1de0: 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  n);.    }..    i
1df0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1e00: 20 69 6e 74 20 42 69 6e 64 5f 50 61 72 61 6d 49   int Bind_ParamI
1e10: 6e 64 65 78 28 53 51 4c 69 74 65 53 74 61 74 65  ndex(SQLiteState
1e20: 6d 65 6e 74 20 73 74 6d 74 2c 20 73 74 72 69 6e  ment stmt, strin
1e30: 67 20 70 61 72 61 6d 4e 61 6d 65 29 0a 20 20 20  g paramName).   
1e40: 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20   {.      return 
1e50: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
1e60: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
1e70: 5f 70 61 72 61 6d 65 74 65 72 5f 69 6e 64 65 78  _parameter_index
1e80: 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73  _interop(stmt._s
1e90: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 54 6f 55 54  qlite_stmt, ToUT
1ea0: 46 38 28 70 61 72 61 6d 4e 61 6d 65 29 29 3b 0a  F8(paramName));.
1eb0: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
1ec0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
1ed0: 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74 28 53 51 4c   ColumnCount(SQL
1ee0: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
1ef0: 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  t).    {.      r
1f00: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
1f10: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1f20: 33 5f 63 6f 6c 75 6d 6e 5f 63 6f 75 6e 74 5f 69  3_column_count_i
1f30: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
1f40: 69 74 65 5f 73 74 6d 74 29 3b 0a 20 20 20 20 7d  ite_stmt);.    }
1f50: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
1f60: 76 65 72 72 69 64 65 20 73 74 72 69 6e 67 20 43  verride string C
1f70: 6f 6c 75 6d 6e 4e 61 6d 65 28 53 51 4c 69 74 65  olumnName(SQLite
1f80: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
1f90: 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20 7b  int index).    {
1fa0: 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a  .      int len;.
1fb0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 53        return ToS
1fc0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
1fd0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1fe0: 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 5f 69 6e  3_column_name_in
1ff0: 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69  terop(stmt._sqli
2000: 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20  te_stmt, index, 
2010: 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0a  out len), len);.
2020: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
2030: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72  nal override str
2040: 69 6e 67 20 43 6f 6c 75 6d 6e 54 79 70 65 28 53  ing ColumnType(S
2050: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73  QLiteStatement s
2060: 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20  tmt, int index, 
2070: 6f 75 74 20 54 79 70 65 41 66 66 69 6e 69 74 79  out TypeAffinity
2080: 20 6e 41 66 66 69 6e 69 74 79 29 0a 20 20 20 20   nAffinity).    
2090: 7b 0a 20 20 20 20 20 20 6e 41 66 66 69 6e 69 74  {.      nAffinit
20a0: 79 20 3d 20 54 79 70 65 41 66 66 69 6e 69 74 79  y = TypeAffinity
20b0: 2e 4e 6f 6e 65 3b 0a 0a 20 20 20 20 20 20 69 6e  .None;..      in
20c0: 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20 49 6e 74  t len;.      Int
20d0: 50 74 72 20 70 20 3d 20 55 6e 73 61 66 65 4e 61  Ptr p = UnsafeNa
20e0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
20f0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74  te3_column_declt
2100: 79 70 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74  ype_interop(stmt
2110: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
2120: 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 3b 0a  ndex, out len);.
2130: 20 20 20 20 20 20 69 66 20 28 70 20 21 3d 20 49        if (p != I
2140: 6e 74 50 74 72 2e 5a 65 72 6f 29 20 72 65 74 75  ntPtr.Zero) retu
2150: 72 6e 20 54 6f 53 74 72 69 6e 67 28 70 2c 20 6c  rn ToString(p, l
2160: 65 6e 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 0a  en);.      else.
2170: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
2180: 6e 41 66 66 69 6e 69 74 79 20 3d 20 55 6e 73 61  nAffinity = Unsa
2190: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
21a0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74  sqlite3_column_t
21b0: 79 70 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74  ype_interop(stmt
21c0: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
21d0: 6e 64 65 78 29 3b 0a 20 20 20 20 20 20 20 20 73  ndex);.        s
21e0: 77 69 74 63 68 20 28 6e 41 66 66 69 6e 69 74 79  witch (nAffinity
21f0: 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20  ).        {.    
2200: 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65 41        case TypeA
2210: 66 66 69 6e 69 74 79 2e 49 6e 74 36 34 3a 0a 20  ffinity.Int64:. 
2220: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
2230: 6e 20 22 42 49 47 49 4e 54 22 3b 0a 20 20 20 20  n "BIGINT";.    
2240: 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65 41        case TypeA
2250: 66 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65 3a 0a  ffinity.Double:.
2260: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
2270: 72 6e 20 22 44 4f 55 42 4c 45 22 3b 0a 20 20 20  rn "DOUBLE";.   
2280: 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65         case Type
2290: 41 66 66 69 6e 69 74 79 2e 42 6c 6f 62 3a 0a 20  Affinity.Blob:. 
22a0: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
22b0: 6e 20 22 42 4c 4f 42 22 3b 0a 20 20 20 20 20 20  n "BLOB";.      
22c0: 20 20 20 20 64 65 66 61 75 6c 74 3a 0a 20 20 20      default:.   
22d0: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20           return 
22e0: 22 54 45 58 54 22 3b 0a 20 20 20 20 20 20 20 20  "TEXT";.        
22f0: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  }.      }.    }.
2300: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
2310: 65 72 72 69 64 65 20 69 6e 74 20 43 6f 6c 75 6d  erride int Colum
2320: 6e 49 6e 64 65 78 28 53 51 4c 69 74 65 53 74 61  nIndex(SQLiteSta
2330: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 73 74 72  tement stmt, str
2340: 69 6e 67 20 63 6f 6c 75 6d 6e 4e 61 6d 65 29 0a  ing columnName).
2350: 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20      {.      int 
2360: 78 20 3d 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74 28  x = ColumnCount(
2370: 73 74 6d 74 29 3b 0a 0a 20 20 20 20 20 20 66 6f  stmt);..      fo
2380: 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20 6e 20  r (int n = 0; n 
2390: 3c 20 78 3b 20 6e 2b 2b 29 0a 20 20 20 20 20 20  < x; n++).      
23a0: 7b 0a 20 20 20 20 20 20 20 20 69 66 20 28 53 74  {.        if (St
23b0: 72 69 6e 67 2e 43 6f 6d 70 61 72 65 28 63 6f 6c  ring.Compare(col
23c0: 75 6d 6e 4e 61 6d 65 2c 20 43 6f 6c 75 6d 6e 4e  umnName, ColumnN
23d0: 61 6d 65 28 73 74 6d 74 2c 20 6e 29 2c 20 74 72  ame(stmt, n), tr
23e0: 75 65 29 20 3d 3d 20 30 29 20 72 65 74 75 72 6e  ue) == 0) return
23f0: 20 6e 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20   n;.      }.    
2400: 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20 20    return -1;.   
2410: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
2420: 20 6f 76 65 72 72 69 64 65 20 64 6f 75 62 6c 65   override double
2430: 20 47 65 74 44 6f 75 62 6c 65 28 53 51 4c 69 74   GetDouble(SQLit
2440: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
2450: 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20   int index).    
2460: 7b 0a 20 20 20 20 20 20 64 6f 75 62 6c 65 20 76  {.      double v
2470: 61 6c 75 65 3b 0a 20 20 20 20 20 20 55 6e 73 61  alue;.      Unsa
2480: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
2490: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64  sqlite3_column_d
24a0: 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 73 74  ouble_interop(st
24b0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
24c0: 20 69 6e 64 65 78 2c 20 6f 75 74 20 76 61 6c 75   index, out valu
24d0: 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  e);.      return
24e0: 20 76 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20   value;.    }.. 
24f0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
2500: 72 69 64 65 20 69 6e 74 20 47 65 74 49 6e 74 33  ride int GetInt3
2510: 32 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  2(SQLiteStatemen
2520: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
2530: 78 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  x).    {.      r
2540: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
2550: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
2560: 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 5f 69 6e 74  3_column_int_int
2570: 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74  erop(stmt._sqlit
2580: 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0a  e_stmt, index);.
2590: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
25a0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e  nal override lon
25b0: 67 20 47 65 74 49 6e 74 36 34 28 53 51 4c 69 74  g GetInt64(SQLit
25c0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
25d0: 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20   int index).    
25e0: 7b 0a 20 20 20 20 20 20 6c 6f 6e 67 20 76 61 6c  {.      long val
25f0: 75 65 3b 0a 20 20 20 20 20 20 55 6e 73 61 66 65  ue;.      Unsafe
2600: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
2610: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74  lite3_column_int
2620: 36 34 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  64_interop(stmt.
2630: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e  _sqlite_stmt, in
2640: 64 65 78 2c 20 6f 75 74 20 76 61 6c 75 65 29 3b  dex, out value);
2650: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 76 61  .      return va
2660: 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  lue;.    }..    
2670: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
2680: 65 20 73 74 72 69 6e 67 20 47 65 74 54 65 78 74  e string GetText
2690: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
26a0: 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78   stmt, int index
26b0: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e  ).    {.      in
26c0: 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20 72 65 74  t len;.      ret
26d0: 75 72 6e 20 54 6f 53 74 72 69 6e 67 28 55 6e 73  urn ToString(Uns
26e0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
26f0: 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  .sqlite3_column_
2700: 74 65 78 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d  text_interop(stm
2710: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
2720: 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c  index, out len),
2730: 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20   len);.    }..  
2740: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2750: 69 64 65 20 44 61 74 65 54 69 6d 65 20 47 65 74  ide DateTime Get
2760: 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74 65 53  DateTime(SQLiteS
2770: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
2780: 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20 7b 0a  nt index).    {.
2790: 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20        int len;. 
27a0: 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 44 61       return ToDa
27b0: 74 65 54 69 6d 65 28 55 6e 73 61 66 65 4e 61 74  teTime(UnsafeNat
27c0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
27d0: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 5f 69  e3_column_text_i
27e0: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
27f0: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
2800: 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b   out len), len);
2810: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
2820: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f  rnal override lo
2830: 6e 67 20 47 65 74 42 79 74 65 73 28 53 51 4c 69  ng GetBytes(SQLi
2840: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
2850: 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69 6e 74  , int index, int
2860: 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 62 79   nDataOffset, by
2870: 74 65 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20  te[] bDest, int 
2880: 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e  nStart, int nLen
2890: 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  gth).    {.     
28a0: 20 49 6e 74 50 74 72 20 70 74 72 3b 0a 20 20 20   IntPtr ptr;.   
28b0: 20 20 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20 20 20     int nlen;.   
28c0: 20 20 20 69 6e 74 20 6e 43 6f 70 69 65 64 20 3d     int nCopied =
28d0: 20 6e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20   nLength;..     
28e0: 20 6e 6c 65 6e 20 3d 20 55 6e 73 61 66 65 4e 61   nlen = UnsafeNa
28f0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
2900: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65 73  te3_column_bytes
2910: 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73  _interop(stmt._s
2920: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
2930: 78 29 3b 0a 20 20 20 20 20 20 70 74 72 20 3d 20  x);.      ptr = 
2940: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
2950: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ods.sqlite3_colu
2960: 6d 6e 5f 62 6c 6f 62 5f 69 6e 74 65 72 6f 70 28  mn_blob_interop(
2970: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
2980: 74 2c 20 69 6e 64 65 78 29 3b 0a 0a 20 20 20 20  t, index);..    
2990: 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d 20 6e    if (bDest == n
29a0: 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65 6e  ull) return nlen
29b0: 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f  ;..      if (nCo
29c0: 70 69 65 64 20 2b 20 6e 53 74 61 72 74 20 3e 20  pied + nStart > 
29d0: 62 44 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43  bDest.Length) nC
29e0: 6f 70 69 65 64 20 3d 20 62 44 65 73 74 2e 4c 65  opied = bDest.Le
29f0: 6e 67 74 68 20 2d 20 6e 53 74 61 72 74 3b 0a 20  ngth - nStart;. 
2a00: 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64       if (nCopied
2a10: 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e   + nDataOffset >
2a20: 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d   nlen) nCopied =
2a30: 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66   nlen - nDataOff
2a40: 73 65 74 3b 0a 0a 20 20 20 20 20 20 69 66 20 28  set;..      if (
2a50: 6e 43 6f 70 69 65 64 20 3e 20 30 29 0a 20 20 20  nCopied > 0).   
2a60: 20 20 20 20 20 4d 61 72 73 68 61 6c 2e 43 6f 70       Marshal.Cop
2a70: 79 28 28 49 6e 74 50 74 72 29 28 70 74 72 2e 54  y((IntPtr)(ptr.T
2a80: 6f 49 6e 74 33 32 28 29 20 2b 20 6e 44 61 74 61  oInt32() + nData
2a90: 4f 66 66 73 65 74 29 2c 20 62 44 65 73 74 2c 20  Offset), bDest, 
2aa0: 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69 65 64 29  nStart, nCopied)
2ab0: 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 6e 43 6f  ;.      else nCo
2ac0: 70 69 65 64 20 3d 20 30 3b 0a 0a 20 20 20 20 20  pied = 0;..     
2ad0: 20 72 65 74 75 72 6e 20 6e 43 6f 70 69 65 64 3b   return nCopied;
2ae0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
2af0: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f  rnal override lo
2b00: 6e 67 20 47 65 74 43 68 61 72 73 28 53 51 4c 69  ng GetChars(SQLi
2b10: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
2b20: 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69 6e 74  , int index, int
2b30: 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 63 68   nDataOffset, ch
2b40: 61 72 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20  ar[] bDest, int 
2b50: 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e  nStart, int nLen
2b60: 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  gth).    {.     
2b70: 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20 20 20 20 20   int nlen;.     
2b80: 20 69 6e 74 20 6e 43 6f 70 69 65 64 20 3d 20 6e   int nCopied = n
2b90: 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20 20 73  Length;..      s
2ba0: 74 72 69 6e 67 20 73 74 72 20 3d 20 47 65 74 54  tring str = GetT
2bb0: 65 78 74 28 73 74 6d 74 2c 20 69 6e 64 65 78 29  ext(stmt, index)
2bc0: 3b 0a 20 20 20 20 20 20 6e 6c 65 6e 20 3d 20 73  ;.      nlen = s
2bd0: 74 72 2e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20  tr.Length;..    
2be0: 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d 20 6e    if (bDest == n
2bf0: 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65 6e  ull) return nlen
2c00: 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f  ;..      if (nCo
2c10: 70 69 65 64 20 2b 20 6e 53 74 61 72 74 20 3e 20  pied + nStart > 
2c20: 62 44 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43  bDest.Length) nC
2c30: 6f 70 69 65 64 20 3d 20 62 44 65 73 74 2e 4c 65  opied = bDest.Le
2c40: 6e 67 74 68 20 2d 20 6e 53 74 61 72 74 3b 0a 20  ngth - nStart;. 
2c50: 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64       if (nCopied
2c60: 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e   + nDataOffset >
2c70: 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d   nlen) nCopied =
2c80: 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66   nlen - nDataOff
2c90: 73 65 74 3b 0a 0a 20 20 20 20 20 20 69 66 20 28  set;..      if (
2ca0: 6e 43 6f 70 69 65 64 20 3e 20 30 29 0a 20 20 20  nCopied > 0).   
2cb0: 20 20 20 20 20 73 74 72 2e 43 6f 70 79 54 6f 28       str.CopyTo(
2cc0: 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 62 44 65  nDataOffset, bDe
2cd0: 73 74 2c 20 6e 53 74 61 72 74 2c 20 6e 43 6f 70  st, nStart, nCop
2ce0: 69 65 64 29 3b 0a 20 20 20 20 20 20 65 6c 73 65  ied);.      else
2cf0: 20 6e 43 6f 70 69 65 64 20 3d 20 30 3b 0a 0a 20   nCopied = 0;.. 
2d00: 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f 70       return nCop
2d10: 69 65 64 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ied;.    }..    
2d20: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
2d30: 65 20 62 6f 6f 6c 20 49 73 4e 75 6c 6c 28 53 51  e bool IsNull(SQ
2d40: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
2d50: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20  mt, int index). 
2d60: 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72     {.      retur
2d70: 6e 20 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  n (UnsafeNativeM
2d80: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
2d90: 6f 6c 75 6d 6e 5f 74 79 70 65 5f 69 6e 74 65 72  olumn_type_inter
2da0: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
2db0: 73 74 6d 74 2c 20 69 6e 64 65 78 29 20 3d 3d 20  stmt, index) == 
2dc0: 54 79 70 65 41 66 66 69 6e 69 74 79 2e 4e 75 6c  TypeAffinity.Nul
2dd0: 6c 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  l);.    }..    i
2de0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
2df0: 20 69 6e 74 20 41 67 67 72 65 67 61 74 65 43 6f   int AggregateCo
2e00: 75 6e 74 28 69 6e 74 20 63 6f 6e 74 65 78 74 29  unt(int context)
2e10: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74  .    {.      ret
2e20: 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65  urn UnsafeNative
2e30: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
2e40: 61 67 67 72 65 67 61 74 65 5f 63 6f 75 6e 74 5f  aggregate_count_
2e50: 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74 29  interop(context)
2e60: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
2e70: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69  ernal override i
2e80: 6e 74 20 43 72 65 61 74 65 46 75 6e 63 74 69 6f  nt CreateFunctio
2e90: 6e 28 73 74 72 69 6e 67 20 73 74 72 46 75 6e 63  n(string strFunc
2ea0: 74 69 6f 6e 2c 20 69 6e 74 20 6e 41 72 67 73 2c  tion, int nArgs,
2eb0: 20 53 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b 20   SQLiteCallback 
2ec0: 66 75 6e 63 2c 20 53 51 4c 69 74 65 43 61 6c 6c  func, SQLiteCall
2ed0: 62 61 63 6b 20 66 75 6e 63 73 74 65 70 2c 20 53  back funcstep, S
2ee0: 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b 20 66 75  QLiteCallback fu
2ef0: 6e 63 66 69 6e 61 6c 29 0a 20 20 20 20 7b 0a 20  ncfinal).    {. 
2f00: 20 20 20 20 20 69 6e 74 20 6e 43 6f 6f 6b 69 65       int nCookie
2f10: 3b 0a 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  ;..      int n =
2f20: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
2f30: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65  hods.sqlite3_cre
2f40: 61 74 65 5f 66 75 6e 63 74 69 6f 6e 5f 69 6e 74  ate_function_int
2f50: 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55 54 46  erop(_sql, ToUTF
2f60: 38 28 73 74 72 46 75 6e 63 74 69 6f 6e 29 2c 20  8(strFunction), 
2f70: 6e 41 72 67 73 2c 20 31 2c 20 66 75 6e 63 2c 20  nArgs, 1, func, 
2f80: 66 75 6e 63 73 74 65 70 2c 20 66 75 6e 63 66 69  funcstep, funcfi
2f90: 6e 61 6c 2c 20 6f 75 74 20 6e 43 6f 6f 6b 69 65  nal, out nCookie
2fa0: 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e  );.      if (n >
2fb0: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
2fc0: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
2fd0: 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72   SQLiteLastError
2fe0: 28 29 29 3b 0a 0a 20 20 20 20 20 20 72 65 74 75  ());..      retu
2ff0: 72 6e 20 6e 43 6f 6f 6b 69 65 3b 0a 20 20 20 20  rn nCookie;.    
3000: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
3010: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 43 72 65  override int Cre
3020: 61 74 65 43 6f 6c 6c 61 74 69 6f 6e 28 73 74 72  ateCollation(str
3030: 69 6e 67 20 73 74 72 43 6f 6c 6c 61 74 69 6f 6e  ing strCollation
3040: 2c 20 53 51 4c 69 74 65 43 6f 6c 6c 61 74 69 6f  , SQLiteCollatio
3050: 6e 20 66 75 6e 63 29 0a 20 20 20 20 7b 0a 20 20  n func).    {.  
3060: 20 20 20 20 69 6e 74 20 6e 43 6f 6f 6b 69 65 3b      int nCookie;
3070: 0a 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  ..      int n = 
3080: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3090: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61  ods.sqlite3_crea
30a0: 74 65 5f 63 6f 6c 6c 61 74 69 6f 6e 5f 69 6e 74  te_collation_int
30b0: 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55 54 46  erop(_sql, ToUTF
30c0: 38 28 73 74 72 43 6f 6c 6c 61 74 69 6f 6e 29 2c  8(strCollation),
30d0: 20 31 2c 20 30 2c 20 66 75 6e 63 2c 20 6f 75 74   1, 0, func, out
30e0: 20 6e 43 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 20   nCookie);.     
30f0: 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f   if (n > 0) thro
3100: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
3110: 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c  ption(n, SQLiteL
3120: 61 73 74 45 72 72 6f 72 28 29 29 3b 0a 0a 20 20  astError());..  
3130: 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f 6f 6b      return nCook
3140: 69 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  ie;.    }..    i
3150: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
3160: 20 76 6f 69 64 20 46 72 65 65 46 75 6e 63 74 69   void FreeFuncti
3170: 6f 6e 28 69 6e 74 20 6e 43 6f 6f 6b 69 65 29 0a  on(int nCookie).
3180: 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61      {.      Unsa
3190: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
31a0: 73 71 6c 69 74 65 33 5f 66 75 6e 63 74 69 6f 6e  sqlite3_function
31b0: 5f 66 72 65 65 5f 63 61 6c 6c 62 61 63 6b 63 6f  _free_callbackco
31c0: 6f 6b 69 65 28 6e 43 6f 6f 6b 69 65 29 3b 0a 20  okie(nCookie);. 
31d0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
31e0: 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67  al override long
31f0: 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 42 79   GetParamValueBy
3200: 74 65 73 28 69 6e 74 20 70 2c 20 69 6e 74 20 6e  tes(int p, int n
3210: 44 61 74 61 4f 66 66 73 65 74 2c 20 62 79 74 65  DataOffset, byte
3220: 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20 6e 53  [] bDest, int nS
3230: 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e 67 74  tart, int nLengt
3240: 68 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 49  h).    {.      I
3250: 6e 74 50 74 72 20 70 74 72 3b 0a 20 20 20 20 20  ntPtr ptr;.     
3260: 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20 20 20 20 20   int nlen;.     
3270: 20 69 6e 74 20 6e 43 6f 70 69 65 64 20 3d 20 6e   int nCopied = n
3280: 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20 20 6e  Length;..      n
3290: 6c 65 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  len = UnsafeNati
32a0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
32b0: 33 5f 76 61 6c 75 65 5f 62 79 74 65 73 5f 69 6e  3_value_bytes_in
32c0: 74 65 72 6f 70 28 70 29 3b 0a 20 20 20 20 20 20  terop(p);.      
32d0: 70 74 72 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  ptr = UnsafeNati
32e0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
32f0: 33 5f 76 61 6c 75 65 5f 62 6c 6f 62 5f 69 6e 74  3_value_blob_int
3300: 65 72 6f 70 28 70 29 3b 0a 0a 20 20 20 20 20 20  erop(p);..      
3310: 69 66 20 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c  if (bDest == nul
3320: 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0a  l) return nlen;.
3330: 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69  .      if (nCopi
3340: 65 64 20 2b 20 6e 53 74 61 72 74 20 3e 20 62 44  ed + nStart > bD
3350: 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f 70  est.Length) nCop
3360: 69 65 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e 67  ied = bDest.Leng
3370: 74 68 20 2d 20 6e 53 74 61 72 74 3b 0a 20 20 20  th - nStart;.   
3380: 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b     if (nCopied +
3390: 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e 20 6e   nDataOffset > n
33a0: 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d 20 6e  len) nCopied = n
33b0: 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66 73 65  len - nDataOffse
33c0: 74 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43  t;..      if (nC
33d0: 6f 70 69 65 64 20 3e 20 30 29 0a 20 20 20 20 20  opied > 0).     
33e0: 20 20 20 4d 61 72 73 68 61 6c 2e 43 6f 70 79 28     Marshal.Copy(
33f0: 28 49 6e 74 50 74 72 29 28 70 74 72 2e 54 6f 49  (IntPtr)(ptr.ToI
3400: 6e 74 33 32 28 29 20 2b 20 6e 44 61 74 61 4f 66  nt32() + nDataOf
3410: 66 73 65 74 29 2c 20 62 44 65 73 74 2c 20 6e 53  fset), bDest, nS
3420: 74 61 72 74 2c 20 6e 43 6f 70 69 65 64 29 3b 0a  tart, nCopied);.
3430: 20 20 20 20 20 20 65 6c 73 65 20 6e 43 6f 70 69        else nCopi
3440: 65 64 20 3d 20 30 3b 0a 0a 20 20 20 20 20 20 72  ed = 0;..      r
3450: 65 74 75 72 6e 20 6e 43 6f 70 69 65 64 3b 0a 20  eturn nCopied;. 
3460: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
3470: 61 6c 20 6f 76 65 72 72 69 64 65 20 64 6f 75 62  al override doub
3480: 6c 65 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65  le GetParamValue
3490: 44 6f 75 62 6c 65 28 69 6e 74 20 70 74 72 29 0a  Double(int ptr).
34a0: 20 20 20 20 7b 0a 20 20 20 20 20 20 64 6f 75 62      {.      doub
34b0: 6c 65 20 76 61 6c 75 65 3b 0a 20 20 20 20 20 20  le value;.      
34c0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
34d0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75  ods.sqlite3_valu
34e0: 65 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70  e_double_interop
34f0: 28 70 74 72 2c 20 6f 75 74 20 76 61 6c 75 65 29  (ptr, out value)
3500: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 76  ;.      return v
3510: 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  alue;.    }..   
3520: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
3530: 64 65 20 69 6e 74 20 47 65 74 50 61 72 61 6d 56  de int GetParamV
3540: 61 6c 75 65 49 6e 74 33 32 28 69 6e 74 20 70 74  alueInt32(int pt
3550: 72 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  r).    {.      r
3560: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
3570: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
3580: 33 5f 76 61 6c 75 65 5f 69 6e 74 5f 69 6e 74 65  3_value_int_inte
3590: 72 6f 70 28 70 74 72 29 3b 0a 20 20 20 20 7d 0a  rop(ptr);.    }.
35a0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
35b0: 65 72 72 69 64 65 20 6c 6f 6e 67 20 47 65 74 50  erride long GetP
35c0: 61 72 61 6d 56 61 6c 75 65 49 6e 74 36 34 28 69  aramValueInt64(i
35d0: 6e 74 20 70 74 72 29 0a 20 20 20 20 7b 0a 20 20  nt ptr).    {.  
35e0: 20 20 20 20 49 6e 74 36 34 20 76 61 6c 75 65 3b      Int64 value;
35f0: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
3600: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
3610: 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 5f 69  e3_value_int64_i
3620: 6e 74 65 72 6f 70 28 70 74 72 2c 20 6f 75 74 20  nterop(ptr, out 
3630: 76 61 6c 75 65 29 3b 0a 20 20 20 20 20 20 72 65  value);.      re
3640: 74 75 72 6e 20 76 61 6c 75 65 3b 0a 20 20 20 20  turn value;.    
3650: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
3660: 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67 20  override string 
3670: 47 65 74 50 61 72 61 6d 56 61 6c 75 65 54 65 78  GetParamValueTex
3680: 74 28 69 6e 74 20 70 74 72 29 0a 20 20 20 20 7b  t(int ptr).    {
3690: 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a  .      int len;.
36a0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 53        return ToS
36b0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
36c0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
36d0: 33 5f 76 61 6c 75 65 5f 74 65 78 74 5f 69 6e 74  3_value_text_int
36e0: 65 72 6f 70 28 70 74 72 2c 20 6f 75 74 20 6c 65  erop(ptr, out le
36f0: 6e 29 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a  n), len);.    }.
3700: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
3710: 65 72 72 69 64 65 20 54 79 70 65 41 66 66 69 6e  erride TypeAffin
3720: 69 74 79 20 47 65 74 50 61 72 61 6d 56 61 6c 75  ity GetParamValu
3730: 65 54 79 70 65 28 69 6e 74 20 70 74 72 29 0a 20  eType(int ptr). 
3740: 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72     {.      retur
3750: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
3760: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
3770: 6c 75 65 5f 74 79 70 65 5f 69 6e 74 65 72 6f 70  lue_type_interop
3780: 28 70 74 72 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  (ptr);.    }..  
3790: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
37a0: 69 64 65 20 76 6f 69 64 20 52 65 74 75 72 6e 42  ide void ReturnB
37b0: 6c 6f 62 28 69 6e 74 20 63 6f 6e 74 65 78 74 2c  lob(int context,
37c0: 20 62 79 74 65 5b 5d 20 76 61 6c 75 65 29 0a 20   byte[] value). 
37d0: 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66     {.      Unsaf
37e0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
37f0: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 62 6c  qlite3_result_bl
3800: 6f 62 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65  ob_interop(conte
3810: 78 74 2c 20 76 61 6c 75 65 2c 20 76 61 6c 75 65  xt, value, value
3820: 2e 4c 65 6e 67 74 68 2c 20 2d 31 29 3b 0a 20 20  .Length, -1);.  
3830: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
3840: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
3850: 52 65 74 75 72 6e 44 6f 75 62 6c 65 28 69 6e 74  ReturnDouble(int
3860: 20 63 6f 6e 74 65 78 74 2c 20 64 6f 75 62 6c 65   context, double
3870: 20 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20   value).    {.  
3880: 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65      UnsafeNative
3890: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
38a0: 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 5f 69 6e  result_double_in
38b0: 74 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20 72  terop(context, r
38c0: 65 66 20 76 61 6c 75 65 29 3b 0a 20 20 20 20 7d  ef value);.    }
38d0: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
38e0: 76 65 72 72 69 64 65 20 76 6f 69 64 20 52 65 74  verride void Ret
38f0: 75 72 6e 45 72 72 6f 72 28 69 6e 74 20 63 6f 6e  urnError(int con
3900: 74 65 78 74 2c 20 73 74 72 69 6e 67 20 76 61 6c  text, string val
3910: 75 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  ue).    {.      
3920: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3930: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75  ods.sqlite3_resu
3940: 6c 74 5f 65 72 72 6f 72 5f 69 6e 74 65 72 6f 70  lt_error_interop
3950: 28 63 6f 6e 74 65 78 74 2c 20 54 6f 55 54 46 38  (context, ToUTF8
3960: 28 76 61 6c 75 65 29 2c 20 76 61 6c 75 65 2e 4c  (value), value.L
3970: 65 6e 67 74 68 29 3b 0a 20 20 20 20 7d 0a 0a 20  ength);.    }.. 
3980: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
3990: 72 69 64 65 20 76 6f 69 64 20 52 65 74 75 72 6e  ride void Return
39a0: 49 6e 74 33 32 28 69 6e 74 20 63 6f 6e 74 65 78  Int32(int contex
39b0: 74 2c 20 69 6e 74 20 76 61 6c 75 65 29 0a 20 20  t, int value).  
39c0: 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65    {.      Unsafe
39d0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
39e0: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74  lite3_result_int
39f0: 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74  _interop(context
3a00: 2c 20 76 61 6c 75 65 29 3b 0a 20 20 20 20 7d 0a  , value);.    }.
3a10: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
3a20: 65 72 72 69 64 65 20 76 6f 69 64 20 52 65 74 75  erride void Retu
3a30: 72 6e 49 6e 74 36 34 28 69 6e 74 20 63 6f 6e 74  rnInt64(int cont
3a40: 65 78 74 2c 20 6c 6f 6e 67 20 76 61 6c 75 65 29  ext, long value)
3a50: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73  .    {.      Uns
3a60: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
3a70: 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f  .sqlite3_result_
3a80: 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 63 6f  int64_interop(co
3a90: 6e 74 65 78 74 2c 20 72 65 66 20 76 61 6c 75 65  ntext, ref value
3aa0: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
3ab0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
3ac0: 76 6f 69 64 20 52 65 74 75 72 6e 4e 75 6c 6c 28  void ReturnNull(
3ad0: 69 6e 74 20 63 6f 6e 74 65 78 74 29 0a 20 20 20  int context).   
3ae0: 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e   {.      UnsafeN
3af0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
3b00: 69 74 65 33 5f 72 65 73 75 6c 74 5f 6e 75 6c 6c  ite3_result_null
3b10: 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74  _interop(context
3b20: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
3b30: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
3b40: 76 6f 69 64 20 52 65 74 75 72 6e 54 65 78 74 28  void ReturnText(
3b50: 69 6e 74 20 63 6f 6e 74 65 78 74 2c 20 73 74 72  int context, str
3b60: 69 6e 67 20 76 61 6c 75 65 29 0a 20 20 20 20 7b  ing value).    {
3b70: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
3b80: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
3b90: 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74 5f 69  e3_result_text_i
3ba0: 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20  nterop(context, 
3bb0: 54 6f 55 54 46 38 28 76 61 6c 75 65 29 2c 20 76  ToUTF8(value), v
3bc0: 61 6c 75 65 2e 4c 65 6e 67 74 68 2c 20 2d 31 29  alue.Length, -1)
3bd0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
3be0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69  ernal override i
3bf0: 6e 74 20 41 67 67 72 65 67 61 74 65 43 6f 6e 74  nt AggregateCont
3c00: 65 78 74 28 69 6e 74 20 63 6f 6e 74 65 78 74 29  ext(int context)
3c10: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74  .    {.      ret
3c20: 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65  urn UnsafeNative
3c30: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
3c40: 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78  aggregate_contex
3c50: 74 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78  t_interop(contex
3c60: 74 2c 20 31 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  t, 1);.    }..  
3c70: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
3c80: 69 64 65 20 76 6f 69 64 20 53 65 74 52 65 61 6c  ide void SetReal
3c90: 43 6f 6c 4e 61 6d 65 73 28 62 6f 6f 6c 20 62 4f  ColNames(bool bO
3ca0: 6e 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 55  n).    {.      U
3cb0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
3cc0: 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 61 6c 63  ds.sqlite3_realc
3cd0: 6f 6c 6e 61 6d 65 73 28 5f 73 71 6c 2c 20 43 6f  olnames(_sql, Co
3ce0: 6e 76 65 72 74 2e 54 6f 49 6e 74 33 32 28 62 4f  nvert.ToInt32(bO
3cf0: 6e 29 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d  n));.    }.  }.}
3d00: 0a                                               .