System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact ba637b9539617e7d3bfd9c07c07c24e689748d71:


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 73 74 72 69 6e 67 20 56 65 72 73 69 6f 6e  e string Version
0590: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65 74  .    {.      get
05a0: 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20  .      {.       
05b0: 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20   int len;.      
05c0: 20 20 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e    return ToStrin
05d0: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
05e0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6c 69  thods.sqlite3_li
05f0: 62 76 65 72 73 69 6f 6e 5f 69 6e 74 65 72 6f 70  bversion_interop
0600: 28 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b  (out len), len);
0610: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a  .      }.    }..
0620: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
0630: 72 72 69 64 65 20 69 6e 74 20 43 68 61 6e 67 65  rride int Change
0640: 73 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65  s.    {.      ge
0650: 74 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20  t.      {.      
0660: 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e    return UnsafeN
0670: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
0680: 69 74 65 33 5f 63 68 61 6e 67 65 73 5f 69 6e 74  ite3_changes_int
0690: 65 72 6f 70 28 5f 73 71 6c 29 3b 0a 20 20 20 20  erop(_sql);.    
06a0: 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69    }.    }..    i
06b0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
06c0: 20 76 6f 69 64 20 4f 70 65 6e 28 73 74 72 69 6e   void Open(strin
06d0: 67 20 73 74 72 46 69 6c 65 6e 61 6d 65 29 0a 20  g strFilename). 
06e0: 20 20 20 7b 0a 20 20 20 20 20 20 69 66 20 28 5f     {.      if (_
06f0: 73 71 6c 20 21 3d 20 30 29 20 72 65 74 75 72 6e  sql != 0) return
0700: 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  ;.      int n = 
0710: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
0720: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6f 70 65 6e  ods.sqlite3_open
0730: 5f 69 6e 74 65 72 6f 70 28 54 6f 55 54 46 38 28  _interop(ToUTF8(
0740: 73 74 72 46 69 6c 65 6e 61 6d 65 29 2c 20 6f 75  strFilename), ou
0750: 74 20 5f 73 71 6c 29 3b 0a 20 20 20 20 20 20 69  t _sql);.      i
0760: 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20  f (n > 0) throw 
0770: 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74  new SQLiteExcept
0780: 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73  ion(n, SQLiteLas
0790: 74 45 72 72 6f 72 28 29 29 3b 0a 0a 20 20 20 20  tError());..    
07a0: 20 20 5f 66 75 6e 63 74 69 6f 6e 73 41 72 72 61    _functionsArra
07b0: 79 20 3d 20 53 51 4c 69 74 65 46 75 6e 63 74 69  y = SQLiteFuncti
07c0: 6f 6e 2e 42 69 6e 64 46 75 6e 63 74 69 6f 6e 73  on.BindFunctions
07d0: 28 74 68 69 73 29 3b 0a 20 20 20 20 7d 0a 0a 20  (this);.    }.. 
07e0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
07f0: 72 69 64 65 20 76 6f 69 64 20 53 65 74 54 69 6d  ride void SetTim
0800: 65 6f 75 74 28 69 6e 74 20 6e 54 69 6d 65 6f 75  eout(int nTimeou
0810: 74 4d 53 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  tMS).    {.     
0820: 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e   int n = UnsafeN
0830: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
0840: 69 74 65 33 5f 62 75 73 79 5f 74 69 6d 65 6f 75  ite3_busy_timeou
0850: 74 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20  t_interop(_sql, 
0860: 6e 54 69 6d 65 6f 75 74 4d 53 29 3b 0a 20 20 20  nTimeoutMS);.   
0870: 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68     if (n > 0) th
0880: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
0890: 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74  ception(n, SQLit
08a0: 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a 20  eLastError());. 
08b0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
08c0: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
08d0: 20 45 78 65 63 75 74 65 28 73 74 72 69 6e 67 20   Execute(string 
08e0: 73 74 72 53 71 6c 29 0a 20 20 20 20 7b 0a 20 20  strSql).    {.  
08f0: 20 20 20 20 49 6e 74 50 74 72 20 70 3b 0a 20 20      IntPtr p;.  
0900: 20 20 20 20 73 74 72 69 6e 67 20 73 74 72 20 3d      string str =
0910: 20 73 74 72 53 71 6c 3b 0a 20 20 20 20 20 20 69   strSql;.      i
0920: 6e 74 20 6c 65 6e 3b 0a 0a 20 20 20 20 20 20 69  nt len;..      i
0930: 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74  nt n = UnsafeNat
0940: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
0950: 65 33 5f 65 78 65 63 5f 69 6e 74 65 72 6f 70 28  e3_exec_interop(
0960: 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 73 74 72  _sql, ToUTF8(str
0970: 53 71 6c 29 2c 20 30 2c 20 30 2c 20 6f 75 74 20  Sql), 0, 0, out 
0980: 70 2c 20 6f 75 74 20 6c 65 6e 29 3b 0a 20 20 20  p, out len);.   
0990: 20 20 20 69 66 20 28 70 20 21 3d 20 49 6e 74 50     if (p != IntP
09a0: 74 72 2e 5a 65 72 6f 29 0a 20 20 20 20 20 20 7b  tr.Zero).      {
09b0: 0a 20 20 20 20 20 20 20 20 73 74 72 20 3d 20 54  .        str = T
09c0: 6f 53 74 72 69 6e 67 28 70 2c 20 6c 65 6e 29 3b  oString(p, len);
09d0: 0a 20 20 20 20 20 20 20 20 55 6e 73 61 66 65 4e  .        UnsafeN
09e0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
09f0: 69 74 65 33 5f 66 72 65 65 5f 69 6e 74 65 72 6f  ite3_free_intero
0a00: 70 28 70 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  p(p);.      }.  
0a10: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
0a20: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
0a30: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 73 74 72 29  xception(n, str)
0a40: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
0a50: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 62  ernal override b
0a60: 6f 6f 6c 20 53 74 65 70 28 53 51 4c 69 74 65 53  ool Step(SQLiteS
0a70: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 29 0a 20  tatement stmt). 
0a80: 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e     {.      int n
0a90: 3b 0a 0a 20 20 20 20 20 20 77 68 69 6c 65 20 28  ;..      while (
0aa0: 74 72 75 65 29 0a 20 20 20 20 20 20 7b 0a 20 20  true).      {.  
0ab0: 20 20 20 20 20 20 6e 20 3d 20 55 6e 73 61 66 65        n = Unsafe
0ac0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
0ad0: 6c 69 74 65 33 5f 73 74 65 70 5f 69 6e 74 65 72  lite3_step_inter
0ae0: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
0af0: 73 74 6d 74 29 3b 0a 0a 20 20 20 20 20 20 20 20  stmt);..        
0b00: 69 66 20 28 6e 20 3d 3d 20 31 30 30 29 20 72 65  if (n == 100) re
0b10: 74 75 72 6e 20 74 72 75 65 3b 0a 20 20 20 20 20  turn true;.     
0b20: 20 20 20 69 66 20 28 6e 20 3d 3d 20 31 30 31 29     if (n == 101)
0b30: 20 72 65 74 75 72 6e 20 66 61 6c 73 65 3b 0a 0a   return false;..
0b40: 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20          if (n > 
0b50: 30 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  0).        {.   
0b60: 20 20 20 20 20 20 20 2f 2f 20 41 6e 20 65 72 72         // An err
0b70: 6f 72 20 6f 63 63 75 72 72 65 64 2c 20 61 74 74  or occurred, att
0b80: 65 6d 70 74 20 74 6f 20 72 65 73 65 74 20 74 68  empt to reset th
0b90: 65 20 73 74 61 74 65 6d 65 6e 74 2e 20 20 49 66  e statement.  If
0ba0: 20 74 68 65 20 72 65 73 65 74 20 77 6f 72 6b 65   the reset worke
0bb0: 64 20 62 65 63 61 75 73 65 20 74 68 65 0a 20 20  d because the.  
0bc0: 20 20 20 20 20 20 20 20 2f 2f 20 73 63 68 65 6d          // schem
0bd0: 61 20 68 61 73 20 63 68 61 6e 67 65 64 2c 20 72  a has changed, r
0be0: 65 2d 74 72 79 20 74 68 65 20 73 74 65 70 20 61  e-try the step a
0bf0: 67 61 69 6e 2e 20 20 4f 74 68 65 72 77 69 73 65  gain.  Otherwise
0c00: 20 74 68 72 6f 77 20 74 68 65 20 6f 72 69 67 69   throw the origi
0c10: 6e 61 6c 20 65 72 72 6f 72 2e 0a 20 20 20 20 20  nal error..     
0c20: 20 20 20 20 20 73 74 72 69 6e 67 20 73 74 72 20       string str 
0c30: 3d 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f  = SQLiteLastErro
0c40: 72 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 0a  r();.          .
0c50: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 52 65            if (Re
0c60: 73 65 74 28 73 74 6d 74 29 20 3d 3d 20 66 61 6c  set(stmt) == fal
0c70: 73 65 29 0a 20 20 20 20 20 20 20 20 20 20 20 20  se).            
0c80: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
0c90: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 73 74 72  Exception(n, str
0ca0: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
0cb0: 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20     }.    }..    
0cc0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
0cd0: 65 20 76 6f 69 64 20 46 69 6e 61 6c 69 7a 65 28  e void Finalize(
0ce0: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
0cf0: 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20 20  stmt).    {.    
0d00: 20 20 69 66 20 28 73 74 6d 74 2e 5f 73 71 6c 69    if (stmt._sqli
0d10: 74 65 5f 73 74 6d 74 20 3e 20 30 29 0a 20 20 20  te_stmt > 0).   
0d20: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69 6e 74     {.        int
0d30: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
0d40: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
0d50: 5f 66 69 6e 61 6c 69 7a 65 5f 69 6e 74 65 72 6f  _finalize_intero
0d60: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
0d70: 74 6d 74 29 3b 0a 20 20 20 20 20 20 20 20 69 66  tmt);.        if
0d80: 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e   (n > 0) throw n
0d90: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
0da0: 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74  on(n, SQLiteLast
0db0: 45 72 72 6f 72 28 29 29 3b 0a 20 20 20 20 20 20  Error());.      
0dc0: 7d 0a 20 20 20 20 20 20 73 74 6d 74 2e 5f 73 71  }.      stmt._sq
0dd0: 6c 69 74 65 5f 73 74 6d 74 20 3d 20 30 3b 0a 20  lite_stmt = 0;. 
0de0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
0df0: 61 6c 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c  al override bool
0e00: 20 52 65 73 65 74 28 53 51 4c 69 74 65 53 74 61   Reset(SQLiteSta
0e10: 74 65 6d 65 6e 74 20 73 74 6d 74 29 0a 20 20 20  tement stmt).   
0e20: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d   {.      int n =
0e30: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
0e40: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73  hods.sqlite3_res
0e50: 65 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  et_interop(stmt.
0e60: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29 3b 0a 0a  _sqlite_stmt);..
0e70: 20 20 20 20 20 20 2f 2f 20 49 66 20 74 68 65 20        // If the 
0e80: 73 63 68 65 6d 61 20 63 68 61 6e 67 65 64 2c 20  schema changed, 
0e90: 74 72 79 20 61 6e 64 20 72 65 2d 70 72 65 70 61  try and re-prepa
0ea0: 72 65 20 69 74 0a 20 20 20 20 20 20 69 66 20 28  re it.      if (
0eb0: 6e 20 3d 3d 20 31 37 29 20 2f 2f 20 53 51 4c 49  n == 17) // SQLI
0ec0: 54 45 5f 53 43 48 45 4d 41 0a 20 20 20 20 20 20  TE_SCHEMA.      
0ed0: 7b 0a 20 20 20 20 20 20 20 20 2f 2f 20 52 65 63  {.        // Rec
0ee0: 72 65 61 74 65 20 61 20 64 75 6d 6d 79 20 73 74  reate a dummy st
0ef0: 61 74 65 6d 65 6e 74 0a 20 20 20 20 20 20 20 20  atement.        
0f00: 69 6e 74 20 6e 63 20 3d 20 30 3b 0a 20 20 20 20  int nc = 0;.    
0f10: 20 20 20 20 73 74 72 69 6e 67 20 73 74 72 3b 0a      string str;.
0f20: 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 53          using (S
0f30: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 74  QLiteStatement t
0f40: 6d 70 20 3d 20 50 72 65 70 61 72 65 28 73 74 6d  mp = Prepare(stm
0f50: 74 2e 5f 73 71 6c 53 74 61 74 65 6d 65 6e 74 2c  t._sqlStatement,
0f60: 20 72 65 66 20 6e 63 2c 20 6f 75 74 20 73 74 72   ref nc, out str
0f70: 29 29 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20  )).        {.   
0f80: 20 20 20 20 20 20 20 2f 2f 20 46 69 6e 61 6c 69         // Finali
0f90: 7a 65 20 74 68 65 20 65 78 69 73 74 69 6e 67 20  ze the existing 
0fa0: 73 74 61 74 65 6d 65 6e 74 0a 20 20 20 20 20 20  statement.      
0fb0: 20 20 20 20 46 69 6e 61 6c 69 7a 65 28 73 74 6d      Finalize(stm
0fc0: 74 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f  t);..          /
0fd0: 2f 20 52 65 61 73 73 69 67 6e 20 61 20 6e 65 77  / Reassign a new
0fe0: 20 73 74 61 74 65 6d 65 6e 74 20 70 6f 69 6e 74   statement point
0ff0: 65 72 20 74 6f 20 74 68 65 20 6f 6c 64 20 73 74  er to the old st
1000: 61 74 65 6d 65 6e 74 20 61 6e 64 20 63 6c 65 61  atement and clea
1010: 72 20 74 68 65 20 74 65 6d 70 6f 72 61 72 79 20  r the temporary 
1020: 6f 6e 65 0a 20 20 20 20 20 20 20 20 20 20 73 74  one.          st
1030: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 20  mt._sqlite_stmt 
1040: 3d 20 74 6d 70 2e 5f 73 71 6c 69 74 65 5f 73 74  = tmp._sqlite_st
1050: 6d 74 3b 0a 20 20 20 20 20 20 20 20 20 20 74 6d  mt;.          tm
1060: 70 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 20 3d  p._sqlite_stmt =
1070: 20 30 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f   0;..          /
1080: 2f 20 52 65 61 70 70 6c 79 20 70 61 72 61 6d 65  / Reapply parame
1090: 74 65 72 73 0a 20 20 20 20 20 20 20 20 20 20 73  ters.          s
10a0: 74 6d 74 2e 42 69 6e 64 50 61 72 61 6d 65 74 65  tmt.BindParamete
10b0: 72 73 28 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  rs();.        }.
10c0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 74          return t
10d0: 72 75 65 3b 20 2f 2f 20 52 65 73 65 74 20 77 61  rue; // Reset wa
10e0: 73 20 4f 4b 2c 20 77 69 74 68 20 73 63 68 65 6d  s OK, with schem
10f0: 61 20 63 68 61 6e 67 65 0a 20 20 20 20 20 20 7d  a change.      }
1100: 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20  ..      if (n > 
1110: 30 29 0a 20 20 20 20 20 20 20 20 74 68 72 6f 77  0).        throw
1120: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
1130: 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61  tion(n, SQLiteLa
1140: 73 74 45 72 72 6f 72 28 29 29 3b 0a 0a 20 20 20  stError());..   
1150: 20 20 20 72 65 74 75 72 6e 20 66 61 6c 73 65 3b     return false;
1160: 20 2f 2f 20 57 65 20 72 65 73 65 74 20 4f 4b 2c   // We reset OK,
1170: 20 6e 6f 20 73 63 68 65 6d 61 20 63 68 61 6e 67   no schema chang
1180: 65 73 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  es.    }..    in
1190: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
11a0: 73 74 72 69 6e 67 20 53 51 4c 69 74 65 4c 61 73  string SQLiteLas
11b0: 74 45 72 72 6f 72 28 29 0a 20 20 20 20 7b 0a 20  tError().    {. 
11c0: 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20       int len;.  
11d0: 20 20 20 20 72 65 74 75 72 6e 20 54 6f 53 74 72      return ToStr
11e0: 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65  ing(UnsafeNative
11f0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
1200: 65 72 72 6d 73 67 5f 69 6e 74 65 72 6f 70 28 5f  errmsg_interop(_
1210: 73 71 6c 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c  sql, out len), l
1220: 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  en);.    }..    
1230: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
1240: 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  e SQLiteStatemen
1250: 74 20 50 72 65 70 61 72 65 28 73 74 72 69 6e 67  t Prepare(string
1260: 20 73 74 72 53 71 6c 2c 20 72 65 66 20 69 6e 74   strSql, ref int
1270: 20 6e 50 61 72 61 6d 53 74 61 72 74 2c 20 6f 75   nParamStart, ou
1280: 74 20 73 74 72 69 6e 67 20 73 74 72 52 65 6d 61  t string strRema
1290: 69 6e 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  in).    {.      
12a0: 69 6e 74 20 73 74 6d 74 3b 0a 20 20 20 20 20 20  int stmt;.      
12b0: 49 6e 74 50 74 72 20 70 74 72 3b 0a 20 20 20 20  IntPtr ptr;.    
12c0: 20 20 69 6e 74 20 6c 65 6e 3b 0a 0a 20 20 20 20    int len;..    
12d0: 20 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55    byte[] b = ToU
12e0: 54 46 38 28 73 74 72 53 71 6c 29 3b 0a 0a 20 20  TF8(strSql);..  
12f0: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
1300: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
1310: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
1320: 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 62 2c  interop(_sql, b,
1330: 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20 6f   b.Length - 1, o
1340: 75 74 20 73 74 6d 74 2c 20 6f 75 74 20 70 74 72  ut stmt, out ptr
1350: 2c 20 6f 75 74 20 6c 65 6e 29 3b 0a 20 20 20 20  , out len);.    
1360: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
1370: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
1380: 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65  eption(n, SQLite
1390: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a 0a 20  LastError());.. 
13a0: 20 20 20 20 20 73 74 72 52 65 6d 61 69 6e 20 3d       strRemain =
13b0: 20 54 6f 53 74 72 69 6e 67 28 70 74 72 2c 20 6c   ToString(ptr, l
13c0: 65 6e 29 3b 0a 0a 20 20 20 20 20 20 53 51 4c 69  en);..      SQLi
13d0: 74 65 53 74 61 74 65 6d 65 6e 74 20 63 6d 64 20  teStatement cmd 
13e0: 3d 20 6e 65 77 20 53 51 4c 69 74 65 53 74 61 74  = new SQLiteStat
13f0: 65 6d 65 6e 74 28 74 68 69 73 2c 20 73 74 6d 74  ement(this, stmt
1400: 2c 20 73 74 72 53 71 6c 2e 53 75 62 73 74 72 69  , strSql.Substri
1410: 6e 67 28 30 2c 20 73 74 72 53 71 6c 2e 4c 65 6e  ng(0, strSql.Len
1420: 67 74 68 20 2d 20 73 74 72 52 65 6d 61 69 6e 2e  gth - strRemain.
1430: 4c 65 6e 67 74 68 29 2c 20 72 65 66 20 6e 50 61  Length), ref nPa
1440: 72 61 6d 53 74 61 72 74 29 3b 0a 0a 20 20 20 20  ramStart);..    
1450: 20 20 72 65 74 75 72 6e 20 63 6d 64 3b 0a 20 20    return cmd;.  
1460: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
1470: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
1480: 42 69 6e 64 5f 44 6f 75 62 6c 65 28 53 51 4c 69  Bind_Double(SQLi
1490: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
14a0: 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 64 6f 75  , int index, dou
14b0: 62 6c 65 20 76 61 6c 75 65 29 0a 20 20 20 20 7b  ble value).    {
14c0: 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55  .      int n = U
14d0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
14e0: 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  ds.sqlite3_bind_
14f0: 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 73  double_interop(s
1500: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
1510: 2c 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c  , index, ref val
1520: 75 65 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e  ue);.      if (n
1530: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
1540: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
1550: 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72  n, SQLiteLastErr
1560: 6f 72 28 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  or());.    }..  
1570: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
1580: 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 49 6e  ide void Bind_In
1590: 74 33 32 28 53 51 4c 69 74 65 53 74 61 74 65 6d  t32(SQLiteStatem
15a0: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
15b0: 64 65 78 2c 20 69 6e 74 20 76 61 6c 75 65 29 0a  dex, int value).
15c0: 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20      {.      int 
15d0: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
15e0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
15f0: 62 69 6e 64 5f 69 6e 74 5f 69 6e 74 65 72 6f 70  bind_int_interop
1600: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
1610: 6d 74 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65  mt, index, value
1620: 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e  );.      if (n >
1630: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
1640: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
1650: 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72   SQLiteLastError
1660: 28 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ());.    }..    
1670: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
1680: 65 20 76 6f 69 64 20 42 69 6e 64 5f 49 6e 74 36  e void Bind_Int6
1690: 34 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  4(SQLiteStatemen
16a0: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
16b0: 78 2c 20 6c 6f 6e 67 20 76 61 6c 75 65 29 0a 20  x, long value). 
16c0: 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e     {.      int n
16d0: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
16e0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
16f0: 69 6e 64 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f  ind_int64_intero
1700: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
1710: 74 6d 74 2c 20 69 6e 64 65 78 2c 20 72 65 66 20  tmt, index, ref 
1720: 76 61 6c 75 65 29 3b 0a 20 20 20 20 20 20 69 66  value);.      if
1730: 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e   (n > 0) throw n
1740: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
1750: 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74  on(n, SQLiteLast
1760: 45 72 72 6f 72 28 29 29 3b 0a 20 20 20 20 7d 0a  Error());.    }.
1770: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
1780: 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64  erride void Bind
1790: 5f 54 65 78 74 28 53 51 4c 69 74 65 53 74 61 74  _Text(SQLiteStat
17a0: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
17b0: 69 6e 64 65 78 2c 20 73 74 72 69 6e 67 20 76 61  index, string va
17c0: 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  lue).    {.     
17d0: 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54   byte[] b = ToUT
17e0: 46 38 28 76 61 6c 75 65 29 3b 0a 20 20 20 20 20  F8(value);.     
17f0: 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e   int n = UnsafeN
1800: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
1810: 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 5f 69  ite3_bind_text_i
1820: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
1830: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
1840: 20 62 2c 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31   b, b.Length - 1
1850: 2c 20 2d 31 29 3b 0a 20 20 20 20 20 20 69 66 20  , -1);.      if 
1860: 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65  (n > 0) throw ne
1870: 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  w SQLiteExceptio
1880: 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45  n(n, SQLiteLastE
1890: 72 72 6f 72 28 29 29 3b 0a 20 20 20 20 7d 0a 0a  rror());.    }..
18a0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
18b0: 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f  rride void Bind_
18c0: 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74 65 53  DateTime(SQLiteS
18d0: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
18e0: 6e 74 20 69 6e 64 65 78 2c 20 44 61 74 65 54 69  nt index, DateTi
18f0: 6d 65 20 64 74 29 0a 20 20 20 20 7b 0a 20 20 20  me dt).    {.   
1900: 20 20 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f     byte[] b = To
1910: 55 54 46 38 28 64 74 29 3b 0a 20 20 20 20 20 20  UTF8(dt);.      
1920: 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61  int n = UnsafeNa
1930: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
1940: 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 5f 69 6e  te3_bind_text_in
1950: 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69  terop(stmt._sqli
1960: 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20  te_stmt, index, 
1970: 62 2c 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c  b, b.Length - 1,
1980: 20 2d 31 29 3b 0a 20 20 20 20 20 20 69 66 20 28   -1);.      if (
1990: 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77  n > 0) throw new
19a0: 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e   SQLiteException
19b0: 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72  (n, SQLiteLastEr
19c0: 72 6f 72 28 29 29 3b 0a 20 20 20 20 7d 0a 0a 20  ror());.    }.. 
19d0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
19e0: 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 42  ride void Bind_B
19f0: 6c 6f 62 28 53 51 4c 69 74 65 53 74 61 74 65 6d  lob(SQLiteStatem
1a00: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
1a10: 64 65 78 2c 20 62 79 74 65 5b 5d 20 62 6c 6f 62  dex, byte[] blob
1a20: 44 61 74 61 29 0a 20 20 20 20 7b 0a 20 20 20 20  Data).    {.    
1a30: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
1a40: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
1a50: 6c 69 74 65 33 5f 62 69 6e 64 5f 62 6c 6f 62 5f  lite3_bind_blob_
1a60: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
1a70: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
1a80: 2c 20 62 6c 6f 62 44 61 74 61 2c 20 62 6c 6f 62  , blobData, blob
1a90: 44 61 74 61 2e 4c 65 6e 67 74 68 2c 20 2d 31 29  Data.Length, -1)
1aa0: 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20  ;.      if (n > 
1ab0: 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c  0) throw new SQL
1ac0: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
1ad0: 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72 28  SQLiteLastError(
1ae0: 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  ));.    }..    i
1af0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1b00: 20 76 6f 69 64 20 42 69 6e 64 5f 4e 75 6c 6c 28   void Bind_Null(
1b10: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
1b20: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29  stmt, int index)
1b30: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74  .    {.      int
1b40: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
1b50: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
1b60: 5f 62 69 6e 64 5f 6e 75 6c 6c 5f 69 6e 74 65 72  _bind_null_inter
1b70: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
1b80: 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0a 20 20  stmt, index);.  
1b90: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
1ba0: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
1bb0: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69  xception(n, SQLi
1bc0: 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a  teLastError());.
1bd0: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
1be0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
1bf0: 20 42 69 6e 64 5f 50 61 72 61 6d 43 6f 75 6e 74   Bind_ParamCount
1c00: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
1c10: 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20   stmt).    {.   
1c20: 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65     return Unsafe
1c30: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
1c40: 6c 69 74 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d  lite3_bind_param
1c50: 65 74 65 72 5f 63 6f 75 6e 74 5f 69 6e 74 65 72  eter_count_inter
1c60: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
1c70: 73 74 6d 74 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  stmt);.    }..  
1c80: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
1c90: 69 64 65 20 73 74 72 69 6e 67 20 42 69 6e 64 5f  ide string Bind_
1ca0: 50 61 72 61 6d 4e 61 6d 65 28 53 51 4c 69 74 65  ParamName(SQLite
1cb0: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
1cc0: 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20 7b  int index).    {
1cd0: 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a  .      int len;.
1ce0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 53        return ToS
1cf0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
1d00: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1d10: 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72  3_bind_parameter
1d20: 5f 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74  _name_interop(st
1d30: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
1d40: 20 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29   index, out len)
1d50: 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20  , len);.    }.. 
1d60: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
1d70: 72 69 64 65 20 69 6e 74 20 42 69 6e 64 5f 50 61  ride int Bind_Pa
1d80: 72 61 6d 49 6e 64 65 78 28 53 51 4c 69 74 65 53  ramIndex(SQLiteS
1d90: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 73  tatement stmt, s
1da0: 74 72 69 6e 67 20 70 61 72 61 6d 4e 61 6d 65 29  tring paramName)
1db0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74  .    {.      ret
1dc0: 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65  urn UnsafeNative
1dd0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
1de0: 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f 69  bind_parameter_i
1df0: 6e 64 65 78 5f 69 6e 74 65 72 6f 70 28 73 74 6d  ndex_interop(stm
1e00: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
1e10: 54 6f 55 54 46 38 28 70 61 72 61 6d 4e 61 6d 65  ToUTF8(paramName
1e20: 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  ));.    }..    i
1e30: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1e40: 20 69 6e 74 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74   int ColumnCount
1e50: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
1e60: 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20   stmt).    {.   
1e70: 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65     return Unsafe
1e80: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
1e90: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 63 6f 75  lite3_column_cou
1ea0: 6e 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  nt_interop(stmt.
1eb0: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29 3b 0a 20  _sqlite_stmt);. 
1ec0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
1ed0: 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72 69  al override stri
1ee0: 6e 67 20 43 6f 6c 75 6d 6e 4e 61 6d 65 28 53 51  ng ColumnName(SQ
1ef0: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
1f00: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20  mt, int index). 
1f10: 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6c     {.      int l
1f20: 65 6e 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  en;.      return
1f30: 20 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65   ToString(Unsafe
1f40: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
1f50: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d  lite3_column_nam
1f60: 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  e_interop(stmt._
1f70: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
1f80: 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65  ex, out len), le
1f90: 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  n);.    }..    i
1fa0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1fb0: 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 54 79   string ColumnTy
1fc0: 70 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  pe(SQLiteStateme
1fd0: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
1fe0: 65 78 2c 20 6f 75 74 20 54 79 70 65 41 66 66 69  ex, out TypeAffi
1ff0: 6e 69 74 79 20 6e 41 66 66 69 6e 69 74 79 29 0a  nity nAffinity).
2000: 20 20 20 20 7b 0a 20 20 20 20 20 20 6e 41 66 66      {.      nAff
2010: 69 6e 69 74 79 20 3d 20 54 79 70 65 41 66 66 69  inity = TypeAffi
2020: 6e 69 74 79 2e 4e 6f 6e 65 3b 0a 0a 20 20 20 20  nity.None;..    
2030: 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20    int len;.     
2040: 20 49 6e 74 50 74 72 20 70 20 3d 20 55 6e 73 61   IntPtr p = Unsa
2050: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
2060: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64  sqlite3_column_d
2070: 65 63 6c 74 79 70 65 5f 69 6e 74 65 72 6f 70 28  ecltype_interop(
2080: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
2090: 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65  t, index, out le
20a0: 6e 29 3b 0a 20 20 20 20 20 20 69 66 20 28 70 20  n);.      if (p 
20b0: 21 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f 29 20  != IntPtr.Zero) 
20c0: 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e 67 28  return ToString(
20d0: 70 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 20 20 65  p, len);.      e
20e0: 6c 73 65 0a 20 20 20 20 20 20 7b 0a 20 20 20 20  lse.      {.    
20f0: 20 20 20 20 6e 41 66 66 69 6e 69 74 79 20 3d 20      nAffinity = 
2100: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
2110: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ods.sqlite3_colu
2120: 6d 6e 5f 74 79 70 65 5f 69 6e 74 65 72 6f 70 28  mn_type_interop(
2130: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
2140: 74 2c 20 69 6e 64 65 78 29 3b 0a 20 20 20 20 20  t, index);.     
2150: 20 20 20 73 77 69 74 63 68 20 28 6e 41 66 66 69     switch (nAffi
2160: 6e 69 74 79 29 0a 20 20 20 20 20 20 20 20 7b 0a  nity).        {.
2170: 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20 54            case T
2180: 79 70 65 41 66 66 69 6e 69 74 79 2e 49 6e 74 36  ypeAffinity.Int6
2190: 34 3a 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  4:.            r
21a0: 65 74 75 72 6e 20 22 42 49 47 49 4e 54 22 3b 0a  eturn "BIGINT";.
21b0: 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20 54            case T
21c0: 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f 75 62  ypeAffinity.Doub
21d0: 6c 65 3a 0a 20 20 20 20 20 20 20 20 20 20 20 20  le:.            
21e0: 72 65 74 75 72 6e 20 22 44 4f 55 42 4c 45 22 3b  return "DOUBLE";
21f0: 0a 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20  .          case 
2200: 54 79 70 65 41 66 66 69 6e 69 74 79 2e 42 6c 6f  TypeAffinity.Blo
2210: 62 3a 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  b:.            r
2220: 65 74 75 72 6e 20 22 42 4c 4f 42 22 3b 0a 20 20  eturn "BLOB";.  
2230: 20 20 20 20 20 20 20 20 64 65 66 61 75 6c 74 3a          default:
2240: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74  .            ret
2250: 75 72 6e 20 22 54 45 58 54 22 3b 0a 20 20 20 20  urn "TEXT";.    
2260: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20      }.      }.  
2270: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
2280: 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 43  l override int C
2290: 6f 6c 75 6d 6e 49 6e 64 65 78 28 53 51 4c 69 74  olumnIndex(SQLit
22a0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
22b0: 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e 4e 61   string columnNa
22c0: 6d 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  me).    {.      
22d0: 66 6f 72 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20  for (int n = 0; 
22e0: 6e 20 3c 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74 28  n < ColumnCount(
22f0: 73 74 6d 74 29 3b 20 6e 2b 2b 29 0a 20 20 20 20  stmt); n++).    
2300: 20 20 7b 0a 20 20 20 20 20 20 20 20 69 66 20 28    {.        if (
2310: 53 74 72 69 6e 67 2e 43 6f 6d 70 61 72 65 28 63  String.Compare(c
2320: 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 43 6f 6c 75 6d  olumnName, Colum
2330: 6e 4e 61 6d 65 28 73 74 6d 74 2c 20 6e 29 2c 20  nName(stmt, n), 
2340: 74 72 75 65 29 20 3d 3d 20 30 29 20 72 65 74 75  true) == 0) retu
2350: 72 6e 20 6e 3b 0a 20 20 20 20 20 20 7d 0a 20 20  rn n;.      }.  
2360: 20 20 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20      return -1;. 
2370: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
2380: 61 6c 20 6f 76 65 72 72 69 64 65 20 64 6f 75 62  al override doub
2390: 6c 65 20 47 65 74 44 6f 75 62 6c 65 28 53 51 4c  le GetDouble(SQL
23a0: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
23b0: 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20  t, int index).  
23c0: 20 20 7b 0a 20 20 20 20 20 20 64 6f 75 62 6c 65    {.      double
23d0: 20 76 61 6c 75 65 3b 0a 20 20 20 20 20 20 55 6e   value;.      Un
23e0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
23f0: 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  s.sqlite3_column
2400: 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28  _double_interop(
2410: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
2420: 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20 76 61  t, index, out va
2430: 6c 75 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75  lue);.      retu
2440: 72 6e 20 76 61 6c 75 65 3b 0a 20 20 20 20 7d 0a  rn value;.    }.
2450: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
2460: 65 72 72 69 64 65 20 69 6e 74 20 47 65 74 49 6e  erride int GetIn
2470: 74 33 32 28 53 51 4c 69 74 65 53 74 61 74 65 6d  t32(SQLiteStatem
2480: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
2490: 64 65 78 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  dex).    {.     
24a0: 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61   return UnsafeNa
24b0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
24c0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 5f 69  te3_column_int_i
24d0: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
24e0: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29  ite_stmt, index)
24f0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
2500: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c  ernal override l
2510: 6f 6e 67 20 47 65 74 49 6e 74 36 34 28 53 51 4c  ong GetInt64(SQL
2520: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
2530: 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20  t, int index).  
2540: 20 20 7b 0a 20 20 20 20 20 20 6c 6f 6e 67 20 76    {.      long v
2550: 61 6c 75 65 3b 0a 20 20 20 20 20 20 55 6e 73 61  alue;.      Unsa
2560: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
2570: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69  sqlite3_column_i
2580: 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 73 74 6d  nt64_interop(stm
2590: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
25a0: 69 6e 64 65 78 2c 20 6f 75 74 20 76 61 6c 75 65  index, out value
25b0: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  );.      return 
25c0: 76 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20 20  value;.    }..  
25d0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
25e0: 69 64 65 20 73 74 72 69 6e 67 20 47 65 74 54 65  ide string GetTe
25f0: 78 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  xt(SQLiteStateme
2600: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
2610: 65 78 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  ex).    {.      
2620: 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20 72  int len;.      r
2630: 65 74 75 72 6e 20 54 6f 53 74 72 69 6e 67 28 55  eturn ToString(U
2640: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
2650: 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  ds.sqlite3_colum
2660: 6e 5f 74 65 78 74 5f 69 6e 74 65 72 6f 70 28 73  n_text_interop(s
2670: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
2680: 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e  , index, out len
2690: 29 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a  ), len);.    }..
26a0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
26b0: 72 72 69 64 65 20 44 61 74 65 54 69 6d 65 20 47  rride DateTime G
26c0: 65 74 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74  etDateTime(SQLit
26d0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
26e0: 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20   int index).    
26f0: 7b 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b  {.      int len;
2700: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f  .      return To
2710: 44 61 74 65 54 69 6d 65 28 55 6e 73 61 66 65 4e  DateTime(UnsafeN
2720: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
2730: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74  ite3_column_text
2740: 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73  _interop(stmt._s
2750: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
2760: 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e  x, out len), len
2770: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
2780: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
2790: 6c 6f 6e 67 20 47 65 74 42 79 74 65 73 28 53 51  long GetBytes(SQ
27a0: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
27b0: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69  mt, int index, i
27c0: 6e 74 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20  nt nDataOffset, 
27d0: 62 79 74 65 5b 5d 20 62 44 65 73 74 2c 20 69 6e  byte[] bDest, in
27e0: 74 20 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c  t nStart, int nL
27f0: 65 6e 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20  ength).    {.   
2800: 20 20 20 49 6e 74 50 74 72 20 70 74 72 3b 0a 20     IntPtr ptr;. 
2810: 20 20 20 20 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20       int nlen;. 
2820: 20 20 20 20 20 69 6e 74 20 6e 43 6f 70 69 65 64       int nCopied
2830: 20 3d 20 6e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20   = nLength;..   
2840: 20 20 20 6e 6c 65 6e 20 3d 20 55 6e 73 61 66 65     nlen = Unsafe
2850: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
2860: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74  lite3_column_byt
2870: 65 73 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  es_interop(stmt.
2880: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e  _sqlite_stmt, in
2890: 64 65 78 29 3b 0a 20 20 20 20 20 20 70 74 72 20  dex);.      ptr 
28a0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
28b0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
28c0: 6c 75 6d 6e 5f 62 6c 6f 62 5f 69 6e 74 65 72 6f  lumn_blob_intero
28d0: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
28e0: 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0a 0a 20 20  tmt, index);..  
28f0: 20 20 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d      if (bDest ==
2900: 20 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c   null) return nl
2910: 65 6e 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e  en;..      if (n
2920: 43 6f 70 69 65 64 20 2b 20 6e 53 74 61 72 74 20  Copied + nStart 
2930: 3e 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 29 20  > bDest.Length) 
2940: 6e 43 6f 70 69 65 64 20 3d 20 62 44 65 73 74 2e  nCopied = bDest.
2950: 4c 65 6e 67 74 68 20 2d 20 6e 53 74 61 72 74 3b  Length - nStart;
2960: 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69  .      if (nCopi
2970: 65 64 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74  ed + nDataOffset
2980: 20 3e 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64   > nlen) nCopied
2990: 20 3d 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f   = nlen - nDataO
29a0: 66 66 73 65 74 3b 0a 0a 20 20 20 20 20 20 69 66  ffset;..      if
29b0: 20 28 6e 43 6f 70 69 65 64 20 3e 20 30 29 0a 20   (nCopied > 0). 
29c0: 20 20 20 20 20 20 20 4d 61 72 73 68 61 6c 2e 43         Marshal.C
29d0: 6f 70 79 28 28 49 6e 74 50 74 72 29 28 70 74 72  opy((IntPtr)(ptr
29e0: 2e 54 6f 49 6e 74 33 32 28 29 20 2b 20 6e 44 61  .ToInt32() + nDa
29f0: 74 61 4f 66 66 73 65 74 29 2c 20 62 44 65 73 74  taOffset), bDest
2a00: 2c 20 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69 65  , nStart, nCopie
2a10: 64 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 6e  d);.      else n
2a20: 43 6f 70 69 65 64 20 3d 20 30 3b 0a 0a 20 20 20  Copied = 0;..   
2a30: 20 20 20 72 65 74 75 72 6e 20 6e 43 6f 70 69 65     return nCopie
2a40: 64 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  d;.    }..    in
2a50: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
2a60: 6c 6f 6e 67 20 47 65 74 43 68 61 72 73 28 53 51  long GetChars(SQ
2a70: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
2a80: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69  mt, int index, i
2a90: 6e 74 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20  nt nDataOffset, 
2aa0: 63 68 61 72 5b 5d 20 62 44 65 73 74 2c 20 69 6e  char[] bDest, in
2ab0: 74 20 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c  t nStart, int nL
2ac0: 65 6e 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20  ength).    {.   
2ad0: 20 20 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20 20 20     int nlen;.   
2ae0: 20 20 20 69 6e 74 20 6e 43 6f 70 69 65 64 20 3d     int nCopied =
2af0: 20 6e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20   nLength;..     
2b00: 20 73 74 72 69 6e 67 20 73 74 72 20 3d 20 47 65   string str = Ge
2b10: 74 54 65 78 74 28 73 74 6d 74 2c 20 69 6e 64 65  tText(stmt, inde
2b20: 78 29 3b 0a 20 20 20 20 20 20 6e 6c 65 6e 20 3d  x);.      nlen =
2b30: 20 73 74 72 2e 4c 65 6e 67 74 68 3b 0a 0a 20 20   str.Length;..  
2b40: 20 20 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d      if (bDest ==
2b50: 20 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c   null) return nl
2b60: 65 6e 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e  en;..      if (n
2b70: 43 6f 70 69 65 64 20 2b 20 6e 53 74 61 72 74 20  Copied + nStart 
2b80: 3e 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 29 20  > bDest.Length) 
2b90: 6e 43 6f 70 69 65 64 20 3d 20 62 44 65 73 74 2e  nCopied = bDest.
2ba0: 4c 65 6e 67 74 68 20 2d 20 6e 53 74 61 72 74 3b  Length - nStart;
2bb0: 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69  .      if (nCopi
2bc0: 65 64 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74  ed + nDataOffset
2bd0: 20 3e 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64   > nlen) nCopied
2be0: 20 3d 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f   = nlen - nDataO
2bf0: 66 66 73 65 74 3b 0a 0a 20 20 20 20 20 20 69 66  ffset;..      if
2c00: 20 28 6e 43 6f 70 69 65 64 20 3e 20 30 29 0a 20   (nCopied > 0). 
2c10: 20 20 20 20 20 20 20 73 74 72 2e 43 6f 70 79 54         str.CopyT
2c20: 6f 28 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 62  o(nDataOffset, b
2c30: 44 65 73 74 2c 20 6e 53 74 61 72 74 2c 20 6e 43  Dest, nStart, nC
2c40: 6f 70 69 65 64 29 3b 0a 20 20 20 20 20 20 65 6c  opied);.      el
2c50: 73 65 20 6e 43 6f 70 69 65 64 20 3d 20 30 3b 0a  se nCopied = 0;.
2c60: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43  .      return nC
2c70: 6f 70 69 65 64 3b 0a 20 20 20 20 7d 0a 0a 20 20  opied;.    }..  
2c80: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2c90: 69 64 65 20 62 6f 6f 6c 20 49 73 4e 75 6c 6c 28  ide bool IsNull(
2ca0: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
2cb0: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29  stmt, int index)
2cc0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74  .    {.      ret
2cd0: 75 72 6e 20 28 55 6e 73 61 66 65 4e 61 74 69 76  urn (UnsafeNativ
2ce0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
2cf0: 5f 63 6f 6c 75 6d 6e 5f 74 79 70 65 5f 69 6e 74  _column_type_int
2d00: 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74  erop(stmt._sqlit
2d10: 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 20 3d  e_stmt, index) =
2d20: 3d 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 4e  = TypeAffinity.N
2d30: 75 6c 6c 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  ull);.    }..   
2d40: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
2d50: 64 65 20 69 6e 74 20 41 67 67 72 65 67 61 74 65  de int Aggregate
2d60: 43 6f 75 6e 74 28 69 6e 74 20 63 6f 6e 74 65 78  Count(int contex
2d70: 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  t).    {.      r
2d80: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
2d90: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
2da0: 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 75 6e  3_aggregate_coun
2db0: 74 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78  t_interop(contex
2dc0: 74 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  t);.    }..    i
2dd0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
2de0: 20 69 6e 74 20 43 72 65 61 74 65 46 75 6e 63 74   int CreateFunct
2df0: 69 6f 6e 28 73 74 72 69 6e 67 20 73 74 72 46 75  ion(string strFu
2e00: 6e 63 74 69 6f 6e 2c 20 69 6e 74 20 6e 41 72 67  nction, int nArg
2e10: 73 2c 20 53 51 4c 69 74 65 43 61 6c 6c 62 61 63  s, SQLiteCallbac
2e20: 6b 20 66 75 6e 63 2c 20 53 51 4c 69 74 65 43 61  k func, SQLiteCa
2e30: 6c 6c 62 61 63 6b 20 66 75 6e 63 73 74 65 70 2c  llback funcstep,
2e40: 20 53 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b 20   SQLiteCallback 
2e50: 66 75 6e 63 66 69 6e 61 6c 29 0a 20 20 20 20 7b  funcfinal).    {
2e60: 0a 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 6f 6b  .      int nCook
2e70: 69 65 3b 0a 0a 20 20 20 20 20 20 69 6e 74 20 6e  ie;..      int n
2e80: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
2e90: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
2ea0: 72 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 5f 69  reate_function_i
2eb0: 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55  nterop(_sql, ToU
2ec0: 54 46 38 28 73 74 72 46 75 6e 63 74 69 6f 6e 29  TF8(strFunction)
2ed0: 2c 20 6e 41 72 67 73 2c 20 31 2c 20 66 75 6e 63  , nArgs, 1, func
2ee0: 2c 20 66 75 6e 63 73 74 65 70 2c 20 66 75 6e 63  , funcstep, func
2ef0: 66 69 6e 61 6c 2c 20 6f 75 74 20 6e 43 6f 6f 6b  final, out nCook
2f00: 69 65 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e  ie);.      if (n
2f10: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
2f20: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
2f30: 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72  n, SQLiteLastErr
2f40: 6f 72 28 29 29 3b 0a 0a 20 20 20 20 20 20 72 65  or());..      re
2f50: 74 75 72 6e 20 6e 43 6f 6f 6b 69 65 3b 0a 20 20  turn nCookie;.  
2f60: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
2f70: 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 43  l override int C
2f80: 72 65 61 74 65 43 6f 6c 6c 61 74 69 6f 6e 28 73  reateCollation(s
2f90: 74 72 69 6e 67 20 73 74 72 43 6f 6c 6c 61 74 69  tring strCollati
2fa0: 6f 6e 2c 20 53 51 4c 69 74 65 43 6f 6c 6c 61 74  on, SQLiteCollat
2fb0: 69 6f 6e 20 66 75 6e 63 29 0a 20 20 20 20 7b 0a  ion func).    {.
2fc0: 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 6f 6b 69        int nCooki
2fd0: 65 3b 0a 0a 20 20 20 20 20 20 69 6e 74 20 6e 20  e;..      int n 
2fe0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
2ff0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 72  thods.sqlite3_cr
3000: 65 61 74 65 5f 63 6f 6c 6c 61 74 69 6f 6e 5f 69  eate_collation_i
3010: 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55  nterop(_sql, ToU
3020: 54 46 38 28 73 74 72 43 6f 6c 6c 61 74 69 6f 6e  TF8(strCollation
3030: 29 2c 20 31 2c 20 30 2c 20 66 75 6e 63 2c 20 6f  ), 1, 0, func, o
3040: 75 74 20 6e 43 6f 6f 6b 69 65 29 3b 0a 20 20 20  ut nCookie);.   
3050: 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68     if (n > 0) th
3060: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
3070: 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74  ception(n, SQLit
3080: 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a 0a  eLastError());..
3090: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f        return nCo
30a0: 6f 6b 69 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  okie;.    }..   
30b0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
30c0: 64 65 20 76 6f 69 64 20 46 72 65 65 46 75 6e 63  de void FreeFunc
30d0: 74 69 6f 6e 28 69 6e 74 20 6e 43 6f 6f 6b 69 65  tion(int nCookie
30e0: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e  ).    {.      Un
30f0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
3100: 73 2e 73 71 6c 69 74 65 33 5f 66 75 6e 63 74 69  s.sqlite3_functi
3110: 6f 6e 5f 66 72 65 65 5f 63 61 6c 6c 62 61 63 6b  on_free_callback
3120: 63 6f 6f 6b 69 65 28 6e 43 6f 6f 6b 69 65 29 3b  cookie(nCookie);
3130: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
3140: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f  rnal override lo
3150: 6e 67 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65  ng GetParamValue
3160: 42 79 74 65 73 28 69 6e 74 20 70 2c 20 69 6e 74  Bytes(int p, int
3170: 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 62 79   nDataOffset, by
3180: 74 65 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20  te[] bDest, int 
3190: 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e  nStart, int nLen
31a0: 67 74 68 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  gth).    {.     
31b0: 20 49 6e 74 50 74 72 20 70 74 72 3b 0a 20 20 20   IntPtr ptr;.   
31c0: 20 20 20 69 6e 74 20 6e 6c 65 6e 3b 0a 20 20 20     int nlen;.   
31d0: 20 20 20 69 6e 74 20 6e 43 6f 70 69 65 64 20 3d     int nCopied =
31e0: 20 6e 4c 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20   nLength;..     
31f0: 20 6e 6c 65 6e 20 3d 20 55 6e 73 61 66 65 4e 61   nlen = UnsafeNa
3200: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
3210: 74 65 33 5f 76 61 6c 75 65 5f 62 79 74 65 73 5f  te3_value_bytes_
3220: 69 6e 74 65 72 6f 70 28 70 29 3b 0a 20 20 20 20  interop(p);.    
3230: 20 20 70 74 72 20 3d 20 55 6e 73 61 66 65 4e 61    ptr = UnsafeNa
3240: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
3250: 74 65 33 5f 76 61 6c 75 65 5f 62 6c 6f 62 5f 69  te3_value_blob_i
3260: 6e 74 65 72 6f 70 28 70 29 3b 0a 0a 20 20 20 20  nterop(p);..    
3270: 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d 20 6e    if (bDest == n
3280: 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65 6e  ull) return nlen
3290: 3b 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f  ;..      if (nCo
32a0: 70 69 65 64 20 2b 20 6e 53 74 61 72 74 20 3e 20  pied + nStart > 
32b0: 62 44 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43  bDest.Length) nC
32c0: 6f 70 69 65 64 20 3d 20 62 44 65 73 74 2e 4c 65  opied = bDest.Le
32d0: 6e 67 74 68 20 2d 20 6e 53 74 61 72 74 3b 0a 20  ngth - nStart;. 
32e0: 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64       if (nCopied
32f0: 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e   + nDataOffset >
3300: 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d   nlen) nCopied =
3310: 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66   nlen - nDataOff
3320: 73 65 74 3b 0a 0a 20 20 20 20 20 20 69 66 20 28  set;..      if (
3330: 6e 43 6f 70 69 65 64 20 3e 20 30 29 0a 20 20 20  nCopied > 0).   
3340: 20 20 20 20 20 4d 61 72 73 68 61 6c 2e 43 6f 70       Marshal.Cop
3350: 79 28 28 49 6e 74 50 74 72 29 28 70 74 72 2e 54  y((IntPtr)(ptr.T
3360: 6f 49 6e 74 33 32 28 29 20 2b 20 6e 44 61 74 61  oInt32() + nData
3370: 4f 66 66 73 65 74 29 2c 20 62 44 65 73 74 2c 20  Offset), bDest, 
3380: 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69 65 64 29  nStart, nCopied)
3390: 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 6e 43 6f  ;.      else nCo
33a0: 70 69 65 64 20 3d 20 30 3b 0a 0a 20 20 20 20 20  pied = 0;..     
33b0: 20 72 65 74 75 72 6e 20 6e 43 6f 70 69 65 64 3b   return nCopied;
33c0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
33d0: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 64 6f  rnal override do
33e0: 75 62 6c 65 20 47 65 74 50 61 72 61 6d 56 61 6c  uble GetParamVal
33f0: 75 65 44 6f 75 62 6c 65 28 69 6e 74 20 70 74 72  ueDouble(int ptr
3400: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 64 6f  ).    {.      do
3410: 75 62 6c 65 20 76 61 6c 75 65 3b 0a 20 20 20 20  uble value;.    
3420: 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65    UnsafeNativeMe
3430: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
3440: 6c 75 65 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72  lue_double_inter
3450: 6f 70 28 70 74 72 2c 20 6f 75 74 20 76 61 6c 75  op(ptr, out valu
3460: 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  e);.      return
3470: 20 76 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20   value;.    }.. 
3480: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
3490: 72 69 64 65 20 69 6e 74 20 47 65 74 50 61 72 61  ride int GetPara
34a0: 6d 56 61 6c 75 65 49 6e 74 33 32 28 69 6e 74 20  mValueInt32(int 
34b0: 70 74 72 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  ptr).    {.     
34c0: 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61   return UnsafeNa
34d0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
34e0: 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 5f 69 6e  te3_value_int_in
34f0: 74 65 72 6f 70 28 70 74 72 29 3b 0a 20 20 20 20  terop(ptr);.    
3500: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
3510: 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47 65  override long Ge
3520: 74 50 61 72 61 6d 56 61 6c 75 65 49 6e 74 36 34  tParamValueInt64
3530: 28 69 6e 74 20 70 74 72 29 0a 20 20 20 20 7b 0a  (int ptr).    {.
3540: 20 20 20 20 20 20 49 6e 74 36 34 20 76 61 6c 75        Int64 valu
3550: 65 3b 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e  e;.      UnsafeN
3560: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
3570: 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34  ite3_value_int64
3580: 5f 69 6e 74 65 72 6f 70 28 70 74 72 2c 20 6f 75  _interop(ptr, ou
3590: 74 20 76 61 6c 75 65 29 3b 0a 20 20 20 20 20 20  t value);.      
35a0: 72 65 74 75 72 6e 20 76 61 6c 75 65 3b 0a 20 20  return value;.  
35b0: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
35c0: 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e  l override strin
35d0: 67 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 54  g GetParamValueT
35e0: 65 78 74 28 69 6e 74 20 70 74 72 29 0a 20 20 20  ext(int ptr).   
35f0: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e   {.      int len
3600: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 54  ;.      return T
3610: 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61  oString(UnsafeNa
3620: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
3630: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 5f 69  te3_value_text_i
3640: 6e 74 65 72 6f 70 28 70 74 72 2c 20 6f 75 74 20  nterop(ptr, out 
3650: 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0a 20 20 20 20  len), len);.    
3660: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
3670: 6f 76 65 72 72 69 64 65 20 54 79 70 65 41 66 66  override TypeAff
3680: 69 6e 69 74 79 20 47 65 74 50 61 72 61 6d 56 61  inity GetParamVa
3690: 6c 75 65 54 79 70 65 28 69 6e 74 20 70 74 72 29  lueType(int ptr)
36a0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74  .    {.      ret
36b0: 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65  urn UnsafeNative
36c0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
36d0: 76 61 6c 75 65 5f 74 79 70 65 5f 69 6e 74 65 72  value_type_inter
36e0: 6f 70 28 70 74 72 29 3b 0a 20 20 20 20 7d 0a 0a  op(ptr);.    }..
36f0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
3700: 72 72 69 64 65 20 76 6f 69 64 20 52 65 74 75 72  rride void Retur
3710: 6e 42 6c 6f 62 28 69 6e 74 20 63 6f 6e 74 65 78  nBlob(int contex
3720: 74 2c 20 62 79 74 65 5b 5d 20 76 61 6c 75 65 29  t, byte[] value)
3730: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73  .    {.      Uns
3740: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
3750: 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f  .sqlite3_result_
3760: 62 6c 6f 62 5f 69 6e 74 65 72 6f 70 28 63 6f 6e  blob_interop(con
3770: 74 65 78 74 2c 20 76 61 6c 75 65 2c 20 76 61 6c  text, value, val
3780: 75 65 2e 4c 65 6e 67 74 68 2c 20 2d 31 29 3b 0a  ue.Length, -1);.
3790: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
37a0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
37b0: 64 20 52 65 74 75 72 6e 44 6f 75 62 6c 65 28 69  d ReturnDouble(i
37c0: 6e 74 20 63 6f 6e 74 65 78 74 2c 20 64 6f 75 62  nt context, doub
37d0: 6c 65 20 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a  le value).    {.
37e0: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
37f0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
3800: 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 5f  3_result_double_
3810: 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c  interop(context,
3820: 20 72 65 66 20 76 61 6c 75 65 29 3b 0a 20 20 20   ref value);.   
3830: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
3840: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 52   override void R
3850: 65 74 75 72 6e 45 72 72 6f 72 28 69 6e 74 20 63  eturnError(int c
3860: 6f 6e 74 65 78 74 2c 20 73 74 72 69 6e 67 20 76  ontext, string v
3870: 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20 20  alue).    {.    
3880: 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65    UnsafeNativeMe
3890: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65  thods.sqlite3_re
38a0: 73 75 6c 74 5f 65 72 72 6f 72 5f 69 6e 74 65 72  sult_error_inter
38b0: 6f 70 28 63 6f 6e 74 65 78 74 2c 20 54 6f 55 54  op(context, ToUT
38c0: 46 38 28 76 61 6c 75 65 29 2c 20 76 61 6c 75 65  F8(value), value
38d0: 2e 4c 65 6e 67 74 68 29 3b 0a 20 20 20 20 7d 0a  .Length);.    }.
38e0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
38f0: 65 72 72 69 64 65 20 76 6f 69 64 20 52 65 74 75  erride void Retu
3900: 72 6e 49 6e 74 33 32 28 69 6e 74 20 63 6f 6e 74  rnInt32(int cont
3910: 65 78 74 2c 20 69 6e 74 20 76 61 6c 75 65 29 0a  ext, int value).
3920: 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61      {.      Unsa
3930: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
3940: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69  sqlite3_result_i
3950: 6e 74 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65  nt_interop(conte
3960: 78 74 2c 20 76 61 6c 75 65 29 3b 0a 20 20 20 20  xt, value);.    
3970: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
3980: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 52 65  override void Re
3990: 74 75 72 6e 49 6e 74 36 34 28 69 6e 74 20 63 6f  turnInt64(int co
39a0: 6e 74 65 78 74 2c 20 6c 6f 6e 67 20 76 61 6c 75  ntext, long valu
39b0: 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 55  e).    {.      U
39c0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
39d0: 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  ds.sqlite3_resul
39e0: 74 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28  t_int64_interop(
39f0: 63 6f 6e 74 65 78 74 2c 20 72 65 66 20 76 61 6c  context, ref val
3a00: 75 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ue);.    }..    
3a10: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
3a20: 65 20 76 6f 69 64 20 52 65 74 75 72 6e 4e 75 6c  e void ReturnNul
3a30: 6c 28 69 6e 74 20 63 6f 6e 74 65 78 74 29 0a 20  l(int context). 
3a40: 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66     {.      Unsaf
3a50: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
3a60: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 6e 75  qlite3_result_nu
3a70: 6c 6c 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65  ll_interop(conte
3a80: 78 74 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  xt);.    }..    
3a90: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
3aa0: 65 20 76 6f 69 64 20 52 65 74 75 72 6e 54 65 78  e void ReturnTex
3ab0: 74 28 69 6e 74 20 63 6f 6e 74 65 78 74 2c 20 73  t(int context, s
3ac0: 74 72 69 6e 67 20 76 61 6c 75 65 29 0a 20 20 20  tring value).   
3ad0: 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e   {.      UnsafeN
3ae0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
3af0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74  ite3_result_text
3b00: 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74  _interop(context
3b10: 2c 20 54 6f 55 54 46 38 28 76 61 6c 75 65 29 2c  , ToUTF8(value),
3b20: 20 76 61 6c 75 65 2e 4c 65 6e 67 74 68 2c 20 2d   value.Length, -
3b30: 31 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  1);.    }..    i
3b40: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
3b50: 20 69 6e 74 20 41 67 67 72 65 67 61 74 65 43 6f   int AggregateCo
3b60: 6e 74 65 78 74 28 69 6e 74 20 63 6f 6e 74 65 78  ntext(int contex
3b70: 74 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  t).    {.      r
3b80: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
3b90: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
3ba0: 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74  3_aggregate_cont
3bb0: 65 78 74 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74  ext_interop(cont
3bc0: 65 78 74 2c 20 31 29 3b 0a 20 20 20 20 7d 0a 0a  ext, 1);.    }..
3bd0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
3be0: 72 72 69 64 65 20 76 6f 69 64 20 53 65 74 52 65  rride void SetRe
3bf0: 61 6c 43 6f 6c 4e 61 6d 65 73 28 62 6f 6f 6c 20  alColNames(bool 
3c00: 62 4f 6e 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  bOn).    {.     
3c10: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
3c20: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 61  hods.sqlite3_rea
3c30: 6c 63 6f 6c 6e 61 6d 65 73 28 5f 73 71 6c 2c 20  lcolnames(_sql, 
3c40: 43 6f 6e 76 65 72 74 2e 54 6f 49 6e 74 33 32 28  Convert.ToInt32(
3c50: 62 4f 6e 29 29 3b 0a 20 20 20 20 7d 0a 20 20 7d  bOn));.    }.  }
3c60: 0a 7d 0a                                         .}.