/usr/include/terralib/kernel/TeThreadSignal.h is in libterralib-dev 4.3.0+dfsg.2-11.
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 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 | /************************************************************************************
TerraLib - a library for developing GIS applications.
Copyright � 2001-2007 INPE and Tecgraf/PUC-Rio.
This code is part of the TerraLib library.
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.
You should have received a copy of the GNU Lesser General Public
License along with this library.
The authors reassure the license terms regarding the warranties.
They specifically disclaim any warranties, including, but not limited to,
the implied warranties of merchantability and fitness for a particular purpose.
The library provided hereunder is on an "as is" basis, and the authors have no
obligation to provide maintenance, support, updates, enhancements, or modifications.
In no event shall INPE and Tecgraf / PUC-Rio be held liable to any party for direct,
indirect, special, incidental, or consequential damages arising out of the use
of this library and its documentation.
*************************************************************************************/
/*! \file TeThreadSignal.h
\brief This file contains definitions about a class to deal thread
signals.
*/
#ifndef TETHREADSIGNAL_H
#define TETHREADSIGNAL_H
#include "TeDefines.h"
#if TePLATFORM == TePLATFORMCODE_MSWINDOWS
#include <windows.h>
#include "TeMutex.h"
#elif TePLATFORM == TePLATFORMCODE_LINUX || TePLATFORM == TePLATFORMCODE_AIX
#include <pthread.h>
#include <errno.h>
#else
#error "ERROR: Unsupported platform"
#endif
/**
* @brief A class to deal with thread signals.
* @author Emiliano F. Castejon <castejon@dpi.inpe.br>
* @ingroup MultProgToolsGroup
*/
class TL_DLL TeThreadSignal
{
public :
/**
* @brief Default constructor.
*/
TeThreadSignal();
/**
* @brief Default destructor.
*/
~TeThreadSignal();
/**
* @brief Emit a broadcast signal unblocking all waiting threads.
*/
void emitSignal();
/**
* @brief Block the current thread waiting for a signal.
* @param waiting_time The maximim waiting time in milliseconds
* ( 0 == INFINITE ).
* @return true if a signal was received, false if the waiting
* time has finished or an error occurred.
*/
bool waitSignal( unsigned int waiting_time = 0 );
protected :
#if TePLATFORM == TePLATFORMCODE_MSWINDOWS
/**
* @brief Count of the number of waiters.
*/
int waiters_count_;
/**
* @brief Serialize access to waiters_count_.
*/
TeMutex waiters_count_lock_;
/**
* @brief Number of threads to release via a
* signal broadcast.
*/
int release_count_;
/**
* @brief Keeps track of the current "generation" so that we
* don't allow one thread to steal all the "releases" from the
* broadcast.
*/
int wait_generation_count_;
/**
* @brief A manual-reset event that's used to block and release
* waiting threads.
*/
HANDLE event_;
#elif TePLATFORM == TePLATFORMCODE_LINUX || TePLATFORM == TePLATFORMCODE_AIX
/**
* @brief The mutex instance.
*/
pthread_mutex_t m_access_;
/**
* @brief The condition var instance.
*/
pthread_cond_t condition_var_;
#else
#error "Unsuported plataform"
#endif
private :
/**
* @brief Alternative constructor.
*/
TeThreadSignal( const TeThreadSignal& ) {};
/**
* @brief operator= overload.
* @return A const reference to the current instance.
*/
const TeThreadSignal& operator=( const TeThreadSignal& ) { return *this; };
};
#endif
|