System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 02255e2543b62648d9f73ed000b1e6a36fb2a2b9:


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 0d 0a 20  soft.com).. *.. 
00b0: 2a 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74 68  * Released to th
00c0: 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c  e public domain,
00d0: 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77 6e   use at your own
00e0: 20 72 69 73 6b 21 0d 0a 20 2a 2a 2a 2a 2a 2a 2a   risk!.. *******
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 2f 0d 0a 0d 0a 6e 61 6d 65 73 70 61 63 65 20  */....namespace 
0130: 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69  System.Data.SQLi
0140: 74 65 0d 0a 7b 0d 0a 20 20 20 20 75 73 69 6e 67  te..{..    using
0150: 20 53 79 73 74 65 6d 3b 0d 0a 20 20 20 20 75 73   System;..    us
0160: 69 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 61 3b  ing System.Data;
0170: 0d 0a 20 20 20 20 75 73 69 6e 67 20 53 79 73 74  ..    using Syst
0180: 65 6d 2e 44 61 74 61 2e 43 6f 6d 6d 6f 6e 3b 0d  em.Data.Common;.
0190: 0a 20 20 20 20 75 73 69 6e 67 20 53 79 73 74 65  .    using Syste
01a0: 6d 2e 54 68 72 65 61 64 69 6e 67 3b 0d 0a 0d 0a  m.Threading;....
01b0: 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f      ////////////
01c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
01d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
01e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
01f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0200: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0210: 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c  ///....    /// <
0220: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f  summary>..    //
0230: 2f 20 53 51 4c 69 74 65 20 69 6d 70 6c 65 6d 65  / SQLite impleme
0240: 6e 74 61 74 69 6f 6e 20 6f 66 20 44 62 54 72 61  ntation of DbTra
0250: 6e 73 61 63 74 69 6f 6e 2e 0d 0a 20 20 20 20 2f  nsaction...    /
0260: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
0270: 20 20 20 70 75 62 6c 69 63 20 73 65 61 6c 65 64     public sealed
0280: 20 63 6c 61 73 73 20 53 51 4c 69 74 65 54 72 61   class SQLiteTra
0290: 6e 73 61 63 74 69 6f 6e 20 3a 20 44 62 54 72 61  nsaction : DbTra
02a0: 6e 73 61 63 74 69 6f 6e 0d 0a 20 20 20 20 7b 0d  nsaction..    {.
02b0: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c 73 75  .        /// <su
02c0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 20 20  mmary>..        
02d0: 2f 2f 2f 20 54 68 65 20 63 6f 6e 6e 65 63 74 69  /// The connecti
02e0: 6f 6e 20 74 6f 20 77 68 69 63 68 20 74 68 69 73  on to which this
02f0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 73 20   transaction is 
0300: 62 6f 75 6e 64 0d 0a 20 20 20 20 20 20 20 20 2f  bound..        /
0310: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
0320: 20 20 20 20 20 20 20 69 6e 74 65 72 6e 61 6c 20         internal 
0330: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
0340: 20 5f 63 6e 6e 3b 0d 0a 0d 0a 20 20 20 20 20 20   _cnn;....      
0350: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
0360: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 4d 61 74  .        /// Mat
0370: 63 68 65 73 20 74 68 65 20 76 65 72 73 69 6f 6e  ches the version
0380: 20 6f 66 20 74 68 65 20 63 6f 6e 6e 65 63 74 69   of the connecti
0390: 6f 6e 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f  on...        ///
03a0: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20   </summary>..   
03b0: 20 20 20 20 20 70 72 69 76 61 74 65 20 69 6e 74       private int
03c0: 20 5f 76 65 72 73 69 6f 6e 3b 0d 0a 0d 0a 20 20   _version;....  
03d0: 20 20 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61        /// <summa
03e0: 72 79 3e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f  ry>..        ///
03f0: 20 54 68 65 20 69 73 6f 6c 61 74 69 6f 6e 20 6c   The isolation l
0400: 65 76 65 6c 20 66 6f 72 20 74 68 69 73 20 74 72  evel for this tr
0410: 61 6e 73 61 63 74 69 6f 6e 2e 0d 0a 20 20 20 20  ansaction...    
0420: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
0430: 79 3e 0d 0a 20 20 20 20 20 20 20 20 70 72 69 76  y>..        priv
0440: 61 74 65 20 49 73 6f 6c 61 74 69 6f 6e 4c 65 76  ate IsolationLev
0450: 65 6c 20 5f 6c 65 76 65 6c 3b 0d 0a 0d 0a 20 20  el _level;....  
0460: 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f        //////////
0470: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0480: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0490: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
04a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
04b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
04c0: 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20 20  /////....       
04d0: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a   /// <summary>..
04e0: 20 20 20 20 20 20 20 20 2f 2f 2f 20 43 6f 6e 73          /// Cons
04f0: 74 72 75 63 74 73 20 74 68 65 20 74 72 61 6e 73  tructs the trans
0500: 61 63 74 69 6f 6e 20 6f 62 6a 65 63 74 2c 20 62  action object, b
0510: 69 6e 64 69 6e 67 20 69 74 20 74 6f 20 74 68 65  inding it to the
0520: 20 73 75 70 70 6c 69 65 64 20 63 6f 6e 6e 65 63   supplied connec
0530: 74 69 6f 6e 0d 0a 20 20 20 20 20 20 20 20 2f 2f  tion..        //
0540: 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  / </summary>..  
0550: 20 20 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d        /// <param
0560: 20 6e 61 6d 65 3d 22 63 6f 6e 6e 65 63 74 69 6f   name="connectio
0570: 6e 22 3e 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f  n">The connectio
0580: 6e 20 74 6f 20 6f 70 65 6e 20 61 20 74 72 61 6e  n to open a tran
0590: 73 61 63 74 69 6f 6e 20 6f 6e 3c 2f 70 61 72 61  saction on</para
05a0: 6d 3e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20  m>..        /// 
05b0: 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 64 65 66  <param name="def
05c0: 65 72 72 65 64 4c 6f 63 6b 22 3e 54 52 55 45 20  erredLock">TRUE 
05d0: 74 6f 20 64 65 66 65 72 20 74 68 65 20 77 72 69  to defer the wri
05e0: 74 65 6c 6f 63 6b 2c 20 6f 72 20 46 41 4c 53 45  telock, or FALSE
05f0: 20 74 6f 20 6c 6f 63 6b 20 69 6d 6d 65 64 69 61   to lock immedia
0600: 74 65 6c 79 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  tely</param>..  
0610: 20 20 20 20 20 20 69 6e 74 65 72 6e 61 6c 20 53        internal S
0620: 51 4c 69 74 65 54 72 61 6e 73 61 63 74 69 6f 6e  QLiteTransaction
0630: 28 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f  (SQLiteConnectio
0640: 6e 20 63 6f 6e 6e 65 63 74 69 6f 6e 2c 20 62 6f  n connection, bo
0650: 6f 6c 20 64 65 66 65 72 72 65 64 4c 6f 63 6b 29  ol deferredLock)
0660: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
0670: 20 20 20 20 20 20 20 20 20 5f 63 6e 6e 20 3d 20           _cnn = 
0680: 63 6f 6e 6e 65 63 74 69 6f 6e 3b 0d 0a 20 20 20  connection;..   
0690: 20 20 20 20 20 20 20 20 20 5f 76 65 72 73 69 6f           _versio
06a0: 6e 20 3d 20 5f 63 6e 6e 2e 5f 76 65 72 73 69 6f  n = _cnn._versio
06b0: 6e 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20  n;....          
06c0: 20 20 5f 6c 65 76 65 6c 20 3d 20 28 64 65 66 65    _level = (defe
06d0: 72 72 65 64 4c 6f 63 6b 20 3d 3d 20 74 72 75 65  rredLock == true
06e0: 29 20 3f 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ) ?..           
06f0: 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65       SQLiteConne
0700: 63 74 69 6f 6e 2e 44 65 66 65 72 72 65 64 49 73  ction.DeferredIs
0710: 6f 6c 61 74 69 6f 6e 4c 65 76 65 6c 20 3a 0d 0a  olationLevel :..
0720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0730: 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e  SQLiteConnection
0740: 2e 49 6d 6d 65 64 69 61 74 65 49 73 6f 6c 61 74  .ImmediateIsolat
0750: 69 6f 6e 4c 65 76 65 6c 3b 0d 0a 0d 0a 20 20 20  ionLevel;....   
0760: 20 20 20 20 20 20 20 20 20 69 66 20 28 5f 63 6e           if (_cn
0770: 6e 2e 5f 74 72 61 6e 73 61 63 74 69 6f 6e 4c 65  n._transactionLe
0780: 76 65 6c 2b 2b 20 3d 3d 20 30 29 0d 0a 20 20 20  vel++ == 0)..   
0790: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
07a0: 20 20 20 20 20 20 20 20 20 20 20 20 74 72 79 0d              try.
07b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
07c0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
07d0: 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28 53          using (S
07e0: 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63 6d 64  QLiteCommand cmd
07f0: 20 3d 20 5f 63 6e 6e 2e 43 72 65 61 74 65 43 6f   = _cnn.CreateCo
0800: 6d 6d 61 6e 64 28 29 29 0d 0a 20 20 20 20 20 20  mmand())..      
0810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d                {.
0820: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0830: 20 20 20 20 20 20 20 20 20 69 66 20 28 21 64 65           if (!de
0840: 66 65 72 72 65 64 4c 6f 63 6b 29 0d 0a 20 20 20  ferredLock)..   
0850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0860: 20 20 20 20 20 20 20 20 20 63 6d 64 2e 43 6f 6d           cmd.Com
0870: 6d 61 6e 64 54 65 78 74 20 3d 20 22 42 45 47 49  mandText = "BEGI
0880: 4e 20 49 4d 4d 45 44 49 41 54 45 3b 22 3b 0d 0a  N IMMEDIATE;";..
0890: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08a0: 20 20 20 20 20 20 20 20 65 6c 73 65 0d 0a 20 20          else..  
08b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08c0: 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 43 6f            cmd.Co
08d0: 6d 6d 61 6e 64 54 65 78 74 20 3d 20 22 42 45 47  mmandText = "BEG
08e0: 49 4e 3b 22 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  IN;";....       
08f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0900: 20 63 6d 64 2e 45 78 65 63 75 74 65 4e 6f 6e 51   cmd.ExecuteNonQ
0910: 75 65 72 79 28 29 3b 0d 0a 20 20 20 20 20 20 20  uery();..       
0920: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a               }..
0930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0940: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  }..             
0950: 20 20 20 63 61 74 63 68 20 28 53 51 4c 69 74 65     catch (SQLite
0960: 45 78 63 65 70 74 69 6f 6e 29 0d 0a 20 20 20 20  Exception)..    
0970: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
0980: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0990: 20 20 20 5f 63 6e 6e 2e 5f 74 72 61 6e 73 61 63     _cnn._transac
09a0: 74 69 6f 6e 4c 65 76 65 6c 2d 2d 3b 0d 0a 20 20  tionLevel--;..  
09b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
09c0: 20 20 5f 63 6e 6e 20 3d 20 6e 75 6c 6c 3b 0d 0a    _cnn = null;..
09d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
09e0: 20 20 20 20 20 20 74 68 72 6f 77 3b 0d 0a 20 20        throw;..  
09f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d                }.
0a00: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  .            }..
0a10: 20 20 20 20 20 20 20 20 20 20 20 20 65 6c 73 65              else
0a20: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d  ..            {.
0a30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0a40: 20 74 68 72 6f 77 20 6e 65 77 20 53 51 4c 69 74   throw new SQLit
0a50: 65 45 78 63 65 70 74 69 6f 6e 28 22 54 72 61 6e  eException("Tran
0a60: 73 61 63 74 69 6f 6e 20 69 73 20 61 6c 72 65 61  saction is alrea
0a70: 64 79 20 61 63 74 69 76 65 20 6f 6e 20 74 68 69  dy active on thi
0a80: 73 20 63 6f 6e 6e 65 63 74 69 6f 6e 22 29 3b 0d  s connection");.
0a90: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  .            }..
0aa0: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20          }....   
0ab0: 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f       ///////////
0ac0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ad0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ae0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0af0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0b00: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0b10: 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ////....        
0b20: 23 72 65 67 69 6f 6e 20 49 44 69 73 70 6f 73 61  #region IDisposa
0b30: 62 6c 65 20 22 50 61 74 74 65 72 6e 22 20 4d 65  ble "Pattern" Me
0b40: 6d 62 65 72 73 0d 0a 20 20 20 20 20 20 20 20 70  mbers..        p
0b50: 72 69 76 61 74 65 20 62 6f 6f 6c 20 64 69 73 70  rivate bool disp
0b60: 6f 73 65 64 3b 0d 0a 20 20 20 20 20 20 20 20 70  osed;..        p
0b70: 72 69 76 61 74 65 20 76 6f 69 64 20 43 68 65 63  rivate void Chec
0b80: 6b 44 69 73 70 6f 73 65 64 28 29 20 2f 2a 20 74  kDisposed() /* t
0b90: 68 72 6f 77 20 2a 2f 0d 0a 20 20 20 20 20 20 20  hrow */..       
0ba0: 20 7b 0d 0a 23 69 66 20 54 48 52 4f 57 5f 4f 4e   {..#if THROW_ON
0bb0: 5f 44 49 53 50 4f 53 45 44 0d 0a 20 20 20 20 20  _DISPOSED..     
0bc0: 20 20 20 20 20 20 20 69 66 20 28 64 69 73 70 6f         if (dispo
0bd0: 73 65 64 29 0d 0a 20 20 20 20 20 20 20 20 20 20  sed)..          
0be0: 20 20 20 20 20 20 74 68 72 6f 77 20 6e 65 77 20        throw new 
0bf0: 4f 62 6a 65 63 74 44 69 73 70 6f 73 65 64 45 78  ObjectDisposedEx
0c00: 63 65 70 74 69 6f 6e 28 74 79 70 65 6f 66 28 53  ception(typeof(S
0c10: 51 4c 69 74 65 54 72 61 6e 73 61 63 74 69 6f 6e  QLiteTransaction
0c20: 29 2e 4e 61 6d 65 29 3b 0d 0a 23 65 6e 64 69 66  ).Name);..#endif
0c30: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20  ..        }.... 
0c40: 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f         /////////
0c50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0c60: 2f 2f 2f 2f 2f 2f 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 2f 2f 2f 2f  ////////////////
0c90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ca0: 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20  //////....      
0cb0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
0cc0: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 44 69 73  .        /// Dis
0cd0: 70 6f 73 65 73 20 74 68 65 20 74 72 61 6e 73 61  poses the transa
0ce0: 63 74 69 6f 6e 2e 20 20 49 66 20 69 74 20 69 73  ction.  If it is
0cf0: 20 63 75 72 72 65 6e 74 6c 79 20 61 63 74 69 76   currently activ
0d00: 65 2c 20 61 6e 79 20 63 68 61 6e 67 65 73 20 61  e, any changes a
0d10: 72 65 20 72 6f 6c 6c 65 64 20 62 61 63 6b 2e 0d  re rolled back..
0d20: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73  .        /// </s
0d30: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 20  ummary>..       
0d40: 20 70 72 6f 74 65 63 74 65 64 20 6f 76 65 72 72   protected overr
0d50: 69 64 65 20 76 6f 69 64 20 44 69 73 70 6f 73 65  ide void Dispose
0d60: 28 62 6f 6f 6c 20 64 69 73 70 6f 73 69 6e 67 29  (bool disposing)
0d70: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
0d80: 20 20 20 20 20 20 20 20 20 74 72 79 0d 0a 20 20           try..  
0d90: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
0da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20               if 
0db0: 28 21 64 69 73 70 6f 73 65 64 29 0d 0a 20 20 20  (!disposed)..   
0dc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a               {..
0dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0de0: 20 20 20 20 69 66 20 28 64 69 73 70 6f 73 69 6e      if (disposin
0df0: 67 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  g)..            
0e00: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
0e10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0e20: 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f     /////////////
0e30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0e40: 2f 2f 2f 2f 2f 2f 2f 0d 0a 20 20 20 20 20 20 20  ///////..       
0e50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0e60: 20 2f 2f 20 64 69 73 70 6f 73 65 20 6d 61 6e 61   // dispose mana
0e70: 67 65 64 20 72 65 73 6f 75 72 63 65 73 20 68 65  ged resources he
0e80: 72 65 2e 2e 2e 0d 0a 20 20 20 20 20 20 20 20 20  re.....         
0e90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
0ea0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0eb0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ec0: 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20  ///....         
0ed0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
0ee0: 66 20 28 49 73 56 61 6c 69 64 28 66 61 6c 73 65  f (IsValid(false
0ef0: 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ))..            
0f00: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
0f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0f20: 20 20 20 20 20 20 20 20 20 20 20 49 73 73 75 65             Issue
0f30: 52 6f 6c 6c 62 61 63 6b 28 66 61 6c 73 65 29 3b  Rollback(false);
0f40: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0f50: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
0f60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0f70: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20   }....          
0f80: 20 20 20 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f            //////
0f90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0fa0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0fb0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0fc0: 20 20 20 20 20 20 2f 2f 20 72 65 6c 65 61 73 65        // release
0fd0: 20 75 6e 6d 61 6e 61 67 65 64 20 72 65 73 6f 75   unmanaged resou
0fe0: 72 63 65 73 20 68 65 72 65 2e 2e 2e 0d 0a 20 20  rces here.....  
0ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1000: 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f    //////////////
1010: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1020: 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 20 20 20 20 20 20  ////////..      
1030: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
1040: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20           }..    
1050: 20 20 20 20 20 20 20 20 66 69 6e 61 6c 6c 79 0d          finally.
1060: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a  .            {..
1070: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1080: 62 61 73 65 2e 44 69 73 70 6f 73 65 28 64 69 73  base.Dispose(dis
1090: 70 6f 73 69 6e 67 29 3b 0d 0a 0d 0a 20 20 20 20  posing);....    
10a0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a              //..
10b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
10c0: 2f 2f 20 4e 4f 54 45 3a 20 45 76 65 72 79 74 68  // NOTE: Everyth
10d0: 69 6e 67 20 73 68 6f 75 6c 64 20 62 65 20 66 75  ing should be fu
10e0: 6c 6c 79 20 64 69 73 70 6f 73 65 64 20 61 74 20  lly disposed at 
10f0: 74 68 69 73 20 70 6f 69 6e 74 2e 0d 0a 20 20 20  this point...   
1100: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 0d               //.
1110: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
1120: 20 64 69 73 70 6f 73 65 64 20 3d 20 74 72 75 65   disposed = true
1130: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  ;..            }
1140: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20  ..        }..   
1150: 20 20 20 20 20 23 65 6e 64 72 65 67 69 6f 6e 0d       #endregion.
1160: 0a 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 2f 2f  ...        /////
1170: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1180: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1190: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
11a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
11b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
11c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20  //////////....  
11d0: 20 20 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61        /// <summa
11e0: 72 79 3e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f  ry>..        ///
11f0: 20 43 6f 6d 6d 69 74 73 20 74 68 65 20 63 75 72   Commits the cur
1200: 72 65 6e 74 20 74 72 61 6e 73 61 63 74 69 6f 6e  rent transaction
1210: 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c  ...        /// <
1220: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20  /summary>..     
1230: 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69     public overri
1240: 64 65 20 76 6f 69 64 20 43 6f 6d 6d 69 74 28 29  de void Commit()
1250: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
1260: 20 20 20 20 20 20 20 20 20 43 68 65 63 6b 44 69           CheckDi
1270: 73 70 6f 73 65 64 28 29 3b 0d 0a 20 20 20 20 20  sposed();..     
1280: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e         SQLiteCon
1290: 6e 65 63 74 69 6f 6e 2e 43 68 65 63 6b 28 5f 63  nection.Check(_c
12a0: 6e 6e 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  nn);..          
12b0: 20 20 49 73 56 61 6c 69 64 28 74 72 75 65 29 3b    IsValid(true);
12c0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
12d0: 69 66 20 28 5f 63 6e 6e 2e 5f 74 72 61 6e 73 61  if (_cnn._transa
12e0: 63 74 69 6f 6e 4c 65 76 65 6c 20 2d 20 31 20 3d  ctionLevel - 1 =
12f0: 3d 20 30 29 0d 0a 20 20 20 20 20 20 20 20 20 20  = 0)..          
1300: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
1310: 20 20 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69       using (SQLi
1320: 74 65 43 6f 6d 6d 61 6e 64 20 63 6d 64 20 3d 20  teCommand cmd = 
1330: 5f 63 6e 6e 2e 43 72 65 61 74 65 43 6f 6d 6d 61  _cnn.CreateComma
1340: 6e 64 28 29 29 0d 0a 20 20 20 20 20 20 20 20 20  nd())..         
1350: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
1360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6d                cm
1370: 64 2e 43 6f 6d 6d 61 6e 64 54 65 78 74 20 3d 20  d.CommandText = 
1380: 22 43 4f 4d 4d 49 54 3b 22 3b 0d 0a 20 20 20 20  "COMMIT;";..    
1390: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
13a0: 63 6d 64 2e 45 78 65 63 75 74 65 4e 6f 6e 51 75  cmd.ExecuteNonQu
13b0: 65 72 79 28 29 3b 0d 0a 20 20 20 20 20 20 20 20  ery();..        
13c0: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
13d0: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
13e0: 20 20 20 20 20 20 5f 63 6e 6e 2e 5f 74 72 61 6e        _cnn._tran
13f0: 73 61 63 74 69 6f 6e 4c 65 76 65 6c 2d 2d 3b 0d  sactionLevel--;.
1400: 0a 20 20 20 20 20 20 20 20 20 20 20 20 5f 63 6e  .            _cn
1410: 6e 20 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20 20  n = null;..     
1420: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
1430: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1440: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1450: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1460: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1470: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1480: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d  ///////////////.
1490: 0a 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c  ...        /// <
14a0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20  summary>..      
14b0: 20 20 2f 2f 2f 20 52 65 74 75 72 6e 73 20 74 68    /// Returns th
14c0: 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 63 6f 6e  e underlying con
14d0: 6e 65 63 74 69 6f 6e 20 74 6f 20 77 68 69 63 68  nection to which
14e0: 20 74 68 69 73 20 74 72 61 6e 73 61 63 74 69 6f   this transactio
14f0: 6e 20 61 70 70 6c 69 65 73 2e 0d 0a 20 20 20 20  n applies...    
1500: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
1510: 79 3e 0d 0a 20 20 20 20 20 20 20 20 70 75 62 6c  y>..        publ
1520: 69 63 20 6e 65 77 20 53 51 4c 69 74 65 43 6f 6e  ic new SQLiteCon
1530: 6e 65 63 74 69 6f 6e 20 43 6f 6e 6e 65 63 74 69  nection Connecti
1540: 6f 6e 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  on..        {.. 
1550: 20 20 20 20 20 20 20 20 20 20 20 67 65 74 20 7b             get {
1560: 20 43 68 65 63 6b 44 69 73 70 6f 73 65 64 28 29   CheckDisposed()
1570: 3b 20 72 65 74 75 72 6e 20 5f 63 6e 6e 3b 20 7d  ; return _cnn; }
1580: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20  ..        }.... 
1590: 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f         /////////
15a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
15b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
15c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
15d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
15e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
15f0: 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20  //////....      
1600: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
1610: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 46 6f 72  .        /// For
1620: 77 61 72 64 73 20 74 6f 20 74 68 65 20 6c 6f 63  wards to the loc
1630: 61 6c 20 43 6f 6e 6e 65 63 74 69 6f 6e 20 70 72  al Connection pr
1640: 6f 70 65 72 74 79 0d 0a 20 20 20 20 20 20 20 20  operty..        
1650: 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a  /// </summary>..
1660: 20 20 20 20 20 20 20 20 70 72 6f 74 65 63 74 65          protecte
1670: 64 20 6f 76 65 72 72 69 64 65 20 44 62 43 6f 6e  d override DbCon
1680: 6e 65 63 74 69 6f 6e 20 44 62 43 6f 6e 6e 65 63  nection DbConnec
1690: 74 69 6f 6e 0d 0a 20 20 20 20 20 20 20 20 7b 0d  tion..        {.
16a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 67 65 74  .            get
16b0: 20 7b 20 72 65 74 75 72 6e 20 43 6f 6e 6e 65 63   { return Connec
16c0: 74 69 6f 6e 3b 20 7d 0d 0a 20 20 20 20 20 20 20  tion; }..       
16d0: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 2f 2f   }....        //
16e0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
16f0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1700: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1710: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1720: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1730: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d  /////////////...
1740: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c 73 75  .        /// <su
1750: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 20 20  mmary>..        
1760: 2f 2f 2f 20 47 65 74 73 20 74 68 65 20 69 73 6f  /// Gets the iso
1770: 6c 61 74 69 6f 6e 20 6c 65 76 65 6c 20 6f 66 20  lation level of 
1780: 74 68 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 2e  the transaction.
1790: 20 20 53 51 4c 69 74 65 20 6f 6e 6c 79 20 73 75    SQLite only su
17a0: 70 70 6f 72 74 73 20 53 65 72 69 61 6c 69 7a 61  pports Serializa
17b0: 62 6c 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 73  ble transactions
17c0: 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c  ...        /// <
17d0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20  /summary>..     
17e0: 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69     public overri
17f0: 64 65 20 49 73 6f 6c 61 74 69 6f 6e 4c 65 76 65  de IsolationLeve
1800: 6c 20 49 73 6f 6c 61 74 69 6f 6e 4c 65 76 65 6c  l IsolationLevel
1810: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
1820: 20 20 20 20 20 20 20 20 20 67 65 74 20 7b 20 43           get { C
1830: 68 65 63 6b 44 69 73 70 6f 73 65 64 28 29 3b 20  heckDisposed(); 
1840: 72 65 74 75 72 6e 20 5f 6c 65 76 65 6c 3b 20 7d  return _level; }
1850: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20  ..        }.... 
1860: 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f         /////////
1870: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1880: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1890: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
18a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
18b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
18c0: 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 20 20  //////....      
18d0: 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d    /// <summary>.
18e0: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 52 6f 6c  .        /// Rol
18f0: 6c 73 20 62 61 63 6b 20 74 68 65 20 61 63 74 69  ls back the acti
1900: 76 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 2e 0d  ve transaction..
1910: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73  .        /// </s
1920: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 20  ummary>..       
1930: 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69 64 65   public override
1940: 20 76 6f 69 64 20 52 6f 6c 6c 62 61 63 6b 28 29   void Rollback()
1950: 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20  ..        {..   
1960: 20 20 20 20 20 20 20 20 20 43 68 65 63 6b 44 69           CheckDi
1970: 73 70 6f 73 65 64 28 29 3b 0d 0a 20 20 20 20 20  sposed();..     
1980: 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e         SQLiteCon
1990: 6e 65 63 74 69 6f 6e 2e 43 68 65 63 6b 28 5f 63  nection.Check(_c
19a0: 6e 6e 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  nn);..          
19b0: 20 20 49 73 56 61 6c 69 64 28 74 72 75 65 29 3b    IsValid(true);
19c0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 49 73  ..            Is
19d0: 73 75 65 52 6f 6c 6c 62 61 63 6b 28 74 72 75 65  sueRollback(true
19e0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 0d  );..        }...
19f0: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f  .        ///////
1a00: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1a10: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1a20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1a30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1a40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1a50: 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20  ////////....    
1a60: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
1a70: 3e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 49  >..        /// I
1a80: 73 73 75 65 20 61 20 52 4f 4c 4c 42 41 43 4b 20  ssue a ROLLBACK 
1a90: 63 6f 6d 6d 61 6e 64 20 61 67 61 69 6e 73 74 20  command against 
1aa0: 74 68 65 20 64 61 74 61 62 61 73 65 20 63 6f 6e  the database con
1ab0: 6e 65 63 74 69 6f 6e 2c 0d 0a 20 20 20 20 20 20  nection,..      
1ac0: 20 20 2f 2f 2f 20 6f 70 74 69 6f 6e 61 6c 6c 79    /// optionally
1ad0: 20 72 65 2d 74 68 72 6f 77 69 6e 67 20 61 6e 79   re-throwing any
1ae0: 20 63 61 75 67 68 74 20 65 78 63 65 70 74 69 6f   caught exceptio
1af0: 6e 2e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20  n...        /// 
1b00: 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20  </summary>..    
1b10: 20 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e      /// <param n
1b20: 61 6d 65 3d 22 74 68 72 6f 77 45 72 72 6f 72 22  ame="throwError"
1b30: 3e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 4e  >..        /// N
1b40: 6f 6e 2d 7a 65 72 6f 20 74 6f 20 72 65 2d 74 68  on-zero to re-th
1b50: 72 6f 77 20 63 61 75 67 68 74 20 65 78 63 65 70  row caught excep
1b60: 74 69 6f 6e 73 2e 0d 0a 20 20 20 20 20 20 20 20  tions...        
1b70: 2f 2f 2f 20 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20  /// </param>..  
1b80: 20 20 20 20 20 20 70 72 69 76 61 74 65 20 76 6f        private vo
1b90: 69 64 20 49 73 73 75 65 52 6f 6c 6c 62 61 63 6b  id IssueRollback
1ba0: 28 62 6f 6f 6c 20 74 68 72 6f 77 45 72 72 6f 72  (bool throwError
1bb0: 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  )..        {..  
1bc0: 20 20 20 20 20 20 20 20 20 20 53 51 4c 69 74 65            SQLite
1bd0: 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6e 6e 20 3d  Connection cnn =
1be0: 20 49 6e 74 65 72 6c 6f 63 6b 65 64 2e 45 78 63   Interlocked.Exc
1bf0: 68 61 6e 67 65 28 72 65 66 20 5f 63 6e 6e 2c 20  hange(ref _cnn, 
1c00: 6e 75 6c 6c 29 3b 0d 0a 0d 0a 20 20 20 20 20 20  null);....      
1c10: 20 20 20 20 20 20 69 66 20 28 63 6e 6e 20 21 3d        if (cnn !=
1c20: 20 6e 75 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20   null)..        
1c30: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
1c40: 20 20 20 20 20 20 20 74 72 79 0d 0a 20 20 20 20         try..    
1c50: 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20              {.. 
1c60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1c70: 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65     using (SQLite
1c80: 43 6f 6d 6d 61 6e 64 20 63 6d 64 20 3d 20 63 6e  Command cmd = cn
1c90: 6e 2e 43 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28  n.CreateCommand(
1ca0: 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ))..            
1cb0: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
1cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1cd0: 20 20 20 63 6d 64 2e 43 6f 6d 6d 61 6e 64 54 65     cmd.CommandTe
1ce0: 78 74 20 3d 20 22 52 4f 4c 4c 42 41 43 4b 3b 22  xt = "ROLLBACK;"
1cf0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
1d00: 20 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 45             cmd.E
1d10: 78 65 63 75 74 65 4e 6f 6e 51 75 65 72 79 28 29  xecuteNonQuery()
1d20: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
1d30: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
1d40: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
1d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 61 74               cat
1d60: 63 68 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ch..            
1d70: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
1d80: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 74             if (t
1d90: 68 72 6f 77 45 72 72 6f 72 29 0d 0a 20 20 20 20  hrowError)..    
1da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1db0: 20 20 20 20 74 68 72 6f 77 3b 0d 0a 20 20 20 20      throw;..    
1dc0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
1dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63                 c
1de0: 6e 6e 2e 5f 74 72 61 6e 73 61 63 74 69 6f 6e 4c  nn._transactionL
1df0: 65 76 65 6c 20 3d 20 30 3b 0d 0a 20 20 20 20 20  evel = 0;..     
1e00: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
1e10: 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 2f    }....        /
1e20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1e30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1e40: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1e50: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1e60: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
1e70: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a  //////////////..
1e80: 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c 73  ..        /// <s
1e90: 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 20  ummary>..       
1ea0: 20 2f 2f 2f 20 43 68 65 63 6b 73 20 74 68 65 20   /// Checks the 
1eb0: 73 74 61 74 65 20 6f 66 20 74 68 69 73 20 74 72  state of this tr
1ec0: 61 6e 73 61 63 74 69 6f 6e 2c 20 6f 70 74 69 6f  ansaction, optio
1ed0: 6e 61 6c 6c 79 20 74 68 72 6f 77 69 6e 67 20 61  nally throwing a
1ee0: 6e 20 65 78 63 65 70 74 69 6f 6e 20 69 66 20 61  n exception if a
1ef0: 20 73 74 61 74 65 20 69 6e 63 6f 6e 73 69 73 74   state inconsist
1f00: 65 6e 63 79 20 69 73 20 66 6f 75 6e 64 2e 0d 0a  ency is found...
1f10: 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 73 75          /// </su
1f20: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 20 20 20 20  mmary>..        
1f30: 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d  /// <param name=
1f40: 22 74 68 72 6f 77 45 72 72 6f 72 22 3e 0d 0a 20  "throwError">.. 
1f50: 20 20 20 20 20 20 20 2f 2f 2f 20 4e 6f 6e 2d 7a         /// Non-z
1f60: 65 72 6f 20 74 6f 20 74 68 72 6f 77 20 61 6e 20  ero to throw an 
1f70: 65 78 63 65 70 74 69 6f 6e 20 69 66 20 61 20 73  exception if a s
1f80: 74 61 74 65 20 69 6e 63 6f 6e 73 69 73 74 65 6e  tate inconsisten
1f90: 63 79 20 69 73 20 66 6f 75 6e 64 2e 0d 0a 20 20  cy is found...  
1fa0: 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 70 61 72 61        /// </para
1fb0: 6d 3e 0d 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20  m>..        /// 
1fc0: 3c 72 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 20  <returns>..     
1fd0: 20 20 20 2f 2f 2f 20 4e 6f 6e 2d 7a 65 72 6f 20     /// Non-zero 
1fe0: 69 66 20 74 68 69 73 20 74 72 61 6e 73 61 63 74  if this transact
1ff0: 69 6f 6e 20 69 73 20 76 61 6c 69 64 3b 20 6f 74  ion is valid; ot
2000: 68 65 72 77 69 73 65 2c 20 66 61 6c 73 65 2e 0d  herwise, false..
2010: 0a 20 20 20 20 20 20 20 20 2f 2f 2f 20 3c 2f 72  .        /// </r
2020: 65 74 75 72 6e 73 3e 0d 0a 20 20 20 20 20 20 20  eturns>..       
2030: 20 69 6e 74 65 72 6e 61 6c 20 62 6f 6f 6c 20 49   internal bool I
2040: 73 56 61 6c 69 64 28 62 6f 6f 6c 20 74 68 72 6f  sValid(bool thro
2050: 77 45 72 72 6f 72 29 0d 0a 20 20 20 20 20 20 20  wError)..       
2060: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
2070: 69 66 20 28 5f 63 6e 6e 20 3d 3d 20 6e 75 6c 6c  if (_cnn == null
2080: 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b  )..            {
2090: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
20a0: 20 20 69 66 20 28 74 68 72 6f 77 45 72 72 6f 72    if (throwError
20b0: 20 3d 3d 20 74 72 75 65 29 20 74 68 72 6f 77 20   == true) throw 
20c0: 6e 65 77 20 41 72 67 75 6d 65 6e 74 4e 75 6c 6c  new ArgumentNull
20d0: 45 78 63 65 70 74 69 6f 6e 28 22 4e 6f 20 63 6f  Exception("No co
20e0: 6e 6e 65 63 74 69 6f 6e 20 61 73 73 6f 63 69 61  nnection associa
20f0: 74 65 64 20 77 69 74 68 20 74 68 69 73 20 74 72  ted with this tr
2100: 61 6e 73 61 63 74 69 6f 6e 22 29 3b 0d 0a 20 20  ansaction");..  
2110: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 65 6c                el
2120: 73 65 20 72 65 74 75 72 6e 20 66 61 6c 73 65 3b  se return false;
2130: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d  ..            }.
2140: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  ...            i
2150: 66 20 28 5f 63 6e 6e 2e 5f 76 65 72 73 69 6f 6e  f (_cnn._version
2160: 20 21 3d 20 5f 76 65 72 73 69 6f 6e 29 0d 0a 20   != _version).. 
2170: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
2180: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 66                if
2190: 20 28 74 68 72 6f 77 45 72 72 6f 72 20 3d 3d 20   (throwError == 
21a0: 74 72 75 65 29 20 74 68 72 6f 77 20 6e 65 77 20  true) throw new 
21b0: 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e 28  SQLiteException(
21c0: 22 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20  "The connection 
21d0: 77 61 73 20 63 6c 6f 73 65 64 20 61 6e 64 20 72  was closed and r
21e0: 65 2d 6f 70 65 6e 65 64 2c 20 63 68 61 6e 67 65  e-opened, change
21f0: 73 20 77 65 72 65 20 61 6c 72 65 61 64 79 20 72  s were already r
2200: 6f 6c 6c 65 64 20 62 61 63 6b 22 29 3b 0d 0a 20  olled back");.. 
2210: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 65                 e
2220: 6c 73 65 20 72 65 74 75 72 6e 20 66 61 6c 73 65  lse return false
2230: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  ;..            }
2240: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66  ..            if
2250: 20 28 5f 63 6e 6e 2e 53 74 61 74 65 20 21 3d 20   (_cnn.State != 
2260: 43 6f 6e 6e 65 63 74 69 6f 6e 53 74 61 74 65 2e  ConnectionState.
2270: 4f 70 65 6e 29 0d 0a 20 20 20 20 20 20 20 20 20  Open)..         
2280: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
2290: 20 20 20 20 20 20 69 66 20 28 74 68 72 6f 77 45        if (throwE
22a0: 72 72 6f 72 20 3d 3d 20 74 72 75 65 29 20 74 68  rror == true) th
22b0: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
22c0: 63 65 70 74 69 6f 6e 28 22 43 6f 6e 6e 65 63 74  ception("Connect
22d0: 69 6f 6e 20 77 61 73 20 63 6c 6f 73 65 64 22 29  ion was closed")
22e0: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
22f0: 20 20 20 65 6c 73 65 20 72 65 74 75 72 6e 20 66     else return f
2300: 61 6c 73 65 3b 0d 0a 20 20 20 20 20 20 20 20 20  alse;..         
2310: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
2320: 20 20 20 20 69 66 20 28 5f 63 6e 6e 2e 5f 74 72      if (_cnn._tr
2330: 61 6e 73 61 63 74 69 6f 6e 4c 65 76 65 6c 20 3d  ansactionLevel =
2340: 3d 20 30 20 7c 7c 20 5f 63 6e 6e 2e 5f 73 71 6c  = 0 || _cnn._sql
2350: 2e 41 75 74 6f 43 6f 6d 6d 69 74 20 3d 3d 20 74  .AutoCommit == t
2360: 72 75 65 29 0d 0a 20 20 20 20 20 20 20 20 20 20  rue)..          
2370: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
2380: 20 20 20 20 20 5f 63 6e 6e 2e 5f 74 72 61 6e 73       _cnn._trans
2390: 61 63 74 69 6f 6e 4c 65 76 65 6c 20 3d 20 30 3b  actionLevel = 0;
23a0: 20 2f 2f 20 4d 61 6b 65 20 73 75 72 65 20 74 68   // Make sure th
23b0: 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 6c 65  e transaction le
23c0: 76 65 6c 20 69 73 20 72 65 73 65 74 20 62 65 66  vel is reset bef
23d0: 6f 72 65 20 72 65 74 75 72 6e 69 6e 67 0d 0a 20  ore returning.. 
23e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69                 i
23f0: 66 20 28 74 68 72 6f 77 45 72 72 6f 72 20 3d 3d  f (throwError ==
2400: 20 74 72 75 65 29 20 74 68 72 6f 77 20 6e 65 77   true) throw new
2410: 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f 6e   SQLiteException
2420: 28 22 4e 6f 20 74 72 61 6e 73 61 63 74 69 6f 6e  ("No transaction
2430: 20 69 73 20 61 63 74 69 76 65 20 6f 6e 20 74 68   is active on th
2440: 69 73 20 63 6f 6e 6e 65 63 74 69 6f 6e 22 29 3b  is connection");
2450: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
2460: 20 20 65 6c 73 65 20 72 65 74 75 72 6e 20 66 61    else return fa
2470: 6c 73 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  lse;..          
2480: 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20    }....         
2490: 20 20 20 72 65 74 75 72 6e 20 74 72 75 65 3b 0d     return true;.
24a0: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
24b0: 7d 0d 0a 7d 0d 0a                                }..}..