OPeNDAP Hyrax Back End Server (BES)  Updated for version 3.8.3
Dimension.h
Go to the documentation of this file.
1 // This file is part of the "NcML Module" project, a BES module designed
3 // to allow NcML files to be used to be used as a wrapper to add
4 // AIS to existing datasets of any format.
5 //
6 // Copyright (c) 2009 OPeNDAP, Inc.
7 // Author: Michael Johnson <m.johnson@opendap.org>
8 //
9 // For more information, please also see the main website: http://opendap.org/
10 //
11 // This library is free software; you can redistribute it and/or
12 // modify it under the terms of the GNU Lesser General Public
13 // License as published by the Free Software Foundation; either
14 // version 2.1 of the License, or (at your option) any later version.
15 //
16 // This library is distributed in the hope that it will be useful,
17 // but WITHOUT ANY WARRANTY; without even the implied warranty of
18 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 // Lesser General Public License for more details.
20 //
21 // You should have received a copy of the GNU Lesser General Public
22 // License along with this library; if not, write to the Free Software
23 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
24 //
25 // Please see the files COPYING and COPYRIGHT for more information on the GLPL.
26 //
27 // You can contact OPeNDAP, Inc. at PO Box 112, Saunderstown, RI. 02874-0112.
29 
30 #ifndef __AGG_UTIL__DIMENSION_H__
31 #define __AGG_UTIL__DIMENSION_H__
32 
33 #include <ostream>
34 #include <string>
35 #include <vector>
36 
37 namespace agg_util
38 {
50  struct Dimension
51  {
52  public:
53  Dimension();
54  Dimension(const std::string& nameArg, unsigned int sizeArg, bool isSharedArg=false, bool isSizeConstantArg=true);
55  ~Dimension();
56 
58  std::string toString() const;
59 
60  // The name of the dimension (merely mnemonic)
61  std::string name;
62 
63  // The cardinality of the dimension (number of elements)
64  unsigned int size;
65 
66  // Whether the dimension in considered as shared across objects
67  bool isShared;
68 
69  // whether the size is allowed to change or not, important for joinExisting, e.g.
71  };
72 
74  std::ostream& operator<<(std::ostream& os, const Dimension& dim);
75 
76  /* Read back in */
77  std::istream& operator>>(std::istream& is, Dimension& dim);
78 
81  {
82  public:
83  DimensionTable(unsigned int capacity=0);
85 
86  void clear();
87 
91  void addDimensionUnique(const Dimension& dim);
92 
97  bool findDimension(const std::string& name, Dimension* pOut=0) const;
98 
99  const std::vector<Dimension>& getDimensions() const;
100 
101  private:
102  std::vector<Dimension> _dimensions;
103  };
104 
105 }
106 
107 #endif /* __AGG_UTIL__DIMENSION_H__ */
std::istream & operator>>(std::istream &is, Dimension &dim)
Definition: Dimension.cc:77
unsigned int size
Definition: Dimension.h:64
std::string name
Definition: Dimension.h:61
bool findDimension(const std::string &name, Dimension *pOut=0) const
Find the dimension with the given name.
Definition: Dimension.cc:88
const std::vector< Dimension > & getDimensions() const
Definition: Dimension.cc:122
Helper class for temporarily hijacking an existing dhi to load a DDX response for one particular file...
std::ostream & operator<<(std::ostream &os, const Dimension &dim)
Dump to stream.
Definition: Dimension.cc:70
Container class for a table of dimensions for a given dataset.
Definition: Dimension.h:80
std::string toString() const
Dump to string and return (using operator<<)
Definition: Dimension.cc:63
Struct for holding information about a dimension of data, minimally a name and a cardinality (size)...
Definition: Dimension.h:50
void addDimensionUnique(const Dimension &dim)
Add the dimension to the table if one with the same name doesn't already exist.
Definition: Dimension.cc:109
DimensionTable(unsigned int capacity=0)