using System; using System.Collections.Generic; using System.Threading; using SQLitePCL.pretty; namespace Emby.Server.Implementations.Data { public class ManagedConnection : IDisposable { private SQLiteDatabaseConnection _db; private readonly SemaphoreSlim _writeLock; private bool _disposed = false; public ManagedConnection(SQLiteDatabaseConnection db, SemaphoreSlim writeLock) { _db = db; _writeLock = writeLock; } public IStatement PrepareStatement(string sql) { return _db.PrepareStatement(sql); } public IEnumerable<IStatement> PrepareAll(string sql) { return _db.PrepareAll(sql); } public void ExecuteAll(string sql) { _db.ExecuteAll(sql); } public void Execute(string sql, params object[] values) { _db.Execute(sql, values); } public void RunQueries(string[] sql) { _db.RunQueries(sql); } public void RunInTransaction(Action<IDatabaseConnection> action, TransactionMode mode) { _db.RunInTransaction(action, mode); } public T RunInTransaction<T>(Func<IDatabaseConnection, T> action, TransactionMode mode) { return _db.RunInTransaction(action, mode); } public IEnumerable<IReadOnlyList<IResultSetValue>> Query(string sql) { return _db.Query(sql); } public IEnumerable<IReadOnlyList<IResultSetValue>> Query(string sql, params object[] values) { return _db.Query(sql, values); } public void Dispose() { if (_disposed) { return; } _writeLock.Release(); _db = null; // Don't dispose it _disposed = true; } } }