bes Updated for version 3.21.1
The Backend Server (BES) is the lower two tiers of the Hyrax data server
GridJoinExistingAggregation.h
1
2// 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) 2010 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__GRID_JOIN_EXISTING_AGGREGATION_H__
31#define __AGG_UTIL__GRID_JOIN_EXISTING_AGGREGATION_H__
32
33#include "ArrayJoinExistingAggregation.h" //agg_util
34#include "Dimension.h" // agg_util
35#include "GridAggregationBase.h" // agg_util
36#include <memory>
37
38namespace agg_util {
39class GridJoinExistingAggregation: public GridAggregationBase {
40public:
41
42 GridJoinExistingAggregation(const libdap::Grid& proto, const AMDList& memberDatasets, const DDSLoader& loaderProto,
43 const Dimension& joinDim);
44
45 GridJoinExistingAggregation(const GridJoinExistingAggregation& proto);
46
47 virtual ~GridJoinExistingAggregation();
48
49 virtual GridJoinExistingAggregation* ptr_duplicate();
50
51 GridJoinExistingAggregation& operator=(const GridJoinExistingAggregation& rhs);
52
61
62protected:
63 // subclass interface
64
66 virtual void transferConstraintsToSubGridHook(Grid* pSubGrid);
67
68 virtual const Dimension& getAggregationDimension() const;
69
70private:
71 // helpers
72
74 void duplicate(const GridJoinExistingAggregation& rhs);
75
77 void cleanup() const noexcept;
78
85 void createRep(const libdap::Grid& protoSubGrid, const AMDList& granuleList);
86
87 // Local helpers to implement transferConstraintsToSubGridHook()
88 void transferConstraintsToSubGridMaps(Grid* pSubGrid);
89 void transferConstraintsToSubGridArray(Grid* pSubGrid);
90
91 // Data Rep
92
93 Dimension _joinDim;
94
95};
96// class GridJoinExistingAggregation
97}// namespace agg_util
98
99#endif /* __AGG_UTIL__GRID_JOIN_EXISTING_AGGREGATION_H__ */
virtual const Dimension & getAggregationDimension() const
virtual void transferConstraintsToSubGridHook(Grid *pSubGrid)
unique_ptr< ArrayJoinExistingAggregation > makeAggregatedOuterMapVector() const
STL class.
Helper class for temporarily hijacking an existing dhi to load a DDX response for one particular file...