rasdaman client API  10.6.3
The Array Analytics Engine: Datacubes at Your Fingertips
sintervaltype.hh
Go to the documentation of this file.
1 /*
2  * This file is part of rasdaman community.
3  *
4  * Rasdaman community is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU Lesser General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * Rasdaman community is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public License
15  * along with rasdaman community. If not, see <http://www.gnu.org/licenses/>.
16  *
17  * Copyright 2003 - 2010 Peter Baumann / rasdaman GmbH.
18  *
19  * For more information please see <http://www.rasdaman.org>
20  * or contact Peter Baumann via <baumann@rasdaman.com>.
21 */
22 
23 #ifndef D_SINTERVAL_TYPE_HH
24 #define D_SINTERVAL_TYPE_HH
25 
26 #include "raslib/type.hh"
27 
28 //@ManMemo: Module: {\bf raslib}
38 class r_Sinterval_Type : public r_Type
39 {
40 public:
41  r_Sinterval_Type() = default;
42  r_Sinterval_Type(const r_Sinterval_Type &) = default;
43  ~r_Sinterval_Type() override = default;
44 
45  r_Type *clone() const override;
46 
48  r_Type::r_Type_Id type_id() const override;
49 
51  void convertToLittleEndian(char *cells, r_Area noCells) const override;
52 
54  void convertToBigEndian(char *cells, r_Area noCells) const override;
55 
57  void print_status(std::ostream &s) const override;
58 
59  bool isSintervalType() const override;
60 };
61 
62 //@Doc: write the status of a sinterval type to a stream
63 extern std::ostream &operator<<(std::ostream &str, const r_Sinterval_Type &type);
64 
65 #endif
This class represents the sinterval type in the ODMG conformant representation of the RasDaMan type s...
Definition: sintervaltype.hh:39
void print_status(std::ostream &s) const override
writes state of object to specified stream
r_Type * clone() const override
clone operation
r_Type::r_Type_Id type_id() const override
retrieve id of the type.
r_Sinterval_Type()=default
r_Sinterval_Type(const r_Sinterval_Type &)=default
bool isSintervalType() const override
check, if type is a Sinterval
void convertToBigEndian(char *cells, r_Area noCells) const override
converts array of cells from Unix byte order to NT byte order.
void convertToLittleEndian(char *cells, r_Area noCells) const override
converts array of cells from NT byte order to Unix byte order.
~r_Sinterval_Type() override=default
This class the superclass for all types in the ODMG conformant representation of the RasDaMan type sy...
Definition: type.hh:51
r_Type_Id
typedef for the enum specifying a primitive type, structure type, marray type, interval type,...
Definition: type.hh:56
std::uint64_t r_Area
number of cells in an mdd object or tile.
Definition: mddtypes.hh:49
std::ostream & operator<<(std::ostream &str, const r_Sinterval_Type &type)