System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 7df0e0e0820c84ea0ebb2cd6105d001822983cd7:


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 20 20  ions.Generic;.  
01a0: 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 47 6c 6f  using System.Glo
01b0: 62 61 6c 69 7a 61 74 69 6f 6e 3b 0a 0a 20 20 2f  balization;..  /
01c0: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20 20 2f  // <summary>.  /
01d0: 2f 2f 20 54 68 69 73 20 63 6c 61 73 73 20 69 6d  // This class im
01e0: 70 6c 65 6d 65 6e 74 73 20 53 51 4c 69 74 65 42  plements SQLiteB
01f0: 61 73 65 20 63 6f 6d 70 6c 65 74 65 6c 79 2c 20  ase completely, 
0200: 61 6e 64 20 69 73 20 74 68 65 20 67 75 74 73 20  and is the guts 
0210: 6f 66 20 74 68 65 20 63 6f 64 65 20 74 68 61 74  of the code that
0220: 20 69 6e 74 65 72 6f 70 27 73 20 53 51 4c 69 74   interop's SQLit
0230: 65 20 77 69 74 68 20 2e 4e 45 54 0a 20 20 2f 2f  e with .NET.  //
0240: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 69  / </summary>.  i
0250: 6e 74 65 72 6e 61 6c 20 63 6c 61 73 73 20 53 51  nternal class SQ
0260: 4c 69 74 65 33 20 3a 20 53 51 4c 69 74 65 42 61  Lite3 : SQLiteBa
0270: 73 65 0a 20 20 7b 0a 20 20 20 20 2f 2f 2f 20 3c  se.  {.    /// <
0280: 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f  summary>.    ///
0290: 20 54 68 65 20 6f 70 61 71 75 65 20 70 6f 69 6e   The opaque poin
02a0: 74 65 72 20 72 65 74 75 72 6e 65 64 20 74 6f 20  ter returned to 
02b0: 75 73 20 62 79 20 74 68 65 20 73 71 6c 69 74 65  us by the sqlite
02c0: 20 70 72 6f 76 69 64 65 72 0a 20 20 20 20 2f 2f   provider.    //
02d0: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20  / </summary>.   
02e0: 20 70 72 6f 74 65 63 74 65 64 20 69 6e 74 20 20   protected int  
02f0: 20 20 20 20 20 20 20 20 20 20 20 20 5f 73 71 6c              _sql
0300: 3b 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ;.    /// <summa
0310: 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20  ry>.    /// The 
0320: 75 73 65 72 2d 64 65 66 69 6e 65 64 20 66 75 6e  user-defined fun
0330: 63 74 69 6f 6e 73 20 72 65 67 69 73 74 65 72 65  ctions registere
0340: 64 20 6f 6e 20 74 68 69 73 20 63 6f 6e 6e 65 63  d on this connec
0350: 74 69 6f 6e 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  tion.    /// </s
0360: 75 6d 6d 61 72 79 3e 0a 20 20 20 20 70 72 6f 74  ummary>.    prot
0370: 65 63 74 65 64 20 53 51 4c 69 74 65 46 75 6e 63  ected SQLiteFunc
0380: 74 69 6f 6e 5b 5d 20 5f 66 75 6e 63 74 69 6f 6e  tion[] _function
0390: 73 41 72 72 61 79 3b 0a 0a 20 20 20 20 69 6e 74  sArray;..    int
03a0: 65 72 6e 61 6c 20 53 51 4c 69 74 65 33 28 53 51  ernal SQLite3(SQ
03b0: 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73 20  LiteDateFormats 
03c0: 66 6d 74 29 0a 20 20 20 20 20 20 3a 20 62 61 73  fmt).      : bas
03d0: 65 28 66 6d 74 29 0a 20 20 20 20 7b 0a 20 20 20  e(fmt).    {.   
03e0: 20 7d 0a 0a 20 20 20 20 70 72 6f 74 65 63 74 65   }..    protecte
03f0: 64 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  d override void 
0400: 44 69 73 70 6f 73 65 28 62 6f 6f 6c 20 62 44 69  Dispose(bool bDi
0410: 73 70 6f 73 69 6e 67 29 0a 20 20 20 20 7b 0a 20  sposing).    {. 
0420: 20 20 20 20 20 43 6c 6f 73 65 28 29 3b 0a 20 20       Close();.  
0430: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
0440: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
0450: 43 6c 6f 73 65 28 29 0a 20 20 20 20 7b 0a 20 20  Close().    {.  
0460: 20 20 20 20 69 66 20 28 5f 73 71 6c 20 21 3d 20      if (_sql != 
0470: 30 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20  0).      {.     
0480: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
0490: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
04a0: 71 6c 69 74 65 33 5f 63 6c 6f 73 65 5f 69 6e 74  qlite3_close_int
04b0: 65 72 6f 70 28 5f 73 71 6c 29 3b 0a 20 20 20 20  erop(_sql);.    
04c0: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
04d0: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
04e0: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69  xception(n, SQLi
04f0: 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a  teLastError());.
0500: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 46 75          SQLiteFu
0510: 6e 63 74 69 6f 6e 2e 55 6e 62 69 6e 64 46 75 6e  nction.UnbindFun
0520: 63 74 69 6f 6e 73 28 74 68 69 73 2c 20 5f 66 75  ctions(this, _fu
0530: 6e 63 74 69 6f 6e 73 41 72 72 61 79 29 3b 0a 20  nctionsArray);. 
0540: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 5f 73 71       }.      _sq
0550: 6c 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 0a 20 20  l = 0;.    }..  
0560: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
0570: 69 64 65 20 76 6f 69 64 20 43 61 6e 63 65 6c 28  ide void Cancel(
0580: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e  ).    {.      Un
0590: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
05a0: 73 2e 73 71 6c 69 74 65 33 5f 69 6e 74 65 72 72  s.sqlite3_interr
05b0: 75 70 74 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c  upt_interop(_sql
05c0: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
05d0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
05e0: 73 74 72 69 6e 67 20 56 65 72 73 69 6f 6e 0a 20  string Version. 
05f0: 20 20 20 7b 0a 20 20 20 20 20 20 67 65 74 0a 20     {.      get. 
0600: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69       {.        i
0610: 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20 20 20 20  nt len;.        
0620: 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e 67 28  return ToString(
0630: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
0640: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6c 69 62 76  ods.sqlite3_libv
0650: 65 72 73 69 6f 6e 5f 69 6e 74 65 72 6f 70 28 6f  ersion_interop(o
0660: 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0a 20  ut len), len);. 
0670: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20       }.    }..  
0680: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
0690: 69 64 65 20 69 6e 74 20 43 68 61 6e 67 65 73 0a  ide int Changes.
06a0: 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65 74 0a      {.      get.
06b0: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
06c0: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
06d0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
06e0: 65 33 5f 63 68 61 6e 67 65 73 5f 69 6e 74 65 72  e3_changes_inter
06f0: 6f 70 28 5f 73 71 6c 29 3b 0a 20 20 20 20 20 20  op(_sql);.      
0700: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  }.    }..    int
0710: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
0720: 6f 69 64 20 4f 70 65 6e 28 73 74 72 69 6e 67 20  oid Open(string 
0730: 73 74 72 46 69 6c 65 6e 61 6d 65 29 0a 20 20 20  strFilename).   
0740: 20 7b 0a 20 20 20 20 20 20 69 66 20 28 5f 73 71   {.      if (_sq
0750: 6c 20 21 3d 20 30 29 20 72 65 74 75 72 6e 3b 0a  l != 0) return;.
0760: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
0770: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
0780: 73 2e 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f 69  s.sqlite3_open_i
0790: 6e 74 65 72 6f 70 28 54 6f 55 54 46 38 28 73 74  nterop(ToUTF8(st
07a0: 72 46 69 6c 65 6e 61 6d 65 29 2c 20 6f 75 74 20  rFilename), out 
07b0: 5f 73 71 6c 29 3b 0a 20 20 20 20 20 20 69 66 20  _sql);.      if 
07c0: 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65  (n > 0) throw ne
07d0: 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  w SQLiteExceptio
07e0: 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45  n(n, SQLiteLastE
07f0: 72 72 6f 72 28 29 29 3b 0a 0a 20 20 20 20 20 20  rror());..      
0800: 5f 66 75 6e 63 74 69 6f 6e 73 41 72 72 61 79 20  _functionsArray 
0810: 3d 20 53 51 4c 69 74 65 46 75 6e 63 74 69 6f 6e  = SQLiteFunction
0820: 2e 42 69 6e 64 46 75 6e 63 74 69 6f 6e 73 28 74  .BindFunctions(t
0830: 68 69 73 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  his);.    }..   
0840: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
0850: 64 65 20 76 6f 69 64 20 53 65 74 54 69 6d 65 6f  de void SetTimeo
0860: 75 74 28 69 6e 74 20 6e 54 69 6d 65 6f 75 74 4d  ut(int nTimeoutM
0870: 53 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  S).    {.      i
0880: 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74  nt n = UnsafeNat
0890: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
08a0: 65 33 5f 62 75 73 79 5f 74 69 6d 65 6f 75 74 5f  e3_busy_timeout_
08b0: 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 6e 54  interop(_sql, nT
08c0: 69 6d 65 6f 75 74 4d 53 29 3b 0a 20 20 20 20 20  imeoutMS);.     
08d0: 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f   if (n > 0) thro
08e0: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
08f0: 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c  ption(n, SQLiteL
0900: 61 73 74 45 72 72 6f 72 28 29 29 3b 0a 20 20 20  astError());.   
0910: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
0920: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 45   override void E
0930: 78 65 63 75 74 65 28 73 74 72 69 6e 67 20 73 74  xecute(string st
0940: 72 53 71 6c 29 0a 20 20 20 20 7b 0a 20 20 20 20  rSql).    {.    
0950: 20 20 49 6e 74 50 74 72 20 70 3b 0a 20 20 20 20    IntPtr p;.    
0960: 20 20 73 74 72 69 6e 67 20 73 74 72 20 3d 20 73    string str = s
0970: 74 72 53 71 6c 3b 0a 20 20 20 20 20 20 69 6e 74  trSql;.      int
0980: 20 6c 65 6e 3b 0a 0a 20 20 20 20 20 20 69 6e 74   len;..      int
0990: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
09a0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
09b0: 5f 65 78 65 63 5f 69 6e 74 65 72 6f 70 28 5f 73  _exec_interop(_s
09c0: 71 6c 2c 20 54 6f 55 54 46 38 28 73 74 72 53 71  ql, ToUTF8(strSq
09d0: 6c 29 2c 20 30 2c 20 30 2c 20 6f 75 74 20 70 2c  l), 0, 0, out p,
09e0: 20 6f 75 74 20 6c 65 6e 29 3b 0a 20 20 20 20 20   out len);.     
09f0: 20 69 66 20 28 70 20 21 3d 20 49 6e 74 50 74 72   if (p != IntPtr
0a00: 2e 5a 65 72 6f 29 0a 20 20 20 20 20 20 7b 0a 20  .Zero).      {. 
0a10: 20 20 20 20 20 20 20 73 74 72 20 3d 20 54 6f 53         str = ToS
0a20: 74 72 69 6e 67 28 70 2c 20 6c 65 6e 29 3b 0a 20  tring(p, len);. 
0a30: 20 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74         UnsafeNat
0a40: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
0a50: 65 33 5f 66 72 65 65 5f 69 6e 74 65 72 6f 70 28  e3_free_interop(
0a60: 70 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  p);.      }.    
0a70: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
0a80: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
0a90: 65 70 74 69 6f 6e 28 6e 2c 20 73 74 72 29 3b 0a  eption(n, str);.
0aa0: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
0ab0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 62 6f 6f  nal override boo
0ac0: 6c 20 53 74 65 70 28 53 51 4c 69 74 65 53 74 61  l Step(SQLiteSta
0ad0: 74 65 6d 65 6e 74 20 73 74 6d 74 29 0a 20 20 20  tement stmt).   
0ae0: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b 0a   {.      int n;.
0af0: 20 20 20 20 20 20 6c 6f 6e 67 20 64 77 74 69 63        long dwtic
0b00: 6b 20 3d 20 30 3b 0a 20 20 20 20 20 20 52 61 6e  k = 0;.      Ran
0b10: 64 6f 6d 20 72 6e 64 20 3d 20 6e 75 6c 6c 3b 0a  dom rnd = null;.
0b20: 0a 20 20 20 20 20 20 77 68 69 6c 65 20 28 74 72  .      while (tr
0b30: 75 65 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20  ue).      {.    
0b40: 20 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61      n = UnsafeNa
0b50: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
0b60: 74 65 33 5f 73 74 65 70 5f 69 6e 74 65 72 6f 70  te3_step_interop
0b70: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
0b80: 6d 74 29 3b 0a 0a 20 20 20 20 20 20 20 20 69 66  mt);..        if
0b90: 20 28 6e 20 3d 3d 20 31 30 30 29 20 72 65 74 75   (n == 100) retu
0ba0: 72 6e 20 74 72 75 65 3b 0a 20 20 20 20 20 20 20  rn true;.       
0bb0: 20 69 66 20 28 6e 20 3d 3d 20 31 30 31 29 20 72   if (n == 101) r
0bc0: 65 74 75 72 6e 20 66 61 6c 73 65 3b 0a 0a 20 20  eturn false;..  
0bd0: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
0be0: 0a 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20  .        {.     
0bf0: 20 20 20 20 20 69 6e 74 20 72 3b 0a 0a 20 20 20       int r;..   
0c00: 20 20 20 20 20 20 20 2f 2f 20 41 6e 20 65 72 72         // An err
0c10: 6f 72 20 6f 63 63 75 72 72 65 64 2c 20 61 74 74  or occurred, att
0c20: 65 6d 70 74 20 74 6f 20 72 65 73 65 74 20 74 68  empt to reset th
0c30: 65 20 73 74 61 74 65 6d 65 6e 74 2e 20 20 49 66  e statement.  If
0c40: 20 74 68 65 20 72 65 73 65 74 20 77 6f 72 6b 65   the reset worke
0c50: 64 20 62 65 63 61 75 73 65 20 74 68 65 0a 20 20  d because the.  
0c60: 20 20 20 20 20 20 20 20 2f 2f 20 73 63 68 65 6d          // schem
0c70: 61 20 68 61 73 20 63 68 61 6e 67 65 64 2c 20 72  a has changed, r
0c80: 65 2d 74 72 79 20 74 68 65 20 73 74 65 70 20 61  e-try the step a
0c90: 67 61 69 6e 2e 20 20 49 66 20 69 74 20 65 72 72  gain.  If it err
0ca0: 6f 72 65 64 20 6f 75 72 20 62 65 63 61 75 73 65  ored our because
0cb0: 20 74 68 65 20 64 61 74 61 62 61 73 65 0a 20 20   the database.  
0cc0: 20 20 20 20 20 20 20 20 2f 2f 20 69 73 20 6c 6f          // is lo
0cd0: 63 6b 65 64 2c 20 74 68 65 6e 20 6b 65 65 70 20  cked, then keep 
0ce0: 72 65 74 72 79 69 6e 67 20 75 6e 74 69 6c 20 74  retrying until t
0cf0: 68 65 20 63 6f 6d 6d 61 6e 64 20 74 69 6d 65 6f  he command timeo
0d00: 75 74 20 6f 63 63 75 72 73 2e 0a 20 20 20 20 20  ut occurs..     
0d10: 20 20 20 20 20 72 20 3d 20 52 65 73 65 74 28 73       r = Reset(s
0d20: 74 6d 74 29 3b 0a 0a 20 20 20 20 20 20 20 20 20  tmt);..         
0d30: 20 69 66 20 28 72 20 3d 3d 20 30 29 0a 20 20 20   if (r == 0).   
0d40: 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e           throw n
0d50: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
0d60: 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74  on(n, SQLiteLast
0d70: 45 72 72 6f 72 28 29 29 3b 0a 0a 20 20 20 20 20  Error());..     
0d80: 20 20 20 20 20 65 6c 73 65 20 69 66 20 28 72 20       else if (r 
0d90: 3d 3d 20 36 20 26 26 20 73 74 6d 74 2e 5f 63 6f  == 6 && stmt._co
0da0: 6d 6d 61 6e 64 20 21 3d 20 6e 75 6c 6c 29 20 2f  mmand != null) /
0db0: 2f 20 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 0a  / SQLITE_LOCKED.
0dc0: 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20            {.    
0dd0: 20 20 20 20 20 20 20 20 2f 2f 20 4b 65 65 70 20          // Keep 
0de0: 74 72 79 69 6e 67 0a 20 20 20 20 20 20 20 20 20  trying.         
0df0: 20 20 20 69 66 20 28 64 77 74 69 63 6b 20 3d 3d     if (dwtick ==
0e00: 20 30 29 20 2f 2f 20 46 69 72 73 74 20 74 69 6d   0) // First tim
0e10: 65 20 77 65 27 76 65 20 65 6e 63 6f 75 6e 74 65  e we've encounte
0e20: 72 65 64 20 74 68 65 20 6c 6f 63 6b 0a 20 20 20  red the lock.   
0e30: 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20 20 20           {.     
0e40: 20 20 20 20 20 20 20 20 20 64 77 74 69 63 6b 20           dwtick 
0e50: 3d 20 44 61 74 65 54 69 6d 65 2e 4e 6f 77 2e 54  = DateTime.Now.T
0e60: 69 63 6b 73 20 2b 20 28 73 74 6d 74 2e 5f 63 6f  icks + (stmt._co
0e70: 6d 6d 61 6e 64 2e 5f 63 6f 6d 6d 61 6e 64 54 69  mmand._commandTi
0e80: 6d 65 6f 75 74 20 2a 20 31 30 30 30 30 30 30 30  meout * 10000000
0e90: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
0ea0: 20 72 6e 64 20 3d 20 6e 65 77 20 52 61 6e 64 6f   rnd = new Rando
0eb0: 6d 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  m();.           
0ec0: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f   }.            /
0ed0: 2f 20 49 66 20 77 65 27 76 65 20 65 78 63 65 65  / If we've excee
0ee0: 64 65 64 20 74 68 65 20 63 6f 6d 6d 61 6e 64 27  ded the command'
0ef0: 73 20 74 69 6d 65 6f 75 74 2c 20 67 69 76 65 20  s timeout, give 
0f00: 75 70 20 61 6e 64 20 74 68 72 6f 77 20 61 6e 20  up and throw an 
0f10: 65 72 72 6f 72 0a 20 20 20 20 20 20 20 20 20 20  error.          
0f20: 20 20 69 66 20 28 44 61 74 65 54 69 6d 65 2e 4e    if (DateTime.N
0f30: 6f 77 2e 54 69 63 6b 73 20 2d 20 64 77 74 69 63  ow.Ticks - dwtic
0f40: 6b 20 3e 20 30 29 0a 20 20 20 20 20 20 20 20 20  k > 0).         
0f50: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20     {.           
0f60: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c     throw new SQL
0f70: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 72 2c 20  iteException(r, 
0f80: 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f 72 28  SQLiteLastError(
0f90: 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ));.            
0fa0: 7d 0a 20 20 20 20 20 20 20 20 20 20 20 20 65 6c  }.            el
0fb0: 73 65 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  se.            {
0fc0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  .              /
0fd0: 2f 20 4f 74 68 65 72 77 69 73 65 20 73 6c 65 65  / Otherwise slee
0fe0: 70 20 66 6f 72 20 61 20 72 61 6e 64 6f 6d 20 61  p for a random a
0ff0: 6d 6f 75 6e 74 20 6f 66 20 74 69 6d 65 20 75 70  mount of time up
1000: 20 74 6f 20 32 35 30 6d 73 0a 20 20 20 20 20 20   to 250ms.      
1010: 20 20 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61          UnsafeNa
1020: 74 69 76 65 4d 65 74 68 6f 64 73 2e 53 6c 65 65  tiveMethods.Slee
1030: 70 28 28 75 69 6e 74 29 72 6e 64 2e 4e 65 78 74  p((uint)rnd.Next
1040: 28 31 2c 20 32 35 30 29 29 3b 0a 20 20 20 20 20  (1, 250));.     
1050: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
1060: 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 7d 0a     }..        }.
1070: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20        }.    }.. 
1080: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
1090: 72 69 64 65 20 76 6f 69 64 20 46 69 6e 61 6c 69  ride void Finali
10a0: 7a 65 53 74 61 74 65 6d 65 6e 74 28 53 51 4c 69  zeStatement(SQLi
10b0: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
10c0: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 66  ).    {.      if
10d0: 20 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73   (stmt._sqlite_s
10e0: 74 6d 74 20 3e 20 30 29 0a 20 20 20 20 20 20 7b  tmt > 0).      {
10f0: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  .        int n =
1100: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
1110: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 66 69 6e  hods.sqlite3_fin
1120: 61 6c 69 7a 65 5f 69 6e 74 65 72 6f 70 28 73 74  alize_interop(st
1130: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29  mt._sqlite_stmt)
1140: 3b 0a 20 20 20 20 20 20 20 20 69 66 20 28 6e 20  ;.        if (n 
1150: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
1160: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
1170: 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f  , SQLiteLastErro
1180: 72 28 29 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  r());.      }.  
1190: 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65      stmt._sqlite
11a0: 5f 73 74 6d 74 20 3d 20 30 3b 0a 20 20 20 20 7d  _stmt = 0;.    }
11b0: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
11c0: 76 65 72 72 69 64 65 20 69 6e 74 20 52 65 73 65  verride int Rese
11d0: 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  t(SQLiteStatemen
11e0: 74 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20 20  t stmt).    {.  
11f0: 20 20 20 20 69 6e 74 20 6e 3b 0a 0a 20 20 20 20      int n;..    
1200: 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69    n = UnsafeNati
1210: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1220: 33 5f 72 65 73 65 74 5f 69 6e 74 65 72 6f 70 28  3_reset_interop(
1230: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
1240: 74 29 3b 0a 0a 20 20 20 20 20 20 2f 2f 20 49 66  t);..      // If
1250: 20 74 68 65 20 73 63 68 65 6d 61 20 63 68 61 6e   the schema chan
1260: 67 65 64 2c 20 74 72 79 20 61 6e 64 20 72 65 2d  ged, try and re-
1270: 70 72 65 70 61 72 65 20 69 74 0a 20 20 20 20 20  prepare it.     
1280: 20 69 66 20 28 6e 20 3d 3d 20 31 37 29 20 2f 2f   if (n == 17) //
1290: 20 53 51 4c 49 54 45 5f 53 43 48 45 4d 41 0a 20   SQLITE_SCHEMA. 
12a0: 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 2f       {.        /
12b0: 2f 20 52 65 63 72 65 61 74 65 20 61 20 64 75 6d  / Recreate a dum
12c0: 6d 79 20 73 74 61 74 65 6d 65 6e 74 0a 20 20 20  my statement.   
12d0: 20 20 20 20 20 69 6e 74 20 6e 63 20 3d 20 30 3b       int nc = 0;
12e0: 0a 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 20  .        string 
12f0: 73 74 72 3b 0a 20 20 20 20 20 20 20 20 75 73 69  str;.        usi
1300: 6e 67 20 28 53 51 4c 69 74 65 53 74 61 74 65 6d  ng (SQLiteStatem
1310: 65 6e 74 20 74 6d 70 20 3d 20 50 72 65 70 61 72  ent tmp = Prepar
1320: 65 28 73 74 6d 74 2e 5f 73 71 6c 53 74 61 74 65  e(stmt._sqlState
1330: 6d 65 6e 74 2c 20 72 65 66 20 6e 63 2c 20 6f 75  ment, ref nc, ou
1340: 74 20 73 74 72 29 29 0a 20 20 20 20 20 20 20 20  t str)).        
1350: 7b 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20 46  {.          // F
1360: 69 6e 61 6c 69 7a 65 20 74 68 65 20 65 78 69 73  inalize the exis
1370: 74 69 6e 67 20 73 74 61 74 65 6d 65 6e 74 0a 20  ting statement. 
1380: 20 20 20 20 20 20 20 20 20 46 69 6e 61 6c 69 7a           Finaliz
1390: 65 53 74 61 74 65 6d 65 6e 74 28 73 74 6d 74 29  eStatement(stmt)
13a0: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20  ;..          // 
13b0: 52 65 61 73 73 69 67 6e 20 61 20 6e 65 77 20 73  Reassign a new s
13c0: 74 61 74 65 6d 65 6e 74 20 70 6f 69 6e 74 65 72  tatement pointer
13d0: 20 74 6f 20 74 68 65 20 6f 6c 64 20 73 74 61 74   to the old stat
13e0: 65 6d 65 6e 74 20 61 6e 64 20 63 6c 65 61 72 20  ement and clear 
13f0: 74 68 65 20 74 65 6d 70 6f 72 61 72 79 20 6f 6e  the temporary on
1400: 65 0a 20 20 20 20 20 20 20 20 20 20 73 74 6d 74  e.          stmt
1410: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 20 3d 20  ._sqlite_stmt = 
1420: 74 6d 70 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmp._sqlite_stmt
1430: 3b 0a 20 20 20 20 20 20 20 20 20 20 74 6d 70 2e  ;.          tmp.
1440: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 20 3d 20 30  _sqlite_stmt = 0
1450: 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20  ;..          // 
1460: 52 65 61 70 70 6c 79 20 70 61 72 61 6d 65 74 65  Reapply paramete
1470: 72 73 0a 20 20 20 20 20 20 20 20 20 20 73 74 6d  rs.          stm
1480: 74 2e 42 69 6e 64 50 61 72 61 6d 65 74 65 72 73  t.BindParameters
1490: 28 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  ();.        }.  
14a0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 2d 31 3b        return -1;
14b0: 20 2f 2f 20 52 65 73 65 74 20 77 61 73 20 4f 4b   // Reset was OK
14c0: 2c 20 77 69 74 68 20 73 63 68 65 6d 61 20 63 68  , with schema ch
14d0: 61 6e 67 65 0a 20 20 20 20 20 20 7d 0a 20 20 20  ange.      }.   
14e0: 20 20 20 65 6c 73 65 20 69 66 20 28 6e 20 3d 3d     else if (n ==
14f0: 20 36 29 20 2f 2f 20 53 51 4c 49 54 45 5f 4c 4f   6) // SQLITE_LO
1500: 43 4b 45 44 0a 20 20 20 20 20 20 20 20 72 65 74  CKED.        ret
1510: 75 72 6e 20 6e 3b 0a 0a 20 20 20 20 20 20 69 66  urn n;..      if
1520: 20 28 6e 20 3e 20 30 29 0a 20 20 20 20 20 20 20   (n > 0).       
1530: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
1540: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51  eException(n, SQ
1550: 4c 69 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29  LiteLastError())
1560: 3b 0a 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ;..      return 
1570: 30 3b 20 2f 2f 20 57 65 20 72 65 73 65 74 20 4f  0; // We reset O
1580: 4b 2c 20 6e 6f 20 73 63 68 65 6d 61 20 63 68 61  K, no schema cha
1590: 6e 67 65 73 0a 20 20 20 20 7d 0a 0a 20 20 20 20  nges.    }..    
15a0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
15b0: 65 20 73 74 72 69 6e 67 20 53 51 4c 69 74 65 4c  e string SQLiteL
15c0: 61 73 74 45 72 72 6f 72 28 29 0a 20 20 20 20 7b  astError().    {
15d0: 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a  .      int len;.
15e0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 54 6f 53        return ToS
15f0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
1600: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1610: 33 5f 65 72 72 6d 73 67 5f 69 6e 74 65 72 6f 70  3_errmsg_interop
1620: 28 5f 73 71 6c 2c 20 6f 75 74 20 6c 65 6e 29 2c  (_sql, out len),
1630: 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20   len);.    }..  
1640: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
1650: 69 64 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d  ide SQLiteStatem
1660: 65 6e 74 20 50 72 65 70 61 72 65 28 73 74 72 69  ent Prepare(stri
1670: 6e 67 20 73 74 72 53 71 6c 2c 20 72 65 66 20 69  ng strSql, ref i
1680: 6e 74 20 6e 50 61 72 61 6d 53 74 61 72 74 2c 20  nt nParamStart, 
1690: 6f 75 74 20 73 74 72 69 6e 67 20 73 74 72 52 65  out string strRe
16a0: 6d 61 69 6e 29 0a 20 20 20 20 7b 0a 20 20 20 20  main).    {.    
16b0: 20 20 69 6e 74 20 73 74 6d 74 3b 0a 20 20 20 20    int stmt;.    
16c0: 20 20 49 6e 74 50 74 72 20 70 74 72 3b 0a 20 20    IntPtr ptr;.  
16d0: 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 0a 20 20      int len;..  
16e0: 20 20 20 20 62 79 74 65 5b 5d 20 62 20 3d 20 54      byte[] b = T
16f0: 6f 55 54 46 38 28 73 74 72 53 71 6c 29 3b 0a 0a  oUTF8(strSql);..
1700: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
1710: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
1720: 73 2e 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  s.sqlite3_prepar
1730: 65 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20  e_interop(_sql, 
1740: 62 2c 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c  b, b.Length - 1,
1750: 20 6f 75 74 20 73 74 6d 74 2c 20 6f 75 74 20 70   out stmt, out p
1760: 74 72 2c 20 6f 75 74 20 6c 65 6e 29 3b 0a 20 20  tr, out len);.  
1770: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
1780: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
1790: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c 69  xception(n, SQLi
17a0: 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0a  teLastError());.
17b0: 0a 20 20 20 20 20 20 73 74 72 52 65 6d 61 69 6e  .      strRemain
17c0: 20 3d 20 54 6f 53 74 72 69 6e 67 28 70 74 72 2c   = ToString(ptr,
17d0: 20 6c 65 6e 29 3b 0a 0a 20 20 20 20 20 20 53 51   len);..      SQ
17e0: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 63 6d  LiteStatement cm
17f0: 64 20 3d 20 6e 75 6c 6c 3b 0a 20 20 20 20 20 20  d = null;.      
1800: 69 66 20 28 73 74 6d 74 20 3e 20 30 29 20 63 6d  if (stmt > 0) cm
1810: 64 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 53 74  d = new SQLiteSt
1820: 61 74 65 6d 65 6e 74 28 74 68 69 73 2c 20 73 74  atement(this, st
1830: 6d 74 2c 20 73 74 72 53 71 6c 2e 53 75 62 73 74  mt, strSql.Subst
1840: 72 69 6e 67 28 30 2c 20 73 74 72 53 71 6c 2e 4c  ring(0, strSql.L
1850: 65 6e 67 74 68 20 2d 20 73 74 72 52 65 6d 61 69  ength - strRemai
1860: 6e 2e 4c 65 6e 67 74 68 29 2c 20 72 65 66 20 6e  n.Length), ref n
1870: 50 61 72 61 6d 53 74 61 72 74 29 3b 0a 0a 20 20  ParamStart);..  
1880: 20 20 20 20 72 65 74 75 72 6e 20 63 6d 64 3b 0a      return cmd;.
1890: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
18a0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
18b0: 64 20 42 69 6e 64 5f 44 6f 75 62 6c 65 28 53 51  d Bind_Double(SQ
18c0: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
18d0: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 64  mt, int index, d
18e0: 6f 75 62 6c 65 20 76 61 6c 75 65 29 0a 20 20 20  ouble value).   
18f0: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d   {.      int n =
1900: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
1910: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
1920: 64 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70  d_double_interop
1930: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
1940: 6d 74 2c 20 69 6e 64 65 78 2c 20 72 65 66 20 76  mt, index, ref v
1950: 61 6c 75 65 29 3b 0a 20 20 20 20 20 20 69 66 20  alue);.      if 
1960: 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65  (n > 0) throw ne
1970: 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  w SQLiteExceptio
1980: 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45  n(n, SQLiteLastE
1990: 72 72 6f 72 28 29 29 3b 0a 20 20 20 20 7d 0a 0a  rror());.    }..
19a0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
19b0: 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f  rride void Bind_
19c0: 49 6e 74 33 32 28 53 51 4c 69 74 65 53 74 61 74  Int32(SQLiteStat
19d0: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
19e0: 69 6e 64 65 78 2c 20 69 6e 74 20 76 61 6c 75 65  index, int value
19f0: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e  ).    {.      in
1a00: 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  t n = UnsafeNati
1a10: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
1a20: 33 5f 62 69 6e 64 5f 69 6e 74 5f 69 6e 74 65 72  3_bind_int_inter
1a30: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
1a40: 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 76 61 6c  stmt, index, val
1a50: 75 65 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e  ue);.      if (n
1a60: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
1a70: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
1a80: 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72  n, SQLiteLastErr
1a90: 6f 72 28 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  or());.    }..  
1aa0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
1ab0: 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 49 6e  ide void Bind_In
1ac0: 74 36 34 28 53 51 4c 69 74 65 53 74 61 74 65 6d  t64(SQLiteStatem
1ad0: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
1ae0: 64 65 78 2c 20 6c 6f 6e 67 20 76 61 6c 75 65 29  dex, long value)
1af0: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74  .    {.      int
1b00: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
1b10: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
1b20: 5f 62 69 6e 64 5f 69 6e 74 36 34 5f 69 6e 74 65  _bind_int64_inte
1b30: 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  rop(stmt._sqlite
1b40: 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 72 65  _stmt, index, re
1b50: 66 20 76 61 6c 75 65 29 3b 0a 20 20 20 20 20 20  f value);.      
1b60: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
1b70: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
1b80: 74 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61  tion(n, SQLiteLa
1b90: 73 74 45 72 72 6f 72 28 29 29 3b 0a 20 20 20 20  stError());.    
1ba0: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
1bb0: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 42 69  override void Bi
1bc0: 6e 64 5f 54 65 78 74 28 53 51 4c 69 74 65 53 74  nd_Text(SQLiteSt
1bd0: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
1be0: 74 20 69 6e 64 65 78 2c 20 73 74 72 69 6e 67 20  t index, string 
1bf0: 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20  value).    {.   
1c00: 20 20 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f     byte[] b = To
1c10: 55 54 46 38 28 76 61 6c 75 65 29 3b 0a 20 20 20  UTF8(value);.   
1c20: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
1c30: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
1c40: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74  qlite3_bind_text
1c50: 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73  _interop(stmt._s
1c60: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
1c70: 78 2c 20 62 2c 20 62 2e 4c 65 6e 67 74 68 20 2d  x, b, b.Length -
1c80: 20 31 2c 20 2d 31 29 3b 0a 20 20 20 20 20 20 69   1, -1);.      i
1c90: 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20  f (n > 0) throw 
1ca0: 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74  new SQLiteExcept
1cb0: 69 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73  ion(n, SQLiteLas
1cc0: 74 45 72 72 6f 72 28 29 29 3b 0a 20 20 20 20 7d  tError());.    }
1cd0: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
1ce0: 76 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e  verride void Bin
1cf0: 64 5f 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74  d_DateTime(SQLit
1d00: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
1d10: 20 69 6e 74 20 69 6e 64 65 78 2c 20 44 61 74 65   int index, Date
1d20: 54 69 6d 65 20 64 74 29 0a 20 20 20 20 7b 0a 20  Time dt).    {. 
1d30: 20 20 20 20 20 62 79 74 65 5b 5d 20 62 20 3d 20       byte[] b = 
1d40: 54 6f 55 54 46 38 28 64 74 29 3b 0a 20 20 20 20  ToUTF8(dt);.    
1d50: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
1d60: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
1d70: 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 5f  lite3_bind_text_
1d80: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
1d90: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
1da0: 2c 20 62 2c 20 62 2e 4c 65 6e 67 74 68 20 2d 20  , b, b.Length - 
1db0: 31 2c 20 2d 31 29 3b 0a 20 20 20 20 20 20 69 66  1, -1);.      if
1dc0: 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e   (n > 0) throw n
1dd0: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
1de0: 6f 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74  on(n, SQLiteLast
1df0: 45 72 72 6f 72 28 29 29 3b 0a 20 20 20 20 7d 0a  Error());.    }.
1e00: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
1e10: 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64  erride void Bind
1e20: 5f 42 6c 6f 62 28 53 51 4c 69 74 65 53 74 61 74  _Blob(SQLiteStat
1e30: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
1e40: 69 6e 64 65 78 2c 20 62 79 74 65 5b 5d 20 62 6c  index, byte[] bl
1e50: 6f 62 44 61 74 61 29 0a 20 20 20 20 7b 0a 20 20  obData).    {.  
1e60: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
1e70: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
1e80: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 62 6c 6f  sqlite3_bind_blo
1e90: 62 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  b_interop(stmt._
1ea0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
1eb0: 65 78 2c 20 62 6c 6f 62 44 61 74 61 2c 20 62 6c  ex, blobData, bl
1ec0: 6f 62 44 61 74 61 2e 4c 65 6e 67 74 68 2c 20 2d  obData.Length, -
1ed0: 31 29 3b 0a 20 20 20 20 20 20 69 66 20 28 6e 20  1);.      if (n 
1ee0: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
1ef0: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
1f00: 2c 20 53 51 4c 69 74 65 4c 61 73 74 45 72 72 6f  , SQLiteLastErro
1f10: 72 28 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  r());.    }..   
1f20: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
1f30: 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 4e 75 6c  de void Bind_Nul
1f40: 6c 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  l(SQLiteStatemen
1f50: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
1f60: 78 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69  x).    {.      i
1f70: 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74  nt n = UnsafeNat
1f80: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
1f90: 65 33 5f 62 69 6e 64 5f 6e 75 6c 6c 5f 69 6e 74  e3_bind_null_int
1fa0: 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74  erop(stmt._sqlit
1fb0: 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0a  e_stmt, index);.
1fc0: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
1fd0: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
1fe0: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51  eException(n, SQ
1ff0: 4c 69 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29  LiteLastError())
2000: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
2010: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69  ernal override i
2020: 6e 74 20 42 69 6e 64 5f 50 61 72 61 6d 43 6f 75  nt Bind_ParamCou
2030: 6e 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  nt(SQLiteStateme
2040: 6e 74 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20  nt stmt).    {. 
2050: 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61       return Unsa
2060: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
2070: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 70 61 72  sqlite3_bind_par
2080: 61 6d 65 74 65 72 5f 63 6f 75 6e 74 5f 69 6e 74  ameter_count_int
2090: 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74  erop(stmt._sqlit
20a0: 65 5f 73 74 6d 74 29 3b 0a 20 20 20 20 7d 0a 0a  e_stmt);.    }..
20b0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
20c0: 72 72 69 64 65 20 73 74 72 69 6e 67 20 42 69 6e  rride string Bin
20d0: 64 5f 50 61 72 61 6d 4e 61 6d 65 28 53 51 4c 69  d_ParamName(SQLi
20e0: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
20f0: 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20  , int index).   
2100: 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e   {.      int len
2110: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 54  ;.      return T
2120: 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61  oString(UnsafeNa
2130: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
2140: 74 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74  te3_bind_paramet
2150: 65 72 5f 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28  er_name_interop(
2160: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
2170: 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65  t, index, out le
2180: 6e 29 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a  n), len);.    }.
2190: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
21a0: 65 72 72 69 64 65 20 69 6e 74 20 42 69 6e 64 5f  erride int Bind_
21b0: 50 61 72 61 6d 49 6e 64 65 78 28 53 51 4c 69 74  ParamIndex(SQLit
21c0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
21d0: 20 73 74 72 69 6e 67 20 70 61 72 61 6d 4e 61 6d   string paramNam
21e0: 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  e).    {.      r
21f0: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
2200: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
2210: 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72  3_bind_parameter
2220: 5f 69 6e 64 65 78 5f 69 6e 74 65 72 6f 70 28 73  _index_interop(s
2230: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
2240: 2c 20 54 6f 55 54 46 38 28 70 61 72 61 6d 4e 61  , ToUTF8(paramNa
2250: 6d 65 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  me));.    }..   
2260: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
2270: 64 65 20 69 6e 74 20 43 6f 6c 75 6d 6e 43 6f 75  de int ColumnCou
2280: 6e 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  nt(SQLiteStateme
2290: 6e 74 20 73 74 6d 74 29 0a 20 20 20 20 7b 0a 20  nt stmt).    {. 
22a0: 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61       return Unsa
22b0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
22c0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 63  sqlite3_column_c
22d0: 6f 75 6e 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d  ount_interop(stm
22e0: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29 3b  t._sqlite_stmt);
22f0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
2300: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74  rnal override st
2310: 72 69 6e 67 20 43 6f 6c 75 6d 6e 4e 61 6d 65 28  ring ColumnName(
2320: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
2330: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29  stmt, int index)
2340: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74  .    {.      int
2350: 20 6c 65 6e 3b 0a 20 20 20 20 20 20 72 65 74 75   len;.      retu
2360: 72 6e 20 54 6f 53 74 72 69 6e 67 28 55 6e 73 61  rn ToString(Unsa
2370: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
2380: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6e  sqlite3_column_n
2390: 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74  ame_interop(stmt
23a0: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
23b0: 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20  ndex, out len), 
23c0: 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  len);.    }..   
23d0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
23e0: 64 65 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e  de string Column
23f0: 54 79 70 65 28 53 51 4c 69 74 65 53 74 61 74 65  Type(SQLiteState
2400: 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69  ment stmt, int i
2410: 6e 64 65 78 2c 20 6f 75 74 20 54 79 70 65 41 66  ndex, out TypeAf
2420: 66 69 6e 69 74 79 20 6e 41 66 66 69 6e 69 74 79  finity nAffinity
2430: 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 6e 41  ).    {.      nA
2440: 66 66 69 6e 69 74 79 20 3d 20 54 79 70 65 41 66  ffinity = TypeAf
2450: 66 69 6e 69 74 79 2e 4e 6f 6e 65 3b 0a 0a 20 20  finity.None;..  
2460: 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20      int len;.   
2470: 20 20 20 49 6e 74 50 74 72 20 70 20 3d 20 55 6e     IntPtr p = Un
2480: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
2490: 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  s.sqlite3_column
24a0: 5f 64 65 63 6c 74 79 70 65 5f 69 6e 74 65 72 6f  _decltype_intero
24b0: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
24c0: 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20  tmt, index, out 
24d0: 6c 65 6e 29 3b 0a 20 20 20 20 20 20 69 66 20 28  len);.      if (
24e0: 70 20 21 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f  p != IntPtr.Zero
24f0: 29 20 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e  ) return ToStrin
2500: 67 28 70 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 20  g(p, len);.     
2510: 20 65 6c 73 65 0a 20 20 20 20 20 20 7b 0a 20 20   else.      {.  
2520: 20 20 20 20 20 20 6e 41 66 66 69 6e 69 74 79 20        nAffinity 
2530: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
2540: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
2550: 6c 75 6d 6e 5f 74 79 70 65 5f 69 6e 74 65 72 6f  lumn_type_intero
2560: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
2570: 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0a 20 20 20  tmt, index);.   
2580: 20 20 20 20 20 73 77 69 74 63 68 20 28 6e 41 66       switch (nAf
2590: 66 69 6e 69 74 79 29 0a 20 20 20 20 20 20 20 20  finity).        
25a0: 7b 0a 20 20 20 20 20 20 20 20 20 20 63 61 73 65  {.          case
25b0: 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 49 6e   TypeAffinity.In
25c0: 74 36 34 3a 0a 20 20 20 20 20 20 20 20 20 20 20  t64:.           
25d0: 20 72 65 74 75 72 6e 20 22 42 49 47 49 4e 54 22   return "BIGINT"
25e0: 3b 0a 20 20 20 20 20 20 20 20 20 20 63 61 73 65  ;.          case
25f0: 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f   TypeAffinity.Do
2600: 75 62 6c 65 3a 0a 20 20 20 20 20 20 20 20 20 20  uble:.          
2610: 20 20 72 65 74 75 72 6e 20 22 44 4f 55 42 4c 45    return "DOUBLE
2620: 22 3b 0a 20 20 20 20 20 20 20 20 20 20 63 61 73  ";.          cas
2630: 65 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 42  e TypeAffinity.B
2640: 6c 6f 62 3a 0a 20 20 20 20 20 20 20 20 20 20 20  lob:.           
2650: 20 72 65 74 75 72 6e 20 22 42 4c 4f 42 22 3b 0a   return "BLOB";.
2660: 20 20 20 20 20 20 20 20 20 20 64 65 66 61 75 6c            defaul
2670: 74 3a 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  t:.            r
2680: 65 74 75 72 6e 20 22 54 45 58 54 22 3b 0a 20 20  eturn "TEXT";.  
2690: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
26a0: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
26b0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
26c0: 20 43 6f 6c 75 6d 6e 49 6e 64 65 78 28 53 51 4c   ColumnIndex(SQL
26d0: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
26e0: 74 2c 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e  t, string column
26f0: 4e 61 6d 65 29 0a 20 20 20 20 7b 0a 20 20 20 20  Name).    {.    
2700: 20 20 69 6e 74 20 78 20 3d 20 43 6f 6c 75 6d 6e    int x = Column
2710: 43 6f 75 6e 74 28 73 74 6d 74 29 3b 0a 0a 20 20  Count(stmt);..  
2720: 20 20 20 20 66 6f 72 20 28 69 6e 74 20 6e 20 3d      for (int n =
2730: 20 30 3b 20 6e 20 3c 20 78 3b 20 6e 2b 2b 29 0a   0; n < x; n++).
2740: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
2750: 69 66 20 28 53 74 72 69 6e 67 2e 43 6f 6d 70 61  if (String.Compa
2760: 72 65 28 63 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 43  re(columnName, C
2770: 6f 6c 75 6d 6e 4e 61 6d 65 28 73 74 6d 74 2c 20  olumnName(stmt, 
2780: 6e 29 2c 20 74 72 75 65 2c 20 43 75 6c 74 75 72  n), true, Cultur
2790: 65 49 6e 66 6f 2e 43 75 72 72 65 6e 74 43 75 6c  eInfo.CurrentCul
27a0: 74 75 72 65 29 20 3d 3d 20 30 29 0a 20 20 20 20  ture) == 0).    
27b0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 3b 0a        return n;.
27c0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65        }.      re
27d0: 74 75 72 6e 20 2d 31 3b 0a 20 20 20 20 7d 0a 0a  turn -1;.    }..
27e0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
27f0: 72 72 69 64 65 20 64 6f 75 62 6c 65 20 47 65 74  rride double Get
2800: 44 6f 75 62 6c 65 28 53 51 4c 69 74 65 53 74 61  Double(SQLiteSta
2810: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
2820: 20 69 6e 64 65 78 29 0a 20 20 20 20 7b 0a 20 20   index).    {.  
2830: 20 20 20 20 64 6f 75 62 6c 65 20 76 61 6c 75 65      double value
2840: 3b 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  ;.      UnsafeNa
2850: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
2860: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 6f 75 62 6c  te3_column_doubl
2870: 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  e_interop(stmt._
2880: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
2890: 65 78 2c 20 6f 75 74 20 76 61 6c 75 65 29 3b 0a  ex, out value);.
28a0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 76 61 6c        return val
28b0: 75 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  ue;.    }..    i
28c0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
28d0: 20 69 6e 74 20 47 65 74 49 6e 74 33 32 28 53 51   int GetInt32(SQ
28e0: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
28f0: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20  mt, int index). 
2900: 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72     {.      retur
2910: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
2920: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
2930: 6c 75 6d 6e 5f 69 6e 74 5f 69 6e 74 65 72 6f 70  lumn_int_interop
2940: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
2950: 6d 74 2c 20 69 6e 64 65 78 29 3b 0a 20 20 20 20  mt, index);.    
2960: 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  }..    internal 
2970: 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47 65  override long Ge
2980: 74 49 6e 74 36 34 28 53 51 4c 69 74 65 53 74 61  tInt64(SQLiteSta
2990: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
29a0: 20 69 6e 64 65 78 29 0a 20 20 20 20 7b 0a 20 20   index).    {.  
29b0: 20 20 20 20 6c 6f 6e 67 20 76 61 6c 75 65 3b 0a      long value;.
29c0: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
29d0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
29e0: 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 5f 69  3_column_int64_i
29f0: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
2a00: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
2a10: 20 6f 75 74 20 76 61 6c 75 65 29 3b 0a 20 20 20   out value);.   
2a20: 20 20 20 72 65 74 75 72 6e 20 76 61 6c 75 65 3b     return value;
2a30: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
2a40: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74  rnal override st
2a50: 72 69 6e 67 20 47 65 74 54 65 78 74 28 53 51 4c  ring GetText(SQL
2a60: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
2a70: 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0a 20 20  t, int index).  
2a80: 20 20 7b 0a 20 20 20 20 20 20 69 6e 74 20 6c 65    {.      int le
2a90: 6e 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  n;.      return 
2aa0: 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e  ToString(UnsafeN
2ab0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
2ac0: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74  ite3_column_text
2ad0: 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73  _interop(stmt._s
2ae0: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
2af0: 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e  x, out len), len
2b00: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
2b10: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
2b20: 44 61 74 65 54 69 6d 65 20 47 65 74 44 61 74 65  DateTime GetDate
2b30: 54 69 6d 65 28 53 51 4c 69 74 65 53 74 61 74 65  Time(SQLiteState
2b40: 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69  ment stmt, int i
2b50: 6e 64 65 78 29 0a 20 20 20 20 7b 0a 20 20 20 20  ndex).    {.    
2b60: 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20 20    int len;.     
2b70: 20 72 65 74 75 72 6e 20 54 6f 44 61 74 65 54 69   return ToDateTi
2b80: 6d 65 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  me(UnsafeNativeM
2b90: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
2ba0: 6f 6c 75 6d 6e 5f 74 65 78 74 5f 69 6e 74 65 72  olumn_text_inter
2bb0: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
2bc0: 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74  stmt, index, out
2bd0: 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0a 20 20 20   len), len);.   
2be0: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
2bf0: 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47   override long G
2c00: 65 74 42 79 74 65 73 28 53 51 4c 69 74 65 53 74  etBytes(SQLiteSt
2c10: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
2c20: 74 20 69 6e 64 65 78 2c 20 69 6e 74 20 6e 44 61  t index, int nDa
2c30: 74 61 4f 66 66 73 65 74 2c 20 62 79 74 65 5b 5d  taOffset, byte[]
2c40: 20 62 44 65 73 74 2c 20 69 6e 74 20 6e 53 74 61   bDest, int nSta
2c50: 72 74 2c 20 69 6e 74 20 6e 4c 65 6e 67 74 68 29  rt, int nLength)
2c60: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 49 6e 74  .    {.      Int
2c70: 50 74 72 20 70 74 72 3b 0a 20 20 20 20 20 20 69  Ptr ptr;.      i
2c80: 6e 74 20 6e 6c 65 6e 3b 0a 20 20 20 20 20 20 69  nt nlen;.      i
2c90: 6e 74 20 6e 43 6f 70 69 65 64 20 3d 20 6e 4c 65  nt nCopied = nLe
2ca0: 6e 67 74 68 3b 0a 0a 20 20 20 20 20 20 6e 6c 65  ngth;..      nle
2cb0: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
2cc0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
2cd0: 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 5f 69 6e 74  column_bytes_int
2ce0: 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74  erop(stmt._sqlit
2cf0: 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0a  e_stmt, index);.
2d00: 20 20 20 20 20 20 70 74 72 20 3d 20 55 6e 73 61        ptr = Unsa
2d10: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
2d20: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62  sqlite3_column_b
2d30: 6c 6f 62 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74  lob_interop(stmt
2d40: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
2d50: 6e 64 65 78 29 3b 0a 0a 20 20 20 20 20 20 69 66  ndex);..      if
2d60: 20 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c 29   (bDest == null)
2d70: 20 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0a 0a 20   return nlen;.. 
2d80: 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64       if (nCopied
2d90: 20 2b 20 6e 53 74 61 72 74 20 3e 20 62 44 65 73   + nStart > bDes
2da0: 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f 70 69 65  t.Length) nCopie
2db0: 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e 67 74 68  d = bDest.Length
2dc0: 20 2d 20 6e 53 74 61 72 74 3b 0a 20 20 20 20 20   - nStart;.     
2dd0: 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b 20 6e   if (nCopied + n
2de0: 44 61 74 61 4f 66 66 73 65 74 20 3e 20 6e 6c 65  DataOffset > nle
2df0: 6e 29 20 6e 43 6f 70 69 65 64 20 3d 20 6e 6c 65  n) nCopied = nle
2e00: 6e 20 2d 20 6e 44 61 74 61 4f 66 66 73 65 74 3b  n - nDataOffset;
2e10: 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70  ..      if (nCop
2e20: 69 65 64 20 3e 20 30 29 0a 20 20 20 20 20 20 20  ied > 0).       
2e30: 20 4d 61 72 73 68 61 6c 2e 43 6f 70 79 28 28 49   Marshal.Copy((I
2e40: 6e 74 50 74 72 29 28 70 74 72 2e 54 6f 49 6e 74  ntPtr)(ptr.ToInt
2e50: 33 32 28 29 20 2b 20 6e 44 61 74 61 4f 66 66 73  32() + nDataOffs
2e60: 65 74 29 2c 20 62 44 65 73 74 2c 20 6e 53 74 61  et), bDest, nSta
2e70: 72 74 2c 20 6e 43 6f 70 69 65 64 29 3b 0a 20 20  rt, nCopied);.  
2e80: 20 20 20 20 65 6c 73 65 20 6e 43 6f 70 69 65 64      else nCopied
2e90: 20 3d 20 30 3b 0a 0a 20 20 20 20 20 20 72 65 74   = 0;..      ret
2ea0: 75 72 6e 20 6e 43 6f 70 69 65 64 3b 0a 20 20 20  urn nCopied;.   
2eb0: 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c   }..    internal
2ec0: 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47   override long G
2ed0: 65 74 43 68 61 72 73 28 53 51 4c 69 74 65 53 74  etChars(SQLiteSt
2ee0: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
2ef0: 74 20 69 6e 64 65 78 2c 20 69 6e 74 20 6e 44 61  t index, int nDa
2f00: 74 61 4f 66 66 73 65 74 2c 20 63 68 61 72 5b 5d  taOffset, char[]
2f10: 20 62 44 65 73 74 2c 20 69 6e 74 20 6e 53 74 61   bDest, int nSta
2f20: 72 74 2c 20 69 6e 74 20 6e 4c 65 6e 67 74 68 29  rt, int nLength)
2f30: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 69 6e 74  .    {.      int
2f40: 20 6e 6c 65 6e 3b 0a 20 20 20 20 20 20 69 6e 74   nlen;.      int
2f50: 20 6e 43 6f 70 69 65 64 20 3d 20 6e 4c 65 6e 67   nCopied = nLeng
2f60: 74 68 3b 0a 0a 20 20 20 20 20 20 73 74 72 69 6e  th;..      strin
2f70: 67 20 73 74 72 20 3d 20 47 65 74 54 65 78 74 28  g str = GetText(
2f80: 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0a 20 20  stmt, index);.  
2f90: 20 20 20 20 6e 6c 65 6e 20 3d 20 73 74 72 2e 4c      nlen = str.L
2fa0: 65 6e 67 74 68 3b 0a 0a 20 20 20 20 20 20 69 66  ength;..      if
2fb0: 20 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c 29   (bDest == null)
2fc0: 20 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0a 0a 20   return nlen;.. 
2fd0: 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64       if (nCopied
2fe0: 20 2b 20 6e 53 74 61 72 74 20 3e 20 62 44 65 73   + nStart > bDes
2ff0: 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f 70 69 65  t.Length) nCopie
3000: 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e 67 74 68  d = bDest.Length
3010: 20 2d 20 6e 53 74 61 72 74 3b 0a 20 20 20 20 20   - nStart;.     
3020: 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b 20 6e   if (nCopied + n
3030: 44 61 74 61 4f 66 66 73 65 74 20 3e 20 6e 6c 65  DataOffset > nle
3040: 6e 29 20 6e 43 6f 70 69 65 64 20 3d 20 6e 6c 65  n) nCopied = nle
3050: 6e 20 2d 20 6e 44 61 74 61 4f 66 66 73 65 74 3b  n - nDataOffset;
3060: 0a 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70  ..      if (nCop
3070: 69 65 64 20 3e 20 30 29 0a 20 20 20 20 20 20 20  ied > 0).       
3080: 20 73 74 72 2e 43 6f 70 79 54 6f 28 6e 44 61 74   str.CopyTo(nDat
3090: 61 4f 66 66 73 65 74 2c 20 62 44 65 73 74 2c 20  aOffset, bDest, 
30a0: 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69 65 64 29  nStart, nCopied)
30b0: 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 6e 43 6f  ;.      else nCo
30c0: 70 69 65 64 20 3d 20 30 3b 0a 0a 20 20 20 20 20  pied = 0;..     
30d0: 20 72 65 74 75 72 6e 20 6e 43 6f 70 69 65 64 3b   return nCopied;
30e0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65  .    }..    inte
30f0: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 62 6f  rnal override bo
3100: 6f 6c 20 49 73 4e 75 6c 6c 28 53 51 4c 69 74 65  ol IsNull(SQLite
3110: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
3120: 69 6e 74 20 69 6e 64 65 78 29 0a 20 20 20 20 7b  int index).    {
3130: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 28 55  .      return (U
3140: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
3150: 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  ds.sqlite3_colum
3160: 6e 5f 74 79 70 65 5f 69 6e 74 65 72 6f 70 28 73  n_type_interop(s
3170: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
3180: 2c 20 69 6e 64 65 78 29 20 3d 3d 20 54 79 70 65  , index) == Type
3190: 41 66 66 69 6e 69 74 79 2e 4e 75 6c 6c 29 3b 0a  Affinity.Null);.
31a0: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
31b0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
31c0: 20 41 67 67 72 65 67 61 74 65 43 6f 75 6e 74 28   AggregateCount(
31d0: 69 6e 74 20 63 6f 6e 74 65 78 74 29 0a 20 20 20  int context).   
31e0: 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20   {.      return 
31f0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3200: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 61 67 67 72  ods.sqlite3_aggr
3210: 65 67 61 74 65 5f 63 6f 75 6e 74 5f 69 6e 74 65  egate_count_inte
3220: 72 6f 70 28 63 6f 6e 74 65 78 74 29 3b 0a 20 20  rop(context);.  
3230: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
3240: 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 43  l override int C
3250: 72 65 61 74 65 46 75 6e 63 74 69 6f 6e 28 73 74  reateFunction(st
3260: 72 69 6e 67 20 73 74 72 46 75 6e 63 74 69 6f 6e  ring strFunction
3270: 2c 20 69 6e 74 20 6e 41 72 67 73 2c 20 53 51 4c  , int nArgs, SQL
3280: 69 74 65 43 61 6c 6c 62 61 63 6b 20 66 75 6e 63  iteCallback func
3290: 2c 20 53 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b  , SQLiteCallback
32a0: 20 66 75 6e 63 73 74 65 70 2c 20 53 51 4c 69 74   funcstep, SQLit
32b0: 65 43 61 6c 6c 62 61 63 6b 20 66 75 6e 63 66 69  eCallback funcfi
32c0: 6e 61 6c 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  nal).    {.     
32d0: 20 69 6e 74 20 6e 43 6f 6f 6b 69 65 3b 0a 0a 20   int nCookie;.. 
32e0: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73       int n = Uns
32f0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
3300: 2e 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f  .sqlite3_create_
3310: 66 75 6e 63 74 69 6f 6e 5f 69 6e 74 65 72 6f 70  function_interop
3320: 28 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 73 74  (_sql, ToUTF8(st
3330: 72 46 75 6e 63 74 69 6f 6e 29 2c 20 6e 41 72 67  rFunction), nArg
3340: 73 2c 20 31 2c 20 66 75 6e 63 2c 20 66 75 6e 63  s, 1, func, func
3350: 73 74 65 70 2c 20 66 75 6e 63 66 69 6e 61 6c 2c  step, funcfinal,
3360: 20 6f 75 74 20 6e 43 6f 6f 6b 69 65 29 3b 0a 20   out nCookie);. 
3370: 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20       if (n > 0) 
3380: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
3390: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 53 51 4c  Exception(n, SQL
33a0: 69 74 65 4c 61 73 74 45 72 72 6f 72 28 29 29 3b  iteLastError());
33b0: 0a 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e  ..      return n
33c0: 43 6f 6f 6b 69 65 3b 0a 20 20 20 20 7d 0a 0a 20  Cookie;.    }.. 
33d0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
33e0: 72 69 64 65 20 69 6e 74 20 43 72 65 61 74 65 43  ride int CreateC
33f0: 6f 6c 6c 61 74 69 6f 6e 28 73 74 72 69 6e 67 20  ollation(string 
3400: 73 74 72 43 6f 6c 6c 61 74 69 6f 6e 2c 20 53 51  strCollation, SQ
3410: 4c 69 74 65 43 6f 6c 6c 61 74 69 6f 6e 20 66 75  LiteCollation fu
3420: 6e 63 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  nc).    {.      
3430: 69 6e 74 20 6e 43 6f 6f 6b 69 65 3b 0a 0a 20 20  int nCookie;..  
3440: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
3450: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
3460: 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 63  sqlite3_create_c
3470: 6f 6c 6c 61 74 69 6f 6e 5f 69 6e 74 65 72 6f 70  ollation_interop
3480: 28 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 73 74  (_sql, ToUTF8(st
3490: 72 43 6f 6c 6c 61 74 69 6f 6e 29 2c 20 31 2c 20  rCollation), 1, 
34a0: 30 2c 20 66 75 6e 63 2c 20 6f 75 74 20 6e 43 6f  0, func, out nCo
34b0: 6f 6b 69 65 29 3b 0a 20 20 20 20 20 20 69 66 20  okie);.      if 
34c0: 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65  (n > 0) throw ne
34d0: 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  w SQLiteExceptio
34e0: 6e 28 6e 2c 20 53 51 4c 69 74 65 4c 61 73 74 45  n(n, SQLiteLastE
34f0: 72 72 6f 72 28 29 29 3b 0a 0a 20 20 20 20 20 20  rror());..      
3500: 72 65 74 75 72 6e 20 6e 43 6f 6f 6b 69 65 3b 0a  return nCookie;.
3510: 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72      }..    inter
3520: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
3530: 64 20 46 72 65 65 46 75 6e 63 74 69 6f 6e 28 69  d FreeFunction(i
3540: 6e 74 20 6e 43 6f 6f 6b 69 65 29 0a 20 20 20 20  nt nCookie).    
3550: 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  {.      UnsafeNa
3560: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
3570: 74 65 33 5f 66 75 6e 63 74 69 6f 6e 5f 66 72 65  te3_function_fre
3580: 65 5f 63 61 6c 6c 62 61 63 6b 63 6f 6f 6b 69 65  e_callbackcookie
3590: 28 6e 43 6f 6f 6b 69 65 29 3b 0a 20 20 20 20 7d  (nCookie);.    }
35a0: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
35b0: 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47 65 74  verride long Get
35c0: 50 61 72 61 6d 56 61 6c 75 65 42 79 74 65 73 28  ParamValueBytes(
35d0: 69 6e 74 20 70 2c 20 69 6e 74 20 6e 44 61 74 61  int p, int nData
35e0: 4f 66 66 73 65 74 2c 20 62 79 74 65 5b 5d 20 62  Offset, byte[] b
35f0: 44 65 73 74 2c 20 69 6e 74 20 6e 53 74 61 72 74  Dest, int nStart
3600: 2c 20 69 6e 74 20 6e 4c 65 6e 67 74 68 29 0a 20  , int nLength). 
3610: 20 20 20 7b 0a 20 20 20 20 20 20 49 6e 74 50 74     {.      IntPt
3620: 72 20 70 74 72 3b 0a 20 20 20 20 20 20 69 6e 74  r ptr;.      int
3630: 20 6e 6c 65 6e 3b 0a 20 20 20 20 20 20 69 6e 74   nlen;.      int
3640: 20 6e 43 6f 70 69 65 64 20 3d 20 6e 4c 65 6e 67   nCopied = nLeng
3650: 74 68 3b 0a 0a 20 20 20 20 20 20 6e 6c 65 6e 20  th;..      nlen 
3660: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
3670: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
3680: 6c 75 65 5f 62 79 74 65 73 5f 69 6e 74 65 72 6f  lue_bytes_intero
3690: 70 28 70 29 3b 0a 20 20 20 20 20 20 70 74 72 20  p(p);.      ptr 
36a0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
36b0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
36c0: 6c 75 65 5f 62 6c 6f 62 5f 69 6e 74 65 72 6f 70  lue_blob_interop
36d0: 28 70 29 3b 0a 0a 20 20 20 20 20 20 69 66 20 28  (p);..      if (
36e0: 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c 29 20 72  bDest == null) r
36f0: 65 74 75 72 6e 20 6e 6c 65 6e 3b 0a 0a 20 20 20  eturn nlen;..   
3700: 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b     if (nCopied +
3710: 20 6e 53 74 61 72 74 20 3e 20 62 44 65 73 74 2e   nStart > bDest.
3720: 4c 65 6e 67 74 68 29 20 6e 43 6f 70 69 65 64 20  Length) nCopied 
3730: 3d 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 20 2d  = bDest.Length -
3740: 20 6e 53 74 61 72 74 3b 0a 20 20 20 20 20 20 69   nStart;.      i
3750: 66 20 28 6e 43 6f 70 69 65 64 20 2b 20 6e 44 61  f (nCopied + nDa
3760: 74 61 4f 66 66 73 65 74 20 3e 20 6e 6c 65 6e 29  taOffset > nlen)
3770: 20 6e 43 6f 70 69 65 64 20 3d 20 6e 6c 65 6e 20   nCopied = nlen 
3780: 2d 20 6e 44 61 74 61 4f 66 66 73 65 74 3b 0a 0a  - nDataOffset;..
3790: 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65        if (nCopie
37a0: 64 20 3e 20 30 29 0a 20 20 20 20 20 20 20 20 4d  d > 0).        M
37b0: 61 72 73 68 61 6c 2e 43 6f 70 79 28 28 49 6e 74  arshal.Copy((Int
37c0: 50 74 72 29 28 70 74 72 2e 54 6f 49 6e 74 33 32  Ptr)(ptr.ToInt32
37d0: 28 29 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74  () + nDataOffset
37e0: 29 2c 20 62 44 65 73 74 2c 20 6e 53 74 61 72 74  ), bDest, nStart
37f0: 2c 20 6e 43 6f 70 69 65 64 29 3b 0a 20 20 20 20  , nCopied);.    
3800: 20 20 65 6c 73 65 20 6e 43 6f 70 69 65 64 20 3d    else nCopied =
3810: 20 30 3b 0a 0a 20 20 20 20 20 20 72 65 74 75 72   0;..      retur
3820: 6e 20 6e 43 6f 70 69 65 64 3b 0a 20 20 20 20 7d  n nCopied;.    }
3830: 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
3840: 76 65 72 72 69 64 65 20 64 6f 75 62 6c 65 20 47  verride double G
3850: 65 74 50 61 72 61 6d 56 61 6c 75 65 44 6f 75 62  etParamValueDoub
3860: 6c 65 28 69 6e 74 20 70 74 72 29 0a 20 20 20 20  le(int ptr).    
3870: 7b 0a 20 20 20 20 20 20 64 6f 75 62 6c 65 20 76  {.      double v
3880: 61 6c 75 65 3b 0a 20 20 20 20 20 20 55 6e 73 61  alue;.      Unsa
3890: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
38a0: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 64 6f  sqlite3_value_do
38b0: 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 70 74 72  uble_interop(ptr
38c0: 2c 20 6f 75 74 20 76 61 6c 75 65 29 3b 0a 20 20  , out value);.  
38d0: 20 20 20 20 72 65 74 75 72 6e 20 76 61 6c 75 65      return value
38e0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74  ;.    }..    int
38f0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69  ernal override i
3900: 6e 74 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65  nt GetParamValue
3910: 49 6e 74 33 32 28 69 6e 74 20 70 74 72 29 0a 20  Int32(int ptr). 
3920: 20 20 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72     {.      retur
3930: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
3940: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
3950: 6c 75 65 5f 69 6e 74 5f 69 6e 74 65 72 6f 70 28  lue_int_interop(
3960: 70 74 72 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  ptr);.    }..   
3970: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
3980: 64 65 20 6c 6f 6e 67 20 47 65 74 50 61 72 61 6d  de long GetParam
3990: 56 61 6c 75 65 49 6e 74 36 34 28 69 6e 74 20 70  ValueInt64(int p
39a0: 74 72 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  tr).    {.      
39b0: 49 6e 74 36 34 20 76 61 6c 75 65 3b 0a 20 20 20  Int64 value;.   
39c0: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
39d0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76  ethods.sqlite3_v
39e0: 61 6c 75 65 5f 69 6e 74 36 34 5f 69 6e 74 65 72  alue_int64_inter
39f0: 6f 70 28 70 74 72 2c 20 6f 75 74 20 76 61 6c 75  op(ptr, out valu
3a00: 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  e);.      return
3a10: 20 76 61 6c 75 65 3b 0a 20 20 20 20 7d 0a 0a 20   value;.    }.. 
3a20: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
3a30: 72 69 64 65 20 73 74 72 69 6e 67 20 47 65 74 50  ride string GetP
3a40: 61 72 61 6d 56 61 6c 75 65 54 65 78 74 28 69 6e  aramValueText(in
3a50: 74 20 70 74 72 29 0a 20 20 20 20 7b 0a 20 20 20  t ptr).    {.   
3a60: 20 20 20 69 6e 74 20 6c 65 6e 3b 0a 20 20 20 20     int len;.    
3a70: 20 20 72 65 74 75 72 6e 20 54 6f 53 74 72 69 6e    return ToStrin
3a80: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
3a90: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
3aa0: 6c 75 65 5f 74 65 78 74 5f 69 6e 74 65 72 6f 70  lue_text_interop
3ab0: 28 70 74 72 2c 20 6f 75 74 20 6c 65 6e 29 2c 20  (ptr, out len), 
3ac0: 6c 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  len);.    }..   
3ad0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
3ae0: 64 65 20 54 79 70 65 41 66 66 69 6e 69 74 79 20  de TypeAffinity 
3af0: 47 65 74 50 61 72 61 6d 56 61 6c 75 65 54 79 70  GetParamValueTyp
3b00: 65 28 69 6e 74 20 70 74 72 29 0a 20 20 20 20 7b  e(int ptr).    {
3b10: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e  .      return Un
3b20: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
3b30: 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f  s.sqlite3_value_
3b40: 74 79 70 65 5f 69 6e 74 65 72 6f 70 28 70 74 72  type_interop(ptr
3b50: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
3b60: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
3b70: 76 6f 69 64 20 52 65 74 75 72 6e 42 6c 6f 62 28  void ReturnBlob(
3b80: 69 6e 74 20 63 6f 6e 74 65 78 74 2c 20 62 79 74  int context, byt
3b90: 65 5b 5d 20 76 61 6c 75 65 29 0a 20 20 20 20 7b  e[] value).    {
3ba0: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
3bb0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
3bc0: 65 33 5f 72 65 73 75 6c 74 5f 62 6c 6f 62 5f 69  e3_result_blob_i
3bd0: 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20  nterop(context, 
3be0: 76 61 6c 75 65 2c 20 76 61 6c 75 65 2e 4c 65 6e  value, value.Len
3bf0: 67 74 68 2c 20 2d 31 29 3b 0a 20 20 20 20 7d 0a  gth, -1);.    }.
3c00: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
3c10: 65 72 72 69 64 65 20 76 6f 69 64 20 52 65 74 75  erride void Retu
3c20: 72 6e 44 6f 75 62 6c 65 28 69 6e 74 20 63 6f 6e  rnDouble(int con
3c30: 74 65 78 74 2c 20 64 6f 75 62 6c 65 20 76 61 6c  text, double val
3c40: 75 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  ue).    {.      
3c50: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
3c60: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75  ods.sqlite3_resu
3c70: 6c 74 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f  lt_double_intero
3c80: 70 28 63 6f 6e 74 65 78 74 2c 20 72 65 66 20 76  p(context, ref v
3c90: 61 6c 75 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  alue);.    }..  
3ca0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
3cb0: 69 64 65 20 76 6f 69 64 20 52 65 74 75 72 6e 45  ide void ReturnE
3cc0: 72 72 6f 72 28 69 6e 74 20 63 6f 6e 74 65 78 74  rror(int context
3cd0: 2c 20 73 74 72 69 6e 67 20 76 61 6c 75 65 29 0a  , string value).
3ce0: 20 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61      {.      Unsa
3cf0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
3d00: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 65  sqlite3_result_e
3d10: 72 72 6f 72 5f 69 6e 74 65 72 6f 70 28 63 6f 6e  rror_interop(con
3d20: 74 65 78 74 2c 20 54 6f 55 54 46 38 28 76 61 6c  text, ToUTF8(val
3d30: 75 65 29 2c 20 76 61 6c 75 65 2e 4c 65 6e 67 74  ue), value.Lengt
3d40: 68 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69  h);.    }..    i
3d50: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
3d60: 20 76 6f 69 64 20 52 65 74 75 72 6e 49 6e 74 33   void ReturnInt3
3d70: 32 28 69 6e 74 20 63 6f 6e 74 65 78 74 2c 20 69  2(int context, i
3d80: 6e 74 20 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a  nt value).    {.
3d90: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
3da0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
3db0: 33 5f 72 65 73 75 6c 74 5f 69 6e 74 5f 69 6e 74  3_result_int_int
3dc0: 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20 76 61  erop(context, va
3dd0: 6c 75 65 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  lue);.    }..   
3de0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
3df0: 64 65 20 76 6f 69 64 20 52 65 74 75 72 6e 49 6e  de void ReturnIn
3e00: 74 36 34 28 69 6e 74 20 63 6f 6e 74 65 78 74 2c  t64(int context,
3e10: 20 6c 6f 6e 67 20 76 61 6c 75 65 29 0a 20 20 20   long value).   
3e20: 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e   {.      UnsafeN
3e30: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
3e40: 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36  ite3_result_int6
3e50: 34 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78  4_interop(contex
3e60: 74 2c 20 72 65 66 20 76 61 6c 75 65 29 3b 0a 20  t, ref value);. 
3e70: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
3e80: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
3e90: 20 52 65 74 75 72 6e 4e 75 6c 6c 28 69 6e 74 20   ReturnNull(int 
3ea0: 63 6f 6e 74 65 78 74 29 0a 20 20 20 20 7b 0a 20  context).    {. 
3eb0: 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76       UnsafeNativ
3ec0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
3ed0: 5f 72 65 73 75 6c 74 5f 6e 75 6c 6c 5f 69 6e 74  _result_null_int
3ee0: 65 72 6f 70 28 63 6f 6e 74 65 78 74 29 3b 0a 20  erop(context);. 
3ef0: 20 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e     }..    intern
3f00: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
3f10: 20 52 65 74 75 72 6e 54 65 78 74 28 69 6e 74 20   ReturnText(int 
3f20: 63 6f 6e 74 65 78 74 2c 20 73 74 72 69 6e 67 20  context, string 
3f30: 76 61 6c 75 65 29 0a 20 20 20 20 7b 0a 20 20 20  value).    {.   
3f40: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
3f50: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72  ethods.sqlite3_r
3f60: 65 73 75 6c 74 5f 74 65 78 74 5f 69 6e 74 65 72  esult_text_inter
3f70: 6f 70 28 63 6f 6e 74 65 78 74 2c 20 54 6f 55 54  op(context, ToUT
3f80: 46 38 28 76 61 6c 75 65 29 2c 20 76 61 6c 75 65  F8(value), value
3f90: 2e 4c 65 6e 67 74 68 2c 20 2d 31 29 3b 0a 20 20  .Length, -1);.  
3fa0: 20 20 7d 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61    }..    interna
3fb0: 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 41  l override int A
3fc0: 67 67 72 65 67 61 74 65 43 6f 6e 74 65 78 74 28  ggregateContext(
3fd0: 69 6e 74 20 63 6f 6e 74 65 78 74 29 0a 20 20 20  int context).   
3fe0: 20 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20   {.      return 
3ff0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
4000: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 61 67 67 72  ods.sqlite3_aggr
4010: 65 67 61 74 65 5f 63 6f 6e 74 65 78 74 5f 69 6e  egate_context_in
4020: 74 65 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20 31  terop(context, 1
4030: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 6e  );.    }..    in
4040: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
4050: 76 6f 69 64 20 53 65 74 52 65 61 6c 43 6f 6c 4e  void SetRealColN
4060: 61 6d 65 73 28 62 6f 6f 6c 20 62 4f 6e 29 0a 20  ames(bool bOn). 
4070: 20 20 20 7b 0a 20 20 20 20 20 20 55 6e 73 61 66     {.      Unsaf
4080: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
4090: 71 6c 69 74 65 33 5f 72 65 61 6c 63 6f 6c 6e 61  qlite3_realcolna
40a0: 6d 65 73 28 5f 73 71 6c 2c 20 43 6f 6e 76 65 72  mes(_sql, Conver
40b0: 74 2e 54 6f 49 6e 74 33 32 28 62 4f 6e 29 29 3b  t.ToInt32(bOn));
40c0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a           .    }.  }.}.