This file is indexed.

/usr/include/terralib/kernel/TeOverlay.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
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
/************************************************************************************
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 TeOverlay.h
    \brief This file contains structures and definitions for set operation on polygons.
	\author Gilberto Ribeiro de Queiroz <gribeiro@dpi.inpe.br>
 */

#ifndef  __TERRALIB_INTERNAL_OVERLAY_H
#define  __TERRALIB_INTERNAL_OVERLAY_H

#include "TeMultiGeometry.h"

/**
 * @brief Contains structures and definitions needed to execute Set Operations for polygons and lines (union, intersection e difference).
 */

namespace TeOVERLAY
{	
/** @defgroup SetOperations Set Operations
 *  Set operations for polygons and lines: intersection, union or difference.
 *  @{
 */

/** \brief Executes one of the possible Set Operations on polygons. 
    \param redPols		The first list of disjoint polygons (and without self-intersections).
	\param bluePols		The second list of disjoint polygons (and without self-intersections).
	\param polsOut		The polygon list from the operation result.
	\param operation	Type of operation: TeUNION, TeINTERSECTION or TeDIFFERENCE.
	\return				True if the operation success and false if an error has ocurried.
	
	\note Each polygon list must have disjoint polygons, otherwise, the result is undefined. This function must not be called directly,
	      instead of call it, choose a specific function below, because, this signature is deprecated and will change in near future.
*/
TL_DLL bool TeOverlay(const TePolygonSet& redPols, const TePolygonSet& bluePols, TePolygonSet& polsOut, const short& operation);

/** \brief Calculates the union Set Operation for polygons.
    \param redPols		The first list of disjoint polygons (and without self-intersections).
	\param bluePols		The second list of disjoint polygons (and without self-intersections).
	\param polsOut		The polygon list from the operation result.
	\return				True if the operation success and false if an error has ocurried.

*/
TL_DLL bool TeUnion(TePolygonSet& redPols, TePolygonSet& bluePols, TePolygonSet& polsOut);


/** \brief Calculates the  intersection Set Operation for polygons.
    \param redPols      The first list of disjoint polygons (and without self-intersections).
	\param bluePols		The second list of disjoint polygons (and without self-intersections).
	\param polsOut      The polygon list from the operation result.
	\return				True if the operation success and false if an error has ocurried.

*/
TL_DLL bool TeIntersection(const TePolygonSet& redPols, const TePolygonSet& bluePols, TePolygonSet& polsOut);


/** \brief Calculates the difference set operation for polygons (redPols minus bluePols).
    \param redPols      The first list of disjoint polygons (and without self-intersections).
	\param bluePols		The second list of disjoint polygons (and without self-intersections).
	\param polsOut      The polygon list from the operation result.
	\return				True if the operation success and false if an error has ocurried.

*/
TL_DLL bool TeDifference(TePolygonSet& redPols, TePolygonSet& bluePols, TePolygonSet& polsOut);


/** \brief Executes one of the possible Set Operations for lines and polygons. 
    \param redLines		A disjoint line list (and without self-intersections).
	\param bluePols		A list of disjoint polygons (and without self-intersections).
	\param operation    Type of operation: TeUNION, TeINTERSECTION or TeDIFFERENCE.
	\return				A geometry that can contains only lines on intersection and difference cases, and lines + polygons on union case.

	\note This function must not be called directly, instead of call it, choose a specific function below,
	      because, this signature is deprecated and will change in near future.

*/
TL_DLL TeMultiGeometry TeOverlay(const TeLineSet& redLines, const TePolygonSet& bluePols, const short& operation);


/** \brief Calculates the union set operation for lines and polygons.
    \param redLines     A disjoint line list (and without self-intersections).
	\param bluePols		A list of disjoint polygons (and without self-intersections).
	\return				A geometry formed by lines and polygons or only by polygons.

*/
TL_DLL TeMultiGeometry TeUnion(TeLineSet& redLines, TePolygonSet& bluePols);


/** \brief Calculates the intersection set operation for lines and polygons.
    \param redLines     A disjoint line list (and without self-intersections).
	\param bluePols		A list of disjoint polygons (and without self-intersections).
	\return				A geometry formed only by lines or empty.

*/
TL_DLL TeMultiGeometry TeIntersection(TeLineSet& redLines, TePolygonSet& bluePols);


/** \brief Calculates the defference set operation for lines and polygons.
    \param redLines     A disjoint line list (and without self-intersections).
	\param bluePols		A list of disjoint polygons (and without self-intersections).
	\return				A geometry formed only by lines or empty.

*/
TL_DLL TeMultiGeometry TeDifference(TeLineSet& redLines, TePolygonSet& bluePols);


/** \brief Calculates the union of all polygons passed in polsIn parameter, and returns a polygon set (polsOut).
    \param polsIn            A list of polygons, may have overlap (disjoint or not).
	\param polsOut           Where the union will be stored.
	\param makeCopy          If true, before to start the union process a copy will be done for all coordinates, otherwise, the rings and coordinates of the input polygon will be used and so, the input can be invalidate (because of handle/body share of implementaton) bu this will save some memory.
	\param fixOrientation    If true, the ring orientation is checked, otherwise, it is assumed that they are in correct order of processing (you may set to false only if you know implementation details otherwise an error may occur).
*/
TL_DLL bool TeUnion(TePolygonSet& polsIn, TePolygonSet& polsOut, const bool& makeCopy = true, const bool fixOrientation = true);


/** \brief Calculates the intersection set operation for polygons. This version of intersection will reuse some pre-processing of redPols, and will do intersection between redPols and each polygonset in bluePols vector. The result of each individual operation (redPols x a polygonset from the blue vector) will be store in the output vector in the same order of polygonsets in bluePols. If an intersection is empty, an empty polygonset will be stored to indicate this.
    \param redPols			A list of disjoint polygons (and without self-intersections) used as a mask to cut each polygonset in bluePols vector.
	\param bluePols			A vector that contains polygonsets that will be individually cutted by redPols, and each blue polygonset must be disjoint (and without self-intersections).
	\param vecPolsOut       A vector with the result of intersection between redPols and each polygonset in the blue polygonset vector.
	\param resultVec        A vector of bool that tells if individual intersection succeed or not.
	\param makeCopy         If true, before to start the union process a copy will be done for all coordinates, otherwise, the rings and coordinates of the input polygon will be used and so, the input can be invalidate (because of handle/body share of implementaton) bu this will save some memory.
	\param fixOrientation   If true, the ring orientation is checked, otherwise, it is assumed that they are in correct order of processing (you may set to false only if you know implementation details otherwise an error may occur).
	\return				True if the operation success and false if an error has ocurried.

	\note The output vector may contains polygonsets thar are empty, only to indicate that intersection was empty, so be carefull.

*/
TL_DLL bool TeIntersection(TePolygonSet& redPols, vector<TePolygonSet>& bluePols, vector<TePolygonSet>& vecPolsOut, vector<bool>& resultVec, const bool& makeCopy = true, const bool fixOrientation = true);


/** \brief Calculates the union set operation for polygons.
           This version of union will reuse some pre-processing of redPols,
		   and will do union between redPols and each polygonset in bluePols.
		   The result of each individual operation (redPols x a polygonset from the blue vector)
		   will be store in the output vector in the same order of polygonsets in bluePols.
    \param redPols			A list of disjoint polygons (and without self-intersections) used as a mask to cut each polygonset in bluePols vector.
	\param bluePols			A vector that contains polygonsets that will be individually cutted by redPols, and each blue polygonset must be disjoint (and without self-intersections).
	\param vecPolsOut       A vector with the result of union between redPols and each polygonset in the blue polygonset vector.
	\param resultVec        A vector of bool that tells if individual intersection succeed or not.
	\param makeCopy         If true, before to start the union process a copy will be done for all coordinates, otherwise, the rings and coordinates of the input polygon will be used and so, the input can be invalidate (because of handle/body share of implementaton) bu this will save some memory.
	\param fixOrientation   If true, the ring orientation is checked, otherwise, it is assumed that they are in correct order of processing (you may set to false only if you know implementation details otherwise an error may occur).
	\return				True if the operation success and false if an error has ocurried.
*/
TL_DLL bool TeUnion(TePolygonSet& redPols, vector<TePolygonSet>& bluePols, vector<TePolygonSet>& vecPolsOut, vector<bool>& resultVec, const bool& makeCopy = true, const bool fixOrientation = true);


/** \brief Calculates the difference set operation for polygons.
           This version of difference will reuse some pre-processing of redPols,
		   and will do difference between redPols and each polygonset in bluePols vector.
		   The result of each individual operation (redPols x a polygonset from the blue vector)
		   will be store in the output vector in the same order of polygonsets in bluePols.
		   If an intersection is empty, an empty polygonset will be stored to indicate this.
    \param redPols			A list of disjoint polygons (and without self-intersections) used as a mask to cut each polygonset in bluePols vector.
	\param bluePols			A vector that contains polygonsets that will be individually cutted by redPols, and each blue polygonset must be disjoint (and without self-intersections).
	\param vecPolsOut       A vector with the result of differnce between redPols and each polygonset in the blue polygonset vector.
	\param resultVec        A vector of bool that tells if individual intersection succeed or not.
	\param makeCopy         If true, before to start the union process a copy will be done for all coordinates, otherwise, the rings and coordinates of the input polygon will be used and so, the input can be invalidate (because of handle/body share of implementaton) bu this will save some memory.
	\param fixOrientation   If true, the ring orientation is checked, otherwise, it is assumed that they are in correct order of processing (you may set to false only if you know implementation details otherwise an error may occur).
	\return				True if the operation success and false if an error has ocurried.

	\note The output vector may contains polygonsets thar are empty, only to indicate that intersection was empty, so be carefull.
*/
TL_DLL bool TeDifference(TePolygonSet& redPols, vector<TePolygonSet>& bluePols, vector<TePolygonSet>& vecPolsOut, vector<bool>& resultVec, const bool& makeCopy = true, const bool fixOrientation = true);

/** \brief Calculates the union of all polygons passed in polsIn parameter,
           and returns a polygon set (polsOut).
	       This type of union use a different strategy from the
		   previous one: do union for each pair and
		   then repeat until we have only two pairs.
    \param psetIn            A list of polygons, may have overlap (disjoint or not).
	\param psetOut           Where the union will be stored.
 */
TL_DLL bool TePairUnion(TePolygonSet& psetIn, TePolygonSet& psetOut);

/** \brief Valid polygon holes: if they have a commom edge,
           they will be joined (THIS IS FOR INTERNAL USE ONLY).
	\param  polygon		The polygon to check holes.
	\param  psValid		The result polygon.
	\return				Returns true if the operation successed otherwise returns false.
 */
TL_DLL bool TeValidPolygonHoles(TePolygon& polygon, TePolygonSet& psValid);

/** \brief Valid polygon holes: if they have a commom edge, they will be joined (THIS IS FOR INTERNAL USE ONLY).
	\param  polygons	The polygons to check holes.
	\param  psValid		The result polygon.
	\return				Returns true if the operation successed otherwise returns false.
 */
TL_DLL bool TeValidPolygonHoles(TePolygonSet& polygons, TePolygonSet& psValid);

/** @} */ 

}	// end namespace TeOVERLAY

#endif //__TERRALIB_INTERNAL_OVERLAY_H