/usr/include/magics/GeoPointsDecoder.h is in libmagics++-dev 2.18.15-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 | /******************************** LICENSE ********************************
Copyright 2007 European Centre for Medium-Range Weather Forecasts (ECMWF)
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
******************************** LICENSE ********************************/
/*! \file GeoPointsDecoder.h
\brief Definition of the Template class GeoPointsDecoder.
Magics Team - ECMWF 2005
Started: Mon 12-Dec-2005
Changes:
*/
#ifndef GeoPointsDecoder_H
#define GeoPointsDecoder_H
#include "magics.h"
#include "GeoPointsDecoderAttributes.h"
#include "Data.h"
#include "Decoder.h"
#include "UserPoint.h"
namespace magics {
class XmlNode;
class GeoPointsDecoder: public GeoPointsDecoderAttributes,
public Data, public Decoder, public PointsList {
public:
GeoPointsDecoder();
virtual ~GeoPointsDecoder();
//! Method to access the data as a list of points : Used by psymb.
virtual void decode(const Transformation&);
virtual void decode();
void set(const map<string, string>& map ) { GeoPointsDecoderAttributes::set(map); }
void set(const XmlNode& node ) { GeoPointsDecoderAttributes::set(node); }
PointsHandler& points() {
decode();
pointsHandlers_.push_back(new PointsHandler(*this));
return *(pointsHandlers_.back());
}
PointsHandler& points(const Transformation& transformation) {
decode(transformation);
pointsHandlers_.push_back(new PointsHandler(*this));
return *(pointsHandlers_.back());
}
void customisedPoints(const Transformation&, const std::set<string>&, CustomisedPointsList& );
void add(const Transformation&, UserPoint&);
void add(const Transformation&, CustomisedPoint&);
void yxdtlv2(const string&, const Transformation&);
void xyv2(const string&, const Transformation&);
void yxdtlv1(const string&);
void xyv1(const string&s);
void polar(const string&, const Transformation&);
void lluv(const string&, const Transformation&);
void initInfo();
void visit(MetaDataCollector&);
void visit(ValuesCollector&);
void customisedPoints(const Transformation& t, const std::set<string>& n, CustomisedPointsList& out, bool all)
{
customisedPoints(t, n, out);
}
PointsHandler& points(const Transformation& t, bool) { return points(t); }
protected:
//! Method to print string about this class on to a stream of type ostream (virtual).
virtual void print(ostream&) const;
typedef void (GeoPointsDecoder::*SimpleDecode)(const string&);
typedef void (GeoPointsDecoder::*Decode)(const string&, const Transformation&);
std::map<string, Decode> formats_;
std::map<string, SimpleDecode> simple_formats_;
vector<CustomisedPoint*> customisedPoints_;
private:
//! Copy constructor - No copy allowed
GeoPointsDecoder(const GeoPointsDecoder&);
//! Overloaded << operator to copy - No copy allowed
GeoPointsDecoder& operator=(const GeoPointsDecoder&);
// -- Friends
//! Overloaded << operator to call print().
friend ostream& operator<<(ostream& s,const GeoPointsDecoder& p)
{ p.print(s); return s; }
};
} // namespace magics
#endif
|