diff options
author | Max Horn | 2005-01-15 22:41:23 +0000 |
---|---|---|
committer | Max Horn | 2005-01-15 22:41:23 +0000 |
commit | 541076d8dbce579f1a47b5f181502a1e7f7708cc (patch) | |
tree | d59596f75083e78cecb6b13a643319869d268dca /common | |
parent | 2d2cef23a02cd5cfca4246da30001f545efcd10a (diff) | |
download | scummvm-rg350-541076d8dbce579f1a47b5f181502a1e7f7708cc.tar.gz scummvm-rg350-541076d8dbce579f1a47b5f181502a1e7f7708cc.tar.bz2 scummvm-rg350-541076d8dbce579f1a47b5f181502a1e7f7708cc.zip |
Added a convenience class 'Mutex'
svn-id: r16566
Diffstat (limited to 'common')
-rw-r--r-- | common/module.mk | 1 | ||||
-rw-r--r-- | common/mutex.cpp | 76 | ||||
-rw-r--r-- | common/mutex.h | 22 |
3 files changed, 98 insertions, 1 deletions
diff --git a/common/module.mk b/common/module.mk index ba51fb1267..1a7b47a73e 100644 --- a/common/module.mk +++ b/common/module.mk @@ -4,6 +4,7 @@ MODULE_OBJS := \ common/config-manager.o \ common/file.o \ common/md5.o \ + common/mutex.o \ common/str.o \ common/stream.o \ common/timer.o \ diff --git a/common/mutex.cpp b/common/mutex.cpp new file mode 100644 index 0000000000..b98ee91344 --- /dev/null +++ b/common/mutex.cpp @@ -0,0 +1,76 @@ +/* ScummVM - Scumm Interpreter + * Copyright (C) 2003-2005 The ScummVM project + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * + * $Header$ + * + */ + +#include "stdafx.h" +#include "common/mutex.h" +#include "common/system.h" + +namespace Common { + +Mutex::Mutex() { + _mutex = g_system->createMutex(); +} + +Mutex::~Mutex() { + g_system->deleteMutex(_mutex); +} + +void Mutex::lock() { + g_system->lockMutex(_mutex); +} + +void Mutex::unlock() { + g_system->unlockMutex(_mutex); +} + + +#pragma mark - + + +StackLock::StackLock(OSystem::MutexRef mutex, const char *mutexName) + : _mutex(mutex), _mutexName(mutexName) { + lock(); +} + +StackLock::StackLock(const Mutex &mutex, const char *mutexName) + : _mutex(mutex._mutex), _mutexName(mutexName) { + lock(); +} + +StackLock::~StackLock() { + unlock(); +} + +void StackLock::lock() { + if (_mutexName != NULL) + debug(6, "Locking mutex %s", _mutexName); + + g_system->lockMutex(_mutex); +} + +void StackLock::unlock() { + if (_mutexName != NULL) + debug(6, "Unlocking mutex %s", _mutexName); + + g_system->unlockMutex(_mutex); +} + +} // End of namespace Common diff --git a/common/mutex.h b/common/mutex.h index 6b7ba55851..cdb52f394b 100644 --- a/common/mutex.h +++ b/common/mutex.h @@ -26,10 +26,12 @@ namespace Common { +class Mutex; + /** * An pseudo-opaque mutex type. See OSystem::createMutex etc. for more details. */ -typedef struct Mutex *MutexRef; +typedef struct OpaqueMutex *MutexRef; /** @@ -43,10 +45,28 @@ class StackLock { void unlock(); public: StackLock(MutexRef mutex, const char *mutexName = NULL); + StackLock(const Mutex &mutex, const char *mutexName = NULL); ~StackLock(); }; +/** + * Wrapper class around the OSystem mutex functions. + */ +class Mutex { + friend class StackLock; + + MutexRef _mutex; + +public: + Mutex(); + ~Mutex(); + + void lock(); + void unlock(); +}; + + } // End of namespace Common #endif |