System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact d4785e319ff3ac18f34cceedace56aa6293e48ac:


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 75 73 69 6e 67 20 53  te..{..  using S
0150: 79 73 74 65 6d 3b 0d 0a 20 20 75 73 69 6e 67 20  ystem;..  using 
0160: 53 79 73 74 65 6d 2e 44 61 74 61 3b 0d 0a 20 20  System.Data;..  
0170: 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44 61 74  using System.Dat
0180: 61 2e 43 6f 6d 6d 6f 6e 3b 0d 0a 20 20 75 73 69  a.Common;..  usi
0190: 6e 67 20 53 79 73 74 65 6d 2e 54 68 72 65 61 64  ng System.Thread
01a0: 69 6e 67 3b 0d 0a 0d 0a 20 20 2f 2f 2f 20 3c 73  ing;....  /// <s
01b0: 75 6d 6d 61 72 79 3e 0d 0a 20 20 2f 2f 2f 20 53  ummary>..  /// S
01c0: 51 4c 69 74 65 20 69 6d 70 6c 65 6d 65 6e 74 61  QLite implementa
01d0: 74 69 6f 6e 20 6f 66 20 44 62 54 72 61 6e 73 61  tion of DbTransa
01e0: 63 74 69 6f 6e 2e 0d 0a 20 20 2f 2f 2f 20 3c 2f  ction...  /// </
01f0: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 70 75 62 6c  summary>..  publ
0200: 69 63 20 73 65 61 6c 65 64 20 63 6c 61 73 73 20  ic sealed class 
0210: 53 51 4c 69 74 65 54 72 61 6e 73 61 63 74 69 6f  SQLiteTransactio
0220: 6e 20 3a 20 44 62 54 72 61 6e 73 61 63 74 69 6f  n : DbTransactio
0230: 6e 0d 0a 20 20 7b 0d 0a 20 20 20 20 2f 2f 2f 20  n..  {..    /// 
0240: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
0250: 2f 2f 20 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f  // The connectio
0260: 6e 20 74 6f 20 77 68 69 63 68 20 74 68 69 73 20  n to which this 
0270: 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 73 20 62  transaction is b
0280: 6f 75 6e 64 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ound..    /// </
0290: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 69 6e  summary>..    in
02a0: 74 65 72 6e 61 6c 20 53 51 4c 69 74 65 43 6f 6e  ternal SQLiteCon
02b0: 6e 65 63 74 69 6f 6e 20 5f 63 6e 6e 3b 0d 0a 20  nection _cnn;.. 
02c0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 6c 6f 6e 67     internal long
02d0: 20 5f 76 65 72 73 69 6f 6e 3b 20 2f 2f 20 4d 61   _version; // Ma
02e0: 74 63 68 65 73 20 74 68 65 20 76 65 72 73 69 6f  tches the versio
02f0: 6e 20 6f 66 20 74 68 65 20 63 6f 6e 6e 65 63 74  n of the connect
0300: 69 6f 6e 0d 0a 20 20 20 20 70 72 69 76 61 74 65  ion..    private
0310: 20 49 73 6f 6c 61 74 69 6f 6e 4c 65 76 65 6c 20   IsolationLevel 
0320: 5f 6c 65 76 65 6c 3b 0d 0a 0d 0a 20 20 20 20 2f  _level;....    /
0330: 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20  // <summary>..  
0340: 20 20 2f 2f 2f 20 43 6f 6e 73 74 72 75 63 74 73    /// Constructs
0350: 20 74 68 65 20 74 72 61 6e 73 61 63 74 69 6f 6e   the transaction
0360: 20 6f 62 6a 65 63 74 2c 20 62 69 6e 64 69 6e 67   object, binding
0370: 20 69 74 20 74 6f 20 74 68 65 20 73 75 70 70 6c   it to the suppl
0380: 69 65 64 20 63 6f 6e 6e 65 63 74 69 6f 6e 0d 0a  ied connection..
0390: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
03a0: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70 61 72  y>..    /// <par
03b0: 61 6d 20 6e 61 6d 65 3d 22 63 6f 6e 6e 65 63 74  am name="connect
03c0: 69 6f 6e 22 3e 54 68 65 20 63 6f 6e 6e 65 63 74  ion">The connect
03d0: 69 6f 6e 20 74 6f 20 6f 70 65 6e 20 61 20 74 72  ion to open a tr
03e0: 61 6e 73 61 63 74 69 6f 6e 20 6f 6e 3c 2f 70 61  ansaction on</pa
03f0: 72 61 6d 3e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 70  ram>..    /// <p
0400: 61 72 61 6d 20 6e 61 6d 65 3d 22 64 65 66 65 72  aram name="defer
0410: 72 65 64 4c 6f 63 6b 22 3e 54 52 55 45 20 74 6f  redLock">TRUE to
0420: 20 64 65 66 65 72 20 74 68 65 20 77 72 69 74 65   defer the write
0430: 6c 6f 63 6b 2c 20 6f 72 20 46 41 4c 53 45 20 74  lock, or FALSE t
0440: 6f 20 6c 6f 63 6b 20 69 6d 6d 65 64 69 61 74 65  o lock immediate
0450: 6c 79 3c 2f 70 61 72 61 6d 3e 0d 0a 20 20 20 20  ly</param>..    
0460: 69 6e 74 65 72 6e 61 6c 20 53 51 4c 69 74 65 54  internal SQLiteT
0470: 72 61 6e 73 61 63 74 69 6f 6e 28 53 51 4c 69 74  ransaction(SQLit
0480: 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6f 6e 6e  eConnection conn
0490: 65 63 74 69 6f 6e 2c 20 62 6f 6f 6c 20 64 65 66  ection, bool def
04a0: 65 72 72 65 64 4c 6f 63 6b 29 0d 0a 20 20 20 20  erredLock)..    
04b0: 7b 0d 0a 20 20 20 20 20 20 5f 63 6e 6e 20 3d 20  {..      _cnn = 
04c0: 63 6f 6e 6e 65 63 74 69 6f 6e 3b 0d 0a 20 20 20  connection;..   
04d0: 20 20 20 5f 76 65 72 73 69 6f 6e 20 3d 20 5f 63     _version = _c
04e0: 6e 6e 2e 5f 76 65 72 73 69 6f 6e 3b 0d 0a 0d 0a  nn._version;....
04f0: 20 20 20 20 20 20 5f 6c 65 76 65 6c 20 3d 20 28        _level = (
0500: 64 65 66 65 72 72 65 64 4c 6f 63 6b 20 3d 3d 20  deferredLock == 
0510: 74 72 75 65 29 20 3f 0d 0a 20 20 20 20 20 20 20  true) ?..       
0520: 20 20 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74     SQLiteConnect
0530: 69 6f 6e 2e 44 65 66 65 72 72 65 64 49 73 6f 6c  ion.DeferredIsol
0540: 61 74 69 6f 6e 4c 65 76 65 6c 20 3a 0d 0a 20 20  ationLevel :..  
0550: 20 20 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f          SQLiteCo
0560: 6e 6e 65 63 74 69 6f 6e 2e 49 6d 6d 65 64 69 61  nnection.Immedia
0570: 74 65 49 73 6f 6c 61 74 69 6f 6e 4c 65 76 65 6c  teIsolationLevel
0580: 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20 28 5f  ;....      if (_
0590: 63 6e 6e 2e 5f 74 72 61 6e 73 61 63 74 69 6f 6e  cnn._transaction
05a0: 4c 65 76 65 6c 2b 2b 20 3d 3d 20 30 29 0d 0a 20  Level++ == 0).. 
05b0: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
05c0: 74 72 79 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  try..        {..
05d0: 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20            using 
05e0: 28 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63  (SQLiteCommand c
05f0: 6d 64 20 3d 20 5f 63 6e 6e 2e 43 72 65 61 74 65  md = _cnn.Create
0600: 43 6f 6d 6d 61 6e 64 28 29 29 0d 0a 20 20 20 20  Command())..    
0610: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
0620: 20 20 20 20 20 69 66 20 28 21 64 65 66 65 72 72       if (!deferr
0630: 65 64 4c 6f 63 6b 29 0d 0a 20 20 20 20 20 20 20  edLock)..       
0640: 20 20 20 20 20 20 20 63 6d 64 2e 43 6f 6d 6d 61         cmd.Comma
0650: 6e 64 54 65 78 74 20 3d 20 22 42 45 47 49 4e 20  ndText = "BEGIN 
0660: 49 4d 4d 45 44 49 41 54 45 22 3b 0d 0a 20 20 20  IMMEDIATE";..   
0670: 20 20 20 20 20 20 20 20 20 65 6c 73 65 0d 0a 20           else.. 
0680: 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6d 64               cmd
0690: 2e 43 6f 6d 6d 61 6e 64 54 65 78 74 20 3d 20 22  .CommandText = "
06a0: 42 45 47 49 4e 22 3b 0d 0a 0d 0a 20 20 20 20 20  BEGIN";....     
06b0: 20 20 20 20 20 20 20 63 6d 64 2e 45 78 65 63 75         cmd.Execu
06c0: 74 65 4e 6f 6e 51 75 65 72 79 28 29 3b 0d 0a 20  teNonQuery();.. 
06d0: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20           }..    
06e0: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 63      }..        c
06f0: 61 74 63 68 20 28 53 51 4c 69 74 65 45 78 63 65  atch (SQLiteExce
0700: 70 74 69 6f 6e 29 0d 0a 20 20 20 20 20 20 20 20  ption)..        
0710: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 5f 63 6e  {..          _cn
0720: 6e 2e 5f 74 72 61 6e 73 61 63 74 69 6f 6e 4c 65  n._transactionLe
0730: 76 65 6c 2d 2d 3b 0d 0a 20 20 20 20 20 20 20 20  vel--;..        
0740: 20 20 5f 63 6e 6e 20 3d 20 6e 75 6c 6c 3b 0d 0a    _cnn = null;..
0750: 20 20 20 20 20 20 20 20 20 20 74 68 72 6f 77 3b            throw;
0760: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20  ..        }..   
0770: 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20     }..    }.... 
0780: 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f     /////////////
0790: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
07a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
07b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
07c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
07d0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
07e0: 2f 2f 0d 0a 0d 0a 20 20 20 20 23 72 65 67 69 6f  //....    #regio
07f0: 6e 20 49 44 69 73 70 6f 73 61 62 6c 65 20 22 50  n IDisposable "P
0800: 61 74 74 65 72 6e 22 20 4d 65 6d 62 65 72 73 0d  attern" Members.
0810: 0a 20 20 20 20 70 72 69 76 61 74 65 20 62 6f 6f  .    private boo
0820: 6c 20 64 69 73 70 6f 73 65 64 3b 0d 0a 20 20 20  l disposed;..   
0830: 20 70 72 69 76 61 74 65 20 76 6f 69 64 20 43 68   private void Ch
0840: 65 63 6b 44 69 73 70 6f 73 65 64 28 29 20 2f 2a  eckDisposed() /*
0850: 20 74 68 72 6f 77 20 2a 2f 0d 0a 20 20 20 20 7b   throw */..    {
0860: 0d 0a 23 69 66 20 54 48 52 4f 57 5f 4f 4e 5f 44  ..#if THROW_ON_D
0870: 49 53 50 4f 53 45 44 0d 0a 20 20 20 20 20 20 20  ISPOSED..       
0880: 20 69 66 20 28 64 69 73 70 6f 73 65 64 29 0d 0a   if (disposed)..
0890: 20 20 20 20 20 20 20 20 20 20 20 20 74 68 72 6f              thro
08a0: 77 20 6e 65 77 20 4f 62 6a 65 63 74 44 69 73 70  w new ObjectDisp
08b0: 6f 73 65 64 45 78 63 65 70 74 69 6f 6e 28 74 79  osedException(ty
08c0: 70 65 6f 66 28 53 51 4c 69 74 65 54 72 61 6e 73  peof(SQLiteTrans
08d0: 61 63 74 69 6f 6e 29 2e 4e 61 6d 65 29 3b 0d 0a  action).Name);..
08e0: 23 65 6e 64 69 66 0d 0a 20 20 20 20 7d 0d 0a 0d  #endif..    }...
08f0: 0a 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  .    ///////////
0900: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0910: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0920: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0930: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0940: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0950: 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20  ////....    /// 
0960: 3c 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f  <summary>..    /
0970: 2f 2f 20 44 69 73 70 6f 73 65 73 20 74 68 65 20  // Disposes the 
0980: 74 72 61 6e 73 61 63 74 69 6f 6e 2e 20 20 49 66  transaction.  If
0990: 20 69 74 20 69 73 20 63 75 72 72 65 6e 74 6c 79   it is currently
09a0: 20 61 63 74 69 76 65 2c 20 61 6e 79 20 63 68 61   active, any cha
09b0: 6e 67 65 73 20 61 72 65 20 72 6f 6c 6c 65 64 20  nges are rolled 
09c0: 62 61 63 6b 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c  back...    /// <
09d0: 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70  /summary>..    p
09e0: 72 6f 74 65 63 74 65 64 20 6f 76 65 72 72 69 64  rotected overrid
09f0: 65 20 76 6f 69 64 20 44 69 73 70 6f 73 65 28 62  e void Dispose(b
0a00: 6f 6f 6c 20 64 69 73 70 6f 73 69 6e 67 29 0d 0a  ool disposing)..
0a10: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 74      {..        t
0a20: 72 79 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  ry..        {.. 
0a30: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 28 21             if (!
0a40: 64 69 73 70 6f 73 65 64 29 0d 0a 20 20 20 20 20  disposed)..     
0a50: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
0a60: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 64 69            if (di
0a70: 73 70 6f 73 69 6e 67 29 0d 0a 20 20 20 20 20 20  sposing)..      
0a80: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
0a90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0aa0: 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f   ///////////////
0ab0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ac0: 2f 2f 2f 2f 2f 0d 0a 20 20 20 20 20 20 20 20 20  /////..         
0ad0: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 64 69             // di
0ae0: 73 70 6f 73 65 20 6d 61 6e 61 67 65 64 20 72 65  spose managed re
0af0: 73 6f 75 72 63 65 73 20 68 65 72 65 2e 2e 2e 0d  sources here....
0b00: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0b10: 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f       ///////////
0b20: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0b30: 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20  /////////....   
0b40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0b50: 20 69 66 20 28 49 73 56 61 6c 69 64 28 66 61 6c   if (IsValid(fal
0b60: 73 65 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20  se))..          
0b70: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
0b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0b90: 20 20 20 20 20 49 73 73 75 65 52 6f 6c 6c 62 61       IssueRollba
0ba0: 63 6b 28 66 61 6c 73 65 29 3b 0d 0a 20 20 20 20  ck(false);..    
0bb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0bc0: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  }..             
0bd0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
0be0: 20 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f          ////////
0bf0: 2f 2f 2f 2f 2f 2f 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 0d 0a  //////////////..
0c10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0c20: 2f 2f 20 72 65 6c 65 61 73 65 20 75 6e 6d 61 6e  // release unman
0c30: 61 67 65 64 20 72 65 73 6f 75 72 63 65 73 20 68  aged resources h
0c40: 65 72 65 2e 2e 2e 0d 0a 20 20 20 20 20 20 20 20  ere.....        
0c50: 20 20 20 20 20 20 20 20 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 0d 0a  //////////////..
0c80: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
0c90: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
0ca0: 20 20 66 69 6e 61 6c 6c 79 0d 0a 20 20 20 20 20    finally..     
0cb0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
0cc0: 20 20 62 61 73 65 2e 44 69 73 70 6f 73 65 28 64    base.Dispose(d
0cd0: 69 73 70 6f 73 69 6e 67 29 3b 0d 0a 0d 0a 20 20  isposing);....  
0ce0: 20 20 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20 20            //..  
0cf0: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54            // NOT
0d00: 45 3a 20 45 76 65 72 79 74 68 69 6e 67 20 73 68  E: Everything sh
0d10: 6f 75 6c 64 20 62 65 20 66 75 6c 6c 79 20 64 69  ould be fully di
0d20: 73 70 6f 73 65 64 20 61 74 20 74 68 69 73 20 70  sposed at this p
0d30: 6f 69 6e 74 2e 0d 0a 20 20 20 20 20 20 20 20 20  oint...         
0d40: 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 20 20 20     //..         
0d50: 20 20 20 64 69 73 70 6f 73 65 64 20 3d 20 74 72     disposed = tr
0d60: 75 65 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a  ue;..        }..
0d70: 20 20 20 20 7d 0d 0a 20 20 20 20 23 65 6e 64 72      }..    #endr
0d80: 65 67 69 6f 6e 0d 0a 0d 0a 20 20 20 20 2f 2f 2f  egion....    ///
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 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0dc0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0dd0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0de0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a  ////////////....
0df0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
0e00: 3e 0d 0a 20 20 20 20 2f 2f 2f 20 43 6f 6d 6d 69  >..    /// Commi
0e10: 74 73 20 74 68 65 20 63 75 72 72 65 6e 74 20 74  ts the current t
0e20: 72 61 6e 73 61 63 74 69 6f 6e 2e 0d 0a 20 20 20  ransaction...   
0e30: 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d   /// </summary>.
0e40: 0a 20 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72  .    public over
0e50: 72 69 64 65 20 76 6f 69 64 20 43 6f 6d 6d 69 74  ride void Commit
0e60: 28 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  ()..    {..     
0e70: 20 43 68 65 63 6b 44 69 73 70 6f 73 65 64 28 29   CheckDisposed()
0e80: 3b 0d 0a 20 20 20 20 20 20 53 51 4c 69 74 65 43  ;..      SQLiteC
0e90: 6f 6e 6e 65 63 74 69 6f 6e 2e 43 68 65 63 6b 28  onnection.Check(
0ea0: 5f 63 6e 6e 29 3b 0d 0a 20 20 20 20 20 20 49 73  _cnn);..      Is
0eb0: 56 61 6c 69 64 28 74 72 75 65 29 3b 0d 0a 0d 0a  Valid(true);....
0ec0: 20 20 20 20 20 20 69 66 20 28 5f 63 6e 6e 2e 5f        if (_cnn._
0ed0: 74 72 61 6e 73 61 63 74 69 6f 6e 4c 65 76 65 6c  transactionLevel
0ee0: 20 2d 20 31 20 3d 3d 20 30 29 0d 0a 20 20 20 20   - 1 == 0)..    
0ef0: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 75 73 69    {..        usi
0f00: 6e 67 20 28 53 51 4c 69 74 65 43 6f 6d 6d 61 6e  ng (SQLiteComman
0f10: 64 20 63 6d 64 20 3d 20 5f 63 6e 6e 2e 43 72 65  d cmd = _cnn.Cre
0f20: 61 74 65 43 6f 6d 6d 61 6e 64 28 29 29 0d 0a 20  ateCommand()).. 
0f30: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
0f40: 20 20 20 20 63 6d 64 2e 43 6f 6d 6d 61 6e 64 54      cmd.CommandT
0f50: 65 78 74 20 3d 20 22 43 4f 4d 4d 49 54 22 3b 0d  ext = "COMMIT";.
0f60: 0a 20 20 20 20 20 20 20 20 20 20 63 6d 64 2e 45  .          cmd.E
0f70: 78 65 63 75 74 65 4e 6f 6e 51 75 65 72 79 28 29  xecuteNonQuery()
0f80: 3b 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20  ;..        }..  
0f90: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 5f 63 6e      }..      _cn
0fa0: 6e 2e 5f 74 72 61 6e 73 61 63 74 69 6f 6e 4c 65  n._transactionLe
0fb0: 76 65 6c 2d 2d 3b 0d 0a 20 20 20 20 20 20 5f 63  vel--;..      _c
0fc0: 6e 6e 20 3d 20 6e 75 6c 6c 3b 0d 0a 20 20 20 20  nn = null;..    
0fd0: 7d 0d 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75  }....    /// <su
0fe0: 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20  mmary>..    /// 
0ff0: 52 65 74 75 72 6e 73 20 74 68 65 20 75 6e 64 65  Returns the unde
1000: 72 6c 79 69 6e 67 20 63 6f 6e 6e 65 63 74 69 6f  rlying connectio
1010: 6e 20 74 6f 20 77 68 69 63 68 20 74 68 69 73 20  n to which this 
1020: 74 72 61 6e 73 61 63 74 69 6f 6e 20 61 70 70 6c  transaction appl
1030: 69 65 73 2e 0d 0a 20 20 20 20 2f 2f 2f 20 3c 2f  ies...    /// </
1040: 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20 20 70 75  summary>..    pu
1050: 62 6c 69 63 20 6e 65 77 20 53 51 4c 69 74 65 43  blic new SQLiteC
1060: 6f 6e 6e 65 63 74 69 6f 6e 20 43 6f 6e 6e 65 63  onnection Connec
1070: 74 69 6f 6e 0d 0a 20 20 20 20 7b 0d 0a 20 20 20  tion..    {..   
1080: 20 20 20 67 65 74 20 7b 20 43 68 65 63 6b 44 69     get { CheckDi
1090: 73 70 6f 73 65 64 28 29 3b 20 72 65 74 75 72 6e  sposed(); return
10a0: 20 5f 63 6e 6e 3b 20 7d 0d 0a 20 20 20 20 7d 0d   _cnn; }..    }.
10b0: 0a 0d 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d  ...    /// <summ
10c0: 61 72 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 46 6f  ary>..    /// Fo
10d0: 72 77 61 72 64 73 20 74 6f 20 74 68 65 20 6c 6f  rwards to the lo
10e0: 63 61 6c 20 43 6f 6e 6e 65 63 74 69 6f 6e 20 70  cal Connection p
10f0: 72 6f 70 65 72 74 79 0d 0a 20 20 20 20 2f 2f 2f  roperty..    ///
1100: 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20 20 20   </summary>..   
1110: 20 70 72 6f 74 65 63 74 65 64 20 6f 76 65 72 72   protected overr
1120: 69 64 65 20 44 62 43 6f 6e 6e 65 63 74 69 6f 6e  ide DbConnection
1130: 20 44 62 43 6f 6e 6e 65 63 74 69 6f 6e 0d 0a 20   DbConnection.. 
1140: 20 20 20 7b 0d 0a 20 20 20 20 20 20 67 65 74 20     {..      get 
1150: 7b 20 72 65 74 75 72 6e 20 43 6f 6e 6e 65 63 74  { return Connect
1160: 69 6f 6e 3b 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d  ion; }..    }...
1170: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
1180: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 47 65 74 73  y>..    /// Gets
1190: 20 74 68 65 20 69 73 6f 6c 61 74 69 6f 6e 20 6c   the isolation l
11a0: 65 76 65 6c 20 6f 66 20 74 68 65 20 74 72 61 6e  evel of the tran
11b0: 73 61 63 74 69 6f 6e 2e 20 20 53 51 4c 69 74 65  saction.  SQLite
11c0: 20 6f 6e 6c 79 20 73 75 70 70 6f 72 74 73 20 53   only supports S
11d0: 65 72 69 61 6c 69 7a 61 62 6c 65 20 74 72 61 6e  erializable tran
11e0: 73 61 63 74 69 6f 6e 73 2e 0d 0a 20 20 20 20 2f  sactions...    /
11f0: 2f 2f 20 3c 2f 73 75 6d 6d 61 72 79 3e 0d 0a 20  // </summary>.. 
1200: 20 20 20 70 75 62 6c 69 63 20 6f 76 65 72 72 69     public overri
1210: 64 65 20 49 73 6f 6c 61 74 69 6f 6e 4c 65 76 65  de IsolationLeve
1220: 6c 20 49 73 6f 6c 61 74 69 6f 6e 4c 65 76 65 6c  l IsolationLevel
1230: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 67  ..    {..      g
1240: 65 74 20 7b 20 43 68 65 63 6b 44 69 73 70 6f 73  et { CheckDispos
1250: 65 64 28 29 3b 20 72 65 74 75 72 6e 20 5f 6c 65  ed(); return _le
1260: 76 65 6c 3b 20 7d 0d 0a 20 20 20 20 7d 0d 0a 0d  vel; }..    }...
1270: 0a 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72  .    /// <summar
1280: 79 3e 0d 0a 20 20 20 20 2f 2f 2f 20 52 6f 6c 6c  y>..    /// Roll
1290: 73 20 62 61 63 6b 20 74 68 65 20 61 63 74 69 76  s back the activ
12a0: 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 2e 0d 0a  e transaction...
12b0: 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d 6d 61 72      /// </summar
12c0: 79 3e 0d 0a 20 20 20 20 70 75 62 6c 69 63 20 6f  y>..    public o
12d0: 76 65 72 72 69 64 65 20 76 6f 69 64 20 52 6f 6c  verride void Rol
12e0: 6c 62 61 63 6b 28 29 0d 0a 20 20 20 20 7b 0d 0a  lback()..    {..
12f0: 20 20 20 20 20 20 43 68 65 63 6b 44 69 73 70 6f        CheckDispo
1300: 73 65 64 28 29 3b 0d 0a 20 20 20 20 20 20 53 51  sed();..      SQ
1310: 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 2e 43  LiteConnection.C
1320: 68 65 63 6b 28 5f 63 6e 6e 29 3b 0d 0a 20 20 20  heck(_cnn);..   
1330: 20 20 20 49 73 56 61 6c 69 64 28 74 72 75 65 29     IsValid(true)
1340: 3b 0d 0a 20 20 20 20 20 20 49 73 73 75 65 52 6f  ;..      IssueRo
1350: 6c 6c 62 61 63 6b 28 74 72 75 65 29 3b 0d 0a 20  llback(true);.. 
1360: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74 65     }....    inte
1370: 72 6e 61 6c 20 76 6f 69 64 20 49 73 73 75 65 52  rnal void IssueR
1380: 6f 6c 6c 62 61 63 6b 28 62 6f 6f 6c 20 74 68 72  ollback(bool thr
1390: 6f 77 45 72 72 6f 72 29 0d 0a 20 20 20 20 7b 0d  owError)..    {.
13a0: 0a 20 20 20 20 20 20 53 51 4c 69 74 65 43 6f 6e  .      SQLiteCon
13b0: 6e 65 63 74 69 6f 6e 20 63 6e 6e 20 3d 20 49 6e  nection cnn = In
13c0: 74 65 72 6c 6f 63 6b 65 64 2e 45 78 63 68 61 6e  terlocked.Exchan
13d0: 67 65 28 72 65 66 20 5f 63 6e 6e 2c 20 6e 75 6c  ge(ref _cnn, nul
13e0: 6c 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  l);....      if 
13f0: 28 63 6e 6e 20 21 3d 20 6e 75 6c 6c 29 0d 0a 20  (cnn != null).. 
1400: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
1410: 74 72 79 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a  try..        {..
1420: 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20            using 
1430: 28 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20 63  (SQLiteCommand c
1440: 6d 64 20 3d 20 63 6e 6e 2e 43 72 65 61 74 65 43  md = cnn.CreateC
1450: 6f 6d 6d 61 6e 64 28 29 29 0d 0a 20 20 20 20 20  ommand())..     
1460: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
1470: 20 20 20 20 63 6d 64 2e 43 6f 6d 6d 61 6e 64 54      cmd.CommandT
1480: 65 78 74 20 3d 20 22 52 4f 4c 4c 42 41 43 4b 22  ext = "ROLLBACK"
1490: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 63  ;..            c
14a0: 6d 64 2e 45 78 65 63 75 74 65 4e 6f 6e 51 75 65  md.ExecuteNonQue
14b0: 72 79 28 29 3b 0d 0a 20 20 20 20 20 20 20 20 20  ry();..         
14c0: 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20   }..        }.. 
14d0: 20 20 20 20 20 20 20 63 61 74 63 68 0d 0a 20 20         catch..  
14e0: 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20        {..       
14f0: 20 20 20 69 66 20 28 74 68 72 6f 77 45 72 72 6f     if (throwErro
1500: 72 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  r)..            
1510: 74 68 72 6f 77 3b 0d 0a 20 20 20 20 20 20 20 20  throw;..        
1520: 7d 0d 0a 20 20 20 20 20 20 20 20 63 6e 6e 2e 5f  }..        cnn._
1530: 74 72 61 6e 73 61 63 74 69 6f 6e 4c 65 76 65 6c  transactionLevel
1540: 20 3d 20 30 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a   = 0;..      }..
1550: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69 6e 74      }....    int
1560: 65 72 6e 61 6c 20 62 6f 6f 6c 20 49 73 56 61 6c  ernal bool IsVal
1570: 69 64 28 62 6f 6f 6c 20 74 68 72 6f 77 45 72 72  id(bool throwErr
1580: 6f 72 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  or)..    {..    
1590: 20 20 69 66 20 28 5f 63 6e 6e 20 3d 3d 20 6e 75    if (_cnn == nu
15a0: 6c 6c 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20  ll)..      {..  
15b0: 20 20 20 20 20 20 69 66 20 28 74 68 72 6f 77 45        if (throwE
15c0: 72 72 6f 72 20 3d 3d 20 74 72 75 65 29 20 74 68  rror == true) th
15d0: 72 6f 77 20 6e 65 77 20 41 72 67 75 6d 65 6e 74  row new Argument
15e0: 4e 75 6c 6c 45 78 63 65 70 74 69 6f 6e 28 22 4e  NullException("N
15f0: 6f 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 61 73 73  o connection ass
1600: 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68 69  ociated with thi
1610: 73 20 74 72 61 6e 73 61 63 74 69 6f 6e 22 29 3b  s transaction");
1620: 0d 0a 20 20 20 20 20 20 20 20 65 6c 73 65 20 72  ..        else r
1630: 65 74 75 72 6e 20 66 61 6c 73 65 3b 0d 0a 20 20  eturn false;..  
1640: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 69      }....      i
1650: 66 20 28 5f 63 6e 6e 2e 5f 76 65 72 73 69 6f 6e  f (_cnn._version
1660: 20 21 3d 20 5f 76 65 72 73 69 6f 6e 29 0d 0a 20   != _version).. 
1670: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
1680: 69 66 20 28 74 68 72 6f 77 45 72 72 6f 72 20 3d  if (throwError =
1690: 3d 20 74 72 75 65 29 20 74 68 72 6f 77 20 6e 65  = true) throw ne
16a0: 77 20 53 51 4c 69 74 65 45 78 63 65 70 74 69 6f  w SQLiteExceptio
16b0: 6e 28 22 54 68 65 20 63 6f 6e 6e 65 63 74 69 6f  n("The connectio
16c0: 6e 20 77 61 73 20 63 6c 6f 73 65 64 20 61 6e 64  n was closed and
16d0: 20 72 65 2d 6f 70 65 6e 65 64 2c 20 63 68 61 6e   re-opened, chan
16e0: 67 65 73 20 77 65 72 65 20 61 6c 72 65 61 64 79  ges were already
16f0: 20 72 6f 6c 6c 65 64 20 62 61 63 6b 22 29 3b 0d   rolled back");.
1700: 0a 20 20 20 20 20 20 20 20 65 6c 73 65 20 72 65  .        else re
1710: 74 75 72 6e 20 66 61 6c 73 65 3b 0d 0a 20 20 20  turn false;..   
1720: 20 20 20 7d 0d 0a 20 20 20 20 20 20 69 66 20 28     }..      if (
1730: 5f 63 6e 6e 2e 53 74 61 74 65 20 21 3d 20 43 6f  _cnn.State != Co
1740: 6e 6e 65 63 74 69 6f 6e 53 74 61 74 65 2e 4f 70  nnectionState.Op
1750: 65 6e 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20  en)..      {..  
1760: 20 20 20 20 20 20 69 66 20 28 74 68 72 6f 77 45        if (throwE
1770: 72 72 6f 72 20 3d 3d 20 74 72 75 65 29 20 74 68  rror == true) th
1780: 72 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78  row new SQLiteEx
1790: 63 65 70 74 69 6f 6e 28 22 43 6f 6e 6e 65 63 74  ception("Connect
17a0: 69 6f 6e 20 77 61 73 20 63 6c 6f 73 65 64 22 29  ion was closed")
17b0: 3b 0d 0a 20 20 20 20 20 20 20 20 65 6c 73 65 20  ;..        else 
17c0: 72 65 74 75 72 6e 20 66 61 6c 73 65 3b 0d 0a 20  return false;.. 
17d0: 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20       }....      
17e0: 69 66 20 28 5f 63 6e 6e 2e 5f 74 72 61 6e 73 61  if (_cnn._transa
17f0: 63 74 69 6f 6e 4c 65 76 65 6c 20 3d 3d 20 30 20  ctionLevel == 0 
1800: 7c 7c 20 5f 63 6e 6e 2e 5f 73 71 6c 2e 41 75 74  || _cnn._sql.Aut
1810: 6f 43 6f 6d 6d 69 74 20 3d 3d 20 74 72 75 65 29  oCommit == true)
1820: 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20  ..      {..     
1830: 20 20 20 5f 63 6e 6e 2e 5f 74 72 61 6e 73 61 63     _cnn._transac
1840: 74 69 6f 6e 4c 65 76 65 6c 20 3d 20 30 3b 20 2f  tionLevel = 0; /
1850: 2f 20 4d 61 6b 65 20 73 75 72 65 20 74 68 65 20  / Make sure the 
1860: 74 72 61 6e 73 61 63 74 69 6f 6e 20 6c 65 76 65  transaction leve
1870: 6c 20 69 73 20 72 65 73 65 74 20 62 65 66 6f 72  l is reset befor
1880: 65 20 72 65 74 75 72 6e 69 6e 67 0d 0a 20 20 20  e returning..   
1890: 20 20 20 20 20 69 66 20 28 74 68 72 6f 77 45 72       if (throwEr
18a0: 72 6f 72 20 3d 3d 20 74 72 75 65 29 20 74 68 72  ror == true) thr
18b0: 6f 77 20 6e 65 77 20 53 51 4c 69 74 65 45 78 63  ow new SQLiteExc
18c0: 65 70 74 69 6f 6e 28 22 4e 6f 20 74 72 61 6e 73  eption("No trans
18d0: 61 63 74 69 6f 6e 20 69 73 20 61 63 74 69 76 65  action is active
18e0: 20 6f 6e 20 74 68 69 73 20 63 6f 6e 6e 65 63 74   on this connect
18f0: 69 6f 6e 22 29 3b 0d 0a 20 20 20 20 20 20 20 20  ion");..        
1900: 65 6c 73 65 20 72 65 74 75 72 6e 20 66 61 6c 73  else return fals
1910: 65 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 0d 0a 20  e;..      }.... 
1920: 20 20 20 20 20 72 65 74 75 72 6e 20 74 72 75 65       return true
1930: 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 7d  ;..    }..  }..}
1940: 0d 0a                                            ..