/usr/include/terralib/kernel/TeThreadFunctor.h is in libterralib-dev 4.0.0-5ubuntu1.
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 | /************************************************************************************
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 TeThreadFunctor.h
* \brief This file contains a base class for thread in function style manner.
* \author Emiliano F. Castejon <castejon@dpi.inpe.br>
* \author Gilberto Ribeiro de Queiroz <gribeiro@dpi.inpe.br>
*/
#ifndef __TERRALIB_INTERNAL_TETRHEADFUNCTOR_H
#define __TERRALIB_INTERNAL_TETRHEADFUNCTOR_H
#include "TeThread.h"
#include "TeThreadParameters.h"
#include "TeSharedPtr.h"
#include "TeDefines.h"
/** \class TeThreadFunctor
* \brief A base class for thread in function style manner.
*
*
* If you are interested in using TerraLib thread
* support in a function style model, you should create
* objects of this class by specifying a function to be called by
* the thread when it starts.<br>
* To start the thread, call start method,
* it is non-blocking.<br>
* If you want to use the thread support
* in a object oriented way, see TeThread class.
*
*
* \sa TeThread
* \author Emiliano F. Castejon <castejon@dpi.inpe.br>
* \author Gilberto Ribeiro de Queiroz <gribeiro@dpi.inpe.br>
* \ingroup MultProgToolsGroup
*
*/
class TL_DLL TeThreadFunctor : public TeThread
{
public:
/** \brief Type definition for a thread start function pointer.
* \param params The thread parameters.
* \return true if OK, false on erros.
*/
typedef bool (*TeThreadStartFunctT1)( const TeThreadParameters& params );
/** \brief Type definition for a thread start function pointer.
* \param userParamsPtr A pointer to anything required by the user.
* \return true if OK, false on erros.
*/
typedef bool (*TeThreadStartFunctT2)( void* userParamsPtr );
/** \deprecated Use TeThreadStartFunctT1. */
typedef TeThreadStartFunctT1 TeThreadStartFunctT;
/** @typedef TeSharedPtr< TeThread > pointer
* Type definition for an thread instance pointer.
*/
typedef TeSharedPtr< TeThreadFunctor > pointer;
/** \brief Default Constructor.
*/
TeThreadFunctor();
/** \brief Default Destructor
*/
~TeThreadFunctor();
/** \brief Returns the current thread execution return value.
*/
const bool& getReturnValue() const;
/** \brief Change the internal thread start function pointer.
* \param startFuncPtr The new thread start function pointer.
* \note The thread mus be stopped for calling this method.
*/
void setStartFunctPtr( TeThreadStartFunctT1 startFuncPtr );
/** \brief Change the internal thread start function pointer.
* \param startFuncPtr The new thread start function pointer.
* \note The thread mus be stopped for calling this method.
*/
void setStartFunctPtr( TeThreadStartFunctT2 startFuncPtr );
/** \brief Sets the parameter that will be passed to the function after
* the thread startup.
* \param params The parameters to the thread function.
* \note The thread must be stopped before calling this method.
*/
void setParameters(const TeThreadParameters& params);
/** \brief Sets a pointer that will be passed to the function after
* the thread startup.
* \param userParamsPtr The user parameters pointer.
* \note The thread must be stopped before calling this method.
*/
void setParametersPtr( void* userParamsPtr );
protected:
// Overloaded method from TeThread.
void run();
protected:
bool threadReturnValue_; //!< User function return value.
TeThreadParameters threadUserParams_; //!< The current user parameters instance.
TeThreadStartFunctT1 threadStartFuncPtr1_; //!< A pointer to the current user thread start function.
TeThreadStartFunctT2 threadStartFuncPtr2_; //!< A pointer to the current user thread start function.
void* userParamsPtr_;//!< A pointer to the current user thread start function parameters pointer.
};
#endif // __TERRALIB_INTERNAL_TETRHEADFUNCTOR_H
|