diff options
Diffstat (limited to 'extern/audaspace/src')
-rw-r--r-- | extern/audaspace/src/devices/SoftwareDevice.cpp | 6 | ||||
-rw-r--r-- | extern/audaspace/src/devices/ThreadedDevice.cpp | 65 |
2 files changed, 68 insertions, 3 deletions
diff --git a/extern/audaspace/src/devices/SoftwareDevice.cpp b/extern/audaspace/src/devices/SoftwareDevice.cpp index c8c1c6081c2..7a2561515f4 100644 --- a/extern/audaspace/src/devices/SoftwareDevice.cpp +++ b/extern/audaspace/src/devices/SoftwareDevice.cpp @@ -737,7 +737,7 @@ void SoftwareDevice::mix(data_t* buffer, int length) { m_buffer.assureSize(length * AUD_SAMPLE_SIZE(m_specs)); - std::lock_guard<std::recursive_mutex> lock(m_mutex); + std::lock_guard<ILockable> lock(*this); { std::shared_ptr<SoftwareDevice::SoftwareHandle> sound; @@ -880,7 +880,7 @@ std::shared_ptr<IHandle> SoftwareDevice::play(std::shared_ptr<IReader> reader, b // play sound std::shared_ptr<SoftwareDevice::SoftwareHandle> sound = std::shared_ptr<SoftwareDevice::SoftwareHandle>(new SoftwareDevice::SoftwareHandle(this, reader, pitch, resampler, mapper, keep)); - std::lock_guard<std::recursive_mutex> lock(m_mutex); + std::lock_guard<ILockable> lock(*this); m_playingSounds.push_back(sound); @@ -897,7 +897,7 @@ std::shared_ptr<IHandle> SoftwareDevice::play(std::shared_ptr<ISound> sound, boo void SoftwareDevice::stopAll() { - std::lock_guard<std::recursive_mutex> lock(m_mutex); + std::lock_guard<ILockable> lock(*this); while(!m_playingSounds.empty()) m_playingSounds.front()->stop(); diff --git a/extern/audaspace/src/devices/ThreadedDevice.cpp b/extern/audaspace/src/devices/ThreadedDevice.cpp new file mode 100644 index 00000000000..44ceccb8a60 --- /dev/null +++ b/extern/audaspace/src/devices/ThreadedDevice.cpp @@ -0,0 +1,65 @@ +/******************************************************************************* + * Copyright 2009-2016 Jörg Müller + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + ******************************************************************************/ + +#include "devices/ThreadedDevice.h" + +#include <mutex> + +AUD_NAMESPACE_BEGIN + +void ThreadedDevice::start() +{ + std::lock_guard<ILockable> lock(*this); + + // thread is still running, we can abort stopping it + if(m_stop) + m_stop = false; + + // thread is not running, let's start it + else if(!m_playing) + { + if(m_thread.joinable()) + m_thread.join(); + + m_playing = true; + + m_thread = std::thread(&ThreadedDevice::runMixingThread, this); + } +} + +void ThreadedDevice::playing(bool playing) +{ + if((!m_playing || m_stop) && playing) + start(); + else + m_stop = true; +} + +ThreadedDevice::ThreadedDevice() : + m_playing(false), + m_stop(false) +{ +} + +void aud::ThreadedDevice::stopMixingThread() +{ + stopAll(); + + if(m_thread.joinable()) + m_thread.join(); +} + +AUD_NAMESPACE_END |