/usr/include/ptlib/mutex.h is in libpt-dev 2.10.11~dfsg-2.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 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 | /*
* mutex.h
*
* Mutual exclusion thread synchonisation class.
*
* Portable Windows Library
*
* Copyright (c) 1993-1998 Equivalence Pty. Ltd.
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is Portable Windows Library.
*
* The Initial Developer of the Original Code is Equivalence Pty. Ltd.
*
* Portions are Copyright (C) 1993 Free Software Foundation, Inc.
* All Rights Reserved.
*
* Contributor(s): ______________________________________.
*
* $Revision: 24177 $
* $Author: rjongbloed $
* $Date: 2010-04-05 06:52:04 -0500 (Mon, 05 Apr 2010) $
*/
#ifndef PTLIB_MUTEX_H
#define PTLIB_MUTEX_H
#ifdef P_USE_PRAGMA
#pragma interface
#endif
#include <ptlib/critsec.h>
#include <ptlib/semaphor.h>
/**This class defines a thread mutual exclusion object. A mutex is where a
piece of code or data cannot be accessed by more than one thread at a time.
To prevent this the PMutex is used in the following manner:
<pre><code>
PMutex mutex;
...
mutex.Wait();
... critical section - only one thread at a time here.
mutex.Signal();
...
</code></pre>
The first thread will pass through the <code>Wait()</code> function, a second
thread will block on that function until the first calls the
<code>Signal()</code> function, releasing the second thread.
*/
/*
* On Windows, It is convenient for PTimedMutex to be an ancestor of PSemaphore
* But that is the only platform where it is - every other platform (i.e. Unix)
* uses different constructs for these objects, so there is no need for a PTimedMute
* to carry around all of the PSemaphore members
*/
#ifdef _WIN32
class PTimedMutex : public PSemaphore
{
PCLASSINFO(PTimedMutex, PSemaphore);
#else
class PTimedMutex : public PSync
{
PCLASSINFO(PTimedMutex, PSync)
#endif
public:
/* Create a new mutex.
Initially the mutex will not be "set", so the first call to Wait() will
never wait.
*/
PTimedMutex();
PTimedMutex(const PTimedMutex & mutex);
/** Try to enter the critical section for exlusive access. Does not wait.
@return true if cirical section entered, leave/Signal must be called.
*/
PINLINE bool Try() { return Wait(0); }
// Include platform dependent part of class
#ifdef _WIN32
#include "msos/ptlib/mutex.h"
#else
#include "unix/ptlib/mutex.h"
#endif
};
// On Windows, critical sections are recursive and so we can use them for mutexes
// The only Posix mutex that is recursive is pthread_mutex, so we have to use that
#ifdef _WIN32
/** \class PMutex
Synonym for PCriticalSection
*/
typedef PCriticalSection PMutex;
#else
/** \class PMutex
Synonym for PTimedMutex
*/
typedef PTimedMutex PMutex;
#define PCriticalSection PTimedMutex
#endif
#endif // PTLIB_MUTEX_H
// End Of File ///////////////////////////////////////////////////////////////
|