System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 704aea05e584f321ade383d4b1653548b90f6892:


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 0d 0a 20 20 20 20 20 20 20 20 6c 6f  );....        lo
1eb0: 63 6b 20 28 5f 73 71 6c 29 0d 0a 20 20 20 20 20  ck (_sql)..     
1ec0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
1ed0: 20 20 2f 2f 20 64 6f 20 6e 6f 74 68 69 6e 67 2e    // do nothing.
1ee0: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20  ..        }..   
1ef0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 2f 2f 20 42     }..      // B
1f00: 69 6e 64 20 66 75 6e 63 74 69 6f 6e 73 20 74 6f  ind functions to
1f10: 20 74 68 69 73 20 63 6f 6e 6e 65 63 74 69 6f 6e   this connection
1f20: 2e 20 20 49 66 20 61 6e 79 20 70 72 65 76 69 6f  .  If any previo
1f30: 75 73 20 66 75 6e 63 74 69 6f 6e 73 20 6f 66 20  us functions of 
1f40: 74 68 65 20 73 61 6d 65 20 6e 61 6d 65 0d 0a 20  the same name.. 
1f50: 20 20 20 20 20 2f 2f 20 77 65 72 65 20 61 6c 72       // were alr
1f60: 65 61 64 79 20 62 6f 75 6e 64 2c 20 74 68 65 6e  eady bound, then
1f70: 20 74 68 65 20 6e 65 77 20 62 69 6e 64 69 6e 67   the new binding
1f80: 73 20 72 65 70 6c 61 63 65 20 74 68 65 20 6f 6c  s replace the ol
1f90: 64 2e 0d 0a 20 20 20 20 20 20 5f 66 75 6e 63 74  d...      _funct
1fa0: 69 6f 6e 73 41 72 72 61 79 20 3d 20 53 51 4c 69  ionsArray = SQLi
1fb0: 74 65 46 75 6e 63 74 69 6f 6e 2e 42 69 6e 64 46  teFunction.BindF
1fc0: 75 6e 63 74 69 6f 6e 73 28 74 68 69 73 2c 20 63  unctions(this, c
1fd0: 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 29 3b  onnectionFlags);
1fe0: 0d 0a 20 20 20 20 20 20 53 65 74 54 69 6d 65 6f  ..      SetTimeo
1ff0: 75 74 28 30 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  ut(0);..    }...
2000: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
2010: 65 72 72 69 64 65 20 76 6f 69 64 20 43 6c 65 61  erride void Clea
2020: 72 50 6f 6f 6c 28 29 0d 0a 20 20 20 20 7b 0d 0a  rPool()..    {..
2030: 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e        SQLiteConn
2040: 65 63 74 69 6f 6e 50 6f 6f 6c 2e 43 6c 65 61 72  ectionPool.Clear
2050: 50 6f 6f 6c 28 5f 66 69 6c 65 4e 61 6d 65 29 3b  Pool(_fileName);
2060: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
2070: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
2080: 20 69 6e 74 20 43 6f 75 6e 74 50 6f 6f 6c 28 29   int CountPool()
2090: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
20a0: 20 44 69 63 74 69 6f 6e 61 72 79 3c 73 74 72 69   Dictionary<stri
20b0: 6e 67 2c 20 69 6e 74 3e 20 63 6f 75 6e 74 73 20  ng, int> counts 
20c0: 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 20  = null;..       
20d0: 20 69 6e 74 20 74 6f 74 61 6c 43 6f 75 6e 74 20   int totalCount 
20e0: 3d 20 30 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  = 0;....        
20f0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
2100: 50 6f 6f 6c 2e 47 65 74 43 6f 75 6e 74 73 28 5f  Pool.GetCounts(_
2110: 66 69 6c 65 4e 61 6d 65 2c 0d 0a 20 20 20 20 20  fileName,..     
2120: 20 20 20 20 20 20 20 72 65 66 20 63 6f 75 6e 74         ref count
2130: 73 2c 20 72 65 66 20 74 6f 74 61 6c 43 6f 75 6e  s, ref totalCoun
2140: 74 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72  t);....        r
2150: 65 74 75 72 6e 20 74 6f 74 61 6c 43 6f 75 6e 74  eturn totalCount
2160: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
2170: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
2180: 65 20 76 6f 69 64 20 53 65 74 54 69 6d 65 6f 75  e void SetTimeou
2190: 74 28 69 6e 74 20 6e 54 69 6d 65 6f 75 74 4d 53  t(int nTimeoutMS
21a0: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
21b0: 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61  int n = UnsafeNa
21c0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
21d0: 74 65 33 5f 62 75 73 79 5f 74 69 6d 65 6f 75 74  te3_busy_timeout
21e0: 28 5f 73 71 6c 2c 20 6e 54 69 6d 65 6f 75 74 4d  (_sql, nTimeoutM
21f0: 53 29 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 6e  S);..      if (n
2200: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
2210: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
2220: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
2230: 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  ));..    }....  
2240: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2250: 69 64 65 20 62 6f 6f 6c 20 53 74 65 70 28 53 51  ide bool Step(SQ
2260: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
2270: 6d 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  mt)..    {..    
2280: 20 20 69 6e 74 20 6e 3b 0d 0a 20 20 20 20 20 20    int n;..      
2290: 52 61 6e 64 6f 6d 20 72 6e 64 20 3d 20 6e 75 6c  Random rnd = nul
22a0: 6c 3b 0d 0a 20 20 20 20 20 20 75 69 6e 74 20 73  l;..      uint s
22b0: 74 61 72 74 74 69 63 6b 20 3d 20 28 75 69 6e 74  tarttick = (uint
22c0: 29 45 6e 76 69 72 6f 6e 6d 65 6e 74 2e 54 69 63  )Environment.Tic
22d0: 6b 43 6f 75 6e 74 3b 0d 0a 20 20 20 20 20 20 75  kCount;..      u
22e0: 69 6e 74 20 74 69 6d 65 6f 75 74 20 3d 20 28 75  int timeout = (u
22f0: 69 6e 74 29 28 73 74 6d 74 2e 5f 63 6f 6d 6d 61  int)(stmt._comma
2300: 6e 64 2e 5f 63 6f 6d 6d 61 6e 64 54 69 6d 65 6f  nd._commandTimeo
2310: 75 74 20 2a 20 31 30 30 30 29 3b 0d 0a 0d 0a 20  ut * 1000);.... 
2320: 20 20 20 20 20 77 68 69 6c 65 20 28 74 72 75 65       while (true
2330: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  )..      {..    
2340: 20 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61      n = UnsafeNa
2350: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
2360: 74 65 33 5f 73 74 65 70 28 73 74 6d 74 2e 5f 73  te3_step(stmt._s
2370: 71 6c 69 74 65 5f 73 74 6d 74 29 3b 0d 0a 0d 0a  qlite_stmt);....
2380: 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3d 3d          if (n ==
2390: 20 31 30 30 29 20 72 65 74 75 72 6e 20 74 72 75   100) return tru
23a0: 65 3b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  e;..        if (
23b0: 6e 20 3d 3d 20 31 30 31 29 20 72 65 74 75 72 6e  n == 101) return
23c0: 20 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 20 20   false;....     
23d0: 20 20 20 69 66 20 28 6e 20 3e 20 30 29 0d 0a 20     if (n > 0).. 
23e0: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
23f0: 20 20 20 20 69 6e 74 20 72 3b 0d 0a 0d 0a 20 20      int r;....  
2400: 20 20 20 20 20 20 20 20 2f 2f 20 41 6e 20 65 72          // An er
2410: 72 6f 72 20 6f 63 63 75 72 72 65 64 2c 20 61 74  ror occurred, at
2420: 74 65 6d 70 74 20 74 6f 20 72 65 73 65 74 20 74  tempt to reset t
2430: 68 65 20 73 74 61 74 65 6d 65 6e 74 2e 20 20 49  he statement.  I
2440: 66 20 74 68 65 20 72 65 73 65 74 20 77 6f 72 6b  f the reset work
2450: 65 64 20 62 65 63 61 75 73 65 20 74 68 65 0d 0a  ed because the..
2460: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 73 63 68            // sch
2470: 65 6d 61 20 68 61 73 20 63 68 61 6e 67 65 64 2c  ema has changed,
2480: 20 72 65 2d 74 72 79 20 74 68 65 20 73 74 65 70   re-try the step
2490: 20 61 67 61 69 6e 2e 20 20 49 66 20 69 74 20 65   again.  If it e
24a0: 72 72 6f 72 65 64 20 6f 75 72 20 62 65 63 61 75  rrored our becau
24b0: 73 65 20 74 68 65 20 64 61 74 61 62 61 73 65 0d  se the database.
24c0: 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20 69 73  .          // is
24d0: 20 6c 6f 63 6b 65 64 2c 20 74 68 65 6e 20 6b 65   locked, then ke
24e0: 65 70 20 72 65 74 72 79 69 6e 67 20 75 6e 74 69  ep retrying unti
24f0: 6c 20 74 68 65 20 63 6f 6d 6d 61 6e 64 20 74 69  l the command ti
2500: 6d 65 6f 75 74 20 6f 63 63 75 72 73 2e 0d 0a 20  meout occurs... 
2510: 20 20 20 20 20 20 20 20 20 72 20 3d 20 52 65 73           r = Res
2520: 65 74 28 73 74 6d 74 29 3b 0d 0a 0d 0a 20 20 20  et(stmt);....   
2530: 20 20 20 20 20 20 20 69 66 20 28 72 20 3d 3d 20         if (r == 
2540: 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  0)..            
2550: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
2560: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74  Exception(n, Get
2570: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 0d  LastError());...
2580: 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65 20  .          else 
2590: 69 66 20 28 28 72 20 3d 3d 20 36 20 7c 7c 20 72  if ((r == 6 || r
25a0: 20 3d 3d 20 35 29 20 26 26 20 73 74 6d 74 2e 5f   == 5) && stmt._
25b0: 63 6f 6d 6d 61 6e 64 20 21 3d 20 6e 75 6c 6c 29  command != null)
25c0: 20 2f 2f 20 53 51 4c 49 54 45 5f 4c 4f 43 4b 45   // SQLITE_LOCKE
25d0: 44 20 7c 7c 20 53 51 4c 49 54 45 5f 42 55 53 59  D || SQLITE_BUSY
25e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20  ..          {.. 
25f0: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 4b 65             // Ke
2600: 65 70 20 74 72 79 69 6e 67 0d 0a 20 20 20 20 20  ep trying..     
2610: 20 20 20 20 20 20 20 69 66 20 28 72 6e 64 20 3d         if (rnd =
2620: 3d 20 6e 75 6c 6c 29 20 2f 2f 20 46 69 72 73 74  = null) // First
2630: 20 74 69 6d 65 20 77 65 27 76 65 20 65 6e 63 6f   time we've enco
2640: 75 6e 74 65 72 65 64 20 74 68 65 20 6c 6f 63 6b  untered the lock
2650: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
2660: 72 6e 64 20 3d 20 6e 65 77 20 52 61 6e 64 6f 6d  rnd = new Random
2670: 28 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20  ();....         
2680: 20 20 20 2f 2f 20 49 66 20 77 65 27 76 65 20 65     // If we've e
2690: 78 63 65 65 64 65 64 20 74 68 65 20 63 6f 6d 6d  xceeded the comm
26a0: 61 6e 64 27 73 20 74 69 6d 65 6f 75 74 2c 20 67  and's timeout, g
26b0: 69 76 65 20 75 70 20 61 6e 64 20 74 68 72 6f 77  ive up and throw
26c0: 20 61 6e 20 65 72 72 6f 72 0d 0a 20 20 20 20 20   an error..     
26d0: 20 20 20 20 20 20 20 69 66 20 28 28 75 69 6e 74         if ((uint
26e0: 29 45 6e 76 69 72 6f 6e 6d 65 6e 74 2e 54 69 63  )Environment.Tic
26f0: 6b 43 6f 75 6e 74 20 2d 20 73 74 61 72 74 74 69  kCount - startti
2700: 63 6b 20 3e 20 74 69 6d 65 6f 75 74 29 0d 0a 20  ck > timeout).. 
2710: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
2720: 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72 6f              thro
2730: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
2740: 70 74 69 6f 6e 28 72 2c 20 47 65 74 4c 61 73 74  ption(r, GetLast
2750: 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 20  Error());..     
2760: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
2770: 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20        else..    
2780: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
2790: 20 20 20 20 20 20 20 20 20 2f 2f 20 4f 74 68 65           // Othe
27a0: 72 77 69 73 65 20 73 6c 65 65 70 20 66 6f 72 20  rwise sleep for 
27b0: 61 20 72 61 6e 64 6f 6d 20 61 6d 6f 75 6e 74 20  a random amount 
27c0: 6f 66 20 74 69 6d 65 20 75 70 20 74 6f 20 31 35  of time up to 15
27d0: 30 6d 73 0d 0a 20 20 20 20 20 20 20 20 20 20 20  0ms..           
27e0: 20 20 20 53 79 73 74 65 6d 2e 54 68 72 65 61 64     System.Thread
27f0: 69 6e 67 2e 54 68 72 65 61 64 2e 53 6c 65 65 70  ing.Thread.Sleep
2800: 28 72 6e 64 2e 4e 65 78 74 28 31 2c 20 31 35 30  (rnd.Next(1, 150
2810: 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ));..           
2820: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d   }..          }.
2830: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
2840: 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20    }..    }....  
2850: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2860: 69 64 65 20 69 6e 74 20 52 65 73 65 74 28 53 51  ide int Reset(SQ
2870: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
2880: 6d 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  mt)..    {..    
2890: 20 20 69 6e 74 20 6e 3b 0d 0a 0d 0a 23 69 66 20    int n;....#if 
28a0: 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44  !SQLITE_STANDARD
28b0: 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55 6e 73 61  ..      n = Unsa
28c0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
28d0: 73 71 6c 69 74 65 33 5f 72 65 73 65 74 5f 69 6e  sqlite3_reset_in
28e0: 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69  terop(stmt._sqli
28f0: 74 65 5f 73 74 6d 74 29 3b 0d 0a 23 65 6c 73 65  te_stmt);..#else
2900: 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55 6e 73 61  ..      n = Unsa
2910: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
2920: 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 73 74  sqlite3_reset(st
2930: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29  mt._sqlite_stmt)
2940: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20  ;..#endif....   
2950: 20 20 20 2f 2f 20 49 66 20 74 68 65 20 73 63 68     // If the sch
2960: 65 6d 61 20 63 68 61 6e 67 65 64 2c 20 74 72 79  ema changed, try
2970: 20 61 6e 64 20 72 65 2d 70 72 65 70 61 72 65 20   and re-prepare 
2980: 69 74 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 20  it..      if (n 
2990: 3d 3d 20 31 37 29 20 2f 2f 20 53 51 4c 49 54 45  == 17) // SQLITE
29a0: 5f 53 43 48 45 4d 41 0d 0a 20 20 20 20 20 20 7b  _SCHEMA..      {
29b0: 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 52 65 63  ..        // Rec
29c0: 72 65 61 74 65 20 61 20 64 75 6d 6d 79 20 73 74  reate a dummy st
29d0: 61 74 65 6d 65 6e 74 0d 0a 20 20 20 20 20 20 20  atement..       
29e0: 20 73 74 72 69 6e 67 20 73 74 72 3b 0d 0a 20 20   string str;..  
29f0: 20 20 20 20 20 20 75 73 69 6e 67 20 28 53 51 4c        using (SQL
2a00: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 74 6d 70  iteStatement tmp
2a10: 20 3d 20 50 72 65 70 61 72 65 28 6e 75 6c 6c 2c   = Prepare(null,
2a20: 20 73 74 6d 74 2e 5f 73 71 6c 53 74 61 74 65 6d   stmt._sqlStatem
2a30: 65 6e 74 2c 20 6e 75 6c 6c 2c 20 28 75 69 6e 74  ent, null, (uint
2a40: 29 28 73 74 6d 74 2e 5f 63 6f 6d 6d 61 6e 64 2e  )(stmt._command.
2a50: 5f 63 6f 6d 6d 61 6e 64 54 69 6d 65 6f 75 74 20  _commandTimeout 
2a60: 2a 20 31 30 30 30 29 2c 20 6f 75 74 20 73 74 72  * 1000), out str
2a70: 29 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  ))..        {.. 
2a80: 20 20 20 20 20 20 20 20 20 2f 2f 20 46 69 6e 61           // Fina
2a90: 6c 69 7a 65 20 74 68 65 20 65 78 69 73 74 69 6e  lize the existin
2aa0: 67 20 73 74 61 74 65 6d 65 6e 74 0d 0a 20 20 20  g statement..   
2ab0: 20 20 20 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c         stmt._sql
2ac0: 69 74 65 5f 73 74 6d 74 2e 44 69 73 70 6f 73 65  ite_stmt.Dispose
2ad0: 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 2f  ();..          /
2ae0: 2f 20 52 65 61 73 73 69 67 6e 20 61 20 6e 65 77  / Reassign a new
2af0: 20 73 74 61 74 65 6d 65 6e 74 20 70 6f 69 6e 74   statement point
2b00: 65 72 20 74 6f 20 74 68 65 20 6f 6c 64 20 73 74  er to the old st
2b10: 61 74 65 6d 65 6e 74 20 61 6e 64 20 63 6c 65 61  atement and clea
2b20: 72 20 74 68 65 20 74 65 6d 70 6f 72 61 72 79 20  r the temporary 
2b30: 6f 6e 65 0d 0a 20 20 20 20 20 20 20 20 20 20 73  one..          s
2b40: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
2b50: 20 3d 20 74 6d 70 2e 5f 73 71 6c 69 74 65 5f 73   = tmp._sqlite_s
2b60: 74 6d 74 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  tmt;..          
2b70: 74 6d 70 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmp._sqlite_stmt
2b80: 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20   = null;....    
2b90: 20 20 20 20 20 20 2f 2f 20 52 65 61 70 70 6c 79        // Reapply
2ba0: 20 70 61 72 61 6d 65 74 65 72 73 0d 0a 20 20 20   parameters..   
2bb0: 20 20 20 20 20 20 20 73 74 6d 74 2e 42 69 6e 64         stmt.Bind
2bc0: 50 61 72 61 6d 65 74 65 72 73 28 29 3b 0d 0a 20  Parameters();.. 
2bd0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
2be0: 20 20 72 65 74 75 72 6e 20 2d 31 3b 20 2f 2f 20    return -1; // 
2bf0: 52 65 73 65 74 20 77 61 73 20 4f 4b 2c 20 77 69  Reset was OK, wi
2c00: 74 68 20 73 63 68 65 6d 61 20 63 68 61 6e 67 65  th schema change
2c10: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20  ..      }..     
2c20: 20 65 6c 73 65 20 69 66 20 28 6e 20 3d 3d 20 36   else if (n == 6
2c30: 20 7c 7c 20 6e 20 3d 3d 20 35 29 20 2f 2f 20 53   || n == 5) // S
2c40: 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 20 7c 7c 20  QLITE_LOCKED || 
2c50: 53 51 4c 49 54 45 5f 42 55 53 59 0d 0a 20 20 20  SQLITE_BUSY..   
2c60: 20 20 20 20 20 72 65 74 75 72 6e 20 6e 3b 0d 0a       return n;..
2c70: 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20  ..      if (n > 
2c80: 30 29 0d 0a 20 20 20 20 20 20 20 20 74 68 72 6f  0)..        thro
2c90: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
2ca0: 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74  ption(n, GetLast
2cb0: 45 72 72 6f 72 28 29 29 3b 0d 0a 0d 0a 20 20 20  Error());....   
2cc0: 20 20 20 72 65 74 75 72 6e 20 30 3b 20 2f 2f 20     return 0; // 
2cd0: 57 65 20 72 65 73 65 74 20 4f 4b 2c 20 6e 6f 20  We reset OK, no 
2ce0: 73 63 68 65 6d 61 20 63 68 61 6e 67 65 73 0d 0a  schema changes..
2cf0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
2d00: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73  ernal override s
2d10: 74 72 69 6e 67 20 47 65 74 4c 61 73 74 45 72 72  tring GetLastErr
2d20: 6f 72 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  or()..    {..   
2d30: 20 20 20 72 65 74 75 72 6e 20 53 51 4c 69 74 65     return SQLite
2d40: 42 61 73 65 2e 47 65 74 4c 61 73 74 45 72 72 6f  Base.GetLastErro
2d50: 72 28 5f 73 71 6c 2c 20 5f 73 71 6c 29 3b 0d 0a  r(_sql, _sql);..
2d60: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
2d70: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 53  ernal override S
2d80: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 50  QLiteStatement P
2d90: 72 65 70 61 72 65 28 53 51 4c 69 74 65 43 6f 6e  repare(SQLiteCon
2da0: 6e 65 63 74 69 6f 6e 20 63 6e 6e 2c 20 73 74 72  nection cnn, str
2db0: 69 6e 67 20 73 74 72 53 71 6c 2c 20 53 51 4c 69  ing strSql, SQLi
2dc0: 74 65 53 74 61 74 65 6d 65 6e 74 20 70 72 65 76  teStatement prev
2dd0: 69 6f 75 73 2c 20 75 69 6e 74 20 74 69 6d 65 6f  ious, uint timeo
2de0: 75 74 4d 53 2c 20 6f 75 74 20 73 74 72 69 6e 67  utMS, out string
2df0: 20 73 74 72 52 65 6d 61 69 6e 29 0d 0a 20 20 20   strRemain)..   
2e00: 20 7b 0d 0a 20 20 20 20 20 20 69 66 20 28 21 53   {..      if (!S
2e10: 74 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d  tring.IsNullOrEm
2e20: 70 74 79 28 73 74 72 53 71 6c 29 29 0d 0a 20 20  pty(strSql))..  
2e30: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 2f      {..        /
2e40: 2f 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f  /..        // NO
2e50: 54 45 3a 20 53 51 4c 69 74 65 20 64 6f 65 73 20  TE: SQLite does 
2e60: 6e 6f 74 20 73 75 70 70 6f 72 74 20 74 68 65 20  not support the 
2e70: 63 6f 6e 63 65 70 74 20 6f 66 20 73 65 70 61 72  concept of separ
2e80: 61 74 65 20 73 63 68 65 6d 61 73 0d 0a 20 20 20  ate schemas..   
2e90: 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20 69 6e       //       in
2ea0: 20 6f 6e 65 20 64 61 74 61 62 61 73 65 3b 20 74   one database; t
2eb0: 68 65 72 65 66 6f 72 65 2c 20 72 65 6d 6f 76 65  herefore, remove
2ec0: 20 74 68 65 20 62 61 73 65 20 73 63 68 65 6d 61   the base schema
2ed0: 20 6e 61 6d 65 0d 0a 20 20 20 20 20 20 20 20 2f   name..        /
2ee0: 2f 20 20 20 20 20 20 20 75 73 65 64 20 74 6f 20  /       used to 
2ef0: 73 6d 6f 6f 74 68 20 69 6e 74 65 67 72 61 74 69  smooth integrati
2f00: 6f 6e 20 77 69 74 68 20 74 68 65 20 62 61 73 65  on with the base
2f10: 20 2e 4e 45 54 20 46 72 61 6d 65 77 6f 72 6b 0d   .NET Framework.
2f20: 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 20  .        //     
2f30: 20 20 64 61 74 61 20 63 6c 61 73 73 65 73 2e 0d    data classes..
2f40: 0a 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20  .        //..   
2f50: 20 20 20 20 20 73 74 72 69 6e 67 20 62 61 73 65       string base
2f60: 53 63 68 65 6d 61 4e 61 6d 65 20 3d 20 28 63 6e  SchemaName = (cn
2f70: 6e 20 21 3d 20 6e 75 6c 6c 29 20 3f 20 63 6e 6e  n != null) ? cnn
2f80: 2e 5f 62 61 73 65 53 63 68 65 6d 61 4e 61 6d 65  ._baseSchemaName
2f90: 20 3a 20 6e 75 6c 6c 3b 0d 0a 0d 0a 20 20 20 20   : null;....    
2fa0: 20 20 20 20 69 66 20 28 21 53 74 72 69 6e 67 2e      if (!String.
2fb0: 49 73 4e 75 6c 6c 4f 72 45 6d 70 74 79 28 62 61  IsNullOrEmpty(ba
2fc0: 73 65 53 63 68 65 6d 61 4e 61 6d 65 29 29 0d 0a  seSchemaName))..
2fd0: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
2fe0: 20 20 20 20 20 73 74 72 53 71 6c 20 3d 20 73 74       strSql = st
2ff0: 72 53 71 6c 2e 52 65 70 6c 61 63 65 28 0d 0a 20  rSql.Replace(.. 
3000: 20 20 20 20 20 20 20 20 20 20 20 20 20 53 74 72               Str
3010: 69 6e 67 2e 46 6f 72 6d 61 74 28 22 5b 7b 30 7d  ing.Format("[{0}
3020: 5d 2e 22 2c 20 62 61 73 65 53 63 68 65 6d 61 4e  ].", baseSchemaN
3030: 61 6d 65 29 2c 20 53 74 72 69 6e 67 2e 45 6d 70  ame), String.Emp
3040: 74 79 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ty);....        
3050: 20 20 73 74 72 53 71 6c 20 3d 20 73 74 72 53 71    strSql = strSq
3060: 6c 2e 52 65 70 6c 61 63 65 28 0d 0a 20 20 20 20  l.Replace(..    
3070: 20 20 20 20 20 20 20 20 20 20 53 74 72 69 6e 67            String
3080: 2e 46 6f 72 6d 61 74 28 22 7b 30 7d 2e 22 2c 20  .Format("{0}.", 
3090: 62 61 73 65 53 63 68 65 6d 61 4e 61 6d 65 29 2c  baseSchemaName),
30a0: 20 53 74 72 69 6e 67 2e 45 6d 70 74 79 29 3b 0d   String.Empty);.
30b0: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
30c0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 53 51 4c    }....      SQL
30d0: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
30e0: 67 73 20 66 6c 61 67 73 20 3d 0d 0a 20 20 20 20  gs flags =..    
30f0: 20 20 20 20 20 20 28 63 6e 6e 20 21 3d 20 6e 75        (cnn != nu
3100: 6c 6c 29 20 3f 20 63 6e 6e 2e 46 6c 61 67 73 20  ll) ? cnn.Flags 
3110: 3a 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  : SQLiteConnecti
3120: 6f 6e 46 6c 61 67 73 2e 44 65 66 61 75 6c 74 3b  onFlags.Default;
3130: 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52  ....#if !PLATFOR
3140: 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f  M_COMPACTFRAMEWO
3150: 52 4b 0d 0a 20 20 20 20 20 20 69 66 20 28 28 66  RK..      if ((f
3160: 6c 61 67 73 20 26 20 53 51 4c 69 74 65 43 6f 6e  lags & SQLiteCon
3170: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67  nectionFlags.Log
3180: 50 72 65 70 61 72 65 29 20 3d 3d 20 53 51 4c 69  Prepare) == SQLi
3190: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
31a0: 73 2e 4c 6f 67 50 72 65 70 61 72 65 29 0d 0a 20  s.LogPrepare).. 
31b0: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
31c0: 20 20 69 66 20 28 28 73 74 72 53 71 6c 20 3d 3d    if ((strSql ==
31d0: 20 6e 75 6c 6c 29 20 7c 7c 20 28 73 74 72 53 71   null) || (strSq
31e0: 6c 2e 4c 65 6e 67 74 68 20 3d 3d 20 30 29 20 7c  l.Length == 0) |
31f0: 7c 20 28 73 74 72 53 71 6c 2e 54 72 69 6d 28 29  | (strSql.Trim()
3200: 2e 4c 65 6e 67 74 68 20 3d 3d 20 30 29 29 0d 0a  .Length == 0))..
3210: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53 51                SQ
3220: 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61  LiteLog.LogMessa
3230: 67 65 28 30 2c 20 22 50 72 65 70 61 72 69 6e 67  ge(0, "Preparing
3240: 20 7b 3c 6e 6f 74 68 69 6e 67 3e 7d 2e 2e 2e 22   {<nothing>}..."
3250: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 65 6c  );..          el
3260: 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  se..            
3270: 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d    SQLiteLog.LogM
3280: 65 73 73 61 67 65 28 30 2c 20 53 74 72 69 6e 67  essage(0, String
3290: 2e 46 6f 72 6d 61 74 28 22 50 72 65 70 61 72 69  .Format("Prepari
32a0: 6e 67 20 7b 7b 7b 30 7d 7d 7d 2e 2e 2e 22 2c 20  ng {{{0}}}...", 
32b0: 73 74 72 53 71 6c 29 29 3b 0d 0a 20 20 20 20 20  strSql));..     
32c0: 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20   }..#endif....  
32d0: 20 20 20 20 49 6e 74 50 74 72 20 73 74 6d 74 20      IntPtr stmt 
32e0: 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f 3b 0d 0a  = IntPtr.Zero;..
32f0: 20 20 20 20 20 20 49 6e 74 50 74 72 20 70 74 72        IntPtr ptr
3300: 20 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f 3b 0d   = IntPtr.Zero;.
3310: 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 20 3d  .      int len =
3320: 20 30 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e   0;..      int n
3330: 20 3d 20 31 37 3b 0d 0a 20 20 20 20 20 20 69 6e   = 17;..      in
3340: 74 20 72 65 74 72 69 65 73 20 3d 20 30 3b 0d 0a  t retries = 0;..
3350: 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62 20 3d        byte[] b =
3360: 20 54 6f 55 54 46 38 28 73 74 72 53 71 6c 29 3b   ToUTF8(strSql);
3370: 0d 0a 20 20 20 20 20 20 73 74 72 69 6e 67 20 74  ..      string t
3380: 79 70 65 64 65 66 73 20 3d 20 6e 75 6c 6c 3b 0d  ypedefs = null;.
3390: 0a 20 20 20 20 20 20 53 51 4c 69 74 65 53 74 61  .      SQLiteSta
33a0: 74 65 6d 65 6e 74 20 63 6d 64 20 3d 20 6e 75 6c  tement cmd = nul
33b0: 6c 3b 0d 0a 20 20 20 20 20 20 52 61 6e 64 6f 6d  l;..      Random
33c0: 20 72 6e 64 20 3d 20 6e 75 6c 6c 3b 0d 0a 20 20   rnd = null;..  
33d0: 20 20 20 20 75 69 6e 74 20 73 74 61 72 74 74 69      uint startti
33e0: 63 6b 20 3d 20 28 75 69 6e 74 29 45 6e 76 69 72  ck = (uint)Envir
33f0: 6f 6e 6d 65 6e 74 2e 54 69 63 6b 43 6f 75 6e 74  onment.TickCount
3400: 3b 0d 0a 0d 0a 20 20 20 20 20 20 47 43 48 61 6e  ;....      GCHan
3410: 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 47 43 48  dle handle = GCH
3420: 61 6e 64 6c 65 2e 41 6c 6c 6f 63 28 62 2c 20 47  andle.Alloc(b, G
3430: 43 48 61 6e 64 6c 65 54 79 70 65 2e 50 69 6e 6e  CHandleType.Pinn
3440: 65 64 29 3b 0d 0a 20 20 20 20 20 20 49 6e 74 50  ed);..      IntP
3450: 74 72 20 70 73 71 6c 20 3d 20 68 61 6e 64 6c 65  tr psql = handle
3460: 2e 41 64 64 72 4f 66 50 69 6e 6e 65 64 4f 62 6a  .AddrOfPinnedObj
3470: 65 63 74 28 29 3b 0d 0a 20 20 20 20 20 20 74 72  ect();..      tr
3480: 79 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  y..      {..    
3490: 20 20 20 20 77 68 69 6c 65 20 28 28 6e 20 3d 3d      while ((n ==
34a0: 20 31 37 20 7c 7c 20 6e 20 3d 3d 20 36 20 7c 7c   17 || n == 6 ||
34b0: 20 6e 20 3d 3d 20 35 29 20 26 26 20 72 65 74 72   n == 5) && retr
34c0: 69 65 73 20 3c 20 33 29 0d 0a 20 20 20 20 20 20  ies < 3)..      
34d0: 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45    {..#if !SQLITE
34e0: 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20  _STANDARD..     
34f0: 20 20 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e       n = UnsafeN
3500: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
3510: 69 74 65 33 5f 70 72 65 70 61 72 65 5f 69 6e 74  ite3_prepare_int
3520: 65 72 6f 70 28 5f 73 71 6c 2c 20 70 73 71 6c 2c  erop(_sql, psql,
3530: 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20 6f   b.Length - 1, o
3540: 75 74 20 73 74 6d 74 2c 20 6f 75 74 20 70 74 72  ut stmt, out ptr
3550: 2c 20 6f 75 74 20 6c 65 6e 29 3b 0d 0a 23 65 6c  , out len);..#el
3560: 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20 6e 20  se..          n 
3570: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
3580: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 70 72  thods.sqlite3_pr
3590: 65 70 61 72 65 28 5f 73 71 6c 2c 20 70 73 71 6c  epare(_sql, psql
35a0: 2c 20 62 2e 4c 65 6e 67 74 68 20 2d 20 31 2c 20  , b.Length - 1, 
35b0: 6f 75 74 20 73 74 6d 74 2c 20 6f 75 74 20 70 74  out stmt, out pt
35c0: 72 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 6c  r);..          l
35d0: 65 6e 20 3d 20 2d 31 3b 0d 0a 23 65 6e 64 69 66  en = -1;..#endif
35e0: 0d 0a 0d 0a 23 69 66 20 44 45 42 55 47 20 26 26  ....#if DEBUG &&
35f0: 20 21 4e 45 54 5f 43 4f 4d 50 41 43 54 5f 32 30   !NET_COMPACT_20
3600: 0d 0a 20 20 20 20 20 20 20 20 20 20 54 72 61 63  ..          Trac
3610: 65 2e 57 72 69 74 65 4c 69 6e 65 28 53 74 72 69  e.WriteLine(Stri
3620: 6e 67 2e 46 6f 72 6d 61 74 28 22 50 72 65 70 61  ng.Format("Prepa
3630: 72 65 3a 20 7b 30 7d 22 2c 20 73 74 6d 74 29 29  re: {0}", stmt))
3640: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20  ;..#endif....   
3650: 20 20 20 20 20 20 20 69 66 20 28 6e 20 3d 3d 20         if (n == 
3660: 31 37 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  17)..           
3670: 20 72 65 74 72 69 65 73 2b 2b 3b 0d 0a 20 20 20   retries++;..   
3680: 20 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28         else if (
3690: 6e 20 3d 3d 20 31 29 0d 0a 20 20 20 20 20 20 20  n == 1)..       
36a0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
36b0: 20 20 69 66 20 28 53 74 72 69 6e 67 2e 43 6f 6d    if (String.Com
36c0: 70 61 72 65 28 47 65 74 4c 61 73 74 45 72 72 6f  pare(GetLastErro
36d0: 72 28 29 2c 20 22 6e 65 61 72 20 5c 22 54 59 50  r(), "near \"TYP
36e0: 45 53 5c 22 3a 20 73 79 6e 74 61 78 20 65 72 72  ES\": syntax err
36f0: 6f 72 22 2c 20 53 74 72 69 6e 67 43 6f 6d 70 61  or", StringCompa
3700: 72 69 73 6f 6e 2e 4f 72 64 69 6e 61 6c 49 67 6e  rison.OrdinalIgn
3710: 6f 72 65 43 61 73 65 29 20 3d 3d 20 30 29 0d 0a  oreCase) == 0)..
3720: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
3730: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6e 74               int
3740: 20 70 6f 73 20 3d 20 73 74 72 53 71 6c 2e 49 6e   pos = strSql.In
3750: 64 65 78 4f 66 28 27 3b 27 29 3b 0d 0a 20 20 20  dexOf(';');..   
3760: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 70             if (p
3770: 6f 73 20 3d 3d 20 2d 31 29 20 70 6f 73 20 3d 20  os == -1) pos = 
3780: 73 74 72 53 71 6c 2e 4c 65 6e 67 74 68 20 2d 20  strSql.Length - 
3790: 31 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  1;....          
37a0: 20 20 20 20 74 79 70 65 64 65 66 73 20 3d 20 73      typedefs = s
37b0: 74 72 53 71 6c 2e 53 75 62 73 74 72 69 6e 67 28  trSql.Substring(
37c0: 30 2c 20 70 6f 73 20 2b 20 31 29 3b 0d 0a 20 20  0, pos + 1);..  
37d0: 20 20 20 20 20 20 20 20 20 20 20 20 73 74 72 53              strS
37e0: 71 6c 20 3d 20 73 74 72 53 71 6c 2e 53 75 62 73  ql = strSql.Subs
37f0: 74 72 69 6e 67 28 70 6f 73 20 2b 20 31 29 3b 0d  tring(pos + 1);.
3800: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
3810: 20 73 74 72 52 65 6d 61 69 6e 20 3d 20 22 22 3b   strRemain = "";
3820: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
3830: 20 20 77 68 69 6c 65 20 28 63 6d 64 20 3d 3d 20    while (cmd == 
3840: 6e 75 6c 6c 20 26 26 20 73 74 72 53 71 6c 2e 4c  null && strSql.L
3850: 65 6e 67 74 68 20 3e 20 30 29 0d 0a 20 20 20 20  ength > 0)..    
3860: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
3870: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6d 64               cmd
3880: 20 3d 20 50 72 65 70 61 72 65 28 63 6e 6e 2c 20   = Prepare(cnn, 
3890: 73 74 72 53 71 6c 2c 20 70 72 65 76 69 6f 75 73  strSql, previous
38a0: 2c 20 74 69 6d 65 6f 75 74 4d 53 2c 20 6f 75 74  , timeoutMS, out
38b0: 20 73 74 72 52 65 6d 61 69 6e 29 3b 0d 0a 20 20   strRemain);..  
38c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 74                st
38d0: 72 53 71 6c 20 3d 20 73 74 72 52 65 6d 61 69 6e  rSql = strRemain
38e0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
38f0: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20   }....          
3900: 20 20 20 20 69 66 20 28 63 6d 64 20 21 3d 20 6e      if (cmd != n
3910: 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ull)..          
3920: 20 20 20 20 20 20 63 6d 64 2e 53 65 74 54 79 70        cmd.SetTyp
3930: 65 73 28 74 79 70 65 64 65 66 73 29 3b 0d 0a 0d  es(typedefs);...
3940: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72  .              r
3950: 65 74 75 72 6e 20 63 6d 64 3b 0d 0a 20 20 20 20  eturn cmd;..    
3960: 20 20 20 20 20 20 20 20 7d 0d 0a 23 69 66 20 21          }..#if !
3970: 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54  PLATFORM_COMPACT
3980: 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20  FRAMEWORK..     
3990: 20 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28         else if (
39a0: 5f 62 75 69 6c 64 69 6e 67 53 63 68 65 6d 61 20  _buildingSchema 
39b0: 3d 3d 20 66 61 6c 73 65 20 26 26 20 53 74 72 69  == false && Stri
39c0: 6e 67 2e 43 6f 6d 70 61 72 65 28 47 65 74 4c 61  ng.Compare(GetLa
39d0: 73 74 45 72 72 6f 72 28 29 2c 20 30 2c 20 22 6e  stError(), 0, "n
39e0: 6f 20 73 75 63 68 20 74 61 62 6c 65 3a 20 54 45  o such table: TE
39f0: 4d 50 2e 53 43 48 45 4d 41 22 2c 20 30 2c 20 32  MP.SCHEMA", 0, 2
3a00: 36 2c 20 53 74 72 69 6e 67 43 6f 6d 70 61 72 69  6, StringCompari
3a10: 73 6f 6e 2e 4f 72 64 69 6e 61 6c 49 67 6e 6f 72  son.OrdinalIgnor
3a20: 65 43 61 73 65 29 20 3d 3d 20 30 29 0d 0a 20 20  eCase) == 0)..  
3a30: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
3a40: 20 20 20 20 20 20 20 20 20 20 20 73 74 72 52 65             strRe
3a50: 6d 61 69 6e 20 3d 20 22 22 3b 0d 0a 20 20 20 20  main = "";..    
3a60: 20 20 20 20 20 20 20 20 20 20 5f 62 75 69 6c 64            _build
3a70: 69 6e 67 53 63 68 65 6d 61 20 3d 20 74 72 75 65  ingSchema = true
3a80: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
3a90: 20 74 72 79 0d 0a 20 20 20 20 20 20 20 20 20 20   try..          
3aa0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
3ab0: 20 20 20 20 20 20 20 49 53 51 4c 69 74 65 53 63         ISQLiteSc
3ac0: 68 65 6d 61 45 78 74 65 6e 73 69 6f 6e 73 20 65  hemaExtensions e
3ad0: 78 74 20 3d 20 28 28 49 53 65 72 76 69 63 65 50  xt = ((IServiceP
3ae0: 72 6f 76 69 64 65 72 29 53 51 4c 69 74 65 46 61  rovider)SQLiteFa
3af0: 63 74 6f 72 79 2e 49 6e 73 74 61 6e 63 65 29 2e  ctory.Instance).
3b00: 47 65 74 53 65 72 76 69 63 65 28 74 79 70 65 6f  GetService(typeo
3b10: 66 28 49 53 51 4c 69 74 65 53 63 68 65 6d 61 45  f(ISQLiteSchemaE
3b20: 78 74 65 6e 73 69 6f 6e 73 29 29 20 61 73 20 49  xtensions)) as I
3b30: 53 51 4c 69 74 65 53 63 68 65 6d 61 45 78 74 65  SQLiteSchemaExte
3b40: 6e 73 69 6f 6e 73 3b 0d 0a 0d 0a 20 20 20 20 20  nsions;....     
3b50: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 65             if (e
3b60: 78 74 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20  xt != null)..   
3b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 65                 e
3b80: 78 74 2e 42 75 69 6c 64 54 65 6d 70 53 63 68 65  xt.BuildTempSche
3b90: 6d 61 28 63 6e 6e 29 3b 0d 0a 0d 0a 20 20 20 20  ma(cnn);....    
3ba0: 20 20 20 20 20 20 20 20 20 20 20 20 77 68 69 6c              whil
3bb0: 65 20 28 63 6d 64 20 3d 3d 20 6e 75 6c 6c 20 26  e (cmd == null &
3bc0: 26 20 73 74 72 53 71 6c 2e 4c 65 6e 67 74 68 20  & strSql.Length 
3bd0: 3e 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20  > 0)..          
3be0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
3bf0: 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 20 3d             cmd =
3c00: 20 50 72 65 70 61 72 65 28 63 6e 6e 2c 20 73 74   Prepare(cnn, st
3c10: 72 53 71 6c 2c 20 70 72 65 76 69 6f 75 73 2c 20  rSql, previous, 
3c20: 74 69 6d 65 6f 75 74 4d 53 2c 20 6f 75 74 20 73  timeoutMS, out s
3c30: 74 72 52 65 6d 61 69 6e 29 3b 0d 0a 20 20 20 20  trRemain);..    
3c40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 74                st
3c50: 72 53 71 6c 20 3d 20 73 74 72 52 65 6d 61 69 6e  rSql = strRemain
3c60: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
3c70: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
3c80: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 63          return c
3c90: 6d 64 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  md;..           
3ca0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20     }..          
3cb0: 20 20 20 20 66 69 6e 61 6c 6c 79 0d 0a 20 20 20      finally..   
3cc0: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
3cd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5f 62                _b
3ce0: 75 69 6c 64 69 6e 67 53 63 68 65 6d 61 20 3d 20  uildingSchema = 
3cf0: 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20 20 20 20  false;..        
3d00: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
3d10: 20 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a       }..#endif..
3d20: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
3d30: 20 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28         else if (
3d40: 6e 20 3d 3d 20 36 20 7c 7c 20 6e 20 3d 3d 20 35  n == 6 || n == 5
3d50: 29 20 2f 2f 20 4c 6f 63 6b 65 64 20 2d 2d 20 64  ) // Locked -- d
3d60: 65 6c 61 79 20 61 20 73 6d 61 6c 6c 20 61 6d 6f  elay a small amo
3d70: 75 6e 74 20 62 65 66 6f 72 65 20 72 65 74 72 79  unt before retry
3d80: 69 6e 67 0d 0a 20 20 20 20 20 20 20 20 20 20 7b  ing..          {
3d90: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f  ..            //
3da0: 20 4b 65 65 70 20 74 72 79 69 6e 67 0d 0a 20 20   Keep trying..  
3db0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 72 6e            if (rn
3dc0: 64 20 3d 3d 20 6e 75 6c 6c 29 20 2f 2f 20 46 69  d == null) // Fi
3dd0: 72 73 74 20 74 69 6d 65 20 77 65 27 76 65 20 65  rst time we've e
3de0: 6e 63 6f 75 6e 74 65 72 65 64 20 74 68 65 20 6c  ncountered the l
3df0: 6f 63 6b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ock..           
3e00: 20 20 20 72 6e 64 20 3d 20 6e 65 77 20 52 61 6e     rnd = new Ran
3e10: 64 6f 6d 28 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  dom();....      
3e20: 20 20 20 20 20 20 2f 2f 20 49 66 20 77 65 27 76        // If we'v
3e30: 65 20 65 78 63 65 65 64 65 64 20 74 68 65 20 63  e exceeded the c
3e40: 6f 6d 6d 61 6e 64 27 73 20 74 69 6d 65 6f 75 74  ommand's timeout
3e50: 2c 20 67 69 76 65 20 75 70 20 61 6e 64 20 74 68  , give up and th
3e60: 72 6f 77 20 61 6e 20 65 72 72 6f 72 0d 0a 20 20  row an error..  
3e70: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 28 75            if ((u
3e80: 69 6e 74 29 45 6e 76 69 72 6f 6e 6d 65 6e 74 2e  int)Environment.
3e90: 54 69 63 6b 43 6f 75 6e 74 20 2d 20 73 74 61 72  TickCount - star
3ea0: 74 74 69 63 6b 20 3e 20 74 69 6d 65 6f 75 74 4d  ttick > timeoutM
3eb0: 53 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  S)..            
3ec0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
3ed0: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
3ee0: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65  eException(n, Ge
3ef0: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
3f00: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
3f10: 20 20 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d             else.
3f20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a  .            {..
3f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f                //
3f40: 20 4f 74 68 65 72 77 69 73 65 20 73 6c 65 65 70   Otherwise sleep
3f50: 20 66 6f 72 20 61 20 72 61 6e 64 6f 6d 20 61 6d   for a random am
3f60: 6f 75 6e 74 20 6f 66 20 74 69 6d 65 20 75 70 20  ount of time up 
3f70: 74 6f 20 31 35 30 6d 73 0d 0a 20 20 20 20 20 20  to 150ms..      
3f80: 20 20 20 20 20 20 20 20 53 79 73 74 65 6d 2e 54          System.T
3f90: 68 72 65 61 64 69 6e 67 2e 54 68 72 65 61 64 2e  hreading.Thread.
3fa0: 53 6c 65 65 70 28 72 6e 64 2e 4e 65 78 74 28 31  Sleep(rnd.Next(1
3fb0: 2c 20 31 35 30 29 29 3b 0d 0a 20 20 20 20 20 20  , 150));..      
3fc0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
3fd0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d     }..        }.
3fe0: 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 6e  ...        if (n
3ff0: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
4000: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
4010: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
4020: 29 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 73  ));....        s
4030: 74 72 52 65 6d 61 69 6e 20 3d 20 55 54 46 38 54  trRemain = UTF8T
4040: 6f 53 74 72 69 6e 67 28 70 74 72 2c 20 6c 65 6e  oString(ptr, len
4050: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66  );....        if
4060: 20 28 73 74 6d 74 20 21 3d 20 49 6e 74 50 74 72   (stmt != IntPtr
4070: 2e 5a 65 72 6f 29 20 63 6d 64 20 3d 20 6e 65 77  .Zero) cmd = new
4080: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
4090: 28 74 68 69 73 2c 20 66 6c 61 67 73 2c 20 6e 65  (this, flags, ne
40a0: 77 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  w SQLiteStatemen
40b0: 74 48 61 6e 64 6c 65 28 5f 73 71 6c 2c 20 73 74  tHandle(_sql, st
40c0: 6d 74 29 2c 20 73 74 72 53 71 6c 2e 53 75 62 73  mt), strSql.Subs
40d0: 74 72 69 6e 67 28 30 2c 20 73 74 72 53 71 6c 2e  tring(0, strSql.
40e0: 4c 65 6e 67 74 68 20 2d 20 73 74 72 52 65 6d 61  Length - strRema
40f0: 69 6e 2e 4c 65 6e 67 74 68 29 2c 20 70 72 65 76  in.Length), prev
4100: 69 6f 75 73 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  ious);....      
4110: 20 20 72 65 74 75 72 6e 20 63 6d 64 3b 0d 0a 20    return cmd;.. 
4120: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 66 69       }..      fi
4130: 6e 61 6c 6c 79 0d 0a 20 20 20 20 20 20 7b 0d 0a  nally..      {..
4140: 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65 2e 46          handle.F
4150: 72 65 65 28 29 3b 0d 0a 20 20 20 20 20 20 7d 0d  ree();..      }.
4160: 0a 20 20 20 20 7d 0d 0a 0d 0a 23 69 66 20 21 50  .    }....#if !P
4170: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
4180: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 70 72  RAMEWORK..    pr
4190: 6f 74 65 63 74 65 64 20 73 74 61 74 69 63 20 76  otected static v
41a0: 6f 69 64 20 4c 6f 67 42 69 6e 64 28 53 51 4c 69  oid LogBind(SQLi
41b0: 74 65 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c  teStatementHandl
41c0: 65 20 68 61 6e 64 6c 65 2c 20 69 6e 74 20 69 6e  e handle, int in
41d0: 64 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  dex)..    {..   
41e0: 20 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64       IntPtr hand
41f0: 6c 65 49 6e 74 50 74 72 20 3d 20 68 61 6e 64 6c  leIntPtr = handl
4200: 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 51  e;....        SQ
4210: 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61  LiteLog.LogMessa
4220: 67 65 28 30 2c 20 53 74 72 69 6e 67 2e 46 6f 72  ge(0, String.For
4230: 6d 61 74 28 0d 0a 20 20 20 20 20 20 20 20 20 20  mat(..          
4240: 20 20 22 42 69 6e 64 69 6e 67 20 73 74 61 74 65    "Binding state
4250: 6d 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74 65  ment {0} paramte
4260: 72 20 23 7b 31 7d 20 61 73 20 4e 55 4c 4c 2e 2e  r #{1} as NULL..
4270: 2e 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  .",..           
4280: 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69   handleIntPtr, i
4290: 6e 64 65 78 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a  ndex));..    }..
42a0: 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64 20  ..    protected 
42b0: 73 74 61 74 69 63 20 76 6f 69 64 20 4c 6f 67 42  static void LogB
42c0: 69 6e 64 28 53 51 4c 69 74 65 53 74 61 74 65 6d  ind(SQLiteStatem
42d0: 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65  entHandle handle
42e0: 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 56 61 6c  , int index, Val
42f0: 75 65 54 79 70 65 20 76 61 6c 75 65 29 0d 0a 20  ueType value).. 
4300: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e     {..        In
4310: 74 50 74 72 20 68 61 6e 64 6c 65 49 6e 74 50 74  tPtr handleIntPt
4320: 72 20 3d 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20  r = handle;.... 
4330: 20 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67         SQLiteLog
4340: 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53  .LogMessage(0, S
4350: 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20  tring.Format(.. 
4360: 20 20 20 20 20 20 20 20 20 20 20 22 42 69 6e 64             "Bind
4370: 69 6e 67 20 73 74 61 74 65 6d 65 6e 74 20 7b 30  ing statement {0
4380: 7d 20 70 61 72 61 6d 74 65 72 20 23 7b 31 7d 20  } paramter #{1} 
4390: 61 73 20 74 79 70 65 20 7b 32 7d 20 77 69 74 68  as type {2} with
43a0: 20 76 61 6c 75 65 20 7b 7b 7b 33 7d 7d 7d 2e 2e   value {{{3}}}..
43b0: 2e 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  .",..           
43c0: 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69   handleIntPtr, i
43d0: 6e 64 65 78 2c 20 76 61 6c 75 65 2e 47 65 74 54  ndex, value.GetT
43e0: 79 70 65 28 29 2c 20 76 61 6c 75 65 29 29 3b 0d  ype(), value));.
43f0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72  .    }....    pr
4400: 69 76 61 74 65 20 73 74 61 74 69 63 20 73 74 72  ivate static str
4410: 69 6e 67 20 46 6f 72 6d 61 74 44 61 74 65 54 69  ing FormatDateTi
4420: 6d 65 28 44 61 74 65 54 69 6d 65 20 76 61 6c 75  me(DateTime valu
4430: 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  e)..    {..     
4440: 20 20 20 53 74 72 69 6e 67 42 75 69 6c 64 65 72     StringBuilder
4450: 20 72 65 73 75 6c 74 20 3d 20 6e 65 77 20 53 74   result = new St
4460: 72 69 6e 67 42 75 69 6c 64 65 72 28 29 3b 0d 0a  ringBuilder();..
4470: 0d 0a 20 20 20 20 20 20 20 20 72 65 73 75 6c 74  ..        result
4480: 2e 41 70 70 65 6e 64 28 76 61 6c 75 65 2e 54 6f  .Append(value.To
4490: 53 74 72 69 6e 67 28 22 79 79 79 79 2d 4d 4d 2d  String("yyyy-MM-
44a0: 64 64 54 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46  ddTHH:mm:ss.FFFF
44b0: 46 46 46 4b 22 29 29 3b 0d 0a 20 20 20 20 20 20  FFFK"));..      
44c0: 20 20 72 65 73 75 6c 74 2e 41 70 70 65 6e 64 28    result.Append(
44d0: 27 20 27 29 3b 0d 0a 20 20 20 20 20 20 20 20 72  ' ');..        r
44e0: 65 73 75 6c 74 2e 41 70 70 65 6e 64 28 76 61 6c  esult.Append(val
44f0: 75 65 2e 4b 69 6e 64 29 3b 0d 0a 20 20 20 20 20  ue.Kind);..     
4500: 20 20 20 72 65 73 75 6c 74 2e 41 70 70 65 6e 64     result.Append
4510: 28 27 20 27 29 3b 0d 0a 20 20 20 20 20 20 20 20  (' ');..        
4520: 72 65 73 75 6c 74 2e 41 70 70 65 6e 64 28 76 61  result.Append(va
4530: 6c 75 65 2e 54 69 63 6b 73 29 3b 0d 0a 0d 0a 20  lue.Ticks);.... 
4540: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 72 65         return re
4550: 73 75 6c 74 2e 54 6f 53 74 72 69 6e 67 28 29 3b  sult.ToString();
4560: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70  ..    }....    p
4570: 72 6f 74 65 63 74 65 64 20 73 74 61 74 69 63 20  rotected static 
4580: 76 6f 69 64 20 4c 6f 67 42 69 6e 64 28 53 51 4c  void LogBind(SQL
4590: 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61 6e 64  iteStatementHand
45a0: 6c 65 20 68 61 6e 64 6c 65 2c 20 69 6e 74 20 69  le handle, int i
45b0: 6e 64 65 78 2c 20 44 61 74 65 54 69 6d 65 20 76  ndex, DateTime v
45c0: 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  alue)..    {..  
45d0: 20 20 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e        IntPtr han
45e0: 64 6c 65 49 6e 74 50 74 72 20 3d 20 68 61 6e 64  dleIntPtr = hand
45f0: 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53  le;....        S
4600: 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73  QLiteLog.LogMess
4610: 61 67 65 28 30 2c 20 53 74 72 69 6e 67 2e 46 6f  age(0, String.Fo
4620: 72 6d 61 74 28 0d 0a 20 20 20 20 20 20 20 20 20  rmat(..         
4630: 20 20 20 22 42 69 6e 64 69 6e 67 20 73 74 61 74     "Binding stat
4640: 65 6d 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74  ement {0} paramt
4650: 65 72 20 23 7b 31 7d 20 61 73 20 74 79 70 65 20  er #{1} as type 
4660: 7b 32 7d 20 77 69 74 68 20 76 61 6c 75 65 20 7b  {2} with value {
4670: 7b 7b 33 7d 7d 7d 2e 2e 2e 22 2c 0d 0a 20 20 20  {{3}}}...",..   
4680: 20 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65 49           handleI
4690: 6e 74 50 74 72 2c 20 69 6e 64 65 78 2c 20 74 79  ntPtr, index, ty
46a0: 70 65 6f 66 28 44 61 74 65 54 69 6d 65 29 2c 20  peof(DateTime), 
46b0: 46 6f 72 6d 61 74 44 61 74 65 54 69 6d 65 28 76  FormatDateTime(v
46c0: 61 6c 75 65 29 29 29 3b 0d 0a 20 20 20 20 7d 0d  alue)));..    }.
46d0: 0a 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64  ...    protected
46e0: 20 73 74 61 74 69 63 20 76 6f 69 64 20 4c 6f 67   static void Log
46f0: 42 69 6e 64 28 53 51 4c 69 74 65 53 74 61 74 65  Bind(SQLiteState
4700: 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c  mentHandle handl
4710: 65 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 73 74  e, int index, st
4720: 72 69 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20 20  ring value)..   
4730: 20 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e 74 50   {..        IntP
4740: 74 72 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20  tr handleIntPtr 
4750: 3d 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20  = handle;....   
4760: 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c       SQLiteLog.L
4770: 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53 74 72  ogMessage(0, Str
4780: 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20 20  ing.Format(..   
4790: 20 20 20 20 20 20 20 20 20 22 42 69 6e 64 69 6e           "Bindin
47a0: 67 20 73 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20  g statement {0} 
47b0: 70 61 72 61 6d 74 65 72 20 23 7b 31 7d 20 61 73  paramter #{1} as
47c0: 20 74 79 70 65 20 7b 32 7d 20 77 69 74 68 20 76   type {2} with v
47d0: 61 6c 75 65 20 7b 7b 7b 33 7d 7d 7d 2e 2e 2e 22  alue {{{3}}}..."
47e0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 68  ,..            h
47f0: 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e 64  andleIntPtr, ind
4800: 65 78 2c 20 74 79 70 65 6f 66 28 53 74 72 69 6e  ex, typeof(Strin
4810: 67 29 2c 20 28 76 61 6c 75 65 20 21 3d 20 6e 75  g), (value != nu
4820: 6c 6c 29 20 3f 20 76 61 6c 75 65 20 3a 20 22 3c  ll) ? value : "<
4830: 6e 75 6c 6c 3e 22 29 29 3b 0d 0a 20 20 20 20 7d  null>"));..    }
4840: 0d 0a 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20  ....    private 
4850: 73 74 61 74 69 63 20 73 74 72 69 6e 67 20 54 6f  static string To
4860: 48 65 78 61 64 65 63 69 6d 61 6c 53 74 72 69 6e  HexadecimalStrin
4870: 67 28 0d 0a 20 20 20 20 20 20 20 20 62 79 74 65  g(..        byte
4880: 5b 5d 20 61 72 72 61 79 0d 0a 20 20 20 20 20 20  [] array..      
4890: 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20    )..    {..    
48a0: 20 20 20 20 69 66 20 28 61 72 72 61 79 20 3d 3d      if (array ==
48b0: 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20   null)..        
48c0: 20 20 20 20 72 65 74 75 72 6e 20 6e 75 6c 6c 3b      return null;
48d0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 74 72 69  ....        Stri
48e0: 6e 67 42 75 69 6c 64 65 72 20 72 65 73 75 6c 74  ngBuilder result
48f0: 20 3d 20 6e 65 77 20 53 74 72 69 6e 67 42 75 69   = new StringBui
4900: 6c 64 65 72 28 61 72 72 61 79 2e 4c 65 6e 67 74  lder(array.Lengt
4910: 68 20 2a 20 32 29 3b 0d 0a 0d 0a 20 20 20 20 20  h * 2);....     
4920: 20 20 20 69 6e 74 20 6c 65 6e 67 74 68 20 3d 20     int length = 
4930: 61 72 72 61 79 2e 4c 65 6e 67 74 68 3b 0d 0a 0d  array.Length;...
4940: 0a 20 20 20 20 20 20 20 20 66 6f 72 20 28 69 6e  .        for (in
4950: 74 20 69 6e 64 65 78 20 3d 20 30 3b 20 69 6e 64  t index = 0; ind
4960: 65 78 20 3c 20 6c 65 6e 67 74 68 3b 20 69 6e 64  ex < length; ind
4970: 65 78 2b 2b 29 0d 0a 20 20 20 20 20 20 20 20 20  ex++)..         
4980: 20 20 20 72 65 73 75 6c 74 2e 41 70 70 65 6e 64     result.Append
4990: 28 61 72 72 61 79 5b 69 6e 64 65 78 5d 2e 54 6f  (array[index].To
49a0: 53 74 72 69 6e 67 28 22 78 32 22 29 29 3b 0d 0a  String("x2"));..
49b0: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
49c0: 20 72 65 73 75 6c 74 2e 54 6f 53 74 72 69 6e 67   result.ToString
49d0: 28 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  ();..    }....  
49e0: 20 20 70 72 6f 74 65 63 74 65 64 20 73 74 61 74    protected stat
49f0: 69 63 20 76 6f 69 64 20 4c 6f 67 42 69 6e 64 28  ic void LogBind(
4a00: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48  SQLiteStatementH
4a10: 61 6e 64 6c 65 20 68 61 6e 64 6c 65 2c 20 69 6e  andle handle, in
4a20: 74 20 69 6e 64 65 78 2c 20 62 79 74 65 5b 5d 20  t index, byte[] 
4a30: 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20  value)..    {.. 
4a40: 20 20 20 20 20 20 20 49 6e 74 50 74 72 20 68 61         IntPtr ha
4a50: 6e 64 6c 65 49 6e 74 50 74 72 20 3d 20 68 61 6e  ndleIntPtr = han
4a60: 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  dle;....        
4a70: 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73  SQLiteLog.LogMes
4a80: 73 61 67 65 28 30 2c 20 53 74 72 69 6e 67 2e 46  sage(0, String.F
4a90: 6f 72 6d 61 74 28 0d 0a 20 20 20 20 20 20 20 20  ormat(..        
4aa0: 20 20 20 20 22 42 69 6e 64 69 6e 67 20 73 74 61      "Binding sta
4ab0: 74 65 6d 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d  tement {0} param
4ac0: 74 65 72 20 23 7b 31 7d 20 61 73 20 74 79 70 65  ter #{1} as type
4ad0: 20 7b 32 7d 20 77 69 74 68 20 76 61 6c 75 65 20   {2} with value 
4ae0: 7b 7b 7b 33 7d 7d 7d 2e 2e 2e 22 2c 0d 0a 20 20  {{{3}}}...",..  
4af0: 20 20 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65            handle
4b00: 49 6e 74 50 74 72 2c 20 69 6e 64 65 78 2c 20 74  IntPtr, index, t
4b10: 79 70 65 6f 66 28 42 79 74 65 5b 5d 29 2c 20 28  ypeof(Byte[]), (
4b20: 76 61 6c 75 65 20 21 3d 20 6e 75 6c 6c 29 20 3f  value != null) ?
4b30: 20 54 6f 48 65 78 61 64 65 63 69 6d 61 6c 53 74   ToHexadecimalSt
4b40: 72 69 6e 67 28 76 61 6c 75 65 29 20 3a 20 22 3c  ring(value) : "<
4b50: 6e 75 6c 6c 3e 22 29 29 3b 0d 0a 20 20 20 20 7d  null>"));..    }
4b60: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20  ..#endif....    
4b70: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
4b80: 65 20 76 6f 69 64 20 42 69 6e 64 5f 44 6f 75 62  e void Bind_Doub
4b90: 6c 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  le(SQLiteStateme
4ba0: 6e 74 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43  nt stmt, SQLiteC
4bb0: 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66  onnectionFlags f
4bc0: 6c 61 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c  lags, int index,
4bd0: 20 64 6f 75 62 6c 65 20 76 61 6c 75 65 29 0d 0a   double value)..
4be0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 53      {..        S
4bf0: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61  QLiteStatementHa
4c00: 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73 74  ndle handle = st
4c10: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 3b  mt._sqlite_stmt;
4c20: 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52  ....#if !PLATFOR
4c30: 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f  M_COMPACTFRAMEWO
4c40: 52 4b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  RK..        if (
4c50: 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65 43  (flags & SQLiteC
4c60: 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c  onnectionFlags.L
4c70: 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69 74  ogBind) == SQLit
4c80: 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73  eConnectionFlags
4c90: 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20 20  .LogBind)..     
4ca0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
4cb0: 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c 65    LogBind(handle
4cc0: 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b  , index, value);
4cd0: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20  ..        }.... 
4ce0: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55         int n = U
4cf0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
4d00: 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  ds.sqlite3_bind_
4d10: 64 6f 75 62 6c 65 28 68 61 6e 64 6c 65 2c 20 69  double(handle, i
4d20: 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 23  ndex, value);..#
4d30: 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 69 6e  else..        in
4d40: 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  t n = UnsafeNati
4d50: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
4d60: 33 5f 62 69 6e 64 5f 64 6f 75 62 6c 65 5f 69 6e  3_bind_double_in
4d70: 74 65 72 6f 70 28 68 61 6e 64 6c 65 2c 20 69 6e  terop(handle, in
4d80: 64 65 78 2c 20 72 65 66 20 76 61 6c 75 65 29 3b  dex, ref value);
4d90: 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20  ..#endif..      
4da0: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
4db0: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
4dc0: 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73  eption(n, GetLas
4dd0: 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20  tError());..    
4de0: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
4df0: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
4e00: 42 69 6e 64 5f 49 6e 74 33 32 28 53 51 4c 69 74  Bind_Int32(SQLit
4e10: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
4e20: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
4e30: 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69 6e  nFlags flags, in
4e40: 74 20 69 6e 64 65 78 2c 20 69 6e 74 20 76 61 6c  t index, int val
4e50: 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ue)..    {..    
4e60: 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d      SQLiteStatem
4e70: 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65  entHandle handle
4e80: 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f   = stmt._sqlite_
4e90: 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c  stmt;....#if !PL
4ea0: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
4eb0: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20  AMEWORK..       
4ec0: 20 69 66 20 28 28 66 6c 61 67 73 20 26 20 53 51   if ((flags & SQ
4ed0: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
4ee0: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20  ags.LogBind) == 
4ef0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
4f00: 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a  Flags.LogBind)..
4f10: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
4f20: 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68         LogBind(h
4f30: 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61  andle, index, va
4f40: 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d  lue);..        }
4f50: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20  ..#endif....    
4f60: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
4f70: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
4f80: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74  sqlite3_bind_int
4f90: 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20  (handle, index, 
4fa0: 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20  value);..       
4fb0: 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f   if (n > 0) thro
4fc0: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
4fd0: 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74  ption(n, GetLast
4fe0: 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d  Error());..    }
4ff0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
5000: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 42   override void B
5010: 69 6e 64 5f 55 49 6e 74 33 32 28 53 51 4c 69 74  ind_UInt32(SQLit
5020: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
5030: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
5040: 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69 6e  nFlags flags, in
5050: 74 20 69 6e 64 65 78 2c 20 75 69 6e 74 20 76 61  t index, uint va
5060: 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  lue)..    {..   
5070: 20 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65       SQLiteState
5080: 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c  mentHandle handl
5090: 65 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65  e = stmt._sqlite
50a0: 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50  _stmt;....#if !P
50b0: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
50c0: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20  RAMEWORK..      
50d0: 20 20 69 66 20 28 28 66 6c 61 67 73 20 26 20 53    if ((flags & S
50e0: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46  QLiteConnectionF
50f0: 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d  lags.LogBind) ==
5100: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
5110: 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d  nFlags.LogBind).
5120: 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  .        {..    
5130: 20 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28          LogBind(
5140: 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76  handle, index, v
5150: 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20  alue);..        
5160: 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20  }..#endif....   
5170: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73       int n = Uns
5180: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
5190: 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 75 69  .sqlite3_bind_ui
51a0: 6e 74 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  nt(handle, index
51b0: 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20  , value);..     
51c0: 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68     if (n > 0) th
51d0: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
51e0: 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61  ception(n, GetLa
51f0: 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20  stError());..   
5200: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
5210: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
5220: 20 42 69 6e 64 5f 49 6e 74 36 34 28 53 51 4c 69   Bind_Int64(SQLi
5230: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
5240: 2c 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  , SQLiteConnecti
5250: 6f 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69  onFlags flags, i
5260: 6e 74 20 69 6e 64 65 78 2c 20 6c 6f 6e 67 20 76  nt index, long v
5270: 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  alue)..    {..  
5280: 20 20 20 20 20 20 53 51 4c 69 74 65 53 74 61 74        SQLiteStat
5290: 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64  ementHandle hand
52a0: 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74  le = stmt._sqlit
52b0: 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21  e_stmt;....#if !
52c0: 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54  PLATFORM_COMPACT
52d0: 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20  FRAMEWORK..     
52e0: 20 20 20 69 66 20 28 28 66 6c 61 67 73 20 26 20     if ((flags & 
52f0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
5300: 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d  Flags.LogBind) =
5310: 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  = SQLiteConnecti
5320: 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29  onFlags.LogBind)
5330: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
5340: 20 20 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64           LogBind
5350: 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20  (handle, index, 
5360: 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20  value);..       
5370: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 6e   }....        in
5380: 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  t n = UnsafeNati
5390: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
53a0: 33 5f 62 69 6e 64 5f 69 6e 74 36 34 28 68 61 6e  3_bind_int64(han
53b0: 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75  dle, index, valu
53c0: 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  e);..#else..    
53d0: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
53e0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
53f0: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74  sqlite3_bind_int
5400: 36 34 5f 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c  64_interop(handl
5410: 65 2c 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61  e, index, ref va
5420: 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20  lue);..#endif.. 
5430: 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30         if (n > 0
5440: 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69  ) throw new SQLi
5450: 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47  teException(n, G
5460: 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d  etLastError());.
5470: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
5480: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
5490: 76 6f 69 64 20 42 69 6e 64 5f 55 49 6e 74 36 34  void Bind_UInt64
54a0: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
54b0: 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e   stmt, SQLiteCon
54c0: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61  nectionFlags fla
54d0: 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 75  gs, int index, u
54e0: 6c 6f 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20 20  long value)..   
54f0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69   {..        SQLi
5500: 74 65 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c  teStatementHandl
5510: 65 20 68 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e  e handle = stmt.
5520: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d  _sqlite_stmt;...
5530: 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43  .#if !PLATFORM_C
5540: 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d  OMPACTFRAMEWORK.
5550: 0a 20 20 20 20 20 20 20 20 69 66 20 28 28 66 6c  .        if ((fl
5560: 61 67 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e  ags & SQLiteConn
5570: 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42  ectionFlags.LogB
5580: 69 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f  ind) == SQLiteCo
5590: 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f  nnectionFlags.Lo
55a0: 67 42 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20  gBind)..        
55b0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 4c  {..            L
55c0: 6f 67 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69  ogBind(handle, i
55d0: 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20  ndex, value);.. 
55e0: 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20         }....    
55f0: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
5600: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
5610: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 75 69 6e  sqlite3_bind_uin
5620: 74 36 34 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65  t64(handle, inde
5630: 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c 73  x, value);..#els
5640: 65 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e  e..        int n
5650: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
5660: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
5670: 69 6e 64 5f 75 69 6e 74 36 34 5f 69 6e 74 65 72  ind_uint64_inter
5680: 6f 70 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  op(handle, index
5690: 2c 20 72 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23  , ref value);..#
56a0: 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20 69  endif..        i
56b0: 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20  f (n > 0) throw 
56c0: 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74  new SQLiteExcept
56d0: 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45 72  ion(n, GetLastEr
56e0: 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a  ror());..    }..
56f0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
5700: 76 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e  verride void Bin
5710: 64 5f 54 65 78 74 28 53 51 4c 69 74 65 53 74 61  d_Text(SQLiteSta
5720: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51 4c  tement stmt, SQL
5730: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
5740: 67 73 20 66 6c 61 67 73 2c 20 69 6e 74 20 69 6e  gs flags, int in
5750: 64 65 78 2c 20 73 74 72 69 6e 67 20 76 61 6c 75  dex, string valu
5760: 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  e)..    {..     
5770: 20 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65     SQLiteStateme
5780: 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20  ntHandle handle 
5790: 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  = stmt._sqlite_s
57a0: 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41  tmt;....#if !PLA
57b0: 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41  TFORM_COMPACTFRA
57c0: 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20  MEWORK..        
57d0: 69 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c  if ((flags & SQL
57e0: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
57f0: 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53  gs.LogBind) == S
5800: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46  QLiteConnectionF
5810: 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20  lags.LogBind).. 
5820: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
5830: 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61        LogBind(ha
5840: 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c  ndle, index, val
5850: 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ue);..        }.
5860: 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20  .#endif....     
5870: 20 20 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f     byte[] b = To
5880: 55 54 46 38 28 76 61 6c 75 65 29 3b 0d 0a 0d 0a  UTF8(value);....
5890: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
58a0: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
58b0: 20 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61          if ((fla
58c0: 67 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65  gs & SQLiteConne
58d0: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
58e0: 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e  nd) == SQLiteCon
58f0: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67  nectionFlags.Log
5900: 42 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b  Bind)..        {
5910: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f  ..            Lo
5920: 67 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e  gBind(handle, in
5930: 64 65 78 2c 20 62 29 3b 0d 0a 20 20 20 20 20 20  dex, b);..      
5940: 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20    }..#endif.... 
5950: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55         int n = U
5960: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
5970: 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  ds.sqlite3_bind_
5980: 74 65 78 74 28 68 61 6e 64 6c 65 2c 20 69 6e 64  text(handle, ind
5990: 65 78 2c 20 62 2c 20 62 2e 4c 65 6e 67 74 68 20  ex, b, b.Length 
59a0: 2d 20 31 2c 20 28 49 6e 74 50 74 72 29 28 2d 31  - 1, (IntPtr)(-1
59b0: 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ));..        if 
59c0: 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65  (n > 0) throw ne
59d0: 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  w SQLiteExceptio
59e0: 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f  n(n, GetLastErro
59f0: 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  r());..    }....
5a00: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
5a10: 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f  rride void Bind_
5a20: 44 61 74 65 54 69 6d 65 28 53 51 4c 69 74 65 53  DateTime(SQLiteS
5a30: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53  tatement stmt, S
5a40: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46  QLiteConnectionF
5a50: 6c 61 67 73 20 66 6c 61 67 73 2c 20 69 6e 74 20  lags flags, int 
5a60: 69 6e 64 65 78 2c 20 44 61 74 65 54 69 6d 65 20  index, DateTime 
5a70: 64 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  dt)..    {..    
5a80: 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d      SQLiteStatem
5a90: 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65  entHandle handle
5aa0: 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f   = stmt._sqlite_
5ab0: 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c  stmt;....#if !PL
5ac0: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
5ad0: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20  AMEWORK..       
5ae0: 20 69 66 20 28 28 66 6c 61 67 73 20 26 20 53 51   if ((flags & SQ
5af0: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
5b00: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20  ags.LogBind) == 
5b10: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
5b20: 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a  Flags.LogBind)..
5b30: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
5b40: 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68         LogBind(h
5b50: 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 64 74  andle, index, dt
5b60: 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 23  );..        }..#
5b70: 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20 20  endif....       
5b80: 20 73 77 69 74 63 68 20 28 5f 64 61 74 65 74 69   switch (_dateti
5b90: 6d 65 46 6f 72 6d 61 74 29 0d 0a 20 20 20 20 20  meFormat)..     
5ba0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
5bb0: 20 20 63 61 73 65 20 53 51 4c 69 74 65 44 61 74    case SQLiteDat
5bc0: 65 46 6f 72 6d 61 74 73 2e 54 69 63 6b 73 3a 0d  eFormats.Ticks:.
5bd0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
5be0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
5bf0: 20 20 20 20 20 20 20 20 6c 6f 6e 67 20 76 61 6c          long val
5c00: 75 65 20 3d 20 64 74 2e 54 69 63 6b 73 3b 0d 0a  ue = dt.Ticks;..
5c10: 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f  ..#if !PLATFORM_
5c20: 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b  COMPACTFRAMEWORK
5c30: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
5c40: 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73        if ((flags
5c50: 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74   & SQLiteConnect
5c60: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
5c70: 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65  ) == SQLiteConne
5c80: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
5c90: 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  nd)..           
5ca0: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
5cb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5cc0: 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64      LogBind(hand
5cd0: 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65  le, index, value
5ce0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
5cf0: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20          }....   
5d00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5d10: 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e   int n = UnsafeN
5d20: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
5d30: 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36 34 28  ite3_bind_int64(
5d40: 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76  handle, index, v
5d50: 61 6c 75 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20  alue);..#else.. 
5d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5d70: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
5d80: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
5d90: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36  qlite3_bind_int6
5da0: 34 5f 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c 65  4_interop(handle
5db0: 2c 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c  , index, ref val
5dc0: 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20  ue);..#endif..  
5dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5de0: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
5df0: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
5e00: 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73  eption(n, GetLas
5e10: 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20  tError());..    
5e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e30: 62 72 65 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20  break;..        
5e40: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
5e50: 20 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 69         case SQLi
5e60: 74 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 4a 75  teDateFormats.Ju
5e70: 6c 69 61 6e 44 61 79 3a 0d 0a 20 20 20 20 20 20  lianDay:..      
5e80: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
5e90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5ea0: 20 64 6f 75 62 6c 65 20 76 61 6c 75 65 20 3d 20   double value = 
5eb0: 54 6f 4a 75 6c 69 61 6e 44 61 79 28 64 74 29 3b  ToJulianDay(dt);
5ec0: 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52  ....#if !PLATFOR
5ed0: 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f  M_COMPACTFRAMEWO
5ee0: 52 4b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  RK..            
5ef0: 20 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61          if ((fla
5f00: 67 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65  gs & SQLiteConne
5f10: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
5f20: 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e  nd) == SQLiteCon
5f30: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67  nectionFlags.Log
5f40: 42 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 20  Bind)..         
5f50: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
5f60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5f70: 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61        LogBind(ha
5f80: 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c  ndle, index, val
5f90: 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  ue);..          
5fa0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20            }.... 
5fb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5fc0: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
5fd0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
5fe0: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62  qlite3_bind_doub
5ff0: 6c 65 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  le(handle, index
6000: 2c 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c 73 65  , value);..#else
6010: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6020: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
6030: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
6040: 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64  s.sqlite3_bind_d
6050: 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 68 61  ouble_interop(ha
6060: 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 72 65 66  ndle, index, ref
6070: 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66   value);..#endif
6080: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6090: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
60a0: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
60b0: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65  eException(n, Ge
60c0: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
60d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
60e0: 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20      break;..    
60f0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
6100: 20 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20             case 
6110: 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74  SQLiteDateFormat
6120: 73 2e 55 6e 69 78 45 70 6f 63 68 3a 0d 0a 20 20  s.UnixEpoch:..  
6130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d                {.
6140: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6150: 20 20 20 20 20 6c 6f 6e 67 20 76 61 6c 75 65 20       long value 
6160: 3d 20 43 6f 6e 76 65 72 74 2e 54 6f 49 6e 74 36  = Convert.ToInt6
6170: 34 28 64 74 2e 53 75 62 74 72 61 63 74 28 55 6e  4(dt.Subtract(Un
6180: 69 78 45 70 6f 63 68 29 2e 54 6f 74 61 6c 53 65  ixEpoch).TotalSe
6190: 63 6f 6e 64 73 29 3b 0d 0a 0d 0a 23 69 66 20 21  conds);....#if !
61a0: 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54  PLATFORM_COMPACT
61b0: 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20  FRAMEWORK..     
61c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
61d0: 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69  f ((flags & SQLi
61e0: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
61f0: 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51  s.LogBind) == SQ
6200: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
6210: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20  ags.LogBind)..  
6220: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6230: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
6240: 20 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67               Log
6250: 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64  Bind(handle, ind
6260: 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20  ex, value);..   
6270: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6280: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20   }....          
6290: 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20            int n 
62a0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
62b0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69  thods.sqlite3_bi
62c0: 6e 64 5f 69 6e 74 36 34 28 68 61 6e 64 6c 65 2c  nd_int64(handle,
62d0: 20 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d   index, value);.
62e0: 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20  .#else..        
62f0: 20 20 20 20 20 20 20 20 20 20 20 20 69 6e 74 20              int 
6300: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
6310: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
6320: 62 69 6e 64 5f 69 6e 74 36 34 5f 69 6e 74 65 72  bind_int64_inter
6330: 6f 70 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  op(handle, index
6340: 2c 20 72 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23  , ref value);..#
6350: 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20 20  endif..         
6360: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 6e             if (n
6370: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
6380: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
6390: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
63a0: 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ));..           
63b0: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d           break;.
63c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
63d0: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
63e0: 64 65 66 61 75 6c 74 3a 0d 0a 20 20 20 20 20 20  default:..      
63f0: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
6400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6410: 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54   byte[] b = ToUT
6420: 46 38 28 64 74 29 3b 0d 0a 0d 0a 23 69 66 20 21  F8(dt);....#if !
6430: 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54  PLATFORM_COMPACT
6440: 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20  FRAMEWORK..     
6450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
6460: 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69  f ((flags & SQLi
6470: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
6480: 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51  s.LogBind) == SQ
6490: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
64a0: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20  ags.LogBind)..  
64b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
64c0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
64d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67               Log
64e0: 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64  Bind(handle, ind
64f0: 65 78 2c 20 62 29 3b 0d 0a 20 20 20 20 20 20 20  ex, b);..       
6500: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a               }..
6510: 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20  #endif....      
6520: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6e                in
6530: 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  t n = UnsafeNati
6540: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
6550: 33 5f 62 69 6e 64 5f 74 65 78 74 28 68 61 6e 64  3_bind_text(hand
6560: 6c 65 2c 20 69 6e 64 65 78 2c 20 62 2c 20 62 2e  le, index, b, b.
6570: 4c 65 6e 67 74 68 20 2d 20 31 2c 20 28 49 6e 74  Length - 1, (Int
6580: 50 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20  Ptr)(-1));..    
6590: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
65a0: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
65b0: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
65c0: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
65d0: 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 20 20  rror());..      
65e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62 72                br
65f0: 65 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  eak;..          
6600: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
6610: 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20   }..    }....   
6620: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
6630: 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 42 6c 6f  de void Bind_Blo
6640: 62 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  b(SQLiteStatemen
6650: 74 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f  t stmt, SQLiteCo
6660: 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c  nnectionFlags fl
6670: 61 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20  ags, int index, 
6680: 62 79 74 65 5b 5d 20 62 6c 6f 62 44 61 74 61 29  byte[] blobData)
6690: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
66a0: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
66b0: 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20  Handle handle = 
66c0: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
66d0: 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46  t;....#if !PLATF
66e0: 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45  ORM_COMPACTFRAME
66f0: 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 69 66  WORK..        if
6700: 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74   ((flags & SQLit
6710: 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73  eConnectionFlags
6720: 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c  .LogBind) == SQL
6730: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
6740: 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20  gs.LogBind)..   
6750: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
6760: 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64      LogBind(hand
6770: 6c 65 2c 20 69 6e 64 65 78 2c 20 62 6c 6f 62 44  le, index, blobD
6780: 61 74 61 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d  ata);..        }
6790: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20  ..#endif....    
67a0: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
67b0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
67c0: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 62 6c 6f  sqlite3_bind_blo
67d0: 62 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c  b(handle, index,
67e0: 20 62 6c 6f 62 44 61 74 61 2c 20 62 6c 6f 62 44   blobData, blobD
67f0: 61 74 61 2e 4c 65 6e 67 74 68 2c 20 28 49 6e 74  ata.Length, (Int
6800: 50 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20  Ptr)(-1));..    
6810: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
6820: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
6830: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c  xception(n, GetL
6840: 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20  astError());..  
6850: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
6860: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
6870: 64 20 42 69 6e 64 5f 4e 75 6c 6c 28 53 51 4c 69  d Bind_Null(SQLi
6880: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
6890: 2c 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  , SQLiteConnecti
68a0: 6f 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69  onFlags flags, i
68b0: 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b  nt index)..    {
68c0: 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65  ..        SQLite
68d0: 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20  StatementHandle 
68e0: 68 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73  handle = stmt._s
68f0: 71 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23  qlite_stmt;....#
6900: 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d  if !PLATFORM_COM
6910: 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20  PACTFRAMEWORK.. 
6920: 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67         if ((flag
6930: 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63  s & SQLiteConnec
6940: 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e  tionFlags.LogBin
6950: 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e  d) == SQLiteConn
6960: 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42  ectionFlags.LogB
6970: 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d  ind)..        {.
6980: 0a 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67  .            Log
6990: 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64  Bind(handle, ind
69a0: 65 78 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ex);..        }.
69b0: 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20  .#endif....     
69c0: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
69d0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
69e0: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 6e 75 6c 6c  qlite3_bind_null
69f0: 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 29 3b  (handle, index);
6a00: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 6e 20  ..        if (n 
6a10: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
6a20: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
6a30: 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29  , GetLastError()
6a40: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
6a50: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
6a60: 64 65 20 69 6e 74 20 42 69 6e 64 5f 50 61 72 61  de int Bind_Para
6a70: 6d 43 6f 75 6e 74 28 53 51 4c 69 74 65 53 74 61  mCount(SQLiteSta
6a80: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51 4c  tement stmt, SQL
6a90: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
6aa0: 67 73 20 66 6c 61 67 73 29 0d 0a 20 20 20 20 7b  gs flags)..    {
6ab0: 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65  ..        SQLite
6ac0: 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20  StatementHandle 
6ad0: 68 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73  handle = stmt._s
6ae0: 71 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 20 20 20  qlite_stmt;..   
6af0: 20 20 20 20 20 69 6e 74 20 76 61 6c 75 65 20 3d       int value =
6b00: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
6b10: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
6b20: 64 5f 70 61 72 61 6d 65 74 65 72 5f 63 6f 75 6e  d_parameter_coun
6b30: 74 28 68 61 6e 64 6c 65 29 3b 0d 0a 0d 0a 23 69  t(handle);....#i
6b40: 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50  f !PLATFORM_COMP
6b50: 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20  ACTFRAMEWORK..  
6b60: 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73        if ((flags
6b70: 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74   & SQLiteConnect
6b80: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
6b90: 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65  ) == SQLiteConne
6ba0: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
6bb0: 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  nd)..        {..
6bc0: 20 20 20 20 20 20 20 20 20 20 20 20 49 6e 74 50              IntP
6bd0: 74 72 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20  tr handleIntPtr 
6be0: 3d 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20  = handle;....   
6bf0: 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 4c           SQLiteL
6c00: 6f 67 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c  og.LogMessage(0,
6c10: 20 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 0d   String.Format(.
6c20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6c30: 20 22 53 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20   "Statement {0} 
6c40: 70 61 72 61 6d 74 65 72 20 63 6f 75 6e 74 20 69  paramter count i
6c50: 73 20 7b 31 7d 2e 22 2c 0d 0a 20 20 20 20 20 20  s {1}.",..      
6c60: 20 20 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65            handle
6c70: 49 6e 74 50 74 72 2c 20 76 61 6c 75 65 29 29 3b  IntPtr, value));
6c80: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 23 65 6e  ..        }..#en
6c90: 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72  dif....        r
6ca0: 65 74 75 72 6e 20 76 61 6c 75 65 3b 0d 0a 20 20  eturn value;..  
6cb0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
6cc0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72  nal override str
6cd0: 69 6e 67 20 42 69 6e 64 5f 50 61 72 61 6d 4e 61  ing Bind_ParamNa
6ce0: 6d 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  me(SQLiteStateme
6cf0: 6e 74 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43  nt stmt, SQLiteC
6d00: 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66  onnectionFlags f
6d10: 6c 61 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 29  lags, int index)
6d20: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
6d30: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
6d40: 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20  Handle handle = 
6d50: 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d  stmt._sqlite_stm
6d60: 74 3b 0d 0a 20 20 20 20 20 20 20 20 73 74 72 69  t;..        stri
6d70: 6e 67 20 6e 61 6d 65 3b 0d 0a 0d 0a 23 69 66 20  ng name;....#if 
6d80: 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44  !SQLITE_STANDARD
6d90: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6c 65  ..        int le
6da0: 6e 3b 0d 0a 20 20 20 20 20 20 20 20 6e 61 6d 65  n;..        name
6db0: 20 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28   = UTF8ToString(
6dc0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
6dd0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
6de0: 5f 70 61 72 61 6d 65 74 65 72 5f 6e 61 6d 65 5f  _parameter_name_
6df0: 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c 65 2c 20  interop(handle, 
6e00: 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c  index, out len),
6e10: 20 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20   len);..#else.. 
6e20: 20 20 20 20 20 20 20 6e 61 6d 65 20 3d 20 55 54         name = UT
6e30: 46 38 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66  F8ToString(Unsaf
6e40: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
6e50: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 70 61 72 61  qlite3_bind_para
6e60: 6d 65 74 65 72 5f 6e 61 6d 65 28 68 61 6e 64 6c  meter_name(handl
6e70: 65 2c 20 69 6e 64 65 78 29 2c 20 2d 31 29 3b 0d  e, index), -1);.
6e80: 0a 23 65 6e 64 69 66 0d 0a 0d 0a 23 69 66 20 21  .#endif....#if !
6e90: 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54  PLATFORM_COMPACT
6ea0: 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20  FRAMEWORK..     
6eb0: 20 20 20 69 66 20 28 28 66 6c 61 67 73 20 26 20     if ((flags & 
6ec0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
6ed0: 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d  Flags.LogBind) =
6ee0: 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  = SQLiteConnecti
6ef0: 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29  onFlags.LogBind)
6f00: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
6f10: 20 20 20 20 20 20 20 20 20 49 6e 74 50 74 72 20           IntPtr 
6f20: 68 61 6e 64 6c 65 49 6e 74 50 74 72 20 3d 20 68  handleIntPtr = h
6f30: 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20 20  andle;....      
6f40: 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e        SQLiteLog.
6f50: 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53 74  LogMessage(0, St
6f60: 72 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20  ring.Format(..  
6f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 53                "S
6f80: 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20 70 61 72  tatement {0} par
6f90: 61 6d 74 65 72 20 23 7b 31 7d 20 6e 61 6d 65 20  amter #{1} name 
6fa0: 69 73 20 7b 7b 7b 32 7d 7d 7d 2e 22 2c 0d 0a 20  is {{{2}}}.",.. 
6fb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 68                 h
6fc0: 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e 64  andleIntPtr, ind
6fd0: 65 78 2c 20 6e 61 6d 65 29 29 3b 0d 0a 20 20 20  ex, name));..   
6fe0: 20 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a       }..#endif..
6ff0: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
7000: 20 6e 61 6d 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d   name;..    }...
7010: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
7020: 65 72 72 69 64 65 20 69 6e 74 20 42 69 6e 64 5f  erride int Bind_
7030: 50 61 72 61 6d 49 6e 64 65 78 28 53 51 4c 69 74  ParamIndex(SQLit
7040: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
7050: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
7060: 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 73 74  nFlags flags, st
7070: 72 69 6e 67 20 70 61 72 61 6d 4e 61 6d 65 29 0d  ring paramName).
7080: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20  .    {..        
7090: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48  SQLiteStatementH
70a0: 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73  andle handle = s
70b0: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
70c0: 3b 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69  ;..        int i
70d0: 6e 64 65 78 20 3d 20 55 6e 73 61 66 65 4e 61 74  ndex = UnsafeNat
70e0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
70f0: 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65  e3_bind_paramete
7100: 72 5f 69 6e 64 65 78 28 68 61 6e 64 6c 65 2c 20  r_index(handle, 
7110: 54 6f 55 54 46 38 28 70 61 72 61 6d 4e 61 6d 65  ToUTF8(paramName
7120: 29 29 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54  ));....#if !PLAT
7130: 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d  FORM_COMPACTFRAM
7140: 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 69  EWORK..        i
7150: 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69  f ((flags & SQLi
7160: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
7170: 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51  s.LogBind) == SQ
7180: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
7190: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20  ags.LogBind)..  
71a0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
71b0: 20 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64       IntPtr hand
71c0: 6c 65 49 6e 74 50 74 72 20 3d 20 68 61 6e 64 6c  leIntPtr = handl
71d0: 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  e;....          
71e0: 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d    SQLiteLog.LogM
71f0: 65 73 73 61 67 65 28 30 2c 20 53 74 72 69 6e 67  essage(0, String
7200: 2e 46 6f 72 6d 61 74 28 0d 0a 20 20 20 20 20 20  .Format(..      
7210: 20 20 20 20 20 20 20 20 20 20 22 53 74 61 74 65            "State
7220: 6d 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74 65  ment {0} paramte
7230: 72 20 69 6e 64 65 78 20 6f 66 20 6e 61 6d 65 20  r index of name 
7240: 7b 7b 7b 31 7d 7d 7d 20 69 73 20 23 7b 32 7d 2e  {{{1}}} is #{2}.
7250: 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ",..            
7260: 20 20 20 20 68 61 6e 64 6c 65 49 6e 74 50 74 72      handleIntPtr
7270: 2c 20 70 61 72 61 6d 4e 61 6d 65 2c 20 69 6e 64  , paramName, ind
7280: 65 78 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d  ex));..        }
7290: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20  ..#endif....    
72a0: 20 20 20 20 72 65 74 75 72 6e 20 69 6e 64 65 78      return index
72b0: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
72c0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
72d0: 65 20 69 6e 74 20 43 6f 6c 75 6d 6e 43 6f 75 6e  e int ColumnCoun
72e0: 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  t(SQLiteStatemen
72f0: 74 20 73 74 6d 74 29 0d 0a 20 20 20 20 7b 0d 0a  t stmt)..    {..
7300: 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73        return Uns
7310: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
7320: 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  .sqlite3_column_
7330: 63 6f 75 6e 74 28 73 74 6d 74 2e 5f 73 71 6c 69  count(stmt._sqli
7340: 74 65 5f 73 74 6d 74 29 3b 0d 0a 20 20 20 20 7d  te_stmt);..    }
7350: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
7360: 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67   override string
7370: 20 43 6f 6c 75 6d 6e 4e 61 6d 65 28 53 51 4c 69   ColumnName(SQLi
7380: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
7390: 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20  , int index)..  
73a0: 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45    {..#if !SQLITE
73b0: 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20  _STANDARD..     
73c0: 20 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20   int len;..     
73d0: 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74   return UTF8ToSt
73e0: 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76  ring(UnsafeNativ
73f0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
7400: 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 5f 69 6e 74  _column_name_int
7410: 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74  erop(stmt._sqlit
7420: 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f  e_stmt, index, o
7430: 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a  ut len), len);..
7440: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 72 65 74  #else..      ret
7450: 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e 67  urn UTF8ToString
7460: 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74  (UnsafeNativeMet
7470: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c  hods.sqlite3_col
7480: 75 6d 6e 5f 6e 61 6d 65 28 73 74 6d 74 2e 5f 73  umn_name(stmt._s
7490: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
74a0: 78 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66  x), -1);..#endif
74b0: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
74c0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
74d0: 20 54 79 70 65 41 66 66 69 6e 69 74 79 20 43 6f   TypeAffinity Co
74e0: 6c 75 6d 6e 41 66 66 69 6e 69 74 79 28 53 51 4c  lumnAffinity(SQL
74f0: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
7500: 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20  t, int index).. 
7510: 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75     {..      retu
7520: 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  rn UnsafeNativeM
7530: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
7540: 6f 6c 75 6d 6e 5f 74 79 70 65 28 73 74 6d 74 2e  olumn_type(stmt.
7550: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e  _sqlite_stmt, in
7560: 64 65 78 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  dex);..    }....
7570: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
7580: 72 72 69 64 65 20 73 74 72 69 6e 67 20 43 6f 6c  rride string Col
7590: 75 6d 6e 54 79 70 65 28 53 51 4c 69 74 65 53 74  umnType(SQLiteSt
75a0: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
75b0: 74 20 69 6e 64 65 78 2c 20 6f 75 74 20 54 79 70  t index, out Typ
75c0: 65 41 66 66 69 6e 69 74 79 20 6e 41 66 66 69 6e  eAffinity nAffin
75d0: 69 74 79 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  ity)..    {..   
75e0: 20 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 23 69 66     int len;..#if
75f0: 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52   !SQLITE_STANDAR
7600: 44 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72 20  D..      IntPtr 
7610: 70 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  p = UnsafeNative
7620: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
7630: 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65 5f  column_decltype_
7640: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
7650: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
7660: 2c 20 6f 75 74 20 6c 65 6e 29 3b 0d 0a 23 65 6c  , out len);..#el
7670: 73 65 0d 0a 20 20 20 20 20 20 6c 65 6e 20 3d 20  se..      len = 
7680: 2d 31 3b 0d 0a 20 20 20 20 20 20 49 6e 74 50 74  -1;..      IntPt
7690: 72 20 70 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  r p = UnsafeNati
76a0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
76b0: 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70  3_column_decltyp
76c0: 65 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  e(stmt._sqlite_s
76d0: 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 23 65  tmt, index);..#e
76e0: 6e 64 69 66 0d 0a 20 20 20 20 20 20 6e 41 66 66  ndif..      nAff
76f0: 69 6e 69 74 79 20 3d 20 43 6f 6c 75 6d 6e 41 66  inity = ColumnAf
7700: 66 69 6e 69 74 79 28 73 74 6d 74 2c 20 69 6e 64  finity(stmt, ind
7710: 65 78 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66  ex);....      if
7720: 20 28 70 20 21 3d 20 49 6e 74 50 74 72 2e 5a 65   (p != IntPtr.Ze
7730: 72 6f 29 20 72 65 74 75 72 6e 20 55 54 46 38 54  ro) return UTF8T
7740: 6f 53 74 72 69 6e 67 28 70 2c 20 6c 65 6e 29 3b  oString(p, len);
7750: 0d 0a 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20  ..      else..  
7760: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 73      {..        s
7770: 74 72 69 6e 67 5b 5d 20 61 72 20 3d 20 73 74 6d  tring[] ar = stm
7780: 74 2e 54 79 70 65 44 65 66 69 6e 69 74 69 6f 6e  t.TypeDefinition
7790: 73 3b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  s;..        if (
77a0: 61 72 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20  ar != null)..   
77b0: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
77c0: 20 20 69 66 20 28 69 6e 64 65 78 20 3c 20 61 72    if (index < ar
77d0: 2e 4c 65 6e 67 74 68 20 26 26 20 61 72 5b 69 6e  .Length && ar[in
77e0: 64 65 78 5d 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20  dex] != null).. 
77f0: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
7800: 6e 20 61 72 5b 69 6e 64 65 78 5d 3b 0d 0a 20 20  n ar[index];..  
7810: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
7820: 20 72 65 74 75 72 6e 20 53 74 72 69 6e 67 2e 45   return String.E
7830: 6d 70 74 79 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  mpty;....       
7840: 20 2f 2f 73 77 69 74 63 68 20 28 6e 41 66 66 69   //switch (nAffi
7850: 6e 69 74 79 29 0d 0a 20 20 20 20 20 20 20 20 2f  nity)..        /
7860: 2f 7b 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20  /{..        //  
7870: 63 61 73 65 20 54 79 70 65 41 66 66 69 6e 69 74  case TypeAffinit
7880: 79 2e 49 6e 74 36 34 3a 0d 0a 20 20 20 20 20 20  y.Int64:..      
7890: 20 20 2f 2f 20 20 20 20 72 65 74 75 72 6e 20 22    //    return "
78a0: 42 49 47 49 4e 54 22 3b 0d 0a 20 20 20 20 20 20  BIGINT";..      
78b0: 20 20 2f 2f 20 20 63 61 73 65 20 54 79 70 65 41    //  case TypeA
78c0: 66 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65 3a 0d  ffinity.Double:.
78d0: 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 72  .        //    r
78e0: 65 74 75 72 6e 20 22 44 4f 55 42 4c 45 22 3b 0d  eturn "DOUBLE";.
78f0: 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 63 61 73  .        //  cas
7900: 65 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 42  e TypeAffinity.B
7910: 6c 6f 62 3a 0d 0a 20 20 20 20 20 20 20 20 2f 2f  lob:..        //
7920: 20 20 20 20 72 65 74 75 72 6e 20 22 42 4c 4f 42      return "BLOB
7930: 22 3b 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20  ";..        //  
7940: 64 65 66 61 75 6c 74 3a 0d 0a 20 20 20 20 20 20  default:..      
7950: 20 20 2f 2f 20 20 20 20 72 65 74 75 72 6e 20 22    //    return "
7960: 54 45 58 54 22 3b 0d 0a 20 20 20 20 20 20 20 20  TEXT";..        
7970: 2f 2f 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20  //}..      }..  
7980: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
7990: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
79a0: 20 43 6f 6c 75 6d 6e 49 6e 64 65 78 28 53 51 4c   ColumnIndex(SQL
79b0: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
79c0: 74 2c 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e  t, string column
79d0: 4e 61 6d 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  Name)..    {..  
79e0: 20 20 20 20 69 6e 74 20 78 20 3d 20 43 6f 6c 75      int x = Colu
79f0: 6d 6e 43 6f 75 6e 74 28 73 74 6d 74 29 3b 0d 0a  mnCount(stmt);..
7a00: 0d 0a 20 20 20 20 20 20 66 6f 72 20 28 69 6e 74  ..      for (int
7a10: 20 6e 20 3d 20 30 3b 20 6e 20 3c 20 78 3b 20 6e   n = 0; n < x; n
7a20: 2b 2b 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20  ++)..      {..  
7a30: 20 20 20 20 20 20 69 66 20 28 53 74 72 69 6e 67        if (String
7a40: 2e 43 6f 6d 70 61 72 65 28 63 6f 6c 75 6d 6e 4e  .Compare(columnN
7a50: 61 6d 65 2c 20 43 6f 6c 75 6d 6e 4e 61 6d 65 28  ame, ColumnName(
7a60: 73 74 6d 74 2c 20 6e 29 2c 20 53 74 72 69 6e 67  stmt, n), String
7a70: 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e  Comparison.Ordin
7a80: 61 6c 49 67 6e 6f 72 65 43 61 73 65 29 20 3d 3d  alIgnoreCase) ==
7a90: 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20 72   0)..          r
7aa0: 65 74 75 72 6e 20 6e 3b 0d 0a 20 20 20 20 20 20  eturn n;..      
7ab0: 7d 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  }..      return 
7ac0: 2d 31 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  -1;..    }....  
7ad0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
7ae0: 69 64 65 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d  ide string Colum
7af0: 6e 4f 72 69 67 69 6e 61 6c 4e 61 6d 65 28 53 51  nOriginalName(SQ
7b00: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74  LiteStatement st
7b10: 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a  mt, int index)..
7b20: 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49      {..#if !SQLI
7b30: 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20  TE_STANDARD..   
7b40: 20 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20     int len;..   
7b50: 20 20 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f     return UTF8To
7b60: 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74  String(UnsafeNat
7b70: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
7b80: 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69 6e  e3_column_origin
7b90: 5f 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74  _name_interop(st
7ba0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
7bb0: 20 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29   index, out len)
7bc0: 2c 20 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a  , len);..#else..
7bd0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 54 46        return UTF
7be0: 38 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65  8ToString(Unsafe
7bf0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
7c00: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69  lite3_column_ori
7c10: 67 69 6e 5f 6e 61 6d 65 28 73 74 6d 74 2e 5f 73  gin_name(stmt._s
7c20: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
7c30: 78 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66  x), -1);..#endif
7c40: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
7c50: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
7c60: 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 44 61   string ColumnDa
7c70: 74 61 62 61 73 65 4e 61 6d 65 28 53 51 4c 69 74  tabaseName(SQLit
7c80: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
7c90: 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20   int index)..   
7ca0: 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f   {..#if !SQLITE_
7cb0: 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20  STANDARD..      
7cc0: 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20  int len;..      
7cd0: 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72  return UTF8ToStr
7ce0: 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65  ing(UnsafeNative
7cf0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
7d00: 63 6f 6c 75 6d 6e 5f 64 61 74 61 62 61 73 65 5f  column_database_
7d10: 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d  name_interop(stm
7d20: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
7d30: 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c  index, out len),
7d40: 20 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20   len);..#else.. 
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 28 73 74 6d 74 2e 5f  base_name(stmt._
7da0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
7db0: 65 78 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69  ex), -1);..#endi
7dc0: 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  f..    }....    
7dd0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
7de0: 65 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 54  e string ColumnT
7df0: 61 62 6c 65 4e 61 6d 65 28 53 51 4c 69 74 65 53  ableName(SQLiteS
7e00: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
7e10: 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b  nt index)..    {
7e20: 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54  ..#if !SQLITE_ST
7e30: 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 69 6e  ANDARD..      in
7e40: 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 72 65  t len;..      re
7e50: 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e  turn UTF8ToStrin
7e60: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
7e70: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
7e80: 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65 5f  lumn_table_name_
7e90: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
7ea0: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
7eb0: 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29  , out len), len)
7ec0: 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20  ;..#else..      
7ed0: 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72  return UTF8ToStr
7ee0: 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65  ing(UnsafeNative
7ef0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
7f00: 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d  column_table_nam
7f10: 65 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  e(stmt._sqlite_s
7f20: 74 6d 74 2c 20 69 6e 64 65 78 29 2c 20 2d 31 29  tmt, index), -1)
7f30: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d  ;..#endif..    }
7f40: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
7f50: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 43   override void C
7f60: 6f 6c 75 6d 6e 4d 65 74 61 44 61 74 61 28 73 74  olumnMetaData(st
7f70: 72 69 6e 67 20 64 61 74 61 42 61 73 65 2c 20 73  ring dataBase, s
7f80: 74 72 69 6e 67 20 74 61 62 6c 65 2c 20 73 74 72  tring table, str
7f90: 69 6e 67 20 63 6f 6c 75 6d 6e 2c 20 6f 75 74 20  ing column, out 
7fa0: 73 74 72 69 6e 67 20 64 61 74 61 54 79 70 65 2c  string dataType,
7fb0: 20 6f 75 74 20 73 74 72 69 6e 67 20 63 6f 6c 6c   out string coll
7fc0: 61 74 65 53 65 71 75 65 6e 63 65 2c 20 6f 75 74  ateSequence, out
7fd0: 20 62 6f 6f 6c 20 6e 6f 74 4e 75 6c 6c 2c 20 6f   bool notNull, o
7fe0: 75 74 20 62 6f 6f 6c 20 70 72 69 6d 61 72 79 4b  ut bool primaryK
7ff0: 65 79 2c 20 6f 75 74 20 62 6f 6f 6c 20 61 75 74  ey, out bool aut
8000: 6f 49 6e 63 72 65 6d 65 6e 74 29 0d 0a 20 20 20  oIncrement)..   
8010: 20 7b 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72   {..      IntPtr
8020: 20 64 61 74 61 54 79 70 65 50 74 72 3b 0d 0a 20   dataTypePtr;.. 
8030: 20 20 20 20 20 49 6e 74 50 74 72 20 63 6f 6c 6c       IntPtr coll
8040: 53 65 71 50 74 72 3b 0d 0a 20 20 20 20 20 20 69  SeqPtr;..      i
8050: 6e 74 20 6e 6e 6f 74 4e 75 6c 6c 3b 0d 0a 20 20  nt nnotNull;..  
8060: 20 20 20 20 69 6e 74 20 6e 70 72 69 6d 61 72 79      int nprimary
8070: 4b 65 79 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20  Key;..      int 
8080: 6e 61 75 74 6f 49 6e 63 3b 0d 0a 20 20 20 20 20  nautoInc;..     
8090: 20 69 6e 74 20 6e 3b 0d 0a 20 20 20 20 20 20 69   int n;..      i
80a0: 6e 74 20 64 74 4c 65 6e 3b 0d 0a 20 20 20 20 20  nt dtLen;..     
80b0: 20 69 6e 74 20 63 73 4c 65 6e 3b 0d 0a 0d 0a 23   int csLen;....#
80c0: 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44  if !SQLITE_STAND
80d0: 41 52 44 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55  ARD..      n = U
80e0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
80f0: 64 73 2e 73 71 6c 69 74 65 33 5f 74 61 62 6c 65  ds.sqlite3_table
8100: 5f 63 6f 6c 75 6d 6e 5f 6d 65 74 61 64 61 74 61  _column_metadata
8110: 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54  _interop(_sql, T
8120: 6f 55 54 46 38 28 64 61 74 61 42 61 73 65 29 2c  oUTF8(dataBase),
8130: 20 54 6f 55 54 46 38 28 74 61 62 6c 65 29 2c 20   ToUTF8(table), 
8140: 54 6f 55 54 46 38 28 63 6f 6c 75 6d 6e 29 2c 20  ToUTF8(column), 
8150: 6f 75 74 20 64 61 74 61 54 79 70 65 50 74 72 2c  out dataTypePtr,
8160: 20 6f 75 74 20 63 6f 6c 6c 53 65 71 50 74 72 2c   out collSeqPtr,
8170: 20 6f 75 74 20 6e 6e 6f 74 4e 75 6c 6c 2c 20 6f   out nnotNull, o
8180: 75 74 20 6e 70 72 69 6d 61 72 79 4b 65 79 2c 20  ut nprimaryKey, 
8190: 6f 75 74 20 6e 61 75 74 6f 49 6e 63 2c 20 6f 75  out nautoInc, ou
81a0: 74 20 64 74 4c 65 6e 2c 20 6f 75 74 20 63 73 4c  t dtLen, out csL
81b0: 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20  en);..#else..   
81c0: 20 20 20 64 74 4c 65 6e 20 3d 20 2d 31 3b 0d 0a     dtLen = -1;..
81d0: 20 20 20 20 20 20 63 73 4c 65 6e 20 3d 20 2d 31        csLen = -1
81e0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55  ;....      n = U
81f0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
8200: 64 73 2e 73 71 6c 69 74 65 33 5f 74 61 62 6c 65  ds.sqlite3_table
8210: 5f 63 6f 6c 75 6d 6e 5f 6d 65 74 61 64 61 74 61  _column_metadata
8220: 28 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 64 61  (_sql, ToUTF8(da
8230: 74 61 42 61 73 65 29 2c 20 54 6f 55 54 46 38 28  taBase), ToUTF8(
8240: 74 61 62 6c 65 29 2c 20 54 6f 55 54 46 38 28 63  table), ToUTF8(c
8250: 6f 6c 75 6d 6e 29 2c 20 6f 75 74 20 64 61 74 61  olumn), out data
8260: 54 79 70 65 50 74 72 2c 20 6f 75 74 20 63 6f 6c  TypePtr, out col
8270: 6c 53 65 71 50 74 72 2c 20 6f 75 74 20 6e 6e 6f  lSeqPtr, out nno
8280: 74 4e 75 6c 6c 2c 20 6f 75 74 20 6e 70 72 69 6d  tNull, out nprim
8290: 61 72 79 4b 65 79 2c 20 6f 75 74 20 6e 61 75 74  aryKey, out naut
82a0: 6f 49 6e 63 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  oInc);..#endif..
82b0: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
82c0: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
82d0: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65  eException(n, Ge
82e0: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
82f0: 0d 0a 20 20 20 20 20 20 64 61 74 61 54 79 70 65  ..      dataType
8300: 20 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28   = UTF8ToString(
8310: 64 61 74 61 54 79 70 65 50 74 72 2c 20 64 74 4c  dataTypePtr, dtL
8320: 65 6e 29 3b 0d 0a 20 20 20 20 20 20 63 6f 6c 6c  en);..      coll
8330: 61 74 65 53 65 71 75 65 6e 63 65 20 3d 20 55 54  ateSequence = UT
8340: 46 38 54 6f 53 74 72 69 6e 67 28 63 6f 6c 6c 53  F8ToString(collS
8350: 65 71 50 74 72 2c 20 63 73 4c 65 6e 29 3b 0d 0a  eqPtr, csLen);..
8360: 0d 0a 20 20 20 20 20 20 6e 6f 74 4e 75 6c 6c 20  ..      notNull 
8370: 3d 20 28 6e 6e 6f 74 4e 75 6c 6c 20 3d 3d 20 31  = (nnotNull == 1
8380: 29 3b 0d 0a 20 20 20 20 20 20 70 72 69 6d 61 72  );..      primar
8390: 79 4b 65 79 20 3d 20 28 6e 70 72 69 6d 61 72 79  yKey = (nprimary
83a0: 4b 65 79 20 3d 3d 20 31 29 3b 0d 0a 20 20 20 20  Key == 1);..    
83b0: 20 20 61 75 74 6f 49 6e 63 72 65 6d 65 6e 74 20    autoIncrement 
83c0: 3d 20 28 6e 61 75 74 6f 49 6e 63 20 3d 3d 20 31  = (nautoInc == 1
83d0: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
83e0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
83f0: 64 65 20 64 6f 75 62 6c 65 20 47 65 74 44 6f 75  de double GetDou
8400: 62 6c 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d  ble(SQLiteStatem
8410: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
8420: 64 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  dex)..    {..   
8430: 20 20 20 64 6f 75 62 6c 65 20 76 61 6c 75 65 3b     double value;
8440: 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f  ..#if !PLATFORM_
8450: 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b  COMPACTFRAMEWORK
8460: 0d 0a 20 20 20 20 20 20 76 61 6c 75 65 20 3d 20  ..      value = 
8470: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
8480: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ods.sqlite3_colu
8490: 6d 6e 5f 64 6f 75 62 6c 65 28 73 74 6d 74 2e 5f  mn_double(stmt._
84a0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
84b0: 65 78 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20  ex);..#else..   
84c0: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
84d0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
84e0: 6f 6c 75 6d 6e 5f 64 6f 75 62 6c 65 5f 69 6e 74  olumn_double_int
84f0: 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74  erop(stmt._sqlit
8500: 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f  e_stmt, index, o
8510: 75 74 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64  ut value);..#end
8520: 69 66 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e  if..      return
8530: 20 76 61 6c 75 65 3b 0d 0a 20 20 20 20 7d 0d 0a   value;..    }..
8540: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
8550: 76 65 72 72 69 64 65 20 69 6e 74 20 47 65 74 49  verride int GetI
8560: 6e 74 33 32 28 53 51 4c 69 74 65 53 74 61 74 65  nt32(SQLiteState
8570: 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69  ment stmt, int i
8580: 6e 64 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  ndex)..    {..  
8590: 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66      return Unsaf
85a0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
85b0: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e  qlite3_column_in
85c0: 74 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  t(stmt._sqlite_s
85d0: 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20  tmt, index);..  
85e0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
85f0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e  nal override lon
8600: 67 20 47 65 74 49 6e 74 36 34 28 53 51 4c 69 74  g GetInt64(SQLit
8610: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
8620: 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20   int index)..   
8630: 20 7b 0d 0a 20 20 20 20 20 20 6c 6f 6e 67 20 76   {..      long v
8640: 61 6c 75 65 3b 0d 0a 23 69 66 20 21 50 4c 41 54  alue;..#if !PLAT
8650: 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d  FORM_COMPACTFRAM
8660: 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 76 61 6c  EWORK..      val
8670: 75 65 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76  ue = UnsafeNativ
8680: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
8690: 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 28 73 74  _column_int64(st
86a0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
86b0: 20 69 6e 64 65 78 29 3b 0d 0a 23 65 6c 73 65 0d   index);..#else.
86c0: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
86d0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
86e0: 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 5f  e3_column_int64_
86f0: 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71  interop(stmt._sq
8700: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
8710: 2c 20 6f 75 74 20 76 61 6c 75 65 29 3b 0d 0a 23  , out value);..#
8720: 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 72 65 74  endif..      ret
8730: 75 72 6e 20 76 61 6c 75 65 3b 0d 0a 20 20 20 20  urn value;..    
8740: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
8750: 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e  l override strin
8760: 67 20 47 65 74 54 65 78 74 28 53 51 4c 69 74 65  g GetText(SQLite
8770: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
8780: 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20  int index)..    
8790: 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53  {..#if !SQLITE_S
87a0: 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 69  TANDARD..      i
87b0: 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 72  nt len;..      r
87c0: 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69  eturn UTF8ToStri
87d0: 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  ng(UnsafeNativeM
87e0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
87f0: 6f 6c 75 6d 6e 5f 74 65 78 74 5f 69 6e 74 65 72  olumn_text_inter
8800: 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  op(stmt._sqlite_
8810: 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74  stmt, index, out
8820: 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23 65   len), len);..#e
8830: 6c 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75 72  lse..      retur
8840: 6e 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55  n UTF8ToString(U
8850: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
8860: 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  ds.sqlite3_colum
8870: 6e 5f 74 65 78 74 28 73 74 6d 74 2e 5f 73 71 6c  n_text(stmt._sql
8880: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29  ite_stmt, index)
8890: 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  , -1);..#endif..
88a0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
88b0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 44  ernal override D
88c0: 61 74 65 54 69 6d 65 20 47 65 74 44 61 74 65 54  ateTime GetDateT
88d0: 69 6d 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d  ime(SQLiteStatem
88e0: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
88f0: 64 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66  dex)..    {..#if
8900: 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52   !SQLITE_STANDAR
8910: 44 0d 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e  D..      int len
8920: 3b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ;..      return 
8930: 54 6f 44 61 74 65 54 69 6d 65 28 55 6e 73 61 66  ToDateTime(Unsaf
8940: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
8950: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65  qlite3_column_te
8960: 78 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  xt_interop(stmt.
8970: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e  _sqlite_stmt, in
8980: 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c  dex, out len), l
8990: 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20  en);..#else..   
89a0: 20 20 20 72 65 74 75 72 6e 20 54 6f 44 61 74 65     return ToDate
89b0: 54 69 6d 65 28 55 6e 73 61 66 65 4e 61 74 69 76  Time(UnsafeNativ
89c0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
89d0: 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 73 74 6d  _column_text(stm
89e0: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
89f0: 69 6e 64 65 78 29 2c 20 2d 31 29 3b 0d 0a 23 65  index), -1);..#e
8a00: 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ndif..    }.... 
8a10: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
8a20: 72 69 64 65 20 6c 6f 6e 67 20 47 65 74 42 79 74  ride long GetByt
8a30: 65 73 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  es(SQLiteStateme
8a40: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
8a50: 65 78 2c 20 69 6e 74 20 6e 44 61 74 61 4f 66 66  ex, int nDataOff
8a60: 73 65 74 2c 20 62 79 74 65 5b 5d 20 62 44 65 73  set, byte[] bDes
8a70: 74 2c 20 69 6e 74 20 6e 53 74 61 72 74 2c 20 69  t, int nStart, i
8a80: 6e 74 20 6e 4c 65 6e 67 74 68 29 0d 0a 20 20 20  nt nLength)..   
8a90: 20 7b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 6c   {..      int nl
8aa0: 65 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76  en = UnsafeNativ
8ab0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
8ac0: 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 28 73 74  _column_bytes(st
8ad0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c  mt._sqlite_stmt,
8ae0: 20 69 6e 64 65 78 29 3b 0d 0a 0d 0a 20 20 20 20   index);....    
8af0: 20 20 2f 2f 20 49 66 20 6e 6f 20 64 65 73 74 69    // If no desti
8b00: 6e 61 74 69 6f 6e 20 62 75 66 66 65 72 2c 20 72  nation buffer, r
8b10: 65 74 75 72 6e 20 74 68 65 20 73 69 7a 65 20 6e  eturn the size n
8b20: 65 65 64 65 64 2e 0d 0a 20 20 20 20 20 20 69 66  eeded...      if
8b30: 20 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c 29   (bDest == null)
8b40: 20 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0d 0a 0d   return nlen;...
8b50: 0a 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 70 69  .      int nCopi
8b60: 65 64 20 3d 20 6e 4c 65 6e 67 74 68 3b 0d 0a 0d  ed = nLength;...
8b70: 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69  .      if (nCopi
8b80: 65 64 20 2b 20 6e 53 74 61 72 74 20 3e 20 62 44  ed + nStart > bD
8b90: 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f 70  est.Length) nCop
8ba0: 69 65 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e 67  ied = bDest.Leng
8bb0: 74 68 20 2d 20 6e 53 74 61 72 74 3b 0d 0a 20 20  th - nStart;..  
8bc0: 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20      if (nCopied 
8bd0: 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e 20  + nDataOffset > 
8be0: 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d 20  nlen) nCopied = 
8bf0: 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66 73  nlen - nDataOffs
8c00: 65 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  et;....      if 
8c10: 28 6e 43 6f 70 69 65 64 20 3e 20 30 29 0d 0a 20  (nCopied > 0).. 
8c20: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
8c30: 49 6e 74 50 74 72 20 70 74 72 20 3d 20 55 6e 73  IntPtr ptr = Uns
8c40: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
8c50: 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  .sqlite3_column_
8c60: 62 6c 6f 62 28 73 74 6d 74 2e 5f 73 71 6c 69 74  blob(stmt._sqlit
8c70: 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d  e_stmt, index);.
8c80: 0a 0d 0a 20 20 20 20 20 20 20 20 4d 61 72 73 68  ...        Marsh
8c90: 61 6c 2e 43 6f 70 79 28 28 49 6e 74 50 74 72 29  al.Copy((IntPtr)
8ca0: 28 70 74 72 2e 54 6f 49 6e 74 36 34 28 29 20 2b  (ptr.ToInt64() +
8cb0: 20 6e 44 61 74 61 4f 66 66 73 65 74 29 2c 20 62   nDataOffset), b
8cc0: 44 65 73 74 2c 20 6e 53 74 61 72 74 2c 20 6e 43  Dest, nStart, nC
8cd0: 6f 70 69 65 64 29 3b 0d 0a 20 20 20 20 20 20 7d  opied);..      }
8ce0: 0d 0a 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20  ..      else..  
8cf0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 6e      {..        n
8d00: 43 6f 70 69 65 64 20 3d 20 30 3b 0d 0a 20 20 20  Copied = 0;..   
8d10: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 72 65     }....      re
8d20: 74 75 72 6e 20 6e 43 6f 70 69 65 64 3b 0d 0a 20  turn nCopied;.. 
8d30: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
8d40: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f  rnal override lo
8d50: 6e 67 20 47 65 74 43 68 61 72 73 28 53 51 4c 69  ng GetChars(SQLi
8d60: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
8d70: 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 69 6e 74  , int index, int
8d80: 20 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 63 68   nDataOffset, ch
8d90: 61 72 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20  ar[] bDest, int 
8da0: 6e 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e  nStart, int nLen
8db0: 67 74 68 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  gth)..    {..   
8dc0: 20 20 20 69 6e 74 20 6e 6c 65 6e 3b 0d 0a 20 20     int nlen;..  
8dd0: 20 20 20 20 69 6e 74 20 6e 43 6f 70 69 65 64 20      int nCopied 
8de0: 3d 20 6e 4c 65 6e 67 74 68 3b 0d 0a 0d 0a 20 20  = nLength;....  
8df0: 20 20 20 20 73 74 72 69 6e 67 20 73 74 72 20 3d      string str =
8e00: 20 47 65 74 54 65 78 74 28 73 74 6d 74 2c 20 69   GetText(stmt, i
8e10: 6e 64 65 78 29 3b 0d 0a 20 20 20 20 20 20 6e 6c  ndex);..      nl
8e20: 65 6e 20 3d 20 73 74 72 2e 4c 65 6e 67 74 68 3b  en = str.Length;
8e30: 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20 28 62 44  ....      if (bD
8e40: 65 73 74 20 3d 3d 20 6e 75 6c 6c 29 20 72 65 74  est == null) ret
8e50: 75 72 6e 20 6e 6c 65 6e 3b 0d 0a 0d 0a 20 20 20  urn nlen;....   
8e60: 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b     if (nCopied +
8e70: 20 6e 53 74 61 72 74 20 3e 20 62 44 65 73 74 2e   nStart > bDest.
8e80: 4c 65 6e 67 74 68 29 20 6e 43 6f 70 69 65 64 20  Length) nCopied 
8e90: 3d 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 20 2d  = bDest.Length -
8ea0: 20 6e 53 74 61 72 74 3b 0d 0a 20 20 20 20 20 20   nStart;..      
8eb0: 69 66 20 28 6e 43 6f 70 69 65 64 20 2b 20 6e 44  if (nCopied + nD
8ec0: 61 74 61 4f 66 66 73 65 74 20 3e 20 6e 6c 65 6e  ataOffset > nlen
8ed0: 29 20 6e 43 6f 70 69 65 64 20 3d 20 6e 6c 65 6e  ) nCopied = nlen
8ee0: 20 2d 20 6e 44 61 74 61 4f 66 66 73 65 74 3b 0d   - nDataOffset;.
8ef0: 0a 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f  ...      if (nCo
8f00: 70 69 65 64 20 3e 20 30 29 0d 0a 20 20 20 20 20  pied > 0)..     
8f10: 20 20 20 73 74 72 2e 43 6f 70 79 54 6f 28 6e 44     str.CopyTo(nD
8f20: 61 74 61 4f 66 66 73 65 74 2c 20 62 44 65 73 74  ataOffset, bDest
8f30: 2c 20 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69 65  , nStart, nCopie
8f40: 64 29 3b 0d 0a 20 20 20 20 20 20 65 6c 73 65 20  d);..      else 
8f50: 6e 43 6f 70 69 65 64 20 3d 20 30 3b 0d 0a 0d 0a  nCopied = 0;....
8f60: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f        return nCo
8f70: 70 69 65 64 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  pied;..    }....
8f80: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
8f90: 72 72 69 64 65 20 62 6f 6f 6c 20 49 73 4e 75 6c  rride bool IsNul
8fa0: 6c 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  l(SQLiteStatemen
8fb0: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
8fc0: 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  x)..    {..     
8fd0: 20 72 65 74 75 72 6e 20 28 43 6f 6c 75 6d 6e 41   return (ColumnA
8fe0: 66 66 69 6e 69 74 79 28 73 74 6d 74 2c 20 69 6e  ffinity(stmt, in
8ff0: 64 65 78 29 20 3d 3d 20 54 79 70 65 41 66 66 69  dex) == TypeAffi
9000: 6e 69 74 79 2e 4e 75 6c 6c 29 3b 0d 0a 20 20 20  nity.Null);..   
9010: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
9020: 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  al override int 
9030: 41 67 67 72 65 67 61 74 65 43 6f 75 6e 74 28 49  AggregateCount(I
9040: 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 29 0d 0a  ntPtr context)..
9050: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74      {..      ret
9060: 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65  urn UnsafeNative
9070: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
9080: 61 67 67 72 65 67 61 74 65 5f 63 6f 75 6e 74 28  aggregate_count(
9090: 63 6f 6e 74 65 78 74 29 3b 0d 0a 20 20 20 20 7d  context);..    }
90a0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
90b0: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 43   override void C
90c0: 72 65 61 74 65 46 75 6e 63 74 69 6f 6e 28 73 74  reateFunction(st
90d0: 72 69 6e 67 20 73 74 72 46 75 6e 63 74 69 6f 6e  ring strFunction
90e0: 2c 20 69 6e 74 20 6e 41 72 67 73 2c 20 62 6f 6f  , int nArgs, boo
90f0: 6c 20 6e 65 65 64 43 6f 6c 6c 53 65 71 2c 20 53  l needCollSeq, S
9100: 51 4c 69 74 65 43 61 6c 6c 62 61 63 6b 20 66 75  QLiteCallback fu
9110: 6e 63 2c 20 53 51 4c 69 74 65 43 61 6c 6c 62 61  nc, SQLiteCallba
9120: 63 6b 20 66 75 6e 63 73 74 65 70 2c 20 53 51 4c  ck funcstep, SQL
9130: 69 74 65 46 69 6e 61 6c 43 61 6c 6c 62 61 63 6b  iteFinalCallback
9140: 20 66 75 6e 63 66 69 6e 61 6c 29 0d 0a 20 20 20   funcfinal)..   
9150: 20 7b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b   {..      int n;
9160: 0d 0a 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f  ....#if !SQLITE_
9170: 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20  STANDARD..      
9180: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
9190: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
91a0: 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 5f  create_function_
91b0: 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f  interop(_sql, To
91c0: 55 54 46 38 28 73 74 72 46 75 6e 63 74 69 6f 6e  UTF8(strFunction
91d0: 29 2c 20 6e 41 72 67 73 2c 20 34 2c 20 49 6e 74  ), nArgs, 4, Int
91e0: 50 74 72 2e 5a 65 72 6f 2c 20 66 75 6e 63 2c 20  Ptr.Zero, func, 
91f0: 66 75 6e 63 73 74 65 70 2c 20 66 75 6e 63 66 69  funcstep, funcfi
9200: 6e 61 6c 2c 20 28 6e 65 65 64 43 6f 6c 6c 53 65  nal, (needCollSe
9210: 71 20 3d 3d 20 74 72 75 65 29 20 3f 20 31 20 3a  q == true) ? 1 :
9220: 20 30 29 3b 0d 0a 20 20 20 20 20 20 69 66 20 28   0);..      if (
9230: 6e 20 3d 3d 20 30 29 20 6e 20 3d 20 55 6e 73 61  n == 0) n = Unsa
9240: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
9250: 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 66  sqlite3_create_f
9260: 75 6e 63 74 69 6f 6e 5f 69 6e 74 65 72 6f 70 28  unction_interop(
9270: 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 73 74 72  _sql, ToUTF8(str
9280: 46 75 6e 63 74 69 6f 6e 29 2c 20 6e 41 72 67 73  Function), nArgs
9290: 2c 20 31 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f  , 1, IntPtr.Zero
92a0: 2c 20 66 75 6e 63 2c 20 66 75 6e 63 73 74 65 70  , func, funcstep
92b0: 2c 20 66 75 6e 63 66 69 6e 61 6c 2c 20 28 6e 65  , funcfinal, (ne
92c0: 65 64 43 6f 6c 6c 53 65 71 20 3d 3d 20 74 72 75  edCollSeq == tru
92d0: 65 29 20 3f 20 31 20 3a 20 30 29 3b 0d 0a 23 65  e) ? 1 : 0);..#e
92e0: 6c 73 65 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55  lse..      n = U
92f0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
9300: 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61 74  ds.sqlite3_creat
9310: 65 5f 66 75 6e 63 74 69 6f 6e 28 5f 73 71 6c 2c  e_function(_sql,
9320: 20 54 6f 55 54 46 38 28 73 74 72 46 75 6e 63 74   ToUTF8(strFunct
9330: 69 6f 6e 29 2c 20 6e 41 72 67 73 2c 20 34 2c 20  ion), nArgs, 4, 
9340: 49 6e 74 50 74 72 2e 5a 65 72 6f 2c 20 66 75 6e  IntPtr.Zero, fun
9350: 63 2c 20 66 75 6e 63 73 74 65 70 2c 20 66 75 6e  c, funcstep, fun
9360: 63 66 69 6e 61 6c 29 3b 0d 0a 20 20 20 20 20 20  cfinal);..      
9370: 69 66 20 28 6e 20 3d 3d 20 30 29 20 6e 20 3d 20  if (n == 0) n = 
9380: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
9390: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61  ods.sqlite3_crea
93a0: 74 65 5f 66 75 6e 63 74 69 6f 6e 28 5f 73 71 6c  te_function(_sql
93b0: 2c 20 54 6f 55 54 46 38 28 73 74 72 46 75 6e 63  , ToUTF8(strFunc
93c0: 74 69 6f 6e 29 2c 20 6e 41 72 67 73 2c 20 31 2c  tion), nArgs, 1,
93d0: 20 49 6e 74 50 74 72 2e 5a 65 72 6f 2c 20 66 75   IntPtr.Zero, fu
93e0: 6e 63 2c 20 66 75 6e 63 73 74 65 70 2c 20 66 75  nc, funcstep, fu
93f0: 6e 63 66 69 6e 61 6c 29 3b 0d 0a 23 65 6e 64 69  ncfinal);..#endi
9400: 66 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e  f..      if (n >
9410: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
9420: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
9430: 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29   GetLastError())
9440: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
9450: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
9460: 65 20 76 6f 69 64 20 43 72 65 61 74 65 43 6f 6c  e void CreateCol
9470: 6c 61 74 69 6f 6e 28 73 74 72 69 6e 67 20 73 74  lation(string st
9480: 72 43 6f 6c 6c 61 74 69 6f 6e 2c 20 53 51 4c 69  rCollation, SQLi
9490: 74 65 43 6f 6c 6c 61 74 69 6f 6e 20 66 75 6e 63  teCollation func
94a0: 2c 20 53 51 4c 69 74 65 43 6f 6c 6c 61 74 69 6f  , SQLiteCollatio
94b0: 6e 20 66 75 6e 63 31 36 29 0d 0a 20 20 20 20 7b  n func16)..    {
94c0: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  ..      int n = 
94d0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
94e0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61  ods.sqlite3_crea
94f0: 74 65 5f 63 6f 6c 6c 61 74 69 6f 6e 28 5f 73 71  te_collation(_sq
9500: 6c 2c 20 54 6f 55 54 46 38 28 73 74 72 43 6f 6c  l, ToUTF8(strCol
9510: 6c 61 74 69 6f 6e 29 2c 20 32 2c 20 49 6e 74 50  lation), 2, IntP
9520: 74 72 2e 5a 65 72 6f 2c 20 66 75 6e 63 31 36 29  tr.Zero, func16)
9530: 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3d  ;..      if (n =
9540: 3d 20 30 29 20 6e 20 3d 20 55 6e 73 61 66 65 4e  = 0) n = UnsafeN
9550: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
9560: 69 74 65 33 5f 63 72 65 61 74 65 5f 63 6f 6c 6c  ite3_create_coll
9570: 61 74 69 6f 6e 28 5f 73 71 6c 2c 20 54 6f 55 54  ation(_sql, ToUT
9580: 46 38 28 73 74 72 43 6f 6c 6c 61 74 69 6f 6e 29  F8(strCollation)
9590: 2c 20 31 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f  , 1, IntPtr.Zero
95a0: 2c 20 66 75 6e 63 29 3b 0d 0a 20 20 20 20 20 20  , func);..      
95b0: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
95c0: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
95d0: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
95e0: 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d  rror());..    }.
95f0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
9600: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 43 6f 6e  override int Con
9610: 74 65 78 74 43 6f 6c 6c 61 74 65 43 6f 6d 70 61  textCollateCompa
9620: 72 65 28 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f  re(CollationEnco
9630: 64 69 6e 67 45 6e 75 6d 20 65 6e 63 2c 20 49 6e  dingEnum enc, In
9640: 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20 73 74  tPtr context, st
9650: 72 69 6e 67 20 73 31 2c 20 73 74 72 69 6e 67 20  ring s1, string 
9660: 73 32 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20  s2)..    {..#if 
9670: 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44  !SQLITE_STANDARD
9680: 0d 0a 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62  ..      byte[] b
9690: 31 3b 0d 0a 20 20 20 20 20 20 62 79 74 65 5b 5d  1;..      byte[]
96a0: 20 62 32 3b 0d 0a 20 20 20 20 20 20 53 79 73 74   b2;..      Syst
96b0: 65 6d 2e 54 65 78 74 2e 45 6e 63 6f 64 69 6e 67  em.Text.Encoding
96c0: 20 63 6f 6e 76 65 72 74 65 72 20 3d 20 6e 75 6c   converter = nul
96d0: 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 73 77 69 74  l;....      swit
96e0: 63 68 20 28 65 6e 63 29 0d 0a 20 20 20 20 20 20  ch (enc)..      
96f0: 7b 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  {..        case 
9700: 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e  CollationEncodin
9710: 67 45 6e 75 6d 2e 55 54 46 38 3a 0d 0a 20 20 20  gEnum.UTF8:..   
9720: 20 20 20 20 20 20 20 63 6f 6e 76 65 72 74 65 72         converter
9730: 20 3d 20 53 79 73 74 65 6d 2e 54 65 78 74 2e 45   = System.Text.E
9740: 6e 63 6f 64 69 6e 67 2e 55 54 46 38 3b 0d 0a 20  ncoding.UTF8;.. 
9750: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d           break;.
9760: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 43 6f  .        case Co
9770: 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67 45  llationEncodingE
9780: 6e 75 6d 2e 55 54 46 31 36 4c 45 3a 0d 0a 20 20  num.UTF16LE:..  
9790: 20 20 20 20 20 20 20 20 63 6f 6e 76 65 72 74 65          converte
97a0: 72 20 3d 20 53 79 73 74 65 6d 2e 54 65 78 74 2e  r = System.Text.
97b0: 45 6e 63 6f 64 69 6e 67 2e 55 6e 69 63 6f 64 65  Encoding.Unicode
97c0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 62 72 65  ;..          bre
97d0: 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73  ak;..        cas
97e0: 65 20 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64  e CollationEncod
97f0: 69 6e 67 45 6e 75 6d 2e 55 54 46 31 36 42 45 3a  ingEnum.UTF16BE:
9800: 0d 0a 20 20 20 20 20 20 20 20 20 20 63 6f 6e 76  ..          conv
9810: 65 72 74 65 72 20 3d 20 53 79 73 74 65 6d 2e 54  erter = System.T
9820: 65 78 74 2e 45 6e 63 6f 64 69 6e 67 2e 42 69 67  ext.Encoding.Big
9830: 45 6e 64 69 61 6e 55 6e 69 63 6f 64 65 3b 0d 0a  EndianUnicode;..
9840: 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b            break;
9850: 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  ..      }....   
9860: 20 20 20 62 31 20 3d 20 63 6f 6e 76 65 72 74 65     b1 = converte
9870: 72 2e 47 65 74 42 79 74 65 73 28 73 31 29 3b 0d  r.GetBytes(s1);.
9880: 0a 20 20 20 20 20 20 62 32 20 3d 20 63 6f 6e 76  .      b2 = conv
9890: 65 72 74 65 72 2e 47 65 74 42 79 74 65 73 28 73  erter.GetBytes(s
98a0: 32 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74  2);....      ret
98b0: 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65  urn UnsafeNative
98c0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
98d0: 63 6f 6e 74 65 78 74 5f 63 6f 6c 6c 63 6f 6d 70  context_collcomp
98e0: 61 72 65 28 63 6f 6e 74 65 78 74 2c 20 62 31 2c  are(context, b1,
98f0: 20 62 31 2e 4c 65 6e 67 74 68 2c 20 62 32 2c 20   b1.Length, b2, 
9900: 62 32 2e 4c 65 6e 67 74 68 29 3b 0d 0a 23 65 6c  b2.Length);..#el
9910: 73 65 0d 0a 20 20 20 20 20 20 74 68 72 6f 77 20  se..      throw 
9920: 6e 65 77 20 4e 6f 74 49 6d 70 6c 65 6d 65 6e 74  new NotImplement
9930: 65 64 45 78 63 65 70 74 69 6f 6e 28 29 3b 0d 0a  edException();..
9940: 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d  #endif..    }...
9950: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
9960: 65 72 72 69 64 65 20 69 6e 74 20 43 6f 6e 74 65  erride int Conte
9970: 78 74 43 6f 6c 6c 61 74 65 43 6f 6d 70 61 72 65  xtCollateCompare
9980: 28 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69  (CollationEncodi
9990: 6e 67 45 6e 75 6d 20 65 6e 63 2c 20 49 6e 74 50  ngEnum enc, IntP
99a0: 74 72 20 63 6f 6e 74 65 78 74 2c 20 63 68 61 72  tr context, char
99b0: 5b 5d 20 63 31 2c 20 63 68 61 72 5b 5d 20 63 32  [] c1, char[] c2
99c0: 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53  )..    {..#if !S
99d0: 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a  QLITE_STANDARD..
99e0: 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62 31 3b        byte[] b1;
99f0: 0d 0a 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62  ..      byte[] b
9a00: 32 3b 0d 0a 20 20 20 20 20 20 53 79 73 74 65 6d  2;..      System
9a10: 2e 54 65 78 74 2e 45 6e 63 6f 64 69 6e 67 20 63  .Text.Encoding c
9a20: 6f 6e 76 65 72 74 65 72 20 3d 20 6e 75 6c 6c 3b  onverter = null;
9a30: 0d 0a 0d 0a 20 20 20 20 20 20 73 77 69 74 63 68  ....      switch
9a40: 20 28 65 6e 63 29 0d 0a 20 20 20 20 20 20 7b 0d   (enc)..      {.
9a50: 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 43 6f  .        case Co
9a60: 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67 45  llationEncodingE
9a70: 6e 75 6d 2e 55 54 46 38 3a 0d 0a 20 20 20 20 20  num.UTF8:..     
9a80: 20 20 20 20 20 63 6f 6e 76 65 72 74 65 72 20 3d       converter =
9a90: 20 53 79 73 74 65 6d 2e 54 65 78 74 2e 45 6e 63   System.Text.Enc
9aa0: 6f 64 69 6e 67 2e 55 54 46 38 3b 0d 0a 20 20 20  oding.UTF8;..   
9ab0: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20         break;.. 
9ac0: 20 20 20 20 20 20 20 63 61 73 65 20 43 6f 6c 6c         case Coll
9ad0: 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67 45 6e 75  ationEncodingEnu
9ae0: 6d 2e 55 54 46 31 36 4c 45 3a 0d 0a 20 20 20 20  m.UTF16LE:..    
9af0: 20 20 20 20 20 20 63 6f 6e 76 65 72 74 65 72 20        converter 
9b00: 3d 20 53 79 73 74 65 6d 2e 54 65 78 74 2e 45 6e  = System.Text.En
9b10: 63 6f 64 69 6e 67 2e 55 6e 69 63 6f 64 65 3b 0d  coding.Unicode;.
9b20: 0a 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b  .          break
9b30: 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  ;..        case 
9b40: 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e  CollationEncodin
9b50: 67 45 6e 75 6d 2e 55 54 46 31 36 42 45 3a 0d 0a  gEnum.UTF16BE:..
9b60: 20 20 20 20 20 20 20 20 20 20 63 6f 6e 76 65 72            conver
9b70: 74 65 72 20 3d 20 53 79 73 74 65 6d 2e 54 65 78  ter = System.Tex
9b80: 74 2e 45 6e 63 6f 64 69 6e 67 2e 42 69 67 45 6e  t.Encoding.BigEn
9b90: 64 69 61 6e 55 6e 69 63 6f 64 65 3b 0d 0a 20 20  dianUnicode;..  
9ba0: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a          break;..
9bb0: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
9bc0: 20 62 31 20 3d 20 63 6f 6e 76 65 72 74 65 72 2e   b1 = converter.
9bd0: 47 65 74 42 79 74 65 73 28 63 31 29 3b 0d 0a 20  GetBytes(c1);.. 
9be0: 20 20 20 20 20 62 32 20 3d 20 63 6f 6e 76 65 72       b2 = conver
9bf0: 74 65 72 2e 47 65 74 42 79 74 65 73 28 63 32 29  ter.GetBytes(c2)
9c00: 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72  ;....      retur
9c10: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
9c20: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
9c30: 6e 74 65 78 74 5f 63 6f 6c 6c 63 6f 6d 70 61 72  ntext_collcompar
9c40: 65 28 63 6f 6e 74 65 78 74 2c 20 62 31 2c 20 62  e(context, b1, b
9c50: 31 2e 4c 65 6e 67 74 68 2c 20 62 32 2c 20 62 32  1.Length, b2, b2
9c60: 2e 4c 65 6e 67 74 68 29 3b 0d 0a 23 65 6c 73 65  .Length);..#else
9c70: 0d 0a 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65  ..      throw ne
9c80: 77 20 4e 6f 74 49 6d 70 6c 65 6d 65 6e 74 65 64  w NotImplemented
9c90: 45 78 63 65 70 74 69 6f 6e 28 29 3b 0d 0a 23 65  Exception();..#e
9ca0: 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ndif..    }.... 
9cb0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
9cc0: 72 69 64 65 20 43 6f 6c 6c 61 74 69 6f 6e 53 65  ride CollationSe
9cd0: 71 75 65 6e 63 65 20 47 65 74 43 6f 6c 6c 61 74  quence GetCollat
9ce0: 69 6f 6e 53 65 71 75 65 6e 63 65 28 53 51 4c 69  ionSequence(SQLi
9cf0: 74 65 46 75 6e 63 74 69 6f 6e 20 66 75 6e 63 2c  teFunction func,
9d00: 20 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 29   IntPtr context)
9d10: 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51  ..    {..#if !SQ
9d20: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
9d30: 20 20 20 20 20 43 6f 6c 6c 61 74 69 6f 6e 53 65       CollationSe
9d40: 71 75 65 6e 63 65 20 73 65 71 20 3d 20 6e 65 77  quence seq = new
9d50: 20 43 6f 6c 6c 61 74 69 6f 6e 53 65 71 75 65 6e   CollationSequen
9d60: 63 65 28 29 3b 0d 0a 20 20 20 20 20 20 69 6e 74  ce();..      int
9d70: 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 69 6e 74   len;..      int
9d80: 20 74 79 70 65 3b 0d 0a 20 20 20 20 20 20 69 6e   type;..      in
9d90: 74 20 65 6e 63 3b 0d 0a 20 20 20 20 20 20 49 6e  t enc;..      In
9da0: 74 50 74 72 20 70 20 3d 20 55 6e 73 61 66 65 4e  tPtr p = UnsafeN
9db0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
9dc0: 69 74 65 33 5f 63 6f 6e 74 65 78 74 5f 63 6f 6c  ite3_context_col
9dd0: 6c 73 65 71 28 63 6f 6e 74 65 78 74 2c 20 6f 75  lseq(context, ou
9de0: 74 20 74 79 70 65 2c 20 6f 75 74 20 65 6e 63 2c  t type, out enc,
9df0: 20 6f 75 74 20 6c 65 6e 29 3b 0d 0a 0d 0a 20 20   out len);....  
9e00: 20 20 20 20 69 66 20 28 70 20 21 3d 20 6e 75 6c      if (p != nul
9e10: 6c 29 20 73 65 71 2e 4e 61 6d 65 20 3d 20 55 54  l) seq.Name = UT
9e20: 46 38 54 6f 53 74 72 69 6e 67 28 70 2c 20 6c 65  F8ToString(p, le
9e30: 6e 29 3b 0d 0a 20 20 20 20 20 20 73 65 71 2e 54  n);..      seq.T
9e40: 79 70 65 20 3d 20 28 43 6f 6c 6c 61 74 69 6f 6e  ype = (Collation
9e50: 54 79 70 65 45 6e 75 6d 29 74 79 70 65 3b 0d 0a  TypeEnum)type;..
9e60: 20 20 20 20 20 20 73 65 71 2e 5f 66 75 6e 63 20        seq._func 
9e70: 3d 20 66 75 6e 63 3b 0d 0a 20 20 20 20 20 20 73  = func;..      s
9e80: 65 71 2e 45 6e 63 6f 64 69 6e 67 20 3d 20 28 43  eq.Encoding = (C
9e90: 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67  ollationEncoding
9ea0: 45 6e 75 6d 29 65 6e 63 3b 0d 0a 0d 0a 20 20 20  Enum)enc;....   
9eb0: 20 20 20 72 65 74 75 72 6e 20 73 65 71 3b 0d 0a     return seq;..
9ec0: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 74 68 72  #else..      thr
9ed0: 6f 77 20 6e 65 77 20 4e 6f 74 49 6d 70 6c 65 6d  ow new NotImplem
9ee0: 65 6e 74 65 64 45 78 63 65 70 74 69 6f 6e 28 29  entedException()
9ef0: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d  ;..#endif..    }
9f00: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
9f10: 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47   override long G
9f20: 65 74 50 61 72 61 6d 56 61 6c 75 65 42 79 74 65  etParamValueByte
9f30: 73 28 49 6e 74 50 74 72 20 70 2c 20 69 6e 74 20  s(IntPtr p, int 
9f40: 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 62 79 74  nDataOffset, byt
9f50: 65 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20 6e  e[] bDest, int n
9f60: 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e 67  Start, int nLeng
9f70: 74 68 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  th)..    {..    
9f80: 20 20 69 6e 74 20 6e 6c 65 6e 20 3d 20 55 6e 73    int nlen = Uns
9f90: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
9fa0: 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62  .sqlite3_value_b
9fb0: 79 74 65 73 28 70 29 3b 0d 0a 0d 0a 20 20 20 20  ytes(p);....    
9fc0: 20 20 2f 2f 20 49 66 20 6e 6f 20 64 65 73 74 69    // If no desti
9fd0: 6e 61 74 69 6f 6e 20 62 75 66 66 65 72 2c 20 72  nation buffer, r
9fe0: 65 74 75 72 6e 20 74 68 65 20 73 69 7a 65 20 6e  eturn the size n
9ff0: 65 65 64 65 64 2e 0d 0a 20 20 20 20 20 20 69 66  eeded...      if
a000: 20 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c 29   (bDest == null)
a010: 20 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0d 0a 0d   return nlen;...
a020: 0a 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 70 69  .      int nCopi
a030: 65 64 20 3d 20 6e 4c 65 6e 67 74 68 3b 0d 0a 0d  ed = nLength;...
a040: 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69  .      if (nCopi
a050: 65 64 20 2b 20 6e 53 74 61 72 74 20 3e 20 62 44  ed + nStart > bD
a060: 65 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f 70  est.Length) nCop
a070: 69 65 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e 67  ied = bDest.Leng
a080: 74 68 20 2d 20 6e 53 74 61 72 74 3b 0d 0a 20 20  th - nStart;..  
a090: 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20      if (nCopied 
a0a0: 2b 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e 20  + nDataOffset > 
a0b0: 6e 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d 20  nlen) nCopied = 
a0c0: 6e 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66 73  nlen - nDataOffs
a0d0: 65 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  et;....      if 
a0e0: 28 6e 43 6f 70 69 65 64 20 3e 20 30 29 0d 0a 20  (nCopied > 0).. 
a0f0: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
a100: 49 6e 74 50 74 72 20 70 74 72 20 3d 20 55 6e 73  IntPtr ptr = Uns
a110: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
a120: 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62  .sqlite3_value_b
a130: 6c 6f 62 28 70 29 3b 0d 0a 0d 0a 20 20 20 20 20  lob(p);....     
a140: 20 20 20 4d 61 72 73 68 61 6c 2e 43 6f 70 79 28     Marshal.Copy(
a150: 28 49 6e 74 50 74 72 29 28 70 74 72 2e 54 6f 49  (IntPtr)(ptr.ToI
a160: 6e 74 36 34 28 29 20 2b 20 6e 44 61 74 61 4f 66  nt64() + nDataOf
a170: 66 73 65 74 29 2c 20 62 44 65 73 74 2c 20 6e 53  fset), bDest, nS
a180: 74 61 72 74 2c 20 6e 43 6f 70 69 65 64 29 3b 0d  tart, nCopied);.
a190: 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20  .      }..      
a1a0: 65 6c 73 65 0d 0a 20 20 20 20 20 20 7b 0d 0a 20  else..      {.. 
a1b0: 20 20 20 20 20 20 20 6e 43 6f 70 69 65 64 20 3d         nCopied =
a1c0: 20 30 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a   0;..      }....
a1d0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f        return nCo
a1e0: 70 69 65 64 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  pied;..    }....
a1f0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
a200: 72 72 69 64 65 20 64 6f 75 62 6c 65 20 47 65 74  rride double Get
a210: 50 61 72 61 6d 56 61 6c 75 65 44 6f 75 62 6c 65  ParamValueDouble
a220: 28 49 6e 74 50 74 72 20 70 74 72 29 0d 0a 20 20  (IntPtr ptr)..  
a230: 20 20 7b 0d 0a 20 20 20 20 20 20 64 6f 75 62 6c    {..      doubl
a240: 65 20 76 61 6c 75 65 3b 0d 0a 23 69 66 20 21 50  e value;..#if !P
a250: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
a260: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20  RAMEWORK..      
a270: 76 61 6c 75 65 20 3d 20 55 6e 73 61 66 65 4e 61  value = UnsafeNa
a280: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
a290: 74 65 33 5f 76 61 6c 75 65 5f 64 6f 75 62 6c 65  te3_value_double
a2a0: 28 70 74 72 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20  (ptr);..#else.. 
a2b0: 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76       UnsafeNativ
a2c0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
a2d0: 5f 76 61 6c 75 65 5f 64 6f 75 62 6c 65 5f 69 6e  _value_double_in
a2e0: 74 65 72 6f 70 28 70 74 72 2c 20 6f 75 74 20 76  terop(ptr, out v
a2f0: 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  alue);..#endif..
a300: 20 20 20 20 20 20 72 65 74 75 72 6e 20 76 61 6c        return val
a310: 75 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  ue;..    }....  
a320: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
a330: 69 64 65 20 69 6e 74 20 47 65 74 50 61 72 61 6d  ide int GetParam
a340: 56 61 6c 75 65 49 6e 74 33 32 28 49 6e 74 50 74  ValueInt32(IntPt
a350: 72 20 70 74 72 29 0d 0a 20 20 20 20 7b 0d 0a 20  r ptr)..    {.. 
a360: 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61       return Unsa
a370: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
a380: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e  sqlite3_value_in
a390: 74 28 70 74 72 29 3b 0d 0a 20 20 20 20 7d 0d 0a  t(ptr);..    }..
a3a0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
a3b0: 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47 65 74  verride long Get
a3c0: 50 61 72 61 6d 56 61 6c 75 65 49 6e 74 36 34 28  ParamValueInt64(
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 49 6e 74 36 34 20   {..      Int64 
a3f0: 76 61 6c 75 65 3b 0d 0a 23 69 66 20 21 50 4c 41  value;..#if !PLA
a400: 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41  TFORM_COMPACTFRA
a410: 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 76 61  MEWORK..      va
a420: 6c 75 65 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  lue = UnsafeNati
a430: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
a440: 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 28 70 74  3_value_int64(pt
a450: 72 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  r);..#else..    
a460: 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65    UnsafeNativeMe
a470: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
a480: 6c 75 65 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f  lue_int64_intero
a490: 70 28 70 74 72 2c 20 6f 75 74 20 76 61 6c 75 65  p(ptr, out value
a4a0: 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20  );..#endif..    
a4b0: 20 20 72 65 74 75 72 6e 20 76 61 6c 75 65 3b 0d    return value;.
a4c0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
a4d0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
a4e0: 73 74 72 69 6e 67 20 47 65 74 50 61 72 61 6d 56  string GetParamV
a4f0: 61 6c 75 65 54 65 78 74 28 49 6e 74 50 74 72 20  alueText(IntPtr 
a500: 70 74 72 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66  ptr)..    {..#if
a510: 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52   !SQLITE_STANDAR
a520: 44 0d 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e  D..      int len
a530: 3b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ;..      return 
a540: 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55 6e 73  UTF8ToString(Uns
a550: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
a560: 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74  .sqlite3_value_t
a570: 65 78 74 5f 69 6e 74 65 72 6f 70 28 70 74 72 2c  ext_interop(ptr,
a580: 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b   out len), len);
a590: 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 72  ..#else..      r
a5a0: 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69  eturn UTF8ToStri
a5b0: 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  ng(UnsafeNativeM
a5c0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76  ethods.sqlite3_v
a5d0: 61 6c 75 65 5f 74 65 78 74 28 70 74 72 29 2c 20  alue_text(ptr), 
a5e0: 2d 31 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20  -1);..#endif..  
a5f0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
a600: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 54 79 70  nal override Typ
a610: 65 41 66 66 69 6e 69 74 79 20 47 65 74 50 61 72  eAffinity GetPar
a620: 61 6d 56 61 6c 75 65 54 79 70 65 28 49 6e 74 50  amValueType(IntP
a630: 74 72 20 70 74 72 29 0d 0a 20 20 20 20 7b 0d 0a  tr ptr)..    {..
a640: 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73        return Uns
a650: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
a660: 2e 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74  .sqlite3_value_t
a670: 79 70 65 28 70 74 72 29 3b 0d 0a 20 20 20 20 7d  ype(ptr);..    }
a680: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
a690: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 52   override void R
a6a0: 65 74 75 72 6e 42 6c 6f 62 28 49 6e 74 50 74 72  eturnBlob(IntPtr
a6b0: 20 63 6f 6e 74 65 78 74 2c 20 62 79 74 65 5b 5d   context, byte[]
a6c0: 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a   value)..    {..
a6d0: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
a6e0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
a6f0: 33 5f 72 65 73 75 6c 74 5f 62 6c 6f 62 28 63 6f  3_result_blob(co
a700: 6e 74 65 78 74 2c 20 76 61 6c 75 65 2c 20 76 61  ntext, value, va
a710: 6c 75 65 2e 4c 65 6e 67 74 68 2c 20 28 49 6e 74  lue.Length, (Int
a720: 50 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20  Ptr)(-1));..    
a730: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
a740: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
a750: 52 65 74 75 72 6e 44 6f 75 62 6c 65 28 49 6e 74  ReturnDouble(Int
a760: 50 74 72 20 63 6f 6e 74 65 78 74 2c 20 64 6f 75  Ptr context, dou
a770: 62 6c 65 20 76 61 6c 75 65 29 0d 0a 20 20 20 20  ble value)..    
a780: 7b 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d  {..#if !PLATFORM
a790: 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52  _COMPACTFRAMEWOR
a7a0: 4b 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e  K..      UnsafeN
a7b0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
a7c0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62  ite3_result_doub
a7d0: 6c 65 28 63 6f 6e 74 65 78 74 2c 20 76 61 6c 75  le(context, valu
a7e0: 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  e);..#else..    
a7f0: 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65    UnsafeNativeMe
a800: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65  thods.sqlite3_re
a810: 73 75 6c 74 5f 64 6f 75 62 6c 65 5f 69 6e 74 65  sult_double_inte
a820: 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20 72 65 66  rop(context, ref
a830: 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66   value);..#endif
a840: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
a850: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
a860: 20 76 6f 69 64 20 52 65 74 75 72 6e 45 72 72 6f   void ReturnErro
a870: 72 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74  r(IntPtr context
a880: 2c 20 73 74 72 69 6e 67 20 76 61 6c 75 65 29 0d  , string value).
a890: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e  .    {..      Un
a8a0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
a8b0: 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74  s.sqlite3_result
a8c0: 5f 65 72 72 6f 72 28 63 6f 6e 74 65 78 74 2c 20  _error(context, 
a8d0: 54 6f 55 54 46 38 28 76 61 6c 75 65 29 2c 20 76  ToUTF8(value), v
a8e0: 61 6c 75 65 2e 4c 65 6e 67 74 68 29 3b 0d 0a 20  alue.Length);.. 
a8f0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
a900: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f  rnal override vo
a910: 69 64 20 52 65 74 75 72 6e 49 6e 74 33 32 28 49  id ReturnInt32(I
a920: 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20 69  ntPtr context, i
a930: 6e 74 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b  nt value)..    {
a940: 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  ..      UnsafeNa
a950: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
a960: 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 28 63  te3_result_int(c
a970: 6f 6e 74 65 78 74 2c 20 76 61 6c 75 65 29 3b 0d  ontext, value);.
a980: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
a990: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
a9a0: 76 6f 69 64 20 52 65 74 75 72 6e 49 6e 74 36 34  void ReturnInt64
a9b0: 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c  (IntPtr context,
a9c0: 20 6c 6f 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20   long value)..  
a9d0: 20 20 7b 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f    {..#if !PLATFO
a9e0: 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57  RM_COMPACTFRAMEW
a9f0: 4f 52 4b 0d 0a 20 20 20 20 20 20 55 6e 73 61 66  ORK..      Unsaf
aa00: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
aa10: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e  qlite3_result_in
aa20: 74 36 34 28 63 6f 6e 74 65 78 74 2c 20 76 61 6c  t64(context, val
aa30: 75 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20  ue);..#else..   
aa40: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
aa50: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72  ethods.sqlite3_r
aa60: 65 73 75 6c 74 5f 69 6e 74 36 34 5f 69 6e 74 65  esult_int64_inte
aa70: 72 6f 70 28 63 6f 6e 74 65 78 74 2c 20 72 65 66  rop(context, ref
aa80: 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66   value);..#endif
aa90: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
aaa0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
aab0: 20 76 6f 69 64 20 52 65 74 75 72 6e 4e 75 6c 6c   void ReturnNull
aac0: 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 29  (IntPtr context)
aad0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55  ..    {..      U
aae0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
aaf0: 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  ds.sqlite3_resul
ab00: 74 5f 6e 75 6c 6c 28 63 6f 6e 74 65 78 74 29 3b  t_null(context);
ab10: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
ab20: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
ab30: 20 76 6f 69 64 20 52 65 74 75 72 6e 54 65 78 74   void ReturnText
ab40: 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c  (IntPtr context,
ab50: 20 73 74 72 69 6e 67 20 76 61 6c 75 65 29 0d 0a   string value)..
ab60: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 62 79 74      {..      byt
ab70: 65 5b 5d 20 62 20 3d 20 54 6f 55 54 46 38 28 76  e[] b = ToUTF8(v
ab80: 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 55 6e  alue);..      Un
ab90: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
aba0: 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74  s.sqlite3_result
abb0: 5f 74 65 78 74 28 63 6f 6e 74 65 78 74 2c 20 54  _text(context, T
abc0: 6f 55 54 46 38 28 76 61 6c 75 65 29 2c 20 62 2e  oUTF8(value), b.
abd0: 4c 65 6e 67 74 68 20 2d 20 31 2c 20 28 49 6e 74  Length - 1, (Int
abe0: 50 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20  Ptr)(-1));..    
abf0: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
ac00: 6c 20 6f 76 65 72 72 69 64 65 20 49 6e 74 50 74  l override IntPt
ac10: 72 20 41 67 67 72 65 67 61 74 65 43 6f 6e 74 65  r AggregateConte
ac20: 78 74 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78  xt(IntPtr contex
ac30: 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  t)..    {..     
ac40: 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61   return UnsafeNa
ac50: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
ac60: 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f  te3_aggregate_co
ac70: 6e 74 65 78 74 28 63 6f 6e 74 65 78 74 2c 20 31  ntext(context, 1
ac80: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
ac90: 20 2f 2f 2f 20 45 6e 61 62 6c 65 73 20 6f 72 20   /// Enables or 
aca0: 64 69 73 61 62 6c 65 64 20 65 78 74 65 6e 64 65  disabled extende
acb0: 64 20 72 65 73 75 6c 74 20 63 6f 64 65 73 20 72  d result codes r
acc0: 65 74 75 72 6e 65 64 20 62 79 20 53 51 4c 69 74  eturned by SQLit
acd0: 65 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  e..    internal 
ace0: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 53 65  override void Se
acf0: 74 45 78 74 65 6e 64 65 64 52 65 73 75 6c 74 43  tExtendedResultC
ad00: 6f 64 65 73 28 62 6f 6f 6c 20 62 4f 6e 4f 66 66  odes(bool bOnOff
ad10: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
ad20: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
ad30: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 65 78 74 65  ods.sqlite3_exte
ad40: 6e 64 65 64 5f 72 65 73 75 6c 74 5f 63 6f 64 65  nded_result_code
ad50: 73 28 5f 73 71 6c 2c 20 28 62 4f 6e 4f 66 66 20  s(_sql, (bOnOff 
ad60: 3f 20 2d 31 20 3a 20 30 29 29 3b 0d 0a 20 20 20  ? -1 : 0));..   
ad70: 20 7d 0d 0a 20 20 20 20 2f 2f 2f 20 47 65 74 73   }..    /// Gets
ad80: 20 74 68 65 20 6c 61 73 74 20 53 51 4c 69 74 65   the last SQLite
ad90: 20 65 72 72 6f 72 20 63 6f 64 65 0d 0a 20 20 20   error code..   
ada0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
adb0: 64 65 20 69 6e 74 20 52 65 73 75 6c 74 43 6f 64  de int ResultCod
adc0: 65 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  e()..    {..    
add0: 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e    return UnsafeN
ade0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
adf0: 69 74 65 33 5f 65 72 72 63 6f 64 65 28 5f 73 71  ite3_errcode(_sq
ae00: 6c 29 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20  l);..    }..    
ae10: 2f 2f 2f 20 47 65 74 73 20 74 68 65 20 6c 61 73  /// Gets the las
ae20: 74 20 53 51 4c 69 74 65 20 65 78 74 65 6e 64 65  t SQLite extende
ae30: 64 20 65 72 72 6f 72 20 63 6f 64 65 0d 0a 20 20  d error code..  
ae40: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
ae50: 69 64 65 20 69 6e 74 20 45 78 74 65 6e 64 65 64  ide int Extended
ae60: 52 65 73 75 6c 74 43 6f 64 65 28 29 0d 0a 20 20  ResultCode()..  
ae70: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72    {..      retur
ae80: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
ae90: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 65 78  thods.sqlite3_ex
aea0: 74 65 6e 64 65 64 5f 65 72 72 63 6f 64 65 28 5f  tended_errcode(_
aeb0: 73 71 6c 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  sql);..    }....
aec0: 20 20 20 20 2f 2f 2f 20 41 64 64 20 61 20 6c 6f      /// Add a lo
aed0: 67 20 6d 65 73 73 61 67 65 20 76 69 61 20 74 68  g message via th
aee0: 65 20 53 51 4c 69 74 65 20 73 71 6c 69 74 65 33  e SQLite sqlite3
aef0: 5f 6c 6f 67 20 69 6e 74 65 72 66 61 63 65 2e 0d  _log interface..
af00: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
af10: 65 72 72 69 64 65 20 76 6f 69 64 20 4c 6f 67 4d  erride void LogM
af20: 65 73 73 61 67 65 28 69 6e 74 20 69 45 72 72 43  essage(int iErrC
af30: 6f 64 65 2c 20 73 74 72 69 6e 67 20 7a 4d 65 73  ode, string zMes
af40: 73 61 67 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  sage)..    {..  
af50: 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65      UnsafeNative
af60: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
af70: 6c 6f 67 28 69 45 72 72 43 6f 64 65 2c 20 54 6f  log(iErrCode, To
af80: 55 54 46 38 28 7a 4d 65 73 73 61 67 65 29 29 3b  UTF8(zMessage));
af90: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 23 69 66 20 49  ..    }....#if I
afa0: 4e 54 45 52 4f 50 5f 43 4f 44 45 43 0d 0a 20 20  NTEROP_CODEC..  
afb0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
afc0: 69 64 65 20 76 6f 69 64 20 53 65 74 50 61 73 73  ide void SetPass
afd0: 77 6f 72 64 28 62 79 74 65 5b 5d 20 70 61 73 73  word(byte[] pass
afe0: 77 6f 72 64 42 79 74 65 73 29 0d 0a 20 20 20 20  wordBytes)..    
aff0: 7b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d  {..      int n =
b000: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
b010: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6b 65 79  hods.sqlite3_key
b020: 28 5f 73 71 6c 2c 20 70 61 73 73 77 6f 72 64 42  (_sql, passwordB
b030: 79 74 65 73 2c 20 70 61 73 73 77 6f 72 64 42 79  ytes, passwordBy
b040: 74 65 73 2e 4c 65 6e 67 74 68 29 3b 0d 0a 20 20  tes.Length);..  
b050: 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74      if (n > 0) t
b060: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
b070: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c  xception(n, GetL
b080: 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20  astError());..  
b090: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
b0a0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
b0b0: 64 20 43 68 61 6e 67 65 50 61 73 73 77 6f 72 64  d ChangePassword
b0c0: 28 62 79 74 65 5b 5d 20 6e 65 77 50 61 73 73 77  (byte[] newPassw
b0d0: 6f 72 64 42 79 74 65 73 29 0d 0a 20 20 20 20 7b  ordBytes)..    {
b0e0: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  ..      int n = 
b0f0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
b100: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 6b 65  ods.sqlite3_reke
b110: 79 28 5f 73 71 6c 2c 20 6e 65 77 50 61 73 73 77  y(_sql, newPassw
b120: 6f 72 64 42 79 74 65 73 2c 20 28 6e 65 77 50 61  ordBytes, (newPa
b130: 73 73 77 6f 72 64 42 79 74 65 73 20 3d 3d 20 6e  sswordBytes == n
b140: 75 6c 6c 29 20 3f 20 30 20 3a 20 6e 65 77 50 61  ull) ? 0 : newPa
b150: 73 73 77 6f 72 64 42 79 74 65 73 2e 4c 65 6e 67  sswordBytes.Leng
b160: 74 68 29 3b 0d 0a 20 20 20 20 20 20 69 66 20 28  th);..      if (
b170: 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77  n > 0) throw new
b180: 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e   SQLiteException
b190: 28 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72  (n, GetLastError
b1a0: 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 23 65 6e  ());..    }..#en
b1b0: 64 69 66 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72  dif....    inter
b1c0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
b1d0: 64 20 53 65 74 55 70 64 61 74 65 48 6f 6f 6b 28  d SetUpdateHook(
b1e0: 53 51 4c 69 74 65 55 70 64 61 74 65 43 61 6c 6c  SQLiteUpdateCall
b1f0: 62 61 63 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20  back func)..    
b200: 7b 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e  {..      UnsafeN
b210: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
b220: 69 74 65 33 5f 75 70 64 61 74 65 5f 68 6f 6f 6b  ite3_update_hook
b230: 28 5f 73 71 6c 2c 20 66 75 6e 63 2c 20 49 6e 74  (_sql, func, Int
b240: 50 74 72 2e 5a 65 72 6f 29 3b 0d 0a 20 20 20 20  Ptr.Zero);..    
b250: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
b260: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
b270: 53 65 74 43 6f 6d 6d 69 74 48 6f 6f 6b 28 53 51  SetCommitHook(SQ
b280: 4c 69 74 65 43 6f 6d 6d 69 74 43 61 6c 6c 62 61  LiteCommitCallba
b290: 63 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b 0d  ck func)..    {.
b2a0: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
b2b0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
b2c0: 65 33 5f 63 6f 6d 6d 69 74 5f 68 6f 6f 6b 28 5f  e3_commit_hook(_
b2d0: 73 71 6c 2c 20 66 75 6e 63 2c 20 49 6e 74 50 74  sql, func, IntPt
b2e0: 72 2e 5a 65 72 6f 29 3b 0d 0a 20 20 20 20 7d 0d  r.Zero);..    }.
b2f0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
b300: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 53 65  override void Se
b310: 74 54 72 61 63 65 43 61 6c 6c 62 61 63 6b 28 53  tTraceCallback(S
b320: 51 4c 69 74 65 54 72 61 63 65 43 61 6c 6c 62 61  QLiteTraceCallba
b330: 63 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b 0d  ck func)..    {.
b340: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
b350: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
b360: 65 33 5f 74 72 61 63 65 28 5f 73 71 6c 2c 20 66  e3_trace(_sql, f
b370: 75 6e 63 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f  unc, IntPtr.Zero
b380: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
b390: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
b3a0: 64 65 20 76 6f 69 64 20 53 65 74 52 6f 6c 6c 62  de void SetRollb
b3b0: 61 63 6b 48 6f 6f 6b 28 53 51 4c 69 74 65 52 6f  ackHook(SQLiteRo
b3c0: 6c 6c 62 61 63 6b 43 61 6c 6c 62 61 63 6b 20 66  llbackCallback f
b3d0: 75 6e 63 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  unc)..    {..   
b3e0: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
b3f0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72  ethods.sqlite3_r
b400: 6f 6c 6c 62 61 63 6b 5f 68 6f 6f 6b 28 5f 73 71  ollback_hook(_sq
b410: 6c 2c 20 66 75 6e 63 2c 20 49 6e 74 50 74 72 2e  l, func, IntPtr.
b420: 5a 65 72 6f 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  Zero);..    }...
b430: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
b440: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 6c 6c 6f  y>..    /// Allo
b450: 77 73 20 74 68 65 20 73 65 74 74 69 6e 67 20 6f  ws the setting o
b460: 66 20 61 20 6c 6f 67 67 69 6e 67 20 63 61 6c 6c  f a logging call
b470: 62 61 63 6b 20 69 6e 76 6f 6b 65 64 20 62 79 20  back invoked by 
b480: 53 51 4c 69 74 65 20 77 68 65 6e 20 61 0d 0a 20  SQLite when a.. 
b490: 20 20 20 2f 2f 2f 20 6c 6f 67 20 65 76 65 6e 74     /// log event
b4a0: 20 6f 63 63 75 72 73 2e 20 20 4f 6e 6c 79 20 6f   occurs.  Only o
b4b0: 6e 65 20 63 61 6c 6c 62 61 63 6b 20 6d 61 79 20  ne callback may 
b4c0: 62 65 20 73 65 74 2e 20 20 49 66 20 4e 55 4c 4c  be set.  If NULL
b4d0: 20 69 73 20 70 61 73 73 65 64 2c 0d 0a 20 20 20   is passed,..   
b4e0: 20 2f 2f 2f 20 74 68 65 20 6c 6f 67 67 69 6e 67   /// the logging
b4f0: 20 63 61 6c 6c 62 61 63 6b 20 69 73 20 75 6e 72   callback is unr
b500: 65 67 69 73 74 65 72 65 64 2e 0d 0a 20 20 20 20  egistered...    
b510: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
b520: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
b530: 61 6d 65 3d 22 66 75 6e 63 22 3e 54 68 65 20 63  ame="func">The c
b540: 61 6c 6c 62 61 63 6b 20 66 75 6e 63 74 69 6f 6e  allback function
b550: 20 74 6f 20 69 6e 76 6f 6b 65 2e 3c 2f 70 61 72   to invoke.</par
b560: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  am>..    /// <re
b570: 74 75 72 6e 73 3e 52 65 74 75 72 6e 73 20 61 20  turns>Returns a 
b580: 72 65 73 75 6c 74 20 63 6f 64 65 3c 2f 72 65 74  result code</ret
b590: 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72  urns>..    inter
b5a0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74  nal override int
b5b0: 20 53 65 74 4c 6f 67 43 61 6c 6c 62 61 63 6b 28   SetLogCallback(
b5c0: 53 51 4c 69 74 65 4c 6f 67 43 61 6c 6c 62 61 63  SQLiteLogCallbac
b5d0: 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b 0d 0a  k func)..    {..
b5e0: 20 20 20 20 20 20 20 20 69 6e 74 20 72 63 20 3d          int rc =
b5f0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
b600: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6e  hods.sqlite3_con
b610: 66 69 67 28 0d 0a 20 20 20 20 20 20 20 20 20 20  fig(..          
b620: 20 20 28 69 6e 74 29 53 51 4c 69 74 65 43 6f 6e    (int)SQLiteCon
b630: 66 69 67 4f 70 73 45 6e 75 6d 2e 53 51 4c 49 54  figOpsEnum.SQLIT
b640: 45 5f 43 4f 4e 46 49 47 5f 4c 4f 47 2c 20 66 75  E_CONFIG_LOG, fu
b650: 6e 63 2c 20 28 49 6e 74 50 74 72 29 30 29 3b 0d  nc, (IntPtr)0);.
b660: 0a 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  ...        retur
b670: 6e 20 72 63 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  n rc;..    }....
b680: 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f      ////////////
b690: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b6a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b6b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b6c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b6d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b6e0: 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c  ///....    /// <
b6f0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
b700: 2f 20 43 72 65 61 74 65 73 20 61 20 6e 65 77 20  / Creates a new 
b710: 53 51 4c 69 74 65 20 62 61 63 6b 75 70 20 6f 62  SQLite backup ob
b720: 6a 65 63 74 20 62 61 73 65 64 20 6f 6e 20 74 68  ject based on th
b730: 65 20 70 72 6f 76 69 64 65 64 20 64 65 73 74 69  e provided desti
b740: 6e 61 74 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20  nation..    /// 
b750: 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74  database connect
b760: 69 6f 6e 2e 20 20 54 68 65 20 73 6f 75 72 63 65  ion.  The source
b770: 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63   database connec
b780: 74 69 6f 6e 20 69 73 20 74 68 65 20 6f 6e 65 0d  tion is the one.
b790: 0a 20 20 20 20 2f 2f 2f 20 61 73 73 6f 63 69 61  .    /// associa
b7a0: 74 65 64 20 77 69 74 68 20 74 68 69 73 20 6f 62  ted with this ob
b7b0: 6a 65 63 74 2e 20 20 54 68 65 20 73 6f 75 72 63  ject.  The sourc
b7c0: 65 20 61 6e 64 20 64 65 73 74 69 6e 61 74 69 6f  e and destinatio
b7d0: 6e 20 64 61 74 61 62 61 73 65 0d 0a 20 20 20 20  n database..    
b7e0: 2f 2f 2f 20 63 6f 6e 6e 65 63 74 69 6f 6e 73 20  /// connections 
b7f0: 63 61 6e 6e 6f 74 20 62 65 20 74 68 65 20 73 61  cannot be the sa
b800: 6d 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  me...    /// </s
b810: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
b820: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 64 65   <param name="de
b830: 73 74 43 6e 6e 22 3e 54 68 65 20 64 65 73 74 69  stCnn">The desti
b840: 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 20  nation database 
b850: 63 6f 6e 6e 65 63 74 69 6f 6e 2e 3c 2f 70 61 72  connection.</par
b860: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  am>..    /// <pa
b870: 72 61 6d 20 6e 61 6d 65 3d 22 64 65 73 74 4e 61  ram name="destNa
b880: 6d 65 22 3e 54 68 65 20 64 65 73 74 69 6e 61 74  me">The destinat
b890: 69 6f 6e 20 64 61 74 61 62 61 73 65 20 6e 61 6d  ion database nam
b8a0: 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  e.</param>..    
b8b0: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
b8c0: 22 73 6f 75 72 63 65 4e 61 6d 65 22 3e 54 68 65  "sourceName">The
b8d0: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65   source database
b8e0: 20 6e 61 6d 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a   name.</param>..
b8f0: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
b900: 3e 54 68 65 20 6e 65 77 6c 79 20 63 72 65 61 74  >The newly creat
b910: 65 64 20 62 61 63 6b 75 70 20 6f 62 6a 65 63 74  ed backup object
b920: 2e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20  .</returns>..   
b930: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
b940: 64 65 20 53 51 4c 69 74 65 42 61 63 6b 75 70 20  de SQLiteBackup 
b950: 49 6e 69 74 69 61 6c 69 7a 65 42 61 63 6b 75 70  InitializeBackup
b960: 28 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74  (..        SQLit
b970: 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 64 65 73 74  eConnection dest
b980: 43 6e 6e 2c 0d 0a 20 20 20 20 20 20 20 20 73 74  Cnn,..        st
b990: 72 69 6e 67 20 64 65 73 74 4e 61 6d 65 2c 0d 0a  ring destName,..
b9a0: 20 20 20 20 20 20 20 20 73 74 72 69 6e 67 20 73          string s
b9b0: 6f 75 72 63 65 4e 61 6d 65 0d 0a 20 20 20 20 20  ourceName..     
b9c0: 20 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20     )..    {..   
b9d0: 20 20 20 20 20 69 66 20 28 64 65 73 74 43 6e 6e       if (destCnn
b9e0: 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20   == null)..     
b9f0: 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77         throw new
ba00: 20 41 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63   ArgumentNullExc
ba10: 65 70 74 69 6f 6e 28 22 64 65 73 74 43 6e 6e 22  eption("destCnn"
ba20: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66  );....        if
ba30: 20 28 64 65 73 74 4e 61 6d 65 20 3d 3d 20 6e 75   (destName == nu
ba40: 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ll)..           
ba50: 20 74 68 72 6f 77 20 6e 65 77 20 41 72 67 75 6d   throw new Argum
ba60: 65 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e  entNullException
ba70: 28 22 64 65 73 74 4e 61 6d 65 22 29 3b 0d 0a 0d  ("destName");...
ba80: 0a 20 20 20 20 20 20 20 20 69 66 20 28 73 6f 75  .        if (sou
ba90: 72 63 65 4e 61 6d 65 20 3d 3d 20 6e 75 6c 6c 29  rceName == null)
baa0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68  ..            th
bab0: 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74  row new Argument
bac0: 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 73  NullException("s
bad0: 6f 75 72 63 65 4e 61 6d 65 22 29 3b 0d 0a 0d 0a  ourceName");....
bae0: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 33 20          SQLite3 
baf0: 64 65 73 74 53 71 6c 69 74 65 33 20 3d 20 64 65  destSqlite3 = de
bb00: 73 74 43 6e 6e 2e 5f 73 71 6c 20 61 73 20 53 51  stCnn._sql as SQ
bb10: 4c 69 74 65 33 3b 0d 0a 0d 0a 20 20 20 20 20 20  Lite3;....      
bb20: 20 20 69 66 20 28 64 65 73 74 53 71 6c 69 74 65    if (destSqlite
bb30: 33 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20  3 == null)..    
bb40: 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65          throw ne
bb50: 77 20 41 72 67 75 6d 65 6e 74 45 78 63 65 70 74  w ArgumentExcept
bb60: 69 6f 6e 28 0d 0a 20 20 20 20 20 20 20 20 20 20  ion(..          
bb70: 20 20 20 20 20 20 22 44 65 73 74 69 6e 61 74 69        "Destinati
bb80: 6f 6e 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61  on connection ha
bb90: 73 20 6e 6f 20 77 72 61 70 70 65 72 2e 22 2c 0d  s no wrapper.",.
bba0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
bbb0: 20 22 64 65 73 74 43 6e 6e 22 29 3b 0d 0a 0d 0a   "destCnn");....
bbc0: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f          SQLiteCo
bbd0: 6e 6e 65 63 74 69 6f 6e 48 61 6e 64 6c 65 20 64  nnectionHandle d
bbe0: 65 73 74 48 61 6e 64 6c 65 20 3d 20 64 65 73 74  estHandle = dest
bbf0: 53 71 6c 69 74 65 33 2e 5f 73 71 6c 3b 0d 0a 0d  Sqlite3._sql;...
bc00: 0a 20 20 20 20 20 20 20 20 69 66 20 28 64 65 73  .        if (des
bc10: 74 48 61 6e 64 6c 65 20 3d 3d 20 6e 75 6c 6c 29  tHandle == null)
bc20: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68  ..            th
bc30: 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74  row new Argument
bc40: 45 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20  Exception(..    
bc50: 20 20 20 20 20 20 20 20 20 20 20 20 22 44 65 73              "Des
bc60: 74 69 6e 61 74 69 6f 6e 20 63 6f 6e 6e 65 63 74  tination connect
bc70: 69 6f 6e 20 68 61 73 20 61 6e 20 69 6e 76 61 6c  ion has an inval
bc80: 69 64 20 68 61 6e 64 6c 65 2e 22 2c 0d 0a 20 20  id handle.",..  
bc90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 64                "d
bca0: 65 73 74 43 6e 6e 22 29 3b 0d 0a 0d 0a 20 20 20  estCnn");....   
bcb0: 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65       SQLiteConne
bcc0: 63 74 69 6f 6e 48 61 6e 64 6c 65 20 73 6f 75 72  ctionHandle sour
bcd0: 63 65 48 61 6e 64 6c 65 20 3d 20 5f 73 71 6c 3b  ceHandle = _sql;
bce0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  ....        if (
bcf0: 73 6f 75 72 63 65 48 61 6e 64 6c 65 20 3d 3d 20  sourceHandle == 
bd00: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
bd10: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76     throw new Inv
bd20: 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63  alidOperationExc
bd30: 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20 20 20  eption(..       
bd40: 20 20 20 20 20 20 20 20 20 22 53 6f 75 72 63 65           "Source
bd50: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61 73 20   connection has 
bd60: 61 6e 20 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c  an invalid handl
bd70: 65 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  e.");....       
bd80: 20 62 79 74 65 5b 5d 20 7a 44 65 73 74 4e 61 6d   byte[] zDestNam
bd90: 65 20 3d 20 54 6f 55 54 46 38 28 64 65 73 74 4e  e = ToUTF8(destN
bda0: 61 6d 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 62  ame);..        b
bdb0: 79 74 65 5b 5d 20 7a 53 6f 75 72 63 65 4e 61 6d  yte[] zSourceNam
bdc0: 65 20 3d 20 54 6f 55 54 46 38 28 73 6f 75 72 63  e = ToUTF8(sourc
bdd0: 65 4e 61 6d 65 29 3b 0d 0a 0d 0a 20 20 20 20 20  eName);....     
bde0: 20 20 20 49 6e 74 50 74 72 20 62 61 63 6b 75 70     IntPtr backup
bdf0: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
be00: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
be10: 61 63 6b 75 70 5f 69 6e 69 74 28 0d 0a 20 20 20  ackup_init(..   
be20: 20 20 20 20 20 20 20 20 20 64 65 73 74 48 61 6e           destHan
be30: 64 6c 65 2c 20 7a 44 65 73 74 4e 61 6d 65 2c 20  dle, zDestName, 
be40: 73 6f 75 72 63 65 48 61 6e 64 6c 65 2c 20 7a 53  sourceHandle, zS
be50: 6f 75 72 63 65 4e 61 6d 65 29 3b 0d 0a 0d 0a 20  ourceName);.... 
be60: 20 20 20 20 20 20 20 69 66 20 28 62 61 63 6b 75         if (backu
be70: 70 20 3d 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f  p == IntPtr.Zero
be80: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74  )..            t
be90: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
bea0: 78 63 65 70 74 69 6f 6e 28 52 65 73 75 6c 74 43  xception(ResultC
beb0: 6f 64 65 28 29 2c 20 47 65 74 4c 61 73 74 45 72  ode(), GetLastEr
bec0: 72 6f 72 28 29 29 3b 0d 0a 0d 0a 20 20 20 20 20  ror());....     
bed0: 20 20 20 72 65 74 75 72 6e 20 6e 65 77 20 53 51     return new SQ
bee0: 4c 69 74 65 42 61 63 6b 75 70 28 0d 0a 20 20 20  LiteBackup(..   
bef0: 20 20 20 20 20 20 20 20 20 74 68 69 73 2c 20 6e           this, n
bf00: 65 77 20 53 51 4c 69 74 65 42 61 63 6b 75 70 48  ew SQLiteBackupH
bf10: 61 6e 64 6c 65 28 64 65 73 74 48 61 6e 64 6c 65  andle(destHandle
bf20: 2c 20 62 61 63 6b 75 70 29 2c 0d 0a 20 20 20 20  , backup),..    
bf30: 20 20 20 20 20 20 20 20 64 65 73 74 48 61 6e 64          destHand
bf40: 6c 65 2c 20 7a 44 65 73 74 4e 61 6d 65 2c 20 73  le, zDestName, s
bf50: 6f 75 72 63 65 48 61 6e 64 6c 65 2c 20 7a 53 6f  ourceHandle, zSo
bf60: 75 72 63 65 4e 61 6d 65 29 3b 0d 0a 20 20 20 20  urceName);..    
bf70: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  }....    /// <su
bf80: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
bf90: 43 6f 70 69 65 73 20 75 70 20 74 6f 20 4e 20 70  Copies up to N p
bfa0: 61 67 65 73 20 66 72 6f 6d 20 74 68 65 20 73 6f  ages from the so
bfb0: 75 72 63 65 20 64 61 74 61 62 61 73 65 20 74 6f  urce database to
bfc0: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   the destination
bfd0: 0d 0a 20 20 20 20 2f 2f 2f 20 64 61 74 61 62 61  ..    /// databa
bfe0: 73 65 20 61 73 73 6f 63 69 61 74 65 64 20 77 69  se associated wi
bff0: 74 68 20 74 68 65 20 73 70 65 63 69 66 69 65 64  th the specified
c000: 20 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 2e 0d   backup object..
c010: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61  .    /// </summa
c020: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  ry>..    /// <pa
c030: 72 61 6d 20 6e 61 6d 65 3d 22 62 61 63 6b 75 70  ram name="backup
c040: 22 3e 54 68 65 20 62 61 63 6b 75 70 20 6f 62 6a  ">The backup obj
c050: 65 63 74 20 74 6f 20 75 73 65 2e 3c 2f 70 61 72  ect to use.</par
c060: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61  am>..    /// <pa
c070: 72 61 6d 20 6e 61 6d 65 3d 22 6e 50 61 67 65 22  ram name="nPage"
c080: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 6e  >..    /// The n
c090: 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 20 74  umber of pages t
c0a0: 6f 20 63 6f 70 79 2c 20 6e 65 67 61 74 69 76 65  o copy, negative
c0b0: 20 74 6f 20 63 6f 70 79 20 61 6c 6c 20 72 65 6d   to copy all rem
c0c0: 61 69 6e 69 6e 67 20 70 61 67 65 73 2e 0d 0a 20  aining pages... 
c0d0: 20 20 20 2f 2f 2f 20 3c 2f 70 61 72 61 6d 3e 0d     /// </param>.
c0e0: 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20  .    /// <param 
c0f0: 6e 61 6d 65 3d 22 72 65 74 72 79 22 3e 0d 0a 20  name="retry">.. 
c100: 20 20 20 2f 2f 2f 20 53 65 74 20 74 6f 20 74 72     /// Set to tr
c110: 75 65 20 69 66 20 74 68 65 20 6f 70 65 72 61 74  ue if the operat
c120: 69 6f 6e 20 6e 65 65 64 73 20 74 6f 20 62 65 20  ion needs to be 
c130: 72 65 74 72 69 65 64 20 64 75 65 20 74 6f 20 64  retried due to d
c140: 61 74 61 62 61 73 65 0d 0a 20 20 20 20 2f 2f 2f  atabase..    ///
c150: 20 6c 6f 63 6b 69 6e 67 20 69 73 73 75 65 73 3b   locking issues;
c160: 20 6f 74 68 65 72 77 69 73 65 2c 20 73 65 74 20   otherwise, set 
c170: 74 6f 20 66 61 6c 73 65 2e 0d 0a 20 20 20 20 2f  to false...    /
c180: 2f 2f 20 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  // </param>..   
c190: 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 0d 0a   /// <returns>..
c1a0: 20 20 20 20 2f 2f 2f 20 54 72 75 65 20 69 66 20      /// True if 
c1b0: 74 68 65 72 65 20 61 72 65 20 6d 6f 72 65 20 70  there are more p
c1c0: 61 67 65 73 20 74 6f 20 62 65 20 63 6f 70 69 65  ages to be copie
c1d0: 64 2c 20 66 61 6c 73 65 20 6f 74 68 65 72 77 69  d, false otherwi
c1e0: 73 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72  se...    /// </r
c1f0: 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74  eturns>..    int
c200: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 62  ernal override b
c210: 6f 6f 6c 20 53 74 65 70 42 61 63 6b 75 70 28 0d  ool StepBackup(.
c220: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 42  .        SQLiteB
c230: 61 63 6b 75 70 20 62 61 63 6b 75 70 2c 0d 0a 20  ackup backup,.. 
c240: 20 20 20 20 20 20 20 69 6e 74 20 6e 50 61 67 65         int nPage
c250: 2c 0d 0a 20 20 20 20 20 20 20 20 6f 75 74 20 62  ,..        out b
c260: 6f 6f 6c 20 72 65 74 72 79 0d 0a 20 20 20 20 20  ool retry..     
c270: 20 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20     )..    {..   
c280: 20 20 20 20 20 72 65 74 72 79 20 3d 20 66 61 6c       retry = fal
c290: 73 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69  se;....        i
c2a0: 66 20 28 62 61 63 6b 75 70 20 3d 3d 20 6e 75 6c  f (backup == nul
c2b0: 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  l)..            
c2c0: 74 68 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65  throw new Argume
c2d0: 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28  ntNullException(
c2e0: 22 62 61 63 6b 75 70 22 29 3b 0d 0a 0d 0a 20 20  "backup");....  
c2f0: 20 20 20 20 20 20 53 51 4c 69 74 65 42 61 63 6b        SQLiteBack
c300: 75 70 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20  upHandle handle 
c310: 3d 20 62 61 63 6b 75 70 2e 5f 73 71 6c 69 74 65  = backup._sqlite
c320: 5f 62 61 63 6b 75 70 3b 0d 0a 0d 0a 20 20 20 20  _backup;....    
c330: 20 20 20 20 69 66 20 28 68 61 6e 64 6c 65 20 3d      if (handle =
c340: 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20  = null)..       
c350: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49       throw new I
c360: 6e 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45  nvalidOperationE
c370: 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20  xception(..     
c380: 20 20 20 20 20 20 20 20 20 20 20 22 42 61 63 6b             "Back
c390: 75 70 20 6f 62 6a 65 63 74 20 68 61 73 20 61 6e  up object has an
c3a0: 20 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 2e   invalid handle.
c3b0: 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69  ");....        i
c3c0: 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74  nt n = UnsafeNat
c3d0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
c3e0: 65 33 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 68  e3_backup_step(h
c3f0: 61 6e 64 6c 65 2c 20 6e 50 61 67 65 29 3b 0d 0a  andle, nPage);..
c400: 20 20 20 20 20 20 20 20 62 61 63 6b 75 70 2e 5f          backup._
c410: 73 74 65 70 52 65 73 75 6c 74 20 3d 20 6e 3b 20  stepResult = n; 
c420: 2f 2a 20 4e 4f 54 45 3a 20 53 61 76 65 20 66 6f  /* NOTE: Save fo
c430: 72 20 75 73 65 20 62 79 20 46 69 6e 69 73 68 42  r use by FinishB
c440: 61 63 6b 75 70 2e 20 2a 2f 0d 0a 0d 0a 20 20 20  ackup. */....   
c450: 20 20 20 20 20 69 66 20 28 6e 20 3d 3d 20 28 69       if (n == (i
c460: 6e 74 29 53 51 4c 69 74 65 45 72 72 6f 72 43 6f  nt)SQLiteErrorCo
c470: 64 65 2e 4f 6b 29 0d 0a 20 20 20 20 20 20 20 20  de.Ok)..        
c480: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  {..            r
c490: 65 74 75 72 6e 20 74 72 75 65 3b 0d 0a 20 20 20  eturn true;..   
c4a0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
c4b0: 65 6c 73 65 20 69 66 20 28 6e 20 3d 3d 20 28 69  else if (n == (i
c4c0: 6e 74 29 53 51 4c 69 74 65 45 72 72 6f 72 43 6f  nt)SQLiteErrorCo
c4d0: 64 65 2e 42 75 73 79 29 0d 0a 20 20 20 20 20 20  de.Busy)..      
c4e0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
c4f0: 20 72 65 74 72 79 20 3d 20 74 72 75 65 3b 0d 0a   retry = true;..
c500: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
c510: 72 6e 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20  rn true;..      
c520: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 65 6c 73    }..        els
c530: 65 20 69 66 20 28 6e 20 3d 3d 20 28 69 6e 74 29  e if (n == (int)
c540: 53 51 4c 69 74 65 45 72 72 6f 72 43 6f 64 65 2e  SQLiteErrorCode.
c550: 4c 6f 63 6b 65 64 29 0d 0a 20 20 20 20 20 20 20  Locked)..       
c560: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
c570: 72 65 74 72 79 20 3d 20 74 72 75 65 3b 0d 0a 20  retry = true;.. 
c580: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
c590: 6e 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20  n true;..       
c5a0: 20 7d 0d 0a 20 20 20 20 20 20 20 20 65 6c 73 65   }..        else
c5b0: 20 69 66 20 28 6e 20 3d 3d 20 28 69 6e 74 29 53   if (n == (int)S
c5c0: 51 4c 69 74 65 45 72 72 6f 72 43 6f 64 65 2e 44  QLiteErrorCode.D
c5d0: 6f 6e 65 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d  one)..        {.
c5e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74  .            ret
c5f0: 75 72 6e 20 66 61 6c 73 65 3b 0d 0a 20 20 20 20  urn false;..    
c600: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 65      }..        e
c610: 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  lse..        {..
c620: 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72 6f              thro
c630: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
c640: 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74  ption(n, GetLast
c650: 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 20  Error());..     
c660: 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20     }..    }.... 
c670: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
c680: 0d 0a 20 20 20 20 2f 2f 2f 20 52 65 74 75 72 6e  ..    /// Return
c690: 73 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20  s the number of 
c6a0: 70 61 67 65 73 20 72 65 6d 61 69 6e 69 6e 67 20  pages remaining 
c6b0: 74 6f 20 62 65 20 63 6f 70 69 65 64 20 66 72 6f  to be copied fro
c6c0: 6d 20 74 68 65 20 73 6f 75 72 63 65 0d 0a 20 20  m the source..  
c6d0: 20 20 2f 2f 2f 20 64 61 74 61 62 61 73 65 20 74    /// database t
c6e0: 6f 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f  o the destinatio
c6f0: 6e 20 64 61 74 61 62 61 73 65 20 61 73 73 6f 63  n database assoc
c700: 69 61 74 65 64 20 77 69 74 68 20 74 68 65 20 73  iated with the s
c710: 70 65 63 69 66 69 65 64 0d 0a 20 20 20 20 2f 2f  pecified..    //
c720: 2f 20 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 2e  / backup object.
c730: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d  ..    /// </summ
c740: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ary>..    /// <p
c750: 61 72 61 6d 20 6e 61 6d 65 3d 22 62 61 63 6b 75  aram name="backu
c760: 70 22 3e 54 68 65 20 62 61 63 6b 75 70 20 6f 62  p">The backup ob
c770: 6a 65 63 74 20 74 6f 20 63 68 65 63 6b 2e 3c 2f  ject to check.</
c780: 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  param>..    /// 
c790: 3c 72 65 74 75 72 6e 73 3e 54 68 65 20 6e 75 6d  <returns>The num
c7a0: 62 65 72 20 6f 66 20 70 61 67 65 73 20 72 65 6d  ber of pages rem
c7b0: 61 69 6e 69 6e 67 20 74 6f 20 62 65 20 63 6f 70  aining to be cop
c7c0: 69 65 64 2e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a  ied.</returns>..
c7d0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
c7e0: 72 72 69 64 65 20 69 6e 74 20 52 65 6d 61 69 6e  rride int Remain
c7f0: 69 6e 67 42 61 63 6b 75 70 28 0d 0a 20 20 20 20  ingBackup(..    
c800: 20 20 20 20 53 51 4c 69 74 65 42 61 63 6b 75 70      SQLiteBackup
c810: 20 62 61 63 6b 75 70 0d 0a 20 20 20 20 20 20 20   backup..       
c820: 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20   )..    {..     
c830: 20 20 20 69 66 20 28 62 61 63 6b 75 70 20 3d 3d     if (backup ==
c840: 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20   null)..        
c850: 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41 72      throw new Ar
c860: 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70 74  gumentNullExcept
c870: 69 6f 6e 28 22 62 61 63 6b 75 70 22 29 3b 0d 0a  ion("backup");..
c880: 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65  ..        SQLite
c890: 42 61 63 6b 75 70 48 61 6e 64 6c 65 20 68 61 6e  BackupHandle han
c8a0: 64 6c 65 20 3d 20 62 61 63 6b 75 70 2e 5f 73 71  dle = backup._sq
c8b0: 6c 69 74 65 5f 62 61 63 6b 75 70 3b 0d 0a 0d 0a  lite_backup;....
c8c0: 20 20 20 20 20 20 20 20 69 66 20 28 68 61 6e 64          if (hand
c8d0: 6c 65 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20  le == null)..   
c8e0: 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e           throw n
c8f0: 65 77 20 49 6e 76 61 6c 69 64 4f 70 65 72 61 74  ew InvalidOperat
c900: 69 6f 6e 45 78 63 65 70 74 69 6f 6e 28 0d 0a 20  ionException(.. 
c910: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22                 "
c920: 42 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 68 61  Backup object ha
c930: 73 20 61 6e 20 69 6e 76 61 6c 69 64 20 68 61 6e  s an invalid han
c940: 64 6c 65 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20  dle.");....     
c950: 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65     return Unsafe
c960: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
c970: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 72 65 6d  lite3_backup_rem
c980: 61 69 6e 69 6e 67 28 68 61 6e 64 6c 65 29 3b 0d  aining(handle);.
c990: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f  .    }....    //
c9a0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20  / <summary>..   
c9b0: 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20 74 68 65   /// Returns the
c9c0: 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66   total number of
c9d0: 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 73 6f   pages in the so
c9e0: 75 72 63 65 20 64 61 74 61 62 61 73 65 20 61 73  urce database as
c9f0: 73 6f 63 69 61 74 65 64 0d 0a 20 20 20 20 2f 2f  sociated..    //
ca00: 2f 20 77 69 74 68 20 74 68 65 20 73 70 65 63 69  / with the speci
ca10: 66 69 65 64 20 62 61 63 6b 75 70 20 6f 62 6a 65  fied backup obje
ca20: 63 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ct...    /// </s
ca30: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
ca40: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 62 61   <param name="ba
ca50: 63 6b 75 70 22 3e 54 68 65 20 62 61 63 6b 75 70  ckup">The backup
ca60: 20 6f 62 6a 65 63 74 20 74 6f 20 63 68 65 63 6b   object to check
ca70: 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  .</param>..    /
ca80: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20  // <returns>The 
ca90: 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66 20  total number of 
caa0: 70 61 67 65 73 20 69 6e 20 74 68 65 20 73 6f 75  pages in the sou
cab0: 72 63 65 20 64 61 74 61 62 61 73 65 2e 3c 2f 72  rce database.</r
cac0: 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74  eturns>..    int
cad0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69  ernal override i
cae0: 6e 74 20 50 61 67 65 43 6f 75 6e 74 42 61 63 6b  nt PageCountBack
caf0: 75 70 28 0d 0a 20 20 20 20 20 20 20 20 53 51 4c  up(..        SQL
cb00: 69 74 65 42 61 63 6b 75 70 20 62 61 63 6b 75 70  iteBackup backup
cb10: 0d 0a 20 20 20 20 20 20 20 20 29 0d 0a 20 20 20  ..        )..   
cb20: 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28   {..        if (
cb30: 62 61 63 6b 75 70 20 3d 3d 20 6e 75 6c 6c 29 0d  backup == null).
cb40: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72  .            thr
cb50: 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 4e  ow new ArgumentN
cb60: 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 62 61  ullException("ba
cb70: 63 6b 75 70 22 29 3b 0d 0a 0d 0a 20 20 20 20 20  ckup");....     
cb80: 20 20 20 53 51 4c 69 74 65 42 61 63 6b 75 70 48     SQLiteBackupH
cb90: 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 62  andle handle = b
cba0: 61 63 6b 75 70 2e 5f 73 71 6c 69 74 65 5f 62 61  ackup._sqlite_ba
cbb0: 63 6b 75 70 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  ckup;....       
cbc0: 20 69 66 20 28 68 61 6e 64 6c 65 20 3d 3d 20 6e   if (handle == n
cbd0: 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ull)..          
cbe0: 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76 61    throw new Inva
cbf0: 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63 65  lidOperationExce
cc00: 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20 20 20 20  ption(..        
cc10: 20 20 20 20 20 20 20 20 22 42 61 63 6b 75 70 20          "Backup 
cc20: 6f 62 6a 65 63 74 20 68 61 73 20 61 6e 20 69 6e  object has an in
cc30: 76 61 6c 69 64 20 68 61 6e 64 6c 65 2e 22 29 3b  valid handle.");
cc40: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75  ....        retu
cc50: 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  rn UnsafeNativeM
cc60: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
cc70: 61 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e 74 28  ackup_pagecount(
cc80: 68 61 6e 64 6c 65 29 3b 0d 0a 20 20 20 20 7d 0d  handle);..    }.
cc90: 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ...    /// <summ
cca0: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 44 65  ary>..    /// De
ccb0: 73 74 72 6f 79 73 20 74 68 65 20 62 61 63 6b 75  stroys the backu
ccc0: 70 20 6f 62 6a 65 63 74 2c 20 72 6f 6c 6c 69 6e  p object, rollin
ccd0: 67 20 62 61 63 6b 20 61 6e 79 20 62 61 63 6b 75  g back any backu
cce0: 70 20 74 68 61 74 20 6d 61 79 20 62 65 20 69 6e  p that may be in
ccf0: 0d 0a 20 20 20 20 2f 2f 2f 20 70 72 6f 67 65 73  ..    /// proges
cd00: 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  s...    /// </su
cd10: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
cd20: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 62 61 63  <param name="bac
cd30: 6b 75 70 22 3e 54 68 65 20 62 61 63 6b 75 70 20  kup">The backup 
cd40: 6f 62 6a 65 63 74 20 74 6f 20 64 65 73 74 72 6f  object to destro
cd50: 79 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  y.</param>..    
cd60: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
cd70: 65 20 76 6f 69 64 20 46 69 6e 69 73 68 42 61 63  e void FinishBac
cd80: 6b 75 70 28 0d 0a 20 20 20 20 20 20 20 20 53 51  kup(..        SQ
cd90: 4c 69 74 65 42 61 63 6b 75 70 20 62 61 63 6b 75  LiteBackup backu
cda0: 70 0d 0a 20 20 20 20 20 20 20 20 29 0d 0a 20 20  p..        )..  
cdb0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20    {..        if 
cdc0: 28 62 61 63 6b 75 70 20 3d 3d 20 6e 75 6c 6c 29  (backup == null)
cdd0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68  ..            th
cde0: 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74  row new Argument
cdf0: 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 62  NullException("b
ce00: 61 63 6b 75 70 22 29 3b 0d 0a 0d 0a 20 20 20 20  ackup");....    
ce10: 20 20 20 20 53 51 4c 69 74 65 42 61 63 6b 75 70      SQLiteBackup
ce20: 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20  Handle handle = 
ce30: 62 61 63 6b 75 70 2e 5f 73 71 6c 69 74 65 5f 62  backup._sqlite_b
ce40: 61 63 6b 75 70 3b 0d 0a 0d 0a 20 20 20 20 20 20  ackup;....      
ce50: 20 20 69 66 20 28 68 61 6e 64 6c 65 20 3d 3d 20    if (handle == 
ce60: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
ce70: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76     throw new Inv
ce80: 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63  alidOperationExc
ce90: 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20 20 20  eption(..       
cea0: 20 20 20 20 20 20 20 20 20 22 42 61 63 6b 75 70           "Backup
ceb0: 20 6f 62 6a 65 63 74 20 68 61 73 20 61 6e 20 69   object has an i
cec0: 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 2e 22 29  nvalid handle.")
ced0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 6e 74  ;....        int
cee0: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
cef0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
cf00: 5f 62 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 68  _backup_finish(h
cf10: 61 6e 64 6c 65 29 3b 0d 0a 20 20 20 20 20 20 20  andle);..       
cf20: 20 68 61 6e 64 6c 65 2e 53 65 74 48 61 6e 64 6c   handle.SetHandl
cf30: 65 41 73 49 6e 76 61 6c 69 64 28 29 3b 0d 0a 0d  eAsInvalid();...
cf40: 0a 20 20 20 20 20 20 20 20 69 66 20 28 28 6e 20  .        if ((n 
cf50: 3e 20 30 29 20 26 26 20 28 6e 20 21 3d 20 62 61  > 0) && (n != ba
cf60: 63 6b 75 70 2e 5f 73 74 65 70 52 65 73 75 6c 74  ckup._stepResult
cf70: 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ))..            
cf80: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
cf90: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74  Exception(n, Get
cfa0: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20  LastError());.. 
cfb0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f     }....    ////
cfc0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
cfd0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
cfe0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
cff0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d000: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d010: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20  ///////////.... 
d020: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
d030: 0d 0a 20 20 20 20 2f 2f 2f 20 44 65 74 65 72 6d  ..    /// Determ
d040: 69 6e 65 73 20 69 66 20 74 68 65 20 53 51 4c 69  ines if the SQLi
d050: 74 65 20 63 6f 72 65 20 6c 69 62 72 61 72 79 20  te core library 
d060: 68 61 73 20 62 65 65 6e 20 69 6e 69 74 69 61 6c  has been initial
d070: 69 7a 65 64 20 66 6f 72 20 74 68 65 0d 0a 20 20  ized for the..  
d080: 20 20 2f 2f 2f 20 63 75 72 72 65 6e 74 20 70 72    /// current pr
d090: 6f 63 65 73 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20  ocess...    /// 
d0a0: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
d0b0: 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 0d 0a 20  /// <returns>.. 
d0c0: 20 20 20 2f 2f 2f 20 41 20 62 6f 6f 6c 65 61 6e     /// A boolean
d0d0: 20 69 6e 64 69 63 61 74 69 6e 67 20 77 68 65 74   indicating whet
d0e0: 68 65 72 20 6f 72 20 6e 6f 74 20 74 68 65 20 53  her or not the S
d0f0: 51 4c 69 74 65 20 63 6f 72 65 20 6c 69 62 72 61  QLite core libra
d100: 72 79 20 68 61 73 20 62 65 65 6e 0d 0a 20 20 20  ry has been..   
d110: 20 2f 2f 2f 20 69 6e 69 74 69 61 6c 69 7a 65 64   /// initialized
d120: 20 66 6f 72 20 74 68 65 20 63 75 72 72 65 6e 74   for the current
d130: 20 70 72 6f 63 65 73 73 2e 0d 0a 20 20 20 20 2f   process...    /
d140: 2f 2f 20 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20  // </returns>.. 
d150: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
d160: 72 69 64 65 20 62 6f 6f 6c 20 49 73 49 6e 69 74  ride bool IsInit
d170: 69 61 6c 69 7a 65 64 28 29 0d 0a 20 20 20 20 7b  ialized()..    {
d180: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
d190: 20 53 74 61 74 69 63 49 73 49 6e 69 74 69 61 6c   StaticIsInitial
d1a0: 69 7a 65 64 28 29 3b 0d 0a 20 20 20 20 7d 0d 0a  ized();..    }..
d1b0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
d1c0: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 44 65 74  ry>..    /// Det
d1d0: 65 72 6d 69 6e 65 73 20 69 66 20 74 68 65 20 53  ermines if the S
d1e0: 51 4c 69 74 65 20 63 6f 72 65 20 6c 69 62 72 61  QLite core libra
d1f0: 72 79 20 68 61 73 20 62 65 65 6e 20 69 6e 69 74  ry has been init
d200: 69 61 6c 69 7a 65 64 20 66 6f 72 20 74 68 65 0d  ialized for the.
d210: 0a 20 20 20 20 2f 2f 2f 20 63 75 72 72 65 6e 74  .    /// current
d220: 20 70 72 6f 63 65 73 73 2e 0d 0a 20 20 20 20 2f   process...    /
d230: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
d240: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
d250: 0d 0a 20 20 20 20 2f 2f 2f 20 41 20 62 6f 6f 6c  ..    /// A bool
d260: 65 61 6e 20 69 6e 64 69 63 61 74 69 6e 67 20 77  ean indicating w
d270: 68 65 74 68 65 72 20 6f 72 20 6e 6f 74 20 74 68  hether or not th
d280: 65 20 53 51 4c 69 74 65 20 63 6f 72 65 20 6c 69  e SQLite core li
d290: 62 72 61 72 79 20 68 61 73 20 62 65 65 6e 0d 0a  brary has been..
d2a0: 20 20 20 20 2f 2f 2f 20 69 6e 69 74 69 61 6c 69      /// initiali
d2b0: 7a 65 64 20 66 6f 72 20 74 68 65 20 63 75 72 72  zed for the curr
d2c0: 65 6e 74 20 70 72 6f 63 65 73 73 2e 0d 0a 20 20  ent process...  
d2d0: 20 20 2f 2f 2f 20 3c 2f 72 65 74 75 72 6e 73 3e    /// </returns>
d2e0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73  ..    internal s
d2f0: 74 61 74 69 63 20 62 6f 6f 6c 20 53 74 61 74 69  tatic bool Stati
d300: 63 49 73 49 6e 69 74 69 61 6c 69 7a 65 64 28 29  cIsInitialized()
d310: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
d320: 20 2f 2f 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20   //..        // 
d330: 42 55 47 46 49 58 3a 20 50 72 65 76 65 6e 74 20  BUGFIX: Prevent 
d340: 72 61 63 65 73 20 77 69 74 68 20 6f 74 68 65 72  races with other
d350: 20 74 68 72 65 61 64 73 20 66 6f 72 20 74 68 69   threads for thi
d360: 73 20 65 6e 74 69 72 65 20 62 6c 6f 63 6b 2c 20  s entire block, 
d370: 64 75 65 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20  due..        // 
d380: 20 20 20 20 20 20 20 20 74 6f 20 74 68 65 20 74          to the t
d390: 72 79 2f 66 69 6e 61 6c 6c 79 20 73 65 6d 61 6e  ry/finally seman
d3a0: 74 69 63 73 2e 20 20 53 65 65 20 74 69 63 6b 65  tics.  See ticke
d3b0: 74 20 5b 37 32 39 30 35 63 39 61 37 37 5d 2e 0d  t [72905c9a77]..
d3c0: 0a 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20  .        //..   
d3d0: 20 20 20 20 20 6c 6f 63 6b 20 28 73 79 6e 63 52       lock (syncR
d3e0: 6f 6f 74 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d  oot)..        {.
d3f0: 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43  .#if !PLATFORM_C
d400: 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d  OMPACTFRAMEWORK.
d410: 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d  .            //.
d420: 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20  .            // 
d430: 4e 4f 54 45 3a 20 53 61 76 65 20 74 68 65 20 73  NOTE: Save the s
d440: 74 61 74 65 20 6f 66 20 74 68 65 20 6c 6f 67 67  tate of the logg
d450: 69 6e 67 20 63 6c 61 73 73 20 61 6e 64 20 74 68  ing class and th
d460: 65 6e 20 72 65 73 74 6f 72 65 20 69 74 0d 0a 20  en restore it.. 
d470: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 20 20             //   
d480: 20 20 20 20 61 66 74 65 72 20 77 65 20 61 72 65      after we are
d490: 20 64 6f 6e 65 20 74 6f 20 61 76 6f 69 64 20 6c   done to avoid l
d4a0: 6f 67 67 69 6e 67 20 74 6f 6f 20 6d 61 6e 79 20  ogging too many 
d4b0: 66 61 6c 73 65 20 65 72 72 6f 72 73 2e 0d 0a 20  false errors... 
d4c0: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20             //.. 
d4d0: 20 20 20 20 20 20 20 20 20 20 20 62 6f 6f 6c 20             bool 
d4e0: 73 61 76 65 64 45 6e 61 62 6c 65 64 20 3d 20 53  savedEnabled = S
d4f0: 51 4c 69 74 65 4c 6f 67 2e 45 6e 61 62 6c 65 64  QLiteLog.Enabled
d500: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 53  ;..            S
d510: 51 4c 69 74 65 4c 6f 67 2e 45 6e 61 62 6c 65 64  QLiteLog.Enabled
d520: 20 3d 20 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20   = false;....   
d530: 20 20 20 20 20 20 20 20 20 74 72 79 0d 0a 20 20           try..  
d540: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 23 65 6e            {..#en
d550: 64 69 66 0d 0a 20 20 20 20 20 20 20 20 20 20 20  dif..           
d560: 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 20       //..       
d570: 20 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45           // NOTE
d580: 3a 20 54 68 69 73 20 6d 65 74 68 6f 64 20 5b 61  : This method [a
d590: 62 5d 75 73 65 73 20 74 68 65 20 66 61 63 74 20  b]uses the fact 
d5a0: 74 68 61 74 20 53 51 4c 69 74 65 20 77 69 6c 6c  that SQLite will
d5b0: 20 61 6c 77 61 79 73 0d 0a 20 20 20 20 20 20 20   always..       
d5c0: 20 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 20           //     
d5d0: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
d5e0: 45 52 52 4f 52 20 66 6f 72 20 61 6e 79 20 75 6e  ERROR for any un
d5f0: 6b 6e 6f 77 6e 20 63 6f 6e 66 69 67 75 72 61 74  known configurat
d600: 69 6f 6e 20 6f 70 74 69 6f 6e 0d 0a 20 20 20 20  ion option..    
d610: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 20              //  
d620: 20 20 20 20 20 2a 75 6e 6c 65 73 73 2a 20 74 68       *unless* th
d630: 65 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72 79  e SQLite library
d640: 20 68 61 73 20 61 6c 72 65 61 64 79 20 62 65 65   has already bee
d650: 6e 20 69 6e 69 74 69 61 6c 69 7a 65 64 2e 0d 0a  n initialized...
d660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
d670: 2f 2f 20 20 20 20 20 20 20 49 6e 20 74 68 61 74  //       In that
d680: 20 63 61 73 65 20 69 74 20 77 69 6c 6c 20 61 6c   case it will al
d690: 77 61 79 73 20 72 65 74 75 72 6e 20 53 51 4c 49  ways return SQLI
d6a0: 54 45 5f 4d 49 53 55 53 45 2e 0d 0a 20 20 20 20  TE_MISUSE...    
d6b0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a              //..
d6c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
d6d0: 69 6e 74 20 72 63 20 3d 20 55 6e 73 61 66 65 4e  int rc = UnsafeN
d6e0: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
d6f0: 69 74 65 33 5f 63 6f 6e 66 69 67 28 0d 0a 20 20  ite3_config(..  
d700: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
d710: 20 20 28 69 6e 74 29 53 51 4c 69 74 65 43 6f 6e    (int)SQLiteCon
d720: 66 69 67 4f 70 73 45 6e 75 6d 2e 53 51 4c 49 54  figOpsEnum.SQLIT
d730: 45 5f 43 4f 4e 46 49 47 5f 4e 4f 4e 45 2c 20 6e  E_CONFIG_NONE, n
d740: 75 6c 6c 2c 20 28 49 6e 74 50 74 72 29 30 29 3b  ull, (IntPtr)0);
d750: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
d760: 20 20 20 20 72 65 74 75 72 6e 20 28 72 63 20 3d      return (rc =
d770: 3d 20 2f 2a 20 53 51 4c 49 54 45 5f 4d 49 53 55  = /* SQLITE_MISU
d780: 53 45 20 2a 2f 20 32 31 29 3b 0d 0a 23 69 66 20  SE */ 21);..#if 
d790: 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43  !PLATFORM_COMPAC
d7a0: 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20  TFRAMEWORK..    
d7b0: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
d7c0: 20 20 20 20 20 20 20 66 69 6e 61 6c 6c 79 0d 0a         finally..
d7d0: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
d7e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53                 S
d7f0: 51 4c 69 74 65 4c 6f 67 2e 45 6e 61 62 6c 65 64  QLiteLog.Enabled
d800: 20 3d 20 73 61 76 65 64 45 6e 61 62 6c 65 64 3b   = savedEnabled;
d810: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d  ..            }.
d820: 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 20  .#endif..       
d830: 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20   }..    }....   
d840: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
d850: 20 20 20 20 2f 2f 2f 20 48 65 6c 70 65 72 20 66      /// Helper f
d860: 75 6e 63 74 69 6f 6e 20 74 6f 20 72 65 74 72 69  unction to retri
d870: 65 76 65 20 61 20 63 6f 6c 75 6d 6e 20 6f 66 20  eve a column of 
d880: 64 61 74 61 20 66 72 6f 6d 20 61 6e 20 61 63 74  data from an act
d890: 69 76 65 20 73 74 61 74 65 6d 65 6e 74 2e 0d 0a  ive statement...
d8a0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
d8b0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  y>..    /// <par
d8c0: 61 6d 20 6e 61 6d 65 3d 22 73 74 6d 74 22 3e 54  am name="stmt">T
d8d0: 68 65 20 73 74 61 74 65 6d 65 6e 74 20 62 65 69  he statement bei
d8e0: 6e 67 20 73 74 65 70 28 29 27 64 20 74 68 72 6f  ng step()'d thro
d8f0: 75 67 68 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20  ugh</param>..   
d900: 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65   /// <param name
d910: 3d 22 69 6e 64 65 78 22 3e 54 68 65 20 63 6f 6c  ="index">The col
d920: 75 6d 6e 20 69 6e 64 65 78 20 74 6f 20 72 65 74  umn index to ret
d930: 72 69 65 76 65 3c 2f 70 61 72 61 6d 3e 0d 0a 20  rieve</param>.. 
d940: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
d950: 6d 65 3d 22 74 79 70 22 3e 54 68 65 20 74 79 70  me="typ">The typ
d960: 65 20 6f 66 20 64 61 74 61 20 63 6f 6e 74 61 69  e of data contai
d970: 6e 65 64 20 69 6e 20 74 68 65 20 63 6f 6c 75 6d  ned in the colum
d980: 6e 2e 20 20 49 66 20 55 6e 69 6e 69 74 69 61 6c  n.  If Uninitial
d990: 69 7a 65 64 2c 20 74 68 69 73 20 66 75 6e 63 74  ized, this funct
d9a0: 69 6f 6e 20 77 69 6c 6c 20 72 65 74 72 69 65 76  ion will retriev
d9b0: 65 20 74 68 65 20 64 61 74 61 74 79 70 65 20 69  e the datatype i
d9c0: 6e 66 6f 72 6d 61 74 69 6f 6e 2e 3c 2f 70 61 72  nformation.</par
d9d0: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  am>..    /// <re
d9e0: 74 75 72 6e 73 3e 52 65 74 75 72 6e 73 20 74 68  turns>Returns th
d9f0: 65 20 64 61 74 61 20 69 6e 20 74 68 65 20 63 6f  e data in the co
da00: 6c 75 6d 6e 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a  lumn</returns>..
da10: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
da20: 72 72 69 64 65 20 6f 62 6a 65 63 74 20 47 65 74  rride object Get
da30: 56 61 6c 75 65 28 53 51 4c 69 74 65 53 74 61 74  Value(SQLiteStat
da40: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20  ement stmt, int 
da50: 69 6e 64 65 78 2c 20 53 51 4c 69 74 65 54 79 70  index, SQLiteTyp
da60: 65 20 74 79 70 29 0d 0a 20 20 20 20 7b 0d 0a 20  e typ)..    {.. 
da70: 20 20 20 20 20 69 66 20 28 49 73 4e 75 6c 6c 28       if (IsNull(
da80: 73 74 6d 74 2c 20 69 6e 64 65 78 29 29 20 72 65  stmt, index)) re
da90: 74 75 72 6e 20 44 42 4e 75 6c 6c 2e 56 61 6c 75  turn DBNull.Valu
daa0: 65 3b 0d 0a 20 20 20 20 20 20 54 79 70 65 41 66  e;..      TypeAf
dab0: 66 69 6e 69 74 79 20 61 66 66 20 3d 20 74 79 70  finity aff = typ
dac0: 2e 41 66 66 69 6e 69 74 79 3b 0d 0a 20 20 20 20  .Affinity;..    
dad0: 20 20 54 79 70 65 20 74 20 3d 20 6e 75 6c 6c 3b    Type t = null;
dae0: 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20 28 74 79  ....      if (ty
daf0: 70 2e 54 79 70 65 20 21 3d 20 44 62 54 79 70 65  p.Type != DbType
db00: 2e 4f 62 6a 65 63 74 29 0d 0a 20 20 20 20 20 20  .Object)..      
db10: 7b 0d 0a 20 20 20 20 20 20 20 20 74 20 3d 20 53  {..        t = S
db20: 51 4c 69 74 65 43 6f 6e 76 65 72 74 2e 53 51 4c  QLiteConvert.SQL
db30: 69 74 65 54 79 70 65 54 6f 54 79 70 65 28 74 79  iteTypeToType(ty
db40: 70 29 3b 0d 0a 20 20 20 20 20 20 20 20 61 66 66  p);..        aff
db50: 20 3d 20 54 79 70 65 54 6f 41 66 66 69 6e 69 74   = TypeToAffinit
db60: 79 28 74 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a  y(t);..      }..
db70: 0d 0a 20 20 20 20 20 20 73 77 69 74 63 68 20 28  ..      switch (
db80: 61 66 66 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20  aff)..      {.. 
db90: 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65         case Type
dba0: 41 66 66 69 6e 69 74 79 2e 42 6c 6f 62 3a 0d 0a  Affinity.Blob:..
dbb0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74 79            if (ty
dbc0: 70 2e 54 79 70 65 20 3d 3d 20 44 62 54 79 70 65  p.Type == DbType
dbd0: 2e 47 75 69 64 20 26 26 20 74 79 70 2e 41 66 66  .Guid && typ.Aff
dbe0: 69 6e 69 74 79 20 3d 3d 20 54 79 70 65 41 66 66  inity == TypeAff
dbf0: 69 6e 69 74 79 2e 54 65 78 74 29 0d 0a 20 20 20  inity.Text)..   
dc00: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20           return 
dc10: 6e 65 77 20 47 75 69 64 28 47 65 74 54 65 78 74  new Guid(GetText
dc20: 28 73 74 6d 74 2c 20 69 6e 64 65 78 29 29 3b 0d  (stmt, index));.
dc30: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 69 6e 74  ...          int
dc40: 20 6e 20 3d 20 28 69 6e 74 29 47 65 74 42 79 74   n = (int)GetByt
dc50: 65 73 28 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20  es(stmt, index, 
dc60: 30 2c 20 6e 75 6c 6c 2c 20 30 2c 20 30 29 3b 0d  0, null, 0, 0);.
dc70: 0a 20 20 20 20 20 20 20 20 20 20 62 79 74 65 5b  .          byte[
dc80: 5d 20 62 20 3d 20 6e 65 77 20 62 79 74 65 5b 6e  ] b = new byte[n
dc90: 5d 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 47 65  ];..          Ge
dca0: 74 42 79 74 65 73 28 73 74 6d 74 2c 20 69 6e 64  tBytes(stmt, ind
dcb0: 65 78 2c 20 30 2c 20 62 2c 20 30 2c 20 6e 29 3b  ex, 0, b, 0, n);
dcc0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66  ....          if
dcd0: 20 28 74 79 70 2e 54 79 70 65 20 3d 3d 20 44 62   (typ.Type == Db
dce0: 54 79 70 65 2e 47 75 69 64 20 26 26 20 6e 20 3d  Type.Guid && n =
dcf0: 3d 20 31 36 29 0d 0a 20 20 20 20 20 20 20 20 20  = 16)..         
dd00: 20 20 20 72 65 74 75 72 6e 20 6e 65 77 20 47 75     return new Gu
dd10: 69 64 28 62 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  id(b);....      
dd20: 20 20 20 20 72 65 74 75 72 6e 20 62 3b 0d 0a 20      return b;.. 
dd30: 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70 65         case Type
dd40: 41 66 66 69 6e 69 74 79 2e 44 61 74 65 54 69 6d  Affinity.DateTim
dd50: 65 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65  e:..          re
dd60: 74 75 72 6e 20 47 65 74 44 61 74 65 54 69 6d 65  turn GetDateTime
dd70: 28 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a  (stmt, index);..
dd80: 20 20 20 20 20 20 20 20 63 61 73 65 20 54 79 70          case Typ
dd90: 65 41 66 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65  eAffinity.Double
dda0: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20  :..          if 
ddb0: 28 74 20 3d 3d 20 6e 75 6c 6c 29 20 72 65 74 75  (t == null) retu
ddc0: 72 6e 20 47 65 74 44 6f 75 62 6c 65 28 73 74 6d  rn GetDouble(stm
ddd0: 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20 20  t, index);..    
dde0: 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20        else..    
ddf0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 43          return C
de00: 6f 6e 76 65 72 74 2e 43 68 61 6e 67 65 54 79 70  onvert.ChangeTyp
de10: 65 28 47 65 74 44 6f 75 62 6c 65 28 73 74 6d 74  e(GetDouble(stmt
de20: 2c 20 69 6e 64 65 78 29 2c 20 74 2c 20 6e 75 6c  , index), t, nul
de30: 6c 29 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73  l);..        cas
de40: 65 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 49  e TypeAffinity.I
de50: 6e 74 36 34 3a 0d 0a 20 20 20 20 20 20 20 20 20  nt64:..         
de60: 20 69 66 20 28 74 20 3d 3d 20 6e 75 6c 6c 29 20   if (t == null) 
de70: 72 65 74 75 72 6e 20 47 65 74 49 6e 74 36 34 28  return GetInt64(
de80: 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20  stmt, index);.. 
de90: 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d 0a 20           else.. 
dea0: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
deb0: 6e 20 43 6f 6e 76 65 72 74 2e 43 68 61 6e 67 65  n Convert.Change
dec0: 54 79 70 65 28 47 65 74 49 6e 74 36 34 28 73 74  Type(GetInt64(st
ded0: 6d 74 2c 20 69 6e 64 65 78 29 2c 20 74 2c 20 6e  mt, index), t, n
dee0: 75 6c 6c 29 3b 0d 0a 20 20 20 20 20 20 20 20 64  ull);..        d
def0: 65 66 61 75 6c 74 3a 0d 0a 20 20 20 20 20 20 20  efault:..       
df00: 20 20 20 72 65 74 75 72 6e 20 47 65 74 54 65 78     return GetTex
df10: 74 28 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d  t(stmt, index);.
df20: 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d  .      }..    }.
df30: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
df40: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 47 65 74  override int Get
df50: 43 75 72 73 6f 72 46 6f 72 54 61 62 6c 65 28 53  CursorForTable(S
df60: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73  QLiteStatement s
df70: 74 6d 74 2c 20 69 6e 74 20 64 62 2c 20 69 6e 74  tmt, int db, int
df80: 20 72 6f 6f 74 50 61 67 65 29 0d 0a 20 20 20 20   rootPage)..    
df90: 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53  {..#if !SQLITE_S
dfa0: 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 72  TANDARD..      r
dfb0: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
dfc0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
dfd0: 33 5f 74 61 62 6c 65 5f 63 75 72 73 6f 72 28 73  3_table_cursor(s
dfe0: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
dff0: 2c 20 64 62 2c 20 72 6f 6f 74 50 61 67 65 29 3b  , db, rootPage);
e000: 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 72  ..#else..      r
e010: 65 74 75 72 6e 20 2d 31 3b 0d 0a 23 65 6e 64 69  eturn -1;..#endi
e020: 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  f..    }....    
e030: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
e040: 65 20 6c 6f 6e 67 20 47 65 74 52 6f 77 49 64 46  e long GetRowIdF
e050: 6f 72 43 75 72 73 6f 72 28 53 51 4c 69 74 65 53  orCursor(SQLiteS
e060: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
e070: 6e 74 20 63 75 72 73 6f 72 29 0d 0a 20 20 20 20  nt cursor)..    
e080: 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53  {..#if !SQLITE_S
e090: 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 6c  TANDARD..      l
e0a0: 6f 6e 67 20 72 6f 77 69 64 3b 0d 0a 20 20 20 20  ong rowid;..    
e0b0: 20 20 69 6e 74 20 72 63 20 3d 20 55 6e 73 61 66    int rc = Unsaf
e0c0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
e0d0: 71 6c 69 74 65 33 5f 63 75 72 73 6f 72 5f 72 6f  qlite3_cursor_ro
e0e0: 77 69 64 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  wid(stmt._sqlite
e0f0: 5f 73 74 6d 74 2c 20 63 75 72 73 6f 72 2c 20 6f  _stmt, cursor, o
e100: 75 74 20 72 6f 77 69 64 29 3b 0d 0a 20 20 20 20  ut rowid);..    
e110: 20 20 69 66 20 28 72 63 20 3d 3d 20 30 29 20 72    if (rc == 0) r
e120: 65 74 75 72 6e 20 72 6f 77 69 64 3b 0d 0a 0d 0a  eturn rowid;....
e130: 20 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0d        return 0;.
e140: 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 72 65  .#else..      re
e150: 74 75 72 6e 20 30 3b 0d 0a 23 65 6e 64 69 66 0d  turn 0;..#endif.
e160: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
e170: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
e180: 76 6f 69 64 20 47 65 74 49 6e 64 65 78 43 6f 6c  void GetIndexCol
e190: 75 6d 6e 45 78 74 65 6e 64 65 64 49 6e 66 6f 28  umnExtendedInfo(
e1a0: 73 74 72 69 6e 67 20 64 61 74 61 62 61 73 65 2c  string database,
e1b0: 20 73 74 72 69 6e 67 20 69 6e 64 65 78 2c 20 73   string index, s
e1c0: 74 72 69 6e 67 20 63 6f 6c 75 6d 6e 2c 20 6f 75  tring column, ou
e1d0: 74 20 69 6e 74 20 73 6f 72 74 4d 6f 64 65 2c 20  t int sortMode, 
e1e0: 6f 75 74 20 69 6e 74 20 6f 6e 45 72 72 6f 72 2c  out int onError,
e1f0: 20 6f 75 74 20 73 74 72 69 6e 67 20 63 6f 6c 6c   out string coll
e200: 61 74 69 6f 6e 53 65 71 75 65 6e 63 65 29 0d 0a  ationSequence)..
e210: 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49      {..#if !SQLI
e220: 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20  TE_STANDARD..   
e230: 20 20 20 49 6e 74 50 74 72 20 63 6f 6c 6c 3b 0d     IntPtr coll;.
e240: 0a 20 20 20 20 20 20 69 6e 74 20 63 6f 6c 6c 6c  .      int colll
e250: 65 6e 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 72  en;..      int r
e260: 63 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 63 20 3d  c;....      rc =
e270: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
e280: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 69 6e 64  hods.sqlite3_ind
e290: 65 78 5f 63 6f 6c 75 6d 6e 5f 69 6e 66 6f 5f 69  ex_column_info_i
e2a0: 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55  nterop(_sql, ToU
e2b0: 54 46 38 28 64 61 74 61 62 61 73 65 29 2c 20 54  TF8(database), T
e2c0: 6f 55 54 46 38 28 69 6e 64 65 78 29 2c 20 54 6f  oUTF8(index), To
e2d0: 55 54 46 38 28 63 6f 6c 75 6d 6e 29 2c 20 6f 75  UTF8(column), ou
e2e0: 74 20 73 6f 72 74 4d 6f 64 65 2c 20 6f 75 74 20  t sortMode, out 
e2f0: 6f 6e 45 72 72 6f 72 2c 20 6f 75 74 20 63 6f 6c  onError, out col
e300: 6c 2c 20 6f 75 74 20 63 6f 6c 6c 6c 65 6e 29 3b  l, out colllen);
e310: 0d 0a 20 20 20 20 20 20 69 66 20 28 72 63 20 21  ..      if (rc !
e320: 3d 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  = 0) throw new S
e330: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 72  QLiteException(r
e340: 63 2c 20 22 22 29 3b 0d 0a 0d 0a 20 20 20 20 20  c, "");....     
e350: 20 63 6f 6c 6c 61 74 69 6f 6e 53 65 71 75 65 6e   collationSequen
e360: 63 65 20 3d 20 55 54 46 38 54 6f 53 74 72 69 6e  ce = UTF8ToStrin
e370: 67 28 63 6f 6c 6c 2c 20 63 6f 6c 6c 6c 65 6e 29  g(coll, colllen)
e380: 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20  ;..#else..      
e390: 73 6f 72 74 4d 6f 64 65 20 3d 20 30 3b 0d 0a 20  sortMode = 0;.. 
e3a0: 20 20 20 20 20 6f 6e 45 72 72 6f 72 20 3d 20 32       onError = 2
e3b0: 3b 0d 0a 20 20 20 20 20 20 63 6f 6c 6c 61 74 69  ;..      collati
e3c0: 6f 6e 53 65 71 75 65 6e 63 65 20 3d 20 22 42 49  onSequence = "BI
e3d0: 4e 41 52 59 22 3b 0d 0a 23 65 6e 64 69 66 0d 0a  NARY";..#endif..
e3e0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
e3f0: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 69  ernal override i
e400: 6e 74 20 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 73  nt FileControl(s
e410: 74 72 69 6e 67 20 7a 44 62 4e 61 6d 65 2c 20 69  tring zDbName, i
e420: 6e 74 20 6f 70 2c 20 49 6e 74 50 74 72 20 70 41  nt op, IntPtr pA
e430: 72 67 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  rg)..    {..    
e440: 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e    return UnsafeN
e450: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
e460: 69 74 65 33 5f 66 69 6c 65 5f 63 6f 6e 74 72 6f  ite3_file_contro
e470: 6c 28 5f 73 71 6c 2c 20 28 7a 44 62 4e 61 6d 65  l(_sql, (zDbName
e480: 20 21 3d 20 6e 75 6c 6c 29 20 3f 20 54 6f 55 54   != null) ? ToUT
e490: 46 38 28 7a 44 62 4e 61 6d 65 29 20 3a 20 6e 75  F8(zDbName) : nu
e4a0: 6c 6c 2c 20 6f 70 2c 20 70 41 72 67 29 3b 0d 0a  ll, op, pArg);..
e4b0: 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 7d 0d 0a         }..  }..}..