OPeNDAP Hyrax Back End Server (BES)  Updated for version 3.8.3
HDF5GMCFMissLLArray.h
Go to the documentation of this file.
1 // This file is part of the hdf5_handler implementing for the CF-compliant
2 // Copyright (c) 2011-2013 The HDF Group, Inc. and OPeNDAP, Inc.
3 //
4 // This is free software; you can redistribute it and/or modify it under the
5 // terms of the GNU Lesser General Public License as published by the Free
6 // Software Foundation; either version 2.1 of the License, or (at your
7 // option) any later version.
8 //
9 // This software is distributed in the hope that it will be useful, but
10 // WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
11 // or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
12 // License for more details.
13 //
14 // You should have received a copy of the GNU Lesser General Public
15 // License along with this library; if not, write to the Free Software
16 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17 //
18 // You can contact OPeNDAP, Inc. at PO Box 112, Saunderstown, RI. 02874-0112.
19 // You can contact The HDF Group, Inc. at 1800 South Oak Street,
20 // Suite 203, Champaign, IL 61820
21 
31 
32 #ifndef _HDF5GMCFMissLLARRAY_H
33 #define _HDF5GMCFMissLLARRAY_H
34 
35 // STL includes
36 #include <string>
37 #include <vector>
38 
39 // DODS includes
40 #include "HDF5CF.h"
41 #include <Array.h>
42 
43 using namespace libdap;
44 
45 class HDF5GMCFMissLLArray:public Array {
46  public:
47  HDF5GMCFMissLLArray(int rank, const string & filename, const hid_t fileid, H5DataType dtype, const string &varfullpath, H5GCFProduct product_type, CVType cvartype, const string & n="", BaseType * v = 0):
48  Array(n,v),
49  rank(rank),
50  filename(filename),
51  fileid(fileid),
52  dtype(dtype),
53  varname(varfullpath),
54  product_type(product_type),
55  cvartype(cvartype)
56  {
57  }
58 
59  virtual ~ HDF5GMCFMissLLArray() {
60  }
61  virtual BaseType *ptr_duplicate();
62  virtual bool read();
63  int format_constraint (int *cor, int *step, int *edg);
64 
65 
66  private:
67  int rank;
68  string filename;
69  hid_t fileid;
70  H5DataType dtype;
71  string varname;
72  H5GCFProduct product_type;
73  CVType cvartype;
74 
75  //template<class T>
76  template<typename T>
77  void obtain_ll_attr_value(hid_t file_id, hid_t s_root_id,const string& s_attr_name, T& attr_value,std::vector<char> & str_attr_value );
78 
79  void obtain_aqu_obpg_l3_ll(int* offset,int* step,int nelms);
80 
81  void obtain_gpm_l3_ll(int* offset,int* step,int nelms);
82 };
83 
84 #endif // _HDF5GMCFMissLLARRAY_H
85 
static class NCMLUtil overview
H5DataType
Definition: HDF5CFUtil.h:54
H5GCFProduct
CVType
Definition: HDF5CF.h:53
HDF5GMCFMissLLArray(int rank, const string &filename, const hid_t fileid, H5DataType dtype, const string &varfullpath, H5GCFProduct product_type, CVType cvartype, const string &n="", BaseType *v=0)
This class specifies the core engineering of mapping HDF5 to DAP by following CF. ...