System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact c3683cc1d65c53be8ce22277a9f17e8899ec646c:


0000: 2f 2a 2a 2a 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 0d 0a 20 2a 20 41 44  *********.. * AD
0040: 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74 61 20 50  O.NET 2.0 Data P
0050: 72 6f 76 69 64 65 72 20 66 6f 72 20 53 51 4c 69  rovider for SQLi
0060: 74 65 20 56 65 72 73 69 6f 6e 20 33 2e 58 0d 0a  te Version 3.X..
0070: 20 2a 20 57 72 69 74 74 65 6e 20 62 79 20 52 6f   * Written by Ro
0080: 62 65 72 74 20 53 69 6d 70 73 6f 6e 20 28 72 6f  bert Simpson (ro
0090: 62 65 72 74 40 62 6c 61 63 6b 63 61 73 74 6c 65  bert@blackcastle
00a0: 73 6f 66 74 2e 63 6f 6d 29 0d 0a 20 2a 20 0d 0a  soft.com).. * ..
00b0: 20 2a 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74   * Released to t
00c0: 68 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e  he public domain
00d0: 2c 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77  , use at your ow
00e0: 6e 20 72 69 73 6b 21 0d 0a 20 2a 2a 2a 2a 2a 2a  n 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 2f 0d 0a 0d 0a 6e 61 6d 65 73 70 61 63 65  **/....namespace
0130: 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c   System.Data.SQL
0140: 69 74 65 0d 0a 7b 0d 0a 20 20 75 73 69 6e 67 20  ite..{..  using 
0150: 53 79 73 74 65 6d 3b 0d 0a 20 20 75 73 69 6e 67  System;..  using
0160: 20 53 79 73 74 65 6d 2e 47 6c 6f 62 61 6c 69 7a   System.Globaliz
0170: 61 74 69 6f 6e 3b 0d 0a 20 20 75 73 69 6e 67 20  ation;..  using 
0180: 53 79 73 74 65 6d 2e 52 65 66 6c 65 63 74 69 6f  System.Reflectio
0190: 6e 3b 0d 0a 20 20 75 73 69 6e 67 20 53 79 73 74  n;..  using Syst
01a0: 65 6d 2e 53 65 63 75 72 69 74 79 2e 50 65 72 6d  em.Security.Perm
01b0: 69 73 73 69 6f 6e 73 3b 0d 0a 0d 0a 20 20 2f 2f  issions;....  //
01c0: 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f  / <summary>..  /
01d0: 2f 2f 20 53 51 4c 69 74 65 20 69 6d 70 6c 65 6d  // SQLite implem
01e0: 65 6e 74 61 74 69 6f 6e 20 6f 66 20 3c 73 65 65  entation of <see
01f0: 20 63 72 65 66 3d 22 49 53 65 72 76 69 63 65 50   cref="IServiceP
0200: 72 6f 76 69 64 65 72 22 20 2f 3e 2e 0d 0a 20 20  rovider" />...  
0210: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
0220: 20 20 70 75 62 6c 69 63 20 73 65 61 6c 65 64 20    public sealed 
0230: 70 61 72 74 69 61 6c 20 63 6c 61 73 73 20 53 51  partial class SQ
0240: 4c 69 74 65 46 61 63 74 6f 72 79 20 3a 20 49 53  LiteFactory : IS
0250: 65 72 76 69 63 65 50 72 6f 76 69 64 65 72 0d 0a  erviceProvider..
0260: 20 20 7b 0d 0a 20 20 20 20 70 72 69 76 61 74 65    {..    private
0270: 20 73 74 61 74 69 63 20 54 79 70 65 20 5f 64 62   static Type _db
0280: 50 72 6f 76 69 64 65 72 53 65 72 76 69 63 65 73  ProviderServices
0290: 54 79 70 65 3b 0d 0a 20 20 20 20 70 72 69 76 61  Type;..    priva
02a0: 74 65 20 73 74 61 74 69 63 20 6f 62 6a 65 63 74  te static object
02b0: 20 5f 73 71 6c 69 74 65 53 65 72 76 69 63 65 73   _sqliteServices
02c0: 3b 0d 0a 0d 0a 20 20 20 20 73 74 61 74 69 63 20  ;....    static 
02d0: 53 51 4c 69 74 65 46 61 63 74 6f 72 79 28 29 0d  SQLiteFactory().
02e0: 0a 20 20 20 20 7b 0d 0a 23 69 66 20 28 53 51 4c  .    {..#if (SQL
02f0: 49 54 45 5f 53 54 41 4e 44 41 52 44 20 7c 7c 20  ITE_STANDARD || 
0300: 55 53 45 5f 49 4e 54 45 52 4f 50 5f 44 4c 4c 20  USE_INTEROP_DLL 
0310: 7c 7c 20 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50  || PLATFORM_COMP
0320: 41 43 54 46 52 41 4d 45 57 4f 52 4b 29 20 26 26  ACTFRAMEWORK) &&
0330: 20 50 52 45 4c 4f 41 44 5f 4e 41 54 49 56 45 5f   PRELOAD_NATIVE_
0340: 4c 49 42 52 41 52 59 0d 0a 20 20 20 20 20 20 20  LIBRARY..       
0350: 20 55 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74   UnsafeNativeMet
0360: 68 6f 64 73 2e 49 6e 69 74 69 61 6c 69 7a 65 28  hods.Initialize(
0370: 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 23 69  );..#endif....#i
0380: 66 20 21 50 4c 41 54 46 4f 52 4d 5f 43 4f 4d 50  f !PLATFORM_COMP
0390: 41 43 54 46 52 41 4d 45 57 4f 52 4b 0d 0a 20 20  ACTFRAMEWORK..  
03a0: 20 20 20 20 20 20 53 51 4c 69 74 65 4c 6f 67 2e        SQLiteLog.
03b0: 49 6e 69 74 69 61 6c 69 7a 65 28 29 3b 0d 0a 23  Initialize();..#
03c0: 65 6c 69 66 20 49 4e 54 45 52 4f 50 5f 4c 4f 47  elif INTEROP_LOG
03d0: 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28 55 6e  ..        if (Un
03e0: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
03f0: 73 2e 73 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67  s.sqlite3_config
0400: 5f 6c 6f 67 5f 69 6e 74 65 72 6f 70 28 29 20 3d  _log_interop() =
0410: 3d 20 53 51 4c 69 74 65 45 72 72 6f 72 43 6f 64  = SQLiteErrorCod
0420: 65 2e 4f 6b 29 0d 0a 20 20 20 20 20 20 20 20 7b  e.Ok)..        {
0430: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 55 6e  ..            Un
0440: 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64  safeNativeMethod
0450: 73 2e 73 71 6c 69 74 65 33 5f 6c 6f 67 28 0d 0a  s.sqlite3_log(..
0460: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0470: 53 51 4c 69 74 65 45 72 72 6f 72 43 6f 64 65 2e  SQLiteErrorCode.
0480: 4f 6b 2c 20 53 51 4c 69 74 65 43 6f 6e 76 65 72  Ok, SQLiteConver
0490: 74 2e 54 6f 55 54 46 38 28 22 6c 6f 67 67 69 6e  t.ToUTF8("loggin
04a0: 67 20 69 6e 69 74 69 61 6c 69 7a 65 64 2e 22 29  g initialized.")
04b0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 23  );..        }..#
04c0: 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20 20  endif....       
04d0: 20 73 74 72 69 6e 67 20 76 65 72 73 69 6f 6e 20   string version 
04e0: 3d 0d 0a 23 69 66 20 4e 45 54 5f 34 30 20 7c 7c  =..#if NET_40 ||
04f0: 20 4e 45 54 5f 34 35 0d 0a 20 20 20 20 20 20 20   NET_45..       
0500: 20 20 20 20 20 22 34 2e 30 2e 30 2e 30 22 3b 0d       "4.0.0.0";.
0510: 0a 23 65 6c 73 65 0d 0a 20 20 20 20 20 20 20 20  .#else..        
0520: 20 20 20 20 22 33 2e 35 2e 30 2e 30 22 3b 0d 0a      "3.5.0.0";..
0530: 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 20 20 20 20  #endif....      
0540: 20 20 5f 64 62 50 72 6f 76 69 64 65 72 53 65 72    _dbProviderSer
0550: 76 69 63 65 73 54 79 70 65 20 3d 20 54 79 70 65  vicesType = Type
0560: 2e 47 65 74 54 79 70 65 28 53 74 72 69 6e 67 2e  .GetType(String.
0570: 46 6f 72 6d 61 74 28 43 75 6c 74 75 72 65 49 6e  Format(CultureIn
0580: 66 6f 2e 49 6e 76 61 72 69 61 6e 74 43 75 6c 74  fo.InvariantCult
0590: 75 72 65 2c 20 22 53 79 73 74 65 6d 2e 44 61 74  ure, "System.Dat
05a0: 61 2e 43 6f 6d 6d 6f 6e 2e 44 62 50 72 6f 76 69  a.Common.DbProvi
05b0: 64 65 72 53 65 72 76 69 63 65 73 2c 20 53 79 73  derServices, Sys
05c0: 74 65 6d 2e 44 61 74 61 2e 45 6e 74 69 74 79 2c  tem.Data.Entity,
05d0: 20 56 65 72 73 69 6f 6e 3d 7b 30 7d 2c 20 43 75   Version={0}, Cu
05e0: 6c 74 75 72 65 3d 6e 65 75 74 72 61 6c 2c 20 50  lture=neutral, P
05f0: 75 62 6c 69 63 4b 65 79 54 6f 6b 65 6e 3d 62 37  ublicKeyToken=b7
0600: 37 61 35 63 35 36 31 39 33 34 65 30 38 39 22 2c  7a5c561934e089",
0610: 20 76 65 72 73 69 6f 6e 29 2c 20 66 61 6c 73 65   version), false
0620: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
0630: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
0640: 20 20 20 20 2f 2f 2f 20 57 69 6c 6c 20 70 72 6f      /// Will pro
0650: 76 69 64 65 20 61 20 3c 73 65 65 20 63 72 65 66  vide a <see cref
0660: 3d 22 49 53 65 72 76 69 63 65 50 72 6f 76 69 64  ="IServiceProvid
0670: 65 72 22 20 2f 3e 20 6f 62 6a 65 63 74 20 69 6e  er" /> object in
0680: 20 2e 4e 45 54 20 33 2e 35 2e 0d 0a 20 20 20 20   .NET 3.5...    
0690: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
06a0: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
06b0: 61 6d 65 3d 22 73 65 72 76 69 63 65 54 79 70 65  ame="serviceType
06c0: 22 3e 54 68 65 20 63 6c 61 73 73 20 6f 72 20 69  ">The class or i
06d0: 6e 74 65 72 66 61 63 65 20 74 79 70 65 20 74 6f  nterface type to
06e0: 20 71 75 65 72 79 20 66 6f 72 2e 3c 2f 70 61 72   query for.</par
06f0: 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 72 65  am>..    /// <re
0700: 74 75 72 6e 73 3e 3c 2f 72 65 74 75 72 6e 73 3e  turns></returns>
0710: 0d 0a 20 20 20 20 6f 62 6a 65 63 74 20 49 53 65  ..    object ISe
0720: 72 76 69 63 65 50 72 6f 76 69 64 65 72 2e 47 65  rviceProvider.Ge
0730: 74 53 65 72 76 69 63 65 28 54 79 70 65 20 73 65  tService(Type se
0740: 72 76 69 63 65 54 79 70 65 29 0d 0a 20 20 20 20  rviceType)..    
0750: 7b 0d 0a 20 20 20 20 20 20 69 66 20 28 73 65 72  {..      if (ser
0760: 76 69 63 65 54 79 70 65 20 3d 3d 20 74 79 70 65  viceType == type
0770: 6f 66 28 49 53 51 4c 69 74 65 53 63 68 65 6d 61  of(ISQLiteSchema
0780: 45 78 74 65 6e 73 69 6f 6e 73 29 20 7c 7c 0d 0a  Extensions) ||..
0790: 20 20 20 20 20 20 20 20 28 5f 64 62 50 72 6f 76          (_dbProv
07a0: 69 64 65 72 53 65 72 76 69 63 65 73 54 79 70 65  iderServicesType
07b0: 20 21 3d 20 6e 75 6c 6c 20 26 26 20 73 65 72 76   != null && serv
07c0: 69 63 65 54 79 70 65 20 3d 3d 20 5f 64 62 50 72  iceType == _dbPr
07d0: 6f 76 69 64 65 72 53 65 72 76 69 63 65 73 54 79  oviderServicesTy
07e0: 70 65 29 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20  pe))..      {.. 
07f0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 47 65         return Ge
0800: 74 53 51 4c 69 74 65 50 72 6f 76 69 64 65 72 53  tSQLiteProviderS
0810: 65 72 76 69 63 65 73 49 6e 73 74 61 6e 63 65 28  ervicesInstance(
0820: 29 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20  );..      }..   
0830: 20 20 20 72 65 74 75 72 6e 20 6e 75 6c 6c 3b 0d     return null;.
0840: 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 5b 52  .    }....    [R
0850: 65 66 6c 65 63 74 69 6f 6e 50 65 72 6d 69 73 73  eflectionPermiss
0860: 69 6f 6e 28 53 65 63 75 72 69 74 79 41 63 74 69  ion(SecurityActi
0870: 6f 6e 2e 41 73 73 65 72 74 2c 20 4d 65 6d 62 65  on.Assert, Membe
0880: 72 41 63 63 65 73 73 20 3d 20 74 72 75 65 29 5d  rAccess = true)]
0890: 0d 0a 20 20 20 20 70 72 69 76 61 74 65 20 6f 62  ..    private ob
08a0: 6a 65 63 74 20 47 65 74 53 51 4c 69 74 65 50 72  ject GetSQLitePr
08b0: 6f 76 69 64 65 72 53 65 72 76 69 63 65 73 49 6e  oviderServicesIn
08c0: 73 74 61 6e 63 65 28 29 0d 0a 20 20 20 20 7b 0d  stance()..    {.
08d0: 0a 20 20 20 20 20 20 20 20 69 66 20 28 5f 73 71  .        if (_sq
08e0: 6c 69 74 65 53 65 72 76 69 63 65 73 20 3d 3d 20  liteServices == 
08f0: 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 7b  null)..        {
0900: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 56 65  ..            Ve
0910: 72 73 69 6f 6e 20 76 65 72 73 69 6f 6e 20 3d 20  rsion version = 
0920: 74 68 69 73 2e 47 65 74 54 79 70 65 28 29 2e 41  this.GetType().A
0930: 73 73 65 6d 62 6c 79 2e 47 65 74 4e 61 6d 65 28  ssembly.GetName(
0940: 29 2e 56 65 72 73 69 6f 6e 3b 0d 0a 20 20 20 20  ).Version;..    
0950: 20 20 20 20 20 20 20 20 54 79 70 65 20 74 79 70          Type typ
0960: 65 20 3d 20 54 79 70 65 2e 47 65 74 54 79 70 65  e = Type.GetType
0970: 28 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 43  (String.Format(C
0980: 75 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72  ultureInfo.Invar
0990: 69 61 6e 74 43 75 6c 74 75 72 65 2c 20 22 53 79  iantCulture, "Sy
09a0: 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65  stem.Data.SQLite
09b0: 2e 53 51 4c 69 74 65 50 72 6f 76 69 64 65 72 53  .SQLiteProviderS
09c0: 65 72 76 69 63 65 73 2c 20 53 79 73 74 65 6d 2e  ervices, System.
09d0: 44 61 74 61 2e 53 51 4c 69 74 65 2e 4c 69 6e 71  Data.SQLite.Linq
09e0: 2c 20 56 65 72 73 69 6f 6e 3d 7b 30 7d 2c 20 43  , Version={0}, C
09f0: 75 6c 74 75 72 65 3d 6e 65 75 74 72 61 6c 2c 20  ulture=neutral, 
0a00: 50 75 62 6c 69 63 4b 65 79 54 6f 6b 65 6e 3d 64  PublicKeyToken=d
0a10: 62 39 33 37 62 63 32 64 34 34 66 66 31 33 39 22  b937bc2d44ff139"
0a20: 2c 20 76 65 72 73 69 6f 6e 29 2c 20 66 61 6c 73  , version), fals
0a30: 65 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20  e);....         
0a40: 20 20 20 69 66 20 28 74 79 70 65 20 21 3d 20 6e     if (type != n
0a50: 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20  ull)..          
0a60: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
0a70: 20 20 20 20 20 46 69 65 6c 64 49 6e 66 6f 20 66       FieldInfo f
0a80: 69 65 6c 64 20 3d 20 74 79 70 65 2e 47 65 74 46  ield = type.GetF
0a90: 69 65 6c 64 28 22 49 6e 73 74 61 6e 63 65 22 2c  ield("Instance",
0aa0: 20 42 69 6e 64 69 6e 67 46 6c 61 67 73 2e 4e 6f   BindingFlags.No
0ab0: 6e 50 75 62 6c 69 63 20 7c 20 42 69 6e 64 69 6e  nPublic | Bindin
0ac0: 67 46 6c 61 67 73 2e 53 74 61 74 69 63 20 7c 20  gFlags.Static | 
0ad0: 42 69 6e 64 69 6e 67 46 6c 61 67 73 2e 49 6e 73  BindingFlags.Ins
0ae0: 74 61 6e 63 65 29 3b 0d 0a 20 20 20 20 20 20 20  tance);..       
0af0: 20 20 20 20 20 20 20 20 20 5f 73 71 6c 69 74 65           _sqlite
0b00: 53 65 72 76 69 63 65 73 20 3d 20 66 69 65 6c 64  Services = field
0b10: 2e 47 65 74 56 61 6c 75 65 28 6e 75 6c 6c 29 3b  .GetValue(null);
0b20: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d  ..            }.
0b30: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
0b40: 20 20 20 20 72 65 74 75 72 6e 20 5f 73 71 6c 69      return _sqli
0b50: 74 65 53 65 72 76 69 63 65 73 3b 0d 0a 20 20 20  teServices;..   
0b60: 20 7d 0d 0a 20 20 7d 0d 0a 7d 0d 0a               }..  }..}..