/usr/include/ETL/_mutex_win32.h is in etl-dev 0.04.19-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | /*! ========================================================================
** Extended Template and Library
** Mutex Abstraction Class Implementation
** $Id$
**
** Copyright (c) 2002 Robert B. Quattlebaum Jr.
**
** This package 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 package 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.
**
** === N O T E S ===========================================================
**
** This is an internal header file, included by other ETL headers.
** You should not attempt to use it directly.
**
** ========================================================================= */
/* === S T A R T =========================================================== */
#ifndef __ETL__MUTEX_WIN32_H_
#define __ETL__MUTEX_WIN32_H_
/* === H E A D E R S ======================================================= */
#include <windows.h>
// extern HANDLE CreateMutex(NULL, FALSE, NULL);
// extern CloseHandle(handle);
// extern WaitForSingleObject(handle, INFINITE);
// extern ReleaseMutex(handle);
/* === M A C R O S ========================================================= */
/* === C L A S S E S & S T R U C T S ======================================= */
_ETL_BEGIN_NAMESPACE
class mutex
{
HANDLE handle;
public:
mutex()
{ handle = CreateMutex(NULL, FALSE, NULL); }
~mutex()
{ CloseHandle(handle); }
//! Exception-safe mutex lock class
class lock
{
mutex *_mtx;
public:
lock(mutex &x):_mtx(&x) { _mtx->lock_mutex(); }
~lock() { _mtx->unlock_mutex(); }
mutex &get() { return *_mtx; }
};
void lock_mutex(void)
{ WaitForSingleObject(handle, INFINITE); }
bool try_lock_mutex(void)
{ return WaitForSingleObject(handle, INFINITE)==WAIT_FAILED; }
void unlock_mutex(void)
{ ReleaseMutex(handle); }
};
_ETL_END_NAMESPACE
/* === E X T E R N S ======================================================= */
/* === E N D =============================================================== */
#endif
|