System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 7e6d441f91bbfc77dafc4abf8e65676373f29214:


0000: ef bb bf 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .../************
0010: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0020: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0030: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0d 0a 20 2a  ************.. *
0040: 20 41 44 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74   ADO.NET 2.0 Dat
0050: 61 20 50 72 6f 76 69 64 65 72 20 66 6f 72 20 53  a Provider for S
0060: 51 4c 69 74 65 20 56 65 72 73 69 6f 6e 20 33 2e  QLite Version 3.
0070: 58 0d 0a 20 2a 20 57 72 69 74 74 65 6e 20 62 79  X.. * Written by
0080: 20 52 6f 62 65 72 74 20 53 69 6d 70 73 6f 6e 20   Robert Simpson 
0090: 28 72 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73  (robert@blackcas
00a0: 74 6c 65 73 6f 66 74 2e 63 6f 6d 29 0d 0a 20 2a  tlesoft.com).. *
00b0: 20 0d 0a 20 2a 20 52 65 6c 65 61 73 65 64 20 74   .. * Released t
00c0: 6f 20 74 68 65 20 70 75 62 6c 69 63 20 64 6f 6d  o the public dom
00d0: 61 69 6e 2c 20 75 73 65 20 61 74 20 79 6f 75 72  ain, use at your
00e0: 20 6f 77 6e 20 72 69 73 6b 21 0d 0a 20 2a 2a 2a   own risk!.. ***
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 2a 2a 2a 2a 2f 0d 0a 0d 0a 6e 61 6d 65 73 70  *****/....namesp
0130: 61 63 65 20 53 79 73 74 65 6d 2e 44 61 74 61 2e  ace System.Data.
0140: 53 51 4c 69 74 65 0d 0a 7b 0d 0a 20 20 75 73 69  SQLite..{..  usi
0150: 6e 67 20 53 79 73 74 65 6d 3b 0d 0a 20 20 75 73  ng System;..  us
0160: 69 6e 67 20 53 79 73 74 65 6d 2e 43 6f 6c 6c 65  ing System.Colle
0170: 63 74 69 6f 6e 73 2e 47 65 6e 65 72 69 63 3b 0d  ctions.Generic;.
0180: 0a 23 69 66 20 44 45 42 55 47 0d 0a 20 20 75 73  .#if DEBUG..  us
0190: 69 6e 67 20 53 79 73 74 65 6d 2e 44 69 61 67 6e  ing System.Diagn
01a0: 6f 73 74 69 63 73 3b 0d 0a 23 65 6e 64 69 66 0d  ostics;..#endif.
01b0: 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e  .  using System.
01c0: 52 75 6e 74 69 6d 65 2e 49 6e 74 65 72 6f 70 53  Runtime.InteropS
01d0: 65 72 76 69 63 65 73 3b 0d 0a 20 20 75 73 69 6e  ervices;..  usin
01e0: 67 20 53 79 73 74 65 6d 2e 54 65 78 74 3b 0d 0a  g System.Text;..
01f0: 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f  ..#if !PLATFORM_
0200: 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b  COMPACTFRAMEWORK
0210: 0d 0a 20 20 5b 55 6e 6d 61 6e 61 67 65 64 46 75  ..  [UnmanagedFu
0220: 6e 63 74 69 6f 6e 50 6f 69 6e 74 65 72 28 43 61  nctionPointer(Ca
0230: 6c 6c 69 6e 67 43 6f 6e 76 65 6e 74 69 6f 6e 2e  llingConvention.
0240: 43 64 65 63 6c 29 5d 0d 0a 23 65 6e 64 69 66 0d  Cdecl)]..#endif.
0250: 0a 20 20 69 6e 74 65 72 6e 61 6c 20 64 65 6c 65  .  internal dele
0260: 67 61 74 65 20 76 6f 69 64 20 53 51 4c 69 74 65  gate void SQLite
0270: 4c 6f 67 43 61 6c 6c 62 61 63 6b 28 49 6e 74 50  LogCallback(IntP
0280: 74 72 20 70 75 73 65 72 2c 20 69 6e 74 20 65 72  tr puser, int er
0290: 72 5f 63 6f 64 65 2c 20 49 6e 74 50 74 72 20 6d  r_code, IntPtr m
02a0: 65 73 73 61 67 65 29 3b 0d 0a 0d 0a 20 20 2f 2f  essage);....  //
02b0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f  / <summary>..  /
02c0: 2f 2f 20 54 68 69 73 20 63 6c 61 73 73 20 69 6d  // This class im
02d0: 70 6c 65 6d 65 6e 74 73 20 53 51 4c 69 74 65 42  plements SQLiteB
02e0: 61 73 65 20 63 6f 6d 70 6c 65 74 65 6c 79 2c 20  ase completely, 
02f0: 61 6e 64 20 69 73 20 74 68 65 20 67 75 74 73 20  and is the guts 
0300: 6f 66 20 74 68 65 20 63 6f 64 65 20 74 68 61 74  of the code that
0310: 20 69 6e 74 65 72 6f 70 27 73 20 53 51 4c 69 74   interop's SQLit
0320: 65 20 77 69 74 68 20 2e 4e 45 54 0d 0a 20 20 2f  e with .NET..  /
0330: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
0340: 20 69 6e 74 65 72 6e 61 6c 20 63 6c 61 73 73 20   internal class 
0350: 53 51 4c 69 74 65 33 20 3a 20 53 51 4c 69 74 65  SQLite3 : SQLite
0360: 42 61 73 65 0d 0a 20 20 7b 0d 0a 20 20 20 20 70  Base..  {..    p
0370: 72 69 76 61 74 65 20 73 74 61 74 69 63 20 6f 62  rivate static ob
0380: 6a 65 63 74 20 73 79 6e 63 52 6f 6f 74 20 3d 20  ject syncRoot = 
0390: 6e 65 77 20 6f 62 6a 65 63 74 28 29 3b 0d 0a 0d  new object();...
03a0: 0a 20 20 20 20 2f 2f 0d 0a 20 20 20 20 2f 2f 20  .    //..    // 
03b0: 4e 4f 54 45 3a 20 54 68 69 73 20 69 73 20 74 68  NOTE: This is th
03c0: 65 20 70 75 62 6c 69 63 20 6b 65 79 20 66 6f 72  e public key for
03d0: 20 74 68 65 20 53 79 73 74 65 6d 2e 44 61 74 61   the System.Data
03e0: 2e 53 51 4c 69 74 65 20 61 73 73 65 6d 62 6c 79  .SQLite assembly
03f0: 2e 20 20 49 66 20 79 6f 75 20 63 68 61 6e 67 65  .  If you change
0400: 20 74 68 65 0d 0a 20 20 20 20 2f 2f 20 20 20 20   the..    //    
0410: 20 20 20 53 4e 4b 20 66 69 6c 65 2c 20 79 6f 75     SNK file, you
0420: 20 77 69 6c 6c 20 6e 65 65 64 20 74 6f 20 63 68   will need to ch
0430: 61 6e 67 65 20 74 68 69 73 20 61 73 20 77 65 6c  ange this as wel
0440: 6c 2e 0d 0a 20 20 20 20 2f 2f 0d 0a 20 20 20 20  l...    //..    
0450: 69 6e 74 65 72 6e 61 6c 20 63 6f 6e 73 74 20 73  internal const s
0460: 74 72 69 6e 67 20 50 75 62 6c 69 63 4b 65 79 20  tring PublicKey 
0470: 3d 0d 0a 20 20 20 20 20 20 20 20 22 30 30 32 34  =..        "0024
0480: 30 30 30 30 30 34 38 30 30 30 30 30 39 34 30 30  0000048000009400
0490: 30 30 30 30 30 36 30 32 30 30 30 30 30 30 32 34  0000060200000024
04a0: 30 30 30 30 35 32 35 33 34 31 33 31 30 30 30 34  0000525341310004
04b0: 30 30 30 30 30 31 30 30 30 31 30 30 30 35 61 32  00000100010005a2
04c0: 38 38 64 65 35 36 38 37 63 34 65 31 22 20 2b 0d  88de5687c4e1" +.
04d0: 0a 20 20 20 20 20 20 20 20 22 62 36 32 31 64 64  .        "b621dd
04e0: 66 66 35 64 38 34 34 37 32 37 34 31 38 39 35 36  ff5d844727418956
04f0: 39 39 37 66 34 37 35 65 62 38 32 39 34 32 39 65  997f475eb829429e
0500: 34 31 31 61 66 66 33 65 39 33 66 39 37 62 37 30  411aff3e93f97b70
0510: 64 65 36 39 38 62 39 37 32 36 34 30 39 32 35 62  de698b972640925b
0520: 64 64 34 34 32 38 30 64 66 30 22 20 2b 0d 0a 20  dd44280df0" +.. 
0530: 20 20 20 20 20 20 20 22 61 32 35 61 38 34 33 32         "a25a8432
0540: 36 36 39 37 33 37 30 34 31 33 37 63 62 62 30 65  66973704137cbb0e
0550: 37 34 34 31 63 31 66 65 37 63 61 65 34 65 32 34  7441c1fe7cae4e24
0560: 34 30 61 65 39 31 61 62 38 63 64 65 33 39 33 33  40ae91ab8cde3933
0570: 66 65 62 63 62 31 61 63 34 38 64 64 33 33 62 34  febcb1ac48dd33b4
0580: 30 65 31 33 63 34 32 31 22 20 2b 0d 0a 20 20 20  0e13c421" +..   
0590: 20 20 20 20 20 22 64 38 32 31 35 63 31 38 61 34       "d8215c18a4
05a0: 33 34 39 61 34 33 36 64 64 34 39 39 65 33 63 33  349a436dd499e3c3
05b0: 38 35 63 63 36 38 33 30 31 35 66 38 38 36 66 36  85cc683015f886f6
05c0: 63 31 30 62 64 39 30 31 31 35 65 62 32 62 64 36  c10bd90115eb2bd6
05d0: 31 62 36 37 37 35 30 38 33 39 65 33 61 31 39 39  1b67750839e3a199
05e0: 34 31 64 63 39 63 22 3b 0d 0a 0d 0a 23 69 66 20  41dc9c";....#if 
05f0: 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43  !PLATFORM_COMPAC
0600: 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20  TFRAMEWORK..    
0610: 69 6e 74 65 72 6e 61 6c 20 63 6f 6e 73 74 20 73  internal const s
0620: 74 72 69 6e 67 20 44 65 73 69 67 6e 65 72 56 65  tring DesignerVe
0630: 72 73 69 6f 6e 20 3d 20 22 31 2e 30 2e 38 31 2e  rsion = "1.0.81.
0640: 30 22 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20  0";..#endif.... 
0650: 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e     /// <summary>
0660: 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20 6f 70  ..    /// The op
0670: 61 71 75 65 20 70 6f 69 6e 74 65 72 20 72 65 74  aque pointer ret
0680: 75 72 6e 65 64 20 74 6f 20 75 73 20 62 79 20 74  urned to us by t
0690: 68 65 20 73 71 6c 69 74 65 20 70 72 6f 76 69 64  he sqlite provid
06a0: 65 72 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  er..    /// </su
06b0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72 6f 74  mmary>..    prot
06c0: 65 63 74 65 64 20 53 51 4c 69 74 65 43 6f 6e 6e  ected SQLiteConn
06d0: 65 63 74 69 6f 6e 48 61 6e 64 6c 65 20 5f 73 71  ectionHandle _sq
06e0: 6c 3b 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65  l;..    protecte
06f0: 64 20 73 74 72 69 6e 67 20 5f 66 69 6c 65 4e 61  d string _fileNa
0700: 6d 65 3b 0d 0a 20 20 20 20 70 72 6f 74 65 63 74  me;..    protect
0710: 65 64 20 62 6f 6f 6c 20 5f 75 73 65 50 6f 6f 6c  ed bool _usePool
0720: 3b 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64  ;..    protected
0730: 20 69 6e 74 20 5f 70 6f 6f 6c 56 65 72 73 69 6f   int _poolVersio
0740: 6e 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46  n;....#if !PLATF
0750: 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45  ORM_COMPACTFRAME
0760: 57 4f 52 4b 0d 0a 20 20 20 20 70 72 69 76 61 74  WORK..    privat
0770: 65 20 62 6f 6f 6c 20 5f 62 75 69 6c 64 69 6e 67  e bool _building
0780: 53 63 68 65 6d 61 3b 0d 0a 23 65 6e 64 69 66 0d  Schema;..#endif.
0790: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
07a0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68 65 20  y>..    /// The 
07b0: 75 73 65 72 2d 64 65 66 69 6e 65 64 20 66 75 6e  user-defined fun
07c0: 63 74 69 6f 6e 73 20 72 65 67 69 73 74 65 72 65  ctions registere
07d0: 64 20 6f 6e 20 74 68 69 73 20 63 6f 6e 6e 65 63  d on this connec
07e0: 74 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  tion..    /// </
07f0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 72  summary>..    pr
0800: 6f 74 65 63 74 65 64 20 53 51 4c 69 74 65 46 75  otected SQLiteFu
0810: 6e 63 74 69 6f 6e 5b 5d 20 5f 66 75 6e 63 74 69  nction[] _functi
0820: 6f 6e 73 41 72 72 61 79 3b 0d 0a 0d 0a 20 20 20  onsArray;....   
0830: 20 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74 65   internal SQLite
0840: 33 28 53 51 4c 69 74 65 44 61 74 65 46 6f 72 6d  3(SQLiteDateForm
0850: 61 74 73 20 66 6d 74 2c 20 44 61 74 65 54 69 6d  ats fmt, DateTim
0860: 65 4b 69 6e 64 20 6b 69 6e 64 29 0d 0a 20 20 20  eKind kind)..   
0870: 20 20 20 3a 20 62 61 73 65 28 66 6d 74 2c 20 6b     : base(fmt, k
0880: 69 6e 64 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  ind)..    {..   
0890: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f 2f 2f   }....    //////
08a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
08f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20  /////////....   
0900: 20 23 72 65 67 69 6f 6e 20 49 44 69 73 70 6f 73   #region IDispos
0910: 61 62 6c 65 20 22 50 61 74 74 65 72 6e 22 20 4d  able "Pattern" M
0920: 65 6d 62 65 72 73 0d 0a 20 20 20 20 70 72 69 76  embers..    priv
0930: 61 74 65 20 62 6f 6f 6c 20 64 69 73 70 6f 73 65  ate bool dispose
0940: 64 3b 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20  d;..    private 
0950: 76 6f 69 64 20 43 68 65 63 6b 44 69 73 70 6f 73  void CheckDispos
0960: 65 64 28 29 20 2f 2a 20 74 68 72 6f 77 20 2a 2f  ed() /* throw */
0970: 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 54 48 52  ..    {..#if THR
0980: 4f 57 5f 4f 4e 5f 44 49 53 50 4f 53 45 44 0d 0a  OW_ON_DISPOSED..
0990: 20 20 20 20 20 20 20 20 69 66 20 28 64 69 73 70          if (disp
09a0: 6f 73 65 64 29 0d 0a 20 20 20 20 20 20 20 20 20  osed)..         
09b0: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 4f 62 6a     throw new Obj
09c0: 65 63 74 44 69 73 70 6f 73 65 64 45 78 63 65 70  ectDisposedExcep
09d0: 74 69 6f 6e 28 74 79 70 65 6f 66 28 53 51 4c 69  tion(typeof(SQLi
09e0: 74 65 33 29 2e 4e 61 6d 65 29 3b 0d 0a 23 65 6e  te3).Name);..#en
09f0: 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  dif..    }....  
0a00: 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f    //////////////
0a10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0a60: 2f 0d 0a 0d 0a 20 20 20 20 70 72 6f 74 65 63 74  /....    protect
0a70: 65 64 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  ed override void
0a80: 20 44 69 73 70 6f 73 65 28 62 6f 6f 6c 20 64 69   Dispose(bool di
0a90: 73 70 6f 73 69 6e 67 29 0d 0a 20 20 20 20 7b 0d  sposing)..    {.
0aa0: 0a 20 20 20 20 20 20 20 20 74 72 79 0d 0a 20 20  .        try..  
0ab0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
0ac0: 20 20 20 20 20 69 66 20 28 21 64 69 73 70 6f 73       if (!dispos
0ad0: 65 64 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ed)..           
0ae0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
0af0: 20 20 20 20 2f 2f 69 66 20 28 64 69 73 70 6f 73      //if (dispos
0b00: 69 6e 67 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ing)..          
0b10: 20 20 20 20 20 20 2f 2f 7b 0d 0a 20 20 20 20 20        //{..     
0b20: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 20 20             //   
0b30: 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f   ///////////////
0b40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0b50: 2f 2f 2f 2f 2f 0d 0a 20 20 20 20 20 20 20 20 20  /////..         
0b60: 20 20 20 20 20 20 20 2f 2f 20 20 20 20 2f 2f 20         //    // 
0b70: 64 69 73 70 6f 73 65 20 6d 61 6e 61 67 65 64 20  dispose managed 
0b80: 72 65 73 6f 75 72 63 65 73 20 68 65 72 65 2e 2e  resources here..
0b90: 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
0ba0: 20 20 20 2f 2f 20 20 20 20 2f 2f 2f 2f 2f 2f 2f     //    ///////
0bb0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0bc0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 20  /////////////.. 
0bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
0be0: 2f 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  /}....          
0bf0: 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f        //////////
0c00: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0c10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 20 20  ////////////..  
0c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f                //
0c30: 20 72 65 6c 65 61 73 65 20 75 6e 6d 61 6e 61 67   release unmanag
0c40: 65 64 20 72 65 73 6f 75 72 63 65 73 20 68 65 72  ed resources her
0c50: 65 2e 2e 2e 0d 0a 20 20 20 20 20 20 20 20 20 20  e.....          
0c60: 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f        //////////
0c70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0c80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a  ////////////....
0c90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0ca0: 43 6c 6f 73 65 28 29 3b 0d 0a 0d 0a 20 20 20 20  Close();....    
0cb0: 20 20 20 20 20 20 20 20 20 20 20 20 64 69 73 70              disp
0cc0: 6f 73 65 64 20 3d 20 74 72 75 65 3b 0d 0a 20 20  osed = true;..  
0cd0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
0ce0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
0cf0: 66 69 6e 61 6c 6c 79 0d 0a 20 20 20 20 20 20 20  finally..       
0d00: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
0d10: 62 61 73 65 2e 44 69 73 70 6f 73 65 28 64 69 73  base.Dispose(dis
0d20: 70 6f 73 69 6e 67 29 3b 0d 0a 20 20 20 20 20 20  posing);..      
0d30: 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20    }..    }..    
0d40: 23 65 6e 64 72 65 67 69 6f 6e 0d 0a 0d 0a 20 20  #endregion....  
0d50: 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f    //////////////
0d60: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0d70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0d80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0d90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0da0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0db0: 2f 0d 0a 0d 0a 20 20 20 20 2f 2f 20 49 74 20 69  /....    // It i
0dc0: 73 6e 27 74 20 6e 65 63 65 73 73 61 72 79 20 74  sn't necessary t
0dd0: 6f 20 63 6c 65 61 6e 75 70 20 61 6e 79 20 66 75  o cleanup any fu
0de0: 6e 63 74 69 6f 6e 73 20 77 65 27 76 65 20 72 65  nctions we've re
0df0: 67 69 73 74 65 72 65 64 2e 20 20 49 66 20 74 68  gistered.  If th
0e00: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 0d 0a 20 20  e connection..  
0e10: 20 20 2f 2f 20 67 6f 65 73 20 74 6f 20 74 68 65    // goes to the
0e20: 20 70 6f 6f 6c 20 61 6e 64 20 69 73 20 72 65 73   pool and is res
0e30: 75 72 72 65 63 74 65 64 20 6c 61 74 65 72 2c 20  urrected later, 
0e40: 72 65 2d 72 65 67 69 73 74 65 72 65 64 20 66 75  re-registered fu
0e50: 6e 63 74 69 6f 6e 73 20 77 69 6c 6c 20 6f 76 65  nctions will ove
0e60: 72 77 72 69 74 65 20 74 68 65 0d 0a 20 20 20 20  rwrite the..    
0e70: 2f 2f 20 70 72 65 76 69 6f 75 73 20 66 75 6e 63  // previous func
0e80: 74 69 6f 6e 73 2e 20 20 54 68 65 20 53 51 4c 69  tions.  The SQLi
0e90: 74 65 46 75 6e 63 74 69 6f 6e 43 6f 6f 6b 69 65  teFunctionCookie
0ea0: 48 61 6e 64 6c 65 20 77 69 6c 6c 20 74 61 6b 65  Handle will take
0eb0: 20 63 61 72 65 20 6f 66 20 66 72 65 65 69 6e 67   care of freeing
0ec0: 20 75 6e 6d 61 6e 61 67 65 64 0d 0a 20 20 20 20   unmanaged..    
0ed0: 2f 2f 20 72 65 73 6f 75 72 63 65 73 20 62 65 6c  // resources bel
0ee0: 6f 6e 67 69 6e 67 20 74 6f 20 74 68 65 20 70 72  onging to the pr
0ef0: 65 76 69 6f 75 73 6c 79 2d 72 65 67 69 73 74 65  eviously-registe
0f00: 72 65 64 20 66 75 6e 63 74 69 6f 6e 73 2e 0d 0a  red functions...
0f10: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
0f20: 72 72 69 64 65 20 76 6f 69 64 20 43 6c 6f 73 65  rride void Close
0f30: 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  ()..    {..     
0f40: 20 69 66 20 28 5f 73 71 6c 20 21 3d 20 6e 75 6c   if (_sql != nul
0f50: 6c 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20  l)..      {..   
0f60: 20 20 20 20 20 20 20 69 66 20 28 5f 75 73 65 50         if (_useP
0f70: 6f 6f 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ool)..          
0f80: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
0f90: 20 53 51 4c 69 74 65 42 61 73 65 2e 52 65 73 65   SQLiteBase.Rese
0fa0: 74 43 6f 6e 6e 65 63 74 69 6f 6e 28 5f 73 71 6c  tConnection(_sql
0fb0: 2c 20 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 20 20  , _sql);..      
0fc0: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f          SQLiteCo
0fd0: 6e 6e 65 63 74 69 6f 6e 50 6f 6f 6c 2e 41 64 64  nnectionPool.Add
0fe0: 28 5f 66 69 6c 65 4e 61 6d 65 2c 20 5f 73 71 6c  (_fileName, _sql
0ff0: 2c 20 5f 70 6f 6f 6c 56 65 72 73 69 6f 6e 29 3b  , _poolVersion);
1000: 0d 0a 0d 0a 23 69 66 20 44 45 42 55 47 20 26 26  ....#if DEBUG &&
1010: 20 21 4e 45 54 5f 43 4f 4d 50 41 43 54 5f 32 30   !NET_COMPACT_20
1020: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1030: 54 72 61 63 65 2e 57 72 69 74 65 4c 69 6e 65 28  Trace.WriteLine(
1040: 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 43  String.Format("C
1050: 6c 6f 73 65 20 28 50 6f 6f 6c 29 3a 20 7b 30 7d  lose (Pool): {0}
1060: 22 2c 20 5f 73 71 6c 29 29 3b 0d 0a 23 65 6e 64  ", _sql));..#end
1070: 69 66 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d  if..          }.
1080: 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d  .          else.
1090: 0a 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  .          {..  
10a0: 20 20 20 20 20 20 20 20 20 20 20 20 5f 73 71 6c              _sql
10b0: 2e 44 69 73 70 6f 73 65 28 29 3b 0d 0a 20 20 20  .Dispose();..   
10c0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
10d0: 20 20 20 20 5f 73 71 6c 20 3d 20 6e 75 6c 6c 3b      _sql = null;
10e0: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
10f0: 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f  ....    ////////
1100: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1110: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1120: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1130: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1140: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1150: 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 69  ///////....    i
1160: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
1170: 20 76 6f 69 64 20 43 61 6e 63 65 6c 28 29 0d 0a   void Cancel()..
1180: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e 73      {..      Uns
1190: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
11a0: 2e 73 71 6c 69 74 65 33 5f 69 6e 74 65 72 72 75  .sqlite3_interru
11b0: 70 74 28 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 7d  pt(_sql);..    }
11c0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
11d0: 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67   override string
11e0: 20 56 65 72 73 69 6f 6e 0d 0a 20 20 20 20 7b 0d   Version..    {.
11f0: 0a 20 20 20 20 20 20 67 65 74 0d 0a 20 20 20 20  .      get..    
1200: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74    {..        ret
1210: 75 72 6e 20 53 51 4c 69 74 65 33 2e 53 51 4c 69  urn SQLite3.SQLi
1220: 74 65 56 65 72 73 69 6f 6e 3b 0d 0a 20 20 20 20  teVersion;..    
1230: 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20    }..    }....  
1240: 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74 69    internal stati
1250: 63 20 73 74 72 69 6e 67 20 44 65 66 69 6e 65 43  c string DefineC
1260: 6f 6e 73 74 61 6e 74 73 0d 0a 20 20 20 20 7b 0d  onstants..    {.
1270: 0a 20 20 20 20 20 20 20 20 67 65 74 0d 0a 20 20  .        get..  
1280: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
1290: 20 20 20 20 20 53 74 72 69 6e 67 42 75 69 6c 64       StringBuild
12a0: 65 72 20 72 65 73 75 6c 74 20 3d 20 6e 65 77 20  er result = new 
12b0: 53 74 72 69 6e 67 42 75 69 6c 64 65 72 28 29 3b  StringBuilder();
12c0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 49 4c  ..            IL
12d0: 69 73 74 3c 73 74 72 69 6e 67 3e 20 6c 69 73 74  ist<string> list
12e0: 20 3d 20 53 51 4c 69 74 65 44 65 66 69 6e 65 43   = SQLiteDefineC
12f0: 6f 6e 73 74 61 6e 74 73 2e 4f 70 74 69 6f 6e 4c  onstants.OptionL
1300: 69 73 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ist;....        
1310: 20 20 20 20 69 66 20 28 6c 69 73 74 20 21 3d 20      if (list != 
1320: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
1330: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
1340: 20 20 20 20 20 20 66 6f 72 65 61 63 68 20 28 73        foreach (s
1350: 74 72 69 6e 67 20 65 6c 65 6d 65 6e 74 20 69 6e  tring element in
1360: 20 6c 69 73 74 29 0d 0a 20 20 20 20 20 20 20 20   list)..        
1370: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
1380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
1390: 66 20 28 65 6c 65 6d 65 6e 74 20 3d 3d 20 6e 75  f (element == nu
13a0: 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ll)..           
13b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e               con
13c0: 74 69 6e 75 65 3b 0d 0a 0d 0a 20 20 20 20 20 20  tinue;....      
13d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66                if
13e0: 20 28 72 65 73 75 6c 74 2e 4c 65 6e 67 74 68 20   (result.Length 
13f0: 3e 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20  > 0)..          
1400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65                re
1410: 73 75 6c 74 2e 41 70 70 65 6e 64 28 27 20 27 29  sult.Append(' ')
1420: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ;....           
1430: 20 20 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e           result.
1440: 41 70 70 65 6e 64 28 65 6c 65 6d 65 6e 74 29 3b  Append(element);
1450: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
1460: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20    }..           
1470: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20   }....          
1480: 20 20 72 65 74 75 72 6e 20 72 65 73 75 6c 74 2e    return result.
1490: 54 6f 53 74 72 69 6e 67 28 29 3b 0d 0a 20 20 20  ToString();..   
14a0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d       }..    }...
14b0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74  .    internal st
14c0: 61 74 69 63 20 73 74 72 69 6e 67 20 53 51 4c 69  atic string SQLi
14d0: 74 65 56 65 72 73 69 6f 6e 0d 0a 20 20 20 20 7b  teVersion..    {
14e0: 0d 0a 20 20 20 20 20 20 67 65 74 0d 0a 20 20 20  ..      get..   
14f0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65     {..        re
1500: 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e  turn UTF8ToStrin
1510: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
1520: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6c 69  thods.sqlite3_li
1530: 62 76 65 72 73 69 6f 6e 28 29 2c 20 2d 31 29 3b  bversion(), -1);
1540: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
1550: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
1560: 20 73 74 61 74 69 63 20 73 74 72 69 6e 67 20 53   static string S
1570: 51 4c 69 74 65 53 6f 75 72 63 65 49 64 0d 0a 20  QLiteSourceId.. 
1580: 20 20 20 7b 0d 0a 20 20 20 20 20 20 67 65 74 0d     {..      get.
1590: 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  .      {..      
15a0: 20 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53    return UTF8ToS
15b0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
15c0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
15d0: 33 5f 73 6f 75 72 63 65 69 64 28 29 2c 20 2d 31  3_sourceid(), -1
15e0: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  );..      }..   
15f0: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
1600: 61 6c 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c  al override bool
1610: 20 41 75 74 6f 43 6f 6d 6d 69 74 0d 0a 20 20 20   AutoCommit..   
1620: 20 7b 0d 0a 20 20 20 20 20 20 67 65 74 0d 0a 20   {..      get.. 
1630: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
1640: 72 65 74 75 72 6e 20 49 73 41 75 74 6f 63 6f 6d  return IsAutocom
1650: 6d 69 74 28 5f 73 71 6c 2c 20 5f 73 71 6c 29 3b  mit(_sql, _sql);
1660: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
1670: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
1680: 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 4c   override long L
1690: 61 73 74 49 6e 73 65 72 74 52 6f 77 49 64 0d 0a  astInsertRowId..
16a0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 67 65 74      {..      get
16b0: 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20  ..      {..     
16c0: 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65     return Unsafe
16d0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
16e0: 6c 69 74 65 33 5f 6c 61 73 74 5f 69 6e 73 65 72  lite3_last_inser
16f0: 74 5f 72 6f 77 69 64 28 5f 73 71 6c 29 3b 0d 0a  t_rowid(_sql);..
1700: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a        }..    }..
1710: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
1720: 76 65 72 72 69 64 65 20 69 6e 74 20 43 68 61 6e  verride int Chan
1730: 67 65 73 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ges..    {..    
1740: 20 20 67 65 74 0d 0a 20 20 20 20 20 20 7b 0d 0a    get..      {..
1750: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 55          return U
1760: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
1770: 64 73 2e 73 71 6c 69 74 65 33 5f 63 68 61 6e 67  ds.sqlite3_chang
1780: 65 73 28 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 20  es(_sql);..     
1790: 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20   }..    }....   
17a0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
17b0: 64 65 20 6c 6f 6e 67 20 4d 65 6d 6f 72 79 55 73  de long MemoryUs
17c0: 65 64 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  ed..    {..     
17d0: 20 67 65 74 0d 0a 20 20 20 20 20 20 7b 0d 0a 20   get..      {.. 
17e0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e         return Un
17f0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
1800: 73 2e 73 71 6c 69 74 65 33 5f 6d 65 6d 6f 72 79  s.sqlite3_memory
1810: 5f 75 73 65 64 28 29 3b 0d 0a 20 20 20 20 20 20  _used();..      
1820: 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  }..    }....    
1830: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
1840: 65 20 6c 6f 6e 67 20 4d 65 6d 6f 72 79 48 69 67  e long MemoryHig
1850: 68 77 61 74 65 72 0d 0a 20 20 20 20 7b 0d 0a 20  hwater..    {.. 
1860: 20 20 20 20 20 67 65 74 0d 0a 20 20 20 20 20 20       get..      
1870: 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  {..        retur
1880: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
1890: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6d 65  thods.sqlite3_me
18a0: 6d 6f 72 79 5f 68 69 67 68 77 61 74 65 72 28 30  mory_highwater(0
18b0: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  );..      }..   
18c0: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73   }....    /// <s
18d0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
18e0: 20 53 68 75 74 64 6f 77 6e 20 74 68 65 20 53 51   Shutdown the SQ
18f0: 4c 69 74 65 20 65 6e 67 69 6e 65 20 73 6f 20 74  Lite engine so t
1900: 68 61 74 20 69 74 20 63 61 6e 20 62 65 20 72 65  hat it can be re
1910: 73 74 61 72 74 65 64 20 77 69 74 68 20 64 69 66  started with dif
1920: 66 65 72 65 6e 74 20 63 6f 6e 66 69 67 20 6f 70  ferent config op
1930: 74 69 6f 6e 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20  tions...    /// 
1940: 57 65 20 64 65 70 65 6e 64 20 6f 6e 20 61 75 74  We depend on aut
1950: 6f 20 69 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e  o initialization
1960: 20 74 6f 20 72 65 63 6f 76 65 72 2e 0d 0a 20 20   to recover...  
1970: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
1980: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  ..    /// <retur
1990: 6e 73 3e 52 65 74 75 72 6e 73 20 61 20 72 65 73  ns>Returns a res
19a0: 75 6c 74 20 63 6f 64 65 3c 2f 72 65 74 75 72 6e  ult code</return
19b0: 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  s>..    internal
19c0: 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 53 68   override int Sh
19d0: 75 74 64 6f 77 6e 28 29 0d 0a 20 20 20 20 7b 0d  utdown()..    {.
19e0: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 72 63 20  .        int rc 
19f0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
1a00: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 73 68  thods.sqlite3_sh
1a10: 75 74 64 6f 77 6e 28 29 3b 0d 0a 20 20 20 20 20  utdown();..     
1a20: 20 20 20 72 65 74 75 72 6e 20 72 63 3b 0d 0a 20     return rc;.. 
1a30: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
1a40: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 62 6f  rnal override bo
1a50: 6f 6c 20 49 73 4f 70 65 6e 28 29 0d 0a 20 20 20  ol IsOpen()..   
1a60: 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75   {..        retu
1a70: 72 6e 20 28 5f 73 71 6c 20 21 3d 20 6e 75 6c 6c  rn (_sql != null
1a80: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
1a90: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
1aa0: 64 65 20 76 6f 69 64 20 4f 70 65 6e 28 73 74 72  de void Open(str
1ab0: 69 6e 67 20 73 74 72 46 69 6c 65 6e 61 6d 65 2c  ing strFilename,
1ac0: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
1ad0: 6e 46 6c 61 67 73 20 63 6f 6e 6e 65 63 74 69 6f  nFlags connectio
1ae0: 6e 46 6c 61 67 73 2c 20 53 51 4c 69 74 65 4f 70  nFlags, SQLiteOp
1af0: 65 6e 46 6c 61 67 73 45 6e 75 6d 20 6f 70 65 6e  enFlagsEnum open
1b00: 46 6c 61 67 73 2c 20 69 6e 74 20 6d 61 78 50 6f  Flags, int maxPo
1b10: 6f 6c 53 69 7a 65 2c 20 62 6f 6f 6c 20 75 73 65  olSize, bool use
1b20: 50 6f 6f 6c 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  Pool)..    {..  
1b30: 20 20 20 20 69 66 20 28 5f 73 71 6c 20 21 3d 20      if (_sql != 
1b40: 6e 75 6c 6c 29 20 72 65 74 75 72 6e 3b 0d 0a 0d  null) return;...
1b50: 0a 20 20 20 20 20 20 5f 75 73 65 50 6f 6f 6c 20  .      _usePool 
1b60: 3d 20 75 73 65 50 6f 6f 6c 3b 0d 0a 20 20 20 20  = usePool;..    
1b70: 20 20 5f 66 69 6c 65 4e 61 6d 65 20 3d 20 73 74    _fileName = st
1b80: 72 46 69 6c 65 6e 61 6d 65 3b 0d 0a 0d 0a 20 20  rFilename;....  
1b90: 20 20 20 20 69 66 20 28 75 73 65 50 6f 6f 6c 29      if (usePool)
1ba0: 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20  ..      {..     
1bb0: 20 20 20 5f 73 71 6c 20 3d 20 53 51 4c 69 74 65     _sql = SQLite
1bc0: 43 6f 6e 6e 65 63 74 69 6f 6e 50 6f 6f 6c 2e 52  ConnectionPool.R
1bd0: 65 6d 6f 76 65 28 73 74 72 46 69 6c 65 6e 61 6d  emove(strFilenam
1be0: 65 2c 20 6d 61 78 50 6f 6f 6c 53 69 7a 65 2c 20  e, maxPoolSize, 
1bf0: 6f 75 74 20 5f 70 6f 6f 6c 56 65 72 73 69 6f 6e  out _poolVersion
1c00: 29 3b 0d 0a 0d 0a 23 69 66 20 44 45 42 55 47 20  );....#if DEBUG 
1c10: 26 26 20 21 4e 45 54 5f 43 4f 4d 50 41 43 54 5f  && !NET_COMPACT_
1c20: 32 30 0d 0a 20 20 20 20 20 20 20 20 54 72 61 63  20..        Trac
1c30: 65 2e 57 72 69 74 65 4c 69 6e 65 28 53 74 72 69  e.WriteLine(Stri
1c40: 6e 67 2e 46 6f 72 6d 61 74 28 22 4f 70 65 6e 20  ng.Format("Open 
1c50: 28 50 6f 6f 6c 29 3a 20 7b 30 7d 22 2c 20 28 5f  (Pool): {0}", (_
1c60: 73 71 6c 20 21 3d 20 6e 75 6c 6c 29 20 3f 20 5f  sql != null) ? _
1c70: 73 71 6c 2e 54 6f 53 74 72 69 6e 67 28 29 20 3a  sql.ToString() :
1c80: 20 22 3c 6e 75 6c 6c 3e 22 29 29 3b 0d 0a 23 65   "<null>"));..#e
1c90: 6e 64 69 66 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d  ndif..      }...
1ca0: 0a 20 20 20 20 20 20 69 66 20 28 5f 73 71 6c 20  .      if (_sql 
1cb0: 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20  == null)..      
1cc0: 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e 74 50 74  {..        IntPt
1cd0: 72 20 64 62 3b 0d 0a 0d 0a 23 69 66 20 21 53 51  r db;....#if !SQ
1ce0: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
1cf0: 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55         int n = U
1d00: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
1d10: 64 73 2e 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f  ds.sqlite3_open_
1d20: 69 6e 74 65 72 6f 70 28 54 6f 55 54 46 38 28 73  interop(ToUTF8(s
1d30: 74 72 46 69 6c 65 6e 61 6d 65 29 2c 20 28 69 6e  trFilename), (in
1d40: 74 29 6f 70 65 6e 46 6c 61 67 73 2c 20 6f 75 74  t)openFlags, out
1d50: 20 64 62 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20   db);..#else..  
1d60: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
1d70: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
1d80: 73 2e 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f 76  s.sqlite3_open_v
1d90: 32 28 54 6f 55 54 46 38 28 73 74 72 46 69 6c 65  2(ToUTF8(strFile
1da0: 6e 61 6d 65 29 2c 20 6f 75 74 20 64 62 2c 20 28  name), out db, (
1db0: 69 6e 74 29 6f 70 65 6e 46 6c 61 67 73 2c 20 49  int)openFlags, I
1dc0: 6e 74 50 74 72 2e 5a 65 72 6f 29 3b 0d 0a 23 65  ntPtr.Zero);..#e
1dd0: 6e 64 69 66 0d 0a 0d 0a 23 69 66 20 44 45 42 55  ndif....#if DEBU
1de0: 47 20 26 26 20 21 4e 45 54 5f 43 4f 4d 50 41 43  G && !NET_COMPAC
1df0: 54 5f 32 30 0d 0a 20 20 20 20 20 20 20 20 54 72  T_20..        Tr
1e00: 61 63 65 2e 57 72 69 74 65 4c 69 6e 65 28 53 74  ace.WriteLine(St
1e10: 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 4f 70 65  ring.Format("Ope
1e20: 6e 3a 20 7b 30 7d 22 2c 20 64 62 29 29 3b 0d 0a  n: {0}", db));..
1e30: 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20  #endif....      
1e40: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
1e50: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
1e60: 65 70 74 69 6f 6e 28 6e 2c 20 6e 75 6c 6c 29 3b  eption(n, null);
1e70: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 5f 73 71 6c  ....        _sql
1e80: 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f 6e   = new SQLiteCon
1e90: 6e 65 63 74 69 6f 6e 48 61 6e 64 6c 65 28 64 62  nectionHandle(db
1ea0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 6c 6f 63 6b  );..        lock
1eb0: 20 28 5f 73 71 6c 29 20 7b 20 2f 2a 20 48 41 43   (_sql) { /* HAC
1ec0: 4b 3a 20 46 6f 72 63 65 20 74 68 65 20 53 79 6e  K: Force the Syn
1ed0: 63 42 6c 6f 63 6b 20 74 6f 20 62 65 20 22 63 72  cBlock to be "cr
1ee0: 65 61 74 65 64 22 20 6e 6f 77 2e 20 2a 2f 20 7d  eated" now. */ }
1ef0: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20  ..      }..     
1f00: 20 2f 2f 20 42 69 6e 64 20 66 75 6e 63 74 69 6f   // Bind functio
1f10: 6e 73 20 74 6f 20 74 68 69 73 20 63 6f 6e 6e 65  ns to this conne
1f20: 63 74 69 6f 6e 2e 20 20 49 66 20 61 6e 79 20 70  ction.  If any p
1f30: 72 65 76 69 6f 75 73 20 66 75 6e 63 74 69 6f 6e  revious function
1f40: 73 20 6f 66 20 74 68 65 20 73 61 6d 65 20 6e 61  s of the same na
1f50: 6d 65 0d 0a 20 20 20 20 20 20 2f 2f 20 77 65 72  me..      // wer
1f60: 65 20 61 6c 72 65 61 64 79 20 62 6f 75 6e 64 2c  e already bound,
1f70: 20 74 68 65 6e 20 74 68 65 20 6e 65 77 20 62 69   then the new bi
1f80: 6e 64 69 6e 67 73 20 72 65 70 6c 61 63 65 20 74  ndings replace t
1f90: 68 65 20 6f 6c 64 2e 0d 0a 20 20 20 20 20 20 5f  he old...      _
1fa0: 66 75 6e 63 74 69 6f 6e 73 41 72 72 61 79 20 3d  functionsArray =
1fb0: 20 53 51 4c 69 74 65 46 75 6e 63 74 69 6f 6e 2e   SQLiteFunction.
1fc0: 42 69 6e 64 46 75 6e 63 74 69 6f 6e 73 28 74 68  BindFunctions(th
1fd0: 69 73 2c 20 63 6f 6e 6e 65 63 74 69 6f 6e 46 6c  is, connectionFl
1fe0: 61 67 73 29 3b 0d 0a 20 20 20 20 20 20 53 65 74  ags);..      Set
1ff0: 54 69 6d 65 6f 75 74 28 30 29 3b 0d 0a 20 20 20  Timeout(0);..   
2000: 20 20 20 47 43 2e 4b 65 65 70 41 6c 69 76 65 28     GC.KeepAlive(
2010: 5f 73 71 6c 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  _sql);..    }...
2020: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
2030: 65 72 72 69 64 65 20 76 6f 69 64 20 43 6c 65 61  erride void Clea
2040: 72 50 6f 6f 6c 28 29 0d 0a 20 20 20 20 7b 0d 0a  rPool()..    {..
2050: 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e        SQLiteConn
2060: 65 63 74 69 6f 6e 50 6f 6f 6c 2e 43 6c 65 61 72  ectionPool.Clear
2070: 50 6f 6f 6c 28 5f 66 69 6c 65 4e 61 6d 65 29 3b  Pool(_fileName);
2080: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
2090: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
20a0: 20 69 6e 74 20 43 6f 75 6e 74 50 6f 6f 6c 28 29   int CountPool()
20b0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20  ..    {..       
20c0: 20 44 69 63 74 69 6f 6e 61 72 79 3c 73 74 72 69   Dictionary<stri
20d0: 6e 67 2c 20 69 6e 74 3e 20 63 6f 75 6e 74 73 20  ng, int> counts 
20e0: 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 20  = null;..       
20f0: 20 69 6e 74 20 6f 70 65 6e 43 6f 75 6e 74 20 3d   int openCount =
2100: 20 30 3b 0d 0a 20 20 20 20 20 20 20 20 69 6e 74   0;..        int
2110: 20 63 6c 6f 73 65 43 6f 75 6e 74 20 3d 20 30 3b   closeCount = 0;
2120: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 74 6f  ..        int to
2130: 74 61 6c 43 6f 75 6e 74 20 3d 20 30 3b 0d 0a 0d  talCount = 0;...
2140: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 43  .        SQLiteC
2150: 6f 6e 6e 65 63 74 69 6f 6e 50 6f 6f 6c 2e 47 65  onnectionPool.Ge
2160: 74 43 6f 75 6e 74 73 28 5f 66 69 6c 65 4e 61 6d  tCounts(_fileNam
2170: 65 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  e,..            
2180: 72 65 66 20 63 6f 75 6e 74 73 2c 20 72 65 66 20  ref counts, ref 
2190: 6f 70 65 6e 43 6f 75 6e 74 2c 20 72 65 66 20 63  openCount, ref c
21a0: 6c 6f 73 65 43 6f 75 6e 74 2c 0d 0a 20 20 20 20  loseCount,..    
21b0: 20 20 20 20 20 20 20 20 72 65 66 20 74 6f 74 61          ref tota
21c0: 6c 43 6f 75 6e 74 29 3b 0d 0a 0d 0a 20 20 20 20  lCount);....    
21d0: 20 20 20 20 72 65 74 75 72 6e 20 74 6f 74 61 6c      return total
21e0: 43 6f 75 6e 74 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  Count;..    }...
21f0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
2200: 65 72 72 69 64 65 20 76 6f 69 64 20 53 65 74 54  erride void SetT
2210: 69 6d 65 6f 75 74 28 69 6e 74 20 6e 54 69 6d 65  imeout(int nTime
2220: 6f 75 74 4d 53 29 0d 0a 20 20 20 20 7b 0d 0a 20  outMS)..    {.. 
2230: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73       int n = Uns
2240: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
2250: 2e 73 71 6c 69 74 65 33 5f 62 75 73 79 5f 74 69  .sqlite3_busy_ti
2260: 6d 65 6f 75 74 28 5f 73 71 6c 2c 20 6e 54 69 6d  meout(_sql, nTim
2270: 65 6f 75 74 4d 53 29 3b 0d 0a 20 20 20 20 20 20  eoutMS);..      
2280: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
2290: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
22a0: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
22b0: 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d  rror());..    }.
22c0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
22d0: 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20 53 74  override bool St
22e0: 65 70 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  ep(SQLiteStateme
22f0: 6e 74 20 73 74 6d 74 29 0d 0a 20 20 20 20 7b 0d  nt stmt)..    {.
2300: 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b 0d 0a 20  .      int n;.. 
2310: 20 20 20 20 20 52 61 6e 64 6f 6d 20 72 6e 64 20       Random rnd 
2320: 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 75  = null;..      u
2330: 69 6e 74 20 73 74 61 72 74 74 69 63 6b 20 3d 20  int starttick = 
2340: 28 75 69 6e 74 29 45 6e 76 69 72 6f 6e 6d 65 6e  (uint)Environmen
2350: 74 2e 54 69 63 6b 43 6f 75 6e 74 3b 0d 0a 20 20  t.TickCount;..  
2360: 20 20 20 20 75 69 6e 74 20 74 69 6d 65 6f 75 74      uint timeout
2370: 20 3d 20 28 75 69 6e 74 29 28 73 74 6d 74 2e 5f   = (uint)(stmt._
2380: 63 6f 6d 6d 61 6e 64 2e 5f 63 6f 6d 6d 61 6e 64  command._command
2390: 54 69 6d 65 6f 75 74 20 2a 20 31 30 30 30 29 3b  Timeout * 1000);
23a0: 0d 0a 0d 0a 20 20 20 20 20 20 77 68 69 6c 65 20  ....      while 
23b0: 28 74 72 75 65 29 0d 0a 20 20 20 20 20 20 7b 0d  (true)..      {.
23c0: 0a 20 20 20 20 20 20 20 20 6e 20 3d 20 55 6e 73  .        n = Uns
23d0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
23e0: 2e 73 71 6c 69 74 65 33 5f 73 74 65 70 28 73 74  .sqlite3_step(st
23f0: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29  mt._sqlite_stmt)
2400: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ;....        if 
2410: 28 6e 20 3d 3d 20 31 30 30 29 20 72 65 74 75 72  (n == 100) retur
2420: 6e 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20  n true;..       
2430: 20 69 66 20 28 6e 20 3d 3d 20 31 30 31 29 20 72   if (n == 101) r
2440: 65 74 75 72 6e 20 66 61 6c 73 65 3b 0d 0a 0d 0a  eturn false;....
2450: 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20          if (n > 
2460: 30 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  0)..        {.. 
2470: 20 20 20 20 20 20 20 20 20 69 6e 74 20 72 3b 0d           int r;.
2480: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20  ...          // 
2490: 41 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 72 65  An error occurre
24a0: 64 2c 20 61 74 74 65 6d 70 74 20 74 6f 20 72 65  d, attempt to re
24b0: 73 65 74 20 74 68 65 20 73 74 61 74 65 6d 65 6e  set the statemen
24c0: 74 2e 20 20 49 66 20 74 68 65 20 72 65 73 65 74  t.  If the reset
24d0: 20 77 6f 72 6b 65 64 20 62 65 63 61 75 73 65 20   worked because 
24e0: 74 68 65 0d 0a 20 20 20 20 20 20 20 20 20 20 2f  the..          /
24f0: 2f 20 73 63 68 65 6d 61 20 68 61 73 20 63 68 61  / schema has cha
2500: 6e 67 65 64 2c 20 72 65 2d 74 72 79 20 74 68 65  nged, re-try the
2510: 20 73 74 65 70 20 61 67 61 69 6e 2e 20 20 49 66   step again.  If
2520: 20 69 74 20 65 72 72 6f 72 65 64 20 6f 75 72 20   it errored our 
2530: 62 65 63 61 75 73 65 20 74 68 65 20 64 61 74 61  because the data
2540: 62 61 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20  base..          
2550: 2f 2f 20 69 73 20 6c 6f 63 6b 65 64 2c 20 74 68  // is locked, th
2560: 65 6e 20 6b 65 65 70 20 72 65 74 72 79 69 6e 67  en keep retrying
2570: 20 75 6e 74 69 6c 20 74 68 65 20 63 6f 6d 6d 61   until the comma
2580: 6e 64 20 74 69 6d 65 6f 75 74 20 6f 63 63 75 72  nd timeout occur
2590: 73 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 72 20  s...          r 
25a0: 3d 20 52 65 73 65 74 28 73 74 6d 74 29 3b 0d 0a  = Reset(stmt);..
25b0: 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28  ..          if (
25c0: 72 20 3d 3d 20 30 29 0d 0a 20 20 20 20 20 20 20  r == 0)..       
25d0: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53       throw new S
25e0: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
25f0: 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29  , GetLastError()
2600: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
2610: 65 6c 73 65 20 69 66 20 28 28 72 20 3d 3d 20 36  else if ((r == 6
2620: 20 7c 7c 20 72 20 3d 3d 20 35 29 20 26 26 20 73   || r == 5) && s
2630: 74 6d 74 2e 5f 63 6f 6d 6d 61 6e 64 20 21 3d 20  tmt._command != 
2640: 6e 75 6c 6c 29 20 2f 2f 20 53 51 4c 49 54 45 5f  null) // SQLITE_
2650: 4c 4f 43 4b 45 44 20 7c 7c 20 53 51 4c 49 54 45  LOCKED || SQLITE
2660: 5f 42 55 53 59 0d 0a 20 20 20 20 20 20 20 20 20  _BUSY..         
2670: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
2680: 2f 2f 20 4b 65 65 70 20 74 72 79 69 6e 67 0d 0a  // Keep trying..
2690: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
26a0: 72 6e 64 20 3d 3d 20 6e 75 6c 6c 29 20 2f 2f 20  rnd == null) // 
26b0: 46 69 72 73 74 20 74 69 6d 65 20 77 65 27 76 65  First time we've
26c0: 20 65 6e 63 6f 75 6e 74 65 72 65 64 20 74 68 65   encountered the
26d0: 20 6c 6f 63 6b 0d 0a 20 20 20 20 20 20 20 20 20   lock..         
26e0: 20 20 20 20 20 72 6e 64 20 3d 20 6e 65 77 20 52       rnd = new R
26f0: 61 6e 64 6f 6d 28 29 3b 0d 0a 0d 0a 20 20 20 20  andom();....    
2700: 20 20 20 20 20 20 20 20 2f 2f 20 49 66 20 77 65          // If we
2710: 27 76 65 20 65 78 63 65 65 64 65 64 20 74 68 65  've exceeded the
2720: 20 63 6f 6d 6d 61 6e 64 27 73 20 74 69 6d 65 6f   command's timeo
2730: 75 74 2c 20 67 69 76 65 20 75 70 20 61 6e 64 20  ut, give up and 
2740: 74 68 72 6f 77 20 61 6e 20 65 72 72 6f 72 0d 0a  throw an error..
2750: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28              if (
2760: 28 75 69 6e 74 29 45 6e 76 69 72 6f 6e 6d 65 6e  (uint)Environmen
2770: 74 2e 54 69 63 6b 43 6f 75 6e 74 20 2d 20 73 74  t.TickCount - st
2780: 61 72 74 74 69 63 6b 20 3e 20 74 69 6d 65 6f 75  arttick > timeou
2790: 74 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  t)..            
27a0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
27b0: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
27c0: 65 45 78 63 65 70 74 69 6f 6e 28 72 2c 20 47 65  eException(r, Ge
27d0: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
27e0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
27f0: 20 20 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d             else.
2800: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a  .            {..
2810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f                //
2820: 20 4f 74 68 65 72 77 69 73 65 20 73 6c 65 65 70   Otherwise sleep
2830: 20 66 6f 72 20 61 20 72 61 6e 64 6f 6d 20 61 6d   for a random am
2840: 6f 75 6e 74 20 6f 66 20 74 69 6d 65 20 75 70 20  ount of time up 
2850: 74 6f 20 31 35 30 6d 73 0d 0a 20 20 20 20 20 20  to 150ms..      
2860: 20 20 20 20 20 20 20 20 53 79 73 74 65 6d 2e 54          System.T
2870: 68 72 65 61 64 69 6e 67 2e 54 68 72 65 61 64 2e  hreading.Thread.
2880: 53 6c 65 65 70 28 72 6e 64 2e 4e 65 78 74 28 31  Sleep(rnd.Next(1
2890: 2c 20 31 35 30 29 29 3b 0d 0a 20 20 20 20 20 20  , 150));..      
28a0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
28b0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d     }..        }.
28c0: 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d  .      }..    }.
28d0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
28e0: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 52 65 73  override int Res
28f0: 65 74 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  et(SQLiteStateme
2900: 6e 74 20 73 74 6d 74 29 0d 0a 20 20 20 20 7b 0d  nt stmt)..    {.
2910: 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b 0d 0a 0d  .      int n;...
2920: 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41  .#if !SQLITE_STA
2930: 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 6e 20 3d  NDARD..      n =
2940: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
2950: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73  hods.sqlite3_res
2960: 65 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e  et_interop(stmt.
2970: 5f 73 71 6c 69 74 65 5f 73 74 6d 74 29 3b 0d 0a  _sqlite_stmt);..
2980: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 6e 20 3d  #else..      n =
2990: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
29a0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73  hods.sqlite3_res
29b0: 65 74 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f  et(stmt._sqlite_
29c0: 73 74 6d 74 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  stmt);..#endif..
29d0: 0d 0a 20 20 20 20 20 20 2f 2f 20 49 66 20 74 68  ..      // If th
29e0: 65 20 73 63 68 65 6d 61 20 63 68 61 6e 67 65 64  e schema changed
29f0: 2c 20 74 72 79 20 61 6e 64 20 72 65 2d 70 72 65  , try and re-pre
2a00: 70 61 72 65 20 69 74 0d 0a 20 20 20 20 20 20 69  pare it..      i
2a10: 66 20 28 6e 20 3d 3d 20 31 37 29 20 2f 2f 20 53  f (n == 17) // S
2a20: 51 4c 49 54 45 5f 53 43 48 45 4d 41 0d 0a 20 20  QLITE_SCHEMA..  
2a30: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 2f      {..        /
2a40: 2f 20 52 65 63 72 65 61 74 65 20 61 20 64 75 6d  / Recreate a dum
2a50: 6d 79 20 73 74 61 74 65 6d 65 6e 74 0d 0a 20 20  my statement..  
2a60: 20 20 20 20 20 20 73 74 72 69 6e 67 20 73 74 72        string str
2a70: 3b 0d 0a 20 20 20 20 20 20 20 20 75 73 69 6e 67  ;..        using
2a80: 20 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e   (SQLiteStatemen
2a90: 74 20 74 6d 70 20 3d 20 50 72 65 70 61 72 65 28  t tmp = Prepare(
2aa0: 6e 75 6c 6c 2c 20 73 74 6d 74 2e 5f 73 71 6c 53  null, stmt._sqlS
2ab0: 74 61 74 65 6d 65 6e 74 2c 20 6e 75 6c 6c 2c 20  tatement, null, 
2ac0: 28 75 69 6e 74 29 28 73 74 6d 74 2e 5f 63 6f 6d  (uint)(stmt._com
2ad0: 6d 61 6e 64 2e 5f 63 6f 6d 6d 61 6e 64 54 69 6d  mand._commandTim
2ae0: 65 6f 75 74 20 2a 20 31 30 30 30 29 2c 20 6f 75  eout * 1000), ou
2af0: 74 20 73 74 72 29 29 0d 0a 20 20 20 20 20 20 20  t str))..       
2b00: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 2f 2f   {..          //
2b10: 20 46 69 6e 61 6c 69 7a 65 20 74 68 65 20 65 78   Finalize the ex
2b20: 69 73 74 69 6e 67 20 73 74 61 74 65 6d 65 6e 74  isting statement
2b30: 0d 0a 20 20 20 20 20 20 20 20 20 20 73 74 6d 74  ..          stmt
2b40: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2e 44 69  ._sqlite_stmt.Di
2b50: 73 70 6f 73 65 28 29 3b 0d 0a 20 20 20 20 20 20  spose();..      
2b60: 20 20 20 20 2f 2f 20 52 65 61 73 73 69 67 6e 20      // Reassign 
2b70: 61 20 6e 65 77 20 73 74 61 74 65 6d 65 6e 74 20  a new statement 
2b80: 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 6f  pointer to the o
2b90: 6c 64 20 73 74 61 74 65 6d 65 6e 74 20 61 6e 64  ld statement and
2ba0: 20 63 6c 65 61 72 20 74 68 65 20 74 65 6d 70 6f   clear the tempo
2bb0: 72 61 72 79 20 6f 6e 65 0d 0a 20 20 20 20 20 20  rary one..      
2bc0: 20 20 20 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65      stmt._sqlite
2bd0: 5f 73 74 6d 74 20 3d 20 74 6d 70 2e 5f 73 71 6c  _stmt = tmp._sql
2be0: 69 74 65 5f 73 74 6d 74 3b 0d 0a 20 20 20 20 20  ite_stmt;..     
2bf0: 20 20 20 20 20 74 6d 70 2e 5f 73 71 6c 69 74 65       tmp._sqlite
2c00: 5f 73 74 6d 74 20 3d 20 6e 75 6c 6c 3b 0d 0a 0d  _stmt = null;...
2c10: 0a 20 20 20 20 20 20 20 20 20 20 2f 2f 20 52 65  .          // Re
2c20: 61 70 70 6c 79 20 70 61 72 61 6d 65 74 65 72 73  apply parameters
2c30: 0d 0a 20 20 20 20 20 20 20 20 20 20 73 74 6d 74  ..          stmt
2c40: 2e 42 69 6e 64 50 61 72 61 6d 65 74 65 72 73 28  .BindParameters(
2c50: 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20  );..        }.. 
2c60: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 2d 31         return -1
2c70: 3b 20 2f 2f 20 52 65 73 65 74 20 77 61 73 20 4f  ; // Reset was O
2c80: 4b 2c 20 77 69 74 68 20 73 63 68 65 6d 61 20 63  K, with schema c
2c90: 68 61 6e 67 65 0d 0a 20 20 20 20 20 20 7d 0d 0a  hange..      }..
2ca0: 20 20 20 20 20 20 65 6c 73 65 20 69 66 20 28 6e        else if (n
2cb0: 20 3d 3d 20 36 20 7c 7c 20 6e 20 3d 3d 20 35 29   == 6 || n == 5)
2cc0: 20 2f 2f 20 53 51 4c 49 54 45 5f 4c 4f 43 4b 45   // SQLITE_LOCKE
2cd0: 44 20 7c 7c 20 53 51 4c 49 54 45 5f 42 55 53 59  D || SQLITE_BUSY
2ce0: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
2cf0: 20 6e 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20   n;....      if 
2d00: 28 6e 20 3e 20 30 29 0d 0a 20 20 20 20 20 20 20  (n > 0)..       
2d10: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
2d20: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65  eException(n, Ge
2d30: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
2d40: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 30  ..      return 0
2d50: 3b 20 2f 2f 20 57 65 20 72 65 73 65 74 20 4f 4b  ; // We reset OK
2d60: 2c 20 6e 6f 20 73 63 68 65 6d 61 20 63 68 61 6e  , no schema chan
2d70: 67 65 73 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  ges..    }....  
2d80: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2d90: 69 64 65 20 73 74 72 69 6e 67 20 47 65 74 4c 61  ide string GetLa
2da0: 73 74 45 72 72 6f 72 28 29 0d 0a 20 20 20 20 7b  stError()..    {
2db0: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 53  ..      return S
2dc0: 51 4c 69 74 65 42 61 73 65 2e 47 65 74 4c 61 73  QLiteBase.GetLas
2dd0: 74 45 72 72 6f 72 28 5f 73 71 6c 2c 20 5f 73 71  tError(_sql, _sq
2de0: 6c 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  l);..    }....  
2df0: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
2e00: 69 64 65 20 53 51 4c 69 74 65 53 74 61 74 65 6d  ide SQLiteStatem
2e10: 65 6e 74 20 50 72 65 70 61 72 65 28 53 51 4c 69  ent Prepare(SQLi
2e20: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6e 6e  teConnection cnn
2e30: 2c 20 73 74 72 69 6e 67 20 73 74 72 53 71 6c 2c  , string strSql,
2e40: 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74   SQLiteStatement
2e50: 20 70 72 65 76 69 6f 75 73 2c 20 75 69 6e 74 20   previous, uint 
2e60: 74 69 6d 65 6f 75 74 4d 53 2c 20 6f 75 74 20 73  timeoutMS, out s
2e70: 74 72 69 6e 67 20 73 74 72 52 65 6d 61 69 6e 29  tring strRemain)
2e80: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69  ..    {..      i
2e90: 66 20 28 21 53 74 72 69 6e 67 2e 49 73 4e 75 6c  f (!String.IsNul
2ea0: 6c 4f 72 45 6d 70 74 79 28 73 74 72 53 71 6c 29  lOrEmpty(strSql)
2eb0: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  )..      {..    
2ec0: 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 20 20      //..        
2ed0: 2f 2f 20 4e 4f 54 45 3a 20 53 51 4c 69 74 65 20  // NOTE: SQLite 
2ee0: 64 6f 65 73 20 6e 6f 74 20 73 75 70 70 6f 72 74  does not support
2ef0: 20 74 68 65 20 63 6f 6e 63 65 70 74 20 6f 66 20   the concept of 
2f00: 73 65 70 61 72 61 74 65 20 73 63 68 65 6d 61 73  separate schemas
2f10: 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20  ..        //    
2f20: 20 20 20 69 6e 20 6f 6e 65 20 64 61 74 61 62 61     in one databa
2f30: 73 65 3b 20 74 68 65 72 65 66 6f 72 65 2c 20 72  se; therefore, r
2f40: 65 6d 6f 76 65 20 74 68 65 20 62 61 73 65 20 73  emove the base s
2f50: 63 68 65 6d 61 20 6e 61 6d 65 0d 0a 20 20 20 20  chema name..    
2f60: 20 20 20 20 2f 2f 20 20 20 20 20 20 20 75 73 65      //       use
2f70: 64 20 74 6f 20 73 6d 6f 6f 74 68 20 69 6e 74 65  d to smooth inte
2f80: 67 72 61 74 69 6f 6e 20 77 69 74 68 20 74 68 65  gration with the
2f90: 20 62 61 73 65 20 2e 4e 45 54 20 46 72 61 6d 65   base .NET Frame
2fa0: 77 6f 72 6b 0d 0a 20 20 20 20 20 20 20 20 2f 2f  work..        //
2fb0: 20 20 20 20 20 20 20 64 61 74 61 20 63 6c 61 73         data clas
2fc0: 73 65 73 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f  ses...        //
2fd0: 0d 0a 20 20 20 20 20 20 20 20 73 74 72 69 6e 67  ..        string
2fe0: 20 62 61 73 65 53 63 68 65 6d 61 4e 61 6d 65 20   baseSchemaName 
2ff0: 3d 20 28 63 6e 6e 20 21 3d 20 6e 75 6c 6c 29 20  = (cnn != null) 
3000: 3f 20 63 6e 6e 2e 5f 62 61 73 65 53 63 68 65 6d  ? cnn._baseSchem
3010: 61 4e 61 6d 65 20 3a 20 6e 75 6c 6c 3b 0d 0a 0d  aName : null;...
3020: 0a 20 20 20 20 20 20 20 20 69 66 20 28 21 53 74  .        if (!St
3030: 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45 6d 70  ring.IsNullOrEmp
3040: 74 79 28 62 61 73 65 53 63 68 65 6d 61 4e 61 6d  ty(baseSchemaNam
3050: 65 29 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  e))..        {..
3060: 20 20 20 20 20 20 20 20 20 20 73 74 72 53 71 6c            strSql
3070: 20 3d 20 73 74 72 53 71 6c 2e 52 65 70 6c 61 63   = strSql.Replac
3080: 65 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  e(..            
3090: 20 20 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28    String.Format(
30a0: 22 5b 7b 30 7d 5d 2e 22 2c 20 62 61 73 65 53 63  "[{0}].", baseSc
30b0: 68 65 6d 61 4e 61 6d 65 29 2c 20 53 74 72 69 6e  hemaName), Strin
30c0: 67 2e 45 6d 70 74 79 29 3b 0d 0a 0d 0a 20 20 20  g.Empty);....   
30d0: 20 20 20 20 20 20 20 73 74 72 53 71 6c 20 3d 20         strSql = 
30e0: 73 74 72 53 71 6c 2e 52 65 70 6c 61 63 65 28 0d  strSql.Replace(.
30f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53  .              S
3100: 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 7b 30  tring.Format("{0
3110: 7d 2e 22 2c 20 62 61 73 65 53 63 68 65 6d 61 4e  }.", baseSchemaN
3120: 61 6d 65 29 2c 20 53 74 72 69 6e 67 2e 45 6d 70  ame), String.Emp
3130: 74 79 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ty);..        }.
3140: 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  .      }....    
3150: 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69    SQLiteConnecti
3160: 6f 6e 46 6c 61 67 73 20 66 6c 61 67 73 20 3d 0d  onFlags flags =.
3170: 0a 20 20 20 20 20 20 20 20 20 20 28 63 6e 6e 20  .          (cnn 
3180: 21 3d 20 6e 75 6c 6c 29 20 3f 20 63 6e 6e 2e 46  != null) ? cnn.F
3190: 6c 61 67 73 20 3a 20 53 51 4c 69 74 65 43 6f 6e  lags : SQLiteCon
31a0: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 44 65 66  nectionFlags.Def
31b0: 61 75 6c 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c  ault;....#if !PL
31c0: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
31d0: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 69  AMEWORK..      i
31e0: 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69  f ((flags & SQLi
31f0: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
3200: 73 2e 4c 6f 67 50 72 65 70 61 72 65 29 20 3d 3d  s.LogPrepare) ==
3210: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
3220: 6e 46 6c 61 67 73 2e 4c 6f 67 50 72 65 70 61 72  nFlags.LogPrepar
3230: 65 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20  e)..      {..   
3240: 20 20 20 20 20 20 20 69 66 20 28 28 73 74 72 53         if ((strS
3250: 71 6c 20 3d 3d 20 6e 75 6c 6c 29 20 7c 7c 20 28  ql == null) || (
3260: 73 74 72 53 71 6c 2e 4c 65 6e 67 74 68 20 3d 3d  strSql.Length ==
3270: 20 30 29 20 7c 7c 20 28 73 74 72 53 71 6c 2e 54   0) || (strSql.T
3280: 72 69 6d 28 29 2e 4c 65 6e 67 74 68 20 3d 3d 20  rim().Length == 
3290: 30 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  0))..           
32a0: 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67     SQLiteLog.Log
32b0: 4d 65 73 73 61 67 65 28 30 2c 20 22 50 72 65 70  Message(0, "Prep
32c0: 61 72 69 6e 67 20 7b 3c 6e 6f 74 68 69 6e 67 3e  aring {<nothing>
32d0: 7d 2e 2e 2e 22 29 3b 0d 0a 20 20 20 20 20 20 20  }...");..       
32e0: 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 20     else..       
32f0: 20 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67         SQLiteLog
3300: 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53  .LogMessage(0, S
3310: 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22 50 72  tring.Format("Pr
3320: 65 70 61 72 69 6e 67 20 7b 7b 7b 30 7d 7d 7d 2e  eparing {{{0}}}.
3330: 2e 2e 22 2c 20 73 74 72 53 71 6c 29 29 3b 0d 0a  ..", strSql));..
3340: 20 20 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d        }..#endif.
3350: 0a 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72 20  ...      IntPtr 
3360: 73 74 6d 74 20 3d 20 49 6e 74 50 74 72 2e 5a 65  stmt = IntPtr.Ze
3370: 72 6f 3b 0d 0a 20 20 20 20 20 20 49 6e 74 50 74  ro;..      IntPt
3380: 72 20 70 74 72 20 3d 20 49 6e 74 50 74 72 2e 5a  r ptr = IntPtr.Z
3390: 65 72 6f 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20  ero;..      int 
33a0: 6c 65 6e 20 3d 20 30 3b 0d 0a 20 20 20 20 20 20  len = 0;..      
33b0: 69 6e 74 20 6e 20 3d 20 31 37 3b 0d 0a 20 20 20  int n = 17;..   
33c0: 20 20 20 69 6e 74 20 72 65 74 72 69 65 73 20 3d     int retries =
33d0: 20 30 3b 0d 0a 20 20 20 20 20 20 62 79 74 65 5b   0;..      byte[
33e0: 5d 20 62 20 3d 20 54 6f 55 54 46 38 28 73 74 72  ] b = ToUTF8(str
33f0: 53 71 6c 29 3b 0d 0a 20 20 20 20 20 20 73 74 72  Sql);..      str
3400: 69 6e 67 20 74 79 70 65 64 65 66 73 20 3d 20 6e  ing typedefs = n
3410: 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 53 51 4c 69  ull;..      SQLi
3420: 74 65 53 74 61 74 65 6d 65 6e 74 20 63 6d 64 20  teStatement cmd 
3430: 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20 20 52  = null;..      R
3440: 61 6e 64 6f 6d 20 72 6e 64 20 3d 20 6e 75 6c 6c  andom rnd = null
3450: 3b 0d 0a 20 20 20 20 20 20 75 69 6e 74 20 73 74  ;..      uint st
3460: 61 72 74 74 69 63 6b 20 3d 20 28 75 69 6e 74 29  arttick = (uint)
3470: 45 6e 76 69 72 6f 6e 6d 65 6e 74 2e 54 69 63 6b  Environment.Tick
3480: 43 6f 75 6e 74 3b 0d 0a 0d 0a 20 20 20 20 20 20  Count;....      
3490: 47 43 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20  GCHandle handle 
34a0: 3d 20 47 43 48 61 6e 64 6c 65 2e 41 6c 6c 6f 63  = GCHandle.Alloc
34b0: 28 62 2c 20 47 43 48 61 6e 64 6c 65 54 79 70 65  (b, GCHandleType
34c0: 2e 50 69 6e 6e 65 64 29 3b 0d 0a 20 20 20 20 20  .Pinned);..     
34d0: 20 49 6e 74 50 74 72 20 70 73 71 6c 20 3d 20 68   IntPtr psql = h
34e0: 61 6e 64 6c 65 2e 41 64 64 72 4f 66 50 69 6e 6e  andle.AddrOfPinn
34f0: 65 64 4f 62 6a 65 63 74 28 29 3b 0d 0a 20 20 20  edObject();..   
3500: 20 20 20 74 72 79 0d 0a 20 20 20 20 20 20 7b 0d     try..      {.
3510: 0a 20 20 20 20 20 20 20 20 77 68 69 6c 65 20 28  .        while (
3520: 28 6e 20 3d 3d 20 31 37 20 7c 7c 20 6e 20 3d 3d  (n == 17 || n ==
3530: 20 36 20 7c 7c 20 6e 20 3d 3d 20 35 29 20 26 26   6 || n == 5) &&
3540: 20 72 65 74 72 69 65 73 20 3c 20 33 29 0d 0a 20   retries < 3).. 
3550: 20 20 20 20 20 20 20 7b 0d 0a 23 69 66 20 21 53         {..#if !S
3560: 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a  QLITE_STANDARD..
3570: 20 20 20 20 20 20 20 20 20 20 6e 20 3d 20 55 6e            n = Un
3580: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
3590: 73 2e 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  s.sqlite3_prepar
35a0: 65 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20  e_interop(_sql, 
35b0: 70 73 71 6c 2c 20 62 2e 4c 65 6e 67 74 68 20 2d  psql, b.Length -
35c0: 20 31 2c 20 6f 75 74 20 73 74 6d 74 2c 20 6f 75   1, out stmt, ou
35d0: 74 20 70 74 72 2c 20 6f 75 74 20 6c 65 6e 29 3b  t ptr, out len);
35e0: 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20  ..#else..       
35f0: 20 20 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74     n = UnsafeNat
3600: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
3610: 65 33 5f 70 72 65 70 61 72 65 28 5f 73 71 6c 2c  e3_prepare(_sql,
3620: 20 70 73 71 6c 2c 20 62 2e 4c 65 6e 67 74 68 20   psql, b.Length 
3630: 2d 20 31 2c 20 6f 75 74 20 73 74 6d 74 2c 20 6f  - 1, out stmt, o
3640: 75 74 20 70 74 72 29 3b 0d 0a 20 20 20 20 20 20  ut ptr);..      
3650: 20 20 20 20 6c 65 6e 20 3d 20 2d 31 3b 0d 0a 23      len = -1;..#
3660: 65 6e 64 69 66 0d 0a 0d 0a 23 69 66 20 44 45 42  endif....#if DEB
3670: 55 47 20 26 26 20 21 4e 45 54 5f 43 4f 4d 50 41  UG && !NET_COMPA
3680: 43 54 5f 32 30 0d 0a 20 20 20 20 20 20 20 20 20  CT_20..         
3690: 20 54 72 61 63 65 2e 57 72 69 74 65 4c 69 6e 65   Trace.WriteLine
36a0: 28 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 22  (String.Format("
36b0: 50 72 65 70 61 72 65 3a 20 7b 30 7d 22 2c 20 73  Prepare: {0}", s
36c0: 74 6d 74 29 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a  tmt));..#endif..
36d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28  ..          if (
36e0: 6e 20 3d 3d 20 31 37 29 0d 0a 20 20 20 20 20 20  n == 17)..      
36f0: 20 20 20 20 20 20 72 65 74 72 69 65 73 2b 2b 3b        retries++;
3700: 0d 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65  ..          else
3710: 20 69 66 20 28 6e 20 3d 3d 20 31 29 0d 0a 20 20   if (n == 1)..  
3720: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
3730: 20 20 20 20 20 20 20 69 66 20 28 53 74 72 69 6e         if (Strin
3740: 67 2e 43 6f 6d 70 61 72 65 28 47 65 74 4c 61 73  g.Compare(GetLas
3750: 74 45 72 72 6f 72 28 29 2c 20 22 6e 65 61 72 20  tError(), "near 
3760: 5c 22 54 59 50 45 53 5c 22 3a 20 73 79 6e 74 61  \"TYPES\": synta
3770: 78 20 65 72 72 6f 72 22 2c 20 53 74 72 69 6e 67  x error", String
3780: 43 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e  Comparison.Ordin
3790: 61 6c 49 67 6e 6f 72 65 43 61 73 65 29 20 3d 3d  alIgnoreCase) ==
37a0: 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20   0)..           
37b0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
37c0: 20 20 69 6e 74 20 70 6f 73 20 3d 20 73 74 72 53    int pos = strS
37d0: 71 6c 2e 49 6e 64 65 78 4f 66 28 27 3b 27 29 3b  ql.IndexOf(';');
37e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
37f0: 69 66 20 28 70 6f 73 20 3d 3d 20 2d 31 29 20 70  if (pos == -1) p
3800: 6f 73 20 3d 20 73 74 72 53 71 6c 2e 4c 65 6e 67  os = strSql.Leng
3810: 74 68 20 2d 20 31 3b 0d 0a 0d 0a 20 20 20 20 20  th - 1;....     
3820: 20 20 20 20 20 20 20 20 20 74 79 70 65 64 65 66           typedef
3830: 73 20 3d 20 73 74 72 53 71 6c 2e 53 75 62 73 74  s = strSql.Subst
3840: 72 69 6e 67 28 30 2c 20 70 6f 73 20 2b 20 31 29  ring(0, pos + 1)
3850: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
3860: 20 73 74 72 53 71 6c 20 3d 20 73 74 72 53 71 6c   strSql = strSql
3870: 2e 53 75 62 73 74 72 69 6e 67 28 70 6f 73 20 2b  .Substring(pos +
3880: 20 31 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20   1);....        
3890: 20 20 20 20 20 20 73 74 72 52 65 6d 61 69 6e 20        strRemain 
38a0: 3d 20 22 22 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  = "";....       
38b0: 20 20 20 20 20 20 20 77 68 69 6c 65 20 28 63 6d         while (cm
38c0: 64 20 3d 3d 20 6e 75 6c 6c 20 26 26 20 73 74 72  d == null && str
38d0: 53 71 6c 2e 4c 65 6e 67 74 68 20 3e 20 30 29 0d  Sql.Length > 0).
38e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b  .              {
38f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3900: 20 20 63 6d 64 20 3d 20 50 72 65 70 61 72 65 28    cmd = Prepare(
3910: 63 6e 6e 2c 20 73 74 72 53 71 6c 2c 20 70 72 65  cnn, strSql, pre
3920: 76 69 6f 75 73 2c 20 74 69 6d 65 6f 75 74 4d 53  vious, timeoutMS
3930: 2c 20 6f 75 74 20 73 74 72 52 65 6d 61 69 6e 29  , out strRemain)
3940: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
3950: 20 20 20 73 74 72 53 71 6c 20 3d 20 73 74 72 52     strSql = strR
3960: 65 6d 61 69 6e 3b 0d 0a 20 20 20 20 20 20 20 20  emain;..        
3970: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
3980: 20 20 20 20 20 20 20 20 20 69 66 20 28 63 6d 64           if (cmd
3990: 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20   != null)..     
39a0: 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 53             cmd.S
39b0: 65 74 54 79 70 65 73 28 74 79 70 65 64 65 66 73  etTypes(typedefs
39c0: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
39d0: 20 20 20 20 72 65 74 75 72 6e 20 63 6d 64 3b 0d      return cmd;.
39e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  .            }..
39f0: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
3a00: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
3a10: 20 20 20 20 20 20 20 20 20 20 20 20 65 6c 73 65              else
3a20: 20 69 66 20 28 5f 62 75 69 6c 64 69 6e 67 53 63   if (_buildingSc
3a30: 68 65 6d 61 20 3d 3d 20 66 61 6c 73 65 20 26 26  hema == false &&
3a40: 20 53 74 72 69 6e 67 2e 43 6f 6d 70 61 72 65 28   String.Compare(
3a50: 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 2c 20  GetLastError(), 
3a60: 30 2c 20 22 6e 6f 20 73 75 63 68 20 74 61 62 6c  0, "no such tabl
3a70: 65 3a 20 54 45 4d 50 2e 53 43 48 45 4d 41 22 2c  e: TEMP.SCHEMA",
3a80: 20 30 2c 20 32 36 2c 20 53 74 72 69 6e 67 43 6f   0, 26, StringCo
3a90: 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e 61 6c  mparison.Ordinal
3aa0: 49 67 6e 6f 72 65 43 61 73 65 29 20 3d 3d 20 30  IgnoreCase) == 0
3ab0: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  )..            {
3ac0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3ad0: 73 74 72 52 65 6d 61 69 6e 20 3d 20 22 22 3b 0d  strRemain = "";.
3ae0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 5f  .              _
3af0: 62 75 69 6c 64 69 6e 67 53 63 68 65 6d 61 20 3d  buildingSchema =
3b00: 20 74 72 75 65 3b 0d 0a 20 20 20 20 20 20 20 20   true;..        
3b10: 20 20 20 20 20 20 74 72 79 0d 0a 20 20 20 20 20        try..     
3b20: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
3b30: 20 20 20 20 20 20 20 20 20 20 20 20 49 53 51 4c              ISQL
3b40: 69 74 65 53 63 68 65 6d 61 45 78 74 65 6e 73 69  iteSchemaExtensi
3b50: 6f 6e 73 20 65 78 74 20 3d 20 28 28 49 53 65 72  ons ext = ((ISer
3b60: 76 69 63 65 50 72 6f 76 69 64 65 72 29 53 51 4c  viceProvider)SQL
3b70: 69 74 65 46 61 63 74 6f 72 79 2e 49 6e 73 74 61  iteFactory.Insta
3b80: 6e 63 65 29 2e 47 65 74 53 65 72 76 69 63 65 28  nce).GetService(
3b90: 74 79 70 65 6f 66 28 49 53 51 4c 69 74 65 53 63  typeof(ISQLiteSc
3ba0: 68 65 6d 61 45 78 74 65 6e 73 69 6f 6e 73 29 29  hemaExtensions))
3bb0: 20 61 73 20 49 53 51 4c 69 74 65 53 63 68 65 6d   as ISQLiteSchem
3bc0: 61 45 78 74 65 6e 73 69 6f 6e 73 3b 0d 0a 0d 0a  aExtensions;....
3bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3be0: 69 66 20 28 65 78 74 20 21 3d 20 6e 75 6c 6c 29  if (ext != null)
3bf0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3c00: 20 20 20 20 65 78 74 2e 42 75 69 6c 64 54 65 6d      ext.BuildTem
3c10: 70 53 63 68 65 6d 61 28 63 6e 6e 29 3b 0d 0a 0d  pSchema(cnn);...
3c20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3c30: 20 77 68 69 6c 65 20 28 63 6d 64 20 3d 3d 20 6e   while (cmd == n
3c40: 75 6c 6c 20 26 26 20 73 74 72 53 71 6c 2e 4c 65  ull && strSql.Le
3c50: 6e 67 74 68 20 3e 20 30 29 0d 0a 20 20 20 20 20  ngth > 0)..     
3c60: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
3c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3c80: 63 6d 64 20 3d 20 50 72 65 70 61 72 65 28 63 6e  cmd = Prepare(cn
3c90: 6e 2c 20 73 74 72 53 71 6c 2c 20 70 72 65 76 69  n, strSql, previ
3ca0: 6f 75 73 2c 20 74 69 6d 65 6f 75 74 4d 53 2c 20  ous, timeoutMS, 
3cb0: 6f 75 74 20 73 74 72 52 65 6d 61 69 6e 29 3b 0d  out strRemain);.
3cc0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3cd0: 20 20 20 73 74 72 53 71 6c 20 3d 20 73 74 72 52     strSql = strR
3ce0: 65 6d 61 69 6e 3b 0d 0a 20 20 20 20 20 20 20 20  emain;..        
3cf0: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20          }....   
3d00: 20 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74               ret
3d10: 75 72 6e 20 63 6d 64 3b 0d 0a 20 20 20 20 20 20  urn cmd;..      
3d20: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
3d30: 20 20 20 20 20 20 20 20 20 66 69 6e 61 6c 6c 79           finally
3d40: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
3d50: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
3d60: 20 20 20 5f 62 75 69 6c 64 69 6e 67 53 63 68 65     _buildingSche
3d70: 6d 61 20 3d 20 66 61 6c 73 65 3b 0d 0a 20 20 20  ma = false;..   
3d80: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20             }..  
3d90: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 23 65 6e            }..#en
3da0: 64 69 66 0d 0a 20 20 20 20 20 20 20 20 20 20 7d  dif..          }
3db0: 0d 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65  ..          else
3dc0: 20 69 66 20 28 6e 20 3d 3d 20 36 20 7c 7c 20 6e   if (n == 6 || n
3dd0: 20 3d 3d 20 35 29 20 2f 2f 20 4c 6f 63 6b 65 64   == 5) // Locked
3de0: 20 2d 2d 20 64 65 6c 61 79 20 61 20 73 6d 61 6c   -- delay a smal
3df0: 6c 20 61 6d 6f 75 6e 74 20 62 65 66 6f 72 65 20  l amount before 
3e00: 72 65 74 72 79 69 6e 67 0d 0a 20 20 20 20 20 20  retrying..      
3e10: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
3e20: 20 20 20 2f 2f 20 4b 65 65 70 20 74 72 79 69 6e     // Keep tryin
3e30: 67 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  g..            i
3e40: 66 20 28 72 6e 64 20 3d 3d 20 6e 75 6c 6c 29 20  f (rnd == null) 
3e50: 2f 2f 20 46 69 72 73 74 20 74 69 6d 65 20 77 65  // First time we
3e60: 27 76 65 20 65 6e 63 6f 75 6e 74 65 72 65 64 20  've encountered 
3e70: 74 68 65 20 6c 6f 63 6b 0d 0a 20 20 20 20 20 20  the lock..      
3e80: 20 20 20 20 20 20 20 20 72 6e 64 20 3d 20 6e 65          rnd = ne
3e90: 77 20 52 61 6e 64 6f 6d 28 29 3b 0d 0a 0d 0a 20  w Random();.... 
3ea0: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 49 66             // If
3eb0: 20 77 65 27 76 65 20 65 78 63 65 65 64 65 64 20   we've exceeded 
3ec0: 74 68 65 20 63 6f 6d 6d 61 6e 64 27 73 20 74 69  the command's ti
3ed0: 6d 65 6f 75 74 2c 20 67 69 76 65 20 75 70 20 61  meout, give up a
3ee0: 6e 64 20 74 68 72 6f 77 20 61 6e 20 65 72 72 6f  nd throw an erro
3ef0: 72 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  r..            i
3f00: 66 20 28 28 75 69 6e 74 29 45 6e 76 69 72 6f 6e  f ((uint)Environ
3f10: 6d 65 6e 74 2e 54 69 63 6b 43 6f 75 6e 74 20 2d  ment.TickCount -
3f20: 20 73 74 61 72 74 74 69 63 6b 20 3e 20 74 69 6d   starttick > tim
3f30: 65 6f 75 74 4d 53 29 0d 0a 20 20 20 20 20 20 20  eoutMS)..       
3f40: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
3f50: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
3f60: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
3f70: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
3f80: 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ));..           
3f90: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
3fa0: 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 20 20  else..          
3fb0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
3fc0: 20 20 20 2f 2f 20 4f 74 68 65 72 77 69 73 65 20     // Otherwise 
3fd0: 73 6c 65 65 70 20 66 6f 72 20 61 20 72 61 6e 64  sleep for a rand
3fe0: 6f 6d 20 61 6d 6f 75 6e 74 20 6f 66 20 74 69 6d  om amount of tim
3ff0: 65 20 75 70 20 74 6f 20 31 35 30 6d 73 0d 0a 20  e up to 150ms.. 
4000: 20 20 20 20 20 20 20 20 20 20 20 20 20 53 79 73               Sys
4010: 74 65 6d 2e 54 68 72 65 61 64 69 6e 67 2e 54 68  tem.Threading.Th
4020: 72 65 61 64 2e 53 6c 65 65 70 28 72 6e 64 2e 4e  read.Sleep(rnd.N
4030: 65 78 74 28 31 2c 20 31 35 30 29 29 3b 0d 0a 20  ext(1, 150));.. 
4040: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20             }..  
4050: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
4060: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
4070: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
4080: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
4090: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
40a0: 72 72 6f 72 28 29 29 3b 0d 0a 0d 0a 20 20 20 20  rror());....    
40b0: 20 20 20 20 73 74 72 52 65 6d 61 69 6e 20 3d 20      strRemain = 
40c0: 55 54 46 38 54 6f 53 74 72 69 6e 67 28 70 74 72  UTF8ToString(ptr
40d0: 2c 20 6c 65 6e 29 3b 0d 0a 0d 0a 20 20 20 20 20  , len);....     
40e0: 20 20 20 69 66 20 28 73 74 6d 74 20 21 3d 20 49     if (stmt != I
40f0: 6e 74 50 74 72 2e 5a 65 72 6f 29 20 63 6d 64 20  ntPtr.Zero) cmd 
4100: 3d 20 6e 65 77 20 53 51 4c 69 74 65 53 74 61 74  = new SQLiteStat
4110: 65 6d 65 6e 74 28 74 68 69 73 2c 20 66 6c 61 67  ement(this, flag
4120: 73 2c 20 6e 65 77 20 53 51 4c 69 74 65 53 74 61  s, new SQLiteSta
4130: 74 65 6d 65 6e 74 48 61 6e 64 6c 65 28 73 74 6d  tementHandle(stm
4140: 74 29 2c 20 73 74 72 53 71 6c 2e 53 75 62 73 74  t), strSql.Subst
4150: 72 69 6e 67 28 30 2c 20 73 74 72 53 71 6c 2e 4c  ring(0, strSql.L
4160: 65 6e 67 74 68 20 2d 20 73 74 72 52 65 6d 61 69  ength - strRemai
4170: 6e 2e 4c 65 6e 67 74 68 29 2c 20 70 72 65 76 69  n.Length), previ
4180: 6f 75 73 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  ous);....       
4190: 20 72 65 74 75 72 6e 20 63 6d 64 3b 0d 0a 20 20   return cmd;..  
41a0: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 66 69 6e      }..      fin
41b0: 61 6c 6c 79 0d 0a 20 20 20 20 20 20 7b 0d 0a 20  ally..      {.. 
41c0: 20 20 20 20 20 20 20 68 61 6e 64 6c 65 2e 46 72         handle.Fr
41d0: 65 65 28 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a  ee();..      }..
41e0: 20 20 20 20 7d 0d 0a 0d 0a 23 69 66 20 21 50 4c      }....#if !PL
41f0: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
4200: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 70 72 6f  AMEWORK..    pro
4210: 74 65 63 74 65 64 20 73 74 61 74 69 63 20 76 6f  tected static vo
4220: 69 64 20 4c 6f 67 42 69 6e 64 28 53 51 4c 69 74  id LogBind(SQLit
4230: 65 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65  eStatementHandle
4240: 20 68 61 6e 64 6c 65 2c 20 69 6e 74 20 69 6e 64   handle, int ind
4250: 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ex)..    {..    
4260: 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64 6c      IntPtr handl
4270: 65 49 6e 74 50 74 72 20 3d 20 68 61 6e 64 6c 65  eIntPtr = handle
4280: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 51 4c  ;....        SQL
4290: 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61 67  iteLog.LogMessag
42a0: 65 28 30 2c 20 53 74 72 69 6e 67 2e 46 6f 72 6d  e(0, String.Form
42b0: 61 74 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  at(..           
42c0: 20 22 42 69 6e 64 69 6e 67 20 73 74 61 74 65 6d   "Binding statem
42d0: 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74 65 72  ent {0} paramter
42e0: 20 23 7b 31 7d 20 61 73 20 4e 55 4c 4c 2e 2e 2e   #{1} as NULL...
42f0: 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ",..            
4300: 68 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e  handleIntPtr, in
4310: 64 65 78 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  dex));..    }...
4320: 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64 20 73  .    protected s
4330: 74 61 74 69 63 20 76 6f 69 64 20 4c 6f 67 42 69  tatic void LogBi
4340: 6e 64 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  nd(SQLiteStateme
4350: 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 2c  ntHandle handle,
4360: 20 69 6e 74 20 69 6e 64 65 78 2c 20 56 61 6c 75   int index, Valu
4370: 65 54 79 70 65 20 76 61 6c 75 65 29 0d 0a 20 20  eType value)..  
4380: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e 74    {..        Int
4390: 50 74 72 20 68 61 6e 64 6c 65 49 6e 74 50 74 72  Ptr handleIntPtr
43a0: 20 3d 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20   = handle;....  
43b0: 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e        SQLiteLog.
43c0: 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53 74  LogMessage(0, St
43d0: 72 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20  ring.Format(..  
43e0: 20 20 20 20 20 20 20 20 20 20 22 42 69 6e 64 69            "Bindi
43f0: 6e 67 20 73 74 61 74 65 6d 65 6e 74 20 7b 30 7d  ng statement {0}
4400: 20 70 61 72 61 6d 74 65 72 20 23 7b 31 7d 20 61   paramter #{1} a
4410: 73 20 74 79 70 65 20 7b 32 7d 20 77 69 74 68 20  s type {2} with 
4420: 76 61 6c 75 65 20 7b 7b 7b 33 7d 7d 7d 2e 2e 2e  value {{{3}}}...
4430: 22 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ",..            
4440: 68 61 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e  handleIntPtr, in
4450: 64 65 78 2c 20 76 61 6c 75 65 2e 47 65 74 54 79  dex, value.GetTy
4460: 70 65 28 29 2c 20 76 61 6c 75 65 29 29 3b 0d 0a  pe(), value));..
4470: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72 69      }....    pri
4480: 76 61 74 65 20 73 74 61 74 69 63 20 73 74 72 69  vate static stri
4490: 6e 67 20 46 6f 72 6d 61 74 44 61 74 65 54 69 6d  ng FormatDateTim
44a0: 65 28 44 61 74 65 54 69 6d 65 20 76 61 6c 75 65  e(DateTime value
44b0: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
44c0: 20 20 53 74 72 69 6e 67 42 75 69 6c 64 65 72 20    StringBuilder 
44d0: 72 65 73 75 6c 74 20 3d 20 6e 65 77 20 53 74 72  result = new Str
44e0: 69 6e 67 42 75 69 6c 64 65 72 28 29 3b 0d 0a 0d  ingBuilder();...
44f0: 0a 20 20 20 20 20 20 20 20 72 65 73 75 6c 74 2e  .        result.
4500: 41 70 70 65 6e 64 28 76 61 6c 75 65 2e 54 6f 53  Append(value.ToS
4510: 74 72 69 6e 67 28 22 79 79 79 79 2d 4d 4d 2d 64  tring("yyyy-MM-d
4520: 64 54 48 48 3a 6d 6d 3a 73 73 2e 46 46 46 46 46  dTHH:mm:ss.FFFFF
4530: 46 46 4b 22 29 29 3b 0d 0a 20 20 20 20 20 20 20  FFK"));..       
4540: 20 72 65 73 75 6c 74 2e 41 70 70 65 6e 64 28 27   result.Append('
4550: 20 27 29 3b 0d 0a 20 20 20 20 20 20 20 20 72 65   ');..        re
4560: 73 75 6c 74 2e 41 70 70 65 6e 64 28 76 61 6c 75  sult.Append(valu
4570: 65 2e 4b 69 6e 64 29 3b 0d 0a 20 20 20 20 20 20  e.Kind);..      
4580: 20 20 72 65 73 75 6c 74 2e 41 70 70 65 6e 64 28    result.Append(
4590: 27 20 27 29 3b 0d 0a 20 20 20 20 20 20 20 20 72  ' ');..        r
45a0: 65 73 75 6c 74 2e 41 70 70 65 6e 64 28 76 61 6c  esult.Append(val
45b0: 75 65 2e 54 69 63 6b 73 29 3b 0d 0a 0d 0a 20 20  ue.Ticks);....  
45c0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 72 65 73        return res
45d0: 75 6c 74 2e 54 6f 53 74 72 69 6e 67 28 29 3b 0d  ult.ToString();.
45e0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 70 72  .    }....    pr
45f0: 6f 74 65 63 74 65 64 20 73 74 61 74 69 63 20 76  otected static v
4600: 6f 69 64 20 4c 6f 67 42 69 6e 64 28 53 51 4c 69  oid LogBind(SQLi
4610: 74 65 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c  teStatementHandl
4620: 65 20 68 61 6e 64 6c 65 2c 20 69 6e 74 20 69 6e  e handle, int in
4630: 64 65 78 2c 20 44 61 74 65 54 69 6d 65 20 76 61  dex, DateTime va
4640: 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  lue)..    {..   
4650: 20 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64       IntPtr hand
4660: 6c 65 49 6e 74 50 74 72 20 3d 20 68 61 6e 64 6c  leIntPtr = handl
4670: 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 51  e;....        SQ
4680: 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73 61  LiteLog.LogMessa
4690: 67 65 28 30 2c 20 53 74 72 69 6e 67 2e 46 6f 72  ge(0, String.For
46a0: 6d 61 74 28 0d 0a 20 20 20 20 20 20 20 20 20 20  mat(..          
46b0: 20 20 22 42 69 6e 64 69 6e 67 20 73 74 61 74 65    "Binding state
46c0: 6d 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74 65  ment {0} paramte
46d0: 72 20 23 7b 31 7d 20 61 73 20 74 79 70 65 20 7b  r #{1} as type {
46e0: 32 7d 20 77 69 74 68 20 76 61 6c 75 65 20 7b 7b  2} with value {{
46f0: 7b 33 7d 7d 7d 2e 2e 2e 22 2c 0d 0a 20 20 20 20  {3}}}...",..    
4700: 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65 49 6e          handleIn
4710: 74 50 74 72 2c 20 69 6e 64 65 78 2c 20 74 79 70  tPtr, index, typ
4720: 65 6f 66 28 44 61 74 65 54 69 6d 65 29 2c 20 46  eof(DateTime), F
4730: 6f 72 6d 61 74 44 61 74 65 54 69 6d 65 28 76 61  ormatDateTime(va
4740: 6c 75 65 29 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a  lue)));..    }..
4750: 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64 20  ..    protected 
4760: 73 74 61 74 69 63 20 76 6f 69 64 20 4c 6f 67 42  static void LogB
4770: 69 6e 64 28 53 51 4c 69 74 65 53 74 61 74 65 6d  ind(SQLiteStatem
4780: 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65  entHandle handle
4790: 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 73 74 72  , int index, str
47a0: 69 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20 20 20  ing value)..    
47b0: 7b 0d 0a 20 20 20 20 20 20 20 20 49 6e 74 50 74  {..        IntPt
47c0: 72 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20 3d  r handleIntPtr =
47d0: 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20   handle;....    
47e0: 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f      SQLiteLog.Lo
47f0: 67 4d 65 73 73 61 67 65 28 30 2c 20 53 74 72 69  gMessage(0, Stri
4800: 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20 20 20  ng.Format(..    
4810: 20 20 20 20 20 20 20 20 22 42 69 6e 64 69 6e 67          "Binding
4820: 20 73 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20 70   statement {0} p
4830: 61 72 61 6d 74 65 72 20 23 7b 31 7d 20 61 73 20  aramter #{1} as 
4840: 74 79 70 65 20 7b 32 7d 20 77 69 74 68 20 76 61  type {2} with va
4850: 6c 75 65 20 7b 7b 7b 33 7d 7d 7d 2e 2e 2e 22 2c  lue {{{3}}}...",
4860: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 68 61  ..            ha
4870: 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e 64 65  ndleIntPtr, inde
4880: 78 2c 20 74 79 70 65 6f 66 28 53 74 72 69 6e 67  x, typeof(String
4890: 29 2c 20 28 76 61 6c 75 65 20 21 3d 20 6e 75 6c  ), (value != nul
48a0: 6c 29 20 3f 20 76 61 6c 75 65 20 3a 20 22 3c 6e  l) ? value : "<n
48b0: 75 6c 6c 3e 22 29 29 3b 0d 0a 20 20 20 20 7d 0d  ull>"));..    }.
48c0: 0a 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20 73  ...    private s
48d0: 74 61 74 69 63 20 73 74 72 69 6e 67 20 54 6f 48  tatic string ToH
48e0: 65 78 61 64 65 63 69 6d 61 6c 53 74 72 69 6e 67  exadecimalString
48f0: 28 0d 0a 20 20 20 20 20 20 20 20 62 79 74 65 5b  (..        byte[
4900: 5d 20 61 72 72 61 79 0d 0a 20 20 20 20 20 20 20  ] array..       
4910: 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20   )..    {..     
4920: 20 20 20 69 66 20 28 61 72 72 61 79 20 3d 3d 20     if (array == 
4930: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
4940: 20 20 20 72 65 74 75 72 6e 20 6e 75 6c 6c 3b 0d     return null;.
4950: 0a 0d 0a 20 20 20 20 20 20 20 20 53 74 72 69 6e  ...        Strin
4960: 67 42 75 69 6c 64 65 72 20 72 65 73 75 6c 74 20  gBuilder result 
4970: 3d 20 6e 65 77 20 53 74 72 69 6e 67 42 75 69 6c  = new StringBuil
4980: 64 65 72 28 61 72 72 61 79 2e 4c 65 6e 67 74 68  der(array.Length
4990: 20 2a 20 32 29 3b 0d 0a 0d 0a 20 20 20 20 20 20   * 2);....      
49a0: 20 20 69 6e 74 20 6c 65 6e 67 74 68 20 3d 20 61    int length = a
49b0: 72 72 61 79 2e 4c 65 6e 67 74 68 3b 0d 0a 0d 0a  rray.Length;....
49c0: 20 20 20 20 20 20 20 20 66 6f 72 20 28 69 6e 74          for (int
49d0: 20 69 6e 64 65 78 20 3d 20 30 3b 20 69 6e 64 65   index = 0; inde
49e0: 78 20 3c 20 6c 65 6e 67 74 68 3b 20 69 6e 64 65  x < length; inde
49f0: 78 2b 2b 29 0d 0a 20 20 20 20 20 20 20 20 20 20  x++)..          
4a00: 20 20 72 65 73 75 6c 74 2e 41 70 70 65 6e 64 28    result.Append(
4a10: 61 72 72 61 79 5b 69 6e 64 65 78 5d 2e 54 6f 53  array[index].ToS
4a20: 74 72 69 6e 67 28 22 78 32 22 29 29 3b 0d 0a 0d  tring("x2"));...
4a30: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
4a40: 72 65 73 75 6c 74 2e 54 6f 53 74 72 69 6e 67 28  result.ToString(
4a50: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
4a60: 20 70 72 6f 74 65 63 74 65 64 20 73 74 61 74 69   protected stati
4a70: 63 20 76 6f 69 64 20 4c 6f 67 42 69 6e 64 28 53  c void LogBind(S
4a80: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61  QLiteStatementHa
4a90: 6e 64 6c 65 20 68 61 6e 64 6c 65 2c 20 69 6e 74  ndle handle, int
4aa0: 20 69 6e 64 65 78 2c 20 62 79 74 65 5b 5d 20 76   index, byte[] v
4ab0: 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  alue)..    {..  
4ac0: 20 20 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e        IntPtr han
4ad0: 64 6c 65 49 6e 74 50 74 72 20 3d 20 68 61 6e 64  dleIntPtr = hand
4ae0: 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53  le;....        S
4af0: 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65 73 73  QLiteLog.LogMess
4b00: 61 67 65 28 30 2c 20 53 74 72 69 6e 67 2e 46 6f  age(0, String.Fo
4b10: 72 6d 61 74 28 0d 0a 20 20 20 20 20 20 20 20 20  rmat(..         
4b20: 20 20 20 22 42 69 6e 64 69 6e 67 20 73 74 61 74     "Binding stat
4b30: 65 6d 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74  ement {0} paramt
4b40: 65 72 20 23 7b 31 7d 20 61 73 20 74 79 70 65 20  er #{1} as type 
4b50: 7b 32 7d 20 77 69 74 68 20 76 61 6c 75 65 20 7b  {2} with value {
4b60: 7b 7b 33 7d 7d 7d 2e 2e 2e 22 2c 0d 0a 20 20 20  {{3}}}...",..   
4b70: 20 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65 49           handleI
4b80: 6e 74 50 74 72 2c 20 69 6e 64 65 78 2c 20 74 79  ntPtr, index, ty
4b90: 70 65 6f 66 28 42 79 74 65 5b 5d 29 2c 20 28 76  peof(Byte[]), (v
4ba0: 61 6c 75 65 20 21 3d 20 6e 75 6c 6c 29 20 3f 20  alue != null) ? 
4bb0: 54 6f 48 65 78 61 64 65 63 69 6d 61 6c 53 74 72  ToHexadecimalStr
4bc0: 69 6e 67 28 76 61 6c 75 65 29 20 3a 20 22 3c 6e  ing(value) : "<n
4bd0: 75 6c 6c 3e 22 29 29 3b 0d 0a 20 20 20 20 7d 0d  ull>"));..    }.
4be0: 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 69  .#endif....    i
4bf0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
4c00: 20 76 6f 69 64 20 42 69 6e 64 5f 44 6f 75 62 6c   void Bind_Doubl
4c10: 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  e(SQLiteStatemen
4c20: 74 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f  t stmt, SQLiteCo
4c30: 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c  nnectionFlags fl
4c40: 61 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20  ags, int index, 
4c50: 64 6f 75 62 6c 65 20 76 61 6c 75 65 29 0d 0a 20  double value).. 
4c60: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 53 51     {..        SQ
4c70: 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61 6e  LiteStatementHan
4c80: 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73 74 6d  dle handle = stm
4c90: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 3b 0d  t._sqlite_stmt;.
4ca0: 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d  ...#if !PLATFORM
4cb0: 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52  _COMPACTFRAMEWOR
4cc0: 4b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 28  K..        if ((
4cd0: 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65 43 6f  flags & SQLiteCo
4ce0: 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f  nnectionFlags.Lo
4cf0: 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65  gBind) == SQLite
4d00: 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e  ConnectionFlags.
4d10: 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20 20 20  LogBind)..      
4d20: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
4d30: 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c 65 2c   LogBind(handle,
4d40: 20 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d   index, value);.
4d50: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20  .        }....  
4d60: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
4d70: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
4d80: 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64  s.sqlite3_bind_d
4d90: 6f 75 62 6c 65 28 68 61 6e 64 6c 65 2c 20 69 6e  ouble(handle, in
4da0: 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 23 65  dex, value);..#e
4db0: 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 69 6e 74  lse..        int
4dc0: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
4dd0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
4de0: 5f 62 69 6e 64 5f 64 6f 75 62 6c 65 5f 69 6e 74  _bind_double_int
4df0: 65 72 6f 70 28 68 61 6e 64 6c 65 2c 20 69 6e 64  erop(handle, ind
4e00: 65 78 2c 20 72 65 66 20 76 61 6c 75 65 29 3b 0d  ex, ref value);.
4e10: 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 20  .#endif..       
4e20: 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f   if (n > 0) thro
4e30: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
4e40: 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74  ption(n, GetLast
4e50: 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d  Error());..    }
4e60: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
4e70: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 42   override void B
4e80: 69 6e 64 5f 49 6e 74 33 32 28 53 51 4c 69 74 65  ind_Int32(SQLite
4e90: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
4ea0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
4eb0: 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69 6e 74  Flags flags, int
4ec0: 20 69 6e 64 65 78 2c 20 69 6e 74 20 76 61 6c 75   index, int valu
4ed0: 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  e)..    {..     
4ee0: 20 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65     SQLiteStateme
4ef0: 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20  ntHandle handle 
4f00: 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  = stmt._sqlite_s
4f10: 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41  tmt;....#if !PLA
4f20: 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41  TFORM_COMPACTFRA
4f30: 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20  MEWORK..        
4f40: 69 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c  if ((flags & SQL
4f50: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
4f60: 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53  gs.LogBind) == S
4f70: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46  QLiteConnectionF
4f80: 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20  lags.LogBind).. 
4f90: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
4fa0: 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61        LogBind(ha
4fb0: 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c  ndle, index, val
4fc0: 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ue);..        }.
4fd0: 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20  .#endif....     
4fe0: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
4ff0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
5000: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 28  qlite3_bind_int(
5010: 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76  handle, index, v
5020: 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20  alue);..        
5030: 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77  if (n > 0) throw
5040: 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70   new SQLiteExcep
5050: 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45  tion(n, GetLastE
5060: 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d  rror());..    }.
5070: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
5080: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 42 69  override void Bi
5090: 6e 64 5f 55 49 6e 74 33 32 28 53 51 4c 69 74 65  nd_UInt32(SQLite
50a0: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
50b0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
50c0: 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69 6e 74  Flags flags, int
50d0: 20 69 6e 64 65 78 2c 20 75 69 6e 74 20 76 61 6c   index, uint val
50e0: 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ue)..    {..    
50f0: 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d      SQLiteStatem
5100: 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65  entHandle handle
5110: 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f   = stmt._sqlite_
5120: 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c  stmt;....#if !PL
5130: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
5140: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20  AMEWORK..       
5150: 20 69 66 20 28 28 66 6c 61 67 73 20 26 20 53 51   if ((flags & SQ
5160: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
5170: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20  ags.LogBind) == 
5180: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
5190: 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a  Flags.LogBind)..
51a0: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
51b0: 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68         LogBind(h
51c0: 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61  andle, index, va
51d0: 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d  lue);..        }
51e0: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20  ..#endif....    
51f0: 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61      int n = Unsa
5200: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
5210: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 75 69 6e  sqlite3_bind_uin
5220: 74 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c  t(handle, index,
5230: 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20   value);..      
5240: 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72    if (n > 0) thr
5250: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
5260: 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73  eption(n, GetLas
5270: 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20  tError());..    
5280: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
5290: 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20  l override void 
52a0: 42 69 6e 64 5f 49 6e 74 36 34 28 53 51 4c 69 74  Bind_Int64(SQLit
52b0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
52c0: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
52d0: 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69 6e  nFlags flags, in
52e0: 74 20 69 6e 64 65 78 2c 20 6c 6f 6e 67 20 76 61  t index, long va
52f0: 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  lue)..    {..   
5300: 20 20 20 20 20 53 51 4c 69 74 65 53 74 61 74 65       SQLiteState
5310: 6d 65 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c  mentHandle handl
5320: 65 20 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65  e = stmt._sqlite
5330: 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50  _stmt;....#if !P
5340: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
5350: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20  RAMEWORK..      
5360: 20 20 69 66 20 28 28 66 6c 61 67 73 20 26 20 53    if ((flags & S
5370: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46  QLiteConnectionF
5380: 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d  lags.LogBind) ==
5390: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
53a0: 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d  nFlags.LogBind).
53b0: 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  .        {..    
53c0: 20 20 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28          LogBind(
53d0: 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76  handle, index, v
53e0: 61 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 20 20  alue);..        
53f0: 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 6e 74  }....        int
5400: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
5410: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
5420: 5f 62 69 6e 64 5f 69 6e 74 36 34 28 68 61 6e 64  _bind_int64(hand
5430: 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65  le, index, value
5440: 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20  );..#else..     
5450: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
5460: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
5470: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36  qlite3_bind_int6
5480: 34 5f 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c 65  4_interop(handle
5490: 2c 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c  , index, ref val
54a0: 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20  ue);..#endif..  
54b0: 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29        if (n > 0)
54c0: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
54d0: 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65  eException(n, Ge
54e0: 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a  tLastError());..
54f0: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
5500: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
5510: 6f 69 64 20 42 69 6e 64 5f 55 49 6e 74 36 34 28  oid Bind_UInt64(
5520: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 20  SQLiteStatement 
5530: 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e 6e  stmt, SQLiteConn
5540: 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61 67  ectionFlags flag
5550: 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 75 6c  s, int index, ul
5560: 6f 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20 20 20  ong value)..    
5570: 7b 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74  {..        SQLit
5580: 65 53 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65  eStatementHandle
5590: 20 68 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f   handle = stmt._
55a0: 73 71 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a  sqlite_stmt;....
55b0: 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f  #if !PLATFORM_CO
55c0: 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a  MPACTFRAMEWORK..
55d0: 20 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61          if ((fla
55e0: 67 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65  gs & SQLiteConne
55f0: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
5600: 6e 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e  nd) == SQLiteCon
5610: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67  nectionFlags.Log
5620: 42 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b  Bind)..        {
5630: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f  ..            Lo
5640: 67 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e  gBind(handle, in
5650: 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20  dex, value);..  
5660: 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20        }....     
5670: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
5680: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
5690: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 75 69 6e 74  qlite3_bind_uint
56a0: 36 34 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78  64(handle, index
56b0: 2c 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c 73 65  , value);..#else
56c0: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20  ..        int n 
56d0: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
56e0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69  thods.sqlite3_bi
56f0: 6e 64 5f 75 69 6e 74 36 34 5f 69 6e 74 65 72 6f  nd_uint64_intero
5700: 70 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c  p(handle, index,
5710: 20 72 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23 65   ref value);..#e
5720: 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20 69 66  ndif..        if
5730: 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e   (n > 0) throw n
5740: 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69  ew SQLiteExcepti
5750: 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45 72 72  on(n, GetLastErr
5760: 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  or());..    }...
5770: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
5780: 65 72 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64  erride void Bind
5790: 5f 54 65 78 74 28 53 51 4c 69 74 65 53 74 61 74  _Text(SQLiteStat
57a0: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51 4c 69  ement stmt, SQLi
57b0: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
57c0: 73 20 66 6c 61 67 73 2c 20 69 6e 74 20 69 6e 64  s flags, int ind
57d0: 65 78 2c 20 73 74 72 69 6e 67 20 76 61 6c 75 65  ex, string value
57e0: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
57f0: 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e    SQLiteStatemen
5800: 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d  tHandle handle =
5810: 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74   stmt._sqlite_st
5820: 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54  mt;....#if !PLAT
5830: 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d  FORM_COMPACTFRAM
5840: 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 69  EWORK..        i
5850: 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69  f ((flags & SQLi
5860: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
5870: 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51  s.LogBind) == SQ
5880: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
5890: 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20  ags.LogBind)..  
58a0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
58b0: 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e       LogBind(han
58c0: 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75  dle, index, valu
58d0: 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a  e);..        }..
58e0: 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20  #endif....      
58f0: 20 20 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55    byte[] b = ToU
5900: 54 46 38 28 76 61 6c 75 65 29 3b 0d 0a 0d 0a 23  TF8(value);....#
5910: 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d  if !PLATFORM_COM
5920: 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20  PACTFRAMEWORK.. 
5930: 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67         if ((flag
5940: 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63  s & SQLiteConnec
5950: 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e  tionFlags.LogBin
5960: 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e  d) == SQLiteConn
5970: 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42  ectionFlags.LogB
5980: 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d  ind)..        {.
5990: 0a 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67  .            Log
59a0: 42 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64  Bind(handle, ind
59b0: 65 78 2c 20 62 29 3b 0d 0a 20 20 20 20 20 20 20  ex, b);..       
59c0: 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20   }..#endif....  
59d0: 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e        int n = Un
59e0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
59f0: 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74  s.sqlite3_bind_t
5a00: 65 78 74 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65  ext(handle, inde
5a10: 78 2c 20 62 2c 20 62 2e 4c 65 6e 67 74 68 20 2d  x, b, b.Length -
5a20: 20 31 2c 20 28 49 6e 74 50 74 72 29 28 2d 31 29   1, (IntPtr)(-1)
5a30: 29 3b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  );..        if (
5a40: 6e 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77  n > 0) throw new
5a50: 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e   SQLiteException
5a60: 28 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72  (n, GetLastError
5a70: 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ());..    }.... 
5a80: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
5a90: 72 69 64 65 20 76 6f 69 64 20 42 69 6e 64 5f 44  ride void Bind_D
5aa0: 61 74 65 54 69 6d 65 28 53 51 4c 69 74 65 53 74  ateTime(SQLiteSt
5ab0: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51  atement stmt, SQ
5ac0: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c  LiteConnectionFl
5ad0: 61 67 73 20 66 6c 61 67 73 2c 20 69 6e 74 20 69  ags flags, int i
5ae0: 6e 64 65 78 2c 20 44 61 74 65 54 69 6d 65 20 64  ndex, DateTime d
5af0: 74 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  t)..    {..     
5b00: 20 20 20 53 51 4c 69 74 65 53 74 61 74 65 6d 65     SQLiteStateme
5b10: 6e 74 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20  ntHandle handle 
5b20: 3d 20 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  = stmt._sqlite_s
5b30: 74 6d 74 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41  tmt;....#if !PLA
5b40: 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41  TFORM_COMPACTFRA
5b50: 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20  MEWORK..        
5b60: 69 66 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c  if ((flags & SQL
5b70: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
5b80: 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53  gs.LogBind) == S
5b90: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46  QLiteConnectionF
5ba0: 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20  lags.LogBind).. 
5bb0: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
5bc0: 20 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61        LogBind(ha
5bd0: 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 64 74 29  ndle, index, dt)
5be0: 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 23 65  ;..        }..#e
5bf0: 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ndif....        
5c00: 73 77 69 74 63 68 20 28 5f 64 61 74 65 74 69 6d  switch (_datetim
5c10: 65 46 6f 72 6d 61 74 29 0d 0a 20 20 20 20 20 20  eFormat)..      
5c20: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
5c30: 20 63 61 73 65 20 53 51 4c 69 74 65 44 61 74 65   case SQLiteDate
5c40: 46 6f 72 6d 61 74 73 2e 54 69 63 6b 73 3a 0d 0a  Formats.Ticks:..
5c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5c60: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
5c70: 20 20 20 20 20 20 20 6c 6f 6e 67 20 76 61 6c 75         long valu
5c80: 65 20 3d 20 64 74 2e 54 69 63 6b 73 3b 0d 0a 0d  e = dt.Ticks;...
5c90: 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43  .#if !PLATFORM_C
5ca0: 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d  OMPACTFRAMEWORK.
5cb0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
5cc0: 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73 20       if ((flags 
5cd0: 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  & SQLiteConnecti
5ce0: 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29  onFlags.LogBind)
5cf0: 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63   == SQLiteConnec
5d00: 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e  tionFlags.LogBin
5d10: 64 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  d)..            
5d20: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
5d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5d40: 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c     LogBind(handl
5d50: 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75 65 29  e, index, value)
5d60: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
5d70: 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20         }....    
5d80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5d90: 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61  int n = UnsafeNa
5da0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
5db0: 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36 34 28 68  te3_bind_int64(h
5dc0: 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61  andle, index, va
5dd0: 6c 75 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20  lue);..#else..  
5de0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5df0: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
5e00: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
5e10: 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36 34  lite3_bind_int64
5e20: 5f 69 6e 74 65 72 6f 70 28 68 61 6e 64 6c 65 2c  _interop(handle,
5e30: 20 69 6e 64 65 78 2c 20 72 65 66 20 76 61 6c 75   index, ref valu
5e40: 65 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20  e);..#endif..   
5e50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e60: 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f   if (n > 0) thro
5e70: 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65  w new SQLiteExce
5e80: 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74  ption(n, GetLast
5e90: 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 20  Error());..     
5ea0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 62                 b
5eb0: 72 65 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20 20  reak;..         
5ec0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
5ed0: 20 20 20 20 20 20 63 61 73 65 20 53 51 4c 69 74        case SQLit
5ee0: 65 44 61 74 65 46 6f 72 6d 61 74 73 2e 4a 75 6c  eDateFormats.Jul
5ef0: 69 61 6e 44 61 79 3a 0d 0a 20 20 20 20 20 20 20  ianDay:..       
5f00: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
5f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5f20: 64 6f 75 62 6c 65 20 76 61 6c 75 65 20 3d 20 54  double value = T
5f30: 6f 4a 75 6c 69 61 6e 44 61 79 28 64 74 29 3b 0d  oJulianDay(dt);.
5f40: 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d  ...#if !PLATFORM
5f50: 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52  _COMPACTFRAMEWOR
5f60: 4b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  K..             
5f70: 20 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67         if ((flag
5f80: 73 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63  s & SQLiteConnec
5f90: 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e  tionFlags.LogBin
5fa0: 64 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e  d) == SQLiteConn
5fb0: 65 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42  ectionFlags.LogB
5fc0: 69 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ind)..          
5fd0: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
5fe0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5ff0: 20 20 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e       LogBind(han
6000: 64 6c 65 2c 20 69 6e 64 65 78 2c 20 76 61 6c 75  dle, index, valu
6010: 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  e);..           
6020: 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20           }....  
6030: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6040: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
6050: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
6060: 6c 69 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62 6c  lite3_bind_doubl
6070: 65 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c  e(handle, index,
6080: 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6c 73 65 0d   value);..#else.
6090: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
60a0: 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73       int n = Uns
60b0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
60c0: 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64 6f  .sqlite3_bind_do
60d0: 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 68 61 6e  uble_interop(han
60e0: 64 6c 65 2c 20 69 6e 64 65 78 2c 20 72 65 66 20  dle, index, ref 
60f0: 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d  value);..#endif.
6100: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6110: 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20       if (n > 0) 
6120: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
6130: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74  Exception(n, Get
6140: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20  LastError());.. 
6150: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6160: 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20 20     break;..     
6170: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20             }..  
6180: 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20 53            case S
6190: 51 4c 69 74 65 44 61 74 65 46 6f 72 6d 61 74 73  QLiteDateFormats
61a0: 2e 55 6e 69 78 45 70 6f 63 68 3a 0d 0a 20 20 20  .UnixEpoch:..   
61b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a               {..
61c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
61d0: 20 20 20 20 6c 6f 6e 67 20 76 61 6c 75 65 20 3d      long value =
61e0: 20 43 6f 6e 76 65 72 74 2e 54 6f 49 6e 74 36 34   Convert.ToInt64
61f0: 28 64 74 2e 53 75 62 74 72 61 63 74 28 55 6e 69  (dt.Subtract(Uni
6200: 78 45 70 6f 63 68 29 2e 54 6f 74 61 6c 53 65 63  xEpoch).TotalSec
6210: 6f 6e 64 73 29 3b 0d 0a 0d 0a 23 69 66 20 21 50  onds);....#if !P
6220: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
6230: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20  RAMEWORK..      
6240: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66                if
6250: 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74   ((flags & SQLit
6260: 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73  eConnectionFlags
6270: 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c  .LogBind) == SQL
6280: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
6290: 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20  gs.LogBind)..   
62a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
62b0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
62c0: 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67 42              LogB
62d0: 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65  ind(handle, inde
62e0: 78 2c 20 76 61 6c 75 65 29 3b 0d 0a 20 20 20 20  x, value);..    
62f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6300: 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20  }....           
6310: 20 20 20 20 20 20 20 20 20 69 6e 74 20 6e 20 3d           int n =
6320: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
6330: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e  hods.sqlite3_bin
6340: 64 5f 69 6e 74 36 34 28 68 61 6e 64 6c 65 2c 20  d_int64(handle, 
6350: 69 6e 64 65 78 2c 20 76 61 6c 75 65 29 3b 0d 0a  index, value);..
6360: 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20 20  #else..         
6370: 20 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 6e             int n
6380: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
6390: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62  ethods.sqlite3_b
63a0: 69 6e 64 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f  ind_int64_intero
63b0: 70 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c  p(handle, index,
63c0: 20 72 65 66 20 76 61 6c 75 65 29 3b 0d 0a 23 65   ref value);..#e
63d0: 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20 20 20  ndif..          
63e0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 6e 20            if (n 
63f0: 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53  > 0) throw new S
6400: 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e  QLiteException(n
6410: 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29  , GetLastError()
6420: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
6430: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a          break;..
6440: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6450: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 64  }..            d
6460: 65 66 61 75 6c 74 3a 0d 0a 20 20 20 20 20 20 20  efault:..       
6470: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
6480: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6490: 62 79 74 65 5b 5d 20 62 20 3d 20 54 6f 55 54 46  byte[] b = ToUTF
64a0: 38 28 64 74 29 3b 0d 0a 0d 0a 23 69 66 20 21 50  8(dt);....#if !P
64b0: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
64c0: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20  RAMEWORK..      
64d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66                if
64e0: 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74   ((flags & SQLit
64f0: 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73  eConnectionFlags
6500: 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c  .LogBind) == SQL
6510: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
6520: 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20  gs.LogBind)..   
6530: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6540: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
6550: 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67 42              LogB
6560: 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65  ind(handle, inde
6570: 78 2c 20 62 29 3b 0d 0a 20 20 20 20 20 20 20 20  x, b);..        
6580: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 23              }..#
6590: 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20 20  endif....       
65a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6e 74               int
65b0: 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   n = UnsafeNativ
65c0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
65d0: 5f 62 69 6e 64 5f 74 65 78 74 28 68 61 6e 64 6c  _bind_text(handl
65e0: 65 2c 20 69 6e 64 65 78 2c 20 62 2c 20 62 2e 4c  e, index, b, b.L
65f0: 65 6e 67 74 68 20 2d 20 31 2c 20 28 49 6e 74 50  ength - 1, (IntP
6600: 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20 20  tr)(-1));..     
6610: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
6620: 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20  f (n > 0) throw 
6630: 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74  new SQLiteExcept
6640: 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45 72  ion(n, GetLastEr
6650: 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 20 20 20  ror());..       
6660: 20 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65               bre
6670: 61 6b 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ak;..           
6680: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
6690: 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  }..    }....    
66a0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
66b0: 65 20 76 6f 69 64 20 42 69 6e 64 5f 42 6c 6f 62  e void Bind_Blob
66c0: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
66d0: 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f 6e   stmt, SQLiteCon
66e0: 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c 61  nectionFlags fla
66f0: 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 2c 20 62  gs, int index, b
6700: 79 74 65 5b 5d 20 62 6c 6f 62 44 61 74 61 29 0d  yte[] blobData).
6710: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20  .    {..        
6720: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48  SQLiteStatementH
6730: 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73  andle handle = s
6740: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
6750: 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f  ;....#if !PLATFO
6760: 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57  RM_COMPACTFRAMEW
6770: 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ORK..        if 
6780: 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74 65  ((flags & SQLite
6790: 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 2e  ConnectionFlags.
67a0: 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c 69  LogBind) == SQLi
67b0: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
67c0: 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20 20  s.LogBind)..    
67d0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
67e0: 20 20 20 4c 6f 67 42 69 6e 64 28 68 61 6e 64 6c     LogBind(handl
67f0: 65 2c 20 69 6e 64 65 78 2c 20 62 6c 6f 62 44 61  e, index, blobDa
6800: 74 61 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  ta);..        }.
6810: 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20  .#endif....     
6820: 20 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66     int n = Unsaf
6830: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
6840: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 62 6c 6f 62  qlite3_bind_blob
6850: 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 2c 20  (handle, index, 
6860: 62 6c 6f 62 44 61 74 61 2c 20 62 6c 6f 62 44 61  blobData, blobDa
6870: 74 61 2e 4c 65 6e 67 74 68 2c 20 28 49 6e 74 50  ta.Length, (IntP
6880: 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20 20  tr)(-1));..     
6890: 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68     if (n > 0) th
68a0: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
68b0: 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61  ception(n, GetLa
68c0: 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20  stError());..   
68d0: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
68e0: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
68f0: 20 42 69 6e 64 5f 4e 75 6c 6c 28 53 51 4c 69 74   Bind_Null(SQLit
6900: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
6910: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
6920: 6e 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 69 6e  nFlags flags, in
6930: 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b 0d  t index)..    {.
6940: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 53  .        SQLiteS
6950: 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68  tatementHandle h
6960: 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71  andle = stmt._sq
6970: 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 0d 0a 23 69  lite_stmt;....#i
6980: 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50  f !PLATFORM_COMP
6990: 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20  ACTFRAMEWORK..  
69a0: 20 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73        if ((flags
69b0: 20 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74   & SQLiteConnect
69c0: 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64  ionFlags.LogBind
69d0: 29 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65  ) == SQLiteConne
69e0: 63 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69  ctionFlags.LogBi
69f0: 6e 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  nd)..        {..
6a00: 20 20 20 20 20 20 20 20 20 20 20 20 4c 6f 67 42              LogB
6a10: 69 6e 64 28 68 61 6e 64 6c 65 2c 20 69 6e 64 65  ind(handle, inde
6a20: 78 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a  x);..        }..
6a30: 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20  #endif....      
6a40: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
6a50: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
6a60: 6c 69 74 65 33 5f 62 69 6e 64 5f 6e 75 6c 6c 28  lite3_bind_null(
6a70: 68 61 6e 64 6c 65 2c 20 69 6e 64 65 78 29 3b 0d  handle, index);.
6a80: 0a 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3e  .        if (n >
6a90: 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51   0) throw new SQ
6aa0: 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c  LiteException(n,
6ab0: 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29   GetLastError())
6ac0: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
6ad0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
6ae0: 65 20 69 6e 74 20 42 69 6e 64 5f 50 61 72 61 6d  e int Bind_Param
6af0: 43 6f 75 6e 74 28 53 51 4c 69 74 65 53 74 61 74  Count(SQLiteStat
6b00: 65 6d 65 6e 74 20 73 74 6d 74 2c 20 53 51 4c 69  ement stmt, SQLi
6b10: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67  teConnectionFlag
6b20: 73 20 66 6c 61 67 73 29 0d 0a 20 20 20 20 7b 0d  s flags)..    {.
6b30: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 53  .        SQLiteS
6b40: 74 61 74 65 6d 65 6e 74 48 61 6e 64 6c 65 20 68  tatementHandle h
6b50: 61 6e 64 6c 65 20 3d 20 73 74 6d 74 2e 5f 73 71  andle = stmt._sq
6b60: 6c 69 74 65 5f 73 74 6d 74 3b 0d 0a 20 20 20 20  lite_stmt;..    
6b70: 20 20 20 20 69 6e 74 20 76 61 6c 75 65 20 3d 20      int value = 
6b80: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
6b90: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64  ods.sqlite3_bind
6ba0: 5f 70 61 72 61 6d 65 74 65 72 5f 63 6f 75 6e 74  _parameter_count
6bb0: 28 68 61 6e 64 6c 65 29 3b 0d 0a 0d 0a 23 69 66  (handle);....#if
6bc0: 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41   !PLATFORM_COMPA
6bd0: 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20  CTFRAMEWORK..   
6be0: 20 20 20 20 20 69 66 20 28 28 66 6c 61 67 73 20       if ((flags 
6bf0: 26 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  & SQLiteConnecti
6c00: 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29  onFlags.LogBind)
6c10: 20 3d 3d 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63   == SQLiteConnec
6c20: 74 69 6f 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e  tionFlags.LogBin
6c30: 64 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  d)..        {.. 
6c40: 20 20 20 20 20 20 20 20 20 20 20 49 6e 74 50 74             IntPt
6c50: 72 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 20 3d  r handleIntPtr =
6c60: 20 68 61 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20   handle;....    
6c70: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f          SQLiteLo
6c80: 67 2e 4c 6f 67 4d 65 73 73 61 67 65 28 30 2c 20  g.LogMessage(0, 
6c90: 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a  String.Format(..
6ca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6cb0: 22 53 74 61 74 65 6d 65 6e 74 20 7b 30 7d 20 70  "Statement {0} p
6cc0: 61 72 61 6d 74 65 72 20 63 6f 75 6e 74 20 69 73  aramter count is
6cd0: 20 7b 31 7d 2e 22 2c 0d 0a 20 20 20 20 20 20 20   {1}.",..       
6ce0: 20 20 20 20 20 20 20 20 20 68 61 6e 64 6c 65 49           handleI
6cf0: 6e 74 50 74 72 2c 20 76 61 6c 75 65 29 29 3b 0d  ntPtr, value));.
6d00: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 23 65 6e 64  .        }..#end
6d10: 69 66 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72 65  if....        re
6d20: 74 75 72 6e 20 76 61 6c 75 65 3b 0d 0a 20 20 20  turn value;..   
6d30: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
6d40: 61 6c 20 6f 76 65 72 72 69 64 65 20 73 74 72 69  al override stri
6d50: 6e 67 20 42 69 6e 64 5f 50 61 72 61 6d 4e 61 6d  ng Bind_ParamNam
6d60: 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  e(SQLiteStatemen
6d70: 74 20 73 74 6d 74 2c 20 53 51 4c 69 74 65 43 6f  t stmt, SQLiteCo
6d80: 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73 20 66 6c  nnectionFlags fl
6d90: 61 67 73 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d  ags, int index).
6da0: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20  .    {..        
6db0: 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48  SQLiteStatementH
6dc0: 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73  andle handle = s
6dd0: 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74  tmt._sqlite_stmt
6de0: 3b 0d 0a 20 20 20 20 20 20 20 20 73 74 72 69 6e  ;..        strin
6df0: 67 20 6e 61 6d 65 3b 0d 0a 0d 0a 23 69 66 20 21  g name;....#if !
6e00: 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d  SQLITE_STANDARD.
6e10: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6c 65 6e  .        int len
6e20: 3b 0d 0a 20 20 20 20 20 20 20 20 6e 61 6d 65 20  ;..        name 
6e30: 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55  = UTF8ToString(U
6e40: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
6e50: 64 73 2e 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  ds.sqlite3_bind_
6e60: 70 61 72 61 6d 65 74 65 72 5f 6e 61 6d 65 5f 69  parameter_name_i
6e70: 6e 74 65 72 6f 70 28 68 61 6e 64 6c 65 2c 20 69  nterop(handle, i
6e80: 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20  ndex, out len), 
6e90: 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20  len);..#else..  
6ea0: 20 20 20 20 20 20 6e 61 6d 65 20 3d 20 55 54 46        name = UTF
6eb0: 38 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65  8ToString(Unsafe
6ec0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
6ed0: 6c 69 74 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d  lite3_bind_param
6ee0: 65 74 65 72 5f 6e 61 6d 65 28 68 61 6e 64 6c 65  eter_name(handle
6ef0: 2c 20 69 6e 64 65 78 29 2c 20 2d 31 29 3b 0d 0a  , index), -1);..
6f00: 23 65 6e 64 69 66 0d 0a 0d 0a 23 69 66 20 21 50  #endif....#if !P
6f10: 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46  LATFORM_COMPACTF
6f20: 52 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20  RAMEWORK..      
6f30: 20 20 69 66 20 28 28 66 6c 61 67 73 20 26 20 53    if ((flags & S
6f40: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46  QLiteConnectionF
6f50: 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d  lags.LogBind) ==
6f60: 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f   SQLiteConnectio
6f70: 6e 46 6c 61 67 73 2e 4c 6f 67 42 69 6e 64 29 0d  nFlags.LogBind).
6f80: 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  .        {..    
6f90: 20 20 20 20 20 20 20 20 49 6e 74 50 74 72 20 68          IntPtr h
6fa0: 61 6e 64 6c 65 49 6e 74 50 74 72 20 3d 20 68 61  andleIntPtr = ha
6fb0: 6e 64 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  ndle;....       
6fc0: 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e 4c       SQLiteLog.L
6fd0: 6f 67 4d 65 73 73 61 67 65 28 30 2c 20 53 74 72  ogMessage(0, Str
6fe0: 69 6e 67 2e 46 6f 72 6d 61 74 28 0d 0a 20 20 20  ing.Format(..   
6ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 53 74               "St
7000: 61 74 65 6d 65 6e 74 20 7b 30 7d 20 70 61 72 61  atement {0} para
7010: 6d 74 65 72 20 23 7b 31 7d 20 6e 61 6d 65 20 69  mter #{1} name i
7020: 73 20 7b 7b 7b 32 7d 7d 7d 2e 22 2c 0d 0a 20 20  s {{{2}}}.",..  
7030: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 68 61                ha
7040: 6e 64 6c 65 49 6e 74 50 74 72 2c 20 69 6e 64 65  ndleIntPtr, inde
7050: 78 2c 20 6e 61 6d 65 29 29 3b 0d 0a 20 20 20 20  x, name));..    
7060: 20 20 20 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d      }..#endif...
7070: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
7080: 6e 61 6d 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  name;..    }....
7090: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
70a0: 72 72 69 64 65 20 69 6e 74 20 42 69 6e 64 5f 50  rride int Bind_P
70b0: 61 72 61 6d 49 6e 64 65 78 28 53 51 4c 69 74 65  aramIndex(SQLite
70c0: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
70d0: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
70e0: 46 6c 61 67 73 20 66 6c 61 67 73 2c 20 73 74 72  Flags flags, str
70f0: 69 6e 67 20 70 61 72 61 6d 4e 61 6d 65 29 0d 0a  ing paramName)..
7100: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 53      {..        S
7110: 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74 48 61  QLiteStatementHa
7120: 6e 64 6c 65 20 68 61 6e 64 6c 65 20 3d 20 73 74  ndle handle = st
7130: 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 3b  mt._sqlite_stmt;
7140: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 6e  ..        int in
7150: 64 65 78 20 3d 20 55 6e 73 61 66 65 4e 61 74 69  dex = UnsafeNati
7160: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
7170: 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72  3_bind_parameter
7180: 5f 69 6e 64 65 78 28 68 61 6e 64 6c 65 2c 20 54  _index(handle, T
7190: 6f 55 54 46 38 28 70 61 72 61 6d 4e 61 6d 65 29  oUTF8(paramName)
71a0: 29 3b 0d 0a 0d 0a 23 69 66 20 21 50 4c 41 54 46  );....#if !PLATF
71b0: 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45  ORM_COMPACTFRAME
71c0: 57 4f 52 4b 0d 0a 20 20 20 20 20 20 20 20 69 66  WORK..        if
71d0: 20 28 28 66 6c 61 67 73 20 26 20 53 51 4c 69 74   ((flags & SQLit
71e0: 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61 67 73  eConnectionFlags
71f0: 2e 4c 6f 67 42 69 6e 64 29 20 3d 3d 20 53 51 4c  .LogBind) == SQL
7200: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 46 6c 61  iteConnectionFla
7210: 67 73 2e 4c 6f 67 42 69 6e 64 29 0d 0a 20 20 20  gs.LogBind)..   
7220: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
7230: 20 20 20 20 49 6e 74 50 74 72 20 68 61 6e 64 6c      IntPtr handl
7240: 65 49 6e 74 50 74 72 20 3d 20 68 61 6e 64 6c 65  eIntPtr = handle
7250: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ;....           
7260: 20 53 51 4c 69 74 65 4c 6f 67 2e 4c 6f 67 4d 65   SQLiteLog.LogMe
7270: 73 73 61 67 65 28 30 2c 20 53 74 72 69 6e 67 2e  ssage(0, String.
7280: 46 6f 72 6d 61 74 28 0d 0a 20 20 20 20 20 20 20  Format(..       
7290: 20 20 20 20 20 20 20 20 20 22 53 74 61 74 65 6d           "Statem
72a0: 65 6e 74 20 7b 30 7d 20 70 61 72 61 6d 74 65 72  ent {0} paramter
72b0: 20 69 6e 64 65 78 20 6f 66 20 6e 61 6d 65 20 7b   index of name {
72c0: 7b 7b 31 7d 7d 7d 20 69 73 20 23 7b 32 7d 2e 22  {{1}}} is #{2}."
72d0: 2c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ,..             
72e0: 20 20 20 68 61 6e 64 6c 65 49 6e 74 50 74 72 2c     handleIntPtr,
72f0: 20 70 61 72 61 6d 4e 61 6d 65 2c 20 69 6e 64 65   paramName, inde
7300: 78 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d  x));..        }.
7310: 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20  .#endif....     
7320: 20 20 20 72 65 74 75 72 6e 20 69 6e 64 65 78 3b     return index;
7330: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
7340: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
7350: 20 69 6e 74 20 43 6f 6c 75 6d 6e 43 6f 75 6e 74   int ColumnCount
7360: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
7370: 20 73 74 6d 74 29 0d 0a 20 20 20 20 7b 0d 0a 20   stmt)..    {.. 
7380: 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61       return Unsa
7390: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
73a0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 63  sqlite3_column_c
73b0: 6f 75 6e 74 28 73 74 6d 74 2e 5f 73 71 6c 69 74  ount(stmt._sqlit
73c0: 65 5f 73 74 6d 74 29 3b 0d 0a 20 20 20 20 7d 0d  e_stmt);..    }.
73d0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
73e0: 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67 20  override string 
73f0: 43 6f 6c 75 6d 6e 4e 61 6d 65 28 53 51 4c 69 74  ColumnName(SQLit
7400: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
7410: 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20   int index)..   
7420: 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f   {..#if !SQLITE_
7430: 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20  STANDARD..      
7440: 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20  int len;..      
7450: 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72  return UTF8ToStr
7460: 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65  ing(UnsafeNative
7470: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
7480: 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 5f 69 6e 74 65  column_name_inte
7490: 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  rop(stmt._sqlite
74a0: 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75  _stmt, index, ou
74b0: 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23  t len), len);..#
74c0: 65 6c 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75  else..      retu
74d0: 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28  rn UTF8ToString(
74e0: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
74f0: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ods.sqlite3_colu
7500: 6d 6e 5f 6e 61 6d 65 28 73 74 6d 74 2e 5f 73 71  mn_name(stmt._sq
7510: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
7520: 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66 0d  ), -1);..#endif.
7530: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
7540: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
7550: 54 79 70 65 41 66 66 69 6e 69 74 79 20 43 6f 6c  TypeAffinity Col
7560: 75 6d 6e 41 66 66 69 6e 69 74 79 28 53 51 4c 69  umnAffinity(SQLi
7570: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
7580: 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20  , int index)..  
7590: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72    {..      retur
75a0: 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  n UnsafeNativeMe
75b0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
75c0: 6c 75 6d 6e 5f 74 79 70 65 28 73 74 6d 74 2e 5f  lumn_type(stmt._
75d0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
75e0: 65 78 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ex);..    }.... 
75f0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
7600: 72 69 64 65 20 73 74 72 69 6e 67 20 43 6f 6c 75  ride string Colu
7610: 6d 6e 54 79 70 65 28 53 51 4c 69 74 65 53 74 61  mnType(SQLiteSta
7620: 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74  tement stmt, int
7630: 20 69 6e 64 65 78 2c 20 6f 75 74 20 54 79 70 65   index, out Type
7640: 41 66 66 69 6e 69 74 79 20 6e 41 66 66 69 6e 69  Affinity nAffini
7650: 74 79 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ty)..    {..    
7660: 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 23 69 66 20    int len;..#if 
7670: 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44  !SQLITE_STANDARD
7680: 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72 20 70  ..      IntPtr p
7690: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
76a0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
76b0: 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65 5f 69  olumn_decltype_i
76c0: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
76d0: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
76e0: 20 6f 75 74 20 6c 65 6e 29 3b 0d 0a 23 65 6c 73   out len);..#els
76f0: 65 0d 0a 20 20 20 20 20 20 6c 65 6e 20 3d 20 2d  e..      len = -
7700: 31 3b 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72  1;..      IntPtr
7710: 20 70 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76   p = UnsafeNativ
7720: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
7730: 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65  _column_decltype
7740: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
7750: 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 23 65 6e  mt, index);..#en
7760: 64 69 66 0d 0a 20 20 20 20 20 20 6e 41 66 66 69  dif..      nAffi
7770: 6e 69 74 79 20 3d 20 43 6f 6c 75 6d 6e 41 66 66  nity = ColumnAff
7780: 69 6e 69 74 79 28 73 74 6d 74 2c 20 69 6e 64 65  inity(stmt, inde
7790: 78 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  x);....      if 
77a0: 28 70 20 21 3d 20 49 6e 74 50 74 72 2e 5a 65 72  (p != IntPtr.Zer
77b0: 6f 29 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f  o) return UTF8To
77c0: 53 74 72 69 6e 67 28 70 2c 20 6c 65 6e 29 3b 0d  String(p, len);.
77d0: 0a 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20  .      else..   
77e0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 73 74     {..        st
77f0: 72 69 6e 67 5b 5d 20 61 72 20 3d 20 73 74 6d 74  ring[] ar = stmt
7800: 2e 54 79 70 65 44 65 66 69 6e 69 74 69 6f 6e 73  .TypeDefinitions
7810: 3b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 61  ;..        if (a
7820: 72 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20  r != null)..    
7830: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
7840: 20 69 66 20 28 69 6e 64 65 78 20 3c 20 61 72 2e   if (index < ar.
7850: 4c 65 6e 67 74 68 20 26 26 20 61 72 5b 69 6e 64  Length && ar[ind
7860: 65 78 5d 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20 20  ex] != null)..  
7870: 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e            return
7880: 20 61 72 5b 69 6e 64 65 78 5d 3b 0d 0a 20 20 20   ar[index];..   
7890: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
78a0: 72 65 74 75 72 6e 20 53 74 72 69 6e 67 2e 45 6d  return String.Em
78b0: 70 74 79 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  pty;....        
78c0: 2f 2f 73 77 69 74 63 68 20 28 6e 41 66 66 69 6e  //switch (nAffin
78d0: 69 74 79 29 0d 0a 20 20 20 20 20 20 20 20 2f 2f  ity)..        //
78e0: 7b 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 63  {..        //  c
78f0: 61 73 65 20 54 79 70 65 41 66 66 69 6e 69 74 79  ase TypeAffinity
7900: 2e 49 6e 74 36 34 3a 0d 0a 20 20 20 20 20 20 20  .Int64:..       
7910: 20 2f 2f 20 20 20 20 72 65 74 75 72 6e 20 22 42   //    return "B
7920: 49 47 49 4e 54 22 3b 0d 0a 20 20 20 20 20 20 20  IGINT";..       
7930: 20 2f 2f 20 20 63 61 73 65 20 54 79 70 65 41 66   //  case TypeAf
7940: 66 69 6e 69 74 79 2e 44 6f 75 62 6c 65 3a 0d 0a  finity.Double:..
7950: 20 20 20 20 20 20 20 20 2f 2f 20 20 20 20 72 65          //    re
7960: 74 75 72 6e 20 22 44 4f 55 42 4c 45 22 3b 0d 0a  turn "DOUBLE";..
7970: 20 20 20 20 20 20 20 20 2f 2f 20 20 63 61 73 65          //  case
7980: 20 54 79 70 65 41 66 66 69 6e 69 74 79 2e 42 6c   TypeAffinity.Bl
7990: 6f 62 3a 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20  ob:..        // 
79a0: 20 20 20 72 65 74 75 72 6e 20 22 42 4c 4f 42 22     return "BLOB"
79b0: 3b 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 64  ;..        //  d
79c0: 65 66 61 75 6c 74 3a 0d 0a 20 20 20 20 20 20 20  efault:..       
79d0: 20 2f 2f 20 20 20 20 72 65 74 75 72 6e 20 22 54   //    return "T
79e0: 45 58 54 22 3b 0d 0a 20 20 20 20 20 20 20 20 2f  EXT";..        /
79f0: 2f 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  /}..      }..   
7a00: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
7a10: 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  al override int 
7a20: 43 6f 6c 75 6d 6e 49 6e 64 65 78 28 53 51 4c 69  ColumnIndex(SQLi
7a30: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
7a40: 2c 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e 4e  , string columnN
7a50: 61 6d 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  ame)..    {..   
7a60: 20 20 20 69 6e 74 20 78 20 3d 20 43 6f 6c 75 6d     int x = Colum
7a70: 6e 43 6f 75 6e 74 28 73 74 6d 74 29 3b 0d 0a 0d  nCount(stmt);...
7a80: 0a 20 20 20 20 20 20 66 6f 72 20 28 69 6e 74 20  .      for (int 
7a90: 6e 20 3d 20 30 3b 20 6e 20 3c 20 78 3b 20 6e 2b  n = 0; n < x; n+
7aa0: 2b 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20  +)..      {..   
7ab0: 20 20 20 20 20 69 66 20 28 53 74 72 69 6e 67 2e       if (String.
7ac0: 43 6f 6d 70 61 72 65 28 63 6f 6c 75 6d 6e 4e 61  Compare(columnNa
7ad0: 6d 65 2c 20 43 6f 6c 75 6d 6e 4e 61 6d 65 28 73  me, ColumnName(s
7ae0: 74 6d 74 2c 20 6e 29 2c 20 53 74 72 69 6e 67 43  tmt, n), StringC
7af0: 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e 61  omparison.Ordina
7b00: 6c 49 67 6e 6f 72 65 43 61 73 65 29 20 3d 3d 20  lIgnoreCase) == 
7b10: 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20 72 65  0)..          re
7b20: 74 75 72 6e 20 6e 3b 0d 0a 20 20 20 20 20 20 7d  turn n;..      }
7b30: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 2d  ..      return -
7b40: 31 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  1;..    }....   
7b50: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
7b60: 64 65 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e  de string Column
7b70: 4f 72 69 67 69 6e 61 6c 4e 61 6d 65 28 53 51 4c  OriginalName(SQL
7b80: 69 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d  iteStatement stm
7b90: 74 2c 20 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20  t, int index).. 
7ba0: 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54     {..#if !SQLIT
7bb0: 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20  E_STANDARD..    
7bc0: 20 20 69 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20    int len;..    
7bd0: 20 20 72 65 74 75 72 6e 20 55 54 46 38 54 6f 53    return UTF8ToS
7be0: 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61 74 69  tring(UnsafeNati
7bf0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
7c00: 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f  3_column_origin_
7c10: 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d  name_interop(stm
7c20: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
7c30: 69 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c  index, out len),
7c40: 20 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20   len);..#else.. 
7c50: 20 20 20 20 20 72 65 74 75 72 6e 20 55 54 46 38       return UTF8
7c60: 54 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e  ToString(UnsafeN
7c70: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
7c80: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67  ite3_column_orig
7c90: 69 6e 5f 6e 61 6d 65 28 73 74 6d 74 2e 5f 73 71  in_name(stmt._sq
7ca0: 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78  lite_stmt, index
7cb0: 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66 0d  ), -1);..#endif.
7cc0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
7cd0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
7ce0: 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 44 61 74  string ColumnDat
7cf0: 61 62 61 73 65 4e 61 6d 65 28 53 51 4c 69 74 65  abaseName(SQLite
7d00: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
7d10: 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20  int index)..    
7d20: 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53  {..#if !SQLITE_S
7d30: 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 69  TANDARD..      i
7d40: 6e 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 72  nt len;..      r
7d50: 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69  eturn UTF8ToStri
7d60: 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  ng(UnsafeNativeM
7d70: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
7d80: 6f 6c 75 6d 6e 5f 64 61 74 61 62 61 73 65 5f 6e  olumn_database_n
7d90: 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74  ame_interop(stmt
7da0: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
7db0: 6e 64 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20  ndex, out len), 
7dc0: 6c 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20  len);..#else..  
7dd0: 20 20 20 20 72 65 74 75 72 6e 20 55 54 46 38 54      return UTF8T
7de0: 6f 53 74 72 69 6e 67 28 55 6e 73 61 66 65 4e 61  oString(UnsafeNa
7df0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
7e00: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62  te3_column_datab
7e10: 61 73 65 5f 6e 61 6d 65 28 73 74 6d 74 2e 5f 73  ase_name(stmt._s
7e20: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
7e30: 78 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66  x), -1);..#endif
7e40: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
7e50: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
7e60: 20 73 74 72 69 6e 67 20 43 6f 6c 75 6d 6e 54 61   string ColumnTa
7e70: 62 6c 65 4e 61 6d 65 28 53 51 4c 69 74 65 53 74  bleName(SQLiteSt
7e80: 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69 6e  atement stmt, in
7e90: 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b 0d  t index)..    {.
7ea0: 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54 41  .#if !SQLITE_STA
7eb0: 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 69 6e 74  NDARD..      int
7ec0: 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 72 65 74   len;..      ret
7ed0: 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e 67  urn UTF8ToString
7ee0: 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74  (UnsafeNativeMet
7ef0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c  hods.sqlite3_col
7f00: 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65 5f 69  umn_table_name_i
7f10: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
7f20: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
7f30: 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b   out len), len);
7f40: 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 72  ..#else..      r
7f50: 65 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69  eturn UTF8ToStri
7f60: 6e 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  ng(UnsafeNativeM
7f70: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
7f80: 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65  olumn_table_name
7f90: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
7fa0: 6d 74 2c 20 69 6e 64 65 78 29 2c 20 2d 31 29 3b  mt, index), -1);
7fb0: 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d  ..#endif..    }.
7fc0: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
7fd0: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 43 6f  override void Co
7fe0: 6c 75 6d 6e 4d 65 74 61 44 61 74 61 28 73 74 72  lumnMetaData(str
7ff0: 69 6e 67 20 64 61 74 61 42 61 73 65 2c 20 73 74  ing dataBase, st
8000: 72 69 6e 67 20 74 61 62 6c 65 2c 20 73 74 72 69  ring table, stri
8010: 6e 67 20 63 6f 6c 75 6d 6e 2c 20 6f 75 74 20 73  ng column, out s
8020: 74 72 69 6e 67 20 64 61 74 61 54 79 70 65 2c 20  tring dataType, 
8030: 6f 75 74 20 73 74 72 69 6e 67 20 63 6f 6c 6c 61  out string colla
8040: 74 65 53 65 71 75 65 6e 63 65 2c 20 6f 75 74 20  teSequence, out 
8050: 62 6f 6f 6c 20 6e 6f 74 4e 75 6c 6c 2c 20 6f 75  bool notNull, ou
8060: 74 20 62 6f 6f 6c 20 70 72 69 6d 61 72 79 4b 65  t bool primaryKe
8070: 79 2c 20 6f 75 74 20 62 6f 6f 6c 20 61 75 74 6f  y, out bool auto
8080: 49 6e 63 72 65 6d 65 6e 74 29 0d 0a 20 20 20 20  Increment)..    
8090: 7b 0d 0a 20 20 20 20 20 20 49 6e 74 50 74 72 20  {..      IntPtr 
80a0: 64 61 74 61 54 79 70 65 50 74 72 3b 0d 0a 20 20  dataTypePtr;..  
80b0: 20 20 20 20 49 6e 74 50 74 72 20 63 6f 6c 6c 53      IntPtr collS
80c0: 65 71 50 74 72 3b 0d 0a 20 20 20 20 20 20 69 6e  eqPtr;..      in
80d0: 74 20 6e 6e 6f 74 4e 75 6c 6c 3b 0d 0a 20 20 20  t nnotNull;..   
80e0: 20 20 20 69 6e 74 20 6e 70 72 69 6d 61 72 79 4b     int nprimaryK
80f0: 65 79 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e  ey;..      int n
8100: 61 75 74 6f 49 6e 63 3b 0d 0a 20 20 20 20 20 20  autoInc;..      
8110: 69 6e 74 20 6e 3b 0d 0a 20 20 20 20 20 20 69 6e  int n;..      in
8120: 74 20 64 74 4c 65 6e 3b 0d 0a 20 20 20 20 20 20  t dtLen;..      
8130: 69 6e 74 20 63 73 4c 65 6e 3b 0d 0a 0d 0a 23 69  int csLen;....#i
8140: 66 20 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41  f !SQLITE_STANDA
8150: 52 44 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55 6e  RD..      n = Un
8160: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
8170: 73 2e 73 71 6c 69 74 65 33 5f 74 61 62 6c 65 5f  s.sqlite3_table_
8180: 63 6f 6c 75 6d 6e 5f 6d 65 74 61 64 61 74 61 5f  column_metadata_
8190: 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f  interop(_sql, To
81a0: 55 54 46 38 28 64 61 74 61 42 61 73 65 29 2c 20  UTF8(dataBase), 
81b0: 54 6f 55 54 46 38 28 74 61 62 6c 65 29 2c 20 54  ToUTF8(table), T
81c0: 6f 55 54 46 38 28 63 6f 6c 75 6d 6e 29 2c 20 6f  oUTF8(column), o
81d0: 75 74 20 64 61 74 61 54 79 70 65 50 74 72 2c 20  ut dataTypePtr, 
81e0: 6f 75 74 20 63 6f 6c 6c 53 65 71 50 74 72 2c 20  out collSeqPtr, 
81f0: 6f 75 74 20 6e 6e 6f 74 4e 75 6c 6c 2c 20 6f 75  out nnotNull, ou
8200: 74 20 6e 70 72 69 6d 61 72 79 4b 65 79 2c 20 6f  t nprimaryKey, o
8210: 75 74 20 6e 61 75 74 6f 49 6e 63 2c 20 6f 75 74  ut nautoInc, out
8220: 20 64 74 4c 65 6e 2c 20 6f 75 74 20 63 73 4c 65   dtLen, out csLe
8230: 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  n);..#else..    
8240: 20 20 64 74 4c 65 6e 20 3d 20 2d 31 3b 0d 0a 20    dtLen = -1;.. 
8250: 20 20 20 20 20 63 73 4c 65 6e 20 3d 20 2d 31 3b       csLen = -1;
8260: 0d 0a 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55 6e  ....      n = Un
8270: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
8280: 73 2e 73 71 6c 69 74 65 33 5f 74 61 62 6c 65 5f  s.sqlite3_table_
8290: 63 6f 6c 75 6d 6e 5f 6d 65 74 61 64 61 74 61 28  column_metadata(
82a0: 5f 73 71 6c 2c 20 54 6f 55 54 46 38 28 64 61 74  _sql, ToUTF8(dat
82b0: 61 42 61 73 65 29 2c 20 54 6f 55 54 46 38 28 74  aBase), ToUTF8(t
82c0: 61 62 6c 65 29 2c 20 54 6f 55 54 46 38 28 63 6f  able), ToUTF8(co
82d0: 6c 75 6d 6e 29 2c 20 6f 75 74 20 64 61 74 61 54  lumn), out dataT
82e0: 79 70 65 50 74 72 2c 20 6f 75 74 20 63 6f 6c 6c  ypePtr, out coll
82f0: 53 65 71 50 74 72 2c 20 6f 75 74 20 6e 6e 6f 74  SeqPtr, out nnot
8300: 4e 75 6c 6c 2c 20 6f 75 74 20 6e 70 72 69 6d 61  Null, out nprima
8310: 72 79 4b 65 79 2c 20 6f 75 74 20 6e 61 75 74 6f  ryKey, out nauto
8320: 49 6e 63 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20  Inc);..#endif.. 
8330: 20 20 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20       if (n > 0) 
8340: 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65  throw new SQLite
8350: 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74  Exception(n, Get
8360: 4c 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 0d  LastError());...
8370: 0a 20 20 20 20 20 20 64 61 74 61 54 79 70 65 20  .      dataType 
8380: 3d 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 64  = UTF8ToString(d
8390: 61 74 61 54 79 70 65 50 74 72 2c 20 64 74 4c 65  ataTypePtr, dtLe
83a0: 6e 29 3b 0d 0a 20 20 20 20 20 20 63 6f 6c 6c 61  n);..      colla
83b0: 74 65 53 65 71 75 65 6e 63 65 20 3d 20 55 54 46  teSequence = UTF
83c0: 38 54 6f 53 74 72 69 6e 67 28 63 6f 6c 6c 53 65  8ToString(collSe
83d0: 71 50 74 72 2c 20 63 73 4c 65 6e 29 3b 0d 0a 0d  qPtr, csLen);...
83e0: 0a 20 20 20 20 20 20 6e 6f 74 4e 75 6c 6c 20 3d  .      notNull =
83f0: 20 28 6e 6e 6f 74 4e 75 6c 6c 20 3d 3d 20 31 29   (nnotNull == 1)
8400: 3b 0d 0a 20 20 20 20 20 20 70 72 69 6d 61 72 79  ;..      primary
8410: 4b 65 79 20 3d 20 28 6e 70 72 69 6d 61 72 79 4b  Key = (nprimaryK
8420: 65 79 20 3d 3d 20 31 29 3b 0d 0a 20 20 20 20 20  ey == 1);..     
8430: 20 61 75 74 6f 49 6e 63 72 65 6d 65 6e 74 20 3d   autoIncrement =
8440: 20 28 6e 61 75 74 6f 49 6e 63 20 3d 3d 20 31 29   (nautoInc == 1)
8450: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
8460: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
8470: 65 20 64 6f 75 62 6c 65 20 47 65 74 44 6f 75 62  e double GetDoub
8480: 6c 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  le(SQLiteStateme
8490: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
84a0: 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  ex)..    {..    
84b0: 20 20 64 6f 75 62 6c 65 20 76 61 6c 75 65 3b 0d    double value;.
84c0: 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43  .#if !PLATFORM_C
84d0: 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d  OMPACTFRAMEWORK.
84e0: 0a 20 20 20 20 20 20 76 61 6c 75 65 20 3d 20 55  .      value = U
84f0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
8500: 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  ds.sqlite3_colum
8510: 6e 5f 64 6f 75 62 6c 65 28 73 74 6d 74 2e 5f 73  n_double(stmt._s
8520: 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65  qlite_stmt, inde
8530: 78 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  x);..#else..    
8540: 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65    UnsafeNativeMe
8550: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
8560: 6c 75 6d 6e 5f 64 6f 75 62 6c 65 5f 69 6e 74 65  lumn_double_inte
8570: 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  rop(stmt._sqlite
8580: 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75  _stmt, index, ou
8590: 74 20 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69  t value);..#endi
85a0: 66 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  f..      return 
85b0: 76 61 6c 75 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  value;..    }...
85c0: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
85d0: 65 72 72 69 64 65 20 69 6e 74 20 47 65 74 49 6e  erride int GetIn
85e0: 74 33 32 28 53 51 4c 69 74 65 53 74 61 74 65 6d  t32(SQLiteStatem
85f0: 65 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e  ent stmt, int in
8600: 64 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  dex)..    {..   
8610: 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65     return Unsafe
8620: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
8630: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74  lite3_column_int
8640: 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73 74  (stmt._sqlite_st
8650: 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20 20 20  mt, index);..   
8660: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
8670: 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67  al override long
8680: 20 47 65 74 49 6e 74 36 34 28 53 51 4c 69 74 65   GetInt64(SQLite
8690: 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20  Statement stmt, 
86a0: 69 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20  int index)..    
86b0: 7b 0d 0a 20 20 20 20 20 20 6c 6f 6e 67 20 76 61  {..      long va
86c0: 6c 75 65 3b 0d 0a 23 69 66 20 21 50 4c 41 54 46  lue;..#if !PLATF
86d0: 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45  ORM_COMPACTFRAME
86e0: 57 4f 52 4b 0d 0a 20 20 20 20 20 20 76 61 6c 75  WORK..      valu
86f0: 65 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  e = UnsafeNative
8700: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
8710: 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 28 73 74 6d  column_int64(stm
8720: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
8730: 69 6e 64 65 78 29 3b 0d 0a 23 65 6c 73 65 0d 0a  index);..#else..
8740: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
8750: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
8760: 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 5f 69  3_column_int64_i
8770: 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f 73 71 6c  nterop(stmt._sql
8780: 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 2c  ite_stmt, index,
8790: 20 6f 75 74 20 76 61 6c 75 65 29 3b 0d 0a 23 65   out value);..#e
87a0: 6e 64 69 66 0d 0a 20 20 20 20 20 20 72 65 74 75  ndif..      retu
87b0: 72 6e 20 76 61 6c 75 65 3b 0d 0a 20 20 20 20 7d  rn value;..    }
87c0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
87d0: 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67   override string
87e0: 20 47 65 74 54 65 78 74 28 53 51 4c 69 74 65 53   GetText(SQLiteS
87f0: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
8800: 6e 74 20 69 6e 64 65 78 29 0d 0a 20 20 20 20 7b  nt index)..    {
8810: 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53 54  ..#if !SQLITE_ST
8820: 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 69 6e  ANDARD..      in
8830: 74 20 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 72 65  t len;..      re
8840: 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e  turn UTF8ToStrin
8850: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
8860: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f  thods.sqlite3_co
8870: 6c 75 6d 6e 5f 74 65 78 74 5f 69 6e 74 65 72 6f  lumn_text_intero
8880: 70 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  p(stmt._sqlite_s
8890: 74 6d 74 2c 20 69 6e 64 65 78 2c 20 6f 75 74 20  tmt, index, out 
88a0: 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d 0a 23 65 6c  len), len);..#el
88b0: 73 65 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e  se..      return
88c0: 20 55 54 46 38 54 6f 53 74 72 69 6e 67 28 55 6e   UTF8ToString(Un
88d0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
88e0: 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  s.sqlite3_column
88f0: 5f 74 65 78 74 28 73 74 6d 74 2e 5f 73 71 6c 69  _text(stmt._sqli
8900: 74 65 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 2c  te_stmt, index),
8910: 20 2d 31 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20   -1);..#endif.. 
8920: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
8930: 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 44 61  rnal override Da
8940: 74 65 54 69 6d 65 20 47 65 74 44 61 74 65 54 69  teTime GetDateTi
8950: 6d 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65  me(SQLiteStateme
8960: 6e 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64  nt stmt, int ind
8970: 65 78 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20  ex)..    {..#if 
8980: 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44  !SQLITE_STANDARD
8990: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b  ..      int len;
89a0: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 54  ..      return T
89b0: 6f 44 61 74 65 54 69 6d 65 28 55 6e 73 61 66 65  oDateTime(Unsafe
89c0: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
89d0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78  lite3_column_tex
89e0: 74 5f 69 6e 74 65 72 6f 70 28 73 74 6d 74 2e 5f  t_interop(stmt._
89f0: 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69 6e 64  sqlite_stmt, ind
8a00: 65 78 2c 20 6f 75 74 20 6c 65 6e 29 2c 20 6c 65  ex, out len), le
8a10: 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  n);..#else..    
8a20: 20 20 72 65 74 75 72 6e 20 54 6f 44 61 74 65 54    return ToDateT
8a30: 69 6d 65 28 55 6e 73 61 66 65 4e 61 74 69 76 65  ime(UnsafeNative
8a40: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
8a50: 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 73 74 6d 74  column_text(stmt
8a60: 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20 69  ._sqlite_stmt, i
8a70: 6e 64 65 78 29 2c 20 2d 31 29 3b 0d 0a 23 65 6e  ndex), -1);..#en
8a80: 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  dif..    }....  
8a90: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
8aa0: 69 64 65 20 6c 6f 6e 67 20 47 65 74 42 79 74 65  ide long GetByte
8ab0: 73 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  s(SQLiteStatemen
8ac0: 74 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65  t stmt, int inde
8ad0: 78 2c 20 69 6e 74 20 6e 44 61 74 61 4f 66 66 73  x, int nDataOffs
8ae0: 65 74 2c 20 62 79 74 65 5b 5d 20 62 44 65 73 74  et, byte[] bDest
8af0: 2c 20 69 6e 74 20 6e 53 74 61 72 74 2c 20 69 6e  , int nStart, in
8b00: 74 20 6e 4c 65 6e 67 74 68 29 0d 0a 20 20 20 20  t nLength)..    
8b10: 7b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 6c 65  {..      int nle
8b20: 6e 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  n = UnsafeNative
8b30: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
8b40: 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 28 73 74 6d  column_bytes(stm
8b50: 74 2e 5f 73 71 6c 69 74 65 5f 73 74 6d 74 2c 20  t._sqlite_stmt, 
8b60: 69 6e 64 65 78 29 3b 0d 0a 0d 0a 20 20 20 20 20  index);....     
8b70: 20 2f 2f 20 49 66 20 6e 6f 20 64 65 73 74 69 6e   // If no destin
8b80: 61 74 69 6f 6e 20 62 75 66 66 65 72 2c 20 72 65  ation buffer, re
8b90: 74 75 72 6e 20 74 68 65 20 73 69 7a 65 20 6e 65  turn the size ne
8ba0: 65 64 65 64 2e 0d 0a 20 20 20 20 20 20 69 66 20  eded...      if 
8bb0: 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c 29 20  (bDest == null) 
8bc0: 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0d 0a 0d 0a  return nlen;....
8bd0: 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 70 69 65        int nCopie
8be0: 64 20 3d 20 6e 4c 65 6e 67 74 68 3b 0d 0a 0d 0a  d = nLength;....
8bf0: 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65        if (nCopie
8c00: 64 20 2b 20 6e 53 74 61 72 74 20 3e 20 62 44 65  d + nStart > bDe
8c10: 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f 70 69  st.Length) nCopi
8c20: 65 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e 67 74  ed = bDest.Lengt
8c30: 68 20 2d 20 6e 53 74 61 72 74 3b 0d 0a 20 20 20  h - nStart;..   
8c40: 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b     if (nCopied +
8c50: 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e 20 6e   nDataOffset > n
8c60: 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d 20 6e  len) nCopied = n
8c70: 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66 73 65  len - nDataOffse
8c80: 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20 28  t;....      if (
8c90: 6e 43 6f 70 69 65 64 20 3e 20 30 29 0d 0a 20 20  nCopied > 0)..  
8ca0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 49      {..        I
8cb0: 6e 74 50 74 72 20 70 74 72 20 3d 20 55 6e 73 61  ntPtr ptr = Unsa
8cc0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
8cd0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62  sqlite3_column_b
8ce0: 6c 6f 62 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65  lob(stmt._sqlite
8cf0: 5f 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a  _stmt, index);..
8d00: 0d 0a 20 20 20 20 20 20 20 20 4d 61 72 73 68 61  ..        Marsha
8d10: 6c 2e 43 6f 70 79 28 28 49 6e 74 50 74 72 29 28  l.Copy((IntPtr)(
8d20: 70 74 72 2e 54 6f 49 6e 74 36 34 28 29 20 2b 20  ptr.ToInt64() + 
8d30: 6e 44 61 74 61 4f 66 66 73 65 74 29 2c 20 62 44  nDataOffset), bD
8d40: 65 73 74 2c 20 6e 53 74 61 72 74 2c 20 6e 43 6f  est, nStart, nCo
8d50: 70 69 65 64 29 3b 0d 0a 20 20 20 20 20 20 7d 0d  pied);..      }.
8d60: 0a 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20 20  .      else..   
8d70: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 6e 43     {..        nC
8d80: 6f 70 69 65 64 20 3d 20 30 3b 0d 0a 20 20 20 20  opied = 0;..    
8d90: 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74    }....      ret
8da0: 75 72 6e 20 6e 43 6f 70 69 65 64 3b 0d 0a 20 20  urn nCopied;..  
8db0: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
8dc0: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 6c 6f 6e  nal override lon
8dd0: 67 20 47 65 74 43 68 61 72 73 28 53 51 4c 69 74  g GetChars(SQLit
8de0: 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c  eStatement stmt,
8df0: 20 69 6e 74 20 69 6e 64 65 78 2c 20 69 6e 74 20   int index, int 
8e00: 6e 44 61 74 61 4f 66 66 73 65 74 2c 20 63 68 61  nDataOffset, cha
8e10: 72 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20 6e  r[] bDest, int n
8e20: 53 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e 67  Start, int nLeng
8e30: 74 68 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  th)..    {..    
8e40: 20 20 69 6e 74 20 6e 6c 65 6e 3b 0d 0a 20 20 20    int nlen;..   
8e50: 20 20 20 69 6e 74 20 6e 43 6f 70 69 65 64 20 3d     int nCopied =
8e60: 20 6e 4c 65 6e 67 74 68 3b 0d 0a 0d 0a 20 20 20   nLength;....   
8e70: 20 20 20 73 74 72 69 6e 67 20 73 74 72 20 3d 20     string str = 
8e80: 47 65 74 54 65 78 74 28 73 74 6d 74 2c 20 69 6e  GetText(stmt, in
8e90: 64 65 78 29 3b 0d 0a 20 20 20 20 20 20 6e 6c 65  dex);..      nle
8ea0: 6e 20 3d 20 73 74 72 2e 4c 65 6e 67 74 68 3b 0d  n = str.Length;.
8eb0: 0a 0d 0a 20 20 20 20 20 20 69 66 20 28 62 44 65  ...      if (bDe
8ec0: 73 74 20 3d 3d 20 6e 75 6c 6c 29 20 72 65 74 75  st == null) retu
8ed0: 72 6e 20 6e 6c 65 6e 3b 0d 0a 0d 0a 20 20 20 20  rn nlen;....    
8ee0: 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b 20    if (nCopied + 
8ef0: 6e 53 74 61 72 74 20 3e 20 62 44 65 73 74 2e 4c  nStart > bDest.L
8f00: 65 6e 67 74 68 29 20 6e 43 6f 70 69 65 64 20 3d  ength) nCopied =
8f10: 20 62 44 65 73 74 2e 4c 65 6e 67 74 68 20 2d 20   bDest.Length - 
8f20: 6e 53 74 61 72 74 3b 0d 0a 20 20 20 20 20 20 69  nStart;..      i
8f30: 66 20 28 6e 43 6f 70 69 65 64 20 2b 20 6e 44 61  f (nCopied + nDa
8f40: 74 61 4f 66 66 73 65 74 20 3e 20 6e 6c 65 6e 29  taOffset > nlen)
8f50: 20 6e 43 6f 70 69 65 64 20 3d 20 6e 6c 65 6e 20   nCopied = nlen 
8f60: 2d 20 6e 44 61 74 61 4f 66 66 73 65 74 3b 0d 0a  - nDataOffset;..
8f70: 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70  ..      if (nCop
8f80: 69 65 64 20 3e 20 30 29 0d 0a 20 20 20 20 20 20  ied > 0)..      
8f90: 20 20 73 74 72 2e 43 6f 70 79 54 6f 28 6e 44 61    str.CopyTo(nDa
8fa0: 74 61 4f 66 66 73 65 74 2c 20 62 44 65 73 74 2c  taOffset, bDest,
8fb0: 20 6e 53 74 61 72 74 2c 20 6e 43 6f 70 69 65 64   nStart, nCopied
8fc0: 29 3b 0d 0a 20 20 20 20 20 20 65 6c 73 65 20 6e  );..      else n
8fd0: 43 6f 70 69 65 64 20 3d 20 30 3b 0d 0a 0d 0a 20  Copied = 0;.... 
8fe0: 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f 70       return nCop
8ff0: 69 65 64 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ied;..    }.... 
9000: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
9010: 72 69 64 65 20 62 6f 6f 6c 20 49 73 4e 75 6c 6c  ride bool IsNull
9020: 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e 74  (SQLiteStatement
9030: 20 73 74 6d 74 2c 20 69 6e 74 20 69 6e 64 65 78   stmt, int index
9040: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
9050: 72 65 74 75 72 6e 20 28 43 6f 6c 75 6d 6e 41 66  return (ColumnAf
9060: 66 69 6e 69 74 79 28 73 74 6d 74 2c 20 69 6e 64  finity(stmt, ind
9070: 65 78 29 20 3d 3d 20 54 79 70 65 41 66 66 69 6e  ex) == TypeAffin
9080: 69 74 79 2e 4e 75 6c 6c 29 3b 0d 0a 20 20 20 20  ity.Null);..    
9090: 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  }....    interna
90a0: 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20 41  l override int A
90b0: 67 67 72 65 67 61 74 65 43 6f 75 6e 74 28 49 6e  ggregateCount(In
90c0: 74 50 74 72 20 63 6f 6e 74 65 78 74 29 0d 0a 20  tPtr context).. 
90d0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75     {..      retu
90e0: 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  rn UnsafeNativeM
90f0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 61  ethods.sqlite3_a
9100: 67 67 72 65 67 61 74 65 5f 63 6f 75 6e 74 28 63  ggregate_count(c
9110: 6f 6e 74 65 78 74 29 3b 0d 0a 20 20 20 20 7d 0d  ontext);..    }.
9120: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
9130: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 43 72  override void Cr
9140: 65 61 74 65 46 75 6e 63 74 69 6f 6e 28 73 74 72  eateFunction(str
9150: 69 6e 67 20 73 74 72 46 75 6e 63 74 69 6f 6e 2c  ing strFunction,
9160: 20 69 6e 74 20 6e 41 72 67 73 2c 20 62 6f 6f 6c   int nArgs, bool
9170: 20 6e 65 65 64 43 6f 6c 6c 53 65 71 2c 20 53 51   needCollSeq, SQ
9180: 4c 69 74 65 43 61 6c 6c 62 61 63 6b 20 66 75 6e  LiteCallback fun
9190: 63 2c 20 53 51 4c 69 74 65 43 61 6c 6c 62 61 63  c, SQLiteCallbac
91a0: 6b 20 66 75 6e 63 73 74 65 70 2c 20 53 51 4c 69  k funcstep, SQLi
91b0: 74 65 46 69 6e 61 6c 43 61 6c 6c 62 61 63 6b 20  teFinalCallback 
91c0: 66 75 6e 63 66 69 6e 61 6c 29 0d 0a 20 20 20 20  funcfinal)..    
91d0: 7b 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 3b 0d  {..      int n;.
91e0: 0a 0d 0a 23 69 66 20 21 53 51 4c 49 54 45 5f 53  ...#if !SQLITE_S
91f0: 54 41 4e 44 41 52 44 0d 0a 20 20 20 20 20 20 6e  TANDARD..      n
9200: 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d   = UnsafeNativeM
9210: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
9220: 72 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 5f 69  reate_function_i
9230: 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20 54 6f 55  nterop(_sql, ToU
9240: 54 46 38 28 73 74 72 46 75 6e 63 74 69 6f 6e 29  TF8(strFunction)
9250: 2c 20 6e 41 72 67 73 2c 20 34 2c 20 49 6e 74 50  , nArgs, 4, IntP
9260: 74 72 2e 5a 65 72 6f 2c 20 66 75 6e 63 2c 20 66  tr.Zero, func, f
9270: 75 6e 63 73 74 65 70 2c 20 66 75 6e 63 66 69 6e  uncstep, funcfin
9280: 61 6c 2c 20 28 6e 65 65 64 43 6f 6c 6c 53 65 71  al, (needCollSeq
9290: 20 3d 3d 20 74 72 75 65 29 20 3f 20 31 20 3a 20   == true) ? 1 : 
92a0: 30 29 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 6e  0);..      if (n
92b0: 20 3d 3d 20 30 29 20 6e 20 3d 20 55 6e 73 61 66   == 0) n = Unsaf
92c0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
92d0: 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 66 75  qlite3_create_fu
92e0: 6e 63 74 69 6f 6e 5f 69 6e 74 65 72 6f 70 28 5f  nction_interop(_
92f0: 73 71 6c 2c 20 54 6f 55 54 46 38 28 73 74 72 46  sql, ToUTF8(strF
9300: 75 6e 63 74 69 6f 6e 29 2c 20 6e 41 72 67 73 2c  unction), nArgs,
9310: 20 31 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f 2c   1, IntPtr.Zero,
9320: 20 66 75 6e 63 2c 20 66 75 6e 63 73 74 65 70 2c   func, funcstep,
9330: 20 66 75 6e 63 66 69 6e 61 6c 2c 20 28 6e 65 65   funcfinal, (nee
9340: 64 43 6f 6c 6c 53 65 71 20 3d 3d 20 74 72 75 65  dCollSeq == true
9350: 29 20 3f 20 31 20 3a 20 30 29 3b 0d 0a 23 65 6c  ) ? 1 : 0);..#el
9360: 73 65 0d 0a 20 20 20 20 20 20 6e 20 3d 20 55 6e  se..      n = Un
9370: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
9380: 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65  s.sqlite3_create
9390: 5f 66 75 6e 63 74 69 6f 6e 28 5f 73 71 6c 2c 20  _function(_sql, 
93a0: 54 6f 55 54 46 38 28 73 74 72 46 75 6e 63 74 69  ToUTF8(strFuncti
93b0: 6f 6e 29 2c 20 6e 41 72 67 73 2c 20 34 2c 20 49  on), nArgs, 4, I
93c0: 6e 74 50 74 72 2e 5a 65 72 6f 2c 20 66 75 6e 63  ntPtr.Zero, func
93d0: 2c 20 66 75 6e 63 73 74 65 70 2c 20 66 75 6e 63  , funcstep, func
93e0: 66 69 6e 61 6c 29 3b 0d 0a 20 20 20 20 20 20 69  final);..      i
93f0: 66 20 28 6e 20 3d 3d 20 30 29 20 6e 20 3d 20 55  f (n == 0) n = U
9400: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
9410: 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61 74  ds.sqlite3_creat
9420: 65 5f 66 75 6e 63 74 69 6f 6e 28 5f 73 71 6c 2c  e_function(_sql,
9430: 20 54 6f 55 54 46 38 28 73 74 72 46 75 6e 63 74   ToUTF8(strFunct
9440: 69 6f 6e 29 2c 20 6e 41 72 67 73 2c 20 31 2c 20  ion), nArgs, 1, 
9450: 49 6e 74 50 74 72 2e 5a 65 72 6f 2c 20 66 75 6e  IntPtr.Zero, fun
9460: 63 2c 20 66 75 6e 63 73 74 65 70 2c 20 66 75 6e  c, funcstep, fun
9470: 63 66 69 6e 61 6c 29 3b 0d 0a 23 65 6e 64 69 66  cfinal);..#endif
9480: 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3e 20  ..      if (n > 
9490: 30 29 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c  0) throw new SQL
94a0: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
94b0: 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b  GetLastError());
94c0: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
94d0: 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65  nternal override
94e0: 20 76 6f 69 64 20 43 72 65 61 74 65 43 6f 6c 6c   void CreateColl
94f0: 61 74 69 6f 6e 28 73 74 72 69 6e 67 20 73 74 72  ation(string str
9500: 43 6f 6c 6c 61 74 69 6f 6e 2c 20 53 51 4c 69 74  Collation, SQLit
9510: 65 43 6f 6c 6c 61 74 69 6f 6e 20 66 75 6e 63 2c  eCollation func,
9520: 20 53 51 4c 69 74 65 43 6f 6c 6c 61 74 69 6f 6e   SQLiteCollation
9530: 20 66 75 6e 63 31 36 29 0d 0a 20 20 20 20 7b 0d   func16)..    {.
9540: 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55  .      int n = U
9550: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
9560: 64 73 2e 73 71 6c 69 74 65 33 5f 63 72 65 61 74  ds.sqlite3_creat
9570: 65 5f 63 6f 6c 6c 61 74 69 6f 6e 28 5f 73 71 6c  e_collation(_sql
9580: 2c 20 54 6f 55 54 46 38 28 73 74 72 43 6f 6c 6c  , ToUTF8(strColl
9590: 61 74 69 6f 6e 29 2c 20 32 2c 20 49 6e 74 50 74  ation), 2, IntPt
95a0: 72 2e 5a 65 72 6f 2c 20 66 75 6e 63 31 36 29 3b  r.Zero, func16);
95b0: 0d 0a 20 20 20 20 20 20 69 66 20 28 6e 20 3d 3d  ..      if (n ==
95c0: 20 30 29 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61   0) n = UnsafeNa
95d0: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
95e0: 74 65 33 5f 63 72 65 61 74 65 5f 63 6f 6c 6c 61  te3_create_colla
95f0: 74 69 6f 6e 28 5f 73 71 6c 2c 20 54 6f 55 54 46  tion(_sql, ToUTF
9600: 38 28 73 74 72 43 6f 6c 6c 61 74 69 6f 6e 29 2c  8(strCollation),
9610: 20 31 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f 2c   1, IntPtr.Zero,
9620: 20 66 75 6e 63 29 3b 0d 0a 20 20 20 20 20 20 69   func);..      i
9630: 66 20 28 6e 20 3e 20 30 29 20 74 68 72 6f 77 20  f (n > 0) throw 
9640: 6e 65 77 20 53 51 4c 69 74 65 45 78 63 65 70 74  new SQLiteExcept
9650: 69 6f 6e 28 6e 2c 20 47 65 74 4c 61 73 74 45 72  ion(n, GetLastEr
9660: 72 6f 72 28 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a  ror());..    }..
9670: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
9680: 76 65 72 72 69 64 65 20 69 6e 74 20 43 6f 6e 74  verride int Cont
9690: 65 78 74 43 6f 6c 6c 61 74 65 43 6f 6d 70 61 72  extCollateCompar
96a0: 65 28 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64  e(CollationEncod
96b0: 69 6e 67 45 6e 75 6d 20 65 6e 63 2c 20 49 6e 74  ingEnum enc, Int
96c0: 50 74 72 20 63 6f 6e 74 65 78 74 2c 20 73 74 72  Ptr context, str
96d0: 69 6e 67 20 73 31 2c 20 73 74 72 69 6e 67 20 73  ing s1, string s
96e0: 32 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21  2)..    {..#if !
96f0: 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d  SQLITE_STANDARD.
9700: 0a 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62 31  .      byte[] b1
9710: 3b 0d 0a 20 20 20 20 20 20 62 79 74 65 5b 5d 20  ;..      byte[] 
9720: 62 32 3b 0d 0a 20 20 20 20 20 20 53 79 73 74 65  b2;..      Syste
9730: 6d 2e 54 65 78 74 2e 45 6e 63 6f 64 69 6e 67 20  m.Text.Encoding 
9740: 63 6f 6e 76 65 72 74 65 72 20 3d 20 6e 75 6c 6c  converter = null
9750: 3b 0d 0a 0d 0a 20 20 20 20 20 20 73 77 69 74 63  ;....      switc
9760: 68 20 28 65 6e 63 29 0d 0a 20 20 20 20 20 20 7b  h (enc)..      {
9770: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 43  ..        case C
9780: 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67  ollationEncoding
9790: 45 6e 75 6d 2e 55 54 46 38 3a 0d 0a 20 20 20 20  Enum.UTF8:..    
97a0: 20 20 20 20 20 20 63 6f 6e 76 65 72 74 65 72 20        converter 
97b0: 3d 20 53 79 73 74 65 6d 2e 54 65 78 74 2e 45 6e  = System.Text.En
97c0: 63 6f 64 69 6e 67 2e 55 54 46 38 3b 0d 0a 20 20  coding.UTF8;..  
97d0: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a          break;..
97e0: 20 20 20 20 20 20 20 20 63 61 73 65 20 43 6f 6c          case Col
97f0: 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67 45 6e  lationEncodingEn
9800: 75 6d 2e 55 54 46 31 36 4c 45 3a 0d 0a 20 20 20  um.UTF16LE:..   
9810: 20 20 20 20 20 20 20 63 6f 6e 76 65 72 74 65 72         converter
9820: 20 3d 20 53 79 73 74 65 6d 2e 54 65 78 74 2e 45   = System.Text.E
9830: 6e 63 6f 64 69 6e 67 2e 55 6e 69 63 6f 64 65 3b  ncoding.Unicode;
9840: 0d 0a 20 20 20 20 20 20 20 20 20 20 62 72 65 61  ..          brea
9850: 6b 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65  k;..        case
9860: 20 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69   CollationEncodi
9870: 6e 67 45 6e 75 6d 2e 55 54 46 31 36 42 45 3a 0d  ngEnum.UTF16BE:.
9880: 0a 20 20 20 20 20 20 20 20 20 20 63 6f 6e 76 65  .          conve
9890: 72 74 65 72 20 3d 20 53 79 73 74 65 6d 2e 54 65  rter = System.Te
98a0: 78 74 2e 45 6e 63 6f 64 69 6e 67 2e 42 69 67 45  xt.Encoding.BigE
98b0: 6e 64 69 61 6e 55 6e 69 63 6f 64 65 3b 0d 0a 20  ndianUnicode;.. 
98c0: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d           break;.
98d0: 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  .      }....    
98e0: 20 20 62 31 20 3d 20 63 6f 6e 76 65 72 74 65 72    b1 = converter
98f0: 2e 47 65 74 42 79 74 65 73 28 73 31 29 3b 0d 0a  .GetBytes(s1);..
9900: 20 20 20 20 20 20 62 32 20 3d 20 63 6f 6e 76 65        b2 = conve
9910: 72 74 65 72 2e 47 65 74 42 79 74 65 73 28 73 32  rter.GetBytes(s2
9920: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75  );....      retu
9930: 72 6e 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d  rn UnsafeNativeM
9940: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63  ethods.sqlite3_c
9950: 6f 6e 74 65 78 74 5f 63 6f 6c 6c 63 6f 6d 70 61  ontext_collcompa
9960: 72 65 28 63 6f 6e 74 65 78 74 2c 20 62 31 2c 20  re(context, b1, 
9970: 62 31 2e 4c 65 6e 67 74 68 2c 20 62 32 2c 20 62  b1.Length, b2, b
9980: 32 2e 4c 65 6e 67 74 68 29 3b 0d 0a 23 65 6c 73  2.Length);..#els
9990: 65 0d 0a 20 20 20 20 20 20 74 68 72 6f 77 20 6e  e..      throw n
99a0: 65 77 20 4e 6f 74 49 6d 70 6c 65 6d 65 6e 74 65  ew NotImplemente
99b0: 64 45 78 63 65 70 74 69 6f 6e 28 29 3b 0d 0a 23  dException();..#
99c0: 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  endif..    }....
99d0: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
99e0: 72 72 69 64 65 20 69 6e 74 20 43 6f 6e 74 65 78  rride int Contex
99f0: 74 43 6f 6c 6c 61 74 65 43 6f 6d 70 61 72 65 28  tCollateCompare(
9a00: 43 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e  CollationEncodin
9a10: 67 45 6e 75 6d 20 65 6e 63 2c 20 49 6e 74 50 74  gEnum enc, IntPt
9a20: 72 20 63 6f 6e 74 65 78 74 2c 20 63 68 61 72 5b  r context, char[
9a30: 5d 20 63 31 2c 20 63 68 61 72 5b 5d 20 63 32 29  ] c1, char[] c2)
9a40: 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51  ..    {..#if !SQ
9a50: 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20  LITE_STANDARD.. 
9a60: 20 20 20 20 20 62 79 74 65 5b 5d 20 62 31 3b 0d       byte[] b1;.
9a70: 0a 20 20 20 20 20 20 62 79 74 65 5b 5d 20 62 32  .      byte[] b2
9a80: 3b 0d 0a 20 20 20 20 20 20 53 79 73 74 65 6d 2e  ;..      System.
9a90: 54 65 78 74 2e 45 6e 63 6f 64 69 6e 67 20 63 6f  Text.Encoding co
9aa0: 6e 76 65 72 74 65 72 20 3d 20 6e 75 6c 6c 3b 0d  nverter = null;.
9ab0: 0a 0d 0a 20 20 20 20 20 20 73 77 69 74 63 68 20  ...      switch 
9ac0: 28 65 6e 63 29 0d 0a 20 20 20 20 20 20 7b 0d 0a  (enc)..      {..
9ad0: 20 20 20 20 20 20 20 20 63 61 73 65 20 43 6f 6c          case Col
9ae0: 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67 45 6e  lationEncodingEn
9af0: 75 6d 2e 55 54 46 38 3a 0d 0a 20 20 20 20 20 20  um.UTF8:..      
9b00: 20 20 20 20 63 6f 6e 76 65 72 74 65 72 20 3d 20      converter = 
9b10: 53 79 73 74 65 6d 2e 54 65 78 74 2e 45 6e 63 6f  System.Text.Enco
9b20: 64 69 6e 67 2e 55 54 46 38 3b 0d 0a 20 20 20 20  ding.UTF8;..    
9b30: 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20        break;..  
9b40: 20 20 20 20 20 20 63 61 73 65 20 43 6f 6c 6c 61        case Colla
9b50: 74 69 6f 6e 45 6e 63 6f 64 69 6e 67 45 6e 75 6d  tionEncodingEnum
9b60: 2e 55 54 46 31 36 4c 45 3a 0d 0a 20 20 20 20 20  .UTF16LE:..     
9b70: 20 20 20 20 20 63 6f 6e 76 65 72 74 65 72 20 3d       converter =
9b80: 20 53 79 73 74 65 6d 2e 54 65 78 74 2e 45 6e 63   System.Text.Enc
9b90: 6f 64 69 6e 67 2e 55 6e 69 63 6f 64 65 3b 0d 0a  oding.Unicode;..
9ba0: 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b            break;
9bb0: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 43  ..        case C
9bc0: 6f 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67  ollationEncoding
9bd0: 45 6e 75 6d 2e 55 54 46 31 36 42 45 3a 0d 0a 20  Enum.UTF16BE:.. 
9be0: 20 20 20 20 20 20 20 20 20 63 6f 6e 76 65 72 74           convert
9bf0: 65 72 20 3d 20 53 79 73 74 65 6d 2e 54 65 78 74  er = System.Text
9c00: 2e 45 6e 63 6f 64 69 6e 67 2e 42 69 67 45 6e 64  .Encoding.BigEnd
9c10: 69 61 6e 55 6e 69 63 6f 64 65 3b 0d 0a 20 20 20  ianUnicode;..   
9c20: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20         break;.. 
9c30: 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20       }....      
9c40: 62 31 20 3d 20 63 6f 6e 76 65 72 74 65 72 2e 47  b1 = converter.G
9c50: 65 74 42 79 74 65 73 28 63 31 29 3b 0d 0a 20 20  etBytes(c1);..  
9c60: 20 20 20 20 62 32 20 3d 20 63 6f 6e 76 65 72 74      b2 = convert
9c70: 65 72 2e 47 65 74 42 79 74 65 73 28 63 32 29 3b  er.GetBytes(c2);
9c80: 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e  ....      return
9c90: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
9ca0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6e  hods.sqlite3_con
9cb0: 74 65 78 74 5f 63 6f 6c 6c 63 6f 6d 70 61 72 65  text_collcompare
9cc0: 28 63 6f 6e 74 65 78 74 2c 20 62 31 2c 20 62 31  (context, b1, b1
9cd0: 2e 4c 65 6e 67 74 68 2c 20 62 32 2c 20 62 32 2e  .Length, b2, b2.
9ce0: 4c 65 6e 67 74 68 29 3b 0d 0a 23 65 6c 73 65 0d  Length);..#else.
9cf0: 0a 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77  .      throw new
9d00: 20 4e 6f 74 49 6d 70 6c 65 6d 65 6e 74 65 64 45   NotImplementedE
9d10: 78 63 65 70 74 69 6f 6e 28 29 3b 0d 0a 23 65 6e  xception();..#en
9d20: 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  dif..    }....  
9d30: 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72    internal overr
9d40: 69 64 65 20 43 6f 6c 6c 61 74 69 6f 6e 53 65 71  ide CollationSeq
9d50: 75 65 6e 63 65 20 47 65 74 43 6f 6c 6c 61 74 69  uence GetCollati
9d60: 6f 6e 53 65 71 75 65 6e 63 65 28 53 51 4c 69 74  onSequence(SQLit
9d70: 65 46 75 6e 63 74 69 6f 6e 20 66 75 6e 63 2c 20  eFunction func, 
9d80: 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 29 0d  IntPtr context).
9d90: 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c  .    {..#if !SQL
9da0: 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20  ITE_STANDARD..  
9db0: 20 20 20 20 43 6f 6c 6c 61 74 69 6f 6e 53 65 71      CollationSeq
9dc0: 75 65 6e 63 65 20 73 65 71 20 3d 20 6e 65 77 20  uence seq = new 
9dd0: 43 6f 6c 6c 61 74 69 6f 6e 53 65 71 75 65 6e 63  CollationSequenc
9de0: 65 28 29 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20  e();..      int 
9df0: 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20  len;..      int 
9e00: 74 79 70 65 3b 0d 0a 20 20 20 20 20 20 69 6e 74  type;..      int
9e10: 20 65 6e 63 3b 0d 0a 20 20 20 20 20 20 49 6e 74   enc;..      Int
9e20: 50 74 72 20 70 20 3d 20 55 6e 73 61 66 65 4e 61  Ptr p = UnsafeNa
9e30: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
9e40: 74 65 33 5f 63 6f 6e 74 65 78 74 5f 63 6f 6c 6c  te3_context_coll
9e50: 73 65 71 28 63 6f 6e 74 65 78 74 2c 20 6f 75 74  seq(context, out
9e60: 20 74 79 70 65 2c 20 6f 75 74 20 65 6e 63 2c 20   type, out enc, 
9e70: 6f 75 74 20 6c 65 6e 29 3b 0d 0a 0d 0a 20 20 20  out len);....   
9e80: 20 20 20 69 66 20 28 70 20 21 3d 20 6e 75 6c 6c     if (p != null
9e90: 29 20 73 65 71 2e 4e 61 6d 65 20 3d 20 55 54 46  ) seq.Name = UTF
9ea0: 38 54 6f 53 74 72 69 6e 67 28 70 2c 20 6c 65 6e  8ToString(p, len
9eb0: 29 3b 0d 0a 20 20 20 20 20 20 73 65 71 2e 54 79  );..      seq.Ty
9ec0: 70 65 20 3d 20 28 43 6f 6c 6c 61 74 69 6f 6e 54  pe = (CollationT
9ed0: 79 70 65 45 6e 75 6d 29 74 79 70 65 3b 0d 0a 20  ypeEnum)type;.. 
9ee0: 20 20 20 20 20 73 65 71 2e 5f 66 75 6e 63 20 3d       seq._func =
9ef0: 20 66 75 6e 63 3b 0d 0a 20 20 20 20 20 20 73 65   func;..      se
9f00: 71 2e 45 6e 63 6f 64 69 6e 67 20 3d 20 28 43 6f  q.Encoding = (Co
9f10: 6c 6c 61 74 69 6f 6e 45 6e 63 6f 64 69 6e 67 45  llationEncodingE
9f20: 6e 75 6d 29 65 6e 63 3b 0d 0a 0d 0a 20 20 20 20  num)enc;....    
9f30: 20 20 72 65 74 75 72 6e 20 73 65 71 3b 0d 0a 23    return seq;..#
9f40: 65 6c 73 65 0d 0a 20 20 20 20 20 20 74 68 72 6f  else..      thro
9f50: 77 20 6e 65 77 20 4e 6f 74 49 6d 70 6c 65 6d 65  w new NotImpleme
9f60: 6e 74 65 64 45 78 63 65 70 74 69 6f 6e 28 29 3b  ntedException();
9f70: 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d  ..#endif..    }.
9f80: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
9f90: 6f 76 65 72 72 69 64 65 20 6c 6f 6e 67 20 47 65  override long Ge
9fa0: 74 50 61 72 61 6d 56 61 6c 75 65 42 79 74 65 73  tParamValueBytes
9fb0: 28 49 6e 74 50 74 72 20 70 2c 20 69 6e 74 20 6e  (IntPtr p, int n
9fc0: 44 61 74 61 4f 66 66 73 65 74 2c 20 62 79 74 65  DataOffset, byte
9fd0: 5b 5d 20 62 44 65 73 74 2c 20 69 6e 74 20 6e 53  [] bDest, int nS
9fe0: 74 61 72 74 2c 20 69 6e 74 20 6e 4c 65 6e 67 74  tart, int nLengt
9ff0: 68 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  h)..    {..     
a000: 20 69 6e 74 20 6e 6c 65 6e 20 3d 20 55 6e 73 61   int nlen = Unsa
a010: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
a020: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 79  sqlite3_value_by
a030: 74 65 73 28 70 29 3b 0d 0a 0d 0a 20 20 20 20 20  tes(p);....     
a040: 20 2f 2f 20 49 66 20 6e 6f 20 64 65 73 74 69 6e   // If no destin
a050: 61 74 69 6f 6e 20 62 75 66 66 65 72 2c 20 72 65  ation buffer, re
a060: 74 75 72 6e 20 74 68 65 20 73 69 7a 65 20 6e 65  turn the size ne
a070: 65 64 65 64 2e 0d 0a 20 20 20 20 20 20 69 66 20  eded...      if 
a080: 28 62 44 65 73 74 20 3d 3d 20 6e 75 6c 6c 29 20  (bDest == null) 
a090: 72 65 74 75 72 6e 20 6e 6c 65 6e 3b 0d 0a 0d 0a  return nlen;....
a0a0: 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 70 69 65        int nCopie
a0b0: 64 20 3d 20 6e 4c 65 6e 67 74 68 3b 0d 0a 0d 0a  d = nLength;....
a0c0: 20 20 20 20 20 20 69 66 20 28 6e 43 6f 70 69 65        if (nCopie
a0d0: 64 20 2b 20 6e 53 74 61 72 74 20 3e 20 62 44 65  d + nStart > bDe
a0e0: 73 74 2e 4c 65 6e 67 74 68 29 20 6e 43 6f 70 69  st.Length) nCopi
a0f0: 65 64 20 3d 20 62 44 65 73 74 2e 4c 65 6e 67 74  ed = bDest.Lengt
a100: 68 20 2d 20 6e 53 74 61 72 74 3b 0d 0a 20 20 20  h - nStart;..   
a110: 20 20 20 69 66 20 28 6e 43 6f 70 69 65 64 20 2b     if (nCopied +
a120: 20 6e 44 61 74 61 4f 66 66 73 65 74 20 3e 20 6e   nDataOffset > n
a130: 6c 65 6e 29 20 6e 43 6f 70 69 65 64 20 3d 20 6e  len) nCopied = n
a140: 6c 65 6e 20 2d 20 6e 44 61 74 61 4f 66 66 73 65  len - nDataOffse
a150: 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20 28  t;....      if (
a160: 6e 43 6f 70 69 65 64 20 3e 20 30 29 0d 0a 20 20  nCopied > 0)..  
a170: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 49      {..        I
a180: 6e 74 50 74 72 20 70 74 72 20 3d 20 55 6e 73 61  ntPtr ptr = Unsa
a190: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
a1a0: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 6c  sqlite3_value_bl
a1b0: 6f 62 28 70 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  ob(p);....      
a1c0: 20 20 4d 61 72 73 68 61 6c 2e 43 6f 70 79 28 28    Marshal.Copy((
a1d0: 49 6e 74 50 74 72 29 28 70 74 72 2e 54 6f 49 6e  IntPtr)(ptr.ToIn
a1e0: 74 36 34 28 29 20 2b 20 6e 44 61 74 61 4f 66 66  t64() + nDataOff
a1f0: 73 65 74 29 2c 20 62 44 65 73 74 2c 20 6e 53 74  set), bDest, nSt
a200: 61 72 74 2c 20 6e 43 6f 70 69 65 64 29 3b 0d 0a  art, nCopied);..
a210: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 65        }..      e
a220: 6c 73 65 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20  lse..      {..  
a230: 20 20 20 20 20 20 6e 43 6f 70 69 65 64 20 3d 20        nCopied = 
a240: 30 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20  0;..      }.... 
a250: 20 20 20 20 20 72 65 74 75 72 6e 20 6e 43 6f 70       return nCop
a260: 69 65 64 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ied;..    }.... 
a270: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
a280: 72 69 64 65 20 64 6f 75 62 6c 65 20 47 65 74 50  ride double GetP
a290: 61 72 61 6d 56 61 6c 75 65 44 6f 75 62 6c 65 28  aramValueDouble(
a2a0: 49 6e 74 50 74 72 20 70 74 72 29 0d 0a 20 20 20  IntPtr ptr)..   
a2b0: 20 7b 0d 0a 20 20 20 20 20 20 64 6f 75 62 6c 65   {..      double
a2c0: 20 76 61 6c 75 65 3b 0d 0a 23 69 66 20 21 50 4c   value;..#if !PL
a2d0: 41 54 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52  ATFORM_COMPACTFR
a2e0: 41 4d 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 76  AMEWORK..      v
a2f0: 61 6c 75 65 20 3d 20 55 6e 73 61 66 65 4e 61 74  alue = UnsafeNat
a300: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
a310: 65 33 5f 76 61 6c 75 65 5f 64 6f 75 62 6c 65 28  e3_value_double(
a320: 70 74 72 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20  ptr);..#else..  
a330: 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65      UnsafeNative
a340: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
a350: 76 61 6c 75 65 5f 64 6f 75 62 6c 65 5f 69 6e 74  value_double_int
a360: 65 72 6f 70 28 70 74 72 2c 20 6f 75 74 20 76 61  erop(ptr, out va
a370: 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20  lue);..#endif.. 
a380: 20 20 20 20 20 72 65 74 75 72 6e 20 76 61 6c 75       return valu
a390: 65 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  e;..    }....   
a3a0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
a3b0: 64 65 20 69 6e 74 20 47 65 74 50 61 72 61 6d 56  de int GetParamV
a3c0: 61 6c 75 65 49 6e 74 33 32 28 49 6e 74 50 74 72  alueInt32(IntPtr
a3d0: 20 70 74 72 29 0d 0a 20 20 20 20 7b 0d 0a 20 20   ptr)..    {..  
a3e0: 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66      return Unsaf
a3f0: 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73  eNativeMethods.s
a400: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74  qlite3_value_int
a410: 28 70 74 72 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d  (ptr);..    }...
a420: 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76  .    internal ov
a430: 65 72 72 69 64 65 20 6c 6f 6e 67 20 47 65 74 50  erride long GetP
a440: 61 72 61 6d 56 61 6c 75 65 49 6e 74 36 34 28 49  aramValueInt64(I
a450: 6e 74 50 74 72 20 70 74 72 29 0d 0a 20 20 20 20  ntPtr ptr)..    
a460: 7b 0d 0a 20 20 20 20 20 20 49 6e 74 36 34 20 76  {..      Int64 v
a470: 61 6c 75 65 3b 0d 0a 23 69 66 20 21 50 4c 41 54  alue;..#if !PLAT
a480: 46 4f 52 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d  FORM_COMPACTFRAM
a490: 45 57 4f 52 4b 0d 0a 20 20 20 20 20 20 76 61 6c  EWORK..      val
a4a0: 75 65 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76  ue = UnsafeNativ
a4b0: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
a4c0: 5f 76 61 6c 75 65 5f 69 6e 74 36 34 28 70 74 72  _value_int64(ptr
a4d0: 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20  );..#else..     
a4e0: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
a4f0: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61 6c  hods.sqlite3_val
a500: 75 65 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70  ue_int64_interop
a510: 28 70 74 72 2c 20 6f 75 74 20 76 61 6c 75 65 29  (ptr, out value)
a520: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20 20  ;..#endif..     
a530: 20 72 65 74 75 72 6e 20 76 61 6c 75 65 3b 0d 0a   return value;..
a540: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
a550: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 73  ernal override s
a560: 74 72 69 6e 67 20 47 65 74 50 61 72 61 6d 56 61  tring GetParamVa
a570: 6c 75 65 54 65 78 74 28 49 6e 74 50 74 72 20 70  lueText(IntPtr p
a580: 74 72 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20  tr)..    {..#if 
a590: 21 53 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44  !SQLITE_STANDARD
a5a0: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 3b  ..      int len;
a5b0: 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 55  ..      return U
a5c0: 54 46 38 54 6f 53 74 72 69 6e 67 28 55 6e 73 61  TF8ToString(Unsa
a5d0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
a5e0: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65  sqlite3_value_te
a5f0: 78 74 5f 69 6e 74 65 72 6f 70 28 70 74 72 2c 20  xt_interop(ptr, 
a600: 6f 75 74 20 6c 65 6e 29 2c 20 6c 65 6e 29 3b 0d  out len), len);.
a610: 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 72 65  .#else..      re
a620: 74 75 72 6e 20 55 54 46 38 54 6f 53 74 72 69 6e  turn UTF8ToStrin
a630: 67 28 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  g(UnsafeNativeMe
a640: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 76 61  thods.sqlite3_va
a650: 6c 75 65 5f 74 65 78 74 28 70 74 72 29 2c 20 2d  lue_text(ptr), -
a660: 31 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20  1);..#endif..   
a670: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
a680: 61 6c 20 6f 76 65 72 72 69 64 65 20 54 79 70 65  al override Type
a690: 41 66 66 69 6e 69 74 79 20 47 65 74 50 61 72 61  Affinity GetPara
a6a0: 6d 56 61 6c 75 65 54 79 70 65 28 49 6e 74 50 74  mValueType(IntPt
a6b0: 72 20 70 74 72 29 0d 0a 20 20 20 20 7b 0d 0a 20  r ptr)..    {.. 
a6c0: 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61       return Unsa
a6d0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
a6e0: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 79  sqlite3_value_ty
a6f0: 70 65 28 70 74 72 29 3b 0d 0a 20 20 20 20 7d 0d  pe(ptr);..    }.
a700: 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ...    internal 
a710: 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 52 65  override void Re
a720: 74 75 72 6e 42 6c 6f 62 28 49 6e 74 50 74 72 20  turnBlob(IntPtr 
a730: 63 6f 6e 74 65 78 74 2c 20 62 79 74 65 5b 5d 20  context, byte[] 
a740: 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d 0a 20  value)..    {.. 
a750: 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76       UnsafeNativ
a760: 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33  eMethods.sqlite3
a770: 5f 72 65 73 75 6c 74 5f 62 6c 6f 62 28 63 6f 6e  _result_blob(con
a780: 74 65 78 74 2c 20 76 61 6c 75 65 2c 20 76 61 6c  text, value, val
a790: 75 65 2e 4c 65 6e 67 74 68 2c 20 28 49 6e 74 50  ue.Length, (IntP
a7a0: 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20 7d  tr)(-1));..    }
a7b0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
a7c0: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 52   override void R
a7d0: 65 74 75 72 6e 44 6f 75 62 6c 65 28 49 6e 74 50  eturnDouble(IntP
a7e0: 74 72 20 63 6f 6e 74 65 78 74 2c 20 64 6f 75 62  tr context, doub
a7f0: 6c 65 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b  le value)..    {
a800: 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f  ..#if !PLATFORM_
a810: 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f 52 4b  COMPACTFRAMEWORK
a820: 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  ..      UnsafeNa
a830: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
a840: 74 65 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c  te3_result_doubl
a850: 65 28 63 6f 6e 74 65 78 74 2c 20 76 61 6c 75 65  e(context, value
a860: 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20  );..#else..     
a870: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
a880: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 73  hods.sqlite3_res
a890: 75 6c 74 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72  ult_double_inter
a8a0: 6f 70 28 63 6f 6e 74 65 78 74 2c 20 72 65 66 20  op(context, ref 
a8b0: 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d  value);..#endif.
a8c0: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
a8d0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
a8e0: 76 6f 69 64 20 52 65 74 75 72 6e 45 72 72 6f 72  void ReturnError
a8f0: 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c  (IntPtr context,
a900: 20 73 74 72 69 6e 67 20 76 61 6c 75 65 29 0d 0a   string value)..
a910: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e 73      {..      Uns
a920: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
a930: 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f  .sqlite3_result_
a940: 65 72 72 6f 72 28 63 6f 6e 74 65 78 74 2c 20 54  error(context, T
a950: 6f 55 54 46 38 28 76 61 6c 75 65 29 2c 20 76 61  oUTF8(value), va
a960: 6c 75 65 2e 4c 65 6e 67 74 68 29 3b 0d 0a 20 20  lue.Length);..  
a970: 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72    }....    inter
a980: 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69  nal override voi
a990: 64 20 52 65 74 75 72 6e 49 6e 74 33 32 28 49 6e  d ReturnInt32(In
a9a0: 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20 69 6e  tPtr context, in
a9b0: 74 20 76 61 6c 75 65 29 0d 0a 20 20 20 20 7b 0d  t value)..    {.
a9c0: 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74  .      UnsafeNat
a9d0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
a9e0: 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 28 63 6f  e3_result_int(co
a9f0: 6e 74 65 78 74 2c 20 76 61 6c 75 65 29 3b 0d 0a  ntext, value);..
aa00: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
aa10: 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20 76  ernal override v
aa20: 6f 69 64 20 52 65 74 75 72 6e 49 6e 74 36 34 28  oid ReturnInt64(
aa30: 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20  IntPtr context, 
aa40: 6c 6f 6e 67 20 76 61 6c 75 65 29 0d 0a 20 20 20  long value)..   
aa50: 20 7b 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52   {..#if !PLATFOR
aa60: 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f  M_COMPACTFRAMEWO
aa70: 52 4b 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65  RK..      Unsafe
aa80: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
aa90: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74  lite3_result_int
aaa0: 36 34 28 63 6f 6e 74 65 78 74 2c 20 76 61 6c 75  64(context, valu
aab0: 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  e);..#else..    
aac0: 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65    UnsafeNativeMe
aad0: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 65  thods.sqlite3_re
aae0: 73 75 6c 74 5f 69 6e 74 36 34 5f 69 6e 74 65 72  sult_int64_inter
aaf0: 6f 70 28 63 6f 6e 74 65 78 74 2c 20 72 65 66 20  op(context, ref 
ab00: 76 61 6c 75 65 29 3b 0d 0a 23 65 6e 64 69 66 0d  value);..#endif.
ab10: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
ab20: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
ab30: 76 6f 69 64 20 52 65 74 75 72 6e 4e 75 6c 6c 28  void ReturnNull(
ab40: 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 29 0d  IntPtr context).
ab50: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55 6e  .    {..      Un
ab60: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
ab70: 73 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74  s.sqlite3_result
ab80: 5f 6e 75 6c 6c 28 63 6f 6e 74 65 78 74 29 3b 0d  _null(context);.
ab90: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e  .    }....    in
aba0: 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64 65 20  ternal override 
abb0: 76 6f 69 64 20 52 65 74 75 72 6e 54 65 78 74 28  void ReturnText(
abc0: 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74 2c 20  IntPtr context, 
abd0: 73 74 72 69 6e 67 20 76 61 6c 75 65 29 0d 0a 20  string value).. 
abe0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 62 79 74 65     {..      byte
abf0: 5b 5d 20 62 20 3d 20 54 6f 55 54 46 38 28 76 61  [] b = ToUTF8(va
ac00: 6c 75 65 29 3b 0d 0a 20 20 20 20 20 20 55 6e 73  lue);..      Uns
ac10: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
ac20: 2e 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f  .sqlite3_result_
ac30: 74 65 78 74 28 63 6f 6e 74 65 78 74 2c 20 54 6f  text(context, To
ac40: 55 54 46 38 28 76 61 6c 75 65 29 2c 20 62 2e 4c  UTF8(value), b.L
ac50: 65 6e 67 74 68 20 2d 20 31 2c 20 28 49 6e 74 50  ength - 1, (IntP
ac60: 74 72 29 28 2d 31 29 29 3b 0d 0a 20 20 20 20 7d  tr)(-1));..    }
ac70: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
ac80: 20 6f 76 65 72 72 69 64 65 20 49 6e 74 50 74 72   override IntPtr
ac90: 20 41 67 67 72 65 67 61 74 65 43 6f 6e 74 65 78   AggregateContex
aca0: 74 28 49 6e 74 50 74 72 20 63 6f 6e 74 65 78 74  t(IntPtr context
acb0: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
acc0: 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74  return UnsafeNat
acd0: 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74  iveMethods.sqlit
ace0: 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 6e  e3_aggregate_con
acf0: 74 65 78 74 28 63 6f 6e 74 65 78 74 2c 20 31 29  text(context, 1)
ad00: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
ad10: 2f 2f 2f 20 45 6e 61 62 6c 65 73 20 6f 72 20 64  /// Enables or d
ad20: 69 73 61 62 6c 65 64 20 65 78 74 65 6e 64 65 64  isabled extended
ad30: 20 72 65 73 75 6c 74 20 63 6f 64 65 73 20 72 65   result codes re
ad40: 74 75 72 6e 65 64 20 62 79 20 53 51 4c 69 74 65  turned by SQLite
ad50: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
ad60: 76 65 72 72 69 64 65 20 76 6f 69 64 20 53 65 74  verride void Set
ad70: 45 78 74 65 6e 64 65 64 52 65 73 75 6c 74 43 6f  ExtendedResultCo
ad80: 64 65 73 28 62 6f 6f 6c 20 62 4f 6e 4f 66 66 29  des(bool bOnOff)
ad90: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 55  ..    {..      U
ada0: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
adb0: 64 73 2e 73 71 6c 69 74 65 33 5f 65 78 74 65 6e  ds.sqlite3_exten
adc0: 64 65 64 5f 72 65 73 75 6c 74 5f 63 6f 64 65 73  ded_result_codes
add0: 28 5f 73 71 6c 2c 20 28 62 4f 6e 4f 66 66 20 3f  (_sql, (bOnOff ?
ade0: 20 2d 31 20 3a 20 30 29 29 3b 0d 0a 20 20 20 20   -1 : 0));..    
adf0: 7d 0d 0a 20 20 20 20 2f 2f 2f 20 47 65 74 73 20  }..    /// Gets 
ae00: 74 68 65 20 6c 61 73 74 20 53 51 4c 69 74 65 20  the last SQLite 
ae10: 65 72 72 6f 72 20 63 6f 64 65 0d 0a 20 20 20 20  error code..    
ae20: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
ae30: 65 20 69 6e 74 20 52 65 73 75 6c 74 43 6f 64 65  e int ResultCode
ae40: 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  ()..    {..     
ae50: 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61   return UnsafeNa
ae60: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
ae70: 74 65 33 5f 65 72 72 63 6f 64 65 28 5f 73 71 6c  te3_errcode(_sql
ae80: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20 2f  );..    }..    /
ae90: 2f 2f 20 47 65 74 73 20 74 68 65 20 6c 61 73 74  // Gets the last
aea0: 20 53 51 4c 69 74 65 20 65 78 74 65 6e 64 65 64   SQLite extended
aeb0: 20 65 72 72 6f 72 20 63 6f 64 65 0d 0a 20 20 20   error code..   
aec0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
aed0: 64 65 20 69 6e 74 20 45 78 74 65 6e 64 65 64 52  de int ExtendedR
aee0: 65 73 75 6c 74 43 6f 64 65 28 29 0d 0a 20 20 20  esultCode()..   
aef0: 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e   {..      return
af00: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
af10: 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 65 78 74  hods.sqlite3_ext
af20: 65 6e 64 65 64 5f 65 72 72 63 6f 64 65 28 5f 73  ended_errcode(_s
af30: 71 6c 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ql);..    }.... 
af40: 20 20 20 2f 2f 2f 20 41 64 64 20 61 20 6c 6f 67     /// Add a log
af50: 20 6d 65 73 73 61 67 65 20 76 69 61 20 74 68 65   message via the
af60: 20 53 51 4c 69 74 65 20 73 71 6c 69 74 65 33 5f   SQLite sqlite3_
af70: 6c 6f 67 20 69 6e 74 65 72 66 61 63 65 2e 0d 0a  log interface...
af80: 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65      internal ove
af90: 72 72 69 64 65 20 76 6f 69 64 20 4c 6f 67 4d 65  rride void LogMe
afa0: 73 73 61 67 65 28 69 6e 74 20 69 45 72 72 43 6f  ssage(int iErrCo
afb0: 64 65 2c 20 73 74 72 69 6e 67 20 7a 4d 65 73 73  de, string zMess
afc0: 61 67 65 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  age)..    {..   
afd0: 20 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d     UnsafeNativeM
afe0: 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6c  ethods.sqlite3_l
aff0: 6f 67 28 69 45 72 72 43 6f 64 65 2c 20 54 6f 55  og(iErrCode, ToU
b000: 54 46 38 28 7a 4d 65 73 73 61 67 65 29 29 3b 0d  TF8(zMessage));.
b010: 0a 20 20 20 20 7d 0d 0a 0d 0a 23 69 66 20 49 4e  .    }....#if IN
b020: 54 45 52 4f 50 5f 43 4f 44 45 43 0d 0a 20 20 20  TEROP_CODEC..   
b030: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
b040: 64 65 20 76 6f 69 64 20 53 65 74 50 61 73 73 77  de void SetPassw
b050: 6f 72 64 28 62 79 74 65 5b 5d 20 70 61 73 73 77  ord(byte[] passw
b060: 6f 72 64 42 79 74 65 73 29 0d 0a 20 20 20 20 7b  ordBytes)..    {
b070: 0d 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20  ..      int n = 
b080: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
b090: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 6b 65 79 28  ods.sqlite3_key(
b0a0: 5f 73 71 6c 2c 20 70 61 73 73 77 6f 72 64 42 79  _sql, passwordBy
b0b0: 74 65 73 2c 20 70 61 73 73 77 6f 72 64 42 79 74  tes, passwordByt
b0c0: 65 73 2e 4c 65 6e 67 74 68 29 3b 0d 0a 20 20 20  es.Length);..   
b0d0: 20 20 20 69 66 20 28 6e 20 3e 20 30 29 20 74 68     if (n > 0) th
b0e0: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
b0f0: 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c 61  ception(n, GetLa
b100: 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20 20  stError());..   
b110: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
b120: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
b130: 20 43 68 61 6e 67 65 50 61 73 73 77 6f 72 64 28   ChangePassword(
b140: 62 79 74 65 5b 5d 20 6e 65 77 50 61 73 73 77 6f  byte[] newPasswo
b150: 72 64 42 79 74 65 73 29 0d 0a 20 20 20 20 7b 0d  rdBytes)..    {.
b160: 0a 20 20 20 20 20 20 69 6e 74 20 6e 20 3d 20 55  .      int n = U
b170: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
b180: 64 73 2e 73 71 6c 69 74 65 33 5f 72 65 6b 65 79  ds.sqlite3_rekey
b190: 28 5f 73 71 6c 2c 20 6e 65 77 50 61 73 73 77 6f  (_sql, newPasswo
b1a0: 72 64 42 79 74 65 73 2c 20 28 6e 65 77 50 61 73  rdBytes, (newPas
b1b0: 73 77 6f 72 64 42 79 74 65 73 20 3d 3d 20 6e 75  swordBytes == nu
b1c0: 6c 6c 29 20 3f 20 30 20 3a 20 6e 65 77 50 61 73  ll) ? 0 : newPas
b1d0: 73 77 6f 72 64 42 79 74 65 73 2e 4c 65 6e 67 74  swordBytes.Lengt
b1e0: 68 29 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 6e  h);..      if (n
b1f0: 20 3e 20 30 29 20 74 68 72 6f 77 20 6e 65 77 20   > 0) throw new 
b200: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
b210: 6e 2c 20 47 65 74 4c 61 73 74 45 72 72 6f 72 28  n, GetLastError(
b220: 29 29 3b 0d 0a 20 20 20 20 7d 0d 0a 23 65 6e 64  ));..    }..#end
b230: 69 66 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e  if....    intern
b240: 61 6c 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64  al override void
b250: 20 53 65 74 55 70 64 61 74 65 48 6f 6f 6b 28 53   SetUpdateHook(S
b260: 51 4c 69 74 65 55 70 64 61 74 65 43 61 6c 6c 62  QLiteUpdateCallb
b270: 61 63 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b  ack func)..    {
b280: 0d 0a 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61  ..      UnsafeNa
b290: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
b2a0: 74 65 33 5f 75 70 64 61 74 65 5f 68 6f 6f 6b 28  te3_update_hook(
b2b0: 5f 73 71 6c 2c 20 66 75 6e 63 2c 20 49 6e 74 50  _sql, func, IntP
b2c0: 74 72 2e 5a 65 72 6f 29 3b 0d 0a 20 20 20 20 7d  tr.Zero);..    }
b2d0: 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c  ....    internal
b2e0: 20 6f 76 65 72 72 69 64 65 20 76 6f 69 64 20 53   override void S
b2f0: 65 74 43 6f 6d 6d 69 74 48 6f 6f 6b 28 53 51 4c  etCommitHook(SQL
b300: 69 74 65 43 6f 6d 6d 69 74 43 61 6c 6c 62 61 63  iteCommitCallbac
b310: 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b 0d 0a  k func)..    {..
b320: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
b330: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
b340: 33 5f 63 6f 6d 6d 69 74 5f 68 6f 6f 6b 28 5f 73  3_commit_hook(_s
b350: 71 6c 2c 20 66 75 6e 63 2c 20 49 6e 74 50 74 72  ql, func, IntPtr
b360: 2e 5a 65 72 6f 29 3b 0d 0a 20 20 20 20 7d 0d 0a  .Zero);..    }..
b370: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
b380: 76 65 72 72 69 64 65 20 76 6f 69 64 20 53 65 74  verride void Set
b390: 54 72 61 63 65 43 61 6c 6c 62 61 63 6b 28 53 51  TraceCallback(SQ
b3a0: 4c 69 74 65 54 72 61 63 65 43 61 6c 6c 62 61 63  LiteTraceCallbac
b3b0: 6b 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b 0d 0a  k func)..    {..
b3c0: 20 20 20 20 20 20 55 6e 73 61 66 65 4e 61 74 69        UnsafeNati
b3d0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
b3e0: 33 5f 74 72 61 63 65 28 5f 73 71 6c 2c 20 66 75  3_trace(_sql, fu
b3f0: 6e 63 2c 20 49 6e 74 50 74 72 2e 5a 65 72 6f 29  nc, IntPtr.Zero)
b400: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
b410: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
b420: 65 20 76 6f 69 64 20 53 65 74 52 6f 6c 6c 62 61  e void SetRollba
b430: 63 6b 48 6f 6f 6b 28 53 51 4c 69 74 65 52 6f 6c  ckHook(SQLiteRol
b440: 6c 62 61 63 6b 43 61 6c 6c 62 61 63 6b 20 66 75  lbackCallback fu
b450: 6e 63 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  nc)..    {..    
b460: 20 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65    UnsafeNativeMe
b470: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 72 6f  thods.sqlite3_ro
b480: 6c 6c 62 61 63 6b 5f 68 6f 6f 6b 28 5f 73 71 6c  llback_hook(_sql
b490: 2c 20 66 75 6e 63 2c 20 49 6e 74 50 74 72 2e 5a  , func, IntPtr.Z
b4a0: 65 72 6f 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a  ero);..    }....
b4b0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
b4c0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 6c 6c 6f 77  >..    /// Allow
b4d0: 73 20 74 68 65 20 73 65 74 74 69 6e 67 20 6f 66  s the setting of
b4e0: 20 61 20 6c 6f 67 67 69 6e 67 20 63 61 6c 6c 62   a logging callb
b4f0: 61 63 6b 20 69 6e 76 6f 6b 65 64 20 62 79 20 53  ack invoked by S
b500: 51 4c 69 74 65 20 77 68 65 6e 20 61 0d 0a 20 20  QLite when a..  
b510: 20 20 2f 2f 2f 20 6c 6f 67 20 65 76 65 6e 74 20    /// log event 
b520: 6f 63 63 75 72 73 2e 20 20 4f 6e 6c 79 20 6f 6e  occurs.  Only on
b530: 65 20 63 61 6c 6c 62 61 63 6b 20 6d 61 79 20 62  e callback may b
b540: 65 20 73 65 74 2e 20 20 49 66 20 4e 55 4c 4c 20  e set.  If NULL 
b550: 69 73 20 70 61 73 73 65 64 2c 0d 0a 20 20 20 20  is passed,..    
b560: 2f 2f 2f 20 74 68 65 20 6c 6f 67 67 69 6e 67 20  /// the logging 
b570: 63 61 6c 6c 62 61 63 6b 20 69 73 20 75 6e 72 65  callback is unre
b580: 67 69 73 74 65 72 65 64 2e 0d 0a 20 20 20 20 2f  gistered...    /
b590: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
b5a0: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
b5b0: 6d 65 3d 22 66 75 6e 63 22 3e 54 68 65 20 63 61  me="func">The ca
b5c0: 6c 6c 62 61 63 6b 20 66 75 6e 63 74 69 6f 6e 20  llback function 
b5d0: 74 6f 20 69 6e 76 6f 6b 65 2e 3c 2f 70 61 72 61  to invoke.</para
b5e0: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74  m>..    /// <ret
b5f0: 75 72 6e 73 3e 52 65 74 75 72 6e 73 20 61 20 72  urns>Returns a r
b600: 65 73 75 6c 74 20 63 6f 64 65 3c 2f 72 65 74 75  esult code</retu
b610: 72 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e  rns>..    intern
b620: 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  al override int 
b630: 53 65 74 4c 6f 67 43 61 6c 6c 62 61 63 6b 28 53  SetLogCallback(S
b640: 51 4c 69 74 65 4c 6f 67 43 61 6c 6c 62 61 63 6b  QLiteLogCallback
b650: 20 66 75 6e 63 29 0d 0a 20 20 20 20 7b 0d 0a 20   func)..    {.. 
b660: 20 20 20 20 20 20 20 69 6e 74 20 72 63 20 3d 20         int rc = 
b670: 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68  UnsafeNativeMeth
b680: 6f 64 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6e 66  ods.sqlite3_conf
b690: 69 67 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ig(..           
b6a0: 20 28 69 6e 74 29 53 51 4c 69 74 65 43 6f 6e 66   (int)SQLiteConf
b6b0: 69 67 4f 70 73 45 6e 75 6d 2e 53 51 4c 49 54 45  igOpsEnum.SQLITE
b6c0: 5f 43 4f 4e 46 49 47 5f 4c 4f 47 2c 20 66 75 6e  _CONFIG_LOG, fun
b6d0: 63 2c 20 28 49 6e 74 50 74 72 29 30 29 3b 0d 0a  c, (IntPtr)0);..
b6e0: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  ..        return
b6f0: 20 72 63 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20   rc;..    }.... 
b700: 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f     /////////////
b710: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b720: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b730: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b740: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b750: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
b760: 2f 2f 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73  //....    /// <s
b770: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
b780: 20 43 72 65 61 74 65 73 20 61 20 6e 65 77 20 53   Creates a new S
b790: 51 4c 69 74 65 20 62 61 63 6b 75 70 20 6f 62 6a  QLite backup obj
b7a0: 65 63 74 20 62 61 73 65 64 20 6f 6e 20 74 68 65  ect based on the
b7b0: 20 70 72 6f 76 69 64 65 64 20 64 65 73 74 69 6e   provided destin
b7c0: 61 74 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20 64  ation..    /// d
b7d0: 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69  atabase connecti
b7e0: 6f 6e 2e 20 20 54 68 65 20 73 6f 75 72 63 65 20  on.  The source 
b7f0: 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74  database connect
b800: 69 6f 6e 20 69 73 20 74 68 65 20 6f 6e 65 0d 0a  ion is the one..
b810: 20 20 20 20 2f 2f 2f 20 61 73 73 6f 63 69 61 74      /// associat
b820: 65 64 20 77 69 74 68 20 74 68 69 73 20 6f 62 6a  ed with this obj
b830: 65 63 74 2e 20 20 54 68 65 20 73 6f 75 72 63 65  ect.  The source
b840: 20 61 6e 64 20 64 65 73 74 69 6e 61 74 69 6f 6e   and destination
b850: 20 64 61 74 61 62 61 73 65 0d 0a 20 20 20 20 2f   database..    /
b860: 2f 2f 20 63 6f 6e 6e 65 63 74 69 6f 6e 73 20 63  // connections c
b870: 61 6e 6e 6f 74 20 62 65 20 74 68 65 20 73 61 6d  annot be the sam
b880: 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  e...    /// </su
b890: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
b8a0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 64 65 73  <param name="des
b8b0: 74 43 6e 6e 22 3e 54 68 65 20 64 65 73 74 69 6e  tCnn">The destin
b8c0: 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 20 63  ation database c
b8d0: 6f 6e 6e 65 63 74 69 6f 6e 2e 3c 2f 70 61 72 61  onnection.</para
b8e0: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  m>..    /// <par
b8f0: 61 6d 20 6e 61 6d 65 3d 22 64 65 73 74 4e 61 6d  am name="destNam
b900: 65 22 3e 54 68 65 20 64 65 73 74 69 6e 61 74 69  e">The destinati
b910: 6f 6e 20 64 61 74 61 62 61 73 65 20 6e 61 6d 65  on database name
b920: 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  .</param>..    /
b930: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
b940: 73 6f 75 72 63 65 4e 61 6d 65 22 3e 54 68 65 20  sourceName">The 
b950: 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20  source database 
b960: 6e 61 6d 65 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20  name.</param>.. 
b970: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
b980: 54 68 65 20 6e 65 77 6c 79 20 63 72 65 61 74 65  The newly create
b990: 64 20 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 2e  d backup object.
b9a0: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
b9b0: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
b9c0: 65 20 53 51 4c 69 74 65 42 61 63 6b 75 70 20 49  e SQLiteBackup I
b9d0: 6e 69 74 69 61 6c 69 7a 65 42 61 63 6b 75 70 28  nitializeBackup(
b9e0: 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65  ..        SQLite
b9f0: 43 6f 6e 6e 65 63 74 69 6f 6e 20 64 65 73 74 43  Connection destC
ba00: 6e 6e 2c 0d 0a 20 20 20 20 20 20 20 20 73 74 72  nn,..        str
ba10: 69 6e 67 20 64 65 73 74 4e 61 6d 65 2c 0d 0a 20  ing destName,.. 
ba20: 20 20 20 20 20 20 20 73 74 72 69 6e 67 20 73 6f         string so
ba30: 75 72 63 65 4e 61 6d 65 0d 0a 20 20 20 20 20 20  urceName..      
ba40: 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20    )..    {..    
ba50: 20 20 20 20 69 66 20 28 64 65 73 74 43 6e 6e 20      if (destCnn 
ba60: 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20  == null)..      
ba70: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
ba80: 41 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65  ArgumentNullExce
ba90: 70 74 69 6f 6e 28 22 64 65 73 74 43 6e 6e 22 29  ption("destCnn")
baa0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20  ;....        if 
bab0: 28 64 65 73 74 4e 61 6d 65 20 3d 3d 20 6e 75 6c  (destName == nul
bac0: 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  l)..            
bad0: 74 68 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65  throw new Argume
bae0: 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28  ntNullException(
baf0: 22 64 65 73 74 4e 61 6d 65 22 29 3b 0d 0a 0d 0a  "destName");....
bb00: 20 20 20 20 20 20 20 20 69 66 20 28 73 6f 75 72          if (sour
bb10: 63 65 4e 61 6d 65 20 3d 3d 20 6e 75 6c 6c 29 0d  ceName == null).
bb20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72  .            thr
bb30: 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 4e  ow new ArgumentN
bb40: 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 73 6f  ullException("so
bb50: 75 72 63 65 4e 61 6d 65 22 29 3b 0d 0a 0d 0a 20  urceName");.... 
bb60: 20 20 20 20 20 20 20 53 51 4c 69 74 65 33 20 64         SQLite3 d
bb70: 65 73 74 53 71 6c 69 74 65 33 20 3d 20 64 65 73  estSqlite3 = des
bb80: 74 43 6e 6e 2e 5f 73 71 6c 20 61 73 20 53 51 4c  tCnn._sql as SQL
bb90: 69 74 65 33 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  ite3;....       
bba0: 20 69 66 20 28 64 65 73 74 53 71 6c 69 74 65 33   if (destSqlite3
bbb0: 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20   == null)..     
bbc0: 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77         throw new
bbd0: 20 41 72 67 75 6d 65 6e 74 45 78 63 65 70 74 69   ArgumentExcepti
bbe0: 6f 6e 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  on(..           
bbf0: 20 20 20 20 20 22 44 65 73 74 69 6e 61 74 69 6f       "Destinatio
bc00: 6e 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61 73  n connection has
bc10: 20 6e 6f 20 77 72 61 70 70 65 72 2e 22 2c 0d 0a   no wrapper.",..
bc20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bc30: 22 64 65 73 74 43 6e 6e 22 29 3b 0d 0a 0d 0a 20  "destCnn");.... 
bc40: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e         SQLiteCon
bc50: 6e 65 63 74 69 6f 6e 48 61 6e 64 6c 65 20 64 65  nectionHandle de
bc60: 73 74 48 61 6e 64 6c 65 20 3d 20 64 65 73 74 53  stHandle = destS
bc70: 71 6c 69 74 65 33 2e 5f 73 71 6c 3b 0d 0a 0d 0a  qlite3._sql;....
bc80: 20 20 20 20 20 20 20 20 69 66 20 28 64 65 73 74          if (dest
bc90: 48 61 6e 64 6c 65 20 3d 3d 20 6e 75 6c 6c 29 0d  Handle == null).
bca0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72  .            thr
bcb0: 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74 45  ow new ArgumentE
bcc0: 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20  xception(..     
bcd0: 20 20 20 20 20 20 20 20 20 20 20 22 44 65 73 74             "Dest
bce0: 69 6e 61 74 69 6f 6e 20 63 6f 6e 6e 65 63 74 69  ination connecti
bcf0: 6f 6e 20 68 61 73 20 61 6e 20 69 6e 76 61 6c 69  on has an invali
bd00: 64 20 68 61 6e 64 6c 65 2e 22 2c 0d 0a 20 20 20  d handle.",..   
bd10: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 64 65               "de
bd20: 73 74 43 6e 6e 22 29 3b 0d 0a 0d 0a 20 20 20 20  stCnn");....    
bd30: 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63      SQLiteConnec
bd40: 74 69 6f 6e 48 61 6e 64 6c 65 20 73 6f 75 72 63  tionHandle sourc
bd50: 65 48 61 6e 64 6c 65 20 3d 20 5f 73 71 6c 3b 0d  eHandle = _sql;.
bd60: 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 73  ...        if (s
bd70: 6f 75 72 63 65 48 61 6e 64 6c 65 20 3d 3d 20 6e  ourceHandle == n
bd80: 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ull)..          
bd90: 20 20 74 68 72 6f 77 20 6e 65 77 20 49 6e 76 61    throw new Inva
bda0: 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45 78 63 65  lidOperationExce
bdb0: 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20 20 20 20  ption(..        
bdc0: 20 20 20 20 20 20 20 20 22 53 6f 75 72 63 65 20          "Source 
bdd0: 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61 73 20 61  connection has a
bde0: 6e 20 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65  n invalid handle
bdf0: 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  .");....        
be00: 62 79 74 65 5b 5d 20 7a 44 65 73 74 4e 61 6d 65  byte[] zDestName
be10: 20 3d 20 54 6f 55 54 46 38 28 64 65 73 74 4e 61   = ToUTF8(destNa
be20: 6d 65 29 3b 0d 0a 20 20 20 20 20 20 20 20 62 79  me);..        by
be30: 74 65 5b 5d 20 7a 53 6f 75 72 63 65 4e 61 6d 65  te[] zSourceName
be40: 20 3d 20 54 6f 55 54 46 38 28 73 6f 75 72 63 65   = ToUTF8(source
be50: 4e 61 6d 65 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  Name);....      
be60: 20 20 49 6e 74 50 74 72 20 62 61 63 6b 75 70 20    IntPtr backup 
be70: 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65  = UnsafeNativeMe
be80: 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f 62 61  thods.sqlite3_ba
be90: 63 6b 75 70 5f 69 6e 69 74 28 0d 0a 20 20 20 20  ckup_init(..    
bea0: 20 20 20 20 20 20 20 20 64 65 73 74 48 61 6e 64          destHand
beb0: 6c 65 2c 20 7a 44 65 73 74 4e 61 6d 65 2c 20 73  le, zDestName, s
bec0: 6f 75 72 63 65 48 61 6e 64 6c 65 2c 20 7a 53 6f  ourceHandle, zSo
bed0: 75 72 63 65 4e 61 6d 65 29 3b 0d 0a 0d 0a 20 20  urceName);....  
bee0: 20 20 20 20 20 20 69 66 20 28 62 61 63 6b 75 70        if (backup
bef0: 20 3d 3d 20 49 6e 74 50 74 72 2e 5a 65 72 6f 29   == IntPtr.Zero)
bf00: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 68  ..            th
bf10: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
bf20: 63 65 70 74 69 6f 6e 28 52 65 73 75 6c 74 43 6f  ception(ResultCo
bf30: 64 65 28 29 2c 20 47 65 74 4c 61 73 74 45 72 72  de(), GetLastErr
bf40: 6f 72 28 29 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  or());....      
bf50: 20 20 72 65 74 75 72 6e 20 6e 65 77 20 53 51 4c    return new SQL
bf60: 69 74 65 42 61 63 6b 75 70 28 0d 0a 20 20 20 20  iteBackup(..    
bf70: 20 20 20 20 20 20 20 20 74 68 69 73 2c 20 6e 65          this, ne
bf80: 77 20 53 51 4c 69 74 65 42 61 63 6b 75 70 48 61  w SQLiteBackupHa
bf90: 6e 64 6c 65 28 62 61 63 6b 75 70 29 2c 20 64 65  ndle(backup), de
bfa0: 73 74 48 61 6e 64 6c 65 2c 20 7a 44 65 73 74 4e  stHandle, zDestN
bfb0: 61 6d 65 2c 0d 0a 20 20 20 20 20 20 20 20 20 20  ame,..          
bfc0: 20 20 73 6f 75 72 63 65 48 61 6e 64 6c 65 2c 20    sourceHandle, 
bfd0: 7a 53 6f 75 72 63 65 4e 61 6d 65 29 3b 0d 0a 20  zSourceName);.. 
bfe0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20     }....    /// 
bff0: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
c000: 2f 2f 20 43 6f 70 69 65 73 20 75 70 20 74 6f 20  // Copies up to 
c010: 4e 20 70 61 67 65 73 20 66 72 6f 6d 20 74 68 65  N pages from the
c020: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65   source database
c030: 20 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61 74   to the destinat
c040: 69 6f 6e 0d 0a 20 20 20 20 2f 2f 2f 20 64 61 74  ion..    /// dat
c050: 61 62 61 73 65 20 61 73 73 6f 63 69 61 74 65 64  abase associated
c060: 20 77 69 74 68 20 74 68 65 20 73 70 65 63 69 66   with the specif
c070: 69 65 64 20 62 61 63 6b 75 70 20 6f 62 6a 65 63  ied backup objec
c080: 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75  t...    /// </su
c090: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
c0a0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 62 61 63  <param name="bac
c0b0: 6b 75 70 22 3e 54 68 65 20 62 61 63 6b 75 70 20  kup">The backup 
c0c0: 6f 62 6a 65 63 74 20 74 6f 20 75 73 65 2e 3c 2f  object to use.</
c0d0: 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  param>..    /// 
c0e0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 6e 50 61  <param name="nPa
c0f0: 67 65 22 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 68  ge">..    /// Th
c100: 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61 67 65  e number of page
c110: 73 20 74 6f 20 63 6f 70 79 2c 20 6e 65 67 61 74  s to copy, negat
c120: 69 76 65 20 74 6f 20 63 6f 70 79 20 61 6c 6c 20  ive to copy all 
c130: 72 65 6d 61 69 6e 69 6e 67 20 70 61 67 65 73 2e  remaining pages.
c140: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 70 61 72 61  ..    /// </para
c150: 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  m>..    /// <par
c160: 61 6d 20 6e 61 6d 65 3d 22 72 65 74 72 79 22 3e  am name="retry">
c170: 0d 0a 20 20 20 20 2f 2f 2f 20 53 65 74 20 74 6f  ..    /// Set to
c180: 20 74 72 75 65 20 69 66 20 74 68 65 20 6f 70 65   true if the ope
c190: 72 61 74 69 6f 6e 20 6e 65 65 64 73 20 74 6f 20  ration needs to 
c1a0: 62 65 20 72 65 74 72 69 65 64 20 64 75 65 20 74  be retried due t
c1b0: 6f 20 64 61 74 61 62 61 73 65 0d 0a 20 20 20 20  o database..    
c1c0: 2f 2f 2f 20 6c 6f 63 6b 69 6e 67 20 69 73 73 75  /// locking issu
c1d0: 65 73 3b 20 6f 74 68 65 72 77 69 73 65 2c 20 73  es; otherwise, s
c1e0: 65 74 20 74 6f 20 66 61 6c 73 65 2e 0d 0a 20 20  et to false...  
c1f0: 20 20 2f 2f 2f 20 3c 2f 70 61 72 61 6d 3e 0d 0a    /// </param>..
c200: 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73      /// <returns
c210: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 54 72 75 65 20  >..    /// True 
c220: 69 66 20 74 68 65 72 65 20 61 72 65 20 6d 6f 72  if there are mor
c230: 65 20 70 61 67 65 73 20 74 6f 20 62 65 20 63 6f  e pages to be co
c240: 70 69 65 64 2c 20 66 61 6c 73 65 20 6f 74 68 65  pied, false othe
c250: 72 77 69 73 65 2e 0d 0a 20 20 20 20 2f 2f 2f 20  rwise...    /// 
c260: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
c270: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
c280: 65 20 62 6f 6f 6c 20 53 74 65 70 42 61 63 6b 75  e bool StepBacku
c290: 70 28 0d 0a 20 20 20 20 20 20 20 20 53 51 4c 69  p(..        SQLi
c2a0: 74 65 42 61 63 6b 75 70 20 62 61 63 6b 75 70 2c  teBackup backup,
c2b0: 0d 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 50  ..        int nP
c2c0: 61 67 65 2c 0d 0a 20 20 20 20 20 20 20 20 6f 75  age,..        ou
c2d0: 74 20 62 6f 6f 6c 20 72 65 74 72 79 0d 0a 20 20  t bool retry..  
c2e0: 20 20 20 20 20 20 29 0d 0a 20 20 20 20 7b 0d 0a        )..    {..
c2f0: 20 20 20 20 20 20 20 20 72 65 74 72 79 20 3d 20          retry = 
c300: 66 61 6c 73 65 3b 0d 0a 0d 0a 20 20 20 20 20 20  false;....      
c310: 20 20 69 66 20 28 62 61 63 6b 75 70 20 3d 3d 20    if (backup == 
c320: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20  null)..         
c330: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 41 72 67     throw new Arg
c340: 75 6d 65 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69  umentNullExcepti
c350: 6f 6e 28 22 62 61 63 6b 75 70 22 29 3b 0d 0a 0d  on("backup");...
c360: 0a 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 42  .        SQLiteB
c370: 61 63 6b 75 70 48 61 6e 64 6c 65 20 68 61 6e 64  ackupHandle hand
c380: 6c 65 20 3d 20 62 61 63 6b 75 70 2e 5f 73 71 6c  le = backup._sql
c390: 69 74 65 5f 62 61 63 6b 75 70 3b 0d 0a 0d 0a 20  ite_backup;.... 
c3a0: 20 20 20 20 20 20 20 69 66 20 28 68 61 6e 64 6c         if (handl
c3b0: 65 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20  e == null)..    
c3c0: 20 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65          throw ne
c3d0: 77 20 49 6e 76 61 6c 69 64 4f 70 65 72 61 74 69  w InvalidOperati
c3e0: 6f 6e 45 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20  onException(..  
c3f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 42                "B
c400: 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 68 61 73  ackup object has
c410: 20 61 6e 20 69 6e 76 61 6c 69 64 20 68 61 6e 64   an invalid hand
c420: 6c 65 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  le.");....      
c430: 20 20 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65    int n = Unsafe
c440: 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71  NativeMethods.sq
c450: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65  lite3_backup_ste
c460: 70 28 68 61 6e 64 6c 65 2c 20 6e 50 61 67 65 29  p(handle, nPage)
c470: 3b 0d 0a 20 20 20 20 20 20 20 20 62 61 63 6b 75  ;..        backu
c480: 70 2e 5f 73 74 65 70 52 65 73 75 6c 74 20 3d 20  p._stepResult = 
c490: 6e 3b 20 2f 2a 20 4e 4f 54 45 3a 20 53 61 76 65  n; /* NOTE: Save
c4a0: 20 66 6f 72 20 75 73 65 20 62 79 20 46 69 6e 69   for use by Fini
c4b0: 73 68 42 61 63 6b 75 70 2e 20 2a 2f 0d 0a 0d 0a  shBackup. */....
c4c0: 20 20 20 20 20 20 20 20 69 66 20 28 6e 20 3d 3d          if (n ==
c4d0: 20 28 69 6e 74 29 53 51 4c 69 74 65 45 72 72 6f   (int)SQLiteErro
c4e0: 72 43 6f 64 65 2e 4f 6b 29 0d 0a 20 20 20 20 20  rCode.Ok)..     
c4f0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
c500: 20 20 72 65 74 75 72 6e 20 74 72 75 65 3b 0d 0a    return true;..
c510: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
c520: 20 20 20 65 6c 73 65 20 69 66 20 28 6e 20 3d 3d     else if (n ==
c530: 20 28 69 6e 74 29 53 51 4c 69 74 65 45 72 72 6f   (int)SQLiteErro
c540: 72 43 6f 64 65 2e 42 75 73 79 29 0d 0a 20 20 20  rCode.Busy)..   
c550: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
c560: 20 20 20 20 72 65 74 72 79 20 3d 20 74 72 75 65      retry = true
c570: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 72  ;..            r
c580: 65 74 75 72 6e 20 74 72 75 65 3b 0d 0a 20 20 20  eturn true;..   
c590: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
c5a0: 65 6c 73 65 20 69 66 20 28 6e 20 3d 3d 20 28 69  else if (n == (i
c5b0: 6e 74 29 53 51 4c 69 74 65 45 72 72 6f 72 43 6f  nt)SQLiteErrorCo
c5c0: 64 65 2e 4c 6f 63 6b 65 64 29 0d 0a 20 20 20 20  de.Locked)..    
c5d0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
c5e0: 20 20 20 72 65 74 72 79 20 3d 20 74 72 75 65 3b     retry = true;
c5f0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65  ..            re
c600: 74 75 72 6e 20 74 72 75 65 3b 0d 0a 20 20 20 20  turn true;..    
c610: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 65      }..        e
c620: 6c 73 65 20 69 66 20 28 6e 20 3d 3d 20 28 69 6e  lse if (n == (in
c630: 74 29 53 51 4c 69 74 65 45 72 72 6f 72 43 6f 64  t)SQLiteErrorCod
c640: 65 2e 44 6f 6e 65 29 0d 0a 20 20 20 20 20 20 20  e.Done)..       
c650: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
c660: 72 65 74 75 72 6e 20 66 61 6c 73 65 3b 0d 0a 20  return false;.. 
c670: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
c680: 20 20 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20    else..        
c690: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 74  {..            t
c6a0: 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45  hrow new SQLiteE
c6b0: 78 63 65 70 74 69 6f 6e 28 6e 2c 20 47 65 74 4c  xception(n, GetL
c6c0: 61 73 74 45 72 72 6f 72 28 29 29 3b 0d 0a 20 20  astError());..  
c6d0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a        }..    }..
c6e0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
c6f0: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 52 65 74  ry>..    /// Ret
c700: 75 72 6e 73 20 74 68 65 20 6e 75 6d 62 65 72 20  urns the number 
c710: 6f 66 20 70 61 67 65 73 20 72 65 6d 61 69 6e 69  of pages remaini
c720: 6e 67 20 74 6f 20 62 65 20 63 6f 70 69 65 64 20  ng to be copied 
c730: 66 72 6f 6d 20 74 68 65 20 73 6f 75 72 63 65 0d  from the source.
c740: 0a 20 20 20 20 2f 2f 2f 20 64 61 74 61 62 61 73  .    /// databas
c750: 65 20 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61  e to the destina
c760: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 20 61 73  tion database as
c770: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68  sociated with th
c780: 65 20 73 70 65 63 69 66 69 65 64 0d 0a 20 20 20  e specified..   
c790: 20 2f 2f 2f 20 62 61 63 6b 75 70 20 6f 62 6a 65   /// backup obje
c7a0: 63 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73  ct...    /// </s
c7b0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
c7c0: 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 62 61   <param name="ba
c7d0: 63 6b 75 70 22 3e 54 68 65 20 62 61 63 6b 75 70  ckup">The backup
c7e0: 20 6f 62 6a 65 63 74 20 74 6f 20 63 68 65 63 6b   object to check
c7f0: 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f  .</param>..    /
c800: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20  // <returns>The 
c810: 6e 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 20  number of pages 
c820: 72 65 6d 61 69 6e 69 6e 67 20 74 6f 20 62 65 20  remaining to be 
c830: 63 6f 70 69 65 64 2e 3c 2f 72 65 74 75 72 6e 73  copied.</returns
c840: 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  >..    internal 
c850: 6f 76 65 72 72 69 64 65 20 69 6e 74 20 52 65 6d  override int Rem
c860: 61 69 6e 69 6e 67 42 61 63 6b 75 70 28 0d 0a 20  ainingBackup(.. 
c870: 20 20 20 20 20 20 20 53 51 4c 69 74 65 42 61 63         SQLiteBac
c880: 6b 75 70 20 62 61 63 6b 75 70 0d 0a 20 20 20 20  kup backup..    
c890: 20 20 20 20 29 0d 0a 20 20 20 20 7b 0d 0a 20 20      )..    {..  
c8a0: 20 20 20 20 20 20 69 66 20 28 62 61 63 6b 75 70        if (backup
c8b0: 20 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20   == null)..     
c8c0: 20 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77         throw new
c8d0: 20 41 72 67 75 6d 65 6e 74 4e 75 6c 6c 45 78 63   ArgumentNullExc
c8e0: 65 70 74 69 6f 6e 28 22 62 61 63 6b 75 70 22 29  eption("backup")
c8f0: 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 53 51 4c  ;....        SQL
c900: 69 74 65 42 61 63 6b 75 70 48 61 6e 64 6c 65 20  iteBackupHandle 
c910: 68 61 6e 64 6c 65 20 3d 20 62 61 63 6b 75 70 2e  handle = backup.
c920: 5f 73 71 6c 69 74 65 5f 62 61 63 6b 75 70 3b 0d  _sqlite_backup;.
c930: 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 68  ...        if (h
c940: 61 6e 64 6c 65 20 3d 3d 20 6e 75 6c 6c 29 0d 0a  andle == null)..
c950: 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72 6f              thro
c960: 77 20 6e 65 77 20 49 6e 76 61 6c 69 64 4f 70 65  w new InvalidOpe
c970: 72 61 74 69 6f 6e 45 78 63 65 70 74 69 6f 6e 28  rationException(
c980: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
c990: 20 20 22 42 61 63 6b 75 70 20 6f 62 6a 65 63 74    "Backup object
c9a0: 20 68 61 73 20 61 6e 20 69 6e 76 61 6c 69 64 20   has an invalid 
c9b0: 68 61 6e 64 6c 65 2e 22 29 3b 0d 0a 0d 0a 20 20  handle.");....  
c9c0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73        return Uns
c9d0: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
c9e0: 2e 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f  .sqlite3_backup_
c9f0: 72 65 6d 61 69 6e 69 6e 67 28 68 61 6e 64 6c 65  remaining(handle
ca00: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
ca10: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
ca20: 20 20 20 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20      /// Returns 
ca30: 74 68 65 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72  the total number
ca40: 20 6f 66 20 70 61 67 65 73 20 69 6e 20 74 68 65   of pages in the
ca50: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65   source database
ca60: 20 61 73 73 6f 63 69 61 74 65 64 0d 0a 20 20 20   associated..   
ca70: 20 2f 2f 2f 20 77 69 74 68 20 74 68 65 20 73 70   /// with the sp
ca80: 65 63 69 66 69 65 64 20 62 61 63 6b 75 70 20 6f  ecified backup o
ca90: 62 6a 65 63 74 2e 0d 0a 20 20 20 20 2f 2f 2f 20  bject...    /// 
caa0: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
cab0: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
cac0: 22 62 61 63 6b 75 70 22 3e 54 68 65 20 62 61 63  "backup">The bac
cad0: 6b 75 70 20 6f 62 6a 65 63 74 20 74 6f 20 63 68  kup object to ch
cae0: 65 63 6b 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  eck.</param>..  
caf0: 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54    /// <returns>T
cb00: 68 65 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20  he total number 
cb10: 6f 66 20 70 61 67 65 73 20 69 6e 20 74 68 65 20  of pages in the 
cb20: 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 2e  source database.
cb30: 3c 2f 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20  </returns>..    
cb40: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
cb50: 65 20 69 6e 74 20 50 61 67 65 43 6f 75 6e 74 42  e int PageCountB
cb60: 61 63 6b 75 70 28 0d 0a 20 20 20 20 20 20 20 20  ackup(..        
cb70: 53 51 4c 69 74 65 42 61 63 6b 75 70 20 62 61 63  SQLiteBackup bac
cb80: 6b 75 70 0d 0a 20 20 20 20 20 20 20 20 29 0d 0a  kup..        )..
cb90: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 69      {..        i
cba0: 66 20 28 62 61 63 6b 75 70 20 3d 3d 20 6e 75 6c  f (backup == nul
cbb0: 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  l)..            
cbc0: 74 68 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65  throw new Argume
cbd0: 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28  ntNullException(
cbe0: 22 62 61 63 6b 75 70 22 29 3b 0d 0a 0d 0a 20 20  "backup");....  
cbf0: 20 20 20 20 20 20 53 51 4c 69 74 65 42 61 63 6b        SQLiteBack
cc00: 75 70 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65 20  upHandle handle 
cc10: 3d 20 62 61 63 6b 75 70 2e 5f 73 71 6c 69 74 65  = backup._sqlite
cc20: 5f 62 61 63 6b 75 70 3b 0d 0a 0d 0a 20 20 20 20  _backup;....    
cc30: 20 20 20 20 69 66 20 28 68 61 6e 64 6c 65 20 3d      if (handle =
cc40: 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20  = null)..       
cc50: 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20 49       throw new I
cc60: 6e 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e 45  nvalidOperationE
cc70: 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20 20  xception(..     
cc80: 20 20 20 20 20 20 20 20 20 20 20 22 42 61 63 6b             "Back
cc90: 75 70 20 6f 62 6a 65 63 74 20 68 61 73 20 61 6e  up object has an
cca0: 20 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65 2e   invalid handle.
ccb0: 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 72  ");....        r
ccc0: 65 74 75 72 6e 20 55 6e 73 61 66 65 4e 61 74 69  eturn UnsafeNati
ccd0: 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65  veMethods.sqlite
cce0: 33 5f 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75  3_backup_pagecou
ccf0: 6e 74 28 68 61 6e 64 6c 65 29 3b 0d 0a 20 20 20  nt(handle);..   
cd00: 20 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73   }....    /// <s
cd10: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f  ummary>..    ///
cd20: 20 44 65 73 74 72 6f 79 73 20 74 68 65 20 62 61   Destroys the ba
cd30: 63 6b 75 70 20 6f 62 6a 65 63 74 2c 20 72 6f 6c  ckup object, rol
cd40: 6c 69 6e 67 20 62 61 63 6b 20 61 6e 79 20 62 61  ling back any ba
cd50: 63 6b 75 70 20 74 68 61 74 20 6d 61 79 20 62 65  ckup that may be
cd60: 20 69 6e 0d 0a 20 20 20 20 2f 2f 2f 20 70 72 6f   in..    /// pro
cd70: 67 65 73 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  gess...    /// <
cd80: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  /summary>..    /
cd90: 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22  // <param name="
cda0: 62 61 63 6b 75 70 22 3e 54 68 65 20 62 61 63 6b  backup">The back
cdb0: 75 70 20 6f 62 6a 65 63 74 20 74 6f 20 64 65 73  up object to des
cdc0: 74 72 6f 79 2e 3c 2f 70 61 72 61 6d 3e 0d 0a 20  troy.</param>.. 
cdd0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
cde0: 72 69 64 65 20 76 6f 69 64 20 46 69 6e 69 73 68  ride void Finish
cdf0: 42 61 63 6b 75 70 28 0d 0a 20 20 20 20 20 20 20  Backup(..       
ce00: 20 53 51 4c 69 74 65 42 61 63 6b 75 70 20 62 61   SQLiteBackup ba
ce10: 63 6b 75 70 0d 0a 20 20 20 20 20 20 20 20 29 0d  ckup..        ).
ce20: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20  .    {..        
ce30: 69 66 20 28 62 61 63 6b 75 70 20 3d 3d 20 6e 75  if (backup == nu
ce40: 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ll)..           
ce50: 20 74 68 72 6f 77 20 6e 65 77 20 41 72 67 75 6d   throw new Argum
ce60: 65 6e 74 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e  entNullException
ce70: 28 22 62 61 63 6b 75 70 22 29 3b 0d 0a 0d 0a 20  ("backup");.... 
ce80: 20 20 20 20 20 20 20 53 51 4c 69 74 65 42 61 63         SQLiteBac
ce90: 6b 75 70 48 61 6e 64 6c 65 20 68 61 6e 64 6c 65  kupHandle handle
cea0: 20 3d 20 62 61 63 6b 75 70 2e 5f 73 71 6c 69 74   = backup._sqlit
ceb0: 65 5f 62 61 63 6b 75 70 3b 0d 0a 0d 0a 20 20 20  e_backup;....   
cec0: 20 20 20 20 20 69 66 20 28 68 61 6e 64 6c 65 20       if (handle 
ced0: 3d 3d 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20  == null)..      
cee0: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
cef0: 49 6e 76 61 6c 69 64 4f 70 65 72 61 74 69 6f 6e  InvalidOperation
cf00: 45 78 63 65 70 74 69 6f 6e 28 0d 0a 20 20 20 20  Exception(..    
cf10: 20 20 20 20 20 20 20 20 20 20 20 20 22 42 61 63              "Bac
cf20: 6b 75 70 20 6f 62 6a 65 63 74 20 68 61 73 20 61  kup object has a
cf30: 6e 20 69 6e 76 61 6c 69 64 20 68 61 6e 64 6c 65  n invalid handle
cf40: 2e 22 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  .");....        
cf50: 69 6e 74 20 6e 20 3d 20 55 6e 73 61 66 65 4e 61  int n = UnsafeNa
cf60: 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c 69  tiveMethods.sqli
cf70: 74 65 33 5f 62 61 63 6b 75 70 5f 66 69 6e 69 73  te3_backup_finis
cf80: 68 28 68 61 6e 64 6c 65 29 3b 0d 0a 20 20 20 20  h(handle);..    
cf90: 20 20 20 20 68 61 6e 64 6c 65 2e 53 65 74 48 61      handle.SetHa
cfa0: 6e 64 6c 65 41 73 49 6e 76 61 6c 69 64 28 29 3b  ndleAsInvalid();
cfb0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  ....        if (
cfc0: 28 6e 20 3e 20 30 29 20 26 26 20 28 6e 20 21 3d  (n > 0) && (n !=
cfd0: 20 62 61 63 6b 75 70 2e 5f 73 74 65 70 52 65 73   backup._stepRes
cfe0: 75 6c 74 29 29 0d 0a 20 20 20 20 20 20 20 20 20  ult))..         
cff0: 20 20 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c     throw new SQL
d000: 69 74 65 45 78 63 65 70 74 69 6f 6e 28 6e 2c 20  iteException(n, 
d010: 47 65 74 4c 61 73 74 45 72 72 6f 72 28 29 29 3b  GetLastError());
d020: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 2f  ..    }....    /
d030: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d040: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d050: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d060: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d070: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
d080: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a  //////////////..
d090: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61  ..    /// <summa
d0a0: 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 44 65 74  ry>..    /// Det
d0b0: 65 72 6d 69 6e 65 73 20 69 66 20 74 68 65 20 53  ermines if the S
d0c0: 51 4c 69 74 65 20 63 6f 72 65 20 6c 69 62 72 61  QLite core libra
d0d0: 72 79 20 68 61 73 20 62 65 65 6e 20 69 6e 69 74  ry has been init
d0e0: 69 61 6c 69 7a 65 64 20 66 6f 72 20 74 68 65 0d  ialized for the.
d0f0: 0a 20 20 20 20 2f 2f 2f 20 63 75 72 72 65 6e 74  .    /// current
d100: 20 70 72 6f 63 65 73 73 2e 0d 0a 20 20 20 20 2f   process...    /
d110: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
d120: 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e 73 3e     /// <returns>
d130: 0d 0a 20 20 20 20 2f 2f 2f 20 41 20 62 6f 6f 6c  ..    /// A bool
d140: 65 61 6e 20 69 6e 64 69 63 61 74 69 6e 67 20 77  ean indicating w
d150: 68 65 74 68 65 72 20 6f 72 20 6e 6f 74 20 74 68  hether or not th
d160: 65 20 53 51 4c 69 74 65 20 63 6f 72 65 20 6c 69  e SQLite core li
d170: 62 72 61 72 79 20 68 61 73 20 62 65 65 6e 0d 0a  brary has been..
d180: 20 20 20 20 2f 2f 2f 20 69 6e 69 74 69 61 6c 69      /// initiali
d190: 7a 65 64 20 66 6f 72 20 74 68 65 20 63 75 72 72  zed for the curr
d1a0: 65 6e 74 20 70 72 6f 63 65 73 73 2e 0d 0a 20 20  ent process...  
d1b0: 20 20 2f 2f 2f 20 3c 2f 72 65 74 75 72 6e 73 3e    /// </returns>
d1c0: 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f  ..    internal o
d1d0: 76 65 72 72 69 64 65 20 62 6f 6f 6c 20 49 73 49  verride bool IsI
d1e0: 6e 69 74 69 61 6c 69 7a 65 64 28 29 0d 0a 20 20  nitialized()..  
d1f0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 72 65 74    {..        ret
d200: 75 72 6e 20 53 74 61 74 69 63 49 73 49 6e 69 74  urn StaticIsInit
d210: 69 61 6c 69 7a 65 64 28 29 3b 0d 0a 20 20 20 20  ialized();..    
d220: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  }....    /// <su
d230: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
d240: 44 65 74 65 72 6d 69 6e 65 73 20 69 66 20 74 68  Determines if th
d250: 65 20 53 51 4c 69 74 65 20 63 6f 72 65 20 6c 69  e SQLite core li
d260: 62 72 61 72 79 20 68 61 73 20 62 65 65 6e 20 69  brary has been i
d270: 6e 69 74 69 61 6c 69 7a 65 64 20 66 6f 72 20 74  nitialized for t
d280: 68 65 0d 0a 20 20 20 20 2f 2f 2f 20 63 75 72 72  he..    /// curr
d290: 65 6e 74 20 70 72 6f 63 65 73 73 2e 0d 0a 20 20  ent process...  
d2a0: 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e    /// </summary>
d2b0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72  ..    /// <retur
d2c0: 6e 73 3e 0d 0a 20 20 20 20 2f 2f 2f 20 41 20 62  ns>..    /// A b
d2d0: 6f 6f 6c 65 61 6e 20 69 6e 64 69 63 61 74 69 6e  oolean indicatin
d2e0: 67 20 77 68 65 74 68 65 72 20 6f 72 20 6e 6f 74  g whether or not
d2f0: 20 74 68 65 20 53 51 4c 69 74 65 20 63 6f 72 65   the SQLite core
d300: 20 6c 69 62 72 61 72 79 20 68 61 73 20 62 65 65   library has bee
d310: 6e 0d 0a 20 20 20 20 2f 2f 2f 20 69 6e 69 74 69  n..    /// initi
d320: 61 6c 69 7a 65 64 20 66 6f 72 20 74 68 65 20 63  alized for the c
d330: 75 72 72 65 6e 74 20 70 72 6f 63 65 73 73 2e 0d  urrent process..
d340: 0a 20 20 20 20 2f 2f 2f 20 3c 2f 72 65 74 75 72  .    /// </retur
d350: 6e 73 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61  ns>..    interna
d360: 6c 20 73 74 61 74 69 63 20 62 6f 6f 6c 20 53 74  l static bool St
d370: 61 74 69 63 49 73 49 6e 69 74 69 61 6c 69 7a 65  aticIsInitialize
d380: 64 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  d()..    {..    
d390: 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 20 20      //..        
d3a0: 2f 2f 20 42 55 47 46 49 58 3a 20 50 72 65 76 65  // BUGFIX: Preve
d3b0: 6e 74 20 72 61 63 65 73 20 77 69 74 68 20 6f 74  nt races with ot
d3c0: 68 65 72 20 74 68 72 65 61 64 73 20 66 6f 72 20  her threads for 
d3d0: 74 68 69 73 20 65 6e 74 69 72 65 20 62 6c 6f 63  this entire bloc
d3e0: 6b 2c 20 64 75 65 0d 0a 20 20 20 20 20 20 20 20  k, due..        
d3f0: 2f 2f 20 20 20 20 20 20 20 20 20 74 6f 20 74 68  //         to th
d400: 65 20 74 72 79 2f 66 69 6e 61 6c 6c 79 20 73 65  e try/finally se
d410: 6d 61 6e 74 69 63 73 2e 20 20 53 65 65 20 74 69  mantics.  See ti
d420: 63 6b 65 74 20 5b 37 32 39 30 35 63 39 61 37 37  cket [72905c9a77
d430: 5d 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 0d 0a  ]...        //..
d440: 20 20 20 20 20 20 20 20 6c 6f 63 6b 20 28 73 79          lock (sy
d450: 6e 63 52 6f 6f 74 29 0d 0a 20 20 20 20 20 20 20  ncRoot)..       
d460: 20 7b 0d 0a 23 69 66 20 21 50 4c 41 54 46 4f 52   {..#if !PLATFOR
d470: 4d 5f 43 4f 4d 50 41 43 54 46 52 41 4d 45 57 4f  M_COMPACTFRAMEWO
d480: 52 4b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  RK..            
d490: 2f 2f 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  //..            
d4a0: 2f 2f 20 4e 4f 54 45 3a 20 53 61 76 65 20 74 68  // NOTE: Save th
d4b0: 65 20 73 74 61 74 65 20 6f 66 20 74 68 65 20 6c  e state of the l
d4c0: 6f 67 67 69 6e 67 20 63 6c 61 73 73 20 61 6e 64  ogging class and
d4d0: 20 74 68 65 6e 20 72 65 73 74 6f 72 65 20 69 74   then restore it
d4e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f  ..            //
d4f0: 20 20 20 20 20 20 20 61 66 74 65 72 20 77 65 20         after we 
d500: 61 72 65 20 64 6f 6e 65 20 74 6f 20 61 76 6f 69  are done to avoi
d510: 64 20 6c 6f 67 67 69 6e 67 20 74 6f 6f 20 6d 61  d logging too ma
d520: 6e 79 20 66 61 6c 73 65 20 65 72 72 6f 72 73 2e  ny false errors.
d530: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f  ..            //
d540: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 62 6f  ..            bo
d550: 6f 6c 20 73 61 76 65 64 45 6e 61 62 6c 65 64 20  ol savedEnabled 
d560: 3d 20 53 51 4c 69 74 65 4c 6f 67 2e 45 6e 61 62  = SQLiteLog.Enab
d570: 6c 65 64 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  led;..          
d580: 20 20 53 51 4c 69 74 65 4c 6f 67 2e 45 6e 61 62    SQLiteLog.Enab
d590: 6c 65 64 20 3d 20 66 61 6c 73 65 3b 0d 0a 0d 0a  led = false;....
d5a0: 20 20 20 20 20 20 20 20 20 20 20 20 74 72 79 0d              try.
d5b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a  .            {..
d5c0: 23 65 6e 64 69 66 0d 0a 20 20 20 20 20 20 20 20  #endif..        
d5d0: 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20          //..    
d5e0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 4e              // N
d5f0: 4f 54 45 3a 20 54 68 69 73 20 6d 65 74 68 6f 64  OTE: This method
d600: 20 5b 61 62 5d 75 73 65 73 20 74 68 65 20 66 61   [ab]uses the fa
d610: 63 74 20 74 68 61 74 20 53 51 4c 69 74 65 20 77  ct that SQLite w
d620: 69 6c 6c 20 61 6c 77 61 79 73 0d 0a 20 20 20 20  ill always..    
d630: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 20              //  
d640: 20 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49       return SQLI
d650: 54 45 5f 45 52 52 4f 52 20 66 6f 72 20 61 6e 79  TE_ERROR for any
d660: 20 75 6e 6b 6e 6f 77 6e 20 63 6f 6e 66 69 67 75   unknown configu
d670: 72 61 74 69 6f 6e 20 6f 70 74 69 6f 6e 0d 0a 20  ration option.. 
d680: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
d690: 2f 20 20 20 20 20 20 20 2a 75 6e 6c 65 73 73 2a  /       *unless*
d6a0: 20 74 68 65 20 53 51 4c 69 74 65 20 6c 69 62 72   the SQLite libr
d6b0: 61 72 79 20 68 61 73 20 61 6c 72 65 61 64 79 20  ary has already 
d6c0: 62 65 65 6e 20 69 6e 69 74 69 61 6c 69 7a 65 64  been initialized
d6d0: 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
d6e0: 20 20 20 2f 2f 20 20 20 20 20 20 20 49 6e 20 74     //       In t
d6f0: 68 61 74 20 63 61 73 65 20 69 74 20 77 69 6c 6c  hat case it will
d700: 20 61 6c 77 61 79 73 20 72 65 74 75 72 6e 20 53   always return S
d710: 51 4c 49 54 45 5f 4d 49 53 55 53 45 2e 0d 0a 20  QLITE_MISUSE... 
d720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
d730: 2f 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  /..             
d740: 20 20 20 69 6e 74 20 72 63 20 3d 20 55 6e 73 61     int rc = Unsa
d750: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
d760: 73 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67 28 0d  sqlite3_config(.
d770: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
d780: 20 20 20 20 20 28 69 6e 74 29 53 51 4c 69 74 65       (int)SQLite
d790: 43 6f 6e 66 69 67 4f 70 73 45 6e 75 6d 2e 53 51  ConfigOpsEnum.SQ
d7a0: 4c 49 54 45 5f 43 4f 4e 46 49 47 5f 4e 4f 4e 45  LITE_CONFIG_NONE
d7b0: 2c 20 6e 75 6c 6c 2c 20 28 49 6e 74 50 74 72 29  , null, (IntPtr)
d7c0: 30 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20  0);....         
d7d0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 28 72         return (r
d7e0: 63 20 3d 3d 20 2f 2a 20 53 51 4c 49 54 45 5f 4d  c == /* SQLITE_M
d7f0: 49 53 55 53 45 20 2a 2f 20 32 31 29 3b 0d 0a 23  ISUSE */ 21);..#
d800: 69 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d  if !PLATFORM_COM
d810: 50 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20  PACTFRAMEWORK.. 
d820: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20             }..  
d830: 20 20 20 20 20 20 20 20 20 20 66 69 6e 61 6c 6c            finall
d840: 79 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  y..            {
d850: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
d860: 20 20 53 51 4c 69 74 65 4c 6f 67 2e 45 6e 61 62    SQLiteLog.Enab
d870: 6c 65 64 20 3d 20 73 61 76 65 64 45 6e 61 62 6c  led = savedEnabl
d880: 65 64 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ed;..           
d890: 20 7d 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20 20   }..#endif..    
d8a0: 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a      }..    }....
d8b0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
d8c0: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 48 65 6c 70 65  >..    /// Helpe
d8d0: 72 20 66 75 6e 63 74 69 6f 6e 20 74 6f 20 72 65  r function to re
d8e0: 74 72 69 65 76 65 20 61 20 63 6f 6c 75 6d 6e 20  trieve a column 
d8f0: 6f 66 20 64 61 74 61 20 66 72 6f 6d 20 61 6e 20  of data from an 
d900: 61 63 74 69 76 65 20 73 74 61 74 65 6d 65 6e 74  active statement
d910: 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ...    /// </sum
d920: 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  mary>..    /// <
d930: 70 61 72 61 6d 20 6e 61 6d 65 3d 22 73 74 6d 74  param name="stmt
d940: 22 3e 54 68 65 20 73 74 61 74 65 6d 65 6e 74 20  ">The statement 
d950: 62 65 69 6e 67 20 73 74 65 70 28 29 27 64 20 74  being step()'d t
d960: 68 72 6f 75 67 68 3c 2f 70 61 72 61 6d 3e 0d 0a  hrough</param>..
d970: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
d980: 61 6d 65 3d 22 69 6e 64 65 78 22 3e 54 68 65 20  ame="index">The 
d990: 63 6f 6c 75 6d 6e 20 69 6e 64 65 78 20 74 6f 20  column index to 
d9a0: 72 65 74 72 69 65 76 65 3c 2f 70 61 72 61 6d 3e  retrieve</param>
d9b0: 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d  ..    /// <param
d9c0: 20 6e 61 6d 65 3d 22 74 79 70 22 3e 54 68 65 20   name="typ">The 
d9d0: 74 79 70 65 20 6f 66 20 64 61 74 61 20 63 6f 6e  type of data con
d9e0: 74 61 69 6e 65 64 20 69 6e 20 74 68 65 20 63 6f  tained in the co
d9f0: 6c 75 6d 6e 2e 20 20 49 66 20 55 6e 69 6e 69 74  lumn.  If Uninit
da00: 69 61 6c 69 7a 65 64 2c 20 74 68 69 73 20 66 75  ialized, this fu
da10: 6e 63 74 69 6f 6e 20 77 69 6c 6c 20 72 65 74 72  nction will retr
da20: 69 65 76 65 20 74 68 65 20 64 61 74 61 74 79 70  ieve the datatyp
da30: 65 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 2e 3c 2f  e information.</
da40: 70 61 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20  param>..    /// 
da50: 3c 72 65 74 75 72 6e 73 3e 52 65 74 75 72 6e 73  <returns>Returns
da60: 20 74 68 65 20 64 61 74 61 20 69 6e 20 74 68 65   the data in the
da70: 20 63 6f 6c 75 6d 6e 3c 2f 72 65 74 75 72 6e 73   column</returns
da80: 3e 0d 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  >..    internal 
da90: 6f 76 65 72 72 69 64 65 20 6f 62 6a 65 63 74 20  override object 
daa0: 47 65 74 56 61 6c 75 65 28 53 51 4c 69 74 65 53  GetValue(SQLiteS
dab0: 74 61 74 65 6d 65 6e 74 20 73 74 6d 74 2c 20 69  tatement stmt, i
dac0: 6e 74 20 69 6e 64 65 78 2c 20 53 51 4c 69 74 65  nt index, SQLite
dad0: 54 79 70 65 20 74 79 70 29 0d 0a 20 20 20 20 7b  Type typ)..    {
dae0: 0d 0a 20 20 20 20 20 20 69 66 20 28 49 73 4e 75  ..      if (IsNu
daf0: 6c 6c 28 73 74 6d 74 2c 20 69 6e 64 65 78 29 29  ll(stmt, index))
db00: 20 72 65 74 75 72 6e 20 44 42 4e 75 6c 6c 2e 56   return DBNull.V
db10: 61 6c 75 65 3b 0d 0a 20 20 20 20 20 20 54 79 70  alue;..      Typ
db20: 65 41 66 66 69 6e 69 74 79 20 61 66 66 20 3d 20  eAffinity aff = 
db30: 74 79 70 2e 41 66 66 69 6e 69 74 79 3b 0d 0a 20  typ.Affinity;.. 
db40: 20 20 20 20 20 54 79 70 65 20 74 20 3d 20 6e 75       Type t = nu
db50: 6c 6c 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  ll;....      if 
db60: 28 74 79 70 2e 54 79 70 65 20 21 3d 20 44 62 54  (typ.Type != DbT
db70: 79 70 65 2e 4f 62 6a 65 63 74 29 0d 0a 20 20 20  ype.Object)..   
db80: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 74 20     {..        t 
db90: 3d 20 53 51 4c 69 74 65 43 6f 6e 76 65 72 74 2e  = SQLiteConvert.
dba0: 53 51 4c 69 74 65 54 79 70 65 54 6f 54 79 70 65  SQLiteTypeToType
dbb0: 28 74 79 70 29 3b 0d 0a 20 20 20 20 20 20 20 20  (typ);..        
dbc0: 61 66 66 20 3d 20 54 79 70 65 54 6f 41 66 66 69  aff = TypeToAffi
dbd0: 6e 69 74 79 28 74 29 3b 0d 0a 20 20 20 20 20 20  nity(t);..      
dbe0: 7d 0d 0a 0d 0a 20 20 20 20 20 20 73 77 69 74 63  }....      switc
dbf0: 68 20 28 61 66 66 29 0d 0a 20 20 20 20 20 20 7b  h (aff)..      {
dc00: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 54  ..        case T
dc10: 79 70 65 41 66 66 69 6e 69 74 79 2e 42 6c 6f 62  ypeAffinity.Blob
dc20: 3a 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20  :..          if 
dc30: 28 74 79 70 2e 54 79 70 65 20 3d 3d 20 44 62 54  (typ.Type == DbT
dc40: 79 70 65 2e 47 75 69 64 20 26 26 20 74 79 70 2e  ype.Guid && typ.
dc50: 41 66 66 69 6e 69 74 79 20 3d 3d 20 54 79 70 65  Affinity == Type
dc60: 41 66 66 69 6e 69 74 79 2e 54 65 78 74 29 0d 0a  Affinity.Text)..
dc70: 20 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75              retu
dc80: 72 6e 20 6e 65 77 20 47 75 69 64 28 47 65 74 54  rn new Guid(GetT
dc90: 65 78 74 28 73 74 6d 74 2c 20 69 6e 64 65 78 29  ext(stmt, index)
dca0: 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  );....          
dcb0: 69 6e 74 20 6e 20 3d 20 28 69 6e 74 29 47 65 74  int n = (int)Get
dcc0: 42 79 74 65 73 28 73 74 6d 74 2c 20 69 6e 64 65  Bytes(stmt, inde
dcd0: 78 2c 20 30 2c 20 6e 75 6c 6c 2c 20 30 2c 20 30  x, 0, null, 0, 0
dce0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 62 79  );..          by
dcf0: 74 65 5b 5d 20 62 20 3d 20 6e 65 77 20 62 79 74  te[] b = new byt
dd00: 65 5b 6e 5d 3b 0d 0a 20 20 20 20 20 20 20 20 20  e[n];..         
dd10: 20 47 65 74 42 79 74 65 73 28 73 74 6d 74 2c 20   GetBytes(stmt, 
dd20: 69 6e 64 65 78 2c 20 30 2c 20 62 2c 20 30 2c 20  index, 0, b, 0, 
dd30: 6e 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20  n);....         
dd40: 20 69 66 20 28 74 79 70 2e 54 79 70 65 20 3d 3d   if (typ.Type ==
dd50: 20 44 62 54 79 70 65 2e 47 75 69 64 20 26 26 20   DbType.Guid && 
dd60: 6e 20 3d 3d 20 31 36 29 0d 0a 20 20 20 20 20 20  n == 16)..      
dd70: 20 20 20 20 20 20 72 65 74 75 72 6e 20 6e 65 77        return new
dd80: 20 47 75 69 64 28 62 29 3b 0d 0a 0d 0a 20 20 20   Guid(b);....   
dd90: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 62 3b         return b;
dda0: 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20 54  ..        case T
ddb0: 79 70 65 41 66 66 69 6e 69 74 79 2e 44 61 74 65  ypeAffinity.Date
ddc0: 54 69 6d 65 3a 0d 0a 20 20 20 20 20 20 20 20 20  Time:..         
ddd0: 20 72 65 74 75 72 6e 20 47 65 74 44 61 74 65 54   return GetDateT
dde0: 69 6d 65 28 73 74 6d 74 2c 20 69 6e 64 65 78 29  ime(stmt, index)
ddf0: 3b 0d 0a 20 20 20 20 20 20 20 20 63 61 73 65 20  ;..        case 
de00: 54 79 70 65 41 66 66 69 6e 69 74 79 2e 44 6f 75  TypeAffinity.Dou
de10: 62 6c 65 3a 0d 0a 20 20 20 20 20 20 20 20 20 20  ble:..          
de20: 69 66 20 28 74 20 3d 3d 20 6e 75 6c 6c 29 20 72  if (t == null) r
de30: 65 74 75 72 6e 20 47 65 74 44 6f 75 62 6c 65 28  eturn GetDouble(
de40: 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b 0d 0a 20  stmt, index);.. 
de50: 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d 0a 20           else.. 
de60: 20 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72             retur
de70: 6e 20 43 6f 6e 76 65 72 74 2e 43 68 61 6e 67 65  n Convert.Change
de80: 54 79 70 65 28 47 65 74 44 6f 75 62 6c 65 28 73  Type(GetDouble(s
de90: 74 6d 74 2c 20 69 6e 64 65 78 29 2c 20 74 2c 20  tmt, index), t, 
dea0: 6e 75 6c 6c 29 3b 0d 0a 20 20 20 20 20 20 20 20  null);..        
deb0: 63 61 73 65 20 54 79 70 65 41 66 66 69 6e 69 74  case TypeAffinit
dec0: 79 2e 49 6e 74 36 34 3a 0d 0a 20 20 20 20 20 20  y.Int64:..      
ded0: 20 20 20 20 69 66 20 28 74 20 3d 3d 20 6e 75 6c      if (t == nul
dee0: 6c 29 20 72 65 74 75 72 6e 20 47 65 74 49 6e 74  l) return GetInt
def0: 36 34 28 73 74 6d 74 2c 20 69 6e 64 65 78 29 3b  64(stmt, index);
df00: 0d 0a 20 20 20 20 20 20 20 20 20 20 65 6c 73 65  ..          else
df10: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 65  ..            re
df20: 74 75 72 6e 20 43 6f 6e 76 65 72 74 2e 43 68 61  turn Convert.Cha
df30: 6e 67 65 54 79 70 65 28 47 65 74 49 6e 74 36 34  ngeType(GetInt64
df40: 28 73 74 6d 74 2c 20 69 6e 64 65 78 29 2c 20 74  (stmt, index), t
df50: 2c 20 6e 75 6c 6c 29 3b 0d 0a 20 20 20 20 20 20  , null);..      
df60: 20 20 64 65 66 61 75 6c 74 3a 0d 0a 20 20 20 20    default:..    
df70: 20 20 20 20 20 20 72 65 74 75 72 6e 20 47 65 74        return Get
df80: 54 65 78 74 28 73 74 6d 74 2c 20 69 6e 64 65 78  Text(stmt, index
df90: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  );..      }..   
dfa0: 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65 72 6e   }....    intern
dfb0: 61 6c 20 6f 76 65 72 72 69 64 65 20 69 6e 74 20  al override int 
dfc0: 47 65 74 43 75 72 73 6f 72 46 6f 72 54 61 62 6c  GetCursorForTabl
dfd0: 65 28 53 51 4c 69 74 65 53 74 61 74 65 6d 65 6e  e(SQLiteStatemen
dfe0: 74 20 73 74 6d 74 2c 20 69 6e 74 20 64 62 2c 20  t stmt, int db, 
dff0: 69 6e 74 20 72 6f 6f 74 50 61 67 65 29 0d 0a 20  int rootPage).. 
e000: 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54     {..#if !SQLIT
e010: 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20  E_STANDARD..    
e020: 20 20 72 65 74 75 72 6e 20 55 6e 73 61 66 65 4e    return UnsafeN
e030: 61 74 69 76 65 4d 65 74 68 6f 64 73 2e 73 71 6c  ativeMethods.sql
e040: 69 74 65 33 5f 74 61 62 6c 65 5f 63 75 72 73 6f  ite3_table_curso
e050: 72 28 73 74 6d 74 2e 5f 73 71 6c 69 74 65 5f 73  r(stmt._sqlite_s
e060: 74 6d 74 2c 20 64 62 2c 20 72 6f 6f 74 50 61 67  tmt, db, rootPag
e070: 65 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20  e);..#else..    
e080: 20 20 72 65 74 75 72 6e 20 2d 31 3b 0d 0a 23 65    return -1;..#e
e090: 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  ndif..    }.... 
e0a0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72     internal over
e0b0: 72 69 64 65 20 6c 6f 6e 67 20 47 65 74 52 6f 77  ride long GetRow
e0c0: 49 64 46 6f 72 43 75 72 73 6f 72 28 53 51 4c 69  IdForCursor(SQLi
e0d0: 74 65 53 74 61 74 65 6d 65 6e 74 20 73 74 6d 74  teStatement stmt
e0e0: 2c 20 69 6e 74 20 63 75 72 73 6f 72 29 0d 0a 20  , int cursor).. 
e0f0: 20 20 20 7b 0d 0a 23 69 66 20 21 53 51 4c 49 54     {..#if !SQLIT
e100: 45 5f 53 54 41 4e 44 41 52 44 0d 0a 20 20 20 20  E_STANDARD..    
e110: 20 20 6c 6f 6e 67 20 72 6f 77 69 64 3b 0d 0a 20    long rowid;.. 
e120: 20 20 20 20 20 69 6e 74 20 72 63 20 3d 20 55 6e       int rc = Un
e130: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
e140: 73 2e 73 71 6c 69 74 65 33 5f 63 75 72 73 6f 72  s.sqlite3_cursor
e150: 5f 72 6f 77 69 64 28 73 74 6d 74 2e 5f 73 71 6c  _rowid(stmt._sql
e160: 69 74 65 5f 73 74 6d 74 2c 20 63 75 72 73 6f 72  ite_stmt, cursor
e170: 2c 20 6f 75 74 20 72 6f 77 69 64 29 3b 0d 0a 20  , out rowid);.. 
e180: 20 20 20 20 20 69 66 20 28 72 63 20 3d 3d 20 30       if (rc == 0
e190: 29 20 72 65 74 75 72 6e 20 72 6f 77 69 64 3b 0d  ) return rowid;.
e1a0: 0a 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  ...      return 
e1b0: 30 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20  0;..#else..     
e1c0: 20 72 65 74 75 72 6e 20 30 3b 0d 0a 23 65 6e 64   return 0;..#end
e1d0: 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  if..    }....   
e1e0: 20 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69   internal overri
e1f0: 64 65 20 76 6f 69 64 20 47 65 74 49 6e 64 65 78  de void GetIndex
e200: 43 6f 6c 75 6d 6e 45 78 74 65 6e 64 65 64 49 6e  ColumnExtendedIn
e210: 66 6f 28 73 74 72 69 6e 67 20 64 61 74 61 62 61  fo(string databa
e220: 73 65 2c 20 73 74 72 69 6e 67 20 69 6e 64 65 78  se, string index
e230: 2c 20 73 74 72 69 6e 67 20 63 6f 6c 75 6d 6e 2c  , string column,
e240: 20 6f 75 74 20 69 6e 74 20 73 6f 72 74 4d 6f 64   out int sortMod
e250: 65 2c 20 6f 75 74 20 69 6e 74 20 6f 6e 45 72 72  e, out int onErr
e260: 6f 72 2c 20 6f 75 74 20 73 74 72 69 6e 67 20 63  or, out string c
e270: 6f 6c 6c 61 74 69 6f 6e 53 65 71 75 65 6e 63 65  ollationSequence
e280: 29 0d 0a 20 20 20 20 7b 0d 0a 23 69 66 20 21 53  )..    {..#if !S
e290: 51 4c 49 54 45 5f 53 54 41 4e 44 41 52 44 0d 0a  QLITE_STANDARD..
e2a0: 20 20 20 20 20 20 49 6e 74 50 74 72 20 63 6f 6c        IntPtr col
e2b0: 6c 3b 0d 0a 20 20 20 20 20 20 69 6e 74 20 63 6f  l;..      int co
e2c0: 6c 6c 6c 65 6e 3b 0d 0a 20 20 20 20 20 20 69 6e  lllen;..      in
e2d0: 74 20 72 63 3b 0d 0a 0d 0a 20 20 20 20 20 20 72  t rc;....      r
e2e0: 63 20 3d 20 55 6e 73 61 66 65 4e 61 74 69 76 65  c = UnsafeNative
e2f0: 4d 65 74 68 6f 64 73 2e 73 71 6c 69 74 65 33 5f  Methods.sqlite3_
e300: 69 6e 64 65 78 5f 63 6f 6c 75 6d 6e 5f 69 6e 66  index_column_inf
e310: 6f 5f 69 6e 74 65 72 6f 70 28 5f 73 71 6c 2c 20  o_interop(_sql, 
e320: 54 6f 55 54 46 38 28 64 61 74 61 62 61 73 65 29  ToUTF8(database)
e330: 2c 20 54 6f 55 54 46 38 28 69 6e 64 65 78 29 2c  , ToUTF8(index),
e340: 20 54 6f 55 54 46 38 28 63 6f 6c 75 6d 6e 29 2c   ToUTF8(column),
e350: 20 6f 75 74 20 73 6f 72 74 4d 6f 64 65 2c 20 6f   out sortMode, o
e360: 75 74 20 6f 6e 45 72 72 6f 72 2c 20 6f 75 74 20  ut onError, out 
e370: 63 6f 6c 6c 2c 20 6f 75 74 20 63 6f 6c 6c 6c 65  coll, out collle
e380: 6e 29 3b 0d 0a 20 20 20 20 20 20 69 66 20 28 72  n);..      if (r
e390: 63 20 21 3d 20 30 29 20 74 68 72 6f 77 20 6e 65  c != 0) throw ne
e3a0: 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  w SQLiteExceptio
e3b0: 6e 28 72 63 2c 20 22 22 29 3b 0d 0a 0d 0a 20 20  n(rc, "");....  
e3c0: 20 20 20 20 63 6f 6c 6c 61 74 69 6f 6e 53 65 71      collationSeq
e3d0: 75 65 6e 63 65 20 3d 20 55 54 46 38 54 6f 53 74  uence = UTF8ToSt
e3e0: 72 69 6e 67 28 63 6f 6c 6c 2c 20 63 6f 6c 6c 6c  ring(coll, colll
e3f0: 65 6e 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20 20  en);..#else..   
e400: 20 20 20 73 6f 72 74 4d 6f 64 65 20 3d 20 30 3b     sortMode = 0;
e410: 0d 0a 20 20 20 20 20 20 6f 6e 45 72 72 6f 72 20  ..      onError 
e420: 3d 20 32 3b 0d 0a 20 20 20 20 20 20 63 6f 6c 6c  = 2;..      coll
e430: 61 74 69 6f 6e 53 65 71 75 65 6e 63 65 20 3d 20  ationSequence = 
e440: 22 42 49 4e 41 52 59 22 3b 0d 0a 23 65 6e 64 69  "BINARY";..#endi
e450: 66 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  f..    }....    
e460: 69 6e 74 65 72 6e 61 6c 20 6f 76 65 72 72 69 64  internal overrid
e470: 65 20 69 6e 74 20 46 69 6c 65 43 6f 6e 74 72 6f  e int FileContro
e480: 6c 28 73 74 72 69 6e 67 20 7a 44 62 4e 61 6d 65  l(string zDbName
e490: 2c 20 69 6e 74 20 6f 70 2c 20 49 6e 74 50 74 72  , int op, IntPtr
e4a0: 20 70 41 72 67 29 0d 0a 20 20 20 20 7b 0d 0a 20   pArg)..    {.. 
e4b0: 20 20 20 20 20 72 65 74 75 72 6e 20 55 6e 73 61       return Unsa
e4c0: 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73 2e  feNativeMethods.
e4d0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 5f 63 6f 6e  sqlite3_file_con
e4e0: 74 72 6f 6c 28 5f 73 71 6c 2c 20 28 7a 44 62 4e  trol(_sql, (zDbN
e4f0: 61 6d 65 20 21 3d 20 6e 75 6c 6c 29 20 3f 20 54  ame != null) ? T
e500: 6f 55 54 46 38 28 7a 44 62 4e 61 6d 65 29 20 3a  oUTF8(zDbName) :
e510: 20 6e 75 6c 6c 2c 20 6f 70 2c 20 70 41 72 67 29   null, op, pArg)
e520: 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 7d  ;..    }..  }..}
e530: 0d 0a                                            ..