aboutsummaryrefslogtreecommitdiff
path: root/src/MusicBuffer.cxx
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2013-01-04 20:50:26 +0100
committerMax Kellermann <max@duempel.org>2013-01-04 21:24:29 +0100
commitefbfe66f21a8865454bc7a9e32305c84c09ba4be (patch)
tree7ea7b79cba8e3356c7735ef98bd251ca513d4ade /src/MusicBuffer.cxx
parent6886063703704796f03d7bfe35747fc2cb01ded2 (diff)
Mutex: new wrapper for std::mutex, replaces GMutex
Diffstat (limited to 'src/MusicBuffer.cxx')
-rw-r--r--src/MusicBuffer.cxx22
1 files changed, 6 insertions, 16 deletions
diff --git a/src/MusicBuffer.cxx b/src/MusicBuffer.cxx
index 5fddddc2..ea03fc0b 100644
--- a/src/MusicBuffer.cxx
+++ b/src/MusicBuffer.cxx
@@ -20,27 +20,21 @@
#include "config.h"
#include "MusicBuffer.hxx"
#include "MusicChunk.hxx"
+#include "thread/Mutex.hxx"
#include "util/SliceBuffer.hxx"
#include "mpd_error.h"
-#include <glib.h>
-
#include <assert.h>
struct music_buffer : public SliceBuffer<music_chunk> {
/** a mutex which protects #available */
- GMutex *mutex;
+ Mutex mutex;
music_buffer(unsigned num_chunks)
- :SliceBuffer(num_chunks),
- mutex(g_mutex_new()) {
+ :SliceBuffer(num_chunks) {
if (IsOOM())
MPD_ERROR("Failed to allocate buffer");
}
-
- ~music_buffer() {
- g_mutex_free(mutex);
- }
};
struct music_buffer *
@@ -64,10 +58,8 @@ music_buffer_size(const struct music_buffer *buffer)
struct music_chunk *
music_buffer_allocate(struct music_buffer *buffer)
{
- g_mutex_lock(buffer->mutex);
- struct music_chunk *chunk = buffer->Allocate();
- g_mutex_unlock(buffer->mutex);
- return chunk;
+ const ScopeLock protect(buffer->mutex);
+ return buffer->Allocate();
}
void
@@ -76,7 +68,7 @@ music_buffer_return(struct music_buffer *buffer, struct music_chunk *chunk)
assert(buffer != NULL);
assert(chunk != NULL);
- g_mutex_lock(buffer->mutex);
+ const ScopeLock protect(buffer->mutex);
if (chunk->other != nullptr) {
assert(chunk->other->other == nullptr);
@@ -84,6 +76,4 @@ music_buffer_return(struct music_buffer *buffer, struct music_chunk *chunk)
}
buffer->Free(chunk);
-
- g_mutex_unlock(buffer->mutex);
}