This file is indexed.

/usr/include/terralib/kernel/TeThreadFunctor.h is in libterralib-dev 4.3.0+dfsg.2-10.

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