This file is indexed.

/usr/include/magics/RasterData.h is in libmagics++-dev 2.30.0-5.

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
/*
 * (C) Copyright 1996-2016 ECMWF.
 * 
 * This software is licensed under the terms of the Apache Licence Version 2.0
 * which can be obtained at http://www.apache.org/licenses/LICENSE-2.0. 
 * In applying this licence, ECMWF does not waive the privileges and immunities 
 * granted to it by virtue of its status as an intergovernmental organisation nor
 * does it submit to any jurisdiction.
 */

/*! \file RasterData.h
    \brief Definition of the Template class RasterData.
    
    Magics Team - ECMWF 2005
    
    Started: Tue 12-Apr-2005
    
    Changes:
    
*/

#ifndef RasterData_H
#define RasterData_H

#include <algorithm>
#include "magics.h"

class TeProjection;


namespace magics {

class Raster : public vector<double>
{
public:
	Raster() {}
	virtual ~Raster() {}
	double operator()(int row, int column) const
		{ return (*this)[row * columns_ + column]; }
	double min() const { if(this->empty()) return -1.; return *(std::min_element(begin(), end())); }
	double max() const { if(this->empty()) return -1.; return *(std::max_element(begin(), end())); }
        inline int   getRows()             const { return rows_; }
	inline int   getColumns()          const { return columns_; }	
	inline void setColumns(int columns)  { columns_ = columns; }
	inline void setRows(int rows)        { rows_ = rows; }

protected:
	 virtual void print(ostream& out) const { 
	 		out << "Raster[";
	 		out << size() << " points, ";
	 		out << min() << ", " << max() << "]"; 
	 }
	 int        rows_;
	 int        columns_;

	
private:
    //! Copy constructor - No copy allowed
	Raster(const Raster&);
    //! Overloaded << operator to copy - No copy allowed
	Raster& operator=(const Raster&);
    
// -- Friends
    //! Overloaded << operator to call print().
	friend ostream& operator<<(ostream& s,const Raster& p)
		{ p.print(s); return s; }

	
};


class RasterData  : public Raster {
	

public:
	RasterData() {}
	virtual ~RasterData() {}
	
	TeProjection& getProjection() { return *projection_; }
	
	inline double getXResolution()      const { return x_; }
	inline double getYResolution()      const { return y_; }

	inline const UserPoint& getLowerLeftCorner()  const { return lowerLeft_; }
	inline const UserPoint& getUpperRightCorner() const { return upperRight_; }
	
	inline void setXResolution(double x ) { x_ = x; }
	inline void setYResolution(double y ) { y_ = y; }
	
	inline void setUpperRightCorner(double lon, double lat) 
		{ upperRight_ = UserPoint(lon, lat); }
	inline void setLowerLeftCorner(double lon, double lat) 
		{ lowerLeft_ = UserPoint(lon, lat); }
	
	inline void setProjection(TeProjection* projection) { projection_ = projection; }
	

protected:
     //! Method to print string about this class on to a stream of type ostream (virtual).
	 virtual void print(ostream&) const {}
	 TeProjection* projection_;
	 double      x_;
	 double      y_;
	 UserPoint             lowerLeft_;
	 UserPoint             upperRight_;
	 	 
private:
    //! Copy constructor - No copy allowed
	RasterData(const RasterData&);
    //! Overloaded << operator to copy - No copy allowed
	RasterData& operator=(const RasterData&);
    
// -- Friends
    //! Overloaded << operator to call print().
	friend ostream& operator<<(ostream& s,const RasterData& p)
		{ p.print(s); return s; }

};

} // namespace magics


#endif