UserSampleQueue.cpp 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /*
  2. * Copyright (c) 2022, kleines Filmröllchen <filmroellchen@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include "UserSampleQueue.h"
  7. namespace Audio {
  8. void UserSampleQueue::append(FixedArray<Sample>&& samples)
  9. {
  10. Threading::MutexLocker lock(m_sample_mutex);
  11. if (m_samples_to_discard != 0)
  12. m_backing_samples = m_backing_samples.release_slice(m_samples_to_discard);
  13. m_backing_samples.append(move(samples));
  14. fix_spans();
  15. }
  16. void UserSampleQueue::clear()
  17. {
  18. discard_samples(size());
  19. }
  20. void UserSampleQueue::fix_spans()
  21. {
  22. Threading::MutexLocker lock(m_sample_mutex);
  23. m_enqueued_samples = m_backing_samples.spans();
  24. m_samples_to_discard = 0;
  25. }
  26. Sample UserSampleQueue::operator[](size_t index)
  27. {
  28. Threading::MutexLocker lock(m_sample_mutex);
  29. return m_enqueued_samples[index];
  30. }
  31. void UserSampleQueue::discard_samples(size_t count)
  32. {
  33. Threading::MutexLocker lock(m_sample_mutex);
  34. m_samples_to_discard += count;
  35. m_enqueued_samples = m_enqueued_samples.slice(count);
  36. }
  37. size_t UserSampleQueue::size()
  38. {
  39. Threading::MutexLocker lock(m_sample_mutex);
  40. return m_enqueued_samples.size();
  41. }
  42. size_t UserSampleQueue::remaining_samples()
  43. {
  44. Threading::MutexLocker lock(m_sample_mutex);
  45. VERIFY(m_backing_samples.size() >= m_samples_to_discard);
  46. return m_backing_samples.size() - m_samples_to_discard;
  47. }
  48. bool UserSampleQueue::is_empty()
  49. {
  50. Threading::MutexLocker lock(m_sample_mutex);
  51. return m_enqueued_samples.is_empty();
  52. }
  53. }