/usr/include/cxxtools/condition.h is in libcxxtools-dev 2.0-4ubuntu2.
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 | /*
* Copyright (C) 2006-2008 by Marc Boris Duerner
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* As a special exception, you may use this file as part of a free
* software library without restriction. Specifically, if other files
* instantiate templates or use macros or inline functions from this
* file, or you compile this file and link it with other files to
* produce an executable, this file does not by itself cause the
* resulting executable to be covered by the GNU General Public
* License. This exception does not however invalidate any other
* reasons why the executable file might be covered by the GNU Library
* General Public License.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef CXXTOOLS_SYSTEM_CONDITION_H
#define CXXTOOLS_SYSTEM_CONDITION_H
#include <cxxtools/api.h>
#include <cxxtools/noncopyable.h>
#include <cxxtools/mutex.h>
#include <cstddef>
namespace cxxtools {
/** @brief This class is used to control concurrent access.
The Condition class is used to control concurrent access in a queued
manner. The Condition class supports two types of signaling events,
manual reset and automatic reset.
Manual resets cause all blocked callers to be released. This can be
understood as some kind of broadcast to signal all blocked callers at
once. Manual resets are triggered by a call to signal().
Automatic resets cause only a single blocked caller to be released.
So this can be seen as some kind of wait queue where only the topmost
is signaled. Automatic resets are signaled by a call to broadcast().
*/
class CXXTOOLS_API Condition : private NonCopyable
{
public:
//! @brief Default Constructor.
Condition();
//! @brief Destructor.
~Condition();
/** @brief Wait until condition becomes signalled.
Causes the caller to be suspended until the condition will be
signaled. The given mutex will be unlocked before the caller
is suspended.
*/
void wait( Mutex& mtx);
void wait( MutexLock& m)
{ this->wait( m.mutex() ); }
/** @brief Wait until condition becomes signalled.
Causes the caller to be suspended until the condition will be
signaled. The given mutex will be unlocked before the caller
is suspended. The suspension takes at maximum ms milliseconds.
Returns true if successful, false if a timeout occurred.
*/
bool wait( Mutex& mtx, unsigned int ms);
bool wait( MutexLock& m, unsigned int ms)
{ return this->wait( m.mutex(), ms ); }
//! @brief Unblock a single blocked thread.
void signal();
//! @brief Unblock all blocked threads.
void broadcast();
private:
class ConditionImpl* _impl;
};
} // !namespace cxxtools
#endif
|