System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 0fd031aaa5c53e3a24c0ce78c149d0907b98c3b0:


0000: ef bb bf 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .../************
0010: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0020: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0030: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0d 0a 20 2a  ************.. *
0040: 20 41 44 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74   ADO.NET 2.0 Dat
0050: 61 20 50 72 6f 76 69 64 65 72 20 66 6f 72 20 53  a Provider for S
0060: 51 4c 69 74 65 20 56 65 72 73 69 6f 6e 20 33 2e  QLite Version 3.
0070: 58 0d 0a 20 2a 20 57 72 69 74 74 65 6e 20 62 79  X.. * Written by
0080: 20 52 6f 62 65 72 74 20 53 69 6d 70 73 6f 6e 20   Robert Simpson 
0090: 28 72 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73  (robert@blackcas
00a0: 74 6c 65 73 6f 66 74 2e 63 6f 6d 29 0d 0a 20 2a  tlesoft.com).. *
00b0: 20 0d 0a 20 2a 20 52 65 6c 65 61 73 65 64 20 74   .. * Released t
00c0: 6f 20 74 68 65 20 70 75 62 6c 69 63 20 64 6f 6d  o the public dom
00d0: 61 69 6e 2c 20 75 73 65 20 61 74 20 79 6f 75 72  ain, use at your
00e0: 20 6f 77 6e 20 72 69 73 6b 21 0d 0a 20 2a 2a 2a   own risk!.. ***
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 2a 2a 2a 2a 2f 0d 0a 0d 0a 6e 61 6d 65 73 70  *****/....namesp
0130: 61 63 65 20 53 79 73 74 65 6d 2e 44 61 74 61 2e  ace System.Data.
0140: 53 51 4c 69 74 65 0d 0a 7b 0d 0a 20 20 75 73 69  SQLite..{..  usi
0150: 6e 67 20 53 79 73 74 65 6d 3b 0d 0a 20 20 75 73  ng System;..  us
0160: 69 6e 67 20 53 79 73 74 65 6d 2e 43 6f 6c 6c 65  ing System.Colle
0170: 63 74 69 6f 6e 73 2e 47 65 6e 65 72 69 63 3b 0d  ctions.Generic;.
0180: 0a 23 69 66 20 44 45 42 55 47 0d 0a 20 20 75 73  .#if DEBUG..  us
0190: 69 6e 67 20 53 79 73 74 65 6d 2e 44 69 61 67 6e  ing System.Diagn
01a0: 6f 73 74 69 63 73 3b 0d 0a 23 65 6e 64 69 66 0d  ostics;..#endif.
01b0: 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e  .  using System.
01c0: 52 75 6e 74 69 6d 65 2e 49 6e 74 65 72 6f 70 53  Runtime.InteropS
01d0: 65 72 76 69 63 65 73 3b 0d 0a 20 20 75 73 69 6e  ervices;..  usin
01e0: 67 20 53 79 73 74 65 6d 2e 54 65 78 74 3b 0d 0a  g System.Text;..
01f0: 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f  ..#if !PLATFORM_
0200: 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b  COMPACTFRAMEWORK
0210: 0d 0a 20 20 5b 55 6e 6d 61 6e 61 67 65 64 46 75  ..  [UnmanagedFu
0220: 6e 63 74 69 6f 6e 50 6f 69 6e 74 65 72 28 43 61  nctionPointer(Ca
0230: 6c 6c 69 6e 67 43 6f 6e 76 65 6e 74 69 6f 6e 2e  llingConvention.
0240: 43 64 65 63 6c 29 5d 0d 0a 23 65 6e 64 69 66 0d  Cdecl)]..#endif.
0250: 0a 20 20 69 6e 74 65 72 6e 61 6c 20 64 65 6c 65  .  internal dele
0260: 67 61 74 65 20 76 6f 69 64 20 53 51 4c 69 74 65  gate void SQLite
0270: 4c 6f 67 43 61 6c 6c 62 61 63 6b 28 49 6e 74 50  LogCallback(IntP
0280: 74 72 20 70 75 73 65 72 2c 20 69 6e 74 20 65 72  tr puser, int er
0290: 72 5f 63 6f 64 65 2c 20 49 6e 74 50 74 72 20 6d  r_code, IntPtr m
02a0: 65 73 73 61 67 65 29 3b 0d 0a 0d 0a 20 20 2f 2f  essage);....  //
02b0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f  / <summary>..  /
02c0: 2f 2f 20 54 68 69 73 20 63 6c 61 73 73 20 69 6d  // This class im
02d0: 70 6c 65 6d 65 6e 74 73 20 53 51 4c 69 74 65 42  plements SQLiteB
02e0: 61 73 65 20 63 6f 6d 70 6c 65 74 65 6c 79 2c 20  ase completely, 
02f0: 61 6e 64 20 69 73 20 74 68 65 20 67 75 74 73 20  and is the guts 
0300: 6f 66 20 74 68 65 20 63 6f 64 65 20 74 68 61 74  of the code that
0310: 20 69 6e 74 65 72 6f 70 27 73 20 53 51 4c 69 74   interop's SQLit
0320: 65 20 77 69 74 68 20 2e 4e 45 54 0d 0a 20 20 2f  e with .NET..  /
0330: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
0340: 20 69 6e 74 65 72 6e 61 6c 20 63 6c 61 73 73 20   internal class 
0350: 53 51 4c 69 74 65 33 20 3a 20 53 51 4c 69 74 65  SQLite3 : SQLite
0360: 42 61 73 65 0d 0a 20 20 7b 0d 0a 20 20 20 20 70  Base..  {..    p
0370: 72 69 76 61 74 65 20 73 74 61 74 69 63 20 6f 62  rivate static ob
0380: 6a 65 63 74 20 73 79 6e 63 52 6f 6f 74 20 3d 20  ject syncRoot = 
0390: 6e 65 77 20 6f 62 6a 65 63 74 28 29 3b 0d 0a 0d  new object();...
03a0: 0a 20 20 20 20 2f 2f 0d 0a 20 20 20 20 2f 2f 20  .    //..    // 
03b0: 4e 4f 54 45 3a 20 54 68 69 73 20 69 73 20 74 68  NOTE: This is th
03c0: 65 20 70 75 62 6c 69 63 20 6b 65 79 20 66 6f 72  e public key for
03d0: 20 74 68 65 20 53 79 73 74 65 6d 2e 44 61 74 61   the System.Data
03e0: 2e 53 51 4c 69 74 65 20 61 73 73 65 6d 62 6c 79  .SQLite assembly
03f0: 2e 20 20 49 66 20 79 6f 75 20 63 68 61 6e 67 65  .  If you change
0400: 20 74 68 65 0d 0a 20 20 20 20 2f 2f 20 20 20 20   the..    //    
0410: 20 20 20 53 4e 4b 20 66 69 6c 65 2c 20 79 6f 75     SNK file, you
0420: 20 77 69 6c 6c 20 6e 65 65 64 20 74 6f 20 63 68   will need to ch
0430: 61 6e 67 65 20 74 68 69 73 20 61 73 20 77 65 6c  ange this as wel
0440: 6c 2e 0d 0a 20 20 20 20 2f 2f 0d 0a 20 20 20 20  l...    //..    
0450: 69 6e 74 65 72 6e 61 6c 20 63 6f 6e 73 74 20 73  internal const s
0460: 74 72 69 6e 67 20 50 75 62 6c 69 63 4b 65 79 20  tring PublicKey 
0470: 3d 0d 0a 20 20 20 20 20 20 20 20 22 30 30 32 34  =..        "0024
0480: 30 30 30 30 30 34 38 30 30 30 30 30 39 34 30 30  0000048000009400
0490: 30 30 30 30 30 36 30 32 30 30 30 30 30 30 32 34  0000060200000024
04a0: 30 30 30 30 35 32 35 33 34 31 33 31 30 30 30 34  0000525341310004
04b0: 30 30 30 30 30 31 30 30 30 31 30 30 30 35 61 32  00000100010005a2
04c0: 38 38 64 65 35 36 38 37 63 34 65 31 22 20 2b 0d  88de5687c4e1" +.
04d0: 0a 20 20 20 20 20 20 20 20 22 62 36 32 31 64 64  .        "b621dd
04e0: 66 66 35 64 38 34 34 37 32 37 34 31 38 39 35 36  ff5d844727418956
04f0: 39 39 37 66 34 37 35 65 62 38 32 39 34 32 39 65  997f475eb829429e
0500: 34 31 31 61 66 66 33 65 39 33 66 39 37 62 37 30  411aff3e93f97b70
0510: 64 65 36 39 38 62 39 37 32 36 34 30 39 32 35 62  de698b972640925b
0520: 64 64 34 34 32 38 30 64 66 30 22 20 2b 0d 0a 20  dd44280df0" +.. 
0530: 20 20 20 20 20 20 20 22 61 32 35 61 38 34 33 32         "a25a8432
0540: 36 36 39 37 33 37 30 34 31 33 37 63 62 62 30 65  66973704137cbb0e
0550: 37 34 34 31 63 31 66 65 37 63 61 65 34 65 32 34  7441c1fe7cae4e24
0560: 34 30 61 65 39 31 61 62 38 63 64 65 33 39 33 33  40ae91ab8cde3933
0570: 66 65 62 63 62 31 61 63 34 38 64 64 33 33 62 34  febcb1ac48dd33b4
0580: 30 65 31 33 63 34 32 31 22 20 2b 0d 0a 20 20 20  0e13c421" +..   
0590: 20 20 20 20 20 22 64 38 32 31 35 63 31 38 61 34       "d8215c18a4
05a0: 33 34 39 61 34 33 36 64 64 34 39 39 65 33 63 33  349a436dd499e3c3
05b0: 38 35 63 63 36 38 33 30 31 35 66 38 38 36 66 36  85cc683015f886f6
05c0: 63 31 30 62 64 39 30 31 31 35 65 62 32 62 64 36  c10bd90115eb2bd6
05d0: 31 62 36 37 37 35 30 38 33 39 65 33 61 31 39 39  1b67750839e3a199
05e0: 34 31 64 63 39 63 22 3b 0d 0a 0d 0a 23 69 66 20  41dc9c";....#if 
05f0: 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43  !PLATFORM_COMPAC
0600: 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20  TFRAMEWORK..    
0610: 69 6e 74 65 72 6e 61 6c 20 63 6f 6e 73 74 20 73  internal const s
0620: 74 72 69 6e 67 20 44 65 73 69 67 6e 65 72 56 65  tring DesignerVe
0630: 72 73 69 6f 6e 20 3d 20 22 31 2e 30 2e 38 31 2e  rsion = "1.0.81.
0640: 30 22 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20  0";..#endif.... 
0650: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
0660: 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 6f 70  ..    /// The op
0670: 61 71 75 65 20 70 6f 69 6e 74 65 72 20 72 65 74  aque pointer ret
0680: 75 72 6e 65 64 20 74 6f 20 75 73 20 62 79 20 74  urned to us by t
0690: 68 65 20 73 71 6c 69 74 65 20 70 72 6f 76 69 64  he sqlite provid
06a0: 65 72 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  er..    /// </su
06b0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72 6f 74  mmary>..    prot
06c0: 65 63 74 65 64 20 53 51 4c 69 74 65 43 6f 6e 6e  ected SQLiteConn
06d0: 65 63 74 69 6f 6e 48 61 6e 64 6c 65 20 5f 73 71  ectionHandle _sq
06e0: 6c 3b 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65  l;..    protecte
06f0: 64 20 73 74 72 69 6e 67 20 5f 66 69 6c 65 4e 61  d string _fileNa
0700: 6d 65 3b 0d 0a 20 20 20 20 70 72 6f 74 65 63 74  me;..    protect
0710: 65 64 20 62 6f 6f 6c 20 5f 75 73 65 50 6f 6f 6c  ed bool _usePool
0720: 3b 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64  ;..    protected
0730: 20 69 6e 74 20 5f 70 6f 6f 6c 56 65 72 73 69 6f   int _poolVersio
0740: 6e 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46  n;....#if !PLATF
0750: 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45  ORM_COMPACTFRAME
0760: 57 4f 52 4b 0d 0a 20 20 20 20 70 72 69 76 61 74  WORK..    privat
0770: 65 20 62 6f 6f 6c 20 5f 62 75 69 6c 64 69 6e 67  e bool _building
0780: 53 63 68 65 6d 61 3b 0d 0a 23 65 6e 64 69 66 0d  Schema;..#endif.
0790: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
07a0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20  y>..    /// The 
07b0: 75 73 65 72 2d 64 65 66 69 6e 65 64 20 66 75 6e  user-defined fun
07c0: 63 74 69 6f 6e 73 20 72 65 67 69 73 74 65 72 65  ctions registere
07d0: 64 20 6f 6e 20 74 68 69 73 20 63 6f 6e 6e 65 63  d on this connec
07e0: 74 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  tion..    /// </
07f0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72  summary>..    pr
0800: 6f 74 65 63 74 65 64 20 53 51 4c 69 74 65 46 75  otected SQLiteFu
0810: 6e 63 74 69 6f 6e 5b 5d 20 5f 66 75 6e 63 74 69  nction[] _functi
0820: 6f 6e 73 41 72 72 61 79 3b 0d 0a 0d 0a 20 20 20  onsArray;....   
0830: 20 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74 65   internal SQLite
0840: 33 28 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d  3(SQLiteDateForm
0850: 61 74 73 20 66 6d 74 2c 20 44 61 74 65 54 69 6d  ats fmt, DateTim
0860: 65 4b 69 6e 64 20 6b 69 6e 64 29 0d 0a 20 20 20  eKind kind)..   
0870: 20 20 20 3a 20 62 61 73 65 28 66 6d 74 2c 20 6b     : base(fmt, k
0880: 69 6e 64 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  ind)..    {..   
0890: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f 2f 2f   }....    //////
08a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20  /////////....   
0900: 20 23 72 65 67 69 6f 6e 20 49 44 69 73 70 6f 73   #region IDispos
0910: 61 62 6c 65 20 22 50 61 74 74 65 72 6e 22 20 4d  able "Pattern" M
0920: 65 6d 62 65 72 73 0d 0a 20 20 20 20 70 72 69 76  embers..    priv
0930: 61 74 65 20 62 6f 6f 6c 20 64 69 73 70 6f 73 65  ate bool dispose
0940: 64 3b 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20  d;..    private 
0950: 76 6f 69 64 20 43 68 65 63 6b 44 69 73 70 6f 73  void CheckDispos
0960: 65 64 28 29 20 2f 2a 20 74 68 72 6f 77 20 2a 2f  ed() /* throw */
0970: 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 54 48 52  ..    {..#if THR
0980: 4f 57 5f 4f 4e 5f 44 49 53 50 4f 53 45 44 0d 0a  OW_ON_DISPOSED..
0990: 20 20 20 20 20 20 20 20 69 66 20 28 64 69 73 70          if (disp
09a0: 6f 73 65 64 29 0d 0a 20 20 20 20 20 20 20 20 20  osed)..         
09b0: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 4f 62 6a     throw new Obj
09c0: 65 63 74 44 69 73 70 6f 73 65 64 45 78 63 65 70  ectDisposedExcep
09d0: 74 69 6f 6e 28 74 79 70 65 6f 66 28 53 51 4c 69  tion(typeof(SQLi
09e0: 74 65 33 29 2e 4e 61 6d 65 29 3b 0d 0a 23 65 6e  te3).Name);..#en
09f0: 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  dif..    }....  
0a00: 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f    //////////////
0a10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a60: 2f 0d 0a 0d 0a 20 20 20 20 70 72 6f 74 65 63 74  /....    protect
0a70: 65 64 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  ed override void
0a80: 20 44 69 73 70 6f 73 65 28 62 6f 6f 6c 20 64 69   Dispose(bool di
0a90: 73 70 6f 73 69 6e 67 29 0d 0a 20 20 20 20 7b 0d  sposing)..    {.
0aa0: 0a 20 20 20 20 20 20 20 20 74 72 79 0d 0a 20 20  .        try..  
0ab0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
0ac0: 20 20 20 20 20 69 66 20 28 21 64 69 73 70 6f 73       if (!dispos
0ad0: 65 64 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ed)..           
0ae0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
0af0: 20 20 20 20 2f 2f 69 66 20 28 64 69 73 70 6f 73      //if (dispos
0b00: 69 6e 67 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ing)..          
0b10: 20 20 20 20 20 20 2f 2f 7b 0d 0a 20 20 20 20 20        //{..     
0b20: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 20 20             //   
0b30: 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f   ///////////////
0b40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0b50: 2f 2f 2f 2f 2f 0d 0a 20 20 20 20 20 20 20 20 20  /////..         
0b60: 20 20 20 20 20 20 20 2f 2f 20 20 20 20 2f 2f 20         //    // 
0b70: 64 69 73 70 6f 73 65 20 6d 61 6e 61 67 65 64 20  dispose managed 
0b80: 72 65 73 6f 75 72 63 65 73 20 68 65 72 65 2e 2e  resources here..
0b90: 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
0ba0: 20 20 20 2f 2f 20 20 20 20 2f 2f 2f 2f 2f 2f 2f     //    ///////
0bb0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0bc0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 20  /////////////.. 
0bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
0be0: 2f 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  /}....          
0bf0: 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f        //////////
0c00: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0c10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 20 20  ////////////..  
0c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f                //
0c30: 20 72 65 6c 65 61 73 65 20 75 6e 6d 61 6e 61 67   release unmanag
0c40: 65 64 20 72 65 73 6f 75 72 63 65 73 20 68 65 72  ed resources her
0c50: 65 2e 2e 2e 0d 0a 20 20 20 20 20 20 20 20 20 20  e.....          
0c60: 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f        //////////
0c70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0c80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a  ////////////....
0c90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0ca0: 43 6c 6f 73 65 28 29 3b 0d 0a 0d 0a 20 20 20 20  Close();....    
0cb0: 20 20 20 20 20 20 20 20 20 20 20 20 64 69 73 70              disp
0cc0: 6f 73 65 64 20 3d 20 74 72 75 65 3b 0d 0a 20 20  osed = true;..  
0cd0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
0ce0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
0cf0: 66 69 6e 61 6c 6c 79 0d 0a 20 20 20 20 20 20 20  finally..       
0d00: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
0d10: 62 61 73 65 2e 44 69 73 70 6f 73 65 28 64 69 73  base.Dispose(dis
0d20: 70 6f 73 69 6e 67 29 3b 0d 0a 20 20 20 20 20 20  posing);..      
0d30: 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20    }..    }..    
0d40: 23 65 6e 64 72 65 67 69 6f 6e 0d 0a 0d 0a 20 20  #endregion....  
0d50: 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f    //////////////
0d60: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0d70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0d80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0d90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0da0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0db0: 2f 0d 0a 0d 0a 20 20 20 20 2f 2f 20 49 74 20 69  /....    // It i
0dc0: 73 6e 27 74 20 6e 65 63 65 73 73 61 72 79 20 74  sn't necessary t
0dd0: 6f 20 63 6c 65 61 6e 75 70 20 61 6e 79 20 66 75  o cleanup any fu
0de0: 6e 63 74 69 6f 6e 73 20 77 65 27 76 65 20 72 65  nctions we've re
0df0: 67 69 73 74 65 72 65 64 2e 20 20 49 66 20 74 68  gistered.  If th
0e00: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 0d 0a 20 20  e connection..  
0e10: 20 20 2f 2f 20 67 6f 65 73 20 74 6f 20 74 68 65    // goes to the
0e20: 20 70 6f 6f 6c 20 61 6e 64 20 69 73 20 72 65 73   pool and is res
0e30: 75 72 72 65 63 74 65 64 20 6c 61 74 65 72 2c 20  urrected later, 
0e40: 72 65 2d 72 65 67 69 73 74 65 72 65 64 20 66 75  re-registered fu
0e50: 6e 63 74 69 6f 6e 73 20 77 69 6c 6c 20 6f 76 65  nctions will ove
0e60: 72 77 72 69 74 65 20 74 68 65 0d 0a 20 20 20 20  rwrite the..    
0e70: 2f 2f 20 70 72 65 76 69 6f 75 73 20 66 75 6e 63  // previous func
0e80: 74 69 6f 6e 73 2e 20 20 54 68 65 20 53 51 4c 69  tions.  The SQLi
0e90: 74 65 46 75 6e 63 74 69 6f 6e 43 6f 6f 6b 69 65  teFunctionCookie
0ea0: 48 61 6e 64 6c 65 20 77 69 6c 6c 20 74 61 6b 65  Handle will take
0eb0: 20 63 61 72 65 20 6f 66 20 66 72 65 65 69 6e 67   care of freeing
0ec0: 20 75 6e 6d 61 6e 61 67 65 64 0d 0a 20 20 20 20   unmanaged..    
0ed0: 2f 2f 20 72 65 73 6f 75 72 63 65 73 20 62 65 6c  // resources bel
0ee0: 6f 6e 67 69 6e 67 20 74 6f 20 74 68 65 20 70 72  onging to the pr
0ef0: 65 76 69 6f 75 73 6c 79 2d 72 65 67 69 73 74 65  eviously-registe
0f00: 72 65 64 20 66 75 6e 63 74 69 6f 6e 73 2e 0d 0a  red functions...
0f10: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
0f20: 72 72 69 64 65 20 76 6f 69 64 20 43 6c 6f 73 65  rride void Close
0f30: 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  ()..    {..     
0f40: 20 69 66 20 28 5f 73 71 6c 20 21 3d 20 6e 75 6c   if (_sql != nul
0f50: 6c 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20  l)..      {..   
0f60: 20 20 20 20 20 20 20 69 66 20 28 5f 75 73 65 50         if (_useP
0f70: 6f 6f 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ool)..          
0f80: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
0f90: 20 53 51 4c 69 74 65 42 61 73 65 2e 52 65 73 65   SQLiteBase.Rese
0fa0: 74 43 6f 6e 6e 65 63 74 69 6f 6e 28 5f 73 71 6c  tConnection(_sql
0fb0: 2c 20 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 20 20  , _sql);..      
0fc0: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f          SQLiteCo
0fd0: 6e 6e 65 63 74 69 6f 6e 50 6f 6f 6c 2e 41 64 64  nnectionPool.Add
0fe0: 28 5f 66 69 6c 65 4e 61 6d 65 2c 20 5f 73 71 6c  (_fileName, _sql
0ff0: 2c 20 5f 70 6f 6f 6c 56 65 72 73 69 6f 6e 29 3b  , _poolVersion);
1000: 0d 0a 0d 0a 23 69 66 20 44 45 42 55 47 20 26 26  ....#if DEBUG &&
1010: 20 21 4e 45 54 5f 43 4f 4d 50 41 43 54 5f 32 30   !NET_COMPACT_20
1020: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1030: 54 72 61 63 65 2e 57 72 69 74 65 4c 69 6e 65 28  Trace.WriteLine(
1040: 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 43  String.Format("C
1050: 6c 6f 73 65 20 28 50 6f 6f 6c 29 3a 20 7b 30 7d  lose (Pool): {0}
1060: 22 2c 20 5f 73 71 6c 29 29 3b 0d 0a 23 65 6e 64  ", _sql));..#end
1070: 69 66 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d  if..          }.
1080: 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d  .          else.
1090: 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  .          {..  
10a0: 20 20 20 20 20 20 20 20 20 20 20 20 5f 73 71 6c              _sql
10b0: 2e 44 69 73 70 6f 73 65 28 29 3b 0d 0a 20 20 20  .Dispose();..   
10c0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
10d0: 20 20 20 20 5f 73 71 6c 20 3d 20 6e 75 6c 6c 3b      _sql = null;
10e0: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
10f0: 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f  ....    ////////
1100: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1110: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1120: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1130: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1140: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1150: 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 69  ///////....    i
1160: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1170: 20 76 6f 69 64 20 43 61 6e 63 65 6c 28 29 0d 0a   void Cancel()..
1180: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e 73      {..      Uns
1190: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
11a0: 2e 73 71 6c 69 74 65 33 5f 69 6e 74 65 72 72 75  .sqlite3_interru
11b0: 70 74 28 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 7d  pt(_sql);..    }
11c0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
11d0: 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67   override string
11e0: 20 56 65 72 73 69 6f 6e 0d 0a 20 20 20 20 7b 0d   Version..    {.
11f0: 0a 20 20 20 20 20 20 67 65 74 0d 0a 20 20 20 20  .      get..    
1200: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74    {..        ret
1210: 75 72 6e 20 53 51 4c 69 74 65 33 2e 53 51 4c 69  urn SQLite3.SQLi
1220: 74 65 56 65 72 73 69 6f 6e 3b 0d 0a 20 20 20 20  teVersion;..    
1230: 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20    }..    }....  
1240: 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69    internal stati
1250: 63 20 73 74 72 69 6e 67 20 44 65 66 69 6e 65 43  c string DefineC
1260: 6f 6e 73 74 61 6e 74 73 0d 0a 20 20 20 20 7b 0d  onstants..    {.
1270: 0a 20 20 20 20 20 20 20 20 67 65 74 0d 0a 20 20  .        get..  
1280: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
1290: 20 20 20 20 20 53 74 72 69 6e 67 42 75 69 6c 64       StringBuild
12a0: 65 72 20 72 65 73 75 6c 74 20 3d 20 6e 65 77 20  er result = new 
12b0: 53 74 72 69 6e 67 42 75 69 6c 64 65 72 28 29 3b  StringBuilder();
12c0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 49 4c  ..            IL
12d0: 69 73 74 3c 73 74 72 69 6e 67 3e 20 6c 69 73 74  ist<string> list
12e0: 20 3d 20 53 51 4c 69 74 65 44 65 66 69 6e 65 43   = SQLiteDefineC
12f0: 6f 6e 73 74 61 6e 74 73 2e 4f 70 74 69 6f 6e 4c  onstants.OptionL
1300: 69 73 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ist;....        
1310: 20 20 20 20 69 66 20 28 6c 69 73 74 20 21 3d 20      if (list != 
1320: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
1330: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
1340: 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 73        foreach (s
1350: 74 72 69 6e 67 20 65 6c 65 6d 65 6e 74 20 69 6e  tring element in
1360: 20 6c 69 73 74 29 0d 0a 20 20 20 20 20 20 20 20   list)..        
1370: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
1380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
1390: 66 20 28 65 6c 65 6d 65 6e 74 20 3d 3d 20 6e 75  f (element == nu
13a0: 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ll)..           
13b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e               con
13c0: 74 69 6e 75 65 3b 0d 0a 0d 0a 20 20 20 20 20 20  tinue;....      
13d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66                if
13e0: 20 28 72 65 73 75 6c 74 2e 4c 65 6e 67 74 68 20   (result.Length 
13f0: 3e 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20  > 0)..          
1400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65                re
1410: 73 75 6c 74 2e 41 70 70 65 6e 64 28 27 20 27 29  sult.Append(' ')
1420: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ;....           
1430: 20 20 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e           result.
1440: 41 70 70 65 6e 64 28 65 6c 65 6d 65 6e 74 29 3b  Append(element);
1450: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1460: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20    }..           
1470: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20   }....          
1480: 20 20 72 65 74 75 72 6e 20 72 65 73 75 6c 74 2e    return result.
1490: 54 6f 53 74 72 69 6e 67 28 29 3b 0d 0a 20 20 20  ToString();..   
14a0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d       }..    }...
14b0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
14c0: 61 74 69 63 20 73 74 72 69 6e 67 20 53 51 4c 69  atic string SQLi
14d0: 74 65 56 65 72 73 69 6f 6e 0d 0a 20 20 20 20 7b  teVersion..    {
14e0: 0d 0a 20 20 20 20 20 20 67 65 74 0d 0a 20 20 20  ..      get..   
14f0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65     {..        re
1500: 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e  turn UTF8ToStrin
1510: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
1520: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6c 69  thods.sqlite3_li
1530: 62 76 65 72 73 69 6f 6e 28 29 2c 20 2d 31 29 3b  bversion(), -1);
1540: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
1550: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
1560: 20 73 74 61 74 69 63 20 73 74 72 69 6e 67 20 53   static string S
1570: 51 4c 69 74 65 53 6f 75 72 63 65 49 64 0d 0a 20  QLiteSourceId.. 
1580: 20 20 20 7b 0d 0a 20 20 20 20 20 20 67 65 74 0d     {..      get.
1590: 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  .      {..      
15a0: 20 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53    return UTF8ToS
15b0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
15c0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
15d0: 33 5f 73 6f 75 72 63 65 69 64 28 29 2c 20 2d 31  3_sourceid(), -1
15e0: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  );..      }..   
15f0: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
1600: 61 6c 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c  al override bool
1610: 20 41 75 74 6f 43 6f 6d 6d 69 74 0d 0a 20 20 20   AutoCommit..   
1620: 20 7b 0d 0a 20 20 20 20 20 20 67 65 74 0d 0a 20   {..      get.. 
1630: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
1640: 72 65 74 75 72 6e 20 49 73 41 75 74 6f 63 6f 6d  return IsAutocom
1650: 6d 69 74 28 5f 73 71 6c 2c 20 5f 73 71 6c 29 3b  mit(_sql, _sql);
1660: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
1670: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
1680: 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 4c   override long L
1690: 61 73 74 49 6e 73 65 72 74 52 6f 77 49 64 0d 0a  astInsertRowId..
16a0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 67 65 74      {..      get
16b0: 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20  ..      {..     
16c0: 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65     return Unsafe
16d0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
16e0: 6c 69 74 65 33 5f 6c 61 73 74 5f 69 6e 73 65 72  lite3_last_inser
16f0: 74 5f 72 6f 77 69 64 28 5f 73 71 6c 29 3b 0d 0a  t_rowid(_sql);..
1700: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a        }..    }..
1710: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
1720: 76 65 72 72 69 64 65 20 69 6e 74 20 43 68 61 6e  verride int Chan
1730: 67 65 73 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ges..    {..    
1740: 20 20 67 65 74 0d 0a 20 20 20 20 20 20 7b 0d 0a    get..      {..
1750: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 55          return U
1760: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
1770: 64 73 2e 73 71 6c 69 74 65 33 5f 63 68 61 6e 67  ds.sqlite3_chang
1780: 65 73 28 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 20  es(_sql);..     
1790: 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20   }..    }....   
17a0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
17b0: 64 65 20 6c 6f 6e 67 20 4d 65 6d 6f 72 79 55 73  de long MemoryUs
17c0: 65 64 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  ed..    {..     
17d0: 20 67 65 74 0d 0a 20 20 20 20 20 20 7b 0d 0a 20   get..      {.. 
17e0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e         return Un
17f0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
1800: 73 2e 73 71 6c 69 74 65 33 5f 6d 65 6d 6f 72 79  s.sqlite3_memory
1810: 5f 75 73 65 64 28 29 3b 0d 0a 20 20 20 20 20 20  _used();..      
1820: 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  }..    }....    
1830: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
1840: 65 20 6c 6f 6e 67 20 4d 65 6d 6f 72 79 48 69 67  e long MemoryHig
1850: 68 77 61 74 65 72 0d 0a 20 20 20 20 7b 0d 0a 20  hwater..    {.. 
1860: 20 20 20 20 20 67 65 74 0d 0a 20 20 20 20 20 20       get..      
1870: 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  {..        retur
1880: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
1890: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6d 65  thods.sqlite3_me
18a0: 6d 6f 72 79 5f 68 69 67 68 77 61 74 65 72 28 30  mory_highwater(0
18b0: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  );..      }..   
18c0: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73   }....    /// <s
18d0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
18e0: 20 53 68 75 74 64 6f 77 6e 20 74 68 65 20 53 51   Shutdown the SQ
18f0: 4c 69 74 65 20 65 6e 67 69 6e 65 20 73 6f 20 74  Lite engine so t
1900: 68 61 74 20 69 74 20 63 61 6e 20 62 65 20 72 65  hat it can be re
1910: 73 74 61 72 74 65 64 20 77 69 74 68 20 64 69 66  started with dif
1920: 66 65 72 65 6e 74 20 63 6f 6e 66 69 67 20 6f 70  ferent config op
1930: 74 69 6f 6e 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20  tions...    /// 
1940: 57 65 20 64 65 70 65 6e 64 20 6f 6e 20 61 75 74  We depend on aut
1950: 6f 20 69 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e  o initialization
1960: 20 74 6f 20 72 65 63 6f 76 65 72 2e 0d 0a 20 20   to recover...  
1970: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
1980: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  ..    /// <retur
1990: 6e 73 3e 52 65 74 75 72 6e 73 20 61 20 72 65 73  ns>Returns a res
19a0: 75 6c 74 20 63 6f 64 65 3c 2f 72 65 74 75 72 6e  ult code</return
19b0: 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  s>..    internal
19c0: 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 53 68   override int Sh
19d0: 75 74 64 6f 77 6e 28 29 0d 0a 20 20 20 20 7b 0d  utdown()..    {.
19e0: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 72 63 20  .        int rc 
19f0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
1a00: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 73 68  thods.sqlite3_sh
1a10: 75 74 64 6f 77 6e 28 29 3b 0d 0a 20 20 20 20 20  utdown();..     
1a20: 20 20 20 72 65 74 75 72 6e 20 72 63 3b 0d 0a 20     return rc;.. 
1a30: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
1a40: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 62 6f  rnal override bo
1a50: 6f 6c 20 49 73 4f 70 65 6e 28 29 0d 0a 20 20 20  ol IsOpen()..   
1a60: 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75   {..        retu
1a70: 72 6e 20 28 5f 73 71 6c 20 21 3d 20 6e 75 6c 6c  rn (_sql != null
1a80: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
1a90: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
1aa0: 64 65 20 76 6f 69 64 20 4f 70 65 6e 28 73 74 72  de void Open(str
1ab0: 69 6e 67 20 73 74 72 46 69 6c 65 6e 61 6d 65 2c  ing strFilename,
1ac0: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
1ad0: 6e 46 6c 61 67 73 20 63 6f 6e 6e 65 63 74 69 6f  nFlags connectio
1ae0: 6e 46 6c 61 67 73 2c 20 53 51 4c 69 74 65 4f 70  nFlags, SQLiteOp
1af0: 65 6e 46 6c 61 67 73 45 6e 75 6d 20 6f 70 65 6e  enFlagsEnum open
1b00: 46 6c 61 67 73 2c 20 69 6e 74 20 6d 61 78 50 6f  Flags, int maxPo
1b10: 6f 6c 53 69 7a 65 2c 20 62 6f 6f 6c 20 75 73 65  olSize, bool use
1b20: 50 6f 6f 6c 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  Pool)..    {..  
1b30: 20 20 20 20 69 66 20 28 5f 73 71 6c 20 21 3d 20      if (_sql != 
1b40: 6e 75 6c 6c 29 20 72 65 74 75 72 6e 3b 0d 0a 0d  null) return;...
1b50: 0a 20 20 20 20 20 20 5f 75 73 65 50 6f 6f 6c 20  .      _usePool 
1b60: 3d 20 75 73 65 50 6f 6f 6c 3b 0d 0a 20 20 20 20  = usePool;..    
1b70: 20 20 5f 66 69 6c 65 4e 61 6d 65 20 3d 20 73 74    _fileName = st
1b80: 72 46 69 6c 65 6e 61 6d 65 3b 0d 0a 0d 0a 20 20  rFilename;....  
1b90: 20 20 20 20 69 66 20 28 75 73 65 50 6f 6f 6c 29      if (usePool)
1ba0: 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20  ..      {..     
1bb0: 20 20 20 5f 73 71 6c 20 3d 20 53 51 4c 69 74 65     _sql = SQLite
1bc0: 43 6f 6e 6e 65 63 74 69 6f 6e 50 6f 6f 6c 2e 52  ConnectionPool.R
1bd0: 65 6d 6f 76 65 28 73 74 72 46 69 6c 65 6e 61 6d  emove(strFilenam
1be0: 65 2c 20 6d 61 78 50 6f 6f 6c 53 69 7a 65 2c 20  e, maxPoolSize, 
1bf0: 6f 75 74 20 5f 70 6f 6f 6c 56 65 72 73 69 6f 6e  out _poolVersion
1c00: 29 3b 0d 0a 0d 0a 23 69 66 20 44 45 42 55 47 20  );....#if DEBUG 
1c10: 26 26 20 21 4e 45 54 5f 43 4f 4d 50 41 43 54 5f  && !NET_COMPACT_
1c20: 32 30 0d 0a 20 20 20 20 20 20 20 20 54 72 61 63  20..        Trac
1c30: 65 2e 57 72 69 74 65 4c 69 6e 65 28 53 74 72 69  e.WriteLine(Stri
1c40: 6e 67 2e 46 6f 72 6d 61 74 28 22 4f 70 65 6e 20  ng.Format("Open 
1c50: 28 50 6f 6f 6c 29 3a 20 7b 30 7d 22 2c 20 28 5f  (Pool): {0}", (_
1c60: 73 71 6c 20 21 3d 20 6e 75 6c 6c 29 20 3f 20 5f  sql != null) ? _
1c70: 73 71 6c 2e 54 6f 53 74 72 69 6e 67 28 29 20 3a  sql.ToString() :
1c80: 20 22 3c 6e 75 6c 6c 3e 22 29 29 3b 0d 0a 23 65   "<null>"));..#e
1c90: 6e 64 69 66 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d  ndif..      }...
1ca0: 0a 20 20 20 20 20 20 69 66 20 28 5f 73 71 6c 20  .      if (_sql 
1cb0: 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20  == null)..      
1cc0: 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e 74 50 74  {..        IntPt
1cd0: 72 20 64 62 3b 0d 0a 0d 0a 23 69 66 20 21 53 51  r db;....#if !SQ
1ce0: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
1cf0: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55         int n = U
1d00: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
1d10: 64 73 2e 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f  ds.sqlite3_open_
1d20: 69 6e 74 65 72 6f 70 28 54 6f 55 54 46 38 28 73  interop(ToUTF8(s
1d30: 74 72 46 69 6c 65 6e 61 6d 65 29 2c 20 28 69 6e  trFilename), (in
1d40: 74 29 6f 70 65 6e 46 6c 61 67 73 2c 20 6f 75 74  t)openFlags, out
1d50: 20 64 62 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20   db);..#else..  
1d60: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
1d70: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
1d80: 73 2e 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f 76  s.sqlite3_open_v
1d90: 32 28 54 6f 55 54 46 38 28 73 74 72 46 69 6c 65  2(ToUTF8(strFile
1da0: 6e 61 6d 65 29 2c 20 6f 75 74 20 64 62 2c 20 28  name), out db, (
1db0: 69 6e 74 29 6f 70 65 6e 46 6c 61 67 73 2c 20 49  int)openFlags, I
1dc0: 6e 74 50 74 72 2e 5a 65 72 6f 29 3b 0d 0a 23 65  ntPtr.Zero);..#e
1dd0: 6e 64 69 66 0d 0a 0d 0a 23 69 66 20 44 45 42 55  ndif....#if DEBU
1de0: 47 20 26 26 20 21 4e 45 54 5f 43 4f 4d 50 41 43  G && !NET_COMPAC
1df0: 54 5f 32 30 0d 0a 20 20 20 20 20 20 20 20 54 72  T_20..        Tr
1e00: 61 63 65 2e 57 72 69 74 65 4c 69 6e 65 28 53 74  ace.WriteLine(St
1e10: 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 4f 70 65  ring.Format("Ope
1e20: 6e 3a 20 7b 30 7d 22 2c 20 64 62 29 29 3b 0d 0a  n: {0}", db));..
1e30: 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20  #endif....      
1e40: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
1e50: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
1e60: 65 70 74 69 6f 6e 28 6e 2c 20 6e 75 6c 6c 29 3b  eption(n, null);
1e70: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 5f 73 71 6c  ....        _sql
1e80: 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f 6e   = new SQLiteCon
1e90: 6e 65 63 74 69 6f 6e 48 61 6e 64 6c 65 28 64 62  nectionHandle(db
1ea0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 6c 6f 63 6b  );..        lock
1eb0: 20 28 5f 73 71 6c 29 20 7b 20 2f 2a 20 48 41 43   (_sql) { /* HAC
1ec0: 4b 3a 20 46 6f 72 63 65 20 74 68 65 20 53 79 6e  K: Force the Syn
1ed0: 63 42 6c 6f 63 6b 20 74 6f 20 62 65 20 22 63 72  cBlock to be "cr
1ee0: 65 61 74 65 64 22 20 6e 6f 77 2e 20 2a 2f 20 7d  eated" now. */ }
1ef0: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20  ..      }..     
1f00: 20 2f 2f 20 42 69 6e 64 20 66 75 6e 63 74 69 6f   // Bind functio
1f10: 6e 73 20 74 6f 20 74 68 69 73 20 63 6f 6e 6e 65  ns to this conne
1f20: 63 74 69 6f 6e 2e 20 20 49 66 20 61 6e 79 20 70  ction.  If any p
1f30: 72 65 76 69 6f 75 73 20 66 75 6e 63 74 69 6f 6e  revious function
1f40: 73 20 6f 66 20 74 68 65 20 73 61 6d 65 20 6e 61  s of the same na
1f50: 6d 65 0d 0a 20 20 20 20 20 20 2f 2f 20 77 65 72  me..      // wer
1f60: 65 20 61 6c 72 65 61 64 79 20 62 6f 75 6e 64 2c  e already bound,
1f70: 20 74 68 65 6e 20 74 68 65 20 6e 65 77 20 62 69   then the new bi
1f80: 6e 64 69 6e 67 73 20 72 65 70 6c 61 63 65 20 74  ndings replace t
1f90: 68 65 20 6f 6c 64 2e 0d 0a 20 20 20 20 20 20 5f  he old...      _
1fa0: 66 75 6e 63 74 69 6f 6e 73 41 72 72 61 79 20 3d  functionsArray =
1fb0: 20 53 51 4c 69 74 65 46 75 6e 63 74 69 6f 6e 2e   SQLiteFunction.
1fc0: 42 69 6e 64 46 75 6e 63 74 69 6f 6e 73 28 74 68  BindFunctions(th
1fd0: 69 73 2c 20 63 6f 6e 6e 65 63 74 69 6f 6e 46 6c  is, connectionFl
1fe0: 61 67 73 29 3b 0d 0a 20 20 20 20 20 20 53 65 74  ags);..      Set
1ff0: 54 69 6d 65 6f 75 74 28 30 29 3b 0d 0a 20 20 20  Timeout(0);..   
2000: 20 20 20 47 43 2e 4b 65 65 70 41 6c 69 76 65 28     GC.KeepAlive(
2010: 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  _sql);..    }...
2020: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
2030: 65 72 72 69 64 65 20 76 6f 69 64 20 43 6c 65 61  erride void Clea
2040: 72 50 6f 6f 6c 28 29 0d 0a 20 20 20 20 7b 0d 0a  rPool()..    {..
2050: 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e        SQLiteConn
2060: 65 63 74 69 6f 6e 50 6f 6f 6c 2e 43 6c 65 61 72  ectionPool.Clear
2070: 50 6f 6f 6c 28 5f 66 69 6c 65 4e 61 6d 65 29 3b  Pool(_fileName);
2080: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
2090: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
20a0: 20 69 6e 74 20 43 6f 75 6e 74 50 6f 6f 6c 28 29   int CountPool()
20b0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
20c0: 20 44 69 63 74 69 6f 6e 61 72 79 3c 73 74 72 69   Dictionary<stri
20d0: 6e 67 2c 20 69 6e 74 3e 20 63 6f 75 6e 74 73 20  ng, int> counts 
20e0: 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 20  = null;..       
20f0: 20 69 6e 74 20 6f 70 65 6e 43 6f 75 6e 74 20 3d   int openCount =
2100: 20 30 3b 0d 0a 20 20 20 20 20 20 20 20 69 6e 74   0;..        int
2110: 20 63 6c 6f 73 65 43 6f 75 6e 74 20 3d 20 30 3b   closeCount = 0;
2120: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 74 6f  ..        int to
2130: 74 61 6c 43 6f 75 6e 74 20 3d 20 30 3b 0d 0a 0d  talCount = 0;...
2140: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 43  .        SQLiteC
2150: 6f 6e 6e 65 63 74 69 6f 6e 50 6f 6f 6c 2e 47 65  onnectionPool.Ge
2160: 74 43 6f 75 6e 74 73 28 5f 66 69 6c 65 4e 61 6d  tCounts(_fileNam
2170: 65 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  e,..            
2180: 72 65 66 20 63 6f 75 6e 74 73 2c 20 72 65 66 20  ref counts, ref 
2190: 6f 70 65 6e 43 6f 75 6e 74 2c 20 72 65 66 20 63  openCount, ref c
21a0: 6c 6f 73 65 43 6f 75 6e 74 2c 0d 0a 20 20 20 20  loseCount,..    
21b0: 20 20 20 20 20 20 20 20 72 65 66 20 74 6f 74 61          ref tota
21c0: 6c 43 6f 75 6e 74 29 3b 0d 0a 0d 0a 20 20 20 20  lCount);....    
21d0: 20 20 20 20 72 65 74 75 72 6e 20 74 6f 74 61 6c      return total
21e0: 43 6f 75 6e 74 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  Count;..    }...
21f0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
2200: 65 72 72 69 64 65 20 76 6f 69 64 20 53 65 74 54  erride void SetT
2210: 69 6d 65 6f 75 74 28 69 6e 74 20 6e 54 69 6d 65  imeout(int nTime
2220: 6f 75 74 4d 53 29 0d 0a 20 20 20 20 7b 0d 0a 20  outMS)..    {.. 
2230: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73       int n = Uns
2240: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
2250: 2e 73 71 6c 69 74 65 33 5f 62 75 73 79 5f 74 69  .sqlite3_busy_ti
2260: 6d 65 6f 75 74 28 5f 73 71 6c 2c 20 6e 54 69 6d  meout(_sql, nTim
2270: 65 6f 75 74 4d 53 29 3b 0d 0a 20 20 20 20 20 20  eoutMS);..      
2280: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
2290: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
22a0: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
22b0: 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d  rror());..    }.
22c0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
22d0: 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20 53 74  override bool St
22e0: 65 70 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  ep(SQLiteStateme
22f0: 6e 74 20 73 74 6d 74 29 0d 0a 20 20 20 20 7b 0d  nt stmt)..    {.
2300: 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b 0d 0a 20  .      int n;.. 
2310: 20 20 20 20 20 52 61 6e 64 6f 6d 20 72 6e 64 20       Random rnd 
2320: 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 75  = null;..      u
2330: 69 6e 74 20 73 74 61 72 74 74 69 63 6b 20 3d 20  int starttick = 
2340: 28 75 69 6e 74 29 45 6e 76 69 72 6f 6e 6d 65 6e  (uint)Environmen
2350: 74 2e 54 69 63 6b 43 6f 75 6e 74 3b 0d 0a 20 20  t.TickCount;..  
2360: 20 20 20 20 75 69 6e 74 20 74 69 6d 65 6f 75 74      uint timeout
2370: 20 3d 20 28 75 69 6e 74 29 28 73 74 6d 74 2e 5f   = (uint)(stmt._
2380: 63 6f 6d 6d 61 6e 64 2e 5f 63 6f 6d 6d 61 6e 64  command._command
2390: 54 69 6d 65 6f 75 74 20 2a 20 31 30 30 30 29 3b  Timeout * 1000);
23a0: 0d 0a 0d 0a 20 20 20 20 20 20 77 68 69 6c 65 20  ....      while 
23b0: 28 74 72 75 65 29 0d 0a 20 20 20 20 20 20 7b 0d  (true)..      {.
23c0: 0a 20 20 20 20 20 20 20 20 6e 20 3d 20 55 6e 73  .        n = Uns
23d0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
23e0: 2e 73 71 6c 69 74 65 33 5f 73 74 65 70 28 73 74  .sqlite3_step(st
23f0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29  mt._sqlite_stmt)
2400: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ;....        if 
2410: 28 6e 20 3d 3d 20 31 30 30 29 20 72 65 74 75 72  (n == 100) retur
2420: 6e 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20  n true;..       
2430: 20 69 66 20 28 6e 20 3d 3d 20 31 30 31 29 20 72   if (n == 101) r
2440: 65 74 75 72 6e 20 66 61 6c 73 65 3b 0d 0a 0d 0a  eturn false;....
2450: 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20          if (n > 
2460: 30 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  0)..        {.. 
2470: 20 20 20 20 20 20 20 20 20 69 6e 74 20 72 3b 0d           int r;.
2480: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20  ...          // 
2490: 41 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65  An error occurre
24a0: 64 2c 20 61 74 74 65 6d 70 74 20 74 6f 20 72 65  d, attempt to re
24b0: 73 65 74 20 74 68 65 20 73 74 61 74 65 6d 65 6e  set the statemen
24c0: 74 2e 20 20 49 66 20 74 68 65 20 72 65 73 65 74  t.  If the reset
24d0: 20 77 6f 72 6b 65 64 20 62 65 63 61 75 73 65 20   worked because 
24e0: 74 68 65 0d 0a 20 20 20 20 20 20 20 20 20 20 2f  the..          /
24f0: 2f 20 73 63 68 65 6d 61 20 68 61 73 20 63 68 61  / schema has cha
2500: 6e 67 65 64 2c 20 72 65 2d 74 72 79 20 74 68 65  nged, re-try the
2510: 20 73 74 65 70 20 61 67 61 69 6e 2e 20 20 49 66   step again.  If
2520: 20 69 74 20 65 72 72 6f 72 65 64 20 6f 75 72 20   it errored our 
2530: 62 65 63 61 75 73 65 20 74 68 65 20 64 61 74 61  because the data
2540: 62 61 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20  base..          
2550: 2f 2f 20 69 73 20 6c 6f 63 6b 65 64 2c 20 74 68  // is locked, th
2560: 65 6e 20 6b 65 65 70 20 72 65 74 72 79 69 6e 67  en keep retrying
2570: 20 75 6e 74 69 6c 20 74 68 65 20 63 6f 6d 6d 61   until the comma
2580: 6e 64 20 74 69 6d 65 6f 75 74 20 6f 63 63 75 72  nd timeout occur
2590: 73 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 72 20  s...          r 
25a0: 3d 20 52 65 73 65 74 28 73 74 6d 74 29 3b 0d 0a  = Reset(stmt);..
25b0: 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28  ..          if (
25c0: 72 20 3d 3d 20 30 29 0d 0a 20 20 20 20 20 20 20  r == 0)..       
25d0: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53       throw new S
25e0: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
25f0: 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29  , GetLastError()
2600: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
2610: 65 6c 73 65 20 69 66 20 28 28 72 20 3d 3d 20 36  else if ((r == 6
2620: 20 7c 7c 20 72 20 3d 3d 20 35 29 20 26 26 20 73   || r == 5) && s
2630: 74 6d 74 2e 5f 63 6f 6d 6d 61 6e 64 20 21 3d 20  tmt._command != 
2640: 6e 75 6c 6c 29 20 2f 2f 20 53 51 4c 49 54 45 5f  null) // SQLITE_
2650: 4c 4f 43 4b 45 44 20 7c 7c 20 53 51 4c 49 54 45  LOCKED || SQLITE
2660: 5f 42 55 53 59 0d 0a 20 20 20 20 20 20 20 20 20  _BUSY..         
2670: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
2680: 2f 2f 20 4b 65 65 70 20 74 72 79 69 6e 67 0d 0a  // Keep trying..
2690: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
26a0: 72 6e 64 20 3d 3d 20 6e 75 6c 6c 29 20 2f 2f 20  rnd == null) // 
26b0: 46 69 72 73 74 20 74 69 6d 65 20 77 65 27 76 65  First time we've
26c0: 20 65 6e 63 6f 75 6e 74 65 72 65 64 20 74 68 65   encountered the
26d0: 20 6c 6f 63 6b 0d 0a 20 20 20 20 20 20 20 20 20   lock..         
26e0: 20 20 20 20 20 72 6e 64 20 3d 20 6e 65 77 20 52       rnd = new R
26f0: 61 6e 64 6f 6d 28 29 3b 0d 0a 0d 0a 20 20 20 20  andom();....    
2700: 20 20 20 20 20 20 20 20 2f 2f 20 49 66 20 77 65          // If we
2710: 27 76 65 20 65 78 63 65 65 64 65 64 20 74 68 65  've exceeded the
2720: 20 63 6f 6d 6d 61 6e 64 27 73 20 74 69 6d 65 6f   command's timeo
2730: 75 74 2c 20 67 69 76 65 20 75 70 20 61 6e 64 20  ut, give up and 
2740: 74 68 72 6f 77 20 61 6e 20 65 72 72 6f 72 0d 0a  throw an error..
2750: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
2760: 28 75 69 6e 74 29 45 6e 76 69 72 6f 6e 6d 65 6e  (uint)Environmen
2770: 74 2e 54 69 63 6b 43 6f 75 6e 74 20 2d 20 73 74  t.TickCount - st
2780: 61 72 74 74 69 63 6b 20 3e 20 74 69 6d 65 6f 75  arttick > timeou
2790: 74 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  t)..            
27a0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
27b0: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
27c0: 65 45 78 63 65 70 74 69 6f 6e 28 72 2c 20 47 65  eException(r, Ge
27d0: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
27e0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
27f0: 20 20 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d             else.
2800: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a  .            {..
2810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f                //
2820: 20 4f 74 68 65 72 77 69 73 65 20 73 6c 65 65 70   Otherwise sleep
2830: 20 66 6f 72 20 61 20 72 61 6e 64 6f 6d 20 61 6d   for a random am
2840: 6f 75 6e 74 20 6f 66 20 74 69 6d 65 20 75 70 20  ount of time up 
2850: 74 6f 20 31 35 30 6d 73 0d 0a 20 20 20 20 20 20  to 150ms..      
2860: 20 20 20 20 20 20 20 20 53 79 73 74 65 6d 2e 54          System.T
2870: 68 72 65 61 64 69 6e 67 2e 54 68 72 65 61 64 2e  hreading.Thread.
2880: 53 6c 65 65 70 28 72 6e 64 2e 4e 65 78 74 28 31  Sleep(rnd.Next(1
2890: 2c 20 31 35 30 29 29 3b 0d 0a 20 20 20 20 20 20  , 150));..      
28a0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
28b0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d     }..        }.
28c0: 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d  .      }..    }.
28d0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
28e0: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 52 65 73  override int Res
28f0: 65 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  et(SQLiteStateme
2900: 6e 74 20 73 74 6d 74 29 0d 0a 20 20 20 20 7b 0d  nt stmt)..    {.
2910: 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b 0d 0a 0d  .      int n;...
2920: 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41  .#if !SQLITE_STA
2930: 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 6e 20 3d  NDARD..      n =
2940: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
2950: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73  hods.sqlite3_res
2960: 65 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  et_interop(stmt.
2970: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29 3b 0d 0a  _sqlite_stmt);..
2980: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 6e 20 3d  #else..      n =
2990: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
29a0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73  hods.sqlite3_res
29b0: 65 74 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  et(stmt._sqlite_
29c0: 73 74 6d 74 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  stmt);..#endif..
29d0: 0d 0a 20 20 20 20 20 20 2f 2f 20 49 66 20 74 68  ..      // If th
29e0: 65 20 73 63 68 65 6d 61 20 63 68 61 6e 67 65 64  e schema changed
29f0: 2c 20 74 72 79 20 61 6e 64 20 72 65 2d 70 72 65  , try and re-pre
2a00: 70 61 72 65 20 69 74 0d 0a 20 20 20 20 20 20 69  pare it..      i
2a10: 66 20 28 6e 20 3d 3d 20 31 37 29 20 2f 2f 20 53  f (n == 17) // S
2a20: 51 4c 49 54 45 5f 53 43 48 45 4d 41 0d 0a 20 20  QLITE_SCHEMA..  
2a30: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 2f      {..        /
2a40: 2f 20 52 65 63 72 65 61 74 65 20 61 20 64 75 6d  / Recreate a dum
2a50: 6d 79 20 73 74 61 74 65 6d 65 6e 74 0d 0a 20 20  my statement..  
2a60: 20 20 20 20 20 20 73 74 72 69 6e 67 20 73 74 72        string str
2a70: 3b 0d 0a 20 20 20 20 20 20 20 20 75 73 69 6e 67  ;..        using
2a80: 20 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e   (SQLiteStatemen
2a90: 74 20 74 6d 70 20 3d 20 50 72 65 70 61 72 65 28  t tmp = Prepare(
2aa0: 6e 75 6c 6c 2c 20 73 74 6d 74 2e 5f 73 71 6c 53  null, stmt._sqlS
2ab0: 74 61 74 65 6d 65 6e 74 2c 20 6e 75 6c 6c 2c 20  tatement, null, 
2ac0: 28 75 69 6e 74 29 28 73 74 6d 74 2e 5f 63 6f 6d  (uint)(stmt._com
2ad0: 6d 61 6e 64 2e 5f 63 6f 6d 6d 61 6e 64 54 69 6d  mand._commandTim
2ae0: 65 6f 75 74 20 2a 20 31 30 30 30 29 2c 20 6f 75  eout * 1000), ou
2af0: 74 20 73 74 72 29 29 0d 0a 20 20 20 20 20 20 20  t str))..       
2b00: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 2f 2f   {..          //
2b10: 20 46 69 6e 61 6c 69 7a 65 20 74 68 65 20 65 78   Finalize the ex
2b20: 69 73 74 69 6e 67 20 73 74 61 74 65 6d 65 6e 74  isting statement
2b30: 0d 0a 20 20 20 20 20 20 20 20 20 20 73 74 6d 74  ..          stmt
2b40: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2e 44 69  ._sqlite_stmt.Di
2b50: 73 70 6f 73 65 28 29 3b 0d 0a 20 20 20 20 20 20  spose();..      
2b60: 20 20 20 20 2f 2f 20 52 65 61 73 73 69 67 6e 20      // Reassign 
2b70: 61 20 6e 65 77 20 73 74 61 74 65 6d 65 6e 74 20  a new statement 
2b80: 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 6f  pointer to the o
2b90: 6c 64 20 73 74 61 74 65 6d 65 6e 74 20 61 6e 64  ld statement and
2ba0: 20 63 6c 65 61 72 20 74 68 65 20 74 65 6d 70 6f   clear the tempo
2bb0: 72 61 72 79 20 6f 6e 65 0d 0a 20 20 20 20 20 20  rary one..      
2bc0: 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65      stmt._sqlite
2bd0: 5f 73 74 6d 74 20 3d 20 74 6d 70 2e 5f 73 71 6c  _stmt = tmp._sql
2be0: 69 74 65 5f 73 74 6d 74 3b 0d 0a 20 20 20 20 20  ite_stmt;..     
2bf0: 20 20 20 20 20 74 6d 70 2e 5f 73 71 6c 69 74 65       tmp._sqlite
2c00: 5f 73 74 6d 74 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d  _stmt = null;...
2c10: 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20 52 65  .          // Re
2c20: 61 70 70 6c 79 20 70 61 72 61 6d 65 74 65 72 73  apply parameters
2c30: 0d 0a 20 20 20 20 20 20 20 20 20 20 73 74 6d 74  ..          stmt
2c40: 2e 42 69 6e 64 50 61 72 61 6d 65 74 65 72 73 28  .BindParameters(
2c50: 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20  );..        }.. 
2c60: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 2d 31         return -1
2c70: 3b 20 2f 2f 20 52 65 73 65 74 20 77 61 73 20 4f  ; // Reset was O
2c80: 4b 2c 20 77 69 74 68 20 73 63 68 65 6d 61 20 63  K, with schema c
2c90: 68 61 6e 67 65 0d 0a 20 20 20 20 20 20 7d 0d 0a  hange..      }..
2ca0: 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28 6e        else if (n
2cb0: 20 3d 3d 20 36 20 7c 7c 20 6e 20 3d 3d 20 35 29   == 6 || n == 5)
2cc0: 20 2f 2f 20 53 51 4c 49 54 45 5f 4c 4f 43 4b 45   // SQLITE_LOCKE
2cd0: 44 20 7c 7c 20 53 51 4c 49 54 45 5f 42 55 53 59  D || SQLITE_BUSY
2ce0: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
2cf0: 20 6e 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20   n;....      if 
2d00: 28 6e 20 3e 20 30 29 0d 0a 20 20 20 20 20 20 20  (n > 0)..       
2d10: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
2d20: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65  eException(n, Ge
2d30: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
2d40: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 30  ..      return 0
2d50: 3b 20 2f 2f 20 57 65 20 72 65 73 65 74 20 4f 4b  ; // We reset OK
2d60: 2c 20 6e 6f 20 73 63 68 65 6d 61 20 63 68 61 6e  , no schema chan
2d70: 67 65 73 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  ges..    }....  
2d80: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2d90: 69 64 65 20 73 74 72 69 6e 67 20 47 65 74 4c 61  ide string GetLa
2da0: 73 74 45 72 72 6f 72 28 29 0d 0a 20 20 20 20 7b  stError()..    {
2db0: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 53  ..      return S
2dc0: 51 4c 69 74 65 42 61 73 65 2e 47 65 74 4c 61 73  QLiteBase.GetLas
2dd0: 74 45 72 72 6f 72 28 5f 73 71 6c 2c 20 5f 73 71  tError(_sql, _sq
2de0: 6c 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  l);..    }....  
2df0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2e00: 69 64 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d  ide SQLiteStatem
2e10: 65 6e 74 20 50 72 65 70 61 72 65 28 53 51 4c 69  ent Prepare(SQLi
2e20: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6e 6e  teConnection cnn
2e30: 2c 20 73 74 72 69 6e 67 20 73 74 72 53 71 6c 2c  , string strSql,
2e40: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
2e50: 20 70 72 65 76 69 6f 75 73 2c 20 75 69 6e 74 20   previous, uint 
2e60: 74 69 6d 65 6f 75 74 4d 53 2c 20 6f 75 74 20 73  timeoutMS, out s
2e70: 74 72 69 6e 67 20 73 74 72 52 65 6d 61 69 6e 29  tring strRemain)
2e80: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69  ..    {..      i
2e90: 66 20 28 21 53 74 72 69 6e 67 2e 49 73 4e 75 6c  f (!String.IsNul
2ea0: 6c 4f 72 45 6d 70 74 79 28 73 74 72 53 71 6c 29  lOrEmpty(strSql)
2eb0: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  )..      {..    
2ec0: 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 20 20      //..        
2ed0: 2f 2f 20 4e 4f 54 45 3a 20 53 51 4c 69 74 65 20  // NOTE: SQLite 
2ee0: 64 6f 65 73 20 6e 6f 74 20 73 75 70 70 6f 72 74  does not support
2ef0: 20 74 68 65 20 63 6f 6e 63 65 70 74 20 6f 66 20   the concept of 
2f00: 73 65 70 61 72 61 74 65 20 73 63 68 65 6d 61 73  separate schemas
2f10: 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20  ..        //    
2f20: 20 20 20 69 6e 20 6f 6e 65 20 64 61 74 61 62 61     in one databa
2f30: 73 65 3b 20 74 68 65 72 65 66 6f 72 65 2c 20 72  se; therefore, r
2f40: 65 6d 6f 76 65 20 74 68 65 20 62 61 73 65 20 73  emove the base s
2f50: 63 68 65 6d 61 20 6e 61 6d 65 0d 0a 20 20 20 20  chema name..    
2f60: 20 20 20 20 2f 2f 20 20 20 20 20 20 20 75 73 65      //       use
2f70: 64 20 74 6f 20 73 6d 6f 6f 74 68 20 69 6e 74 65  d to smooth inte
2f80: 67 72 61 74 69 6f 6e 20 77 69 74 68 20 74 68 65  gration with the
2f90: 20 62 61 73 65 20 2e 4e 45 54 20 46 72 61 6d 65   base .NET Frame
2fa0: 77 6f 72 6b 0d 0a 20 20 20 20 20 20 20 20 2f 2f  work..        //
2fb0: 20 20 20 20 20 20 20 64 61 74 61 20 63 6c 61 73         data clas
2fc0: 73 65 73 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f  ses...        //
2fd0: 0d 0a 20 20 20 20 20 20 20 20 73 74 72 69 6e 67  ..        string
2fe0: 20 62 61 73 65 53 63 68 65 6d 61 4e 61 6d 65 20   baseSchemaName 
2ff0: 3d 20 28 63 6e 6e 20 21 3d 20 6e 75 6c 6c 29 20  = (cnn != null) 
3000: 3f 20 63 6e 6e 2e 5f 62 61 73 65 53 63 68 65 6d  ? cnn._baseSchem
3010: 61 4e 61 6d 65 20 3a 20 6e 75 6c 6c 3b 0d 0a 0d  aName : null;...
3020: 0a 20 20 20 20 20 20 20 20 69 66 20 28 21 53 74  .        if (!St
3030: 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70  ring.IsNullOrEmp
3040: 74 79 28 62 61 73 65 53 63 68 65 6d 61 4e 61 6d  ty(baseSchemaNam
3050: 65 29 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  e))..        {..
3060: 20 20 20 20 20 20 20 20 20 20 73 74 72 53 71 6c            strSql
3070: 20 3d 20 73 74 72 53 71 6c 2e 52 65 70 6c 61 63   = strSql.Replac
3080: 65 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  e(..            
3090: 20 20 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28    String.Format(
30a0: 22 5b 7b 30 7d 5d 2e 22 2c 20 62 61 73 65 53 63  "[{0}].", baseSc
30b0: 68 65 6d 61 4e 61 6d 65 29 2c 20 53 74 72 69 6e  hemaName), Strin
30c0: 67 2e 45 6d 70 74 79 29 3b 0d 0a 0d 0a 20 20 20  g.Empty);....   
30d0: 20 20 20 20 20 20 20 73 74 72 53 71 6c 20 3d 20         strSql = 
30e0: 73 74 72 53 71 6c 2e 52 65 70 6c 61 63 65 28 0d  strSql.Replace(.
30f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53  .              S
3100: 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 7b 30  tring.Format("{0
3110: 7d 2e 22 2c 20 62 61 73 65 53 63 68 65 6d 61 4e  }.", baseSchemaN
3120: 61 6d 65 29 2c 20 53 74 72 69 6e 67 2e 45 6d 70  ame), String.Emp
3130: 74 79 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ty);..        }.
3140: 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  .      }....    
3150: 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69    SQLiteConnecti
3160: 6f 6e 46 6c 61 67 73 20 66 6c 61 67 73 20 3d 0d  onFlags flags =.
3170: 0a 20 20 20 20 20 20 20 20 20 20 28 63 6e 6e 20  .          (cnn 
3180: 21 3d 20 6e 75 6c 6c 29 20 3f 20 63 6e 6e 2e 46  != null) ? cnn.F
3190: 6c 61 67 73 20 3a 20 53 51 4c 69 74 65 43 6f 6e  lags : SQLiteCon
31a0: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 44 65 66  nectionFlags.Def
31b0: 61 75 6c 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c  ault;....#if !PL
31c0: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
31d0: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 69  AMEWORK..      i
31e0: 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69  f ((flags & SQLi
31f0: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
3200: 73 2e 4c 6f 67 50 72 65 70 61 72 65 29 20 3d 3d  s.LogPrepare) ==
3210: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
3220: 6e 46 6c 61 67 73 2e 4c 6f 67 50 72 65 70 61 72  nFlags.LogPrepar
3230: 65 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20  e)..      {..   
3240: 20 20 20 20 20 20 20 69 66 20 28 28 73 74 72 53         if ((strS
3250: 71 6c 20 3d 3d 20 6e 75 6c 6c 29 20 7c 7c 20 28  ql == null) || (
3260: 73 74 72 53 71 6c 2e 4c 65 6e 67 74 68 20 3d 3d  strSql.Length ==
3270: 20 30 29 20 7c 7c 20 28 73 74 72 53 71 6c 2e 54   0) || (strSql.T
3280: 72 69 6d 28 29 2e 4c 65 6e 67 74 68 20 3d 3d 20  rim().Length == 
3290: 30 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  0))..           
32a0: 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67     SQLiteLog.Log
32b0: 4d 65 73 73 61 67 65 28 30 2c 20 22 50 72 65 70  Message(0, "Prep
32c0: 61 72 69 6e 67 20 7b 3c 6e 6f 74 68 69 6e 67 3e  aring {<nothing>
32d0: 7d 2e 2e 2e 22 29 3b 0d 0a 20 20 20 20 20 20 20  }...");..       
32e0: 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 20     else..       
32f0: 20 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67         SQLiteLog
3300: 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53  .LogMessage(0, S
3310: 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 50 72  tring.Format("Pr
3320: 65 70 61 72 69 6e 67 20 7b 7b 7b 30 7d 7d 7d 2e  eparing {{{0}}}.
3330: 2e 2e 22 2c 20 73 74 72 53 71 6c 29 29 3b 0d 0a  ..", strSql));..
3340: 20 20 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d        }..#endif.
3350: 0a 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72 20  ...      IntPtr 
3360: 73 74 6d 74 20 3d 20 49 6e 74 50 74 72 2e 5a 65  stmt = IntPtr.Ze
3370: 72 6f 3b 0d 0a 20 20 20 20 20 20 49 6e 74 50 74  ro;..      IntPt
3380: 72 20 70 74 72 20 3d 20 49 6e 74 50 74 72 2e 5a  r ptr = IntPtr.Z
3390: 65 72 6f 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20  ero;..      int 
33a0: 6c 65 6e 20 3d 20 30 3b 0d 0a 20 20 20 20 20 20  len = 0;..      
33b0: 69 6e 74 20 6e 20 3d 20 31 37 3b 0d 0a 20 20 20  int n = 17;..   
33c0: 20 20 20 69 6e 74 20 72 65 74 72 69 65 73 20 3d     int retries =
33d0: 20 30 3b 0d 0a 20 20 20 20 20 20 62 79 74 65 5b   0;..      byte[
33e0: 5d 20 62 20 3d 20 54 6f 55 54 46 38 28 73 74 72  ] b = ToUTF8(str
33f0: 53 71 6c 29 3b 0d 0a 20 20 20 20 20 20 73 74 72  Sql);..      str
3400: 69 6e 67 20 74 79 70 65 64 65 66 73 20 3d 20 6e  ing typedefs = n
3410: 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 53 51 4c 69  ull;..      SQLi
3420: 74 65 53 74 61 74 65 6d 65 6e 74 20 63 6d 64 20  teStatement cmd 
3430: 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 52  = null;..      R
3440: 61 6e 64 6f 6d 20 72 6e 64 20 3d 20 6e 75 6c 6c  andom rnd = null
3450: 3b 0d 0a 20 20 20 20 20 20 75 69 6e 74 20 73 74  ;..      uint st
3460: 61 72 74 74 69 63 6b 20 3d 20 28 75 69 6e 74 29  arttick = (uint)
3470: 45 6e 76 69 72 6f 6e 6d 65 6e 74 2e 54 69 63 6b  Environment.Tick
3480: 43 6f 75 6e 74 3b 0d 0a 0d 0a 20 20 20 20 20 20  Count;....      
3490: 47 43 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20  GCHandle handle 
34a0: 3d 20 47 43 48 61 6e 64 6c 65 2e 41 6c 6c 6f 63  = GCHandle.Alloc
34b0: 28 62 2c 20 47 43 48 61 6e 64 6c 65 54 79 70 65  (b, GCHandleType
34c0: 2e 50 69 6e 6e 65 64 29 3b 0d 0a 20 20 20 20 20  .Pinned);..     
34d0: 20 49 6e 74 50 74 72 20 70 73 71 6c 20 3d 20 68   IntPtr psql = h
34e0: 61 6e 64 6c 65 2e 41 64 64 72 4f 66 50 69 6e 6e  andle.AddrOfPinn
34f0: 65 64 4f 62 6a 65 63 74 28 29 3b 0d 0a 20 20 20  edObject();..   
3500: 20 20 20 74 72 79 0d 0a 20 20 20 20 20 20 7b 0d     try..      {.
3510: 0a 20 20 20 20 20 20 20 20 77 68 69 6c 65 20 28  .        while (
3520: 28 6e 20 3d 3d 20 31 37 20 7c 7c 20 6e 20 3d 3d  (n == 17 || n ==
3530: 20 36 20 7c 7c 20 6e 20 3d 3d 20 35 29 20 26 26   6 || n == 5) &&
3540: 20 72 65 74 72 69 65 73 20 3c 20 33 29 0d 0a 20   retries < 3).. 
3550: 20 20 20 20 20 20 20 7b 0d 0a 23 69 66 20 21 53         {..#if !S
3560: 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a  QLITE_STANDARD..
3570: 20 20 20 20 20 20 20 20 20 20 6e 20 3d 20 55 6e            n = Un
3580: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
3590: 73 2e 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  s.sqlite3_prepar
35a0: 65 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20  e_interop(_sql, 
35b0: 70 73 71 6c 2c 20 62 2e 4c 65 6e 67 74 68 20 2d  psql, b.Length -
35c0: 20 31 2c 20 6f 75 74 20 73 74 6d 74 2c 20 6f 75   1, out stmt, ou
35d0: 74 20 70 74 72 2c 20 6f 75 74 20 6c 65 6e 29 3b  t ptr, out len);
35e0: 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20  ..#else..       
35f0: 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74     n = UnsafeNat
3600: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
3610: 65 33 5f 70 72 65 70 61 72 65 28 5f 73 71 6c 2c  e3_prepare(_sql,
3620: 20 70 73 71 6c 2c 20 62 2e 4c 65 6e 67 74 68 20   psql, b.Length 
3630: 2d 20 31 2c 20 6f 75 74 20 73 74 6d 74 2c 20 6f  - 1, out stmt, o
3640: 75 74 20 70 74 72 29 3b 0d 0a 20 20 20 20 20 20  ut ptr);..      
3650: 20 20 20 20 6c 65 6e 20 3d 20 2d 31 3b 0d 0a 23      len = -1;..#
3660: 65 6e 64 69 66 0d 0a 0d 0a 23 69 66 20 44 45 42  endif....#if DEB
3670: 55 47 20 26 26 20 21 4e 45 54 5f 43 4f 4d 50 41  UG && !NET_COMPA
3680: 43 54 5f 32 30 0d 0a 20 20 20 20 20 20 20 20 20  CT_20..         
3690: 20 54 72 61 63 65 2e 57 72 69 74 65 4c 69 6e 65   Trace.WriteLine
36a0: 28 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22  (String.Format("
36b0: 50 72 65 70 61 72 65 3a 20 7b 30 7d 22 2c 20 73  Prepare: {0}", s
36c0: 74 6d 74 29 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  tmt));..#endif..
36d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28  ..          if (
36e0: 6e 20 3d 3d 20 31 37 29 0d 0a 20 20 20 20 20 20  n == 17)..      
36f0: 20 20 20 20 20 20 72 65 74 72 69 65 73 2b 2b 3b        retries++;
3700: 0d 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65  ..          else
3710: 20 69 66 20 28 6e 20 3d 3d 20 31 29 0d 0a 20 20   if (n == 1)..  
3720: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
3730: 20 20 20 20 20 20 20 69 66 20 28 53 74 72 69 6e         if (Strin
3740: 67 2e 43 6f 6d 70 61 72 65 28 47 65 74 4c 61 73  g.Compare(GetLas
3750: 74 45 72 72 6f 72 28 29 2c 20 22 6e 65 61 72 20  tError(), "near 
3760: 5c 22 54 59 50 45 53 5c 22 3a 20 73 79 6e 74 61  \"TYPES\": synta
3770: 78 20 65 72 72 6f 72 22 2c 20 53 74 72 69 6e 67  x error", String
3780: 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e  Comparison.Ordin
3790: 61 6c 49 67 6e 6f 72 65 43 61 73 65 29 20 3d 3d  alIgnoreCase) ==
37a0: 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20   0)..           
37b0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
37c0: 20 20 69 6e 74 20 70 6f 73 20 3d 20 73 74 72 53    int pos = strS
37d0: 71 6c 2e 49 6e 64 65 78 4f 66 28 27 3b 27 29 3b  ql.IndexOf(';');
37e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
37f0: 69 66 20 28 70 6f 73 20 3d 3d 20 2d 31 29 20 70  if (pos == -1) p
3800: 6f 73 20 3d 20 73 74 72 53 71 6c 2e 4c 65 6e 67  os = strSql.Leng
3810: 74 68 20 2d 20 31 3b 0d 0a 0d 0a 20 20 20 20 20  th - 1;....     
3820: 20 20 20 20 20 20 20 20 20 74 79 70 65 64 65 66           typedef
3830: 73 20 3d 20 73 74 72 53 71 6c 2e 53 75 62 73 74  s = strSql.Subst
3840: 72 69 6e 67 28 30 2c 20 70 6f 73 20 2b 20 31 29  ring(0, pos + 1)
3850: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
3860: 20 73 74 72 53 71 6c 20 3d 20 73 74 72 53 71 6c   strSql = strSql
3870: 2e 53 75 62 73 74 72 69 6e 67 28 70 6f 73 20 2b  .Substring(pos +
3880: 20 31 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20   1);....        
3890: 20 20 20 20 20 20 73 74 72 52 65 6d 61 69 6e 20        strRemain 
38a0: 3d 20 22 22 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  = "";....       
38b0: 20 20 20 20 20 20 20 77 68 69 6c 65 20 28 63 6d         while (cm
38c0: 64 20 3d 3d 20 6e 75 6c 6c 20 26 26 20 73 74 72  d == null && str
38d0: 53 71 6c 2e 4c 65 6e 67 74 68 20 3e 20 30 29 0d  Sql.Length > 0).
38e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  .              {
38f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3900: 20 20 63 6d 64 20 3d 20 50 72 65 70 61 72 65 28    cmd = Prepare(
3910: 63 6e 6e 2c 20 73 74 72 53 71 6c 2c 20 70 72 65  cnn, strSql, pre
3920: 76 69 6f 75 73 2c 20 74 69 6d 65 6f 75 74 4d 53  vious, timeoutMS
3930: 2c 20 6f 75 74 20 73 74 72 52 65 6d 61 69 6e 29  , out strRemain)
3940: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
3950: 20 20 20 73 74 72 53 71 6c 20 3d 20 73 74 72 52     strSql = strR
3960: 65 6d 61 69 6e 3b 0d 0a 20 20 20 20 20 20 20 20  emain;..        
3970: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
3980: 20 20 20 20 20 20 20 20 20 69 66 20 28 63 6d 64           if (cmd
3990: 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20   != null)..     
39a0: 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 53             cmd.S
39b0: 65 74 54 79 70 65 73 28 74 79 70 65 64 65 66 73  etTypes(typedefs
39c0: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
39d0: 20 20 20 20 72 65 74 75 72 6e 20 63 6d 64 3b 0d      return cmd;.
39e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  .            }..
39f0: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
3a00: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
3a10: 20 20 20 20 20 20 20 20 20 20 20 20 65 6c 73 65              else
3a20: 20 69 66 20 28 5f 62 75 69 6c 64 69 6e 67 53 63   if (_buildingSc
3a30: 68 65 6d 61 20 3d 3d 20 66 61 6c 73 65 20 26 26  hema == false &&
3a40: 20 53 74 72 69 6e 67 2e 43 6f 6d 70 61 72 65 28   String.Compare(
3a50: 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 2c 20  GetLastError(), 
3a60: 30 2c 20 22 6e 6f 20 73 75 63 68 20 74 61 62 6c  0, "no such tabl
3a70: 65 3a 20 54 45 4d 50 2e 53 43 48 45 4d 41 22 2c  e: TEMP.SCHEMA",
3a80: 20 30 2c 20 32 36 2c 20 53 74 72 69 6e 67 43 6f   0, 26, StringCo
3a90: 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e 61 6c  mparison.Ordinal
3aa0: 49 67 6e 6f 72 65 43 61 73 65 29 20 3d 3d 20 30  IgnoreCase) == 0
3ab0: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  )..            {
3ac0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3ad0: 73 74 72 52 65 6d 61 69 6e 20 3d 20 22 22 3b 0d  strRemain = "";.
3ae0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5f  .              _
3af0: 62 75 69 6c 64 69 6e 67 53 63 68 65 6d 61 20 3d  buildingSchema =
3b00: 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20 20   true;..        
3b10: 20 20 20 20 20 20 74 72 79 0d 0a 20 20 20 20 20        try..     
3b20: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
3b30: 20 20 20 20 20 20 20 20 20 20 20 20 49 53 51 4c              ISQL
3b40: 69 74 65 53 63 68 65 6d 61 45 78 74 65 6e 73 69  iteSchemaExtensi
3b50: 6f 6e 73 20 65 78 74 20 3d 20 28 28 49 53 65 72  ons ext = ((ISer
3b60: 76 69 63 65 50 72 6f 76 69 64 65 72 29 53 51 4c  viceProvider)SQL
3b70: 69 74 65 46 61 63 74 6f 72 79 2e 49 6e 73 74 61  iteFactory.Insta
3b80: 6e 63 65 29 2e 47 65 74 53 65 72 76 69 63 65 28  nce).GetService(
3b90: 74 79 70 65 6f 66 28 49 53 51 4c 69 74 65 53 63  typeof(ISQLiteSc
3ba0: 68 65 6d 61 45 78 74 65 6e 73 69 6f 6e 73 29 29  hemaExtensions))
3bb0: 20 61 73 20 49 53 51 4c 69 74 65 53 63 68 65 6d   as ISQLiteSchem
3bc0: 61 45 78 74 65 6e 73 69 6f 6e 73 3b 0d 0a 0d 0a  aExtensions;....
3bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3be0: 69 66 20 28 65 78 74 20 21 3d 20 6e 75 6c 6c 29  if (ext != null)
3bf0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3c00: 20 20 20 20 65 78 74 2e 42 75 69 6c 64 54 65 6d      ext.BuildTem
3c10: 70 53 63 68 65 6d 61 28 63 6e 6e 29 3b 0d 0a 0d  pSchema(cnn);...
3c20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3c30: 20 77 68 69 6c 65 20 28 63 6d 64 20 3d 3d 20 6e   while (cmd == n
3c40: 75 6c 6c 20 26 26 20 73 74 72 53 71 6c 2e 4c 65  ull && strSql.Le
3c50: 6e 67 74 68 20 3e 20 30 29 0d 0a 20 20 20 20 20  ngth > 0)..     
3c60: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
3c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3c80: 63 6d 64 20 3d 20 50 72 65 70 61 72 65 28 63 6e  cmd = Prepare(cn
3c90: 6e 2c 20 73 74 72 53 71 6c 2c 20 70 72 65 76 69  n, strSql, previ
3ca0: 6f 75 73 2c 20 74 69 6d 65 6f 75 74 4d 53 2c 20  ous, timeoutMS, 
3cb0: 6f 75 74 20 73 74 72 52 65 6d 61 69 6e 29 3b 0d  out strRemain);.
3cc0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3cd0: 20 20 20 73 74 72 53 71 6c 20 3d 20 73 74 72 52     strSql = strR
3ce0: 65 6d 61 69 6e 3b 0d 0a 20 20 20 20 20 20 20 20  emain;..        
3cf0: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20          }....   
3d00: 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74               ret
3d10: 75 72 6e 20 63 6d 64 3b 0d 0a 20 20 20 20 20 20  urn cmd;..      
3d20: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
3d30: 20 20 20 20 20 20 20 20 20 66 69 6e 61 6c 6c 79           finally
3d40: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3d50: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
3d60: 20 20 20 5f 62 75 69 6c 64 69 6e 67 53 63 68 65     _buildingSche
3d70: 6d 61 20 3d 20 66 61 6c 73 65 3b 0d 0a 20 20 20  ma = false;..   
3d80: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20             }..  
3d90: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 23 65 6e            }..#en
3da0: 64 69 66 0d 0a 20 20 20 20 20 20 20 20 20 20 7d  dif..          }
3db0: 0d 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65  ..          else
3dc0: 20 69 66 20 28 6e 20 3d 3d 20 36 20 7c 7c 20 6e   if (n == 6 || n
3dd0: 20 3d 3d 20 35 29 20 2f 2f 20 4c 6f 63 6b 65 64   == 5) // Locked
3de0: 20 2d 2d 20 64 65 6c 61 79 20 61 20 73 6d 61 6c   -- delay a smal
3df0: 6c 20 61 6d 6f 75 6e 74 20 62 65 66 6f 72 65 20  l amount before 
3e00: 72 65 74 72 79 69 6e 67 0d 0a 20 20 20 20 20 20  retrying..      
3e10: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
3e20: 20 20 20 2f 2f 20 4b 65 65 70 20 74 72 79 69 6e     // Keep tryin
3e30: 67 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  g..            i
3e40: 66 20 28 72 6e 64 20 3d 3d 20 6e 75 6c 6c 29 20  f (rnd == null) 
3e50: 2f 2f 20 46 69 72 73 74 20 74 69 6d 65 20 77 65  // First time we
3e60: 27 76 65 20 65 6e 63 6f 75 6e 74 65 72 65 64 20  've encountered 
3e70: 74 68 65 20 6c 6f 63 6b 0d 0a 20 20 20 20 20 20  the lock..      
3e80: 20 20 20 20 20 20 20 20 72 6e 64 20 3d 20 6e 65          rnd = ne
3e90: 77 20 52 61 6e 64 6f 6d 28 29 3b 0d 0a 0d 0a 20  w Random();.... 
3ea0: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 49 66             // If
3eb0: 20 77 65 27 76 65 20 65 78 63 65 65 64 65 64 20   we've exceeded 
3ec0: 74 68 65 20 63 6f 6d 6d 61 6e 64 27 73 20 74 69  the command's ti
3ed0: 6d 65 6f 75 74 2c 20 67 69 76 65 20 75 70 20 61  meout, give up a
3ee0: 6e 64 20 74 68 72 6f 77 20 61 6e 20 65 72 72 6f  nd throw an erro
3ef0: 72 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  r..            i
3f00: 66 20 28 28 75 69 6e 74 29 45 6e 76 69 72 6f 6e  f ((uint)Environ
3f10: 6d 65 6e 74 2e 54 69 63 6b 43 6f 75 6e 74 20 2d  ment.TickCount -
3f20: 20 73 74 61 72 74 74 69 63 6b 20 3e 20 74 69 6d   starttick > tim
3f30: 65 6f 75 74 4d 53 29 0d 0a 20 20 20 20 20 20 20  eoutMS)..       
3f40: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
3f50: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
3f60: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
3f70: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
3f80: 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ));..           
3f90: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
3fa0: 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20  else..          
3fb0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
3fc0: 20 20 20 2f 2f 20 4f 74 68 65 72 77 69 73 65 20     // Otherwise 
3fd0: 73 6c 65 65 70 20 66 6f 72 20 61 20 72 61 6e 64  sleep for a rand
3fe0: 6f 6d 20 61 6d 6f 75 6e 74 20 6f 66 20 74 69 6d  om amount of tim
3ff0: 65 20 75 70 20 74 6f 20 31 35 30 6d 73 0d 0a 20  e up to 150ms.. 
4000: 20 20 20 20 20 20 20 20 20 20 20 20 20 53 79 73               Sys
4010: 74 65 6d 2e 54 68 72 65 61 64 69 6e 67 2e 54 68  tem.Threading.Th
4020: 72 65 61 64 2e 53 6c 65 65 70 28 72 6e 64 2e 4e  read.Sleep(rnd.N
4030: 65 78 74 28 31 2c 20 31 35 30 29 29 3b 0d 0a 20  ext(1, 150));.. 
4040: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20             }..  
4050: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
4060: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
4070: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
4080: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
4090: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
40a0: 72 72 6f 72 28 29 29 3b 0d 0a 0d 0a 20 20 20 20  rror());....    
40b0: 20 20 20 20 73 74 72 52 65 6d 61 69 6e 20 3d 20      strRemain = 
40c0: 55 54 46 38 54 6f 53 74 72 69 6e 67 28 70 74 72  UTF8ToString(ptr
40d0: 2c 20 6c 65 6e 29 3b 0d 0a 0d 0a 20 20 20 20 20  , len);....     
40e0: 20 20 20 69 66 20 28 73 74 6d 74 20 21 3d 20 49     if (stmt != I
40f0: 6e 74 50 74 72 2e 5a 65 72 6f 29 20 63 6d 64 20  ntPtr.Zero) cmd 
4100: 3d 20 6e 65 77 20 53 51 4c 69 74 65 53 74 61 74  = new SQLiteStat
4110: 65 6d 65 6e 74 28 74 68 69 73 2c 20 66 6c 61 67  ement(this, flag
4120: 73 2c 20 6e 65 77 20 53 51 4c 69 74 65 53 74 61  s, new SQLiteSta
4130: 74 65 6d 65 6e 74 48 61 6e 64 6c 65 28 5f 73 71  tementHandle(_sq
4140: 6c 2c 20 73 74 6d 74 29 2c 20 73 74 72 53 71 6c  l, stmt), strSql
4150: 2e 53 75 62 73 74 72 69 6e 67 28 30 2c 20 73 74  .Substring(0, st
4160: 72 53 71 6c 2e 4c 65 6e 67 74 68 20 2d 20 73 74  rSql.Length - st
4170: 72 52 65 6d 61 69 6e 2e 4c 65 6e 67 74 68 29 2c  rRemain.Length),
4180: 20 70 72 65 76 69 6f 75 73 29 3b 0d 0a 0d 0a 20   previous);.... 
4190: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 63 6d         return cm
41a0: 64 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  d;..      }..   
41b0: 20 20 20 66 69 6e 61 6c 6c 79 0d 0a 20 20 20 20     finally..    
41c0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 68 61 6e    {..        han
41d0: 64 6c 65 2e 46 72 65 65 28 29 3b 0d 0a 20 20 20  dle.Free();..   
41e0: 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 23     }..    }....#
41f0: 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d  if !PLATFORM_COM
4200: 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20  PACTFRAMEWORK.. 
4210: 20 20 20 70 72 6f 74 65 63 74 65 64 20 73 74 61     protected sta
4220: 74 69 63 20 76 6f 69 64 20 4c 6f 67 42 69 6e 64  tic void LogBind
4230: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
4240: 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 2c 20 69  Handle handle, i
4250: 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b  nt index)..    {
4260: 0d 0a 20 20 20 20 20 20 20 20 49 6e 74 50 74 72  ..        IntPtr
4270: 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20 3d 20   handleIntPtr = 
4280: 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20  handle;....     
4290: 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67     SQLiteLog.Log
42a0: 4d 65 73 73 61 67 65 28 30 2c 20 53 74 72 69 6e  Message(0, Strin
42b0: 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20 20 20 20  g.Format(..     
42c0: 20 20 20 20 20 20 20 22 42 69 6e 64 69 6e 67 20         "Binding 
42d0: 73 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20 70 61  statement {0} pa
42e0: 72 61 6d 74 65 72 20 23 7b 31 7d 20 61 73 20 4e  ramter #{1} as N
42f0: 55 4c 4c 2e 2e 2e 22 2c 0d 0a 20 20 20 20 20 20  ULL...",..      
4300: 20 20 20 20 20 20 68 61 6e 64 6c 65 49 6e 74 50        handleIntP
4310: 74 72 2c 20 69 6e 64 65 78 29 29 3b 0d 0a 20 20  tr, index));..  
4320: 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 6f 74 65    }....    prote
4330: 63 74 65 64 20 73 74 61 74 69 63 20 76 6f 69 64  cted static void
4340: 20 4c 6f 67 42 69 6e 64 28 53 51 4c 69 74 65 53   LogBind(SQLiteS
4350: 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68  tatementHandle h
4360: 61 6e 64 6c 65 2c 20 69 6e 74 20 69 6e 64 65 78  andle, int index
4370: 2c 20 56 61 6c 75 65 54 79 70 65 20 76 61 6c 75  , ValueType valu
4380: 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  e)..    {..     
4390: 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64 6c 65     IntPtr handle
43a0: 49 6e 74 50 74 72 20 3d 20 68 61 6e 64 6c 65 3b  IntPtr = handle;
43b0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69  ....        SQLi
43c0: 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61 67 65  teLog.LogMessage
43d0: 28 30 2c 20 53 74 72 69 6e 67 2e 46 6f 72 6d 61  (0, String.Forma
43e0: 74 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  t(..            
43f0: 22 42 69 6e 64 69 6e 67 20 73 74 61 74 65 6d 65  "Binding stateme
4400: 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74 65 72 20  nt {0} paramter 
4410: 23 7b 31 7d 20 61 73 20 74 79 70 65 20 7b 32 7d  #{1} as type {2}
4420: 20 77 69 74 68 20 76 61 6c 75 65 20 7b 7b 7b 33   with value {{{3
4430: 7d 7d 7d 2e 2e 2e 22 2c 0d 0a 20 20 20 20 20 20  }}}...",..      
4440: 20 20 20 20 20 20 68 61 6e 64 6c 65 49 6e 74 50        handleIntP
4450: 74 72 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65  tr, index, value
4460: 2e 47 65 74 54 79 70 65 28 29 2c 20 76 61 6c 75  .GetType(), valu
4470: 65 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  e));..    }.... 
4480: 20 20 20 70 72 69 76 61 74 65 20 73 74 61 74 69     private stati
4490: 63 20 73 74 72 69 6e 67 20 46 6f 72 6d 61 74 44  c string FormatD
44a0: 61 74 65 54 69 6d 65 28 44 61 74 65 54 69 6d 65  ateTime(DateTime
44b0: 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a   value)..    {..
44c0: 20 20 20 20 20 20 20 20 53 74 72 69 6e 67 42 75          StringBu
44d0: 69 6c 64 65 72 20 72 65 73 75 6c 74 20 3d 20 6e  ilder result = n
44e0: 65 77 20 53 74 72 69 6e 67 42 75 69 6c 64 65 72  ew StringBuilder
44f0: 28 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72  ();....        r
4500: 65 73 75 6c 74 2e 41 70 70 65 6e 64 28 76 61 6c  esult.Append(val
4510: 75 65 2e 54 6f 53 74 72 69 6e 67 28 22 79 79 79  ue.ToString("yyy
4520: 79 2d 4d 4d 2d 64 64 54 48 48 3a 6d 6d 3a 73 73  y-MM-ddTHH:mm:ss
4530: 2e 46 46 46 46 46 46 46 4b 22 29 29 3b 0d 0a 20  .FFFFFFFK"));.. 
4540: 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e 41 70         result.Ap
4550: 70 65 6e 64 28 27 20 27 29 3b 0d 0a 20 20 20 20  pend(' ');..    
4560: 20 20 20 20 72 65 73 75 6c 74 2e 41 70 70 65 6e      result.Appen
4570: 64 28 76 61 6c 75 65 2e 4b 69 6e 64 29 3b 0d 0a  d(value.Kind);..
4580: 20 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e 41          result.A
4590: 70 70 65 6e 64 28 27 20 27 29 3b 0d 0a 20 20 20  ppend(' ');..   
45a0: 20 20 20 20 20 72 65 73 75 6c 74 2e 41 70 70 65       result.Appe
45b0: 6e 64 28 76 61 6c 75 65 2e 54 69 63 6b 73 29 3b  nd(value.Ticks);
45c0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75  ....        retu
45d0: 72 6e 20 72 65 73 75 6c 74 2e 54 6f 53 74 72 69  rn result.ToStri
45e0: 6e 67 28 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  ng();..    }....
45f0: 20 20 20 20 70 72 6f 74 65 63 74 65 64 20 73 74      protected st
4600: 61 74 69 63 20 76 6f 69 64 20 4c 6f 67 42 69 6e  atic void LogBin
4610: 64 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  d(SQLiteStatemen
4620: 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 2c 20  tHandle handle, 
4630: 69 6e 74 20 69 6e 64 65 78 2c 20 44 61 74 65 54  int index, DateT
4640: 69 6d 65 20 76 61 6c 75 65 29 0d 0a 20 20 20 20  ime value)..    
4650: 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e 74 50 74  {..        IntPt
4660: 72 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20 3d  r handleIntPtr =
4670: 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20   handle;....    
4680: 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f      SQLiteLog.Lo
4690: 67 4d 65 73 73 61 67 65 28 30 2c 20 53 74 72 69  gMessage(0, Stri
46a0: 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20 20 20  ng.Format(..    
46b0: 20 20 20 20 20 20 20 20 22 42 69 6e 64 69 6e 67          "Binding
46c0: 20 73 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20 70   statement {0} p
46d0: 61 72 61 6d 74 65 72 20 23 7b 31 7d 20 61 73 20  aramter #{1} as 
46e0: 74 79 70 65 20 7b 32 7d 20 77 69 74 68 20 76 61  type {2} with va
46f0: 6c 75 65 20 7b 7b 7b 33 7d 7d 7d 2e 2e 2e 22 2c  lue {{{3}}}...",
4700: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 68 61  ..            ha
4710: 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e 64 65  ndleIntPtr, inde
4720: 78 2c 20 74 79 70 65 6f 66 28 44 61 74 65 54 69  x, typeof(DateTi
4730: 6d 65 29 2c 20 46 6f 72 6d 61 74 44 61 74 65 54  me), FormatDateT
4740: 69 6d 65 28 76 61 6c 75 65 29 29 29 3b 0d 0a 20  ime(value)));.. 
4750: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 6f 74     }....    prot
4760: 65 63 74 65 64 20 73 74 61 74 69 63 20 76 6f 69  ected static voi
4770: 64 20 4c 6f 67 42 69 6e 64 28 53 51 4c 69 74 65  d LogBind(SQLite
4780: 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20  StatementHandle 
4790: 68 61 6e 64 6c 65 2c 20 69 6e 74 20 69 6e 64 65  handle, int inde
47a0: 78 2c 20 73 74 72 69 6e 67 20 76 61 6c 75 65 29  x, string value)
47b0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
47c0: 20 49 6e 74 50 74 72 20 68 61 6e 64 6c 65 49 6e   IntPtr handleIn
47d0: 74 50 74 72 20 3d 20 68 61 6e 64 6c 65 3b 0d 0a  tPtr = handle;..
47e0: 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65  ..        SQLite
47f0: 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30  Log.LogMessage(0
4800: 2c 20 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28  , String.Format(
4810: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 22 42  ..            "B
4820: 69 6e 64 69 6e 67 20 73 74 61 74 65 6d 65 6e 74  inding statement
4830: 20 7b 30 7d 20 70 61 72 61 6d 74 65 72 20 23 7b   {0} paramter #{
4840: 31 7d 20 61 73 20 74 79 70 65 20 7b 32 7d 20 77  1} as type {2} w
4850: 69 74 68 20 76 61 6c 75 65 20 7b 7b 7b 33 7d 7d  ith value {{{3}}
4860: 7d 2e 2e 2e 22 2c 0d 0a 20 20 20 20 20 20 20 20  }...",..        
4870: 20 20 20 20 68 61 6e 64 6c 65 49 6e 74 50 74 72      handleIntPtr
4880: 2c 20 69 6e 64 65 78 2c 20 74 79 70 65 6f 66 28  , index, typeof(
4890: 53 74 72 69 6e 67 29 2c 20 28 76 61 6c 75 65 20  String), (value 
48a0: 21 3d 20 6e 75 6c 6c 29 20 3f 20 76 61 6c 75 65  != null) ? value
48b0: 20 3a 20 22 3c 6e 75 6c 6c 3e 22 29 29 3b 0d 0a   : "<null>"));..
48c0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69      }....    pri
48d0: 76 61 74 65 20 73 74 61 74 69 63 20 73 74 72 69  vate static stri
48e0: 6e 67 20 54 6f 48 65 78 61 64 65 63 69 6d 61 6c  ng ToHexadecimal
48f0: 53 74 72 69 6e 67 28 0d 0a 20 20 20 20 20 20 20  String(..       
4900: 20 62 79 74 65 5b 5d 20 61 72 72 61 79 0d 0a 20   byte[] array.. 
4910: 20 20 20 20 20 20 20 29 0d 0a 20 20 20 20 7b 0d         )..    {.
4920: 0a 20 20 20 20 20 20 20 20 69 66 20 28 61 72 72  .        if (arr
4930: 61 79 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20  ay == null)..   
4940: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20           return 
4950: 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  null;....       
4960: 20 53 74 72 69 6e 67 42 75 69 6c 64 65 72 20 72   StringBuilder r
4970: 65 73 75 6c 74 20 3d 20 6e 65 77 20 53 74 72 69  esult = new Stri
4980: 6e 67 42 75 69 6c 64 65 72 28 61 72 72 61 79 2e  ngBuilder(array.
4990: 4c 65 6e 67 74 68 20 2a 20 32 29 3b 0d 0a 0d 0a  Length * 2);....
49a0: 20 20 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 67          int leng
49b0: 74 68 20 3d 20 61 72 72 61 79 2e 4c 65 6e 67 74  th = array.Lengt
49c0: 68 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 66 6f  h;....        fo
49d0: 72 20 28 69 6e 74 20 69 6e 64 65 78 20 3d 20 30  r (int index = 0
49e0: 3b 20 69 6e 64 65 78 20 3c 20 6c 65 6e 67 74 68  ; index < length
49f0: 3b 20 69 6e 64 65 78 2b 2b 29 0d 0a 20 20 20 20  ; index++)..    
4a00: 20 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e 41          result.A
4a10: 70 70 65 6e 64 28 61 72 72 61 79 5b 69 6e 64 65  ppend(array[inde
4a20: 78 5d 2e 54 6f 53 74 72 69 6e 67 28 22 78 32 22  x].ToString("x2"
4a30: 29 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72  ));....        r
4a40: 65 74 75 72 6e 20 72 65 73 75 6c 74 2e 54 6f 53  eturn result.ToS
4a50: 74 72 69 6e 67 28 29 3b 0d 0a 20 20 20 20 7d 0d  tring();..    }.
4a60: 0a 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64  ...    protected
4a70: 20 73 74 61 74 69 63 20 76 6f 69 64 20 4c 6f 67   static void Log
4a80: 42 69 6e 64 28 53 51 4c 69 74 65 53 74 61 74 65  Bind(SQLiteState
4a90: 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c  mentHandle handl
4aa0: 65 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 62 79  e, int index, by
4ab0: 74 65 5b 5d 20 76 61 6c 75 65 29 0d 0a 20 20 20  te[] value)..   
4ac0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e 74 50   {..        IntP
4ad0: 74 72 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20  tr handleIntPtr 
4ae0: 3d 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20  = handle;....   
4af0: 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c       SQLiteLog.L
4b00: 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53 74 72  ogMessage(0, Str
4b10: 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20 20  ing.Format(..   
4b20: 20 20 20 20 20 20 20 20 20 22 42 69 6e 64 69 6e           "Bindin
4b30: 67 20 73 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20  g statement {0} 
4b40: 70 61 72 61 6d 74 65 72 20 23 7b 31 7d 20 61 73  paramter #{1} as
4b50: 20 74 79 70 65 20 7b 32 7d 20 77 69 74 68 20 76   type {2} with v
4b60: 61 6c 75 65 20 7b 7b 7b 33 7d 7d 7d 2e 2e 2e 22  alue {{{3}}}..."
4b70: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 68  ,..            h
4b80: 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e 64  andleIntPtr, ind
4b90: 65 78 2c 20 74 79 70 65 6f 66 28 42 79 74 65 5b  ex, typeof(Byte[
4ba0: 5d 29 2c 20 28 76 61 6c 75 65 20 21 3d 20 6e 75  ]), (value != nu
4bb0: 6c 6c 29 20 3f 20 54 6f 48 65 78 61 64 65 63 69  ll) ? ToHexadeci
4bc0: 6d 61 6c 53 74 72 69 6e 67 28 76 61 6c 75 65 29  malString(value)
4bd0: 20 3a 20 22 3c 6e 75 6c 6c 3e 22 29 29 3b 0d 0a   : "<null>"));..
4be0: 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d      }..#endif...
4bf0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
4c00: 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64  erride void Bind
4c10: 5f 44 6f 75 62 6c 65 28 53 51 4c 69 74 65 53 74  _Double(SQLiteSt
4c20: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51  atement stmt, SQ
4c30: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
4c40: 61 67 73 20 66 6c 61 67 73 2c 20 69 6e 74 20 69  ags flags, int i
4c50: 6e 64 65 78 2c 20 64 6f 75 62 6c 65 20 76 61 6c  ndex, double val
4c60: 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ue)..    {..    
4c70: 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d      SQLiteStatem
4c80: 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65  entHandle handle
4c90: 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f   = stmt._sqlite_
4ca0: 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c  stmt;....#if !PL
4cb0: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
4cc0: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20  AMEWORK..       
4cd0: 20 69 66 20 28 28 66 6c 61 67 73 20 26 20 53 51   if ((flags & SQ
4ce0: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
4cf0: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20  ags.LogBind) == 
4d00: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
4d10: 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a  Flags.LogBind)..
4d20: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
4d30: 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68         LogBind(h
4d40: 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61  andle, index, va
4d50: 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d  lue);..        }
4d60: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20  ....        int 
4d70: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
4d80: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
4d90: 62 69 6e 64 5f 64 6f 75 62 6c 65 28 68 61 6e 64  bind_double(hand
4da0: 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65  le, index, value
4db0: 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20  );..#else..     
4dc0: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
4dd0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
4de0: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62  qlite3_bind_doub
4df0: 6c 65 5f 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c  le_interop(handl
4e00: 65 2c 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61  e, index, ref va
4e10: 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20  lue);..#endif.. 
4e20: 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30         if (n > 0
4e30: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
4e40: 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47  teException(n, G
4e50: 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d  etLastError());.
4e60: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
4e70: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
4e80: 76 6f 69 64 20 42 69 6e 64 5f 49 6e 74 33 32 28  void Bind_Int32(
4e90: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
4ea0: 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e 6e  stmt, SQLiteConn
4eb0: 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61 67  ectionFlags flag
4ec0: 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69 6e  s, int index, in
4ed0: 74 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d  t value)..    {.
4ee0: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 53  .        SQLiteS
4ef0: 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68  tatementHandle h
4f00: 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71  andle = stmt._sq
4f10: 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69  lite_stmt;....#i
4f20: 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50  f !PLATFORM_COMP
4f30: 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20  ACTFRAMEWORK..  
4f40: 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73        if ((flags
4f50: 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74   & SQLiteConnect
4f60: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
4f70: 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65  ) == SQLiteConne
4f80: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
4f90: 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  nd)..        {..
4fa0: 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67 42              LogB
4fb0: 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65  ind(handle, inde
4fc0: 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20  x, value);..    
4fd0: 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d      }..#endif...
4fe0: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  .        int n =
4ff0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
5000: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
5010: 64 5f 69 6e 74 28 68 61 6e 64 6c 65 2c 20 69 6e  d_int(handle, in
5020: 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20  dex, value);..  
5030: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
5040: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
5050: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65  eException(n, Ge
5060: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
5070: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
5080: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
5090: 6f 69 64 20 42 69 6e 64 5f 55 49 6e 74 33 32 28  oid Bind_UInt32(
50a0: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
50b0: 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e 6e  stmt, SQLiteConn
50c0: 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61 67  ectionFlags flag
50d0: 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 75 69  s, int index, ui
50e0: 6e 74 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b  nt value)..    {
50f0: 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65  ..        SQLite
5100: 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20  StatementHandle 
5110: 68 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73  handle = stmt._s
5120: 71 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23  qlite_stmt;....#
5130: 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d  if !PLATFORM_COM
5140: 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20  PACTFRAMEWORK.. 
5150: 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67         if ((flag
5160: 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63  s & SQLiteConnec
5170: 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e  tionFlags.LogBin
5180: 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e  d) == SQLiteConn
5190: 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42  ectionFlags.LogB
51a0: 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d  ind)..        {.
51b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67  .            Log
51c0: 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64  Bind(handle, ind
51d0: 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20  ex, value);..   
51e0: 20 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a       }..#endif..
51f0: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20  ..        int n 
5200: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
5210: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69  thods.sqlite3_bi
5220: 6e 64 5f 75 69 6e 74 28 68 61 6e 64 6c 65 2c 20  nd_uint(handle, 
5230: 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a  index, value);..
5240: 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20          if (n > 
5250: 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c  0) throw new SQL
5260: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
5270: 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b  GetLastError());
5280: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
5290: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
52a0: 20 76 6f 69 64 20 42 69 6e 64 5f 49 6e 74 36 34   void Bind_Int64
52b0: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
52c0: 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e   stmt, SQLiteCon
52d0: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61  nectionFlags fla
52e0: 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 6c  gs, int index, l
52f0: 6f 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20 20 20  ong value)..    
5300: 7b 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74  {..        SQLit
5310: 65 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65  eStatementHandle
5320: 20 68 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f   handle = stmt._
5330: 73 71 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a  sqlite_stmt;....
5340: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
5350: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
5360: 20 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61          if ((fla
5370: 67 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65  gs & SQLiteConne
5380: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
5390: 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e  nd) == SQLiteCon
53a0: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67  nectionFlags.Log
53b0: 42 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b  Bind)..        {
53c0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f  ..            Lo
53d0: 67 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e  gBind(handle, in
53e0: 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20  dex, value);..  
53f0: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
5400: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
5410: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
5420: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36  qlite3_bind_int6
5430: 34 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c  4(handle, index,
5440: 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c 73 65 0d   value);..#else.
5450: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  .        int n =
5460: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
5470: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
5480: 64 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28  d_int64_interop(
5490: 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 72  handle, index, r
54a0: 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64  ef value);..#end
54b0: 69 66 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  if..        if (
54c0: 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77  n > 0) throw new
54d0: 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e   SQLiteException
54e0: 28 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72  (n, GetLastError
54f0: 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ());..    }.... 
5500: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
5510: 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 55  ride void Bind_U
5520: 49 6e 74 36 34 28 53 51 4c 69 74 65 53 74 61 74  Int64(SQLiteStat
5530: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51 4c 69  ement stmt, SQLi
5540: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
5550: 73 20 66 6c 61 67 73 2c 20 69 6e 74 20 69 6e 64  s flags, int ind
5560: 65 78 2c 20 75 6c 6f 6e 67 20 76 61 6c 75 65 29  ex, ulong value)
5570: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
5580: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
5590: 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20  Handle handle = 
55a0: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
55b0: 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46  t;....#if !PLATF
55c0: 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45  ORM_COMPACTFRAME
55d0: 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 69 66  WORK..        if
55e0: 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74   ((flags & SQLit
55f0: 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73  eConnectionFlags
5600: 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c  .LogBind) == SQL
5610: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
5620: 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20  gs.LogBind)..   
5630: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
5640: 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64      LogBind(hand
5650: 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65  le, index, value
5660: 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 0d  );..        }...
5670: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  .        int n =
5680: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
5690: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
56a0: 64 5f 75 69 6e 74 36 34 28 68 61 6e 64 6c 65 2c  d_uint64(handle,
56b0: 20 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d   index, value);.
56c0: 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20  .#else..        
56d0: 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61  int n = UnsafeNa
56e0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
56f0: 74 65 33 5f 62 69 6e 64 5f 75 69 6e 74 36 34 5f  te3_bind_uint64_
5700: 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c 65 2c 20  interop(handle, 
5710: 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c 75 65  index, ref value
5720: 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20  );..#endif..    
5730: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
5740: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
5750: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c  xception(n, GetL
5760: 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20  astError());..  
5770: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
5780: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
5790: 64 20 42 69 6e 64 5f 54 65 78 74 28 53 51 4c 69  d Bind_Text(SQLi
57a0: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
57b0: 2c 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  , SQLiteConnecti
57c0: 6f 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69  onFlags flags, i
57d0: 6e 74 20 69 6e 64 65 78 2c 20 73 74 72 69 6e 67  nt index, string
57e0: 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a   value)..    {..
57f0: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 53 74          SQLiteSt
5800: 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61  atementHandle ha
5810: 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71 6c  ndle = stmt._sql
5820: 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66  ite_stmt;....#if
5830: 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41   !PLATFORM_COMPA
5840: 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20  CTFRAMEWORK..   
5850: 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73 20       if ((flags 
5860: 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  & SQLiteConnecti
5870: 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29  onFlags.LogBind)
5880: 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63   == SQLiteConnec
5890: 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e  tionFlags.LogBin
58a0: 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  d)..        {.. 
58b0: 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67 42 69             LogBi
58c0: 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  nd(handle, index
58d0: 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20  , value);..     
58e0: 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a     }..#endif....
58f0: 20 20 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62          byte[] b
5900: 20 3d 20 54 6f 55 54 46 38 28 76 61 6c 75 65 29   = ToUTF8(value)
5910: 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f  ;....#if !PLATFO
5920: 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57  RM_COMPACTFRAMEW
5930: 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ORK..        if 
5940: 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65  ((flags & SQLite
5950: 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e  ConnectionFlags.
5960: 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69  LogBind) == SQLi
5970: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
5980: 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20  s.LogBind)..    
5990: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
59a0: 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c     LogBind(handl
59b0: 65 2c 20 69 6e 64 65 78 2c 20 62 29 3b 0d 0a 20  e, index, b);.. 
59c0: 20 20 20 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66         }..#endif
59d0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20  ....        int 
59e0: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
59f0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
5a00: 62 69 6e 64 5f 74 65 78 74 28 68 61 6e 64 6c 65  bind_text(handle
5a10: 2c 20 69 6e 64 65 78 2c 20 62 2c 20 62 2e 4c 65  , index, b, b.Le
5a20: 6e 67 74 68 20 2d 20 31 2c 20 28 49 6e 74 50 74  ngth - 1, (IntPt
5a30: 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20 20 20  r)(-1));..      
5a40: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
5a50: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
5a60: 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73  eption(n, GetLas
5a70: 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20  tError());..    
5a80: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
5a90: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
5aa0: 42 69 6e 64 5f 44 61 74 65 54 69 6d 65 28 53 51  Bind_DateTime(SQ
5ab0: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
5ac0: 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63  mt, SQLiteConnec
5ad0: 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c  tionFlags flags,
5ae0: 20 69 6e 74 20 69 6e 64 65 78 2c 20 44 61 74 65   int index, Date
5af0: 54 69 6d 65 20 64 74 29 0d 0a 20 20 20 20 7b 0d  Time dt)..    {.
5b00: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 53  .        SQLiteS
5b10: 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68  tatementHandle h
5b20: 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71  andle = stmt._sq
5b30: 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69  lite_stmt;....#i
5b40: 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50  f !PLATFORM_COMP
5b50: 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20  ACTFRAMEWORK..  
5b60: 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73        if ((flags
5b70: 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74   & SQLiteConnect
5b80: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
5b90: 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65  ) == SQLiteConne
5ba0: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
5bb0: 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  nd)..        {..
5bc0: 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67 42              LogB
5bd0: 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65  ind(handle, inde
5be0: 78 2c 20 64 74 29 3b 0d 0a 20 20 20 20 20 20 20  x, dt);..       
5bf0: 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20   }..#endif....  
5c00: 20 20 20 20 20 20 73 77 69 74 63 68 20 28 5f 64        switch (_d
5c10: 61 74 65 74 69 6d 65 46 6f 72 6d 61 74 29 0d 0a  atetimeFormat)..
5c20: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
5c30: 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 69         case SQLi
5c40: 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 54 69  teDateFormats.Ti
5c50: 63 6b 73 3a 0d 0a 20 20 20 20 20 20 20 20 20 20  cks:..          
5c60: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
5c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 6c 6f 6e               lon
5c80: 67 20 76 61 6c 75 65 20 3d 20 64 74 2e 54 69 63  g value = dt.Tic
5c90: 6b 73 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54  ks;....#if !PLAT
5ca0: 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d  FORM_COMPACTFRAM
5cb0: 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 20  EWORK..         
5cc0: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 28             if ((
5cd0: 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65 43 6f  flags & SQLiteCo
5ce0: 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f  nnectionFlags.Lo
5cf0: 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65  gBind) == SQLite
5d00: 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e  ConnectionFlags.
5d10: 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20 20 20  LogBind)..      
5d20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d                {.
5d30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
5d40: 20 20 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64           LogBind
5d50: 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20  (handle, index, 
5d60: 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20  value);..       
5d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a               }..
5d80: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
5d90: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
5da0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
5db0: 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69  s.sqlite3_bind_i
5dc0: 6e 74 36 34 28 68 61 6e 64 6c 65 2c 20 69 6e 64  nt64(handle, ind
5dd0: 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c  ex, value);..#el
5de0: 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  se..            
5df0: 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20          int n = 
5e00: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
5e10: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
5e20: 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 68  _int64_interop(h
5e30: 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 72 65  andle, index, re
5e40: 66 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69  f value);..#endi
5e50: 66 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  f..             
5e60: 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30         if (n > 0
5e70: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
5e80: 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47  teException(n, G
5e90: 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d  etLastError());.
5ea0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
5eb0: 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20       break;..   
5ec0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a               }..
5ed0: 20 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65              case
5ee0: 20 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61   SQLiteDateForma
5ef0: 74 73 2e 4a 75 6c 69 61 6e 44 61 79 3a 0d 0a 20  ts.JulianDay:.. 
5f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
5f10: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
5f20: 20 20 20 20 20 20 64 6f 75 62 6c 65 20 76 61 6c        double val
5f30: 75 65 20 3d 20 54 6f 4a 75 6c 69 61 6e 44 61 79  ue = ToJulianDay
5f40: 28 64 74 29 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c  (dt);....#if !PL
5f50: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
5f60: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20  AMEWORK..       
5f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20               if 
5f80: 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65  ((flags & SQLite
5f90: 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e  ConnectionFlags.
5fa0: 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69  LogBind) == SQLi
5fb0: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
5fc0: 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20  s.LogBind)..    
5fd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5fe0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
5ff0: 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67 42 69             LogBi
6000: 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  nd(handle, index
6010: 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20  , value);..     
6020: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
6030: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
6040: 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20          int n = 
6050: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
6060: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
6070: 5f 64 6f 75 62 6c 65 28 68 61 6e 64 6c 65 2c 20  _double(handle, 
6080: 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a  index, value);..
6090: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 20  #else..         
60a0: 20 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 6e             int n
60b0: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
60c0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
60d0: 69 6e 64 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72  ind_double_inter
60e0: 6f 70 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  op(handle, index
60f0: 2c 20 72 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23  , ref value);..#
6100: 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20 20  endif..         
6110: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 6e             if (n
6120: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
6130: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
6140: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
6150: 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ));..           
6160: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d           break;.
6170: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6180: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
6190: 63 61 73 65 20 53 51 4c 69 74 65 44 61 74 65 46  case SQLiteDateF
61a0: 6f 72 6d 61 74 73 2e 55 6e 69 78 45 70 6f 63 68  ormats.UnixEpoch
61b0: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  :..             
61c0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
61d0: 20 20 20 20 20 20 20 20 20 20 6c 6f 6e 67 20 76            long v
61e0: 61 6c 75 65 20 3d 20 43 6f 6e 76 65 72 74 2e 54  alue = Convert.T
61f0: 6f 49 6e 74 36 34 28 64 74 2e 53 75 62 74 72 61  oInt64(dt.Subtra
6200: 63 74 28 55 6e 69 78 45 70 6f 63 68 29 2e 54 6f  ct(UnixEpoch).To
6210: 74 61 6c 53 65 63 6f 6e 64 73 29 3b 0d 0a 0d 0a  talSeconds);....
6220: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
6230: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
6240: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6250: 20 20 20 20 69 66 20 28 28 66 6c 61 67 73 20 26      if ((flags &
6260: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
6270: 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20  nFlags.LogBind) 
6280: 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74  == SQLiteConnect
6290: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
62a0: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  )..             
62b0: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
62c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
62d0: 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c 65    LogBind(handle
62e0: 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b  , index, value);
62f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6300: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
6310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
6320: 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74  nt n = UnsafeNat
6330: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
6340: 65 33 5f 62 69 6e 64 5f 69 6e 74 36 34 28 68 61  e3_bind_int64(ha
6350: 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c  ndle, index, val
6360: 75 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20  ue);..#else..   
6370: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6380: 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e   int n = UnsafeN
6390: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
63a0: 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36 34 5f  ite3_bind_int64_
63b0: 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c 65 2c 20  interop(handle, 
63c0: 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c 75 65  index, ref value
63d0: 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20  );..#endif..    
63e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
63f0: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
6400: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
6410: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
6420: 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 20 20  rror());..      
6430: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62 72                br
6440: 65 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  eak;..          
6450: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
6460: 20 20 20 20 20 64 65 66 61 75 6c 74 3a 0d 0a 20       default:.. 
6470: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b                 {
6480: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6490: 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62 20 3d        byte[] b =
64a0: 20 54 6f 55 54 46 38 28 64 74 29 3b 0d 0a 0d 0a   ToUTF8(dt);....
64b0: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
64c0: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
64d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
64e0: 20 20 20 20 69 66 20 28 28 66 6c 61 67 73 20 26      if ((flags &
64f0: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
6500: 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20  nFlags.LogBind) 
6510: 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74  == SQLiteConnect
6520: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
6530: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  )..             
6540: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
6550: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6560: 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c 65    LogBind(handle
6570: 2c 20 69 6e 64 65 78 2c 20 62 29 3b 0d 0a 20 20  , index, b);..  
6580: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6590: 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20    }..#endif.... 
65a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
65b0: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
65c0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
65d0: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74  qlite3_bind_text
65e0: 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20  (handle, index, 
65f0: 62 2c 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c  b, b.Length - 1,
6600: 20 28 49 6e 74 50 74 72 29 28 2d 31 29 29 3b 0d   (IntPtr)(-1));.
6610: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6620: 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20       if (n > 0) 
6630: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
6640: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74  Exception(n, Get
6650: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20  LastError());.. 
6660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6670: 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20 20     break;..     
6680: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20             }..  
6690: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a        }..    }..
66a0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
66b0: 76 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e  verride void Bin
66c0: 64 5f 42 6c 6f 62 28 53 51 4c 69 74 65 53 74 61  d_Blob(SQLiteSta
66d0: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51 4c  tement stmt, SQL
66e0: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
66f0: 67 73 20 66 6c 61 67 73 2c 20 69 6e 74 20 69 6e  gs flags, int in
6700: 64 65 78 2c 20 62 79 74 65 5b 5d 20 62 6c 6f 62  dex, byte[] blob
6710: 44 61 74 61 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  Data)..    {..  
6720: 20 20 20 20 20 20 53 51 4c 69 74 65 53 74 61 74        SQLiteStat
6730: 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64  ementHandle hand
6740: 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74  le = stmt._sqlit
6750: 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21  e_stmt;....#if !
6760: 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54  PLATFORM_COMPACT
6770: 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20  FRAMEWORK..     
6780: 20 20 20 69 66 20 28 28 66 6c 61 67 73 20 26 20     if ((flags & 
6790: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
67a0: 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d  Flags.LogBind) =
67b0: 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  = SQLiteConnecti
67c0: 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29  onFlags.LogBind)
67d0: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
67e0: 20 20 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64           LogBind
67f0: 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20  (handle, index, 
6800: 62 6c 6f 62 44 61 74 61 29 3b 0d 0a 20 20 20 20  blobData);..    
6810: 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d      }..#endif...
6820: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  .        int n =
6830: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
6840: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
6850: 64 5f 62 6c 6f 62 28 68 61 6e 64 6c 65 2c 20 69  d_blob(handle, i
6860: 6e 64 65 78 2c 20 62 6c 6f 62 44 61 74 61 2c 20  ndex, blobData, 
6870: 62 6c 6f 62 44 61 74 61 2e 4c 65 6e 67 74 68 2c  blobData.Length,
6880: 20 28 49 6e 74 50 74 72 29 28 2d 31 29 29 3b 0d   (IntPtr)(-1));.
6890: 0a 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e  .        if (n >
68a0: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
68b0: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
68c0: 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29   GetLastError())
68d0: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
68e0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
68f0: 65 20 76 6f 69 64 20 42 69 6e 64 5f 4e 75 6c 6c  e void Bind_Null
6900: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
6910: 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e   stmt, SQLiteCon
6920: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61  nectionFlags fla
6930: 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a  gs, int index)..
6940: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 53      {..        S
6950: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61  QLiteStatementHa
6960: 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73 74  ndle handle = st
6970: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 3b  mt._sqlite_stmt;
6980: 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52  ....#if !PLATFOR
6990: 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f  M_COMPACTFRAMEWO
69a0: 52 4b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  RK..        if (
69b0: 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65 43  (flags & SQLiteC
69c0: 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c  onnectionFlags.L
69d0: 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69 74  ogBind) == SQLit
69e0: 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73  eConnectionFlags
69f0: 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20 20  .LogBind)..     
6a00: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
6a10: 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c 65    LogBind(handle
6a20: 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20 20  , index);..     
6a30: 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a     }..#endif....
6a40: 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20          int n = 
6a50: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
6a60: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
6a70: 5f 6e 75 6c 6c 28 68 61 6e 64 6c 65 2c 20 69 6e  _null(handle, in
6a80: 64 65 78 29 3b 0d 0a 20 20 20 20 20 20 20 20 69  dex);..        i
6a90: 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20  f (n > 0) throw 
6aa0: 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74  new SQLiteExcept
6ab0: 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45 72  ion(n, GetLastEr
6ac0: 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a  ror());..    }..
6ad0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
6ae0: 76 65 72 72 69 64 65 20 69 6e 74 20 42 69 6e 64  verride int Bind
6af0: 5f 50 61 72 61 6d 43 6f 75 6e 74 28 53 51 4c 69  _ParamCount(SQLi
6b00: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
6b10: 2c 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  , SQLiteConnecti
6b20: 6f 6e 46 6c 61 67 73 20 66 6c 61 67 73 29 0d 0a  onFlags flags)..
6b30: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 53      {..        S
6b40: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61  QLiteStatementHa
6b50: 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73 74  ndle handle = st
6b60: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 3b  mt._sqlite_stmt;
6b70: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 76 61  ..        int va
6b80: 6c 75 65 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  lue = UnsafeNati
6b90: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
6ba0: 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72  3_bind_parameter
6bb0: 5f 63 6f 75 6e 74 28 68 61 6e 64 6c 65 29 3b 0d  _count(handle);.
6bc0: 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d  ...#if !PLATFORM
6bd0: 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52  _COMPACTFRAMEWOR
6be0: 4b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 28  K..        if ((
6bf0: 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65 43 6f  flags & SQLiteCo
6c00: 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f  nnectionFlags.Lo
6c10: 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65  gBind) == SQLite
6c20: 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e  ConnectionFlags.
6c30: 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20 20 20  LogBind)..      
6c40: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
6c50: 20 49 6e 74 50 74 72 20 68 61 6e 64 6c 65 49 6e   IntPtr handleIn
6c60: 74 50 74 72 20 3d 20 68 61 6e 64 6c 65 3b 0d 0a  tPtr = handle;..
6c70: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 53 51  ..            SQ
6c80: 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61  LiteLog.LogMessa
6c90: 67 65 28 30 2c 20 53 74 72 69 6e 67 2e 46 6f 72  ge(0, String.For
6ca0: 6d 61 74 28 0d 0a 20 20 20 20 20 20 20 20 20 20  mat(..          
6cb0: 20 20 20 20 20 20 22 53 74 61 74 65 6d 65 6e 74        "Statement
6cc0: 20 7b 30 7d 20 70 61 72 61 6d 74 65 72 20 63 6f   {0} paramter co
6cd0: 75 6e 74 20 69 73 20 7b 31 7d 2e 22 2c 0d 0a 20  unt is {1}.",.. 
6ce0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 68                 h
6cf0: 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 76 61 6c  andleIntPtr, val
6d00: 75 65 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d  ue));..        }
6d10: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20  ..#endif....    
6d20: 20 20 20 20 72 65 74 75 72 6e 20 76 61 6c 75 65      return value
6d30: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
6d40: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
6d50: 65 20 73 74 72 69 6e 67 20 42 69 6e 64 5f 50 61  e string Bind_Pa
6d60: 72 61 6d 4e 61 6d 65 28 53 51 4c 69 74 65 53 74  ramName(SQLiteSt
6d70: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51  atement stmt, SQ
6d80: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
6d90: 61 67 73 20 66 6c 61 67 73 2c 20 69 6e 74 20 69  ags flags, int i
6da0: 6e 64 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  ndex)..    {..  
6db0: 20 20 20 20 20 20 53 51 4c 69 74 65 53 74 61 74        SQLiteStat
6dc0: 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64  ementHandle hand
6dd0: 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74  le = stmt._sqlit
6de0: 65 5f 73 74 6d 74 3b 0d 0a 20 20 20 20 20 20 20  e_stmt;..       
6df0: 20 73 74 72 69 6e 67 20 6e 61 6d 65 3b 0d 0a 0d   string name;...
6e00: 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41  .#if !SQLITE_STA
6e10: 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 20 20 69  NDARD..        i
6e20: 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 20  nt len;..       
6e30: 20 6e 61 6d 65 20 3d 20 55 54 46 38 54 6f 53 74   name = UTF8ToSt
6e40: 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76  ring(UnsafeNativ
6e50: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
6e60: 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f  _bind_parameter_
6e70: 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28 68 61 6e  name_interop(han
6e80: 64 6c 65 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20  dle, index, out 
6e90: 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23 65 6c  len), len);..#el
6ea0: 73 65 0d 0a 20 20 20 20 20 20 20 20 6e 61 6d 65  se..        name
6eb0: 20 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28   = UTF8ToString(
6ec0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
6ed0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
6ee0: 5f 70 61 72 61 6d 65 74 65 72 5f 6e 61 6d 65 28  _parameter_name(
6ef0: 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 29 2c 20  handle, index), 
6f00: 2d 31 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a  -1);..#endif....
6f10: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
6f20: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
6f30: 20 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61          if ((fla
6f40: 67 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65  gs & SQLiteConne
6f50: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
6f60: 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e  nd) == SQLiteCon
6f70: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67  nectionFlags.Log
6f80: 42 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b  Bind)..        {
6f90: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 49 6e  ..            In
6fa0: 74 50 74 72 20 68 61 6e 64 6c 65 49 6e 74 50 74  tPtr handleIntPt
6fb0: 72 20 3d 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20  r = handle;.... 
6fc0: 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74             SQLit
6fd0: 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61 67 65 28  eLog.LogMessage(
6fe0: 30 2c 20 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74  0, String.Format
6ff0: 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  (..             
7000: 20 20 20 22 53 74 61 74 65 6d 65 6e 74 20 7b 30     "Statement {0
7010: 7d 20 70 61 72 61 6d 74 65 72 20 23 7b 31 7d 20  } paramter #{1} 
7020: 6e 61 6d 65 20 69 73 20 7b 7b 7b 32 7d 7d 7d 2e  name is {{{2}}}.
7030: 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ",..            
7040: 20 20 20 20 68 61 6e 64 6c 65 49 6e 74 50 74 72      handleIntPtr
7050: 2c 20 69 6e 64 65 78 2c 20 6e 61 6d 65 29 29 3b  , index, name));
7060: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 23 65 6e  ..        }..#en
7070: 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72  dif....        r
7080: 65 74 75 72 6e 20 6e 61 6d 65 3b 0d 0a 20 20 20  eturn name;..   
7090: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
70a0: 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  al override int 
70b0: 42 69 6e 64 5f 50 61 72 61 6d 49 6e 64 65 78 28  Bind_ParamIndex(
70c0: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
70d0: 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e 6e  stmt, SQLiteConn
70e0: 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61 67  ectionFlags flag
70f0: 73 2c 20 73 74 72 69 6e 67 20 70 61 72 61 6d 4e  s, string paramN
7100: 61 6d 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  ame)..    {..   
7110: 20 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65       SQLiteState
7120: 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c  mentHandle handl
7130: 65 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65  e = stmt._sqlite
7140: 5f 73 74 6d 74 3b 0d 0a 20 20 20 20 20 20 20 20  _stmt;..        
7150: 69 6e 74 20 69 6e 64 65 78 20 3d 20 55 6e 73 61  int index = Unsa
7160: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
7170: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 70 61 72  sqlite3_bind_par
7180: 61 6d 65 74 65 72 5f 69 6e 64 65 78 28 68 61 6e  ameter_index(han
7190: 64 6c 65 2c 20 54 6f 55 54 46 38 28 70 61 72 61  dle, ToUTF8(para
71a0: 6d 4e 61 6d 65 29 29 3b 0d 0a 0d 0a 23 69 66 20  mName));....#if 
71b0: 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43  !PLATFORM_COMPAC
71c0: 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20  TFRAMEWORK..    
71d0: 20 20 20 20 69 66 20 28 28 66 6c 61 67 73 20 26      if ((flags &
71e0: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
71f0: 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20  nFlags.LogBind) 
7200: 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74  == SQLiteConnect
7210: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
7220: 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  )..        {..  
7230: 20 20 20 20 20 20 20 20 20 20 49 6e 74 50 74 72            IntPtr
7240: 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20 3d 20   handleIntPtr = 
7250: 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20  handle;....     
7260: 20 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67         SQLiteLog
7270: 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53  .LogMessage(0, S
7280: 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20  tring.Format(.. 
7290: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22                 "
72a0: 53 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20 70 61  Statement {0} pa
72b0: 72 61 6d 74 65 72 20 69 6e 64 65 78 20 6f 66 20  ramter index of 
72c0: 6e 61 6d 65 20 7b 7b 7b 31 7d 7d 7d 20 69 73 20  name {{{1}}} is 
72d0: 23 7b 32 7d 2e 22 2c 0d 0a 20 20 20 20 20 20 20  #{2}.",..       
72e0: 20 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65 49           handleI
72f0: 6e 74 50 74 72 2c 20 70 61 72 61 6d 4e 61 6d 65  ntPtr, paramName
7300: 2c 20 69 6e 64 65 78 29 29 3b 0d 0a 20 20 20 20  , index));..    
7310: 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d      }..#endif...
7320: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
7330: 69 6e 64 65 78 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  index;..    }...
7340: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
7350: 65 72 72 69 64 65 20 69 6e 74 20 43 6f 6c 75 6d  erride int Colum
7360: 6e 43 6f 75 6e 74 28 53 51 4c 69 74 65 53 74 61  nCount(SQLiteSta
7370: 74 65 6d 65 6e 74 20 73 74 6d 74 29 0d 0a 20 20  tement stmt)..  
7380: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72    {..      retur
7390: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
73a0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
73b0: 6c 75 6d 6e 5f 63 6f 75 6e 74 28 73 74 6d 74 2e  lumn_count(stmt.
73c0: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29 3b 0d 0a  _sqlite_stmt);..
73d0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
73e0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73  ernal override s
73f0: 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 4e 61 6d 65  tring ColumnName
7400: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
7410: 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78   stmt, int index
7420: 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53  )..    {..#if !S
7430: 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a  QLITE_STANDARD..
7440: 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a        int len;..
7450: 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 54 46        return UTF
7460: 38 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65  8ToString(Unsafe
7470: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
7480: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d  lite3_column_nam
7490: 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  e_interop(stmt._
74a0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
74b0: 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65  ex, out len), le
74c0: 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  n);..#else..    
74d0: 20 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53    return UTF8ToS
74e0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
74f0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
7500: 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 28 73 74  3_column_name(st
7510: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
7520: 20 69 6e 64 65 78 29 2c 20 2d 31 29 3b 0d 0a 23   index), -1);..#
7530: 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  endif..    }....
7540: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
7550: 72 72 69 64 65 20 54 79 70 65 41 66 66 69 6e 69  rride TypeAffini
7560: 74 79 20 43 6f 6c 75 6d 6e 41 66 66 69 6e 69 74  ty ColumnAffinit
7570: 79 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  y(SQLiteStatemen
7580: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
7590: 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  x)..    {..     
75a0: 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61   return UnsafeNa
75b0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
75c0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 79 70 65 28  te3_column_type(
75d0: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
75e0: 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20  t, index);..    
75f0: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
7600: 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e  l override strin
7610: 67 20 43 6f 6c 75 6d 6e 54 79 70 65 28 53 51 4c  g ColumnType(SQL
7620: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
7630: 74 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 6f 75  t, int index, ou
7640: 74 20 54 79 70 65 41 66 66 69 6e 69 74 79 20 6e  t TypeAffinity n
7650: 41 66 66 69 6e 69 74 79 29 0d 0a 20 20 20 20 7b  Affinity)..    {
7660: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b  ..      int len;
7670: 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54  ..#if !SQLITE_ST
7680: 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 49 6e  ANDARD..      In
7690: 74 50 74 72 20 70 20 3d 20 55 6e 73 61 66 65 4e  tPtr p = UnsafeN
76a0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
76b0: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c  ite3_column_decl
76c0: 74 79 70 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d  type_interop(stm
76d0: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
76e0: 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 3b  index, out len);
76f0: 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 6c  ..#else..      l
7700: 65 6e 20 3d 20 2d 31 3b 0d 0a 20 20 20 20 20 20  en = -1;..      
7710: 49 6e 74 50 74 72 20 70 20 3d 20 55 6e 73 61 66  IntPtr p = Unsaf
7720: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
7730: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 65  qlite3_column_de
7740: 63 6c 74 79 70 65 28 73 74 6d 74 2e 5f 73 71 6c  cltype(stmt._sql
7750: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29  ite_stmt, index)
7760: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 20  ;..#endif..     
7770: 20 6e 41 66 66 69 6e 69 74 79 20 3d 20 43 6f 6c   nAffinity = Col
7780: 75 6d 6e 41 66 66 69 6e 69 74 79 28 73 74 6d 74  umnAffinity(stmt
7790: 2c 20 69 6e 64 65 78 29 3b 0d 0a 0d 0a 20 20 20  , index);....   
77a0: 20 20 20 69 66 20 28 70 20 21 3d 20 49 6e 74 50     if (p != IntP
77b0: 74 72 2e 5a 65 72 6f 29 20 72 65 74 75 72 6e 20  tr.Zero) return 
77c0: 55 54 46 38 54 6f 53 74 72 69 6e 67 28 70 2c 20  UTF8ToString(p, 
77d0: 6c 65 6e 29 3b 0d 0a 20 20 20 20 20 20 65 6c 73  len);..      els
77e0: 65 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  e..      {..    
77f0: 20 20 20 20 73 74 72 69 6e 67 5b 5d 20 61 72 20      string[] ar 
7800: 3d 20 73 74 6d 74 2e 54 79 70 65 44 65 66 69 6e  = stmt.TypeDefin
7810: 69 74 69 6f 6e 73 3b 0d 0a 20 20 20 20 20 20 20  itions;..       
7820: 20 69 66 20 28 61 72 20 21 3d 20 6e 75 6c 6c 29   if (ar != null)
7830: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
7840: 20 20 20 20 20 20 20 69 66 20 28 69 6e 64 65 78         if (index
7850: 20 3c 20 61 72 2e 4c 65 6e 67 74 68 20 26 26 20   < ar.Length && 
7860: 61 72 5b 69 6e 64 65 78 5d 20 21 3d 20 6e 75 6c  ar[index] != nul
7870: 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  l)..            
7880: 72 65 74 75 72 6e 20 61 72 5b 69 6e 64 65 78 5d  return ar[index]
7890: 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20  ;..        }..  
78a0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 74 72        return Str
78b0: 69 6e 67 2e 45 6d 70 74 79 3b 0d 0a 0d 0a 20 20  ing.Empty;....  
78c0: 20 20 20 20 20 20 2f 2f 73 77 69 74 63 68 20 28        //switch (
78d0: 6e 41 66 66 69 6e 69 74 79 29 0d 0a 20 20 20 20  nAffinity)..    
78e0: 20 20 20 20 2f 2f 7b 0d 0a 20 20 20 20 20 20 20      //{..       
78f0: 20 2f 2f 20 20 63 61 73 65 20 54 79 70 65 41 66   //  case TypeAf
7900: 66 69 6e 69 74 79 2e 49 6e 74 36 34 3a 0d 0a 20  finity.Int64:.. 
7910: 20 20 20 20 20 20 20 2f 2f 20 20 20 20 72 65 74         //    ret
7920: 75 72 6e 20 22 42 49 47 49 4e 54 22 3b 0d 0a 20  urn "BIGINT";.. 
7930: 20 20 20 20 20 20 20 2f 2f 20 20 63 61 73 65 20         //  case 
7940: 54 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f 75  TypeAffinity.Dou
7950: 62 6c 65 3a 0d 0a 20 20 20 20 20 20 20 20 2f 2f  ble:..        //
7960: 20 20 20 20 72 65 74 75 72 6e 20 22 44 4f 55 42      return "DOUB
7970: 4c 45 22 3b 0d 0a 20 20 20 20 20 20 20 20 2f 2f  LE";..        //
7980: 20 20 63 61 73 65 20 54 79 70 65 41 66 66 69 6e    case TypeAffin
7990: 69 74 79 2e 42 6c 6f 62 3a 0d 0a 20 20 20 20 20  ity.Blob:..     
79a0: 20 20 20 2f 2f 20 20 20 20 72 65 74 75 72 6e 20     //    return 
79b0: 22 42 4c 4f 42 22 3b 0d 0a 20 20 20 20 20 20 20  "BLOB";..       
79c0: 20 2f 2f 20 20 64 65 66 61 75 6c 74 3a 0d 0a 20   //  default:.. 
79d0: 20 20 20 20 20 20 20 2f 2f 20 20 20 20 72 65 74         //    ret
79e0: 75 72 6e 20 22 54 45 58 54 22 3b 0d 0a 20 20 20  urn "TEXT";..   
79f0: 20 20 20 20 20 2f 2f 7d 0d 0a 20 20 20 20 20 20       //}..      
7a00: 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  }..    }....    
7a10: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
7a20: 65 20 69 6e 74 20 43 6f 6c 75 6d 6e 49 6e 64 65  e int ColumnInde
7a30: 78 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  x(SQLiteStatemen
7a40: 74 20 73 74 6d 74 2c 20 73 74 72 69 6e 67 20 63  t stmt, string c
7a50: 6f 6c 75 6d 6e 4e 61 6d 65 29 0d 0a 20 20 20 20  olumnName)..    
7a60: 7b 0d 0a 20 20 20 20 20 20 69 6e 74 20 78 20 3d  {..      int x =
7a70: 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74 28 73 74 6d   ColumnCount(stm
7a80: 74 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 66 6f 72  t);....      for
7a90: 20 28 69 6e 74 20 6e 20 3d 20 30 3b 20 6e 20 3c   (int n = 0; n <
7aa0: 20 78 3b 20 6e 2b 2b 29 0d 0a 20 20 20 20 20 20   x; n++)..      
7ab0: 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 53  {..        if (S
7ac0: 74 72 69 6e 67 2e 43 6f 6d 70 61 72 65 28 63 6f  tring.Compare(co
7ad0: 6c 75 6d 6e 4e 61 6d 65 2c 20 43 6f 6c 75 6d 6e  lumnName, Column
7ae0: 4e 61 6d 65 28 73 74 6d 74 2c 20 6e 29 2c 20 53  Name(stmt, n), S
7af0: 74 72 69 6e 67 43 6f 6d 70 61 72 69 73 6f 6e 2e  tringComparison.
7b00: 4f 72 64 69 6e 61 6c 49 67 6e 6f 72 65 43 61 73  OrdinalIgnoreCas
7b10: 65 29 20 3d 3d 20 30 29 0d 0a 20 20 20 20 20 20  e) == 0)..      
7b20: 20 20 20 20 72 65 74 75 72 6e 20 6e 3b 0d 0a 20      return n;.. 
7b30: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 72 65       }..      re
7b40: 74 75 72 6e 20 2d 31 3b 0d 0a 20 20 20 20 7d 0d  turn -1;..    }.
7b50: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
7b60: 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67 20  override string 
7b70: 43 6f 6c 75 6d 6e 4f 72 69 67 69 6e 61 6c 4e 61  ColumnOriginalNa
7b80: 6d 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  me(SQLiteStateme
7b90: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
7ba0: 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20  ex)..    {..#if 
7bb0: 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44  !SQLITE_STANDARD
7bc0: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b  ..      int len;
7bd0: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 55  ..      return U
7be0: 54 46 38 54 6f 53 74 72 69 6e 67 28 55 6e 73 61  TF8ToString(Unsa
7bf0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
7c00: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f  sqlite3_column_o
7c10: 72 69 67 69 6e 5f 6e 61 6d 65 5f 69 6e 74 65 72  rigin_name_inter
7c20: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
7c30: 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74  stmt, index, out
7c40: 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23 65   len), len);..#e
7c50: 6c 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75 72  lse..      retur
7c60: 6e 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55  n UTF8ToString(U
7c70: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
7c80: 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  ds.sqlite3_colum
7c90: 6e 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65 28 73 74  n_origin_name(st
7ca0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
7cb0: 20 69 6e 64 65 78 29 2c 20 2d 31 29 3b 0d 0a 23   index), -1);..#
7cc0: 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  endif..    }....
7cd0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
7ce0: 72 72 69 64 65 20 73 74 72 69 6e 67 20 43 6f 6c  rride string Col
7cf0: 75 6d 6e 44 61 74 61 62 61 73 65 4e 61 6d 65 28  umnDatabaseName(
7d00: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
7d10: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29  stmt, int index)
7d20: 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51  ..    {..#if !SQ
7d30: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
7d40: 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 20       int len;.. 
7d50: 20 20 20 20 20 72 65 74 75 72 6e 20 55 54 46 38       return UTF8
7d60: 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e  ToString(UnsafeN
7d70: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
7d80: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61  ite3_column_data
7d90: 62 61 73 65 5f 6e 61 6d 65 5f 69 6e 74 65 72 6f  base_name_intero
7da0: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
7db0: 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20  tmt, index, out 
7dc0: 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23 65 6c  len), len);..#el
7dd0: 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e  se..      return
7de0: 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55 6e   UTF8ToString(Un
7df0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
7e00: 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  s.sqlite3_column
7e10: 5f 64 61 74 61 62 61 73 65 5f 6e 61 6d 65 28 73  _database_name(s
7e20: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
7e30: 2c 20 69 6e 64 65 78 29 2c 20 2d 31 29 3b 0d 0a  , index), -1);..
7e40: 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d  #endif..    }...
7e50: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
7e60: 65 72 72 69 64 65 20 73 74 72 69 6e 67 20 43 6f  erride string Co
7e70: 6c 75 6d 6e 54 61 62 6c 65 4e 61 6d 65 28 53 51  lumnTableName(SQ
7e80: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
7e90: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a  mt, int index)..
7ea0: 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49      {..#if !SQLI
7eb0: 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20  TE_STANDARD..   
7ec0: 20 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20     int len;..   
7ed0: 20 20 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f     return UTF8To
7ee0: 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74  String(UnsafeNat
7ef0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
7f00: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f  e3_column_table_
7f10: 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d  name_interop(stm
7f20: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
7f30: 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c  index, out len),
7f40: 20 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20   len);..#else.. 
7f50: 20 20 20 20 20 72 65 74 75 72 6e 20 55 54 46 38       return UTF8
7f60: 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e  ToString(UnsafeN
7f70: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
7f80: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c  ite3_column_tabl
7f90: 65 5f 6e 61 6d 65 28 73 74 6d 74 2e 5f 73 71 6c  e_name(stmt._sql
7fa0: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29  ite_stmt, index)
7fb0: 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  , -1);..#endif..
7fc0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
7fd0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
7fe0: 6f 69 64 20 43 6f 6c 75 6d 6e 4d 65 74 61 44 61  oid ColumnMetaDa
7ff0: 74 61 28 73 74 72 69 6e 67 20 64 61 74 61 42 61  ta(string dataBa
8000: 73 65 2c 20 73 74 72 69 6e 67 20 74 61 62 6c 65  se, string table
8010: 2c 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e 2c  , string column,
8020: 20 6f 75 74 20 73 74 72 69 6e 67 20 64 61 74 61   out string data
8030: 54 79 70 65 2c 20 6f 75 74 20 73 74 72 69 6e 67  Type, out string
8040: 20 63 6f 6c 6c 61 74 65 53 65 71 75 65 6e 63 65   collateSequence
8050: 2c 20 6f 75 74 20 62 6f 6f 6c 20 6e 6f 74 4e 75  , out bool notNu
8060: 6c 6c 2c 20 6f 75 74 20 62 6f 6f 6c 20 70 72 69  ll, out bool pri
8070: 6d 61 72 79 4b 65 79 2c 20 6f 75 74 20 62 6f 6f  maryKey, out boo
8080: 6c 20 61 75 74 6f 49 6e 63 72 65 6d 65 6e 74 29  l autoIncrement)
8090: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 49  ..    {..      I
80a0: 6e 74 50 74 72 20 64 61 74 61 54 79 70 65 50 74  ntPtr dataTypePt
80b0: 72 3b 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72  r;..      IntPtr
80c0: 20 63 6f 6c 6c 53 65 71 50 74 72 3b 0d 0a 20 20   collSeqPtr;..  
80d0: 20 20 20 20 69 6e 74 20 6e 6e 6f 74 4e 75 6c 6c      int nnotNull
80e0: 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 70 72  ;..      int npr
80f0: 69 6d 61 72 79 4b 65 79 3b 0d 0a 20 20 20 20 20  imaryKey;..     
8100: 20 69 6e 74 20 6e 61 75 74 6f 49 6e 63 3b 0d 0a   int nautoInc;..
8110: 20 20 20 20 20 20 69 6e 74 20 6e 3b 0d 0a 20 20        int n;..  
8120: 20 20 20 20 69 6e 74 20 64 74 4c 65 6e 3b 0d 0a      int dtLen;..
8130: 20 20 20 20 20 20 69 6e 74 20 63 73 4c 65 6e 3b        int csLen;
8140: 0d 0a 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f  ....#if !SQLITE_
8150: 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20  STANDARD..      
8160: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
8170: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
8180: 74 61 62 6c 65 5f 63 6f 6c 75 6d 6e 5f 6d 65 74  table_column_met
8190: 61 64 61 74 61 5f 69 6e 74 65 72 6f 70 28 5f 73  adata_interop(_s
81a0: 71 6c 2c 20 54 6f 55 54 46 38 28 64 61 74 61 42  ql, ToUTF8(dataB
81b0: 61 73 65 29 2c 20 54 6f 55 54 46 38 28 74 61 62  ase), ToUTF8(tab
81c0: 6c 65 29 2c 20 54 6f 55 54 46 38 28 63 6f 6c 75  le), ToUTF8(colu
81d0: 6d 6e 29 2c 20 6f 75 74 20 64 61 74 61 54 79 70  mn), out dataTyp
81e0: 65 50 74 72 2c 20 6f 75 74 20 63 6f 6c 6c 53 65  ePtr, out collSe
81f0: 71 50 74 72 2c 20 6f 75 74 20 6e 6e 6f 74 4e 75  qPtr, out nnotNu
8200: 6c 6c 2c 20 6f 75 74 20 6e 70 72 69 6d 61 72 79  ll, out nprimary
8210: 4b 65 79 2c 20 6f 75 74 20 6e 61 75 74 6f 49 6e  Key, out nautoIn
8220: 63 2c 20 6f 75 74 20 64 74 4c 65 6e 2c 20 6f 75  c, out dtLen, ou
8230: 74 20 63 73 4c 65 6e 29 3b 0d 0a 23 65 6c 73 65  t csLen);..#else
8240: 0d 0a 20 20 20 20 20 20 64 74 4c 65 6e 20 3d 20  ..      dtLen = 
8250: 2d 31 3b 0d 0a 20 20 20 20 20 20 63 73 4c 65 6e  -1;..      csLen
8260: 20 3d 20 2d 31 3b 0d 0a 0d 0a 20 20 20 20 20 20   = -1;....      
8270: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
8280: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
8290: 74 61 62 6c 65 5f 63 6f 6c 75 6d 6e 5f 6d 65 74  table_column_met
82a0: 61 64 61 74 61 28 5f 73 71 6c 2c 20 54 6f 55 54  adata(_sql, ToUT
82b0: 46 38 28 64 61 74 61 42 61 73 65 29 2c 20 54 6f  F8(dataBase), To
82c0: 55 54 46 38 28 74 61 62 6c 65 29 2c 20 54 6f 55  UTF8(table), ToU
82d0: 54 46 38 28 63 6f 6c 75 6d 6e 29 2c 20 6f 75 74  TF8(column), out
82e0: 20 64 61 74 61 54 79 70 65 50 74 72 2c 20 6f 75   dataTypePtr, ou
82f0: 74 20 63 6f 6c 6c 53 65 71 50 74 72 2c 20 6f 75  t collSeqPtr, ou
8300: 74 20 6e 6e 6f 74 4e 75 6c 6c 2c 20 6f 75 74 20  t nnotNull, out 
8310: 6e 70 72 69 6d 61 72 79 4b 65 79 2c 20 6f 75 74  nprimaryKey, out
8320: 20 6e 61 75 74 6f 49 6e 63 29 3b 0d 0a 23 65 6e   nautoInc);..#en
8330: 64 69 66 0d 0a 20 20 20 20 20 20 69 66 20 28 6e  dif..      if (n
8340: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
8350: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
8360: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
8370: 29 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 64 61 74  ));....      dat
8380: 61 54 79 70 65 20 3d 20 55 54 46 38 54 6f 53 74  aType = UTF8ToSt
8390: 72 69 6e 67 28 64 61 74 61 54 79 70 65 50 74 72  ring(dataTypePtr
83a0: 2c 20 64 74 4c 65 6e 29 3b 0d 0a 20 20 20 20 20  , dtLen);..     
83b0: 20 63 6f 6c 6c 61 74 65 53 65 71 75 65 6e 63 65   collateSequence
83c0: 20 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28   = UTF8ToString(
83d0: 63 6f 6c 6c 53 65 71 50 74 72 2c 20 63 73 4c 65  collSeqPtr, csLe
83e0: 6e 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 6e 6f 74  n);....      not
83f0: 4e 75 6c 6c 20 3d 20 28 6e 6e 6f 74 4e 75 6c 6c  Null = (nnotNull
8400: 20 3d 3d 20 31 29 3b 0d 0a 20 20 20 20 20 20 70   == 1);..      p
8410: 72 69 6d 61 72 79 4b 65 79 20 3d 20 28 6e 70 72  rimaryKey = (npr
8420: 69 6d 61 72 79 4b 65 79 20 3d 3d 20 31 29 3b 0d  imaryKey == 1);.
8430: 0a 20 20 20 20 20 20 61 75 74 6f 49 6e 63 72 65  .      autoIncre
8440: 6d 65 6e 74 20 3d 20 28 6e 61 75 74 6f 49 6e 63  ment = (nautoInc
8450: 20 3d 3d 20 31 29 3b 0d 0a 20 20 20 20 7d 0d 0a   == 1);..    }..
8460: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
8470: 76 65 72 72 69 64 65 20 64 6f 75 62 6c 65 20 47  verride double G
8480: 65 74 44 6f 75 62 6c 65 28 53 51 4c 69 74 65 53  etDouble(SQLiteS
8490: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
84a0: 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b  nt index)..    {
84b0: 0d 0a 20 20 20 20 20 20 64 6f 75 62 6c 65 20 76  ..      double v
84c0: 61 6c 75 65 3b 0d 0a 23 69 66 20 21 50 4c 41 54  alue;..#if !PLAT
84d0: 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d  FORM_COMPACTFRAM
84e0: 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 76 61 6c  EWORK..      val
84f0: 75 65 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76  ue = UnsafeNativ
8500: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
8510: 5f 63 6f 6c 75 6d 6e 5f 64 6f 75 62 6c 65 28 73  _column_double(s
8520: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
8530: 2c 20 69 6e 64 65 78 29 3b 0d 0a 23 65 6c 73 65  , index);..#else
8540: 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  ..      UnsafeNa
8550: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
8560: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 6f 75 62 6c  te3_column_doubl
8570: 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  e_interop(stmt._
8580: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
8590: 65 78 2c 20 6f 75 74 20 76 61 6c 75 65 29 3b 0d  ex, out value);.
85a0: 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 72  .#endif..      r
85b0: 65 74 75 72 6e 20 76 61 6c 75 65 3b 0d 0a 20 20  eturn value;..  
85c0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
85d0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
85e0: 20 47 65 74 49 6e 74 33 32 28 53 51 4c 69 74 65   GetInt32(SQLite
85f0: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
8600: 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20  int index)..    
8610: 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  {..      return 
8620: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
8630: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ods.sqlite3_colu
8640: 6d 6e 5f 69 6e 74 28 73 74 6d 74 2e 5f 73 71 6c  mn_int(stmt._sql
8650: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29  ite_stmt, index)
8660: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
8670: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
8680: 65 20 6c 6f 6e 67 20 47 65 74 49 6e 74 36 34 28  e long GetInt64(
8690: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
86a0: 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29  stmt, int index)
86b0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 6c  ..    {..      l
86c0: 6f 6e 67 20 76 61 6c 75 65 3b 0d 0a 23 69 66 20  ong value;..#if 
86d0: 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43  !PLATFORM_COMPAC
86e0: 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20  TFRAMEWORK..    
86f0: 20 20 76 61 6c 75 65 20 3d 20 55 6e 73 61 66 65    value = Unsafe
8700: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
8710: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74  lite3_column_int
8720: 36 34 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  64(stmt._sqlite_
8730: 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 23  stmt, index);..#
8740: 65 6c 73 65 0d 0a 20 20 20 20 20 20 55 6e 73 61  else..      Unsa
8750: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
8760: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69  sqlite3_column_i
8770: 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 73 74 6d  nt64_interop(stm
8780: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
8790: 69 6e 64 65 78 2c 20 6f 75 74 20 76 61 6c 75 65  index, out value
87a0: 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20  );..#endif..    
87b0: 20 20 72 65 74 75 72 6e 20 76 61 6c 75 65 3b 0d    return value;.
87c0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
87d0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
87e0: 73 74 72 69 6e 67 20 47 65 74 54 65 78 74 28 53  string GetText(S
87f0: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73  QLiteStatement s
8800: 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d  tmt, int index).
8810: 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c  .    {..#if !SQL
8820: 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20  ITE_STANDARD..  
8830: 20 20 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20      int len;..  
8840: 20 20 20 20 72 65 74 75 72 6e 20 55 54 46 38 54      return UTF8T
8850: 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61  oString(UnsafeNa
8860: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
8870: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 5f  te3_column_text_
8880: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
8890: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
88a0: 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29  , out len), len)
88b0: 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20  ;..#else..      
88c0: 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72  return UTF8ToStr
88d0: 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65  ing(UnsafeNative
88e0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
88f0: 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 73 74 6d 74  column_text(stmt
8900: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
8910: 6e 64 65 78 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e  ndex), -1);..#en
8920: 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  dif..    }....  
8930: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
8940: 69 64 65 20 44 61 74 65 54 69 6d 65 20 47 65 74  ide DateTime Get
8950: 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74 65 53  DateTime(SQLiteS
8960: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
8970: 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b  nt index)..    {
8980: 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54  ..#if !SQLITE_ST
8990: 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 69 6e  ANDARD..      in
89a0: 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 72 65  t len;..      re
89b0: 74 75 72 6e 20 54 6f 44 61 74 65 54 69 6d 65 28  turn ToDateTime(
89c0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
89d0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ods.sqlite3_colu
89e0: 6d 6e 5f 74 65 78 74 5f 69 6e 74 65 72 6f 70 28  mn_text_interop(
89f0: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
8a00: 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65  t, index, out le
8a10: 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65  n), len);..#else
8a20: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 54  ..      return T
8a30: 6f 44 61 74 65 54 69 6d 65 28 55 6e 73 61 66 65  oDateTime(Unsafe
8a40: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
8a50: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78  lite3_column_tex
8a60: 74 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  t(stmt._sqlite_s
8a70: 74 6d 74 2c 20 69 6e 64 65 78 29 2c 20 2d 31 29  tmt, index), -1)
8a80: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d  ;..#endif..    }
8a90: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
8aa0: 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47   override long G
8ab0: 65 74 42 79 74 65 73 28 53 51 4c 69 74 65 53 74  etBytes(SQLiteSt
8ac0: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
8ad0: 74 20 69 6e 64 65 78 2c 20 69 6e 74 20 6e 44 61  t index, int nDa
8ae0: 74 61 4f 66 66 73 65 74 2c 20 62 79 74 65 5b 5d  taOffset, byte[]
8af0: 20 62 44 65 73 74 2c 20 69 6e 74 20 6e 53 74 61   bDest, int nSta
8b00: 72 74 2c 20 69 6e 74 20 6e 4c 65 6e 67 74 68 29  rt, int nLength)
8b10: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69  ..    {..      i
8b20: 6e 74 20 6e 6c 65 6e 20 3d 20 55 6e 73 61 66 65  nt nlen = Unsafe
8b30: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
8b40: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74  lite3_column_byt
8b50: 65 73 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  es(stmt._sqlite_
8b60: 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 0d  stmt, index);...
8b70: 0a 20 20 20 20 20 20 2f 2f 20 49 66 20 6e 6f 20  .      // If no 
8b80: 64 65 73 74 69 6e 61 74 69 6f 6e 20 62 75 66 66  destination buff
8b90: 65 72 2c 20 72 65 74 75 72 6e 20 74 68 65 20 73  er, return the s
8ba0: 69 7a 65 20 6e 65 65 64 65 64 2e 0d 0a 20 20 20  ize needed...   
8bb0: 20 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d 20     if (bDest == 
8bc0: 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65  null) return nle
8bd0: 6e 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 6e 74 20  n;....      int 
8be0: 6e 43 6f 70 69 65 64 20 3d 20 6e 4c 65 6e 67 74  nCopied = nLengt
8bf0: 68 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20 28  h;....      if (
8c00: 6e 43 6f 70 69 65 64 20 2b 20 6e 53 74 61 72 74  nCopied + nStart
8c10: 20 3e 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 29   > bDest.Length)
8c20: 20 6e 43 6f 70 69 65 64 20 3d 20 62 44 65 73 74   nCopied = bDest
8c30: 2e 4c 65 6e 67 74 68 20 2d 20 6e 53 74 61 72 74  .Length - nStart
8c40: 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f  ;..      if (nCo
8c50: 70 69 65 64 20 2b 20 6e 44 61 74 61 4f 66 66 73  pied + nDataOffs
8c60: 65 74 20 3e 20 6e 6c 65 6e 29 20 6e 43 6f 70 69  et > nlen) nCopi
8c70: 65 64 20 3d 20 6e 6c 65 6e 20 2d 20 6e 44 61 74  ed = nlen - nDat
8c80: 61 4f 66 66 73 65 74 3b 0d 0a 0d 0a 20 20 20 20  aOffset;....    
8c90: 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 3e 20    if (nCopied > 
8ca0: 30 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20  0)..      {..   
8cb0: 20 20 20 20 20 49 6e 74 50 74 72 20 70 74 72 20       IntPtr ptr 
8cc0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
8cd0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
8ce0: 6c 75 6d 6e 5f 62 6c 6f 62 28 73 74 6d 74 2e 5f  lumn_blob(stmt._
8cf0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
8d00: 65 78 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ex);....        
8d10: 4d 61 72 73 68 61 6c 2e 43 6f 70 79 28 28 49 6e  Marshal.Copy((In
8d20: 74 50 74 72 29 28 70 74 72 2e 54 6f 49 6e 74 36  tPtr)(ptr.ToInt6
8d30: 34 28 29 20 2b 20 6e 44 61 74 61 4f 66 66 73 65  4() + nDataOffse
8d40: 74 29 2c 20 62 44 65 73 74 2c 20 6e 53 74 61 72  t), bDest, nStar
8d50: 74 2c 20 6e 43 6f 70 69 65 64 29 3b 0d 0a 20 20  t, nCopied);..  
8d60: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 65 6c 73      }..      els
8d70: 65 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  e..      {..    
8d80: 20 20 20 20 6e 43 6f 70 69 65 64 20 3d 20 30 3b      nCopied = 0;
8d90: 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  ..      }....   
8da0: 20 20 20 72 65 74 75 72 6e 20 6e 43 6f 70 69 65     return nCopie
8db0: 64 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  d;..    }....   
8dc0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
8dd0: 64 65 20 6c 6f 6e 67 20 47 65 74 43 68 61 72 73  de long GetChars
8de0: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
8df0: 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78   stmt, int index
8e00: 2c 20 69 6e 74 20 6e 44 61 74 61 4f 66 66 73 65  , int nDataOffse
8e10: 74 2c 20 63 68 61 72 5b 5d 20 62 44 65 73 74 2c  t, char[] bDest,
8e20: 20 69 6e 74 20 6e 53 74 61 72 74 2c 20 69 6e 74   int nStart, int
8e30: 20 6e 4c 65 6e 67 74 68 29 0d 0a 20 20 20 20 7b   nLength)..    {
8e40: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 6c 65 6e  ..      int nlen
8e50: 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 43 6f  ;..      int nCo
8e60: 70 69 65 64 20 3d 20 6e 4c 65 6e 67 74 68 3b 0d  pied = nLength;.
8e70: 0a 0d 0a 20 20 20 20 20 20 73 74 72 69 6e 67 20  ...      string 
8e80: 73 74 72 20 3d 20 47 65 74 54 65 78 74 28 73 74  str = GetText(st
8e90: 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20  mt, index);..   
8ea0: 20 20 20 6e 6c 65 6e 20 3d 20 73 74 72 2e 4c 65     nlen = str.Le
8eb0: 6e 67 74 68 3b 0d 0a 0d 0a 20 20 20 20 20 20 69  ngth;....      i
8ec0: 66 20 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c  f (bDest == null
8ed0: 29 20 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0d 0a  ) return nlen;..
8ee0: 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70  ..      if (nCop
8ef0: 69 65 64 20 2b 20 6e 53 74 61 72 74 20 3e 20 62  ied + nStart > b
8f00: 44 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f  Dest.Length) nCo
8f10: 70 69 65 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e  pied = bDest.Len
8f20: 67 74 68 20 2d 20 6e 53 74 61 72 74 3b 0d 0a 20  gth - nStart;.. 
8f30: 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64       if (nCopied
8f40: 20 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e   + nDataOffset >
8f50: 20 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d   nlen) nCopied =
8f60: 20 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66   nlen - nDataOff
8f70: 73 65 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66  set;....      if
8f80: 20 28 6e 43 6f 70 69 65 64 20 3e 20 30 29 0d 0a   (nCopied > 0)..
8f90: 20 20 20 20 20 20 20 20 73 74 72 2e 43 6f 70 79          str.Copy
8fa0: 54 6f 28 6e 44 61 74 61 4f 66 66 73 65 74 2c 20  To(nDataOffset, 
8fb0: 62 44 65 73 74 2c 20 6e 53 74 61 72 74 2c 20 6e  bDest, nStart, n
8fc0: 43 6f 70 69 65 64 29 3b 0d 0a 20 20 20 20 20 20  Copied);..      
8fd0: 65 6c 73 65 20 6e 43 6f 70 69 65 64 20 3d 20 30  else nCopied = 0
8fe0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72  ;....      retur
8ff0: 6e 20 6e 43 6f 70 69 65 64 3b 0d 0a 20 20 20 20  n nCopied;..    
9000: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
9010: 6c 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20  l override bool 
9020: 49 73 4e 75 6c 6c 28 53 51 4c 69 74 65 53 74 61  IsNull(SQLiteSta
9030: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
9040: 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b 0d 0a   index)..    {..
9050: 20 20 20 20 20 20 72 65 74 75 72 6e 20 28 43 6f        return (Co
9060: 6c 75 6d 6e 41 66 66 69 6e 69 74 79 28 73 74 6d  lumnAffinity(stm
9070: 74 2c 20 69 6e 64 65 78 29 20 3d 3d 20 54 79 70  t, index) == Typ
9080: 65 41 66 66 69 6e 69 74 79 2e 4e 75 6c 6c 29 3b  eAffinity.Null);
9090: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
90a0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
90b0: 20 69 6e 74 20 41 67 67 72 65 67 61 74 65 43 6f   int AggregateCo
90c0: 75 6e 74 28 49 6e 74 50 74 72 20 63 6f 6e 74 65  unt(IntPtr conte
90d0: 78 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  xt)..    {..    
90e0: 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e    return UnsafeN
90f0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
9100: 69 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63  ite3_aggregate_c
9110: 6f 75 6e 74 28 63 6f 6e 74 65 78 74 29 3b 0d 0a  ount(context);..
9120: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
9130: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
9140: 6f 69 64 20 43 72 65 61 74 65 46 75 6e 63 74 69  oid CreateFuncti
9150: 6f 6e 28 73 74 72 69 6e 67 20 73 74 72 46 75 6e  on(string strFun
9160: 63 74 69 6f 6e 2c 20 69 6e 74 20 6e 41 72 67 73  ction, int nArgs
9170: 2c 20 62 6f 6f 6c 20 6e 65 65 64 43 6f 6c 6c 53  , bool needCollS
9180: 65 71 2c 20 53 51 4c 69 74 65 43 61 6c 6c 62 61  eq, SQLiteCallba
9190: 63 6b 20 66 75 6e 63 2c 20 53 51 4c 69 74 65 43  ck func, SQLiteC
91a0: 61 6c 6c 62 61 63 6b 20 66 75 6e 63 73 74 65 70  allback funcstep
91b0: 2c 20 53 51 4c 69 74 65 46 69 6e 61 6c 43 61 6c  , SQLiteFinalCal
91c0: 6c 62 61 63 6b 20 66 75 6e 63 66 69 6e 61 6c 29  lback funcfinal)
91d0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69  ..    {..      i
91e0: 6e 74 20 6e 3b 0d 0a 0d 0a 23 69 66 20 21 53 51  nt n;....#if !SQ
91f0: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
9200: 20 20 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e       n = UnsafeN
9210: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
9220: 69 74 65 33 5f 63 72 65 61 74 65 5f 66 75 6e 63  ite3_create_func
9230: 74 69 6f 6e 5f 69 6e 74 65 72 6f 70 28 5f 73 71  tion_interop(_sq
9240: 6c 2c 20 54 6f 55 54 46 38 28 73 74 72 46 75 6e  l, ToUTF8(strFun
9250: 63 74 69 6f 6e 29 2c 20 6e 41 72 67 73 2c 20 34  ction), nArgs, 4
9260: 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f 2c 20 66  , IntPtr.Zero, f
9270: 75 6e 63 2c 20 66 75 6e 63 73 74 65 70 2c 20 66  unc, funcstep, f
9280: 75 6e 63 66 69 6e 61 6c 2c 20 28 6e 65 65 64 43  uncfinal, (needC
9290: 6f 6c 6c 53 65 71 20 3d 3d 20 74 72 75 65 29 20  ollSeq == true) 
92a0: 3f 20 31 20 3a 20 30 29 3b 0d 0a 20 20 20 20 20  ? 1 : 0);..     
92b0: 20 69 66 20 28 6e 20 3d 3d 20 30 29 20 6e 20 3d   if (n == 0) n =
92c0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
92d0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65  hods.sqlite3_cre
92e0: 61 74 65 5f 66 75 6e 63 74 69 6f 6e 5f 69 6e 74  ate_function_int
92f0: 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55 54 46  erop(_sql, ToUTF
9300: 38 28 73 74 72 46 75 6e 63 74 69 6f 6e 29 2c 20  8(strFunction), 
9310: 6e 41 72 67 73 2c 20 31 2c 20 49 6e 74 50 74 72  nArgs, 1, IntPtr
9320: 2e 5a 65 72 6f 2c 20 66 75 6e 63 2c 20 66 75 6e  .Zero, func, fun
9330: 63 73 74 65 70 2c 20 66 75 6e 63 66 69 6e 61 6c  cstep, funcfinal
9340: 2c 20 28 6e 65 65 64 43 6f 6c 6c 53 65 71 20 3d  , (needCollSeq =
9350: 3d 20 74 72 75 65 29 20 3f 20 31 20 3a 20 30 29  = true) ? 1 : 0)
9360: 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20  ;..#else..      
9370: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
9380: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
9390: 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 28  create_function(
93a0: 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 73 74 72  _sql, ToUTF8(str
93b0: 46 75 6e 63 74 69 6f 6e 29 2c 20 6e 41 72 67 73  Function), nArgs
93c0: 2c 20 34 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f  , 4, IntPtr.Zero
93d0: 2c 20 66 75 6e 63 2c 20 66 75 6e 63 73 74 65 70  , func, funcstep
93e0: 2c 20 66 75 6e 63 66 69 6e 61 6c 29 3b 0d 0a 20  , funcfinal);.. 
93f0: 20 20 20 20 20 69 66 20 28 6e 20 3d 3d 20 30 29       if (n == 0)
9400: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
9410: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
9420: 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e  _create_function
9430: 28 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 73 74  (_sql, ToUTF8(st
9440: 72 46 75 6e 63 74 69 6f 6e 29 2c 20 6e 41 72 67  rFunction), nArg
9450: 73 2c 20 31 2c 20 49 6e 74 50 74 72 2e 5a 65 72  s, 1, IntPtr.Zer
9460: 6f 2c 20 66 75 6e 63 2c 20 66 75 6e 63 73 74 65  o, func, funcste
9470: 70 2c 20 66 75 6e 63 66 69 6e 61 6c 29 3b 0d 0a  p, funcfinal);..
9480: 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 69 66  #endif..      if
9490: 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e   (n > 0) throw n
94a0: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
94b0: 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45 72 72  on(n, GetLastErr
94c0: 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  or());..    }...
94d0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
94e0: 65 72 72 69 64 65 20 76 6f 69 64 20 43 72 65 61  erride void Crea
94f0: 74 65 43 6f 6c 6c 61 74 69 6f 6e 28 73 74 72 69  teCollation(stri
9500: 6e 67 20 73 74 72 43 6f 6c 6c 61 74 69 6f 6e 2c  ng strCollation,
9510: 20 53 51 4c 69 74 65 43 6f 6c 6c 61 74 69 6f 6e   SQLiteCollation
9520: 20 66 75 6e 63 2c 20 53 51 4c 69 74 65 43 6f 6c   func, SQLiteCol
9530: 6c 61 74 69 6f 6e 20 66 75 6e 63 31 36 29 0d 0a  lation func16)..
9540: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69 6e 74      {..      int
9550: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
9560: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
9570: 5f 63 72 65 61 74 65 5f 63 6f 6c 6c 61 74 69 6f  _create_collatio
9580: 6e 28 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 73  n(_sql, ToUTF8(s
9590: 74 72 43 6f 6c 6c 61 74 69 6f 6e 29 2c 20 32 2c  trCollation), 2,
95a0: 20 49 6e 74 50 74 72 2e 5a 65 72 6f 2c 20 66 75   IntPtr.Zero, fu
95b0: 6e 63 31 36 29 3b 0d 0a 20 20 20 20 20 20 69 66  nc16);..      if
95c0: 20 28 6e 20 3d 3d 20 30 29 20 6e 20 3d 20 55 6e   (n == 0) n = Un
95d0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
95e0: 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65  s.sqlite3_create
95f0: 5f 63 6f 6c 6c 61 74 69 6f 6e 28 5f 73 71 6c 2c  _collation(_sql,
9600: 20 54 6f 55 54 46 38 28 73 74 72 43 6f 6c 6c 61   ToUTF8(strColla
9610: 74 69 6f 6e 29 2c 20 31 2c 20 49 6e 74 50 74 72  tion), 1, IntPtr
9620: 2e 5a 65 72 6f 2c 20 66 75 6e 63 29 3b 0d 0a 20  .Zero, func);.. 
9630: 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20       if (n > 0) 
9640: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
9650: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74  Exception(n, Get
9660: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20  LastError());.. 
9670: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
9680: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e  rnal override in
9690: 74 20 43 6f 6e 74 65 78 74 43 6f 6c 6c 61 74 65  t ContextCollate
96a0: 43 6f 6d 70 61 72 65 28 43 6f 6c 6c 61 74 69 6f  Compare(Collatio
96b0: 6e 45 6e 63 6f 64 69 6e 67 45 6e 75 6d 20 65 6e  nEncodingEnum en
96c0: 63 2c 20 49 6e 74 50 74 72 20 63 6f 6e 74 65 78  c, IntPtr contex
96d0: 74 2c 20 73 74 72 69 6e 67 20 73 31 2c 20 73 74  t, string s1, st
96e0: 72 69 6e 67 20 73 32 29 0d 0a 20 20 20 20 7b 0d  ring s2)..    {.
96f0: 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41  .#if !SQLITE_STA
9700: 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 62 79 74  NDARD..      byt
9710: 65 5b 5d 20 62 31 3b 0d 0a 20 20 20 20 20 20 62  e[] b1;..      b
9720: 79 74 65 5b 5d 20 62 32 3b 0d 0a 20 20 20 20 20  yte[] b2;..     
9730: 20 53 79 73 74 65 6d 2e 54 65 78 74 2e 45 6e 63   System.Text.Enc
9740: 6f 64 69 6e 67 20 63 6f 6e 76 65 72 74 65 72 20  oding converter 
9750: 3d 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 20  = null;....     
9760: 20 73 77 69 74 63 68 20 28 65 6e 63 29 0d 0a 20   switch (enc).. 
9770: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
9780: 63 61 73 65 20 43 6f 6c 6c 61 74 69 6f 6e 45 6e  case CollationEn
9790: 63 6f 64 69 6e 67 45 6e 75 6d 2e 55 54 46 38 3a  codingEnum.UTF8:
97a0: 0d 0a 20 20 20 20 20 20 20 20 20 20 63 6f 6e 76  ..          conv
97b0: 65 72 74 65 72 20 3d 20 53 79 73 74 65 6d 2e 54  erter = System.T
97c0: 65 78 74 2e 45 6e 63 6f 64 69 6e 67 2e 55 54 46  ext.Encoding.UTF
97d0: 38 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 62 72  8;..          br
97e0: 65 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20 63 61  eak;..        ca
97f0: 73 65 20 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f  se CollationEnco
9800: 64 69 6e 67 45 6e 75 6d 2e 55 54 46 31 36 4c 45  dingEnum.UTF16LE
9810: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 63 6f 6e  :..          con
9820: 76 65 72 74 65 72 20 3d 20 53 79 73 74 65 6d 2e  verter = System.
9830: 54 65 78 74 2e 45 6e 63 6f 64 69 6e 67 2e 55 6e  Text.Encoding.Un
9840: 69 63 6f 64 65 3b 0d 0a 20 20 20 20 20 20 20 20  icode;..        
9850: 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20 20 20    break;..      
9860: 20 20 63 61 73 65 20 43 6f 6c 6c 61 74 69 6f 6e    case Collation
9870: 45 6e 63 6f 64 69 6e 67 45 6e 75 6d 2e 55 54 46  EncodingEnum.UTF
9880: 31 36 42 45 3a 0d 0a 20 20 20 20 20 20 20 20 20  16BE:..         
9890: 20 63 6f 6e 76 65 72 74 65 72 20 3d 20 53 79 73   converter = Sys
98a0: 74 65 6d 2e 54 65 78 74 2e 45 6e 63 6f 64 69 6e  tem.Text.Encodin
98b0: 67 2e 42 69 67 45 6e 64 69 61 6e 55 6e 69 63 6f  g.BigEndianUnico
98c0: 64 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 62  de;..          b
98d0: 72 65 61 6b 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a  reak;..      }..
98e0: 0d 0a 20 20 20 20 20 20 62 31 20 3d 20 63 6f 6e  ..      b1 = con
98f0: 76 65 72 74 65 72 2e 47 65 74 42 79 74 65 73 28  verter.GetBytes(
9900: 73 31 29 3b 0d 0a 20 20 20 20 20 20 62 32 20 3d  s1);..      b2 =
9910: 20 63 6f 6e 76 65 72 74 65 72 2e 47 65 74 42 79   converter.GetBy
9920: 74 65 73 28 73 32 29 3b 0d 0a 0d 0a 20 20 20 20  tes(s2);....    
9930: 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e    return UnsafeN
9940: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
9950: 69 74 65 33 5f 63 6f 6e 74 65 78 74 5f 63 6f 6c  ite3_context_col
9960: 6c 63 6f 6d 70 61 72 65 28 63 6f 6e 74 65 78 74  lcompare(context
9970: 2c 20 62 31 2c 20 62 31 2e 4c 65 6e 67 74 68 2c  , b1, b1.Length,
9980: 20 62 32 2c 20 62 32 2e 4c 65 6e 67 74 68 29 3b   b2, b2.Length);
9990: 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 74  ..#else..      t
99a0: 68 72 6f 77 20 6e 65 77 20 4e 6f 74 49 6d 70 6c  hrow new NotImpl
99b0: 65 6d 65 6e 74 65 64 45 78 63 65 70 74 69 6f 6e  ementedException
99c0: 28 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20  ();..#endif..   
99d0: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
99e0: 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  al override int 
99f0: 43 6f 6e 74 65 78 74 43 6f 6c 6c 61 74 65 43 6f  ContextCollateCo
9a00: 6d 70 61 72 65 28 43 6f 6c 6c 61 74 69 6f 6e 45  mpare(CollationE
9a10: 6e 63 6f 64 69 6e 67 45 6e 75 6d 20 65 6e 63 2c  ncodingEnum enc,
9a20: 20 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c   IntPtr context,
9a30: 20 63 68 61 72 5b 5d 20 63 31 2c 20 63 68 61 72   char[] c1, char
9a40: 5b 5d 20 63 32 29 0d 0a 20 20 20 20 7b 0d 0a 23  [] c2)..    {..#
9a50: 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44  if !SQLITE_STAND
9a60: 41 52 44 0d 0a 20 20 20 20 20 20 62 79 74 65 5b  ARD..      byte[
9a70: 5d 20 62 31 3b 0d 0a 20 20 20 20 20 20 62 79 74  ] b1;..      byt
9a80: 65 5b 5d 20 62 32 3b 0d 0a 20 20 20 20 20 20 53  e[] b2;..      S
9a90: 79 73 74 65 6d 2e 54 65 78 74 2e 45 6e 63 6f 64  ystem.Text.Encod
9aa0: 69 6e 67 20 63 6f 6e 76 65 72 74 65 72 20 3d 20  ing converter = 
9ab0: 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 73  null;....      s
9ac0: 77 69 74 63 68 20 28 65 6e 63 29 0d 0a 20 20 20  witch (enc)..   
9ad0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 63 61     {..        ca
9ae0: 73 65 20 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f  se CollationEnco
9af0: 64 69 6e 67 45 6e 75 6d 2e 55 54 46 38 3a 0d 0a  dingEnum.UTF8:..
9b00: 20 20 20 20 20 20 20 20 20 20 63 6f 6e 76 65 72            conver
9b10: 74 65 72 20 3d 20 53 79 73 74 65 6d 2e 54 65 78  ter = System.Tex
9b20: 74 2e 45 6e 63 6f 64 69 6e 67 2e 55 54 46 38 3b  t.Encoding.UTF8;
9b30: 0d 0a 20 20 20 20 20 20 20 20 20 20 62 72 65 61  ..          brea
9b40: 6b 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65  k;..        case
9b50: 20 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69   CollationEncodi
9b60: 6e 67 45 6e 75 6d 2e 55 54 46 31 36 4c 45 3a 0d  ngEnum.UTF16LE:.
9b70: 0a 20 20 20 20 20 20 20 20 20 20 63 6f 6e 76 65  .          conve
9b80: 72 74 65 72 20 3d 20 53 79 73 74 65 6d 2e 54 65  rter = System.Te
9b90: 78 74 2e 45 6e 63 6f 64 69 6e 67 2e 55 6e 69 63  xt.Encoding.Unic
9ba0: 6f 64 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  ode;..          
9bb0: 62 72 65 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20  break;..        
9bc0: 63 61 73 65 20 43 6f 6c 6c 61 74 69 6f 6e 45 6e  case CollationEn
9bd0: 63 6f 64 69 6e 67 45 6e 75 6d 2e 55 54 46 31 36  codingEnum.UTF16
9be0: 42 45 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 63  BE:..          c
9bf0: 6f 6e 76 65 72 74 65 72 20 3d 20 53 79 73 74 65  onverter = Syste
9c00: 6d 2e 54 65 78 74 2e 45 6e 63 6f 64 69 6e 67 2e  m.Text.Encoding.
9c10: 42 69 67 45 6e 64 69 61 6e 55 6e 69 63 6f 64 65  BigEndianUnicode
9c20: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 62 72 65  ;..          bre
9c30: 61 6b 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a  ak;..      }....
9c40: 20 20 20 20 20 20 62 31 20 3d 20 63 6f 6e 76 65        b1 = conve
9c50: 72 74 65 72 2e 47 65 74 42 79 74 65 73 28 63 31  rter.GetBytes(c1
9c60: 29 3b 0d 0a 20 20 20 20 20 20 62 32 20 3d 20 63  );..      b2 = c
9c70: 6f 6e 76 65 72 74 65 72 2e 47 65 74 42 79 74 65  onverter.GetByte
9c80: 73 28 63 32 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  s(c2);....      
9c90: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
9ca0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
9cb0: 65 33 5f 63 6f 6e 74 65 78 74 5f 63 6f 6c 6c 63  e3_context_collc
9cc0: 6f 6d 70 61 72 65 28 63 6f 6e 74 65 78 74 2c 20  ompare(context, 
9cd0: 62 31 2c 20 62 31 2e 4c 65 6e 67 74 68 2c 20 62  b1, b1.Length, b
9ce0: 32 2c 20 62 32 2e 4c 65 6e 67 74 68 29 3b 0d 0a  2, b2.Length);..
9cf0: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 74 68 72  #else..      thr
9d00: 6f 77 20 6e 65 77 20 4e 6f 74 49 6d 70 6c 65 6d  ow new NotImplem
9d10: 65 6e 74 65 64 45 78 63 65 70 74 69 6f 6e 28 29  entedException()
9d20: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d  ;..#endif..    }
9d30: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
9d40: 20 6f 76 65 72 72 69 64 65 20 43 6f 6c 6c 61 74   override Collat
9d50: 69 6f 6e 53 65 71 75 65 6e 63 65 20 47 65 74 43  ionSequence GetC
9d60: 6f 6c 6c 61 74 69 6f 6e 53 65 71 75 65 6e 63 65  ollationSequence
9d70: 28 53 51 4c 69 74 65 46 75 6e 63 74 69 6f 6e 20  (SQLiteFunction 
9d80: 66 75 6e 63 2c 20 49 6e 74 50 74 72 20 63 6f 6e  func, IntPtr con
9d90: 74 65 78 74 29 0d 0a 20 20 20 20 7b 0d 0a 23 69  text)..    {..#i
9da0: 66 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41  f !SQLITE_STANDA
9db0: 52 44 0d 0a 20 20 20 20 20 20 43 6f 6c 6c 61 74  RD..      Collat
9dc0: 69 6f 6e 53 65 71 75 65 6e 63 65 20 73 65 71 20  ionSequence seq 
9dd0: 3d 20 6e 65 77 20 43 6f 6c 6c 61 74 69 6f 6e 53  = new CollationS
9de0: 65 71 75 65 6e 63 65 28 29 3b 0d 0a 20 20 20 20  equence();..    
9df0: 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20    int len;..    
9e00: 20 20 69 6e 74 20 74 79 70 65 3b 0d 0a 20 20 20    int type;..   
9e10: 20 20 20 69 6e 74 20 65 6e 63 3b 0d 0a 20 20 20     int enc;..   
9e20: 20 20 20 49 6e 74 50 74 72 20 70 20 3d 20 55 6e     IntPtr p = Un
9e30: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
9e40: 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78  s.sqlite3_contex
9e50: 74 5f 63 6f 6c 6c 73 65 71 28 63 6f 6e 74 65 78  t_collseq(contex
9e60: 74 2c 20 6f 75 74 20 74 79 70 65 2c 20 6f 75 74  t, out type, out
9e70: 20 65 6e 63 2c 20 6f 75 74 20 6c 65 6e 29 3b 0d   enc, out len);.
9e80: 0a 0d 0a 20 20 20 20 20 20 69 66 20 28 70 20 21  ...      if (p !
9e90: 3d 20 6e 75 6c 6c 29 20 73 65 71 2e 4e 61 6d 65  = null) seq.Name
9ea0: 20 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28   = UTF8ToString(
9eb0: 70 2c 20 6c 65 6e 29 3b 0d 0a 20 20 20 20 20 20  p, len);..      
9ec0: 73 65 71 2e 54 79 70 65 20 3d 20 28 43 6f 6c 6c  seq.Type = (Coll
9ed0: 61 74 69 6f 6e 54 79 70 65 45 6e 75 6d 29 74 79  ationTypeEnum)ty
9ee0: 70 65 3b 0d 0a 20 20 20 20 20 20 73 65 71 2e 5f  pe;..      seq._
9ef0: 66 75 6e 63 20 3d 20 66 75 6e 63 3b 0d 0a 20 20  func = func;..  
9f00: 20 20 20 20 73 65 71 2e 45 6e 63 6f 64 69 6e 67      seq.Encoding
9f10: 20 3d 20 28 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63   = (CollationEnc
9f20: 6f 64 69 6e 67 45 6e 75 6d 29 65 6e 63 3b 0d 0a  odingEnum)enc;..
9f30: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 73  ..      return s
9f40: 65 71 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  eq;..#else..    
9f50: 20 20 74 68 72 6f 77 20 6e 65 77 20 4e 6f 74 49    throw new NotI
9f60: 6d 70 6c 65 6d 65 6e 74 65 64 45 78 63 65 70 74  mplementedExcept
9f70: 69 6f 6e 28 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  ion();..#endif..
9f80: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
9f90: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c  ernal override l
9fa0: 6f 6e 67 20 47 65 74 50 61 72 61 6d 56 61 6c 75  ong GetParamValu
9fb0: 65 42 79 74 65 73 28 49 6e 74 50 74 72 20 70 2c  eBytes(IntPtr p,
9fc0: 20 69 6e 74 20 6e 44 61 74 61 4f 66 66 73 65 74   int nDataOffset
9fd0: 2c 20 62 79 74 65 5b 5d 20 62 44 65 73 74 2c 20  , byte[] bDest, 
9fe0: 69 6e 74 20 6e 53 74 61 72 74 2c 20 69 6e 74 20  int nStart, int 
9ff0: 6e 4c 65 6e 67 74 68 29 0d 0a 20 20 20 20 7b 0d  nLength)..    {.
a000: 0a 20 20 20 20 20 20 69 6e 74 20 6e 6c 65 6e 20  .      int nlen 
a010: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
a020: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
a030: 6c 75 65 5f 62 79 74 65 73 28 70 29 3b 0d 0a 0d  lue_bytes(p);...
a040: 0a 20 20 20 20 20 20 2f 2f 20 49 66 20 6e 6f 20  .      // If no 
a050: 64 65 73 74 69 6e 61 74 69 6f 6e 20 62 75 66 66  destination buff
a060: 65 72 2c 20 72 65 74 75 72 6e 20 74 68 65 20 73  er, return the s
a070: 69 7a 65 20 6e 65 65 64 65 64 2e 0d 0a 20 20 20  ize needed...   
a080: 20 20 20 69 66 20 28 62 44 65 73 74 20 3d 3d 20     if (bDest == 
a090: 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20 6e 6c 65  null) return nle
a0a0: 6e 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 6e 74 20  n;....      int 
a0b0: 6e 43 6f 70 69 65 64 20 3d 20 6e 4c 65 6e 67 74  nCopied = nLengt
a0c0: 68 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20 28  h;....      if (
a0d0: 6e 43 6f 70 69 65 64 20 2b 20 6e 53 74 61 72 74  nCopied + nStart
a0e0: 20 3e 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 29   > bDest.Length)
a0f0: 20 6e 43 6f 70 69 65 64 20 3d 20 62 44 65 73 74   nCopied = bDest
a100: 2e 4c 65 6e 67 74 68 20 2d 20 6e 53 74 61 72 74  .Length - nStart
a110: 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f  ;..      if (nCo
a120: 70 69 65 64 20 2b 20 6e 44 61 74 61 4f 66 66 73  pied + nDataOffs
a130: 65 74 20 3e 20 6e 6c 65 6e 29 20 6e 43 6f 70 69  et > nlen) nCopi
a140: 65 64 20 3d 20 6e 6c 65 6e 20 2d 20 6e 44 61 74  ed = nlen - nDat
a150: 61 4f 66 66 73 65 74 3b 0d 0a 0d 0a 20 20 20 20  aOffset;....    
a160: 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 3e 20    if (nCopied > 
a170: 30 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20  0)..      {..   
a180: 20 20 20 20 20 49 6e 74 50 74 72 20 70 74 72 20       IntPtr ptr 
a190: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
a1a0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
a1b0: 6c 75 65 5f 62 6c 6f 62 28 70 29 3b 0d 0a 0d 0a  lue_blob(p);....
a1c0: 20 20 20 20 20 20 20 20 4d 61 72 73 68 61 6c 2e          Marshal.
a1d0: 43 6f 70 79 28 28 49 6e 74 50 74 72 29 28 70 74  Copy((IntPtr)(pt
a1e0: 72 2e 54 6f 49 6e 74 36 34 28 29 20 2b 20 6e 44  r.ToInt64() + nD
a1f0: 61 74 61 4f 66 66 73 65 74 29 2c 20 62 44 65 73  ataOffset), bDes
a200: 74 2c 20 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69  t, nStart, nCopi
a210: 65 64 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20  ed);..      }.. 
a220: 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20       else..     
a230: 20 7b 0d 0a 20 20 20 20 20 20 20 20 6e 43 6f 70   {..        nCop
a240: 69 65 64 20 3d 20 30 3b 0d 0a 20 20 20 20 20 20  ied = 0;..      
a250: 7d 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72  }....      retur
a260: 6e 20 6e 43 6f 70 69 65 64 3b 0d 0a 20 20 20 20  n nCopied;..    
a270: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
a280: 6c 20 6f 76 65 72 72 69 64 65 20 64 6f 75 62 6c  l override doubl
a290: 65 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 44  e GetParamValueD
a2a0: 6f 75 62 6c 65 28 49 6e 74 50 74 72 20 70 74 72  ouble(IntPtr ptr
a2b0: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
a2c0: 64 6f 75 62 6c 65 20 76 61 6c 75 65 3b 0d 0a 23  double value;..#
a2d0: 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d  if !PLATFORM_COM
a2e0: 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20  PACTFRAMEWORK.. 
a2f0: 20 20 20 20 20 76 61 6c 75 65 20 3d 20 55 6e 73       value = Uns
a300: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
a310: 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 64  .sqlite3_value_d
a320: 6f 75 62 6c 65 28 70 74 72 29 3b 0d 0a 23 65 6c  ouble(ptr);..#el
a330: 73 65 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65  se..      Unsafe
a340: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
a350: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 64 6f 75 62  lite3_value_doub
a360: 6c 65 5f 69 6e 74 65 72 6f 70 28 70 74 72 2c 20  le_interop(ptr, 
a370: 6f 75 74 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e  out value);..#en
a380: 64 69 66 0d 0a 20 20 20 20 20 20 72 65 74 75 72  dif..      retur
a390: 6e 20 76 61 6c 75 65 3b 0d 0a 20 20 20 20 7d 0d  n value;..    }.
a3a0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
a3b0: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 47 65 74  override int Get
a3c0: 50 61 72 61 6d 56 61 6c 75 65 49 6e 74 33 32 28  ParamValueInt32(
a3d0: 49 6e 74 50 74 72 20 70 74 72 29 0d 0a 20 20 20  IntPtr ptr)..   
a3e0: 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e   {..      return
a3f0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
a400: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c  hods.sqlite3_val
a410: 75 65 5f 69 6e 74 28 70 74 72 29 3b 0d 0a 20 20  ue_int(ptr);..  
a420: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
a430: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e  nal override lon
a440: 67 20 47 65 74 50 61 72 61 6d 56 61 6c 75 65 49  g GetParamValueI
a450: 6e 74 36 34 28 49 6e 74 50 74 72 20 70 74 72 29  nt64(IntPtr ptr)
a460: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 49  ..    {..      I
a470: 6e 74 36 34 20 76 61 6c 75 65 3b 0d 0a 23 69 66  nt64 value;..#if
a480: 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41   !PLATFORM_COMPA
a490: 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20  CTFRAMEWORK..   
a4a0: 20 20 20 76 61 6c 75 65 20 3d 20 55 6e 73 61 66     value = Unsaf
a4b0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
a4c0: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74  qlite3_value_int
a4d0: 36 34 28 70 74 72 29 3b 0d 0a 23 65 6c 73 65 0d  64(ptr);..#else.
a4e0: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
a4f0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
a500: 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 5f 69  e3_value_int64_i
a510: 6e 74 65 72 6f 70 28 70 74 72 2c 20 6f 75 74 20  nterop(ptr, out 
a520: 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d  value);..#endif.
a530: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 76 61  .      return va
a540: 6c 75 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  lue;..    }.... 
a550: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
a560: 72 69 64 65 20 73 74 72 69 6e 67 20 47 65 74 50  ride string GetP
a570: 61 72 61 6d 56 61 6c 75 65 54 65 78 74 28 49 6e  aramValueText(In
a580: 74 50 74 72 20 70 74 72 29 0d 0a 20 20 20 20 7b  tPtr ptr)..    {
a590: 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54  ..#if !SQLITE_ST
a5a0: 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 69 6e  ANDARD..      in
a5b0: 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 72 65  t len;..      re
a5c0: 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e  turn UTF8ToStrin
a5d0: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
a5e0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
a5f0: 6c 75 65 5f 74 65 78 74 5f 69 6e 74 65 72 6f 70  lue_text_interop
a600: 28 70 74 72 2c 20 6f 75 74 20 6c 65 6e 29 2c 20  (ptr, out len), 
a610: 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20  len);..#else..  
a620: 20 20 20 20 72 65 74 75 72 6e 20 55 54 46 38 54      return UTF8T
a630: 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61  oString(UnsafeNa
a640: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
a650: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 28 70  te3_value_text(p
a660: 74 72 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69  tr), -1);..#endi
a670: 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  f..    }....    
a680: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
a690: 65 20 54 79 70 65 41 66 66 69 6e 69 74 79 20 47  e TypeAffinity G
a6a0: 65 74 50 61 72 61 6d 56 61 6c 75 65 54 79 70 65  etParamValueType
a6b0: 28 49 6e 74 50 74 72 20 70 74 72 29 0d 0a 20 20  (IntPtr ptr)..  
a6c0: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72    {..      retur
a6d0: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
a6e0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
a6f0: 6c 75 65 5f 74 79 70 65 28 70 74 72 29 3b 0d 0a  lue_type(ptr);..
a700: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
a710: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
a720: 6f 69 64 20 52 65 74 75 72 6e 42 6c 6f 62 28 49  oid ReturnBlob(I
a730: 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20 62  ntPtr context, b
a740: 79 74 65 5b 5d 20 76 61 6c 75 65 29 0d 0a 20 20  yte[] value)..  
a750: 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e 73 61 66    {..      Unsaf
a760: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
a770: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 62 6c  qlite3_result_bl
a780: 6f 62 28 63 6f 6e 74 65 78 74 2c 20 76 61 6c 75  ob(context, valu
a790: 65 2c 20 76 61 6c 75 65 2e 4c 65 6e 67 74 68 2c  e, value.Length,
a7a0: 20 28 49 6e 74 50 74 72 29 28 2d 31 29 29 3b 0d   (IntPtr)(-1));.
a7b0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
a7c0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
a7d0: 76 6f 69 64 20 52 65 74 75 72 6e 44 6f 75 62 6c  void ReturnDoubl
a7e0: 65 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74  e(IntPtr context
a7f0: 2c 20 64 6f 75 62 6c 65 20 76 61 6c 75 65 29 0d  , double value).
a800: 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 50 4c 41  .    {..#if !PLA
a810: 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41  TFORM_COMPACTFRA
a820: 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 55 6e  MEWORK..      Un
a830: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
a840: 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74  s.sqlite3_result
a850: 5f 64 6f 75 62 6c 65 28 63 6f 6e 74 65 78 74 2c  _double(context,
a860: 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c 73 65 0d   value);..#else.
a870: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
a880: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
a890: 65 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65  e3_result_double
a8a0: 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74  _interop(context
a8b0: 2c 20 72 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23  , ref value);..#
a8c0: 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  endif..    }....
a8d0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
a8e0: 72 72 69 64 65 20 76 6f 69 64 20 52 65 74 75 72  rride void Retur
a8f0: 6e 45 72 72 6f 72 28 49 6e 74 50 74 72 20 63 6f  nError(IntPtr co
a900: 6e 74 65 78 74 2c 20 73 74 72 69 6e 67 20 76 61  ntext, string va
a910: 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  lue)..    {..   
a920: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
a930: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72  ethods.sqlite3_r
a940: 65 73 75 6c 74 5f 65 72 72 6f 72 28 63 6f 6e 74  esult_error(cont
a950: 65 78 74 2c 20 54 6f 55 54 46 38 28 76 61 6c 75  ext, ToUTF8(valu
a960: 65 29 2c 20 76 61 6c 75 65 2e 4c 65 6e 67 74 68  e), value.Length
a970: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
a980: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
a990: 64 65 20 76 6f 69 64 20 52 65 74 75 72 6e 49 6e  de void ReturnIn
a9a0: 74 33 32 28 49 6e 74 50 74 72 20 63 6f 6e 74 65  t32(IntPtr conte
a9b0: 78 74 2c 20 69 6e 74 20 76 61 6c 75 65 29 0d 0a  xt, int value)..
a9c0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e 73      {..      Uns
a9d0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
a9e0: 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f  .sqlite3_result_
a9f0: 69 6e 74 28 63 6f 6e 74 65 78 74 2c 20 76 61 6c  int(context, val
aa00: 75 65 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ue);..    }.... 
aa10: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
aa20: 72 69 64 65 20 76 6f 69 64 20 52 65 74 75 72 6e  ride void Return
aa30: 49 6e 74 36 34 28 49 6e 74 50 74 72 20 63 6f 6e  Int64(IntPtr con
aa40: 74 65 78 74 2c 20 6c 6f 6e 67 20 76 61 6c 75 65  text, long value
aa50: 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 50  )..    {..#if !P
aa60: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
aa70: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20  RAMEWORK..      
aa80: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
aa90: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75  ods.sqlite3_resu
aaa0: 6c 74 5f 69 6e 74 36 34 28 63 6f 6e 74 65 78 74  lt_int64(context
aab0: 2c 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c 73 65  , value);..#else
aac0: 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  ..      UnsafeNa
aad0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
aae0: 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34  te3_result_int64
aaf0: 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 74 65 78 74  _interop(context
ab00: 2c 20 72 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23  , ref value);..#
ab10: 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  endif..    }....
ab20: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
ab30: 72 72 69 64 65 20 76 6f 69 64 20 52 65 74 75 72  rride void Retur
ab40: 6e 4e 75 6c 6c 28 49 6e 74 50 74 72 20 63 6f 6e  nNull(IntPtr con
ab50: 74 65 78 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  text)..    {..  
ab60: 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65      UnsafeNative
ab70: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
ab80: 72 65 73 75 6c 74 5f 6e 75 6c 6c 28 63 6f 6e 74  result_null(cont
ab90: 65 78 74 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  ext);..    }....
aba0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
abb0: 72 72 69 64 65 20 76 6f 69 64 20 52 65 74 75 72  rride void Retur
abc0: 6e 54 65 78 74 28 49 6e 74 50 74 72 20 63 6f 6e  nText(IntPtr con
abd0: 74 65 78 74 2c 20 73 74 72 69 6e 67 20 76 61 6c  text, string val
abe0: 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ue)..    {..    
abf0: 20 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55    byte[] b = ToU
ac00: 54 46 38 28 76 61 6c 75 65 29 3b 0d 0a 20 20 20  TF8(value);..   
ac10: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
ac20: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72  ethods.sqlite3_r
ac30: 65 73 75 6c 74 5f 74 65 78 74 28 63 6f 6e 74 65  esult_text(conte
ac40: 78 74 2c 20 54 6f 55 54 46 38 28 76 61 6c 75 65  xt, ToUTF8(value
ac50: 29 2c 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c  ), b.Length - 1,
ac60: 20 28 49 6e 74 50 74 72 29 28 2d 31 29 29 3b 0d   (IntPtr)(-1));.
ac70: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
ac80: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
ac90: 49 6e 74 50 74 72 20 41 67 67 72 65 67 61 74 65  IntPtr Aggregate
aca0: 43 6f 6e 74 65 78 74 28 49 6e 74 50 74 72 20 63  Context(IntPtr c
acb0: 6f 6e 74 65 78 74 29 0d 0a 20 20 20 20 7b 0d 0a  ontext)..    {..
acc0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73        return Uns
acd0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
ace0: 2e 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67 61  .sqlite3_aggrega
acf0: 74 65 5f 63 6f 6e 74 65 78 74 28 63 6f 6e 74 65  te_context(conte
ad00: 78 74 2c 20 31 29 3b 0d 0a 20 20 20 20 7d 0d 0a  xt, 1);..    }..
ad10: 0d 0a 20 20 20 20 2f 2f 2f 20 45 6e 61 62 6c 65  ..    /// Enable
ad20: 73 20 6f 72 20 64 69 73 61 62 6c 65 64 20 65 78  s or disabled ex
ad30: 74 65 6e 64 65 64 20 72 65 73 75 6c 74 20 63 6f  tended result co
ad40: 64 65 73 20 72 65 74 75 72 6e 65 64 20 62 79 20  des returned by 
ad50: 53 51 4c 69 74 65 0d 0a 20 20 20 20 69 6e 74 65  SQLite..    inte
ad60: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f  rnal override vo
ad70: 69 64 20 53 65 74 45 78 74 65 6e 64 65 64 52 65  id SetExtendedRe
ad80: 73 75 6c 74 43 6f 64 65 73 28 62 6f 6f 6c 20 62  sultCodes(bool b
ad90: 4f 6e 4f 66 66 29 0d 0a 20 20 20 20 7b 0d 0a 20  OnOff)..    {.. 
ada0: 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76       UnsafeNativ
adb0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
adc0: 5f 65 78 74 65 6e 64 65 64 5f 72 65 73 75 6c 74  _extended_result
add0: 5f 63 6f 64 65 73 28 5f 73 71 6c 2c 20 28 62 4f  _codes(_sql, (bO
ade0: 6e 4f 66 66 20 3f 20 2d 31 20 3a 20 30 29 29 3b  nOff ? -1 : 0));
adf0: 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20 2f 2f 2f  ..    }..    ///
ae00: 20 47 65 74 73 20 74 68 65 20 6c 61 73 74 20 53   Gets the last S
ae10: 51 4c 69 74 65 20 65 72 72 6f 72 20 63 6f 64 65  QLite error code
ae20: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
ae30: 76 65 72 72 69 64 65 20 69 6e 74 20 52 65 73 75  verride int Resu
ae40: 6c 74 43 6f 64 65 28 29 0d 0a 20 20 20 20 7b 0d  ltCode()..    {.
ae50: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e  .      return Un
ae60: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
ae70: 73 2e 73 71 6c 69 74 65 33 5f 65 72 72 63 6f 64  s.sqlite3_errcod
ae80: 65 28 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 7d 0d  e(_sql);..    }.
ae90: 0a 20 20 20 20 2f 2f 2f 20 47 65 74 73 20 74 68  .    /// Gets th
aea0: 65 20 6c 61 73 74 20 53 51 4c 69 74 65 20 65 78  e last SQLite ex
aeb0: 74 65 6e 64 65 64 20 65 72 72 6f 72 20 63 6f 64  tended error cod
aec0: 65 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  e..    internal 
aed0: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 45 78 74  override int Ext
aee0: 65 6e 64 65 64 52 65 73 75 6c 74 43 6f 64 65 28  endedResultCode(
aef0: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
af00: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
af10: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
af20: 65 33 5f 65 78 74 65 6e 64 65 64 5f 65 72 72 63  e3_extended_errc
af30: 6f 64 65 28 5f 73 71 6c 29 3b 0d 0a 20 20 20 20  ode(_sql);..    
af40: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 41 64 64  }....    /// Add
af50: 20 61 20 6c 6f 67 20 6d 65 73 73 61 67 65 20 76   a log message v
af60: 69 61 20 74 68 65 20 53 51 4c 69 74 65 20 73 71  ia the SQLite sq
af70: 6c 69 74 65 33 5f 6c 6f 67 20 69 6e 74 65 72 66  lite3_log interf
af80: 61 63 65 2e 0d 0a 20 20 20 20 69 6e 74 65 72 6e  ace...    intern
af90: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
afa0: 20 4c 6f 67 4d 65 73 73 61 67 65 28 69 6e 74 20   LogMessage(int 
afb0: 69 45 72 72 43 6f 64 65 2c 20 73 74 72 69 6e 67  iErrCode, string
afc0: 20 7a 4d 65 73 73 61 67 65 29 0d 0a 20 20 20 20   zMessage)..    
afd0: 7b 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e  {..      UnsafeN
afe0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
aff0: 69 74 65 33 5f 6c 6f 67 28 69 45 72 72 43 6f 64  ite3_log(iErrCod
b000: 65 2c 20 54 6f 55 54 46 38 28 7a 4d 65 73 73 61  e, ToUTF8(zMessa
b010: 67 65 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  ge));..    }....
b020: 23 69 66 20 49 4e 54 45 52 4f 50 5f 43 4f 44 45  #if INTEROP_CODE
b030: 43 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  C..    internal 
b040: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 53 65  override void Se
b050: 74 50 61 73 73 77 6f 72 64 28 62 79 74 65 5b 5d  tPassword(byte[]
b060: 20 70 61 73 73 77 6f 72 64 42 79 74 65 73 29 0d   passwordBytes).
b070: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69 6e  .    {..      in
b080: 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  t n = UnsafeNati
b090: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
b0a0: 33 5f 6b 65 79 28 5f 73 71 6c 2c 20 70 61 73 73  3_key(_sql, pass
b0b0: 77 6f 72 64 42 79 74 65 73 2c 20 70 61 73 73 77  wordBytes, passw
b0c0: 6f 72 64 42 79 74 65 73 2e 4c 65 6e 67 74 68 29  ordBytes.Length)
b0d0: 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e  ;..      if (n >
b0e0: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
b0f0: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
b100: 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29   GetLastError())
b110: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
b120: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
b130: 65 20 76 6f 69 64 20 43 68 61 6e 67 65 50 61 73  e void ChangePas
b140: 73 77 6f 72 64 28 62 79 74 65 5b 5d 20 6e 65 77  sword(byte[] new
b150: 50 61 73 73 77 6f 72 64 42 79 74 65 73 29 0d 0a  PasswordBytes)..
b160: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69 6e 74      {..      int
b170: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
b180: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
b190: 5f 72 65 6b 65 79 28 5f 73 71 6c 2c 20 6e 65 77  _rekey(_sql, new
b1a0: 50 61 73 73 77 6f 72 64 42 79 74 65 73 2c 20 28  PasswordBytes, (
b1b0: 6e 65 77 50 61 73 73 77 6f 72 64 42 79 74 65 73  newPasswordBytes
b1c0: 20 3d 3d 20 6e 75 6c 6c 29 20 3f 20 30 20 3a 20   == null) ? 0 : 
b1d0: 6e 65 77 50 61 73 73 77 6f 72 64 42 79 74 65 73  newPasswordBytes
b1e0: 2e 4c 65 6e 67 74 68 29 3b 0d 0a 20 20 20 20 20  .Length);..     
b1f0: 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f   if (n > 0) thro
b200: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
b210: 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74  ption(n, GetLast
b220: 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d  Error());..    }
b230: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20  ..#endif....    
b240: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
b250: 65 20 76 6f 69 64 20 53 65 74 55 70 64 61 74 65  e void SetUpdate
b260: 48 6f 6f 6b 28 53 51 4c 69 74 65 55 70 64 61 74  Hook(SQLiteUpdat
b270: 65 43 61 6c 6c 62 61 63 6b 20 66 75 6e 63 29 0d  eCallback func).
b280: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e  .    {..      Un
b290: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
b2a0: 73 2e 73 71 6c 69 74 65 33 5f 75 70 64 61 74 65  s.sqlite3_update
b2b0: 5f 68 6f 6f 6b 28 5f 73 71 6c 2c 20 66 75 6e 63  _hook(_sql, func
b2c0: 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f 29 3b 0d  , IntPtr.Zero);.
b2d0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
b2e0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
b2f0: 76 6f 69 64 20 53 65 74 43 6f 6d 6d 69 74 48 6f  void SetCommitHo
b300: 6f 6b 28 53 51 4c 69 74 65 43 6f 6d 6d 69 74 43  ok(SQLiteCommitC
b310: 61 6c 6c 62 61 63 6b 20 66 75 6e 63 29 0d 0a 20  allback func).. 
b320: 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e 73 61     {..      Unsa
b330: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
b340: 73 71 6c 69 74 65 33 5f 63 6f 6d 6d 69 74 5f 68  sqlite3_commit_h
b350: 6f 6f 6b 28 5f 73 71 6c 2c 20 66 75 6e 63 2c 20  ook(_sql, func, 
b360: 49 6e 74 50 74 72 2e 5a 65 72 6f 29 3b 0d 0a 20  IntPtr.Zero);.. 
b370: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
b380: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f  rnal override vo
b390: 69 64 20 53 65 74 54 72 61 63 65 43 61 6c 6c 62  id SetTraceCallb
b3a0: 61 63 6b 28 53 51 4c 69 74 65 54 72 61 63 65 43  ack(SQLiteTraceC
b3b0: 61 6c 6c 62 61 63 6b 20 66 75 6e 63 29 0d 0a 20  allback func).. 
b3c0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e 73 61     {..      Unsa
b3d0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
b3e0: 73 71 6c 69 74 65 33 5f 74 72 61 63 65 28 5f 73  sqlite3_trace(_s
b3f0: 71 6c 2c 20 66 75 6e 63 2c 20 49 6e 74 50 74 72  ql, func, IntPtr
b400: 2e 5a 65 72 6f 29 3b 0d 0a 20 20 20 20 7d 0d 0a  .Zero);..    }..
b410: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
b420: 76 65 72 72 69 64 65 20 76 6f 69 64 20 53 65 74  verride void Set
b430: 52 6f 6c 6c 62 61 63 6b 48 6f 6f 6b 28 53 51 4c  RollbackHook(SQL
b440: 69 74 65 52 6f 6c 6c 62 61 63 6b 43 61 6c 6c 62  iteRollbackCallb
b450: 61 63 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b  ack func)..    {
b460: 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  ..      UnsafeNa
b470: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
b480: 74 65 33 5f 72 6f 6c 6c 62 61 63 6b 5f 68 6f 6f  te3_rollback_hoo
b490: 6b 28 5f 73 71 6c 2c 20 66 75 6e 63 2c 20 49 6e  k(_sql, func, In
b4a0: 74 50 74 72 2e 5a 65 72 6f 29 3b 0d 0a 20 20 20  tPtr.Zero);..   
b4b0: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73   }....    /// <s
b4c0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
b4d0: 20 41 6c 6c 6f 77 73 20 74 68 65 20 73 65 74 74   Allows the sett
b4e0: 69 6e 67 20 6f 66 20 61 20 6c 6f 67 67 69 6e 67  ing of a logging
b4f0: 20 63 61 6c 6c 62 61 63 6b 20 69 6e 76 6f 6b 65   callback invoke
b500: 64 20 62 79 20 53 51 4c 69 74 65 20 77 68 65 6e  d by SQLite when
b510: 20 61 0d 0a 20 20 20 20 2f 2f 2f 20 6c 6f 67 20   a..    /// log 
b520: 65 76 65 6e 74 20 6f 63 63 75 72 73 2e 20 20 4f  event occurs.  O
b530: 6e 6c 79 20 6f 6e 65 20 63 61 6c 6c 62 61 63 6b  nly one callback
b540: 20 6d 61 79 20 62 65 20 73 65 74 2e 20 20 49 66   may be set.  If
b550: 20 4e 55 4c 4c 20 69 73 20 70 61 73 73 65 64 2c   NULL is passed,
b560: 0d 0a 20 20 20 20 2f 2f 2f 20 74 68 65 20 6c 6f  ..    /// the lo
b570: 67 67 69 6e 67 20 63 61 6c 6c 62 61 63 6b 20 69  gging callback i
b580: 73 20 75 6e 72 65 67 69 73 74 65 72 65 64 2e 0d  s unregistered..
b590: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
b5a0: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  ry>..    /// <pa
b5b0: 72 61 6d 20 6e 61 6d 65 3d 22 66 75 6e 63 22 3e  ram name="func">
b5c0: 54 68 65 20 63 61 6c 6c 62 61 63 6b 20 66 75 6e  The callback fun
b5d0: 63 74 69 6f 6e 20 74 6f 20 69 6e 76 6f 6b 65 2e  ction to invoke.
b5e0: 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f  </param>..    //
b5f0: 2f 20 3c 72 65 74 75 72 6e 73 3e 52 65 74 75 72  / <returns>Retur
b600: 6e 73 20 61 20 72 65 73 75 6c 74 20 63 6f 64 65  ns a result code
b610: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
b620: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
b630: 65 20 69 6e 74 20 53 65 74 4c 6f 67 43 61 6c 6c  e int SetLogCall
b640: 62 61 63 6b 28 53 51 4c 69 74 65 4c 6f 67 43 61  back(SQLiteLogCa
b650: 6c 6c 62 61 63 6b 20 66 75 6e 63 29 0d 0a 20 20  llback func)..  
b660: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 6e 74    {..        int
b670: 20 72 63 20 3d 20 55 6e 73 61 66 65 4e 61 74 69   rc = UnsafeNati
b680: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
b690: 33 5f 63 6f 6e 66 69 67 28 0d 0a 20 20 20 20 20  3_config(..     
b6a0: 20 20 20 20 20 20 20 28 69 6e 74 29 53 51 4c 69         (int)SQLi
b6b0: 74 65 43 6f 6e 66 69 67 4f 70 73 45 6e 75 6d 2e  teConfigOpsEnum.
b6c0: 53 51 4c 49 54 45 5f 43 4f 4e 46 49 47 5f 4c 4f  SQLITE_CONFIG_LO
b6d0: 47 2c 20 66 75 6e 63 2c 20 28 49 6e 74 50 74 72  G, func, (IntPtr
b6e0: 29 30 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  )0);....        
b6f0: 72 65 74 75 72 6e 20 72 63 3b 0d 0a 20 20 20 20  return rc;..    
b700: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f 2f 2f 2f  }....    ///////
b710: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b720: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b730: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b740: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b750: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b760: 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20  ////////....    
b770: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
b780: 20 20 20 2f 2f 2f 20 43 72 65 61 74 65 73 20 61     /// Creates a
b790: 20 6e 65 77 20 53 51 4c 69 74 65 20 62 61 63 6b   new SQLite back
b7a0: 75 70 20 6f 62 6a 65 63 74 20 62 61 73 65 64 20  up object based 
b7b0: 6f 6e 20 74 68 65 20 70 72 6f 76 69 64 65 64 20  on the provided 
b7c0: 64 65 73 74 69 6e 61 74 69 6f 6e 0d 0a 20 20 20  destination..   
b7d0: 20 2f 2f 2f 20 64 61 74 61 62 61 73 65 20 63 6f   /// database co
b7e0: 6e 6e 65 63 74 69 6f 6e 2e 20 20 54 68 65 20 73  nnection.  The s
b7f0: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 63  ource database c
b800: 6f 6e 6e 65 63 74 69 6f 6e 20 69 73 20 74 68 65  onnection is the
b810: 20 6f 6e 65 0d 0a 20 20 20 20 2f 2f 2f 20 61 73   one..    /// as
b820: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68  sociated with th
b830: 69 73 20 6f 62 6a 65 63 74 2e 20 20 54 68 65 20  is object.  The 
b840: 73 6f 75 72 63 65 20 61 6e 64 20 64 65 73 74 69  source and desti
b850: 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 0d  nation database.
b860: 0a 20 20 20 20 2f 2f 2f 20 63 6f 6e 6e 65 63 74  .    /// connect
b870: 69 6f 6e 73 20 63 61 6e 6e 6f 74 20 62 65 20 74  ions cannot be t
b880: 68 65 20 73 61 6d 65 2e 0d 0a 20 20 20 20 2f 2f  he same...    //
b890: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
b8a0: 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d    /// <param nam
b8b0: 65 3d 22 64 65 73 74 43 6e 6e 22 3e 54 68 65 20  e="destCnn">The 
b8c0: 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61  destination data
b8d0: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e  base connection.
b8e0: 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f  </param>..    //
b8f0: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 64  / <param name="d
b900: 65 73 74 4e 61 6d 65 22 3e 54 68 65 20 64 65 73  estName">The des
b910: 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73  tination databas
b920: 65 20 6e 61 6d 65 2e 3c 2f 70 61 72 61 6d 3e 0d  e name.</param>.
b930: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
b940: 6e 61 6d 65 3d 22 73 6f 75 72 63 65 4e 61 6d 65  name="sourceName
b950: 22 3e 54 68 65 20 73 6f 75 72 63 65 20 64 61 74  ">The source dat
b960: 61 62 61 73 65 20 6e 61 6d 65 2e 3c 2f 70 61 72  abase name.</par
b970: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  am>..    /// <re
b980: 74 75 72 6e 73 3e 54 68 65 20 6e 65 77 6c 79 20  turns>The newly 
b990: 63 72 65 61 74 65 64 20 62 61 63 6b 75 70 20 6f  created backup o
b9a0: 62 6a 65 63 74 2e 3c 2f 72 65 74 75 72 6e 73 3e  bject.</returns>
b9b0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
b9c0: 76 65 72 72 69 64 65 20 53 51 4c 69 74 65 42 61  verride SQLiteBa
b9d0: 63 6b 75 70 20 49 6e 69 74 69 61 6c 69 7a 65 42  ckup InitializeB
b9e0: 61 63 6b 75 70 28 0d 0a 20 20 20 20 20 20 20 20  ackup(..        
b9f0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
ba00: 20 64 65 73 74 43 6e 6e 2c 0d 0a 20 20 20 20 20   destCnn,..     
ba10: 20 20 20 73 74 72 69 6e 67 20 64 65 73 74 4e 61     string destNa
ba20: 6d 65 2c 0d 0a 20 20 20 20 20 20 20 20 73 74 72  me,..        str
ba30: 69 6e 67 20 73 6f 75 72 63 65 4e 61 6d 65 0d 0a  ing sourceName..
ba40: 20 20 20 20 20 20 20 20 29 0d 0a 20 20 20 20 7b          )..    {
ba50: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 64 65  ..        if (de
ba60: 73 74 43 6e 6e 20 3d 3d 20 6e 75 6c 6c 29 0d 0a  stCnn == null)..
ba70: 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72 6f              thro
ba80: 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 4e 75  w new ArgumentNu
ba90: 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 64 65 73  llException("des
baa0: 74 43 6e 6e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20  tCnn");....     
bab0: 20 20 20 69 66 20 28 64 65 73 74 4e 61 6d 65 20     if (destName 
bac0: 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20  == null)..      
bad0: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
bae0: 41 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65  ArgumentNullExce
baf0: 70 74 69 6f 6e 28 22 64 65 73 74 4e 61 6d 65 22  ption("destName"
bb00: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66  );....        if
bb10: 20 28 73 6f 75 72 63 65 4e 61 6d 65 20 3d 3d 20   (sourceName == 
bb20: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
bb30: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41 72 67     throw new Arg
bb40: 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69  umentNullExcepti
bb50: 6f 6e 28 22 73 6f 75 72 63 65 4e 61 6d 65 22 29  on("sourceName")
bb60: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 51 4c  ;....        SQL
bb70: 69 74 65 33 20 64 65 73 74 53 71 6c 69 74 65 33  ite3 destSqlite3
bb80: 20 3d 20 64 65 73 74 43 6e 6e 2e 5f 73 71 6c 20   = destCnn._sql 
bb90: 61 73 20 53 51 4c 69 74 65 33 3b 0d 0a 0d 0a 20  as SQLite3;.... 
bba0: 20 20 20 20 20 20 20 69 66 20 28 64 65 73 74 53         if (destS
bbb0: 71 6c 69 74 65 33 20 3d 3d 20 6e 75 6c 6c 29 0d  qlite3 == null).
bbc0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72  .            thr
bbd0: 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 45  ow new ArgumentE
bbe0: 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20  xception(..     
bbf0: 20 20 20 20 20 20 20 20 20 20 20 22 44 65 73 74             "Dest
bc00: 69 6e 61 74 69 6f 6e 20 63 6f 6e 6e 65 63 74 69  ination connecti
bc10: 6f 6e 20 68 61 73 20 6e 6f 20 77 72 61 70 70 65  on has no wrappe
bc20: 72 2e 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20  r.",..          
bc30: 20 20 20 20 20 20 22 64 65 73 74 43 6e 6e 22 29        "destCnn")
bc40: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 51 4c  ;....        SQL
bc50: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 48 61 6e  iteConnectionHan
bc60: 64 6c 65 20 64 65 73 74 48 61 6e 64 6c 65 20 3d  dle destHandle =
bc70: 20 64 65 73 74 53 71 6c 69 74 65 33 2e 5f 73 71   destSqlite3._sq
bc80: 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66  l;....        if
bc90: 20 28 64 65 73 74 48 61 6e 64 6c 65 20 3d 3d 20   (destHandle == 
bca0: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
bcb0: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41 72 67     throw new Arg
bcc0: 75 6d 65 6e 74 45 78 63 65 70 74 69 6f 6e 28 0d  umentException(.
bcd0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
bce0: 20 22 44 65 73 74 69 6e 61 74 69 6f 6e 20 63 6f   "Destination co
bcf0: 6e 6e 65 63 74 69 6f 6e 20 68 61 73 20 61 6e 20  nnection has an 
bd00: 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 2e 22  invalid handle."
bd10: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ,..             
bd20: 20 20 20 22 64 65 73 74 43 6e 6e 22 29 3b 0d 0a     "destCnn");..
bd30: 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65  ..        SQLite
bd40: 43 6f 6e 6e 65 63 74 69 6f 6e 48 61 6e 64 6c 65  ConnectionHandle
bd50: 20 73 6f 75 72 63 65 48 61 6e 64 6c 65 20 3d 20   sourceHandle = 
bd60: 5f 73 71 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  _sql;....       
bd70: 20 69 66 20 28 73 6f 75 72 63 65 48 61 6e 64 6c   if (sourceHandl
bd80: 65 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20  e == null)..    
bd90: 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65          throw ne
bda0: 77 20 49 6e 76 61 6c 69 64 4f 70 65 72 61 74 69  w InvalidOperati
bdb0: 6f 6e 45 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20  onException(..  
bdc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 53                "S
bdd0: 6f 75 72 63 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  ource connection
bde0: 20 68 61 73 20 61 6e 20 69 6e 76 61 6c 69 64 20   has an invalid 
bdf0: 68 61 6e 64 6c 65 2e 22 29 3b 0d 0a 0d 0a 20 20  handle.");....  
be00: 20 20 20 20 20 20 62 79 74 65 5b 5d 20 7a 44 65        byte[] zDe
be10: 73 74 4e 61 6d 65 20 3d 20 54 6f 55 54 46 38 28  stName = ToUTF8(
be20: 64 65 73 74 4e 61 6d 65 29 3b 0d 0a 20 20 20 20  destName);..    
be30: 20 20 20 20 62 79 74 65 5b 5d 20 7a 53 6f 75 72      byte[] zSour
be40: 63 65 4e 61 6d 65 20 3d 20 54 6f 55 54 46 38 28  ceName = ToUTF8(
be50: 73 6f 75 72 63 65 4e 61 6d 65 29 3b 0d 0a 0d 0a  sourceName);....
be60: 20 20 20 20 20 20 20 20 49 6e 74 50 74 72 20 62          IntPtr b
be70: 61 63 6b 75 70 20 3d 20 55 6e 73 61 66 65 4e 61  ackup = UnsafeNa
be80: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
be90: 74 65 33 5f 62 61 63 6b 75 70 5f 69 6e 69 74 28  te3_backup_init(
bea0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 64 65  ..            de
beb0: 73 74 48 61 6e 64 6c 65 2c 20 7a 44 65 73 74 4e  stHandle, zDestN
bec0: 61 6d 65 2c 20 73 6f 75 72 63 65 48 61 6e 64 6c  ame, sourceHandl
bed0: 65 2c 20 7a 53 6f 75 72 63 65 4e 61 6d 65 29 3b  e, zSourceName);
bee0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  ....        if (
bef0: 62 61 63 6b 75 70 20 3d 3d 20 49 6e 74 50 74 72  backup == IntPtr
bf00: 2e 5a 65 72 6f 29 0d 0a 20 20 20 20 20 20 20 20  .Zero)..        
bf10: 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53 51      throw new SQ
bf20: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 52 65  LiteException(Re
bf30: 73 75 6c 74 43 6f 64 65 28 29 2c 20 47 65 74 4c  sultCode(), GetL
bf40: 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 0d 0a  astError());....
bf50: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e          return n
bf60: 65 77 20 53 51 4c 69 74 65 42 61 63 6b 75 70 28  ew SQLiteBackup(
bf70: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68  ..            th
bf80: 69 73 2c 20 6e 65 77 20 53 51 4c 69 74 65 42 61  is, new SQLiteBa
bf90: 63 6b 75 70 48 61 6e 64 6c 65 28 64 65 73 74 48  ckupHandle(destH
bfa0: 61 6e 64 6c 65 2c 20 62 61 63 6b 75 70 29 2c 0d  andle, backup),.
bfb0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 64 65 73  .            des
bfc0: 74 48 61 6e 64 6c 65 2c 20 7a 44 65 73 74 4e 61  tHandle, zDestNa
bfd0: 6d 65 2c 20 73 6f 75 72 63 65 48 61 6e 64 6c 65  me, sourceHandle
bfe0: 2c 20 7a 53 6f 75 72 63 65 4e 61 6d 65 29 3b 0d  , zSourceName);.
bff0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
c000: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
c010: 20 2f 2f 2f 20 43 6f 70 69 65 73 20 75 70 20 74   /// Copies up t
c020: 6f 20 4e 20 70 61 67 65 73 20 66 72 6f 6d 20 74  o N pages from t
c030: 68 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61  he source databa
c040: 73 65 20 74 6f 20 74 68 65 20 64 65 73 74 69 6e  se to the destin
c050: 61 74 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20 64  ation..    /// d
c060: 61 74 61 62 61 73 65 20 61 73 73 6f 63 69 61 74  atabase associat
c070: 65 64 20 77 69 74 68 20 74 68 65 20 73 70 65 63  ed with the spec
c080: 69 66 69 65 64 20 62 61 63 6b 75 70 20 6f 62 6a  ified backup obj
c090: 65 63 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ect...    /// </
c0a0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
c0b0: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 62  / <param name="b
c0c0: 61 63 6b 75 70 22 3e 54 68 65 20 62 61 63 6b 75  ackup">The backu
c0d0: 70 20 6f 62 6a 65 63 74 20 74 6f 20 75 73 65 2e  p object to use.
c0e0: 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f  </param>..    //
c0f0: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6e  / <param name="n
c100: 50 61 67 65 22 3e 0d 0a 20 20 20 20 2f 2f 2f 20  Page">..    /// 
c110: 54 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61  The number of pa
c120: 67 65 73 20 74 6f 20 63 6f 70 79 2c 20 6e 65 67  ges to copy, neg
c130: 61 74 69 76 65 20 74 6f 20 63 6f 70 79 20 61 6c  ative to copy al
c140: 6c 20 72 65 6d 61 69 6e 69 6e 67 20 70 61 67 65  l remaining page
c150: 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 70 61  s...    /// </pa
c160: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ram>..    /// <p
c170: 61 72 61 6d 20 6e 61 6d 65 3d 22 72 65 74 72 79  aram name="retry
c180: 22 3e 0d 0a 20 20 20 20 2f 2f 2f 20 53 65 74 20  ">..    /// Set 
c190: 74 6f 20 74 72 75 65 20 69 66 20 74 68 65 20 6f  to true if the o
c1a0: 70 65 72 61 74 69 6f 6e 20 6e 65 65 64 73 20 74  peration needs t
c1b0: 6f 20 62 65 20 72 65 74 72 69 65 64 20 64 75 65  o be retried due
c1c0: 20 74 6f 20 64 61 74 61 62 61 73 65 0d 0a 20 20   to database..  
c1d0: 20 20 2f 2f 2f 20 6c 6f 63 6b 69 6e 67 20 69 73    /// locking is
c1e0: 73 75 65 73 3b 20 6f 74 68 65 72 77 69 73 65 2c  sues; otherwise,
c1f0: 20 73 65 74 20 74 6f 20 66 61 6c 73 65 2e 0d 0a   set to false...
c200: 20 20 20 20 2f 2f 2f 20 3c 2f 70 61 72 61 6d 3e      /// </param>
c210: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  ..    /// <retur
c220: 6e 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 72 75  ns>..    /// Tru
c230: 65 20 69 66 20 74 68 65 72 65 20 61 72 65 20 6d  e if there are m
c240: 6f 72 65 20 70 61 67 65 73 20 74 6f 20 62 65 20  ore pages to be 
c250: 63 6f 70 69 65 64 2c 20 66 61 6c 73 65 20 6f 74  copied, false ot
c260: 68 65 72 77 69 73 65 2e 0d 0a 20 20 20 20 2f 2f  herwise...    //
c270: 2f 20 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20  / </returns>..  
c280: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
c290: 69 64 65 20 62 6f 6f 6c 20 53 74 65 70 42 61 63  ide bool StepBac
c2a0: 6b 75 70 28 0d 0a 20 20 20 20 20 20 20 20 53 51  kup(..        SQ
c2b0: 4c 69 74 65 42 61 63 6b 75 70 20 62 61 63 6b 75  LiteBackup backu
c2c0: 70 2c 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20  p,..        int 
c2d0: 6e 50 61 67 65 2c 0d 0a 20 20 20 20 20 20 20 20  nPage,..        
c2e0: 6f 75 74 20 62 6f 6f 6c 20 72 65 74 72 79 0d 0a  out bool retry..
c2f0: 20 20 20 20 20 20 20 20 29 0d 0a 20 20 20 20 7b          )..    {
c300: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 72 79 20  ..        retry 
c310: 3d 20 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 20  = false;....    
c320: 20 20 20 20 69 66 20 28 62 61 63 6b 75 70 20 3d      if (backup =
c330: 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20  = null)..       
c340: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41       throw new A
c350: 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70  rgumentNullExcep
c360: 74 69 6f 6e 28 22 62 61 63 6b 75 70 22 29 3b 0d  tion("backup");.
c370: 0a 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74  ...        SQLit
c380: 65 42 61 63 6b 75 70 48 61 6e 64 6c 65 20 68 61  eBackupHandle ha
c390: 6e 64 6c 65 20 3d 20 62 61 63 6b 75 70 2e 5f 73  ndle = backup._s
c3a0: 71 6c 69 74 65 5f 62 61 63 6b 75 70 3b 0d 0a 0d  qlite_backup;...
c3b0: 0a 20 20 20 20 20 20 20 20 69 66 20 28 68 61 6e  .        if (han
c3c0: 64 6c 65 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20  dle == null)..  
c3d0: 20 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20            throw 
c3e0: 6e 65 77 20 49 6e 76 61 6c 69 64 4f 70 65 72 61  new InvalidOpera
c3f0: 74 69 6f 6e 45 78 63 65 70 74 69 6f 6e 28 0d 0a  tionException(..
c400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
c410: 22 42 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 68  "Backup object h
c420: 61 73 20 61 6e 20 69 6e 76 61 6c 69 64 20 68 61  as an invalid ha
c430: 6e 64 6c 65 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20  ndle.");....    
c440: 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64 6c      IntPtr handl
c450: 65 50 74 72 20 3d 20 68 61 6e 64 6c 65 3b 0d 0a  ePtr = handle;..
c460: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 68 61  ..        if (ha
c470: 6e 64 6c 65 50 74 72 20 3d 3d 20 49 6e 74 50 74  ndlePtr == IntPt
c480: 72 2e 5a 65 72 6f 29 0d 0a 20 20 20 20 20 20 20  r.Zero)..       
c490: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49       throw new I
c4a0: 6e 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45  nvalidOperationE
c4b0: 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20  xception(..     
c4c0: 20 20 20 20 20 20 20 20 20 20 20 22 42 61 63 6b             "Back
c4d0: 75 70 20 6f 62 6a 65 63 74 20 68 61 73 20 61 6e  up object has an
c4e0: 20 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 20   invalid handle 
c4f0: 70 6f 69 6e 74 65 72 2e 22 29 3b 0d 0a 0d 0a 20  pointer.");.... 
c500: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55         int n = U
c510: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
c520: 64 73 2e 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  ds.sqlite3_backu
c530: 70 5f 73 74 65 70 28 68 61 6e 64 6c 65 50 74 72  p_step(handlePtr
c540: 2c 20 6e 50 61 67 65 29 3b 0d 0a 20 20 20 20 20  , nPage);..     
c550: 20 20 20 62 61 63 6b 75 70 2e 5f 73 74 65 70 52     backup._stepR
c560: 65 73 75 6c 74 20 3d 20 6e 3b 20 2f 2a 20 4e 4f  esult = n; /* NO
c570: 54 45 3a 20 53 61 76 65 20 66 6f 72 20 75 73 65  TE: Save for use
c580: 20 62 79 20 46 69 6e 69 73 68 42 61 63 6b 75 70   by FinishBackup
c590: 2e 20 2a 2f 0d 0a 0d 0a 20 20 20 20 20 20 20 20  . */....        
c5a0: 69 66 20 28 6e 20 3d 3d 20 28 69 6e 74 29 53 51  if (n == (int)SQ
c5b0: 4c 69 74 65 45 72 72 6f 72 43 6f 64 65 2e 4f 6b  LiteErrorCode.Ok
c5c0: 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  )..        {..  
c5d0: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
c5e0: 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20 20   true;..        
c5f0: 7d 0d 0a 20 20 20 20 20 20 20 20 65 6c 73 65 20  }..        else 
c600: 69 66 20 28 6e 20 3d 3d 20 28 69 6e 74 29 53 51  if (n == (int)SQ
c610: 4c 69 74 65 45 72 72 6f 72 43 6f 64 65 2e 42 75  LiteErrorCode.Bu
c620: 73 79 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  sy)..        {..
c630: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 72              retr
c640: 79 20 3d 20 74 72 75 65 3b 0d 0a 20 20 20 20 20  y = true;..     
c650: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 74 72         return tr
c660: 75 65 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a  ue;..        }..
c670: 20 20 20 20 20 20 20 20 65 6c 73 65 20 69 66 20          else if 
c680: 28 6e 20 3d 3d 20 28 69 6e 74 29 53 51 4c 69 74  (n == (int)SQLit
c690: 65 45 72 72 6f 72 43 6f 64 65 2e 4c 6f 63 6b 65  eErrorCode.Locke
c6a0: 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  d)..        {.. 
c6b0: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 72 79             retry
c6c0: 20 3d 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20   = true;..      
c6d0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 74 72 75        return tru
c6e0: 65 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20  e;..        }.. 
c6f0: 20 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28         else if (
c700: 6e 20 3d 3d 20 28 69 6e 74 29 53 51 4c 69 74 65  n == (int)SQLite
c710: 45 72 72 6f 72 43 6f 64 65 2e 44 6f 6e 65 29 0d  ErrorCode.Done).
c720: 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  .        {..    
c730: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 66          return f
c740: 61 6c 73 65 3b 0d 0a 20 20 20 20 20 20 20 20 7d  alse;..        }
c750: 0d 0a 20 20 20 20 20 20 20 20 65 6c 73 65 0d 0a  ..        else..
c760: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
c770: 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77         throw new
c780: 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e   SQLiteException
c790: 28 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72  (n, GetLastError
c7a0: 28 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ());..        }.
c7b0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
c7c0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
c7d0: 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20 74 68 65   /// Returns the
c7e0: 20 6e 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73   number of pages
c7f0: 20 72 65 6d 61 69 6e 69 6e 67 20 74 6f 20 62 65   remaining to be
c800: 20 63 6f 70 69 65 64 20 66 72 6f 6d 20 74 68 65   copied from the
c810: 20 73 6f 75 72 63 65 0d 0a 20 20 20 20 2f 2f 2f   source..    ///
c820: 20 64 61 74 61 62 61 73 65 20 74 6f 20 74 68 65   database to the
c830: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74   destination dat
c840: 61 62 61 73 65 20 61 73 73 6f 63 69 61 74 65 64  abase associated
c850: 20 77 69 74 68 20 74 68 65 20 73 70 65 63 69 66   with the specif
c860: 69 65 64 0d 0a 20 20 20 20 2f 2f 2f 20 62 61 63  ied..    /// bac
c870: 6b 75 70 20 6f 62 6a 65 63 74 2e 0d 0a 20 20 20  kup object...   
c880: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
c890: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
c8a0: 6e 61 6d 65 3d 22 62 61 63 6b 75 70 22 3e 54 68  name="backup">Th
c8b0: 65 20 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 20  e backup object 
c8c0: 74 6f 20 63 68 65 63 6b 2e 3c 2f 70 61 72 61 6d  to check.</param
c8d0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75  >..    /// <retu
c8e0: 72 6e 73 3e 54 68 65 20 6e 75 6d 62 65 72 20 6f  rns>The number o
c8f0: 66 20 70 61 67 65 73 20 72 65 6d 61 69 6e 69 6e  f pages remainin
c900: 67 20 74 6f 20 62 65 20 63 6f 70 69 65 64 2e 3c  g to be copied.<
c910: 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69  /returns>..    i
c920: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
c930: 20 69 6e 74 20 52 65 6d 61 69 6e 69 6e 67 42 61   int RemainingBa
c940: 63 6b 75 70 28 0d 0a 20 20 20 20 20 20 20 20 53  ckup(..        S
c950: 51 4c 69 74 65 42 61 63 6b 75 70 20 62 61 63 6b  QLiteBackup back
c960: 75 70 0d 0a 20 20 20 20 20 20 20 20 29 0d 0a 20  up..        ).. 
c970: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66     {..        if
c980: 20 28 62 61 63 6b 75 70 20 3d 3d 20 6e 75 6c 6c   (backup == null
c990: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74  )..            t
c9a0: 68 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e  hrow new Argumen
c9b0: 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22  tNullException("
c9c0: 62 61 63 6b 75 70 22 29 3b 0d 0a 0d 0a 20 20 20  backup");....   
c9d0: 20 20 20 20 20 53 51 4c 69 74 65 42 61 63 6b 75       SQLiteBacku
c9e0: 70 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d  pHandle handle =
c9f0: 20 62 61 63 6b 75 70 2e 5f 73 71 6c 69 74 65 5f   backup._sqlite_
ca00: 62 61 63 6b 75 70 3b 0d 0a 0d 0a 20 20 20 20 20  backup;....     
ca10: 20 20 20 69 66 20 28 68 61 6e 64 6c 65 20 3d 3d     if (handle ==
ca20: 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20   null)..        
ca30: 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e      throw new In
ca40: 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78  validOperationEx
ca50: 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20 20  ception(..      
ca60: 20 20 20 20 20 20 20 20 20 20 22 42 61 63 6b 75            "Backu
ca70: 70 20 6f 62 6a 65 63 74 20 68 61 73 20 61 6e 20  p object has an 
ca80: 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 2e 22  invalid handle."
ca90: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 49 6e  );....        In
caa0: 74 50 74 72 20 68 61 6e 64 6c 65 50 74 72 20 3d  tPtr handlePtr =
cab0: 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20   handle;....    
cac0: 20 20 20 20 69 66 20 28 68 61 6e 64 6c 65 50 74      if (handlePt
cad0: 72 20 3d 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f  r == IntPtr.Zero
cae0: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74  )..            t
caf0: 68 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64  hrow new Invalid
cb00: 4f 70 65 72 61 74 69 6f 6e 45 78 63 65 70 74 69  OperationExcepti
cb10: 6f 6e 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  on(..           
cb20: 20 20 20 20 20 22 42 61 63 6b 75 70 20 6f 62 6a       "Backup obj
cb30: 65 63 74 20 68 61 73 20 61 6e 20 69 6e 76 61 6c  ect has an inval
cb40: 69 64 20 68 61 6e 64 6c 65 20 70 6f 69 6e 74 65  id handle pointe
cb50: 72 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  r.");....       
cb60: 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61   return UnsafeNa
cb70: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
cb80: 74 65 33 5f 62 61 63 6b 75 70 5f 72 65 6d 61 69  te3_backup_remai
cb90: 6e 69 6e 67 28 68 61 6e 64 6c 65 50 74 72 29 3b  ning(handlePtr);
cba0: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f  ..    }....    /
cbb0: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
cbc0: 20 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20 74 68    /// Returns th
cbd0: 65 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f  e total number o
cbe0: 66 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 73  f pages in the s
cbf0: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 61  ource database a
cc00: 73 73 6f 63 69 61 74 65 64 0d 0a 20 20 20 20 2f  ssociated..    /
cc10: 2f 2f 20 77 69 74 68 20 74 68 65 20 73 70 65 63  // with the spec
cc20: 69 66 69 65 64 20 62 61 63 6b 75 70 20 6f 62 6a  ified backup obj
cc30: 65 63 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ect...    /// </
cc40: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
cc50: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 62  / <param name="b
cc60: 61 63 6b 75 70 22 3e 54 68 65 20 62 61 63 6b 75  ackup">The backu
cc70: 70 20 6f 62 6a 65 63 74 20 74 6f 20 63 68 65 63  p object to chec
cc80: 6b 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  k.</param>..    
cc90: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65  /// <returns>The
cca0: 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66   total number of
ccb0: 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 73 6f   pages in the so
ccc0: 75 72 63 65 20 64 61 74 61 62 61 73 65 2e 3c 2f  urce database.</
ccd0: 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e  returns>..    in
cce0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
ccf0: 69 6e 74 20 50 61 67 65 43 6f 75 6e 74 42 61 63  int PageCountBac
cd00: 6b 75 70 28 0d 0a 20 20 20 20 20 20 20 20 53 51  kup(..        SQ
cd10: 4c 69 74 65 42 61 63 6b 75 70 20 62 61 63 6b 75  LiteBackup backu
cd20: 70 0d 0a 20 20 20 20 20 20 20 20 29 0d 0a 20 20  p..        )..  
cd30: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20    {..        if 
cd40: 28 62 61 63 6b 75 70 20 3d 3d 20 6e 75 6c 6c 29  (backup == null)
cd50: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68  ..            th
cd60: 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74  row new Argument
cd70: 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 62  NullException("b
cd80: 61 63 6b 75 70 22 29 3b 0d 0a 0d 0a 20 20 20 20  ackup");....    
cd90: 20 20 20 20 53 51 4c 69 74 65 42 61 63 6b 75 70      SQLiteBackup
cda0: 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20  Handle handle = 
cdb0: 62 61 63 6b 75 70 2e 5f 73 71 6c 69 74 65 5f 62  backup._sqlite_b
cdc0: 61 63 6b 75 70 3b 0d 0a 0d 0a 20 20 20 20 20 20  ackup;....      
cdd0: 20 20 69 66 20 28 68 61 6e 64 6c 65 20 3d 3d 20    if (handle == 
cde0: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
cdf0: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76     throw new Inv
ce00: 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63  alidOperationExc
ce10: 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20 20 20  eption(..       
ce20: 20 20 20 20 20 20 20 20 20 22 42 61 63 6b 75 70           "Backup
ce30: 20 6f 62 6a 65 63 74 20 68 61 73 20 61 6e 20 69   object has an i
ce40: 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 2e 22 29  nvalid handle.")
ce50: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 49 6e 74  ;....        Int
ce60: 50 74 72 20 68 61 6e 64 6c 65 50 74 72 20 3d 20  Ptr handlePtr = 
ce70: 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20  handle;....     
ce80: 20 20 20 69 66 20 28 68 61 6e 64 6c 65 50 74 72     if (handlePtr
ce90: 20 3d 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f 29   == IntPtr.Zero)
cea0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68  ..            th
ceb0: 72 6f 77 20 6e 65 77 20 49 6e 76 61 6c 69 64 4f  row new InvalidO
cec0: 70 65 72 61 74 69 6f 6e 45 78 63 65 70 74 69 6f  perationExceptio
ced0: 6e 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  n(..            
cee0: 20 20 20 20 22 42 61 63 6b 75 70 20 6f 62 6a 65      "Backup obje
cef0: 63 74 20 68 61 73 20 61 6e 20 69 6e 76 61 6c 69  ct has an invali
cf00: 64 20 68 61 6e 64 6c 65 20 70 6f 69 6e 74 65 72  d handle pointer
cf10: 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  .");....        
cf20: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
cf30: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
cf40: 65 33 5f 62 61 63 6b 75 70 5f 70 61 67 65 63 6f  e3_backup_pageco
cf50: 75 6e 74 28 68 61 6e 64 6c 65 50 74 72 29 3b 0d  unt(handlePtr);.
cf60: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
cf70: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
cf80: 20 2f 2f 2f 20 44 65 73 74 72 6f 79 73 20 74 68   /// Destroys th
cf90: 65 20 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 2c  e backup object,
cfa0: 20 72 6f 6c 6c 69 6e 67 20 62 61 63 6b 20 61 6e   rolling back an
cfb0: 79 20 62 61 63 6b 75 70 20 74 68 61 74 20 6d 61  y backup that ma
cfc0: 79 20 62 65 20 69 6e 0d 0a 20 20 20 20 2f 2f 2f  y be in..    ///
cfd0: 20 70 72 6f 67 65 73 73 2e 0d 0a 20 20 20 20 2f   progess...    /
cfe0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
cff0: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
d000: 6d 65 3d 22 62 61 63 6b 75 70 22 3e 54 68 65 20  me="backup">The 
d010: 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 74 6f  backup object to
d020: 20 64 65 73 74 72 6f 79 2e 3c 2f 70 61 72 61 6d   destroy.</param
d030: 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  >..    internal 
d040: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 46 69  override void Fi
d050: 6e 69 73 68 42 61 63 6b 75 70 28 0d 0a 20 20 20  nishBackup(..   
d060: 20 20 20 20 20 53 51 4c 69 74 65 42 61 63 6b 75       SQLiteBacku
d070: 70 20 62 61 63 6b 75 70 0d 0a 20 20 20 20 20 20  p backup..      
d080: 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20    )..    {..    
d090: 20 20 20 20 69 66 20 28 62 61 63 6b 75 70 20 3d      if (backup =
d0a0: 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20  = null)..       
d0b0: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41       throw new A
d0c0: 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70  rgumentNullExcep
d0d0: 74 69 6f 6e 28 22 62 61 63 6b 75 70 22 29 3b 0d  tion("backup");.
d0e0: 0a 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74  ...        SQLit
d0f0: 65 42 61 63 6b 75 70 48 61 6e 64 6c 65 20 68 61  eBackupHandle ha
d100: 6e 64 6c 65 20 3d 20 62 61 63 6b 75 70 2e 5f 73  ndle = backup._s
d110: 71 6c 69 74 65 5f 62 61 63 6b 75 70 3b 0d 0a 0d  qlite_backup;...
d120: 0a 20 20 20 20 20 20 20 20 69 66 20 28 68 61 6e  .        if (han
d130: 64 6c 65 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20  dle == null)..  
d140: 20 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20            throw 
d150: 6e 65 77 20 49 6e 76 61 6c 69 64 4f 70 65 72 61  new InvalidOpera
d160: 74 69 6f 6e 45 78 63 65 70 74 69 6f 6e 28 0d 0a  tionException(..
d170: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
d180: 22 42 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 68  "Backup object h
d190: 61 73 20 61 6e 20 69 6e 76 61 6c 69 64 20 68 61  as an invalid ha
d1a0: 6e 64 6c 65 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20  ndle.");....    
d1b0: 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64 6c      IntPtr handl
d1c0: 65 50 74 72 20 3d 20 68 61 6e 64 6c 65 3b 0d 0a  ePtr = handle;..
d1d0: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 68 61  ..        if (ha
d1e0: 6e 64 6c 65 50 74 72 20 3d 3d 20 49 6e 74 50 74  ndlePtr == IntPt
d1f0: 72 2e 5a 65 72 6f 29 0d 0a 20 20 20 20 20 20 20  r.Zero)..       
d200: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49       throw new I
d210: 6e 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45  nvalidOperationE
d220: 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20  xception(..     
d230: 20 20 20 20 20 20 20 20 20 20 20 22 42 61 63 6b             "Back
d240: 75 70 20 6f 62 6a 65 63 74 20 68 61 73 20 61 6e  up object has an
d250: 20 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 20   invalid handle 
d260: 70 6f 69 6e 74 65 72 2e 22 29 3b 0d 0a 0d 0a 20  pointer.");.... 
d270: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55         int n = U
d280: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
d290: 64 73 2e 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  ds.sqlite3_backu
d2a0: 70 5f 66 69 6e 69 73 68 28 68 61 6e 64 6c 65 50  p_finish(handleP
d2b0: 74 72 29 3b 0d 0a 20 20 20 20 20 20 20 20 68 61  tr);..        ha
d2c0: 6e 64 6c 65 2e 53 65 74 48 61 6e 64 6c 65 41 73  ndle.SetHandleAs
d2d0: 49 6e 76 61 6c 69 64 28 29 3b 0d 0a 0d 0a 20 20  Invalid();....  
d2e0: 20 20 20 20 20 20 69 66 20 28 28 6e 20 3e 20 30        if ((n > 0
d2f0: 29 20 26 26 20 28 6e 20 21 3d 20 62 61 63 6b 75  ) && (n != backu
d300: 70 2e 5f 73 74 65 70 52 65 73 75 6c 74 29 29 0d  p._stepResult)).
d310: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72  .            thr
d320: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
d330: 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73  eption(n, GetLas
d340: 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20  tError());..    
d350: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f 2f 2f 2f  }....    ///////
d360: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d370: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d380: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d390: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d3a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d3b0: 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20  ////////....    
d3c0: 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20  /// <summary>.. 
d3d0: 20 20 20 2f 2f 2f 20 44 65 74 65 72 6d 69 6e 65     /// Determine
d3e0: 73 20 69 66 20 74 68 65 20 53 51 4c 69 74 65 20  s if the SQLite 
d3f0: 63 6f 72 65 20 6c 69 62 72 61 72 79 20 68 61 73  core library has
d400: 20 62 65 65 6e 20 69 6e 69 74 69 61 6c 69 7a 65   been initialize
d410: 64 20 66 6f 72 20 74 68 65 0d 0a 20 20 20 20 2f  d for the..    /
d420: 2f 2f 20 63 75 72 72 65 6e 74 20 70 72 6f 63 65  // current proce
d430: 73 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ss...    /// </s
d440: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
d450: 20 3c 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20   <returns>..    
d460: 2f 2f 2f 20 41 20 62 6f 6f 6c 65 61 6e 20 69 6e  /// A boolean in
d470: 64 69 63 61 74 69 6e 67 20 77 68 65 74 68 65 72  dicating whether
d480: 20 6f 72 20 6e 6f 74 20 74 68 65 20 53 51 4c 69   or not the SQLi
d490: 74 65 20 63 6f 72 65 20 6c 69 62 72 61 72 79 20  te core library 
d4a0: 68 61 73 20 62 65 65 6e 0d 0a 20 20 20 20 2f 2f  has been..    //
d4b0: 2f 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 66 6f  / initialized fo
d4c0: 72 20 74 68 65 20 63 75 72 72 65 6e 74 20 70 72  r the current pr
d4d0: 6f 63 65 73 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20  ocess...    /// 
d4e0: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
d4f0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
d500: 65 20 62 6f 6f 6c 20 49 73 49 6e 69 74 69 61 6c  e bool IsInitial
d510: 69 7a 65 64 28 29 0d 0a 20 20 20 20 7b 0d 0a 20  ized()..    {.. 
d520: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 74         return St
d530: 61 74 69 63 49 73 49 6e 69 74 69 61 6c 69 7a 65  aticIsInitialize
d540: 64 28 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  d();..    }.... 
d550: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
d560: 0d 0a 20 20 20 20 2f 2f 2f 20 44 65 74 65 72 6d  ..    /// Determ
d570: 69 6e 65 73 20 69 66 20 74 68 65 20 53 51 4c 69  ines if the SQLi
d580: 74 65 20 63 6f 72 65 20 6c 69 62 72 61 72 79 20  te core library 
d590: 68 61 73 20 62 65 65 6e 20 69 6e 69 74 69 61 6c  has been initial
d5a0: 69 7a 65 64 20 66 6f 72 20 74 68 65 0d 0a 20 20  ized for the..  
d5b0: 20 20 2f 2f 2f 20 63 75 72 72 65 6e 74 20 70 72    /// current pr
d5c0: 6f 63 65 73 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20  ocess...    /// 
d5d0: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
d5e0: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 0d 0a 20  /// <returns>.. 
d5f0: 20 20 20 2f 2f 2f 20 41 20 62 6f 6f 6c 65 61 6e     /// A boolean
d600: 20 69 6e 64 69 63 61 74 69 6e 67 20 77 68 65 74   indicating whet
d610: 68 65 72 20 6f 72 20 6e 6f 74 20 74 68 65 20 53  her or not the S
d620: 51 4c 69 74 65 20 63 6f 72 65 20 6c 69 62 72 61  QLite core libra
d630: 72 79 20 68 61 73 20 62 65 65 6e 0d 0a 20 20 20  ry has been..   
d640: 20 2f 2f 2f 20 69 6e 69 74 69 61 6c 69 7a 65 64   /// initialized
d650: 20 66 6f 72 20 74 68 65 20 63 75 72 72 65 6e 74   for the current
d660: 20 70 72 6f 63 65 73 73 2e 0d 0a 20 20 20 20 2f   process...    /
d670: 2f 2f 20 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20  // </returns>.. 
d680: 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74     internal stat
d690: 69 63 20 62 6f 6f 6c 20 53 74 61 74 69 63 49 73  ic bool StaticIs
d6a0: 49 6e 69 74 69 61 6c 69 7a 65 64 28 29 0d 0a 20  Initialized().. 
d6b0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 2f 2f     {..        //
d6c0: 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 42 55 47  ..        // BUG
d6d0: 46 49 58 3a 20 50 72 65 76 65 6e 74 20 72 61 63  FIX: Prevent rac
d6e0: 65 73 20 77 69 74 68 20 6f 74 68 65 72 20 74 68  es with other th
d6f0: 72 65 61 64 73 20 66 6f 72 20 74 68 69 73 20 65  reads for this e
d700: 6e 74 69 72 65 20 62 6c 6f 63 6b 2c 20 64 75 65  ntire block, due
d710: 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20  ..        //    
d720: 20 20 20 20 20 74 6f 20 74 68 65 20 74 72 79 2f       to the try/
d730: 66 69 6e 61 6c 6c 79 20 73 65 6d 61 6e 74 69 63  finally semantic
d740: 73 2e 20 20 53 65 65 20 74 69 63 6b 65 74 20 5b  s.  See ticket [
d750: 37 32 39 30 35 63 39 61 37 37 5d 2e 0d 0a 20 20  72905c9a77]...  
d760: 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20        //..      
d770: 20 20 6c 6f 63 6b 20 28 73 79 6e 63 52 6f 6f 74    lock (syncRoot
d780: 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 23 69  )..        {..#i
d790: 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50  f !PLATFORM_COMP
d7a0: 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20  ACTFRAMEWORK..  
d7b0: 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20            //..  
d7c0: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54            // NOT
d7d0: 45 3a 20 53 61 76 65 20 74 68 65 20 73 74 61 74  E: Save the stat
d7e0: 65 20 6f 66 20 74 68 65 20 6c 6f 67 67 69 6e 67  e of the logging
d7f0: 20 63 6c 61 73 73 20 61 6e 64 20 74 68 65 6e 20   class and then 
d800: 72 65 73 74 6f 72 65 20 69 74 0d 0a 20 20 20 20  restore it..    
d810: 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 20 20          //      
d820: 20 61 66 74 65 72 20 77 65 20 61 72 65 20 64 6f   after we are do
d830: 6e 65 20 74 6f 20 61 76 6f 69 64 20 6c 6f 67 67  ne to avoid logg
d840: 69 6e 67 20 74 6f 6f 20 6d 61 6e 79 20 66 61 6c  ing too many fal
d850: 73 65 20 65 72 72 6f 72 73 2e 0d 0a 20 20 20 20  se errors...    
d860: 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20          //..    
d870: 20 20 20 20 20 20 20 20 62 6f 6f 6c 20 73 61 76          bool sav
d880: 65 64 45 6e 61 62 6c 65 64 20 3d 20 53 51 4c 69  edEnabled = SQLi
d890: 74 65 4c 6f 67 2e 45 6e 61 62 6c 65 64 3b 0d 0a  teLog.Enabled;..
d8a0: 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69              SQLi
d8b0: 74 65 4c 6f 67 2e 45 6e 61 62 6c 65 64 20 3d 20  teLog.Enabled = 
d8c0: 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 20 20 20  false;....      
d8d0: 20 20 20 20 20 20 74 72 79 0d 0a 20 20 20 20 20        try..     
d8e0: 20 20 20 20 20 20 20 7b 0d 0a 23 65 6e 64 69 66         {..#endif
d8f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
d900: 20 20 2f 2f 0d 0a 20 20 20 20 20 20 20 20 20 20    //..          
d910: 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45 3a 20 54        // NOTE: T
d920: 68 69 73 20 6d 65 74 68 6f 64 20 5b 61 62 5d 75  his method [ab]u
d930: 73 65 73 20 74 68 65 20 66 61 63 74 20 74 68 61  ses the fact tha
d940: 74 20 53 51 4c 69 74 65 20 77 69 6c 6c 20 61 6c  t SQLite will al
d950: 77 61 79 73 0d 0a 20 20 20 20 20 20 20 20 20 20  ways..          
d960: 20 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 72        //       r
d970: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52  eturn SQLITE_ERR
d980: 4f 52 20 66 6f 72 20 61 6e 79 20 75 6e 6b 6e 6f  OR for any unkno
d990: 77 6e 20 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e  wn configuration
d9a0: 20 6f 70 74 69 6f 6e 0d 0a 20 20 20 20 20 20 20   option..       
d9b0: 20 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 20           //     
d9c0: 20 20 2a 75 6e 6c 65 73 73 2a 20 74 68 65 20 53    *unless* the S
d9d0: 51 4c 69 74 65 20 6c 69 62 72 61 72 79 20 68 61  QLite library ha
d9e0: 73 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 69  s already been i
d9f0: 6e 69 74 69 61 6c 69 7a 65 64 2e 0d 0a 20 20 20  nitialized...   
da00: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20               // 
da10: 20 20 20 20 20 20 49 6e 20 74 68 61 74 20 63 61        In that ca
da20: 73 65 20 69 74 20 77 69 6c 6c 20 61 6c 77 61 79  se it will alway
da30: 73 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f  s return SQLITE_
da40: 4d 49 53 55 53 45 2e 0d 0a 20 20 20 20 20 20 20  MISUSE...       
da50: 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20           //..   
da60: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6e 74               int
da70: 20 72 63 20 3d 20 55 6e 73 61 66 65 4e 61 74 69   rc = UnsafeNati
da80: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
da90: 33 5f 63 6f 6e 66 69 67 28 0d 0a 20 20 20 20 20  3_config(..     
daa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28                 (
dab0: 69 6e 74 29 53 51 4c 69 74 65 43 6f 6e 66 69 67  int)SQLiteConfig
dac0: 4f 70 73 45 6e 75 6d 2e 53 51 4c 49 54 45 5f 43  OpsEnum.SQLITE_C
dad0: 4f 4e 46 49 47 5f 4e 4f 4e 45 2c 20 6e 75 6c 6c  ONFIG_NONE, null
dae0: 2c 20 28 49 6e 74 50 74 72 29 30 29 3b 0d 0a 0d  , (IntPtr)0);...
daf0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
db00: 20 72 65 74 75 72 6e 20 28 72 63 20 3d 3d 20 2f   return (rc == /
db10: 2a 20 53 51 4c 49 54 45 5f 4d 49 53 55 53 45 20  * SQLITE_MISUSE 
db20: 2a 2f 20 32 31 29 3b 0d 0a 23 69 66 20 21 50 4c  */ 21);..#if !PL
db30: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
db40: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20  AMEWORK..       
db50: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
db60: 20 20 20 20 66 69 6e 61 6c 6c 79 0d 0a 20 20 20      finally..   
db70: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
db80: 20 20 20 20 20 20 20 20 20 20 20 20 53 51 4c 69              SQLi
db90: 74 65 4c 6f 67 2e 45 6e 61 62 6c 65 64 20 3d 20  teLog.Enabled = 
dba0: 73 61 76 65 64 45 6e 61 62 6c 65 64 3b 0d 0a 20  savedEnabled;.. 
dbb0: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 23 65             }..#e
dbc0: 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ndif..        }.
dbd0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
dbe0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
dbf0: 20 2f 2f 2f 20 48 65 6c 70 65 72 20 66 75 6e 63   /// Helper func
dc00: 74 69 6f 6e 20 74 6f 20 72 65 74 72 69 65 76 65  tion to retrieve
dc10: 20 61 20 63 6f 6c 75 6d 6e 20 6f 66 20 64 61 74   a column of dat
dc20: 61 20 66 72 6f 6d 20 61 6e 20 61 63 74 69 76 65  a from an active
dc30: 20 73 74 61 74 65 6d 65 6e 74 2e 0d 0a 20 20 20   statement...   
dc40: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
dc50: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
dc60: 6e 61 6d 65 3d 22 73 74 6d 74 22 3e 54 68 65 20  name="stmt">The 
dc70: 73 74 61 74 65 6d 65 6e 74 20 62 65 69 6e 67 20  statement being 
dc80: 73 74 65 70 28 29 27 64 20 74 68 72 6f 75 67 68  step()'d through
dc90: 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f  </param>..    //
dca0: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 69  / <param name="i
dcb0: 6e 64 65 78 22 3e 54 68 65 20 63 6f 6c 75 6d 6e  ndex">The column
dcc0: 20 69 6e 64 65 78 20 74 6f 20 72 65 74 72 69 65   index to retrie
dcd0: 76 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  ve</param>..    
dce0: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
dcf0: 22 74 79 70 22 3e 54 68 65 20 74 79 70 65 20 6f  "typ">The type o
dd00: 66 20 64 61 74 61 20 63 6f 6e 74 61 69 6e 65 64  f data contained
dd10: 20 69 6e 20 74 68 65 20 63 6f 6c 75 6d 6e 2e 20   in the column. 
dd20: 20 49 66 20 55 6e 69 6e 69 74 69 61 6c 69 7a 65   If Uninitialize
dd30: 64 2c 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e  d, this function
dd40: 20 77 69 6c 6c 20 72 65 74 72 69 65 76 65 20 74   will retrieve t
dd50: 68 65 20 64 61 74 61 74 79 70 65 20 69 6e 66 6f  he datatype info
dd60: 72 6d 61 74 69 6f 6e 2e 3c 2f 70 61 72 61 6d 3e  rmation.</param>
dd70: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  ..    /// <retur
dd80: 6e 73 3e 52 65 74 75 72 6e 73 20 74 68 65 20 64  ns>Returns the d
dd90: 61 74 61 20 69 6e 20 74 68 65 20 63 6f 6c 75 6d  ata in the colum
dda0: 6e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20  n</returns>..   
ddb0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
ddc0: 64 65 20 6f 62 6a 65 63 74 20 47 65 74 56 61 6c  de object GetVal
ddd0: 75 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  ue(SQLiteStateme
dde0: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
ddf0: 65 78 2c 20 53 51 4c 69 74 65 54 79 70 65 20 74  ex, SQLiteType t
de00: 79 70 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  yp)..    {..    
de10: 20 20 69 66 20 28 49 73 4e 75 6c 6c 28 73 74 6d    if (IsNull(stm
de20: 74 2c 20 69 6e 64 65 78 29 29 20 72 65 74 75 72  t, index)) retur
de30: 6e 20 44 42 4e 75 6c 6c 2e 56 61 6c 75 65 3b 0d  n DBNull.Value;.
de40: 0a 20 20 20 20 20 20 54 79 70 65 41 66 66 69 6e  .      TypeAffin
de50: 69 74 79 20 61 66 66 20 3d 20 74 79 70 2e 41 66  ity aff = typ.Af
de60: 66 69 6e 69 74 79 3b 0d 0a 20 20 20 20 20 20 54  finity;..      T
de70: 79 70 65 20 74 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d  ype t = null;...
de80: 0a 20 20 20 20 20 20 69 66 20 28 74 79 70 2e 54  .      if (typ.T
de90: 79 70 65 20 21 3d 20 44 62 54 79 70 65 2e 4f 62  ype != DbType.Ob
dea0: 6a 65 63 74 29 0d 0a 20 20 20 20 20 20 7b 0d 0a  ject)..      {..
deb0: 20 20 20 20 20 20 20 20 74 20 3d 20 53 51 4c 69          t = SQLi
dec0: 74 65 43 6f 6e 76 65 72 74 2e 53 51 4c 69 74 65  teConvert.SQLite
ded0: 54 79 70 65 54 6f 54 79 70 65 28 74 79 70 29 3b  TypeToType(typ);
dee0: 0d 0a 20 20 20 20 20 20 20 20 61 66 66 20 3d 20  ..        aff = 
def0: 54 79 70 65 54 6f 41 66 66 69 6e 69 74 79 28 74  TypeToAffinity(t
df00: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20  );..      }.... 
df10: 20 20 20 20 20 73 77 69 74 63 68 20 28 61 66 66       switch (aff
df20: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  )..      {..    
df30: 20 20 20 20 63 61 73 65 20 54 79 70 65 41 66 66      case TypeAff
df40: 69 6e 69 74 79 2e 42 6c 6f 62 3a 0d 0a 20 20 20  inity.Blob:..   
df50: 20 20 20 20 20 20 20 69 66 20 28 74 79 70 2e 54         if (typ.T
df60: 79 70 65 20 3d 3d 20 44 62 54 79 70 65 2e 47 75  ype == DbType.Gu
df70: 69 64 20 26 26 20 74 79 70 2e 41 66 66 69 6e 69  id && typ.Affini
df80: 74 79 20 3d 3d 20 54 79 70 65 41 66 66 69 6e 69  ty == TypeAffini
df90: 74 79 2e 54 65 78 74 29 0d 0a 20 20 20 20 20 20  ty.Text)..      
dfa0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 65 77        return new
dfb0: 20 47 75 69 64 28 47 65 74 54 65 78 74 28 73 74   Guid(GetText(st
dfc0: 6d 74 2c 20 69 6e 64 65 78 29 29 3b 0d 0a 0d 0a  mt, index));....
dfd0: 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20            int n 
dfe0: 3d 20 28 69 6e 74 29 47 65 74 42 79 74 65 73 28  = (int)GetBytes(
dff0: 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 30 2c 20  stmt, index, 0, 
e000: 6e 75 6c 6c 2c 20 30 2c 20 30 29 3b 0d 0a 20 20  null, 0, 0);..  
e010: 20 20 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62          byte[] b
e020: 20 3d 20 6e 65 77 20 62 79 74 65 5b 6e 5d 3b 0d   = new byte[n];.
e030: 0a 20 20 20 20 20 20 20 20 20 20 47 65 74 42 79  .          GetBy
e040: 74 65 73 28 73 74 6d 74 2c 20 69 6e 64 65 78 2c  tes(stmt, index,
e050: 20 30 2c 20 62 2c 20 30 2c 20 6e 29 3b 0d 0a 0d   0, b, 0, n);...
e060: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74  .          if (t
e070: 79 70 2e 54 79 70 65 20 3d 3d 20 44 62 54 79 70  yp.Type == DbTyp
e080: 65 2e 47 75 69 64 20 26 26 20 6e 20 3d 3d 20 31  e.Guid && n == 1
e090: 36 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  6)..            
e0a0: 72 65 74 75 72 6e 20 6e 65 77 20 47 75 69 64 28  return new Guid(
e0b0: 62 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20  b);....         
e0c0: 20 72 65 74 75 72 6e 20 62 3b 0d 0a 20 20 20 20   return b;..    
e0d0: 20 20 20 20 63 61 73 65 20 54 79 70 65 41 66 66      case TypeAff
e0e0: 69 6e 69 74 79 2e 44 61 74 65 54 69 6d 65 3a 0d  inity.DateTime:.
e0f0: 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72  .          retur
e100: 6e 20 47 65 74 44 61 74 65 54 69 6d 65 28 73 74  n GetDateTime(st
e110: 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20  mt, index);..   
e120: 20 20 20 20 20 63 61 73 65 20 54 79 70 65 41 66       case TypeAf
e130: 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65 3a 0d 0a  finity.Double:..
e140: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74 20            if (t 
e150: 3d 3d 20 6e 75 6c 6c 29 20 72 65 74 75 72 6e 20  == null) return 
e160: 47 65 74 44 6f 75 62 6c 65 28 73 74 6d 74 2c 20  GetDouble(stmt, 
e170: 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20 20 20 20  index);..       
e180: 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 20     else..       
e190: 20 20 20 20 20 72 65 74 75 72 6e 20 43 6f 6e 76       return Conv
e1a0: 65 72 74 2e 43 68 61 6e 67 65 54 79 70 65 28 47  ert.ChangeType(G
e1b0: 65 74 44 6f 75 62 6c 65 28 73 74 6d 74 2c 20 69  etDouble(stmt, i
e1c0: 6e 64 65 78 29 2c 20 74 2c 20 6e 75 6c 6c 29 3b  ndex), t, null);
e1d0: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 54  ..        case T
e1e0: 79 70 65 41 66 66 69 6e 69 74 79 2e 49 6e 74 36  ypeAffinity.Int6
e1f0: 34 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66  4:..          if
e200: 20 28 74 20 3d 3d 20 6e 75 6c 6c 29 20 72 65 74   (t == null) ret
e210: 75 72 6e 20 47 65 74 49 6e 74 36 34 28 73 74 6d  urn GetInt64(stm
e220: 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20  t, index);..    
e230: 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20        else..    
e240: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 43          return C
e250: 6f 6e 76 65 72 74 2e 43 68 61 6e 67 65 54 79 70  onvert.ChangeTyp
e260: 65 28 47 65 74 49 6e 74 36 34 28 73 74 6d 74 2c  e(GetInt64(stmt,
e270: 20 69 6e 64 65 78 29 2c 20 74 2c 20 6e 75 6c 6c   index), t, null
e280: 29 3b 0d 0a 20 20 20 20 20 20 20 20 64 65 66 61  );..        defa
e290: 75 6c 74 3a 0d 0a 20 20 20 20 20 20 20 20 20 20  ult:..          
e2a0: 72 65 74 75 72 6e 20 47 65 74 54 65 78 74 28 73  return GetText(s
e2b0: 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20  tmt, index);..  
e2c0: 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a      }..    }....
e2d0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
e2e0: 72 72 69 64 65 20 69 6e 74 20 47 65 74 43 75 72  rride int GetCur
e2f0: 73 6f 72 46 6f 72 54 61 62 6c 65 28 53 51 4c 69  sorForTable(SQLi
e300: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
e310: 2c 20 69 6e 74 20 64 62 2c 20 69 6e 74 20 72 6f  , int db, int ro
e320: 6f 74 50 61 67 65 29 0d 0a 20 20 20 20 7b 0d 0a  otPage)..    {..
e330: 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41 4e  #if !SQLITE_STAN
e340: 44 41 52 44 0d 0a 20 20 20 20 20 20 72 65 74 75  DARD..      retu
e350: 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  rn UnsafeNativeM
e360: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 74  ethods.sqlite3_t
e370: 61 62 6c 65 5f 63 75 72 73 6f 72 28 73 74 6d 74  able_cursor(stmt
e380: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 64  ._sqlite_stmt, d
e390: 62 2c 20 72 6f 6f 74 50 61 67 65 29 3b 0d 0a 23  b, rootPage);..#
e3a0: 65 6c 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75  else..      retu
e3b0: 72 6e 20 2d 31 3b 0d 0a 23 65 6e 64 69 66 0d 0a  rn -1;..#endif..
e3c0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
e3d0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c  ernal override l
e3e0: 6f 6e 67 20 47 65 74 52 6f 77 49 64 46 6f 72 43  ong GetRowIdForC
e3f0: 75 72 73 6f 72 28 53 51 4c 69 74 65 53 74 61 74  ursor(SQLiteStat
e400: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
e410: 63 75 72 73 6f 72 29 0d 0a 20 20 20 20 7b 0d 0a  cursor)..    {..
e420: 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41 4e  #if !SQLITE_STAN
e430: 44 41 52 44 0d 0a 20 20 20 20 20 20 6c 6f 6e 67  DARD..      long
e440: 20 72 6f 77 69 64 3b 0d 0a 20 20 20 20 20 20 69   rowid;..      i
e450: 6e 74 20 72 63 20 3d 20 55 6e 73 61 66 65 4e 61  nt rc = UnsafeNa
e460: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
e470: 74 65 33 5f 63 75 72 73 6f 72 5f 72 6f 77 69 64  te3_cursor_rowid
e480: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
e490: 6d 74 2c 20 63 75 72 73 6f 72 2c 20 6f 75 74 20  mt, cursor, out 
e4a0: 72 6f 77 69 64 29 3b 0d 0a 20 20 20 20 20 20 69  rowid);..      i
e4b0: 66 20 28 72 63 20 3d 3d 20 30 29 20 72 65 74 75  f (rc == 0) retu
e4c0: 72 6e 20 72 6f 77 69 64 3b 0d 0a 0d 0a 20 20 20  rn rowid;....   
e4d0: 20 20 20 72 65 74 75 72 6e 20 30 3b 0d 0a 23 65     return 0;..#e
e4e0: 6c 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75 72  lse..      retur
e4f0: 6e 20 30 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20  n 0;..#endif..  
e500: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
e510: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
e520: 64 20 47 65 74 49 6e 64 65 78 43 6f 6c 75 6d 6e  d GetIndexColumn
e530: 45 78 74 65 6e 64 65 64 49 6e 66 6f 28 73 74 72  ExtendedInfo(str
e540: 69 6e 67 20 64 61 74 61 62 61 73 65 2c 20 73 74  ing database, st
e550: 72 69 6e 67 20 69 6e 64 65 78 2c 20 73 74 72 69  ring index, stri
e560: 6e 67 20 63 6f 6c 75 6d 6e 2c 20 6f 75 74 20 69  ng column, out i
e570: 6e 74 20 73 6f 72 74 4d 6f 64 65 2c 20 6f 75 74  nt sortMode, out
e580: 20 69 6e 74 20 6f 6e 45 72 72 6f 72 2c 20 6f 75   int onError, ou
e590: 74 20 73 74 72 69 6e 67 20 63 6f 6c 6c 61 74 69  t string collati
e5a0: 6f 6e 53 65 71 75 65 6e 63 65 29 0d 0a 20 20 20  onSequence)..   
e5b0: 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f   {..#if !SQLITE_
e5c0: 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20  STANDARD..      
e5d0: 49 6e 74 50 74 72 20 63 6f 6c 6c 3b 0d 0a 20 20  IntPtr coll;..  
e5e0: 20 20 20 20 69 6e 74 20 63 6f 6c 6c 6c 65 6e 3b      int colllen;
e5f0: 0d 0a 20 20 20 20 20 20 69 6e 74 20 72 63 3b 0d  ..      int rc;.
e600: 0a 0d 0a 20 20 20 20 20 20 72 63 20 3d 20 55 6e  ...      rc = Un
e610: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
e620: 73 2e 73 71 6c 69 74 65 33 5f 69 6e 64 65 78 5f  s.sqlite3_index_
e630: 63 6f 6c 75 6d 6e 5f 69 6e 66 6f 5f 69 6e 74 65  column_info_inte
e640: 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55 54 46 38  rop(_sql, ToUTF8
e650: 28 64 61 74 61 62 61 73 65 29 2c 20 54 6f 55 54  (database), ToUT
e660: 46 38 28 69 6e 64 65 78 29 2c 20 54 6f 55 54 46  F8(index), ToUTF
e670: 38 28 63 6f 6c 75 6d 6e 29 2c 20 6f 75 74 20 73  8(column), out s
e680: 6f 72 74 4d 6f 64 65 2c 20 6f 75 74 20 6f 6e 45  ortMode, out onE
e690: 72 72 6f 72 2c 20 6f 75 74 20 63 6f 6c 6c 2c 20  rror, out coll, 
e6a0: 6f 75 74 20 63 6f 6c 6c 6c 65 6e 29 3b 0d 0a 20  out colllen);.. 
e6b0: 20 20 20 20 20 69 66 20 28 72 63 20 21 3d 20 30       if (rc != 0
e6c0: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
e6d0: 74 65 45 78 63 65 70 74 69 6f 6e 28 72 63 2c 20  teException(rc, 
e6e0: 22 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 63 6f  "");....      co
e6f0: 6c 6c 61 74 69 6f 6e 53 65 71 75 65 6e 63 65 20  llationSequence 
e700: 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 63  = UTF8ToString(c
e710: 6f 6c 6c 2c 20 63 6f 6c 6c 6c 65 6e 29 3b 0d 0a  oll, colllen);..
e720: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 73 6f 72  #else..      sor
e730: 74 4d 6f 64 65 20 3d 20 30 3b 0d 0a 20 20 20 20  tMode = 0;..    
e740: 20 20 6f 6e 45 72 72 6f 72 20 3d 20 32 3b 0d 0a    onError = 2;..
e750: 20 20 20 20 20 20 63 6f 6c 6c 61 74 69 6f 6e 53        collationS
e760: 65 71 75 65 6e 63 65 20 3d 20 22 42 49 4e 41 52  equence = "BINAR
e770: 59 22 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20  Y";..#endif..   
e780: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
e790: 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  al override int 
e7a0: 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 73 74 72 69  FileControl(stri
e7b0: 6e 67 20 7a 44 62 4e 61 6d 65 2c 20 69 6e 74 20  ng zDbName, int 
e7c0: 6f 70 2c 20 49 6e 74 50 74 72 20 70 41 72 67 29  op, IntPtr pArg)
e7d0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72  ..    {..      r
e7e0: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
e7f0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
e800: 33 5f 66 69 6c 65 5f 63 6f 6e 74 72 6f 6c 28 5f  3_file_control(_
e810: 73 71 6c 2c 20 28 7a 44 62 4e 61 6d 65 20 21 3d  sql, (zDbName !=
e820: 20 6e 75 6c 6c 29 20 3f 20 54 6f 55 54 46 38 28   null) ? ToUTF8(
e830: 7a 44 62 4e 61 6d 65 29 20 3a 20 6e 75 6c 6c 2c  zDbName) : null,
e840: 20 6f 70 2c 20 70 41 72 67 29 3b 0d 0a 20 20 20   op, pArg);..   
e850: 20 7d 0d 0a 20 20 7d 0d 0a 7d 0d 0a               }..  }..}..