ManagedConnection.cs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. #pragma warning disable CS1591
  2. #pragma warning disable SA1600
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Threading;
  6. using SQLitePCL.pretty;
  7. namespace Emby.Server.Implementations.Data
  8. {
  9. public class ManagedConnection : IDisposable
  10. {
  11. private SQLiteDatabaseConnection _db;
  12. private readonly SemaphoreSlim _writeLock;
  13. private bool _disposed = false;
  14. public ManagedConnection(SQLiteDatabaseConnection db, SemaphoreSlim writeLock)
  15. {
  16. _db = db;
  17. _writeLock = writeLock;
  18. }
  19. public IStatement PrepareStatement(string sql)
  20. {
  21. return _db.PrepareStatement(sql);
  22. }
  23. public IEnumerable<IStatement> PrepareAll(string sql)
  24. {
  25. return _db.PrepareAll(sql);
  26. }
  27. public void ExecuteAll(string sql)
  28. {
  29. _db.ExecuteAll(sql);
  30. }
  31. public void Execute(string sql, params object[] values)
  32. {
  33. _db.Execute(sql, values);
  34. }
  35. public void RunQueries(string[] sql)
  36. {
  37. _db.RunQueries(sql);
  38. }
  39. public void RunInTransaction(Action<IDatabaseConnection> action, TransactionMode mode)
  40. {
  41. _db.RunInTransaction(action, mode);
  42. }
  43. public T RunInTransaction<T>(Func<IDatabaseConnection, T> action, TransactionMode mode)
  44. {
  45. return _db.RunInTransaction(action, mode);
  46. }
  47. public IEnumerable<IReadOnlyList<IResultSetValue>> Query(string sql)
  48. {
  49. return _db.Query(sql);
  50. }
  51. public IEnumerable<IReadOnlyList<IResultSetValue>> Query(string sql, params object[] values)
  52. {
  53. return _db.Query(sql, values);
  54. }
  55. public void Dispose()
  56. {
  57. if (_disposed)
  58. {
  59. return;
  60. }
  61. _writeLock.Release();
  62. _db = null; // Don't dispose it
  63. _disposed = true;
  64. }
  65. }
  66. }