From 10ce121dbd05e048c89a2b7c32f2ddabbc8fbe77 Mon Sep 17 00:00:00 2001 From: Chris Robinson Date: Sat, 22 Dec 2018 11:38:38 -0800 Subject: Use a normal delete instead of ll_ringbuffer_free And use RingBufferPtr in more places --- Alc/backends/wasapi.cpp | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) (limited to 'Alc/backends/wasapi.cpp') diff --git a/Alc/backends/wasapi.cpp b/Alc/backends/wasapi.cpp index 79e4af04..3f8cad23 100644 --- a/Alc/backends/wasapi.cpp +++ b/Alc/backends/wasapi.cpp @@ -1172,7 +1172,7 @@ struct ALCwasapiCapture final : public ALCbackend, WasapiProxy { ChannelConverter *mChannelConv{nullptr}; SampleConverter *mSampleConv{nullptr}; - ll_ringbuffer_t *mRing{nullptr}; + RingBufferPtr mRing{nullptr}; std::atomic mKillNow{AL_TRUE}; std::thread mThread; @@ -1220,9 +1220,6 @@ void ALCwasapiCapture_Destruct(ALCwasapiCapture *self) CloseHandle(self->mNotifyEvent); self->mNotifyEvent = nullptr; - ll_ringbuffer_free(self->mRing); - self->mRing = nullptr; - DestroySampleConverter(&self->mSampleConv); DestroyChannelConverter(&self->mChannelConv); @@ -1275,7 +1272,7 @@ FORCE_ALIGN int ALCwasapiCapture_recordProc(ALCwasapiCapture *self) rdata = reinterpret_cast(samples.data()); } - auto data = ll_ringbuffer_get_write_vector(self->mRing); + auto data = ll_ringbuffer_get_write_vector(self->mRing.get()); size_t dstframes; if(self->mSampleConv) @@ -1311,7 +1308,7 @@ FORCE_ALIGN int ALCwasapiCapture_recordProc(ALCwasapiCapture *self) dstframes = len1 + len2; } - ll_ringbuffer_write_advance(self->mRing, dstframes); + ll_ringbuffer_write_advance(self->mRing.get(), dstframes); hr = capture->ReleaseBuffer(numsamples); if(FAILED(hr)) ERR("Failed to release capture buffer: 0x%08lx\n", hr); @@ -1696,8 +1693,7 @@ HRESULT ALCwasapiCapture::resetProxy() } buffer_len = maxu(device->UpdateSize*device->NumUpdates, buffer_len); - ll_ringbuffer_free(mRing); - mRing = ll_ringbuffer_create(buffer_len, device->frameSizeFromFmt(), false); + mRing.reset(ll_ringbuffer_create(buffer_len, device->frameSizeFromFmt(), false)); if(!mRing) { ERR("Failed to allocate capture ring buffer\n"); @@ -1790,14 +1786,12 @@ void ALCwasapiCapture::stopProxy() ALuint ALCwasapiCapture_availableSamples(ALCwasapiCapture *self) { - return (ALuint)ll_ringbuffer_read_space(self->mRing); + return (ALuint)ll_ringbuffer_read_space(self->mRing.get()); } ALCenum ALCwasapiCapture_captureSamples(ALCwasapiCapture *self, ALCvoid *buffer, ALCuint samples) { - if(ALCwasapiCapture_availableSamples(self) < samples) - return ALC_INVALID_VALUE; - ll_ringbuffer_read(self->mRing, reinterpret_cast(buffer), samples); + ll_ringbuffer_read(self->mRing.get(), reinterpret_cast(buffer), samples); return ALC_NO_ERROR; } -- cgit v1.2.3