OPeNDAP Hyrax Back End Server (BES)  Updated for version 3.8.3
GridAggregateOnOuterDimension.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 #ifndef __AGG_UTIL__GRID_AGGREGATE_ON_OUTER_DIMENSION_H__
30 #define __AGG_UTIL__GRID_AGGREGATE_ON_OUTER_DIMENSION_H__
31 
32 #include <memory>
33 #include <string>
34 #include <vector>
35 
36 #include "AggregationUtil.h" // agg_util
37 #include "AggMemberDataset.h" // agg_util
38 #include "Dimension.h" // agg_util
39 #include "DDSLoader.h" // agg_util
40 #include <Grid.h> // libdap
41 #include "GridAggregationBase.h" // agg_util
42 
43 namespace libdap
44 {
45  class Array;
46  class Grid;
47 };
48 
49 using std::string;
50 using std::vector;
51 using libdap::Array;
52 using libdap::Grid;
53 
54 namespace agg_util
55 {
85  {
86  public:
95  GridAggregateOnOuterDimension(const Grid& proto,
96  const Dimension& newDim,
97  const AMDList& memberDatasets,
98  const DDSLoader& loaderProto);
99 
101 
103 
105 
107 
108  protected: // Subclass Impl
109 
120  virtual void transferConstraintsToSubGridHook(Grid* pSubGrid);
121 
122  virtual const Dimension& getAggregationDimension() const;
123 
124 
125  private: // helpers
126 
128  void duplicate(const GridAggregateOnOuterDimension& rhs);
129 
131  void cleanup() throw();
132 
138  void createRep(const AMDList& memberDatasets);
139 
140 
141  // Local helpers called from transferConstraintsToSubGridMapsHook()
142  void transferConstraintsToSubGridMaps(Grid* pSubGrid);
143  void transferConstraintsToSubGridArray(Grid* pSubGrid);
144 
145  private: // data rep
146  // The new outer dimension description
147  Dimension _newDim;
148 
149  };
150 
151 }
152 
153 #endif // __AGG_UTIL__GRID_AGGREGATE_ON_OUTER_DIMENSION_H__
Helper class for temporarily hijacking an existing dhi to load a DDX response for one particular file...
static class NCMLUtil overview
class GridAggregateOnOuterDimension : public GridAggregationBase
virtual const Dimension & getAggregationDimension() const
Get the contained aggregation dimension info.
Struct for holding information about a dimension of data, minimally a name and a cardinality (size)...
Definition: Dimension.h:50
GridAggregateOnOuterDimension & operator=(const GridAggregateOnOuterDimension &rhs)
GridAggregateOnOuterDimension(const Grid &proto, const Dimension &newDim, const AMDList &memberDatasets, const DDSLoader &loaderProto)
Create the new Grid from the template proto...
virtual GridAggregateOnOuterDimension * ptr_duplicate()
std::vector< RCPtr< AggMemberDataset > > AMDList
virtual void transferConstraintsToSubGridHook(Grid *pSubGrid)
For the data array and all maps, transfer the constraints from the super grid (ie this) to all the gr...