rasdaman API
oidtype.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 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 General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with rasdaman community. If not, see <http://www.gnu.org/licenses/>.
16 *
17 * Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann /
18 rasdaman GmbH.
19 *
20 * For more information please see <http://www.rasdaman.org>
21 * or contact Peter Baumann via <baumann@rasdaman.com>.
22 /
33 #ifndef _D_OID_TYPE_
34 #define _D_OID_TYPE_
35 
36 #include "raslib/type.hh"
37 
38 //@ManMemo: Module: {\bf raslib}
39 
40 /*@Doc:
41  This class represents the oid type in the ODMG conformant
42  representation of the RasDaMan type system.
43 */
44 
45 class r_Oid_Type : public r_Type
46 {
47 public:
49  r_Oid_Type();
50 
52  r_Oid_Type( const r_Oid_Type& oldObj );
53 
55  virtual r_Type* clone() const;
56 
58  virtual r_Type::r_Type_Id type_id() const;
59 
61  virtual void convertToLittleEndian(char* cells, r_Area noCells) const;
62 
64  virtual void convertToBigEndian(char* cells, r_Area noCells) const;
65 
67  virtual void print_status( std::ostream& s = std::cout ) const;
68 
69  virtual bool isOidType() const;
70 
72  ~r_Oid_Type();
73 };
74 
75 //@Doc: write the status of a oid type to a stream
76 extern std::ostream &operator<<( std::ostream &str, const r_Oid_Type &type );
77 
78 #endif
79 
Definition: type.hh:56
virtual r_Type::r_Type_Id type_id() const =0
retrieve id of the type.
r_Type_Id
Definition: type.hh:61
virtual void convertToLittleEndian(char *cells, r_Area noCells) const =0
converts array of cells from NT byte order to Unix byte order.
virtual r_Type * clone() const =0
clone operation
virtual void convertToBigEndian(char *cells, r_Area noCells) const =0
converts array of cells from Unix byte order to NT byte order.
virtual bool isOidType() const
check, if type is a oid
std::ostream & operator<<(std::ostream &os, const std::vector< T > &list)