System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 0bcc9c35bd07eae287d2a5f2c96a4894ae4f92d6:


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 20 20 20 20 2f 2f 2f 20 3c 73 75 6d  ql;.    /// <sum
02f0: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 54 68  mary>.    /// Th
0300: 65 20 75 73 65 72 2d 64 65 66 69 6e 65 64 20 66  e user-defined f
0310: 75 6e 63 74 69 6f 6e 73 20 72 65 67 69 73 74 65  unctions registe
0320: 72 65 64 20 6f 6e 20 74 68 69 73 20 63 6f 6e 6e  red on this conn
0330: 65 63 74 69 6f 6e 0a 20 20 20 20 2f 2f 2f 20 3c  ection.    /// <
0340: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72  /summary>.    pr
0350: 6f 74 65 63 74 65 64 20 53 51 4c 69 74 65 46 75  otected SQLiteFu
0360: 6e 63 74 69 6f 6e 5b 5d 20 5f 66 75 6e 63 74 69  nction[] _functi
0370: 6f 6e 73 41 72 72 61 79 3b 0a 0a 20 20 20 20 69  onsArray;..    i
0380: 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74 65 33 28  nternal SQLite3(
0390: 44 61 74 65 54 69 6d 65 46 6f 72 6d 61 74 20 66  DateTimeFormat f
03a0: 6d 74 29 0a 20 20 20 20 20 20 3a 20 62 61 73 65  mt).      : base
03b0: 28 66 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20 20  (fmt).    {.    
03c0: 7d 0a 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64  }..    protected
03d0: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 44   override void D
03e0: 69 73 70 6f 73 65 28 62 6f 6f 6c 20 62 44 69 73  ispose(bool bDis
03f0: 70 6f 73 69 6e 67 29 0a 20 20 20 20 7b 0a 20 20  posing).    {.  
0400: 20 20 20 20 43 6c 6f 73 65 28 29 3b 0a 20 20 20      Close();.   
0410: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
0420: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 43   override void C
0430: 6c 6f 73 65 28 29 0a 20 20 20 20 7b 0a 20 20 20  lose().    {.   
0440: 20 20 20 69 66 20 28 5f 73 71 6c 20 21 3d 20 30     if (_sql != 0
0450: 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  ).      {.      
0460: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
0470: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
0480: 6c 69 74 65 33 5f 63 6c 6f 73 65 5f 69 6e 74 65  lite3_close_inte
0490: 72 6f 70 28 5f 73 71 6c 29 3b 0a 20 20 20 20 20  rop(_sql);.     
04a0: 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68     if (n > 0) th
04b0: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
04c0: 63 65 70 74 69 6f 6e 28 6e 2c 20 22 69 6e 20 44  ception(n, "in D
04d0: 69 73 70 6f 73 65 28 29 22 29 3b 0a 20 20 20 20  ispose()");.    
04e0: 20 20 20 20 53 51 4c 69 74 65 46 75 6e 63 74 69      SQLiteFuncti
04f0: 6f 6e 2e 55 6e 62 69 6e 64 46 75 6e 63 74 69 6f  on.UnbindFunctio
0500: 6e 73 28 74 68 69 73 2c 20 5f 66 75 6e 63 74 69  ns(this, _functi
0510: 6f 6e 73 41 72 72 61 79 29 3b 0a 20 20 20 20 20  onsArray);.     
0520: 20 7d 0a 20 20 20 20 20 20 5f 73 71 6c 20 3d 20   }.      _sql = 
0530: 30 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  0;.    }..    in
0540: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
0550: 76 6f 69 64 20 43 61 6e 63 65 6c 28 29 0a 20 20  void Cancel().  
0560: 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65    {.      Unsafe
0570: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
0580: 6c 69 74 65 33 5f 69 6e 74 65 72 72 75 70 74 5f  lite3_interrupt_
0590: 69 6e 74 65 72 6f 70 28 5f 73 71 6c 29 3b 0a 20  interop(_sql);. 
05a0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
05b0: 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72 69  al override stri
05c0: 6e 67 20 56 65 72 73 69 6f 6e 0a 20 20 20 20 7b  ng Version.    {
05d0: 0a 20 20 20 20 20 20 67 65 74 0a 20 20 20 20 20  .      get.     
05e0: 20 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6c   {.        int l
05f0: 65 6e 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75  en;.        retu
0600: 72 6e 20 54 6f 53 74 72 69 6e 67 28 55 6e 73 61  rn ToString(Unsa
0610: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
0620: 73 71 6c 69 74 65 33 5f 6c 69 62 76 65 72 73 69  sqlite3_libversi
0630: 6f 6e 5f 69 6e 74 65 72 6f 70 28 6f 75 74 20 6c  on_interop(out l
0640: 65 6e 29 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 20  en), len);.     
0650: 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e   }.    }..    in
0660: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
0670: 69 6e 74 20 43 68 61 6e 67 65 73 0a 20 20 20 20  int Changes.    
0680: 7b 0a 20 20 20 20 20 20 67 65 74 0a 20 20 20 20  {.      get.    
0690: 20 20 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75    {.        retu
06a0: 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  rn UnsafeNativeM
06b0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
06c0: 68 61 6e 67 65 73 5f 69 6e 74 65 72 6f 70 28 5f  hanges_interop(_
06d0: 73 71 6c 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  sql);.      }.  
06e0: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
06f0: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
0700: 4f 70 65 6e 28 73 74 72 69 6e 67 20 73 74 72 46  Open(string strF
0710: 69 6c 65 6e 61 6d 65 29 0a 20 20 20 20 7b 0a 20  ilename).    {. 
0720: 20 20 20 20 20 69 66 20 28 5f 73 71 6c 20 21 3d       if (_sql !=
0730: 20 30 29 20 72 65 74 75 72 6e 3b 0a 20 20 20 20   0) return;.    
0740: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
0750: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
0760: 6c 69 74 65 33 5f 6f 70 65 6e 5f 69 6e 74 65 72  lite3_open_inter
0770: 6f 70 28 54 6f 55 54 46 38 28 73 74 72 46 69 6c  op(ToUTF8(strFil
0780: 65 6e 61 6d 65 29 2c 20 6f 75 74 20 5f 73 71 6c  ename), out _sql
0790: 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e  );.      if (n >
07a0: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
07b0: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
07c0: 20 22 69 6e 20 4f 70 65 6e 28 29 22 29 3b 0a 0a   "in Open()");..
07d0: 20 20 20 20 20 20 5f 66 75 6e 63 74 69 6f 6e 73        _functions
07e0: 41 72 72 61 79 20 3d 20 53 51 4c 69 74 65 46 75  Array = SQLiteFu
07f0: 6e 63 74 69 6f 6e 2e 42 69 6e 64 46 75 6e 63 74  nction.BindFunct
0800: 69 6f 6e 73 28 74 68 69 73 29 3b 0a 20 20 20 20  ions(this);.    
0810: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
0820: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 53 65  override void Se
0830: 74 54 69 6d 65 6f 75 74 28 69 6e 74 20 6e 54 69  tTimeout(int nTi
0840: 6d 65 6f 75 74 4d 53 29 0a 20 20 20 20 7b 0a 20  meoutMS).    {. 
0850: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73       int n = Uns
0860: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
0870: 2e 73 71 6c 69 74 65 33 5f 62 75 73 79 5f 74 69  .sqlite3_busy_ti
0880: 6d 65 6f 75 74 5f 69 6e 74 65 72 6f 70 28 5f 73  meout_interop(_s
0890: 71 6c 2c 20 6e 54 69 6d 65 6f 75 74 4d 53 29 3b  ql, nTimeoutMS);
08a0: 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30  .      if (n > 0
08b0: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
08c0: 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 22  teException(n, "
08d0: 69 6e 20 53 65 74 54 69 6d 65 6f 75 74 28 29 22  in SetTimeout()"
08e0: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
08f0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
0900: 76 6f 69 64 20 45 78 65 63 75 74 65 28 73 74 72  void Execute(str
0910: 69 6e 67 20 73 74 72 53 71 6c 29 0a 20 20 20 20  ing strSql).    
0920: 7b 0a 20 20 20 20 20 20 49 6e 74 50 74 72 20 70  {.      IntPtr p
0930: 3b 0a 20 20 20 20 20 20 73 74 72 69 6e 67 20 73  ;.      string s
0940: 74 72 20 3d 20 73 74 72 53 71 6c 3b 0a 20 20 20  tr = strSql;.   
0950: 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 0a 20 20 20     int len;..   
0960: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
0970: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
0980: 71 6c 69 74 65 33 5f 65 78 65 63 5f 69 6e 74 65  qlite3_exec_inte
0990: 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55 54 46 38  rop(_sql, ToUTF8
09a0: 28 73 74 72 53 71 6c 29 2c 20 30 2c 20 30 2c 20  (strSql), 0, 0, 
09b0: 6f 75 74 20 70 2c 20 6f 75 74 20 6c 65 6e 29 3b  out p, out len);
09c0: 0a 20 20 20 20 20 20 69 66 20 28 70 20 21 3d 20  .      if (p != 
09d0: 49 6e 74 50 74 72 2e 5a 65 72 6f 29 0a 20 20 20  IntPtr.Zero).   
09e0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 73 74 72     {.        str
09f0: 20 3d 20 54 6f 53 74 72 69 6e 67 28 70 2c 20 6c   = ToString(p, l
0a00: 65 6e 29 3b 0a 20 20 20 20 20 20 20 20 55 6e 73  en);.        Uns
0a10: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
0a20: 2e 73 71 6c 69 74 65 33 5f 66 72 65 65 5f 69 6e  .sqlite3_free_in
0a30: 74 65 72 6f 70 28 70 29 3b 0a 20 20 20 20 20 20  terop(p);.      
0a40: 7d 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20  }.      if (n > 
0a50: 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c  0) throw new SQL
0a60: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
0a70: 73 74 72 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  str);.    }..   
0a80: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
0a90: 64 65 20 62 6f 6f 6c 20 53 74 65 70 28 53 51 4c  de bool Step(SQL
0aa0: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
0ab0: 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  t).    {.      i
0ac0: 6e 74 20 6e 3b 0a 20 20 20 20 20 20 6c 6f 6e 67  nt n;.      long
0ad0: 20 64 77 74 69 63 6b 20 3d 20 30 3b 0a 20 20 20   dwtick = 0;.   
0ae0: 20 20 20 52 61 6e 64 6f 6d 20 72 6e 64 20 3d 20     Random rnd = 
0af0: 6e 75 6c 6c 3b 0a 0a 20 20 20 20 20 20 77 68 69  null;..      whi
0b00: 6c 65 20 28 74 72 75 65 29 0a 20 20 20 20 20 20  le (true).      
0b10: 7b 0a 20 20 20 20 20 20 20 20 6e 20 3d 20 55 6e  {.        n = Un
0b20: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
0b30: 73 2e 73 71 6c 69 74 65 33 5f 73 74 65 70 5f 69  s.sqlite3_step_i
0b40: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
0b50: 69 74 65 5f 73 74 6d 74 29 3b 0a 0a 20 20 20 20  ite_stmt);..    
0b60: 20 20 20 20 69 66 20 28 6e 20 3d 3d 20 31 30 30      if (n == 100
0b70: 29 20 72 65 74 75 72 6e 20 74 72 75 65 3b 0a 20  ) return true;. 
0b80: 20 20 20 20 20 20 20 69 66 20 28 6e 20 3d 3d 20         if (n == 
0b90: 31 30 31 29 20 72 65 74 75 72 6e 20 66 61 6c 73  101) return fals
0ba0: 65 3b 0a 0a 20 20 20 20 20 20 20 20 69 66 20 28  e;..        if (
0bb0: 6e 20 3e 20 30 29 0a 20 20 20 20 20 20 20 20 7b  n > 0).        {
0bc0: 0a 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 72  .          int r
0bd0: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20  ;..          // 
0be0: 41 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65  An error occurre
0bf0: 64 2c 20 61 74 74 65 6d 70 74 20 74 6f 20 72 65  d, attempt to re
0c00: 73 65 74 20 74 68 65 20 73 74 61 74 65 6d 65 6e  set the statemen
0c10: 74 2e 20 20 49 66 20 74 68 65 20 72 65 73 65 74  t.  If the reset
0c20: 20 77 6f 72 6b 65 64 20 62 65 63 61 75 73 65 20   worked because 
0c30: 74 68 65 0a 20 20 20 20 20 20 20 20 20 20 2f 2f  the.          //
0c40: 20 73 63 68 65 6d 61 20 68 61 73 20 63 68 61 6e   schema has chan
0c50: 67 65 64 2c 20 72 65 2d 74 72 79 20 74 68 65 20  ged, re-try the 
0c60: 73 74 65 70 20 61 67 61 69 6e 2e 20 20 49 66 20  step again.  If 
0c70: 69 74 20 65 72 72 6f 72 65 64 20 6f 75 72 20 62  it errored our b
0c80: 65 63 61 75 73 65 20 74 68 65 20 64 61 74 61 62  ecause the datab
0c90: 61 73 65 0a 20 20 20 20 20 20 20 20 20 20 2f 2f  ase.          //
0ca0: 20 69 73 20 6c 6f 63 6b 65 64 2c 20 74 68 65 6e   is locked, then
0cb0: 20 6b 65 65 70 20 72 65 74 72 79 69 6e 67 20 75   keep retrying u
0cc0: 6e 74 69 6c 20 74 68 65 20 63 6f 6d 6d 61 6e 64  ntil the command
0cd0: 20 74 69 6d 65 6f 75 74 20 6f 63 63 75 72 73 2e   timeout occurs.
0ce0: 0a 20 20 20 20 20 20 20 20 20 20 72 20 3d 20 52  .          r = R
0cf0: 65 73 65 74 28 73 74 6d 74 29 3b 0a 0a 20 20 20  eset(stmt);..   
0d00: 20 20 20 20 20 20 20 69 66 20 28 72 20 3d 3d 20         if (r == 
0d10: 30 29 0a 20 20 20 20 20 20 20 20 20 20 20 20 74  0).            t
0d20: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
0d30: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 22 69 6e 20  xception(n, "in 
0d40: 53 74 65 70 28 29 22 29 3b 0a 0a 20 20 20 20 20  Step()");..     
0d50: 20 20 20 20 20 65 6c 73 65 20 69 66 20 28 72 20       else if (r 
0d60: 3d 3d 20 36 20 26 26 20 73 74 6d 74 2e 5f 63 6f  == 6 && stmt._co
0d70: 6d 6d 61 6e 64 20 21 3d 20 6e 75 6c 6c 29 20 2f  mmand != null) /
0d80: 2f 20 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 0a  / SQLITE_LOCKED.
0d90: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
0da0: 20 20 20 20 20 20 20 20 2f 2f 20 4b 65 65 70 20          // Keep 
0db0: 74 72 79 69 6e 67 0a 20 20 20 20 20 20 20 20 20  trying.         
0dc0: 20 20 20 69 66 20 28 64 77 74 69 63 6b 20 3d 3d     if (dwtick ==
0dd0: 20 30 29 20 2f 2f 20 46 69 72 73 74 20 74 69 6d   0) // First tim
0de0: 65 20 77 65 27 76 65 20 65 6e 63 6f 75 6e 74 65  e we've encounte
0df0: 72 65 64 20 74 68 65 20 6c 6f 63 6b 0a 20 20 20  red the lock.   
0e00: 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20           {.     
0e10: 20 20 20 20 20 20 20 20 20 64 77 74 69 63 6b 20           dwtick 
0e20: 3d 20 44 61 74 65 54 69 6d 65 2e 4e 6f 77 2e 54  = DateTime.Now.T
0e30: 69 63 6b 73 20 2b 20 28 73 74 6d 74 2e 5f 63 6f  icks + (stmt._co
0e40: 6d 6d 61 6e 64 2e 5f 63 6f 6d 6d 61 6e 64 54 69  mmand._commandTi
0e50: 6d 65 6f 75 74 20 2a 20 31 30 30 30 30 30 30 30  meout * 10000000
0e60: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
0e70: 20 72 6e 64 20 3d 20 6e 65 77 20 52 61 6e 64 6f   rnd = new Rando
0e80: 6d 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  m();.           
0e90: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f   }.            /
0ea0: 2f 20 49 66 20 77 65 27 76 65 20 65 78 63 65 65  / If we've excee
0eb0: 64 65 64 20 74 68 65 20 63 6f 6d 6d 61 6e 64 27  ded the command'
0ec0: 73 20 74 69 6d 65 6f 75 74 2c 20 67 69 76 65 20  s timeout, give 
0ed0: 75 70 20 61 6e 64 20 74 68 72 6f 77 20 61 6e 20  up and throw an 
0ee0: 65 72 72 6f 72 0a 20 20 20 20 20 20 20 20 20 20  error.          
0ef0: 20 20 69 66 20 28 44 61 74 65 54 69 6d 65 2e 4e    if (DateTime.N
0f00: 6f 77 2e 54 69 63 6b 73 20 2d 20 64 77 74 69 63  ow.Ticks - dwtic
0f10: 6b 20 3e 20 30 29 0a 20 20 20 20 20 20 20 20 20  k > 0).         
0f20: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
0f30: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c     throw new SQL
0f40: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 72 2c 20  iteException(r, 
0f50: 22 69 6e 20 53 74 65 70 28 29 20 2d 20 74 69 6d  "in Step() - tim
0f60: 65 6f 75 74 22 29 3b 0a 20 20 20 20 20 20 20 20  eout");.        
0f70: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
0f80: 20 20 65 6c 73 65 0a 20 20 20 20 20 20 20 20 20    else.         
0f90: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
0fa0: 20 20 20 2f 2f 20 4f 74 68 65 72 77 69 73 65 20     // Otherwise 
0fb0: 73 6c 65 65 70 20 66 6f 72 20 61 20 72 61 6e 64  sleep for a rand
0fc0: 6f 6d 20 61 6d 6f 75 6e 74 20 6f 66 20 74 69 6d  om amount of tim
0fd0: 65 20 75 70 20 74 6f 20 32 35 30 6d 73 0a 20 20  e up to 250ms.  
0fe0: 20 20 20 20 20 20 20 20 20 20 20 20 55 6e 73 61              Unsa
0ff0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
1000: 53 6c 65 65 70 28 28 75 69 6e 74 29 72 6e 64 2e  Sleep((uint)rnd.
1010: 4e 65 78 74 28 31 2c 20 32 35 30 29 29 3b 0a 20  Next(1, 250));. 
1020: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
1030: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20         }..      
1040: 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20    }.      }.    
1050: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
1060: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 46 69  override void Fi
1070: 6e 61 6c 69 7a 65 53 74 61 74 65 6d 65 6e 74 28  nalizeStatement(
1080: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
1090: 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20 20  stmt).    {.    
10a0: 20 20 69 66 20 28 73 74 6d 74 2e 5f 73 71 6c 69    if (stmt._sqli
10b0: 74 65 5f 73 74 6d 74 20 3e 20 30 29 0a 20 20 20  te_stmt > 0).   
10c0: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69 6e 74     {.        int
10d0: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
10e0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
10f0: 5f 66 69 6e 61 6c 69 7a 65 5f 69 6e 74 65 72 6f  _finalize_intero
1100: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
1110: 74 6d 74 29 3b 0a 20 20 20 20 20 20 20 20 69 66  tmt);.        if
1120: 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e   (n > 0) throw n
1130: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
1140: 6f 6e 28 6e 2c 20 22 69 6e 20 46 69 6e 61 6c 69  on(n, "in Finali
1150: 7a 65 28 29 22 29 3b 0a 20 20 20 20 20 20 7d 0a  ze()");.      }.
1160: 20 20 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c 69        stmt._sqli
1170: 74 65 5f 73 74 6d 74 20 3d 20 30 3b 0a 20 20 20  te_stmt = 0;.   
1180: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
1190: 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 52 65   override int Re
11a0: 73 65 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d  set(SQLiteStatem
11b0: 65 6e 74 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a  ent stmt).    {.
11c0: 20 20 20 20 20 20 69 6e 74 20 6e 3b 0a 0a 20 20        int n;..  
11d0: 20 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61      n = UnsafeNa
11e0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
11f0: 74 65 33 5f 72 65 73 65 74 5f 69 6e 74 65 72 6f  te3_reset_intero
1200: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
1210: 74 6d 74 29 3b 0a 0a 20 20 20 20 20 20 2f 2f 20  tmt);..      // 
1220: 49 66 20 74 68 65 20 73 63 68 65 6d 61 20 63 68  If the schema ch
1230: 61 6e 67 65 64 2c 20 74 72 79 20 61 6e 64 20 72  anged, try and r
1240: 65 2d 70 72 65 70 61 72 65 20 69 74 0a 20 20 20  e-prepare it.   
1250: 20 20 20 69 66 20 28 6e 20 3d 3d 20 31 37 29 20     if (n == 17) 
1260: 2f 2f 20 53 51 4c 49 54 45 5f 53 43 48 45 4d 41  // SQLITE_SCHEMA
1270: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
1280: 20 2f 2f 20 52 65 63 72 65 61 74 65 20 61 20 64   // Recreate a d
1290: 75 6d 6d 79 20 73 74 61 74 65 6d 65 6e 74 0a 20  ummy statement. 
12a0: 20 20 20 20 20 20 20 69 6e 74 20 6e 63 20 3d 20         int nc = 
12b0: 30 3b 0a 20 20 20 20 20 20 20 20 73 74 72 69 6e  0;.        strin
12c0: 67 20 73 74 72 3b 0a 20 20 20 20 20 20 20 20 75  g str;.        u
12d0: 73 69 6e 67 20 28 53 51 4c 69 74 65 53 74 61 74  sing (SQLiteStat
12e0: 65 6d 65 6e 74 20 74 6d 70 20 3d 20 50 72 65 70  ement tmp = Prep
12f0: 61 72 65 28 73 74 6d 74 2e 5f 73 71 6c 53 74 61  are(stmt._sqlSta
1300: 74 65 6d 65 6e 74 2c 20 72 65 66 20 6e 63 2c 20  tement, ref nc, 
1310: 6f 75 74 20 73 74 72 29 29 0a 20 20 20 20 20 20  out str)).      
1320: 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 2f 2f    {.          //
1330: 20 46 69 6e 61 6c 69 7a 65 20 74 68 65 20 65 78   Finalize the ex
1340: 69 73 74 69 6e 67 20 73 74 61 74 65 6d 65 6e 74  isting statement
1350: 0a 20 20 20 20 20 20 20 20 20 20 46 69 6e 61 6c  .          Final
1360: 69 7a 65 53 74 61 74 65 6d 65 6e 74 28 73 74 6d  izeStatement(stm
1370: 74 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f  t);..          /
1380: 2f 20 52 65 61 73 73 69 67 6e 20 61 20 6e 65 77  / Reassign a new
1390: 20 73 74 61 74 65 6d 65 6e 74 20 70 6f 69 6e 74   statement point
13a0: 65 72 20 74 6f 20 74 68 65 20 6f 6c 64 20 73 74  er to the old st
13b0: 61 74 65 6d 65 6e 74 20 61 6e 64 20 63 6c 65 61  atement and clea
13c0: 72 20 74 68 65 20 74 65 6d 70 6f 72 61 72 79 20  r the temporary 
13d0: 6f 6e 65 0a 20 20 20 20 20 20 20 20 20 20 73 74  one.          st
13e0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 20  mt._sqlite_stmt 
13f0: 3d 20 74 6d 70 2e 5f 73 71 6c 69 74 65 5f 73 74  = tmp._sqlite_st
1400: 6d 74 3b 0a 20 20 20 20 20 20 20 20 20 20 74 6d  mt;.          tm
1410: 70 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 20 3d  p._sqlite_stmt =
1420: 20 30 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f   0;..          /
1430: 2f 20 52 65 61 70 70 6c 79 20 70 61 72 61 6d 65  / Reapply parame
1440: 74 65 72 73 0a 20 20 20 20 20 20 20 20 20 20 73  ters.          s
1450: 74 6d 74 2e 42 69 6e 64 50 61 72 61 6d 65 74 65  tmt.BindParamete
1460: 72 73 28 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  rs();.        }.
1470: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 2d          return -
1480: 31 3b 20 2f 2f 20 52 65 73 65 74 20 77 61 73 20  1; // Reset was 
1490: 4f 4b 2c 20 77 69 74 68 20 73 63 68 65 6d 61 20  OK, with schema 
14a0: 63 68 61 6e 67 65 0a 20 20 20 20 20 20 7d 0a 20  change.      }. 
14b0: 20 20 20 20 20 65 6c 73 65 20 69 66 20 28 6e 20       else if (n 
14c0: 3d 3d 20 36 29 20 2f 2f 20 53 51 4c 49 54 45 5f  == 6) // SQLITE_
14d0: 4c 4f 43 4b 45 44 0a 20 20 20 20 20 20 20 20 72  LOCKED.        r
14e0: 65 74 75 72 6e 20 6e 3b 0a 0a 20 20 20 20 20 20  eturn n;..      
14f0: 69 66 20 28 6e 20 3e 20 30 29 0a 20 20 20 20 20  if (n > 0).     
1500: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c     throw new SQL
1510: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
1520: 22 69 6e 20 52 65 73 65 74 28 29 22 29 3b 0a 0a  "in Reset()");..
1530: 20 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b 20        return 0; 
1540: 2f 2f 20 57 65 20 72 65 73 65 74 20 4f 4b 2c 20  // We reset OK, 
1550: 6e 6f 20 73 63 68 65 6d 61 20 63 68 61 6e 67 65  no schema change
1560: 73 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  s.    }..    int
1570: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73  ernal override s
1580: 74 72 69 6e 67 20 53 51 4c 69 74 65 4c 61 73 74  tring SQLiteLast
1590: 45 72 72 6f 72 28 29 0a 20 20 20 20 7b 0a 20 20  Error().    {.  
15a0: 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20      int len;.   
15b0: 20 20 20 72 65 74 75 72 6e 20 54 6f 53 74 72 69     return ToStri
15c0: 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  ng(UnsafeNativeM
15d0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 65  ethods.sqlite3_e
15e0: 72 72 6d 73 67 5f 69 6e 74 65 72 6f 70 28 5f 73  rrmsg_interop(_s
15f0: 71 6c 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65  ql, out len), le
1600: 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  n);.    }..    i
1610: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1620: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
1630: 20 50 72 65 70 61 72 65 28 73 74 72 69 6e 67 20   Prepare(string 
1640: 73 74 72 53 71 6c 2c 20 72 65 66 20 69 6e 74 20  strSql, ref int 
1650: 6e 50 61 72 61 6d 53 74 61 72 74 2c 20 6f 75 74  nParamStart, out
1660: 20 73 74 72 69 6e 67 20 73 74 72 52 65 6d 61 69   string strRemai
1670: 6e 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  n).    {.      i
1680: 6e 74 20 73 74 6d 74 3b 0a 20 20 20 20 20 20 49  nt stmt;.      I
1690: 6e 74 50 74 72 20 70 74 72 3b 0a 20 20 20 20 20  ntPtr ptr;.     
16a0: 20 69 6e 74 20 6c 65 6e 3b 0a 0a 20 20 20 20 20   int len;..     
16b0: 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54   byte[] b = ToUT
16c0: 46 38 28 73 74 72 53 71 6c 29 3b 0a 0a 20 20 20  F8(strSql);..   
16d0: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
16e0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
16f0: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 69  qlite3_prepare_i
1700: 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 62 2c 20  nterop(_sql, b, 
1710: 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20 6f 75  b.Length - 1, ou
1720: 74 20 73 74 6d 74 2c 20 6f 75 74 20 70 74 72 2c  t stmt, out ptr,
1730: 20 6f 75 74 20 6c 65 6e 29 3b 0a 20 20 20 20 20   out len);.     
1740: 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f   if (n > 0) thro
1750: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
1760: 70 74 69 6f 6e 28 6e 2c 20 22 69 6e 20 50 72 65  ption(n, "in Pre
1770: 70 61 72 65 28 29 22 29 3b 0a 0a 20 20 20 20 20  pare()");..     
1780: 20 73 74 72 52 65 6d 61 69 6e 20 3d 20 54 6f 53   strRemain = ToS
1790: 74 72 69 6e 67 28 70 74 72 2c 20 6c 65 6e 29 3b  tring(ptr, len);
17a0: 0a 0a 20 20 20 20 20 20 53 51 4c 69 74 65 53 74  ..      SQLiteSt
17b0: 61 74 65 6d 65 6e 74 20 63 6d 64 20 3d 20 6e 75  atement cmd = nu
17c0: 6c 6c 3b 0a 20 20 20 20 20 20 69 66 20 28 73 74  ll;.      if (st
17d0: 6d 74 20 3e 20 30 29 20 63 6d 64 20 3d 20 6e 65  mt > 0) cmd = ne
17e0: 77 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  w SQLiteStatemen
17f0: 74 28 74 68 69 73 2c 20 73 74 6d 74 2c 20 73 74  t(this, stmt, st
1800: 72 53 71 6c 2e 53 75 62 73 74 72 69 6e 67 28 30  rSql.Substring(0
1810: 2c 20 73 74 72 53 71 6c 2e 4c 65 6e 67 74 68 20  , strSql.Length 
1820: 2d 20 73 74 72 52 65 6d 61 69 6e 2e 4c 65 6e 67  - strRemain.Leng
1830: 74 68 29 2c 20 72 65 66 20 6e 50 61 72 61 6d 53  th), ref nParamS
1840: 74 61 72 74 29 3b 0a 0a 20 20 20 20 20 20 72 65  tart);..      re
1850: 74 75 72 6e 20 63 6d 64 3b 0a 20 20 20 20 7d 0a  turn cmd;.    }.
1860: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
1870: 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64  erride void Bind
1880: 5f 44 6f 75 62 6c 65 28 53 51 4c 69 74 65 53 74  _Double(SQLiteSt
1890: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
18a0: 74 20 69 6e 64 65 78 2c 20 64 6f 75 62 6c 65 20  t index, double 
18b0: 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20  value).    {.   
18c0: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
18d0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
18e0: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62  qlite3_bind_doub
18f0: 6c 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  le_interop(stmt.
1900: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e  _sqlite_stmt, in
1910: 64 65 78 2c 20 72 65 66 20 76 61 6c 75 65 29 3b  dex, ref value);
1920: 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30  .      if (n > 0
1930: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
1940: 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 22  teException(n, "
1950: 69 6e 20 42 69 6e 64 5f 44 6f 75 62 6c 65 28 29  in Bind_Double()
1960: 22 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  ");.    }..    i
1970: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1980: 20 76 6f 69 64 20 42 69 6e 64 5f 49 6e 74 33 32   void Bind_Int32
1990: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
19a0: 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78   stmt, int index
19b0: 2c 20 69 6e 74 20 76 61 6c 75 65 29 0a 20 20 20  , int value).   
19c0: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d   {.      int n =
19d0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
19e0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
19f0: 64 5f 69 6e 74 5f 69 6e 74 65 72 6f 70 28 73 74  d_int_interop(st
1a00: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
1a10: 20 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0a   index, value);.
1a20: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
1a30: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
1a40: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 22 69  eException(n, "i
1a50: 6e 20 42 69 6e 64 5f 49 6e 74 33 32 28 29 22 29  n Bind_Int32()")
1a60: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
1a70: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
1a80: 6f 69 64 20 42 69 6e 64 5f 49 6e 74 36 34 28 53  oid Bind_Int64(S
1a90: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73  QLiteStatement s
1aa0: 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20  tmt, int index, 
1ab0: 6c 6f 6e 67 20 76 61 6c 75 65 29 0a 20 20 20 20  long value).    
1ac0: 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  {.      int n = 
1ad0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
1ae0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
1af0: 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 73  _int64_interop(s
1b00: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
1b10: 2c 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c  , index, ref val
1b20: 75 65 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e  ue);.      if (n
1b30: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
1b40: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
1b50: 6e 2c 20 22 69 6e 20 42 69 6e 64 5f 49 6e 74 36  n, "in Bind_Int6
1b60: 34 28 29 22 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  4()");.    }..  
1b70: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
1b80: 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 54 65  ide void Bind_Te
1b90: 78 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  xt(SQLiteStateme
1ba0: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
1bb0: 65 78 2c 20 73 74 72 69 6e 67 20 76 61 6c 75 65  ex, string value
1bc0: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 62 79  ).    {.      by
1bd0: 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54 46 38 28  te[] b = ToUTF8(
1be0: 76 61 6c 75 65 29 3b 0a 20 20 20 20 20 20 69 6e  value);.      in
1bf0: 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  t n = UnsafeNati
1c00: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1c10: 33 5f 62 69 6e 64 5f 74 65 78 74 5f 69 6e 74 65  3_bind_text_inte
1c20: 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  rop(stmt._sqlite
1c30: 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 62 2c  _stmt, index, b,
1c40: 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20 2d   b.Length - 1, -
1c50: 31 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20  1);.      if (n 
1c60: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
1c70: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
1c80: 2c 20 22 69 6e 20 42 69 6e 64 5f 54 65 78 74 28  , "in Bind_Text(
1c90: 29 22 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  )");.    }..    
1ca0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
1cb0: 65 20 76 6f 69 64 20 42 69 6e 64 5f 44 61 74 65  e void Bind_Date
1cc0: 54 69 6d 65 28 53 51 4c 69 74 65 53 74 61 74 65  Time(SQLiteState
1cd0: 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69  ment stmt, int i
1ce0: 6e 64 65 78 2c 20 44 61 74 65 54 69 6d 65 20 64  ndex, DateTime d
1cf0: 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 62  t).    {.      b
1d00: 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54 46 38  yte[] b = ToUTF8
1d10: 28 64 74 29 3b 0a 20 20 20 20 20 20 69 6e 74 20  (dt);.      int 
1d20: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
1d30: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
1d40: 62 69 6e 64 5f 74 65 78 74 5f 69 6e 74 65 72 6f  bind_text_intero
1d50: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
1d60: 74 6d 74 2c 20 69 6e 64 65 78 2c 20 62 2c 20 62  tmt, index, b, b
1d70: 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20 2d 31 29  .Length - 1, -1)
1d80: 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20  ;.      if (n > 
1d90: 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c  0) throw new SQL
1da0: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
1db0: 22 69 6e 20 42 69 6e 64 5f 44 61 74 65 54 69 6d  "in Bind_DateTim
1dc0: 65 28 29 22 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  e()");.    }..  
1dd0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
1de0: 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 42 6c  ide void Bind_Bl
1df0: 6f 62 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  ob(SQLiteStateme
1e00: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
1e10: 65 78 2c 20 62 79 74 65 5b 5d 20 62 6c 6f 62 44  ex, byte[] blobD
1e20: 61 74 61 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  ata).    {.     
1e30: 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e   int n = UnsafeN
1e40: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
1e50: 69 74 65 33 5f 62 69 6e 64 5f 62 6c 6f 62 5f 69  ite3_bind_blob_i
1e60: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
1e70: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
1e80: 20 62 6c 6f 62 44 61 74 61 2c 20 62 6c 6f 62 44   blobData, blobD
1e90: 61 74 61 2e 4c 65 6e 67 74 68 2c 20 2d 31 29 3b  ata.Length, -1);
1ea0: 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30  .      if (n > 0
1eb0: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
1ec0: 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 22  teException(n, "
1ed0: 69 6e 20 42 69 6e 64 5f 42 6c 6f 62 28 29 22 29  in Bind_Blob()")
1ee0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
1ef0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
1f00: 6f 69 64 20 42 69 6e 64 5f 4e 75 6c 6c 28 53 51  oid Bind_Null(SQ
1f10: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
1f20: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20  mt, int index). 
1f30: 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e     {.      int n
1f40: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
1f50: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
1f60: 69 6e 64 5f 6e 75 6c 6c 5f 69 6e 74 65 72 6f 70  ind_null_interop
1f70: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
1f80: 6d 74 2c 20 69 6e 64 65 78 29 3b 0a 20 20 20 20  mt, index);.    
1f90: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
1fa0: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
1fb0: 65 70 74 69 6f 6e 28 6e 2c 20 22 69 6e 20 42 69  eption(n, "in Bi
1fc0: 6e 64 5f 4e 75 6c 6c 28 29 22 29 3b 0a 20 20 20  nd_Null()");.   
1fd0: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
1fe0: 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 42 69   override int Bi
1ff0: 6e 64 5f 50 61 72 61 6d 43 6f 75 6e 74 28 53 51  nd_ParamCount(SQ
2000: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
2010: 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  mt).    {.      
2020: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
2030: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
2040: 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65  e3_bind_paramete
2050: 72 5f 63 6f 75 6e 74 5f 69 6e 74 65 72 6f 70 28  r_count_interop(
2060: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
2070: 74 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  t);.    }..    i
2080: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
2090: 20 73 74 72 69 6e 67 20 42 69 6e 64 5f 50 61 72   string Bind_Par
20a0: 61 6d 4e 61 6d 65 28 53 51 4c 69 74 65 53 74 61  amName(SQLiteSta
20b0: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
20c0: 20 69 6e 64 65 78 29 0a 20 20 20 20 7b 0a 20 20   index).    {.  
20d0: 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20      int len;.   
20e0: 20 20 20 72 65 74 75 72 6e 20 54 6f 53 74 72 69     return ToStri
20f0: 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  ng(UnsafeNativeM
2100: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
2110: 69 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f 6e 61  ind_parameter_na
2120: 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  me_interop(stmt.
2130: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e  _sqlite_stmt, in
2140: 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c  dex, out len), l
2150: 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  en);.    }..    
2160: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
2170: 65 20 69 6e 74 20 42 69 6e 64 5f 50 61 72 61 6d  e int Bind_Param
2180: 49 6e 64 65 78 28 53 51 4c 69 74 65 53 74 61 74  Index(SQLiteStat
2190: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 73 74 72 69  ement stmt, stri
21a0: 6e 67 20 70 61 72 61 6d 4e 61 6d 65 29 0a 20 20  ng paramName).  
21b0: 20 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e    {.      return
21c0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
21d0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
21e0: 64 5f 70 61 72 61 6d 65 74 65 72 5f 69 6e 64 65  d_parameter_inde
21f0: 78 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  x_interop(stmt._
2200: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 54 6f 55  sqlite_stmt, ToU
2210: 54 46 38 28 70 61 72 61 6d 4e 61 6d 65 29 29 3b  TF8(paramName));
2220: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
2230: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e  rnal override in
2240: 74 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74 28 53 51  t ColumnCount(SQ
2250: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
2260: 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  mt).    {.      
2270: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
2280: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
2290: 65 33 5f 63 6f 6c 75 6d 6e 5f 63 6f 75 6e 74 5f  e3_column_count_
22a0: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
22b0: 6c 69 74 65 5f 73 74 6d 74 29 3b 0a 20 20 20 20  lite_stmt);.    
22c0: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
22d0: 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67 20  override string 
22e0: 43 6f 6c 75 6d 6e 4e 61 6d 65 28 53 51 4c 69 74  ColumnName(SQLit
22f0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
2300: 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20   int index).    
2310: 7b 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b  {.      int len;
2320: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f  .      return To
2330: 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74  String(UnsafeNat
2340: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
2350: 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 5f 69  e3_column_name_i
2360: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
2370: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
2380: 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b   out len), len);
2390: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
23a0: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74  rnal override st
23b0: 72 69 6e 67 20 43 6f 6c 75 6d 6e 54 79 70 65 28  ring ColumnType(
23c0: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
23d0: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c  stmt, int index,
23e0: 20 6f 75 74 20 54 79 70 65 41 66 66 69 6e 69 74   out TypeAffinit
23f0: 79 20 6e 41 66 66 69 6e 69 74 79 29 0a 20 20 20  y nAffinity).   
2400: 20 7b 0a 20 20 20 20 20 20 6e 41 66 66 69 6e 69   {.      nAffini
2410: 74 79 20 3d 20 54 79 70 65 41 66 66 69 6e 69 74  ty = TypeAffinit
2420: 79 2e 4e 6f 6e 65 3b 0a 0a 20 20 20 20 20 20 69  y.None;..      i
2430: 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20 49 6e  nt len;.      In
2440: 74 50 74 72 20 70 20 3d 20 55 6e 73 61 66 65 4e  tPtr p = UnsafeN
2450: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
2460: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c  ite3_column_decl
2470: 74 79 70 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d  type_interop(stm
2480: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
2490: 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 3b  index, out len);
24a0: 0a 20 20 20 20 20 20 69 66 20 28 70 20 21 3d 20  .      if (p != 
24b0: 49 6e 74 50 74 72 2e 5a 65 72 6f 29 20 72 65 74  IntPtr.Zero) ret
24c0: 75 72 6e 20 54 6f 53 74 72 69 6e 67 28 70 2c 20  urn ToString(p, 
24d0: 6c 65 6e 29 3b 0a 20 20 20 20 20 20 65 6c 73 65  len);.      else
24e0: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
24f0: 20 6e 41 66 66 69 6e 69 74 79 20 3d 20 55 6e 73   nAffinity = Uns
2500: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
2510: 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  .sqlite3_column_
2520: 74 79 70 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d  type_interop(stm
2530: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
2540: 69 6e 64 65 78 29 3b 0a 20 20 20 20 20 20 20 20  index);.        
2550: 73 77 69 74 63 68 20 28 6e 41 66 66 69 6e 69 74  switch (nAffinit
2560: 79 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  y).        {.   
2570: 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65         case Type
2580: 41 66 66 69 6e 69 74 79 2e 49 6e 74 36 34 3a 0a  Affinity.Int64:.
2590: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
25a0: 72 6e 20 22 42 49 47 49 4e 54 22 3b 0a 20 20 20  rn "BIGINT";.   
25b0: 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65         case Type
25c0: 41 66 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65 3a  Affinity.Double:
25d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74  .            ret
25e0: 75 72 6e 20 22 44 4f 55 42 4c 45 22 3b 0a 20 20  urn "DOUBLE";.  
25f0: 20 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70          case Typ
2600: 65 41 66 66 69 6e 69 74 79 2e 42 6c 6f 62 3a 0a  eAffinity.Blob:.
2610: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
2620: 72 6e 20 22 42 4c 4f 42 22 3b 0a 20 20 20 20 20  rn "BLOB";.     
2630: 20 20 20 20 20 64 65 66 61 75 6c 74 3a 0a 20 20       default:.  
2640: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
2650: 20 22 54 45 58 54 22 3b 0a 20 20 20 20 20 20 20   "TEXT";.       
2660: 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d   }.      }.    }
2670: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
2680: 76 65 72 72 69 64 65 20 69 6e 74 20 43 6f 6c 75  verride int Colu
2690: 6d 6e 49 6e 64 65 78 28 53 51 4c 69 74 65 53 74  mnIndex(SQLiteSt
26a0: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 73 74  atement stmt, st
26b0: 72 69 6e 67 20 63 6f 6c 75 6d 6e 4e 61 6d 65 29  ring columnName)
26c0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74  .    {.      int
26d0: 20 78 20 3d 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74   x = ColumnCount
26e0: 28 73 74 6d 74 29 3b 0a 0a 20 20 20 20 20 20 66  (stmt);..      f
26f0: 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20 6e  or (int n = 0; n
2700: 20 3c 20 78 3b 20 6e 2b 2b 29 0a 20 20 20 20 20   < x; n++).     
2710: 20 7b 0a 20 20 20 20 20 20 20 20 69 66 20 28 53   {.        if (S
2720: 74 72 69 6e 67 2e 43 6f 6d 70 61 72 65 28 63 6f  tring.Compare(co
2730: 6c 75 6d 6e 4e 61 6d 65 2c 20 43 6f 6c 75 6d 6e  lumnName, Column
2740: 4e 61 6d 65 28 73 74 6d 74 2c 20 6e 29 2c 20 74  Name(stmt, n), t
2750: 72 75 65 29 20 3d 3d 20 30 29 20 72 65 74 75 72  rue) == 0) retur
2760: 6e 20 6e 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  n n;.      }.   
2770: 20 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20     return -1;.  
2780: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
2790: 6c 20 6f 76 65 72 72 69 64 65 20 64 6f 75 62 6c  l override doubl
27a0: 65 20 47 65 74 44 6f 75 62 6c 65 28 53 51 4c 69  e GetDouble(SQLi
27b0: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
27c0: 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20  , int index).   
27d0: 20 7b 0a 20 20 20 20 20 20 64 6f 75 62 6c 65 20   {.      double 
27e0: 76 61 6c 75 65 3b 0a 20 20 20 20 20 20 55 6e 73  value;.      Uns
27f0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
2800: 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  .sqlite3_column_
2810: 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 73  double_interop(s
2820: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
2830: 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20 76 61 6c  , index, out val
2840: 75 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72  ue);.      retur
2850: 6e 20 76 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a  n value;.    }..
2860: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
2870: 72 72 69 64 65 20 69 6e 74 20 47 65 74 49 6e 74  rride int GetInt
2880: 33 32 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  32(SQLiteStateme
2890: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
28a0: 65 78 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  ex).    {.      
28b0: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
28c0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
28d0: 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 5f 69 6e  e3_column_int_in
28e0: 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69  terop(stmt._sqli
28f0: 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b  te_stmt, index);
2900: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
2910: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f  rnal override lo
2920: 6e 67 20 47 65 74 49 6e 74 36 34 28 53 51 4c 69  ng GetInt64(SQLi
2930: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
2940: 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20  , int index).   
2950: 20 7b 0a 20 20 20 20 20 20 6c 6f 6e 67 20 76 61   {.      long va
2960: 6c 75 65 3b 0a 20 20 20 20 20 20 55 6e 73 61 66  lue;.      Unsaf
2970: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
2980: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e  qlite3_column_in
2990: 74 36 34 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74  t64_interop(stmt
29a0: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
29b0: 6e 64 65 78 2c 20 6f 75 74 20 76 61 6c 75 65 29  ndex, out value)
29c0: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 76  ;.      return v
29d0: 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  alue;.    }..   
29e0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
29f0: 64 65 20 73 74 72 69 6e 67 20 47 65 74 54 65 78  de string GetTex
2a00: 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  t(SQLiteStatemen
2a10: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
2a20: 78 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  x).    {.      i
2a30: 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20 72 65  nt len;.      re
2a40: 74 75 72 6e 20 54 6f 53 74 72 69 6e 67 28 55 6e  turn ToString(Un
2a50: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
2a60: 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  s.sqlite3_column
2a70: 5f 74 65 78 74 5f 69 6e 74 65 72 6f 70 28 73 74  _text_interop(st
2a80: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
2a90: 20 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29   index, out len)
2aa0: 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20  , len);.    }.. 
2ab0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
2ac0: 72 69 64 65 20 44 61 74 65 54 69 6d 65 20 47 65  ride DateTime Ge
2ad0: 74 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74 65  tDateTime(SQLite
2ae0: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
2af0: 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20 7b  int index).    {
2b00: 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a  .      int len;.
2b10: 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 44        return ToD
2b20: 61 74 65 54 69 6d 65 28 55 6e 73 61 66 65 4e 61  ateTime(UnsafeNa
2b30: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
2b40: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 5f  te3_column_text_
2b50: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
2b60: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
2b70: 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29  , out len), len)
2b80: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
2b90: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c  ernal override l
2ba0: 6f 6e 67 20 47 65 74 42 79 74 65 73 28 53 51 4c  ong GetBytes(SQL
2bb0: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
2bc0: 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69 6e  t, int index, in
2bd0: 74 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 62  t nDataOffset, b
2be0: 79 74 65 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74  yte[] bDest, int
2bf0: 20 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65   nStart, int nLe
2c00: 6e 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20 20  ngth).    {.    
2c10: 20 20 49 6e 74 50 74 72 20 70 74 72 3b 0a 20 20    IntPtr ptr;.  
2c20: 20 20 20 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20 20      int nlen;.  
2c30: 20 20 20 20 69 6e 74 20 6e 43 6f 70 69 65 64 20      int nCopied 
2c40: 3d 20 6e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20  = nLength;..    
2c50: 20 20 6e 6c 65 6e 20 3d 20 55 6e 73 61 66 65 4e    nlen = UnsafeN
2c60: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
2c70: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65  ite3_column_byte
2c80: 73 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  s_interop(stmt._
2c90: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
2ca0: 65 78 29 3b 0a 20 20 20 20 20 20 70 74 72 20 3d  ex);.      ptr =
2cb0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
2cc0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c  hods.sqlite3_col
2cd0: 75 6d 6e 5f 62 6c 6f 62 5f 69 6e 74 65 72 6f 70  umn_blob_interop
2ce0: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
2cf0: 6d 74 2c 20 69 6e 64 65 78 29 3b 0a 0a 20 20 20  mt, index);..   
2d00: 20 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d 20     if (bDest == 
2d10: 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65  null) return nle
2d20: 6e 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43  n;..      if (nC
2d30: 6f 70 69 65 64 20 2b 20 6e 53 74 61 72 74 20 3e  opied + nStart >
2d40: 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e   bDest.Length) n
2d50: 43 6f 70 69 65 64 20 3d 20 62 44 65 73 74 2e 4c  Copied = bDest.L
2d60: 65 6e 67 74 68 20 2d 20 6e 53 74 61 72 74 3b 0a  ength - nStart;.
2d70: 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65        if (nCopie
2d80: 64 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20  d + nDataOffset 
2d90: 3e 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20  > nlen) nCopied 
2da0: 3d 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66  = nlen - nDataOf
2db0: 66 73 65 74 3b 0a 0a 20 20 20 20 20 20 69 66 20  fset;..      if 
2dc0: 28 6e 43 6f 70 69 65 64 20 3e 20 30 29 0a 20 20  (nCopied > 0).  
2dd0: 20 20 20 20 20 20 4d 61 72 73 68 61 6c 2e 43 6f        Marshal.Co
2de0: 70 79 28 28 49 6e 74 50 74 72 29 28 70 74 72 2e  py((IntPtr)(ptr.
2df0: 54 6f 49 6e 74 33 32 28 29 20 2b 20 6e 44 61 74  ToInt32() + nDat
2e00: 61 4f 66 66 73 65 74 29 2c 20 62 44 65 73 74 2c  aOffset), bDest,
2e10: 20 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69 65 64   nStart, nCopied
2e20: 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 6e 43  );.      else nC
2e30: 6f 70 69 65 64 20 3d 20 30 3b 0a 0a 20 20 20 20  opied = 0;..    
2e40: 20 20 72 65 74 75 72 6e 20 6e 43 6f 70 69 65 64    return nCopied
2e50: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
2e60: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c  ernal override l
2e70: 6f 6e 67 20 47 65 74 43 68 61 72 73 28 53 51 4c  ong GetChars(SQL
2e80: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
2e90: 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69 6e  t, int index, in
2ea0: 74 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 63  t nDataOffset, c
2eb0: 68 61 72 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74  har[] bDest, int
2ec0: 20 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65   nStart, int nLe
2ed0: 6e 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20 20  ngth).    {.    
2ee0: 20 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20 20 20 20    int nlen;.    
2ef0: 20 20 69 6e 74 20 6e 43 6f 70 69 65 64 20 3d 20    int nCopied = 
2f00: 6e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20 20  nLength;..      
2f10: 73 74 72 69 6e 67 20 73 74 72 20 3d 20 47 65 74  string str = Get
2f20: 54 65 78 74 28 73 74 6d 74 2c 20 69 6e 64 65 78  Text(stmt, index
2f30: 29 3b 0a 20 20 20 20 20 20 6e 6c 65 6e 20 3d 20  );.      nlen = 
2f40: 73 74 72 2e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20  str.Length;..   
2f50: 20 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d 20     if (bDest == 
2f60: 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65  null) return nle
2f70: 6e 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43  n;..      if (nC
2f80: 6f 70 69 65 64 20 2b 20 6e 53 74 61 72 74 20 3e  opied + nStart >
2f90: 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e   bDest.Length) n
2fa0: 43 6f 70 69 65 64 20 3d 20 62 44 65 73 74 2e 4c  Copied = bDest.L
2fb0: 65 6e 67 74 68 20 2d 20 6e 53 74 61 72 74 3b 0a  ength - nStart;.
2fc0: 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65        if (nCopie
2fd0: 64 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20  d + nDataOffset 
2fe0: 3e 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20  > nlen) nCopied 
2ff0: 3d 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66  = nlen - nDataOf
3000: 66 73 65 74 3b 0a 0a 20 20 20 20 20 20 69 66 20  fset;..      if 
3010: 28 6e 43 6f 70 69 65 64 20 3e 20 30 29 0a 20 20  (nCopied > 0).  
3020: 20 20 20 20 20 20 73 74 72 2e 43 6f 70 79 54 6f        str.CopyTo
3030: 28 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 62 44  (nDataOffset, bD
3040: 65 73 74 2c 20 6e 53 74 61 72 74 2c 20 6e 43 6f  est, nStart, nCo
3050: 70 69 65 64 29 3b 0a 20 20 20 20 20 20 65 6c 73  pied);.      els
3060: 65 20 6e 43 6f 70 69 65 64 20 3d 20 30 3b 0a 0a  e nCopied = 0;..
3070: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f        return nCo
3080: 70 69 65 64 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  pied;.    }..   
3090: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
30a0: 64 65 20 62 6f 6f 6c 20 49 73 4e 75 6c 6c 28 53  de bool IsNull(S
30b0: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73  QLiteStatement s
30c0: 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a  tmt, int index).
30d0: 20 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74 75      {.      retu
30e0: 72 6e 20 28 55 6e 73 61 66 65 4e 61 74 69 76 65  rn (UnsafeNative
30f0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
3100: 63 6f 6c 75 6d 6e 5f 74 79 70 65 5f 69 6e 74 65  column_type_inte
3110: 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  rop(stmt._sqlite
3120: 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 20 3d 3d  _stmt, index) ==
3130: 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 4e 75   TypeAffinity.Nu
3140: 6c 6c 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ll);.    }..    
3150: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
3160: 65 20 69 6e 74 20 41 67 67 72 65 67 61 74 65 43  e int AggregateC
3170: 6f 75 6e 74 28 69 6e 74 20 63 6f 6e 74 65 78 74  ount(int context
3180: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72 65  ).    {.      re
3190: 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76  turn UnsafeNativ
31a0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
31b0: 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 75 6e 74  _aggregate_count
31c0: 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74  _interop(context
31d0: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
31e0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
31f0: 69 6e 74 20 43 72 65 61 74 65 46 75 6e 63 74 69  int CreateFuncti
3200: 6f 6e 28 73 74 72 69 6e 67 20 73 74 72 46 75 6e  on(string strFun
3210: 63 74 69 6f 6e 2c 20 69 6e 74 20 6e 41 72 67 73  ction, int nArgs
3220: 2c 20 53 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b  , SQLiteCallback
3230: 20 66 75 6e 63 2c 20 53 51 4c 69 74 65 43 61 6c   func, SQLiteCal
3240: 6c 62 61 63 6b 20 66 75 6e 63 73 74 65 70 2c 20  lback funcstep, 
3250: 53 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b 20 66  SQLiteCallback f
3260: 75 6e 63 66 69 6e 61 6c 29 0a 20 20 20 20 7b 0a  uncfinal).    {.
3270: 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 6f 6b 69        int nCooki
3280: 65 3b 0a 0a 20 20 20 20 20 20 69 6e 74 20 6e 20  e;..      int n 
3290: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
32a0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 72  thods.sqlite3_cr
32b0: 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 5f 69 6e  eate_function_in
32c0: 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55 54  terop(_sql, ToUT
32d0: 46 38 28 73 74 72 46 75 6e 63 74 69 6f 6e 29 2c  F8(strFunction),
32e0: 20 6e 41 72 67 73 2c 20 31 2c 20 66 75 6e 63 2c   nArgs, 1, func,
32f0: 20 66 75 6e 63 73 74 65 70 2c 20 66 75 6e 63 66   funcstep, funcf
3300: 69 6e 61 6c 2c 20 6f 75 74 20 6e 43 6f 6f 6b 69  inal, out nCooki
3310: 65 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20  e);.      if (n 
3320: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
3330: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
3340: 2c 20 22 69 6e 20 43 72 65 61 74 65 46 75 6e 63  , "in CreateFunc
3350: 74 69 6f 6e 28 29 22 29 3b 0a 0a 20 20 20 20 20  tion()");..     
3360: 20 72 65 74 75 72 6e 20 6e 43 6f 6f 6b 69 65 3b   return nCookie;
3370: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
3380: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e  rnal override in
3390: 74 20 43 72 65 61 74 65 43 6f 6c 6c 61 74 69 6f  t CreateCollatio
33a0: 6e 28 73 74 72 69 6e 67 20 73 74 72 43 6f 6c 6c  n(string strColl
33b0: 61 74 69 6f 6e 2c 20 53 51 4c 69 74 65 43 6f 6c  ation, SQLiteCol
33c0: 6c 61 74 69 6f 6e 20 66 75 6e 63 29 0a 20 20 20  lation func).   
33d0: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 43 6f   {.      int nCo
33e0: 6f 6b 69 65 3b 0a 0a 20 20 20 20 20 20 69 6e 74  okie;..      int
33f0: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
3400: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
3410: 5f 63 72 65 61 74 65 5f 63 6f 6c 6c 61 74 69 6f  _create_collatio
3420: 6e 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20  n_interop(_sql, 
3430: 54 6f 55 54 46 38 28 73 74 72 43 6f 6c 6c 61 74  ToUTF8(strCollat
3440: 69 6f 6e 29 2c 20 31 2c 20 30 2c 20 66 75 6e 63  ion), 1, 0, func
3450: 2c 20 6f 75 74 20 6e 43 6f 6f 6b 69 65 29 3b 0a  , out nCookie);.
3460: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
3470: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
3480: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 22 69  eException(n, "i
3490: 6e 20 43 72 65 61 74 65 43 6f 6c 6c 61 74 69 6f  n CreateCollatio
34a0: 6e 28 29 22 29 3b 0a 0a 20 20 20 20 20 20 72 65  n()");..      re
34b0: 74 75 72 6e 20 6e 43 6f 6f 6b 69 65 3b 0a 20 20  turn nCookie;.  
34c0: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
34d0: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
34e0: 46 72 65 65 46 75 6e 63 74 69 6f 6e 28 69 6e 74  FreeFunction(int
34f0: 20 6e 43 6f 6f 6b 69 65 29 0a 20 20 20 20 7b 0a   nCookie).    {.
3500: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
3510: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
3520: 33 5f 66 75 6e 63 74 69 6f 6e 5f 66 72 65 65 5f  3_function_free_
3530: 63 61 6c 6c 62 61 63 6b 63 6f 6f 6b 69 65 28 6e  callbackcookie(n
3540: 43 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 7d 0a 0a  Cookie);.    }..
3550: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
3560: 72 72 69 64 65 20 6c 6f 6e 67 20 47 65 74 50 61  rride long GetPa
3570: 72 61 6d 56 61 6c 75 65 42 79 74 65 73 28 69 6e  ramValueBytes(in
3580: 74 20 70 2c 20 69 6e 74 20 6e 44 61 74 61 4f 66  t p, int nDataOf
3590: 66 73 65 74 2c 20 62 79 74 65 5b 5d 20 62 44 65  fset, byte[] bDe
35a0: 73 74 2c 20 69 6e 74 20 6e 53 74 61 72 74 2c 20  st, int nStart, 
35b0: 69 6e 74 20 6e 4c 65 6e 67 74 68 29 0a 20 20 20  int nLength).   
35c0: 20 7b 0a 20 20 20 20 20 20 49 6e 74 50 74 72 20   {.      IntPtr 
35d0: 70 74 72 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e  ptr;.      int n
35e0: 6c 65 6e 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e  len;.      int n
35f0: 43 6f 70 69 65 64 20 3d 20 6e 4c 65 6e 67 74 68  Copied = nLength
3600: 3b 0a 0a 20 20 20 20 20 20 6e 6c 65 6e 20 3d 20  ;..      nlen = 
3610: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3620: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75  ods.sqlite3_valu
3630: 65 5f 62 79 74 65 73 5f 69 6e 74 65 72 6f 70 28  e_bytes_interop(
3640: 70 29 3b 0a 20 20 20 20 20 20 70 74 72 20 3d 20  p);.      ptr = 
3650: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3660: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75  ods.sqlite3_valu
3670: 65 5f 62 6c 6f 62 5f 69 6e 74 65 72 6f 70 28 70  e_blob_interop(p
3680: 29 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 62 44  );..      if (bD
3690: 65 73 74 20 3d 3d 20 6e 75 6c 6c 29 20 72 65 74  est == null) ret
36a0: 75 72 6e 20 6e 6c 65 6e 3b 0a 0a 20 20 20 20 20  urn nlen;..     
36b0: 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b 20 6e   if (nCopied + n
36c0: 53 74 61 72 74 20 3e 20 62 44 65 73 74 2e 4c 65  Start > bDest.Le
36d0: 6e 67 74 68 29 20 6e 43 6f 70 69 65 64 20 3d 20  ngth) nCopied = 
36e0: 62 44 65 73 74 2e 4c 65 6e 67 74 68 20 2d 20 6e  bDest.Length - n
36f0: 53 74 61 72 74 3b 0a 20 20 20 20 20 20 69 66 20  Start;.      if 
3700: 28 6e 43 6f 70 69 65 64 20 2b 20 6e 44 61 74 61  (nCopied + nData
3710: 4f 66 66 73 65 74 20 3e 20 6e 6c 65 6e 29 20 6e  Offset > nlen) n
3720: 43 6f 70 69 65 64 20 3d 20 6e 6c 65 6e 20 2d 20  Copied = nlen - 
3730: 6e 44 61 74 61 4f 66 66 73 65 74 3b 0a 0a 20 20  nDataOffset;..  
3740: 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20      if (nCopied 
3750: 3e 20 30 29 0a 20 20 20 20 20 20 20 20 4d 61 72  > 0).        Mar
3760: 73 68 61 6c 2e 43 6f 70 79 28 28 49 6e 74 50 74  shal.Copy((IntPt
3770: 72 29 28 70 74 72 2e 54 6f 49 6e 74 33 32 28 29  r)(ptr.ToInt32()
3780: 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 29 2c   + nDataOffset),
3790: 20 62 44 65 73 74 2c 20 6e 53 74 61 72 74 2c 20   bDest, nStart, 
37a0: 6e 43 6f 70 69 65 64 29 3b 0a 20 20 20 20 20 20  nCopied);.      
37b0: 65 6c 73 65 20 6e 43 6f 70 69 65 64 20 3d 20 30  else nCopied = 0
37c0: 3b 0a 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ;..      return 
37d0: 6e 43 6f 70 69 65 64 3b 0a 20 20 20 20 7d 0a 0a  nCopied;.    }..
37e0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
37f0: 72 72 69 64 65 20 64 6f 75 62 6c 65 20 47 65 74  rride double Get
3800: 50 61 72 61 6d 56 61 6c 75 65 44 6f 75 62 6c 65  ParamValueDouble
3810: 28 69 6e 74 20 70 74 72 29 0a 20 20 20 20 7b 0a  (int ptr).    {.
3820: 20 20 20 20 20 20 64 6f 75 62 6c 65 20 76 61 6c        double val
3830: 75 65 3b 0a 20 20 20 20 20 20 55 6e 73 61 66 65  ue;.      Unsafe
3840: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
3850: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 64 6f 75 62  lite3_value_doub
3860: 6c 65 5f 69 6e 74 65 72 6f 70 28 70 74 72 2c 20  le_interop(ptr, 
3870: 6f 75 74 20 76 61 6c 75 65 29 3b 0a 20 20 20 20  out value);.    
3880: 20 20 72 65 74 75 72 6e 20 76 61 6c 75 65 3b 0a    return value;.
3890: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
38a0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
38b0: 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 49 6e   GetParamValueIn
38c0: 74 33 32 28 69 6e 74 20 70 74 72 29 0a 20 20 20  t32(int ptr).   
38d0: 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20   {.      return 
38e0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
38f0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75  ods.sqlite3_valu
3900: 65 5f 69 6e 74 5f 69 6e 74 65 72 6f 70 28 70 74  e_int_interop(pt
3910: 72 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  r);.    }..    i
3920: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
3930: 20 6c 6f 6e 67 20 47 65 74 50 61 72 61 6d 56 61   long GetParamVa
3940: 6c 75 65 49 6e 74 36 34 28 69 6e 74 20 70 74 72  lueInt64(int ptr
3950: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 49 6e  ).    {.      In
3960: 74 36 34 20 76 61 6c 75 65 3b 0a 20 20 20 20 20  t64 value;.     
3970: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
3980: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c  hods.sqlite3_val
3990: 75 65 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70  ue_int64_interop
39a0: 28 70 74 72 2c 20 6f 75 74 20 76 61 6c 75 65 29  (ptr, out value)
39b0: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 76  ;.      return v
39c0: 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  alue;.    }..   
39d0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
39e0: 64 65 20 73 74 72 69 6e 67 20 47 65 74 50 61 72  de string GetPar
39f0: 61 6d 56 61 6c 75 65 54 65 78 74 28 69 6e 74 20  amValueText(int 
3a00: 70 74 72 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  ptr).    {.     
3a10: 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20   int len;.      
3a20: 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e 67 28  return ToString(
3a30: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3a40: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75  ods.sqlite3_valu
3a50: 65 5f 74 65 78 74 5f 69 6e 74 65 72 6f 70 28 70  e_text_interop(p
3a60: 74 72 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65  tr, out len), le
3a70: 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  n);.    }..    i
3a80: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
3a90: 20 54 79 70 65 41 66 66 69 6e 69 74 79 20 47 65   TypeAffinity Ge
3aa0: 74 50 61 72 61 6d 56 61 6c 75 65 54 79 70 65 28  tParamValueType(
3ab0: 69 6e 74 20 70 74 72 29 0a 20 20 20 20 7b 0a 20  int ptr).    {. 
3ac0: 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61       return Unsa
3ad0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
3ae0: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 79  sqlite3_value_ty
3af0: 70 65 5f 69 6e 74 65 72 6f 70 28 70 74 72 29 3b  pe_interop(ptr);
3b00: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
3b10: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f  rnal override vo
3b20: 69 64 20 52 65 74 75 72 6e 42 6c 6f 62 28 69 6e  id ReturnBlob(in
3b30: 74 20 63 6f 6e 74 65 78 74 2c 20 62 79 74 65 5b  t context, byte[
3b40: 5d 20 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20  ] value).    {. 
3b50: 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76       UnsafeNativ
3b60: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
3b70: 5f 72 65 73 75 6c 74 5f 62 6c 6f 62 5f 69 6e 74  _result_blob_int
3b80: 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20 76 61  erop(context, va
3b90: 6c 75 65 2c 20 76 61 6c 75 65 2e 4c 65 6e 67 74  lue, value.Lengt
3ba0: 68 2c 20 2d 31 29 3b 0a 20 20 20 20 7d 0a 0a 20  h, -1);.    }.. 
3bb0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
3bc0: 72 69 64 65 20 76 6f 69 64 20 52 65 74 75 72 6e  ride void Return
3bd0: 44 6f 75 62 6c 65 28 69 6e 74 20 63 6f 6e 74 65  Double(int conte
3be0: 78 74 2c 20 64 6f 75 62 6c 65 20 76 61 6c 75 65  xt, double value
3bf0: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e  ).    {.      Un
3c00: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
3c10: 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74  s.sqlite3_result
3c20: 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28  _double_interop(
3c30: 63 6f 6e 74 65 78 74 2c 20 72 65 66 20 76 61 6c  context, ref val
3c40: 75 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ue);.    }..    
3c50: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
3c60: 65 20 76 6f 69 64 20 52 65 74 75 72 6e 45 72 72  e void ReturnErr
3c70: 6f 72 28 69 6e 74 20 63 6f 6e 74 65 78 74 2c 20  or(int context, 
3c80: 73 74 72 69 6e 67 20 76 61 6c 75 65 29 0a 20 20  string value).  
3c90: 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65    {.      Unsafe
3ca0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
3cb0: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 65 72 72  lite3_result_err
3cc0: 6f 72 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65  or_interop(conte
3cd0: 78 74 2c 20 54 6f 55 54 46 38 28 76 61 6c 75 65  xt, ToUTF8(value
3ce0: 29 2c 20 76 61 6c 75 65 2e 4c 65 6e 67 74 68 29  ), value.Length)
3cf0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
3d00: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
3d10: 6f 69 64 20 52 65 74 75 72 6e 49 6e 74 33 32 28  oid ReturnInt32(
3d20: 69 6e 74 20 63 6f 6e 74 65 78 74 2c 20 69 6e 74  int context, int
3d30: 20 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20   value).    {.  
3d40: 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65      UnsafeNative
3d50: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
3d60: 72 65 73 75 6c 74 5f 69 6e 74 5f 69 6e 74 65 72  result_int_inter
3d70: 6f 70 28 63 6f 6e 74 65 78 74 2c 20 76 61 6c 75  op(context, valu
3d80: 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  e);.    }..    i
3d90: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
3da0: 20 76 6f 69 64 20 52 65 74 75 72 6e 49 6e 74 36   void ReturnInt6
3db0: 34 28 69 6e 74 20 63 6f 6e 74 65 78 74 2c 20 6c  4(int context, l
3dc0: 6f 6e 67 20 76 61 6c 75 65 29 0a 20 20 20 20 7b  ong value).    {
3dd0: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
3de0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
3df0: 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34 5f  e3_result_int64_
3e00: 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c  interop(context,
3e10: 20 72 65 66 20 76 61 6c 75 65 29 3b 0a 20 20 20   ref value);.   
3e20: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
3e30: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 52   override void R
3e40: 65 74 75 72 6e 4e 75 6c 6c 28 69 6e 74 20 63 6f  eturnNull(int co
3e50: 6e 74 65 78 74 29 0a 20 20 20 20 7b 0a 20 20 20  ntext).    {.   
3e60: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
3e70: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72  ethods.sqlite3_r
3e80: 65 73 75 6c 74 5f 6e 75 6c 6c 5f 69 6e 74 65 72  esult_null_inter
3e90: 6f 70 28 63 6f 6e 74 65 78 74 29 3b 0a 20 20 20  op(context);.   
3ea0: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
3eb0: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 52   override void R
3ec0: 65 74 75 72 6e 54 65 78 74 28 69 6e 74 20 63 6f  eturnText(int co
3ed0: 6e 74 65 78 74 2c 20 73 74 72 69 6e 67 20 76 61  ntext, string va
3ee0: 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  lue).    {.     
3ef0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
3f00: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73  hods.sqlite3_res
3f10: 75 6c 74 5f 74 65 78 74 5f 69 6e 74 65 72 6f 70  ult_text_interop
3f20: 28 63 6f 6e 74 65 78 74 2c 20 54 6f 55 54 46 38  (context, ToUTF8
3f30: 28 76 61 6c 75 65 29 2c 20 76 61 6c 75 65 2e 4c  (value), value.L
3f40: 65 6e 67 74 68 2c 20 2d 31 29 3b 0a 20 20 20 20  ength, -1);.    
3f50: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
3f60: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 41 67 67  override int Agg
3f70: 72 65 67 61 74 65 43 6f 6e 74 65 78 74 28 69 6e  regateContext(in
3f80: 74 20 63 6f 6e 74 65 78 74 29 0a 20 20 20 20 7b  t context).    {
3f90: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e  .      return Un
3fa0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
3fb0: 73 2e 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67  s.sqlite3_aggreg
3fc0: 61 74 65 5f 63 6f 6e 74 65 78 74 5f 69 6e 74 65  ate_context_inte
3fd0: 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20 31 29 3b  rop(context, 1);
3fe0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
3ff0: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f  rnal override vo
4000: 69 64 20 53 65 74 52 65 61 6c 43 6f 6c 4e 61 6d  id SetRealColNam
4010: 65 73 28 62 6f 6f 6c 20 62 4f 6e 29 0a 20 20 20  es(bool bOn).   
4020: 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e   {.      UnsafeN
4030: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
4040: 69 74 65 33 5f 72 65 61 6c 63 6f 6c 6e 61 6d 65  ite3_realcolname
4050: 73 28 5f 73 71 6c 2c 20 43 6f 6e 76 65 72 74 2e  s(_sql, Convert.
4060: 54 6f 49 6e 74 33 32 28 62 4f 6e 29 29 3b 0a 20  ToInt32(bOn));. 
4070: 20 20 20 7d 0a 20 20 7d 0a 7d 0a                    }.  }.}.