/* ====================================================================
* Copyright (c) 2003-2006, The Subcommander Crew
* http://subcommander.tigris.org
*
* Subcommander is licensed as described in the file doc/COPYING, which
* you should have received as part of this distribution.
* ====================================================================
*/
// sc
#include "Mutex.h"
// apr
#include <apr_thread_mutex.h>
namespace sc
{
/**
* Create mutex.
* We use an unnested mutex. Although this is slower on Win32, recursive mutexes have not proven
* to ease debugging. If a recursive mutex is required this may be a sign of a design problem.
*/
Mutex::Mutex()
{
apr_thread_mutex_create( &_mutex, APR_THREAD_MUTEX_UNNESTED, _pool );
}
Mutex::~Mutex()
{
apr_thread_mutex_destroy(_mutex);
}
void Mutex::lock()
{
apr_thread_mutex_lock(_mutex);
}
void Mutex::unlock()
{
apr_thread_mutex_unlock(_mutex);
}
} // namespace
syntax highlighted by Code2HTML, v. 0.9.1