ManagedConnection.cs 2.2 KB

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