From 47e1f28f1fe9fecf969d63f059b8ec8c0184605e Mon Sep 17 00:00:00 2001 From: Bent Bisballe Nyeng Date: Fri, 22 Mar 2013 22:42:05 +0100 Subject: Added Engine->Messageing system. Implemented LoadStatus Message. Added ProgressBar widget. Made FileBrowser chdir to old value (needs further fixing). More printf->hugin ports. --- src/drumgizmo.cc | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) (limited to 'src/drumgizmo.cc') diff --git a/src/drumgizmo.cc b/src/drumgizmo.cc index 93426de..e8ced6a 100644 --- a/src/drumgizmo.cc +++ b/src/drumgizmo.cc @@ -39,7 +39,7 @@ #include "drumkitparser.h" DrumGizmo::DrumGizmo(AudioOutputEngine *o, AudioInputEngine *i) - : oe(o), ie(i) + : loader(this), oe(o), ie(i) { loader.run(); // Start drumkit loader thread. } @@ -57,13 +57,12 @@ DrumGizmo::~DrumGizmo() } /* - * Send a message to the engine. The engine takes over the memory. + * Add a message to the GUI message queue. */ void DrumGizmo::sendMessage(Message *msg) { - message_mutex.lock(); + MutexAutolock l(message_mutex); message_queue.push_back(msg); - message_mutex.unlock(); } /* @@ -71,13 +70,25 @@ void DrumGizmo::sendMessage(Message *msg) */ Message *DrumGizmo::receiveMessage() { + MutexAutolock l(message_mutex); Message *msg = NULL; - message_mutex.lock(); if(message_queue.size()) { msg = message_queue.front(); message_queue.pop_front(); } - message_mutex.unlock(); + return msg; +} + +/* + * Receive message from the engine without removing it from the queue. + */ +Message *DrumGizmo::peekMessage() +{ + MutexAutolock l(message_mutex); + Message *msg = NULL; + if(message_queue.size()) { + msg = message_queue.front(); + } return msg; } -- cgit v1.2.3