From 97a0767c6dfcc49b4dfc611230a0edee4687a226 Mon Sep 17 00:00:00 2001 From: elgiano Date: Sat, 4 Dec 2021 02:59:57 +0100 Subject: [PATCH] fix missing bufData check --- plugins/XPlayBuf/XPlayBuf.cpp | 56 +++++++++++++++++------------------ 1 file changed, 27 insertions(+), 29 deletions(-) diff --git a/plugins/XPlayBuf/XPlayBuf.cpp b/plugins/XPlayBuf/XPlayBuf.cpp index 66131e3..ac29df7 100644 --- a/plugins/XPlayBuf/XPlayBuf.cpp +++ b/plugins/XPlayBuf/XPlayBuf.cpp @@ -328,10 +328,7 @@ bool XPlayBuf::getBuf(int nSamples) { float fbufnum = in0(UGenInput::bufnum); if (fbufnum < 0.f) fbufnum = 0.f; - if (fbufnum == m_fbufnum) { - ACQUIRE_SNDBUF_SHARED(m_buf); - return true; - } else { + if (fbufnum != m_fbufnum) { uint32 bufnum = static_cast(fbufnum); if (bufnum >= mWorld->mNumSndBufs) { int localBufNum = bufnum - mWorld->mNumSndBufs; @@ -340,35 +337,36 @@ bool XPlayBuf::getBuf(int nSamples) { } else { m_buf = mWorld->mSndBufs; } - } else { + } else { m_buf = mWorld->mSndBufs + bufnum; - } - m_fbufnum = fbufnum; + } + m_fbufnum = fbufnum; - ACQUIRE_SNDBUF_SHARED(m_buf); + // store these two to simplify code in other ::next and ::writeFrame + m_numWriteChannels = sc_min(mNumOutputs, m_buf->channels); + m_bufFrames = m_buf->frames; + m_guardFrame = static_cast(m_bufFrames - 2); + } - if (!m_buf->data) { - if (mWorld->mVerbosity > -1 && !mDone && (m_failedBufNum != fbufnum)) { - Print("Buffer UGen: no buffer data\n"); - m_failedBufNum = fbufnum; - } - return false; - } else { - if (m_buf->channels != mNumOutputs) { - if (mWorld->mVerbosity > -1 && !mDone && (m_failedBufNum != fbufnum)) { - Print("Buffer UGen channel mismatch: expected %i, yet buffer has %i " - "channels\n", - mNumOutputs, m_buf->channels); - m_failedBufNum = fbufnum; - } - } - // store these two to simplify code in other ::next and ::writeFrame - m_numWriteChannels = sc_min(mNumOutputs, m_buf->channels); - m_bufFrames = m_buf->frames; - m_guardFrame = static_cast(m_bufFrames - 2); - } + ACQUIRE_SNDBUF_SHARED(m_buf); - return true; + // CHECK_BUFFER_DATA + if (!m_buf->data) { + if (mWorld->mVerbosity > -1 && !mDone && (m_failedBufNum != fbufnum)) { + Print("Buffer UGen: no buffer data\n"); + m_failedBufNum = fbufnum; + } + return false; + } else { + if (m_buf->channels != mNumOutputs) { + if (mWorld->mVerbosity > -1 && !mDone && (m_failedBufNum != fbufnum)) { + Print("Buffer UGen channel mismatch: expected %i, yet buffer has %i " + "channels\n", + mNumOutputs, m_buf->channels); + m_failedBufNum = fbufnum; + } + } + return true; } }