libdap Updated for version 3.21.1
libdap4 is an implementation of OPeNDAP's DAP protocol.
BaseType.h
Go to the documentation of this file.
1
2// -*- mode: c++; c-basic-offset:4 -*-
3
4// This file is part of libdap, A C++ implementation of the OPeNDAP Data
5// Access Protocol.
6
7// Copyright (c) 2002,2003 OPeNDAP, Inc.
8// Author: James Gallagher <jgallagher@opendap.org>
9// Dan Holloway <dan@hollywood.gso.uri.edu>
10// Reza Nekovei <reza@intcomm.net>
11//
12// This library is free software; you can redistribute it and/or
13// modify it under the terms of the GNU Lesser General Public
14// License as published by the Free Software Foundation; either
15// version 2.1 of the License, or (at your option) any later version.
16//
17// This library is distributed in the hope that it will be useful,
18// but WITHOUT ANY WARRANTY; without even the implied warranty of
19// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20// Lesser General Public License for more details.
21//
22// You should have received a copy of the GNU Lesser General Public
23// License along with this library; if not, write to the Free Software
24// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
25//
26// You can contact OPeNDAP, Inc. at PO Box 112, Saunderstown, RI. 02874-0112.
27
28// (c) COPYRIGHT URI/MIT 1994-1999
29// Please read the full copyright statement in the file COPYRIGHT_URI.
30//
31// Authors:
32// jhrg,jimg James Gallagher <jgallagher@gso.uri.edu>
33// dan Dan Holloway <dan@hollywood.gso.uri.edu>
34// reza Reza Nekovei <reza@intcomm.net>
35
36// Abstract base class for the variables in a dataset. This is used to store
37// the type-invariant information that describes a variable as given in the
38// DODS API.
39//
40// jhrg 9/6/94
41
42#ifndef _basetype_h
43#define _basetype_h 1
44
45#include <iostream>
46#include <stack>
47#include <string>
48#include <vector>
49
50#include "AttrTable.h"
51#include "D4AttributeType.h"
52#include "D4Attributes.h"
53
54#include "InternalErr.h"
55
56#include "Type.h"
57#include "dods-datatypes.h"
58
59#include "DapObj.h"
60
61using namespace std;
62
63class Crc32;
64
65namespace libdap {
66
68
69class DDS;
70class Marshaller;
71class UnMarshaller;
72
73class Constructor;
74class XMLWrter;
75
76class DMR;
77class D4Group;
78class XMLWriter;
81
82class D4Attributes;
83
117
118class BaseType : public DapObj {
119private:
120 string d_name; // name of the instance
121 Type d_type; // instance's type
122 string d_dataset; // name of the dataset used to create this BaseType
123
124 bool d_is_read; // true if the value has been read
125 bool d_is_send; // Is the variable in the projection?
126
127 // d_parent points to the Constructor or Vector which holds a particular
128 // variable. It is null for simple variables. The Vector and Constructor
129 // classes must maintain this variable.
130 BaseType *d_parent;
131
132 // Attributes for this variable. Added 05/20/03 jhrg
133 AttrTable d_attr;
134
135 D4Attributes *d_attributes;
136
137 bool d_is_dap4; // True if this is a DAP4 variable, false ... DAP2
138
139 // These are non-empty only for DAP4 variables. Added 9/27/12 jhrg
140
141 // These were/are used for DAP2 CEs, but not for DAP4 ones
142 bool d_in_selection; // Is the variable in the selection?
143 bool d_is_synthesized; // true if the variable is synthesized
144
145protected:
146 void m_duplicate(const BaseType &bt);
147
148public:
149 typedef stack<BaseType *> btp_stack;
150
151 // These ctors assume is_dap4 is false
152 BaseType(const string &n, const Type &t, bool is_dap4 = false);
153 BaseType(const string &n, const string &d, const Type &t, bool is_dap4 = false);
154
155 BaseType(const BaseType &copy_from);
156 ~BaseType() override;
157
158 virtual string toString();
159
160 virtual void transform_to_dap4(D4Group *root, Constructor *container);
161 virtual std::vector<BaseType *> *transform_to_dap2(AttrTable *parent_attr_table);
162
163 void dump(ostream &strm) const override;
164
165 BaseType &operator=(const BaseType &rhs);
166
179 virtual void clear_local_data() { set_read_p(false); }
180
181 virtual bool is_dap4() const { return d_is_dap4; }
182 virtual void set_is_dap4(const bool v) { d_is_dap4 = v; }
183
190 virtual BaseType *ptr_duplicate() = 0;
191
192 virtual string name() const;
193 virtual void set_name(const string &n);
194 virtual std::string FQN() const;
195
196 virtual Type type() const;
197 virtual void set_type(const Type &t);
198 virtual string type_name() const;
199
200 virtual string dataset() const;
201
207 virtual int length() const { return 1; }
208
216 virtual int64_t length_ll() const { return 1; }
217
224 virtual void set_length(int64_t) { /* empty since the length of a BaseType is always one element. jhrg 8/12/22 */ }
225
232 virtual void set_length_ll(int64_t) { /* empty since the length of a BaseType is always one element. jhrg 8/12/22 */
233 }
234
235 virtual bool is_simple_type() const;
236 virtual bool is_vector_type() const;
237 virtual bool is_constructor_type() const;
238
239 virtual bool synthesized_p();
240 virtual void set_synthesized_p(bool state);
241
242 virtual int element_count(bool leaves = false);
243
244 virtual bool read_p();
245 virtual void set_read_p(bool state);
246
247 virtual bool send_p();
248 virtual void set_send_p(bool state);
249
250 virtual AttrTable &get_attr_table();
251 virtual void set_attr_table(const AttrTable &at);
252
253 // DAP4 attributes
254 virtual D4Attributes *attributes();
255 virtual void set_attributes(D4Attributes *);
256 virtual void set_attributes_nocopy(D4Attributes *);
257
258 virtual bool is_in_selection();
259 virtual void set_in_selection(bool state);
260
261 virtual void set_parent(BaseType *parent);
262 virtual BaseType *get_parent() const;
263
264 virtual BaseType *get_ancestor();
265
266 virtual void transfer_attributes(AttrTable *at);
267
268 // I put this comment here because the version in BaseType.cc does not
269 // include the exact_match or s variables since they are not used. Doxygen
270 // was gaging on the comment.
271
302 virtual BaseType *var(const string &name = "", bool exact_match = true, btp_stack *s = nullptr);
303 virtual BaseType *var(const string &name, btp_stack &s);
304
305 virtual void add_var(BaseType *bt, Part part = nil);
306 virtual void add_var_nocopy(BaseType *bt, Part part = nil);
307
308 virtual bool read();
309
310 virtual bool check_semantics(string &msg, bool all = false);
311
312 virtual bool ops(BaseType *b, int op);
313 virtual bool d4_ops(BaseType *b, int op);
314
315 virtual unsigned int width(bool constrained = false) const;
316
317 virtual int64_t width_ll(bool constrained = false) const;
318
319 virtual void print_decl(FILE *out, string space = " ", bool print_semi = true, bool constraint_info = false,
320 bool constrained = false);
321
322 virtual void print_xml(FILE *out, string space = " ", bool constrained = false);
323
324 virtual void print_decl(ostream &out, string space = " ", bool print_semi = true, bool constraint_info = false,
325 bool constrained = false);
326
327 virtual void print_xml(ostream &out, string space = " ", bool constrained = false);
328
329 virtual void print_xml_writer(XMLWriter &xml, bool constrained = false);
330
331 virtual void print_dap4(XMLWriter &xml, bool constrained = false);
332
335
355 virtual unsigned int buf2val(void **val) = 0;
356
386 virtual unsigned int val2buf(void *val, bool reuse = false) = 0;
387
406 virtual void intern_data(ConstraintEvaluator &eval, DDS &dds);
407
451 virtual bool serialize(ConstraintEvaluator &eval, DDS &dds, Marshaller &m, bool ce_eval = true);
452
459 virtual void compute_checksum(Crc32 &checksum) = 0;
460
461 virtual void intern_data();
462
476 virtual void serialize(D4StreamMarshaller &m, DMR &dmr, bool filter = false);
477
502 virtual bool deserialize(UnMarshaller &um, DDS *dds, bool reuse = false);
503
510 virtual void deserialize(D4StreamUnMarshaller &um, DMR &dmr);
511
526
527 virtual void print_val(FILE *out, string space = "", bool print_decl_p = true);
528
543 virtual void print_val(ostream &out, string space = "", bool print_decl_p = true) = 0;
545
546 virtual bool is_dap4_projected(std::vector<string> &projected_dap4_inventory);
547};
548
549} // namespace libdap
550
551#endif // _basetype_h
Definition crc.h:43
Contains the attributes for a dataset.
Definition AttrTable.h:150
The basic data type for the DODS DAP types.
Definition BaseType.h:118
BaseType & operator=(const BaseType &rhs)
Definition BaseType.cc:159
void m_duplicate(const BaseType &bt)
Perform a deep copy.
Definition BaseType.cc:85
virtual bool is_dap4_projected(std::vector< string > &projected_dap4_inventory)
Definition BaseType.cc:1148
virtual void print_xml_writer(XMLWriter &xml, bool constrained=false)
Definition BaseType.cc:987
virtual string type_name() const
Returns the type of the class instance as a string.
Definition BaseType.cc:335
virtual void intern_data()
Read data into this variable.
Definition BaseType.cc:805
virtual bool read()
Read data into a local buffer.
Definition BaseType.cc:775
virtual bool deserialize(UnMarshaller &um, DDS *dds, bool reuse=false)
Receive data from the net.
Definition BaseType.cc:814
virtual AttrTable & get_attr_table()
Definition BaseType.cc:498
virtual string name() const
Returns the name of the class instance.
Definition BaseType.cc:296
virtual void set_in_selection(bool state)
Definition BaseType.cc:611
virtual void print_decl(FILE *out, string space=" ", bool print_semi=true, bool constraint_info=false, bool constrained=false)
Print an ASCII representation of the variable structure.
Definition BaseType.cc:868
virtual BaseType * get_parent() const
Definition BaseType.cc:636
virtual bool read_p()
Has this variable been read?
Definition BaseType.cc:410
virtual unsigned int width(bool constrained=false) const
How many bytes does this variable use Return the number of bytes of storage this variable uses....
Definition BaseType.cc:1138
virtual void set_read_p(bool state)
Sets the value of the read_p property.
Definition BaseType.cc:442
virtual string dataset() const
Returns the name of the dataset used to create this instance.
Definition BaseType.cc:326
virtual bool d4_ops(BaseType *b, int op)
Evaluator a relop for DAP4.
Definition BaseType.cc:1125
virtual void set_length_ll(int64_t)
Set the number of elements in this variable This version of the function deprecates set_length() whic...
Definition BaseType.h:232
virtual void set_attr_table(const AttrTable &at)
Definition BaseType.cc:502
virtual void set_synthesized_p(bool state)
Definition BaseType.cc:397
virtual void set_parent(BaseType *parent)
Definition BaseType.cc:622
virtual int element_count(bool leaves=false)
Count the members of constructor types.
Definition BaseType.cc:385
~BaseType() override
Definition BaseType.cc:150
void dump(ostream &strm) const override
dumps information about this object
Definition BaseType.cc:269
virtual string toString()
Definition BaseType.cc:170
virtual bool is_vector_type() const
Returns true if the instance is a vector (i.e., array) type variable.
Definition BaseType.cc:352
virtual bool is_dap4() const
Definition BaseType.h:181
virtual void print_xml(FILE *out, string space=" ", bool constrained=false)
Definition BaseType.cc:962
virtual void set_name(const string &n)
Sets the name of the class instance.
Definition BaseType.cc:314
virtual bool ops(BaseType *b, int op)
Evaluate relational operators.
Definition BaseType.cc:1101
virtual bool is_constructor_type() const
Returns true if the instance is a constructor (i.e., Structure, Sequence or Grid) type variable.
Definition BaseType.cc:358
virtual void print_val(ostream &out, string space="", bool print_decl_p=true)=0
Prints the value of the variable.
virtual D4Attributes * attributes()
Definition BaseType.cc:507
virtual std::string FQN() const
Definition BaseType.cc:304
virtual bool send_p()
Should this variable be sent?
Definition BaseType.cc:478
virtual void set_length(int64_t)
Set the number of elements for this variable. use -1 to indicate nothing set.
Definition BaseType.h:224
virtual void add_var_nocopy(BaseType *bt, Part part=nil)
Definition BaseType.cc:699
virtual int length() const
How many elements are in this variable? Uses -1 in places.
Definition BaseType.h:207
virtual void clear_local_data()
Definition BaseType.h:179
virtual bool is_simple_type() const
Returns true if the instance is a numeric, string or URL type variable.
Definition BaseType.cc:347
virtual void set_send_p(bool state)
Definition BaseType.cc:488
virtual void set_is_dap4(const bool v)
Definition BaseType.h:182
virtual BaseType * ptr_duplicate()=0
virtual unsigned int val2buf(void *val, bool reuse=false)=0
Loads class data.
virtual int64_t length_ll() const
Get the number of elements in this variable This version of the function deprecates length() which is...
Definition BaseType.h:216
virtual unsigned int buf2val(void **val)=0
Reads the class data.
virtual void set_attributes(D4Attributes *)
Definition BaseType.cc:513
virtual void compute_checksum(Crc32 &checksum)=0
include the data for this variable in the checksum DAP4 includes a checksum with every data response....
virtual void transform_to_dap4(D4Group *root, Constructor *container)
DAP2 to DAP4 transform.
Definition BaseType.cc:200
virtual bool serialize(ConstraintEvaluator &eval, DDS &dds, Marshaller &m, bool ce_eval=true)
Move data to the net, then remove them from the object.
Definition BaseType.cc:810
virtual void add_var(BaseType *bt, Part part=nil)
Add a variable.
Definition BaseType.cc:697
virtual void transfer_attributes(AttrTable *at)
Definition BaseType.cc:544
virtual bool is_in_selection()
Is this variable part of the current selection?
Definition BaseType.cc:600
virtual bool synthesized_p()
Definition BaseType.cc:390
stack< BaseType * > btp_stack
Definition BaseType.h:149
virtual BaseType * get_ancestor()
Definition BaseType.cc:638
virtual bool check_semantics(string &msg, bool all=false)
Compare an object's current state with the semantics of its type.
Definition BaseType.cc:1056
virtual int64_t width_ll(bool constrained=false) const
Definition BaseType.cc:1140
BaseType(const string &n, const Type &t, bool is_dap4=false)
The BaseType constructor.
Definition BaseType.cc:124
virtual BaseType * var(const string &name="", bool exact_match=true, btp_stack *s=nullptr)
Returns a pointer to a member of a constructor class.
Definition BaseType.cc:646
virtual void set_type(const Type &t)
Sets the type of the class instance.
Definition BaseType.cc:332
virtual Type type() const
Returns the type of the class instance.
Definition BaseType.cc:329
virtual void print_val(FILE *out, string space="", bool print_decl_p=true)
Prints the value of the variable.
Definition BaseType.cc:949
virtual void print_dap4(XMLWriter &xml, bool constrained=false)
Definition BaseType.cc:1015
virtual void set_attributes_nocopy(D4Attributes *)
Definition BaseType.cc:515
virtual std::vector< BaseType * > * transform_to_dap2(AttrTable *parent_attr_table)
DAP4 to DAP2 transform.
Definition BaseType.cc:240
Evaluate a constraint expression.
Marshaller that knows how to marshal/serialize dap data objects to a C++ iostream using DAP4's receiv...
Read data from the stream made by D4StreamMarshaller.
libdap base object for common functionality of libdap objects
Definition DapObj.h:49
abstract base class used to marshal/serialize dap data objects
Definition Marshaller.h:50
abstract base class used to unmarshall/deserialize dap data objects
top level DAP object to house generic methods
Definition AISConnect.cc:30
Type
Identifies the data type.
Definition Type.h:94
Part
Names the parts of multi-section constructor data types.
Definition Type.h:48
@ nil
Definition Type.h:49