using System.Collections.Concurrent;
using System.Collections.Generic;
namespace Ryujinx.Audio
{
///
/// A Dummy audio renderer that does not output any audio
///
public class DummyAudioOut : IAalOutput
{
private int lastTrackId = 1;
private ConcurrentQueue m_TrackIds;
private ConcurrentQueue m_Buffers;
private ConcurrentDictionary m_ReleaseCallbacks;
public DummyAudioOut()
{
m_Buffers = new ConcurrentQueue();
m_TrackIds = new ConcurrentQueue();
m_ReleaseCallbacks = new ConcurrentDictionary();
}
///
/// Dummy audio output is always available, Baka!
///
public static bool IsSupported => true;
public PlaybackState GetState(int trackId) => PlaybackState.Stopped;
public int OpenTrack(int sampleRate, int channels, ReleaseCallback callback)
{
int trackId;
if (!m_TrackIds.TryDequeue(out trackId))
{
trackId = ++lastTrackId;
}
m_ReleaseCallbacks[trackId] = callback;
return trackId;
}
public void CloseTrack(int trackId)
{
m_TrackIds.Enqueue(trackId);
m_ReleaseCallbacks.Remove(trackId, out _);
}
public void Start(int trackId) { }
public void Stop(int trackId) { }
public void AppendBuffer(int trackID, long bufferTag, T[] buffer)
where T : struct
{
m_Buffers.Enqueue(bufferTag);
if (m_ReleaseCallbacks.TryGetValue(trackID, out var callback))
{
callback?.Invoke();
}
}
public long[] GetReleasedBuffers(int trackId, int maxCount)
{
List bufferTags = new List();
for (int i = 0; i < maxCount; i++)
{
if (!m_Buffers.TryDequeue(out long tag))
{
break;
}
bufferTags.Add(tag);
}
return bufferTags.ToArray();
}
public bool ContainsBuffer(int trackID, long bufferTag) => false;
public void Dispose()
{
m_Buffers.Clear();
}
}
}