57 #include "Marshaller.h" 58 #include "UnMarshaller.h" 61 #include "D4StreamMarshaller.h" 62 #include "D4StreamUnMarshaller.h" 66 #include "Operators.h" 67 #include "dods-limits.h" 69 #include "InternalErr.h" 70 #include "DapIndent.h" 99 d_buf = copy_from.d_buf;
105 return new Int32(*
this);
110 DBG(cerr <<
"~Int32" << endl);
114 Int32::operator=(
const Int32 &rhs)
119 dynamic_cast<BaseType &
>(*this) = rhs;
129 return sizeof(dods_int32);
136 #if USE_LOCAL_TIMEOUT_SCHEME 144 #if USE_LOCAL_TIMEOUT_SCHEME 147 m.put_int32( d_buf ) ;
155 um.get_int32( d_buf ) ;
163 checksum.
AddData(reinterpret_cast<uint8_t*>(&d_buf),
sizeof(d_buf));
180 m.put_int32( d_buf ) ;
186 um.get_int32( d_buf ) ;
198 "The incoming pointer does not contain any data.");
200 d_buf = *(dods_int32 *)val;
211 throw InternalErr(__FILE__, __LINE__,
"NULL pointer.");
214 *val =
new dods_int32;
216 *(dods_int32 *)*val = d_buf;
228 Int32::set_value(dods_int32 i)
241 fwrite(oss.str().data(),
sizeof(char), oss.str().length(), out);
248 out <<
" = " << (int) d_buf <<
";\n";
263 throw InternalErr(__FILE__, __LINE__,
"This value not read!");
273 throw InternalErr(__FILE__, __LINE__,
"This value not read!");
284 DBG(cerr <<
"b->typename(): " << b->
type_name() << endl);
287 return Cmp<dods_int32, dods_int8>(op, d_buf,
static_cast<Int8*
>(b)->value());
289 return Cmp<dods_int32, dods_byte>(op, d_buf,
static_cast<Byte*
>(b)->value());
291 return Cmp<dods_int32, dods_int16>(op, d_buf,
static_cast<Int16*
>(b)->value());
293 return Cmp<dods_int32, dods_uint16>(op, d_buf,
static_cast<UInt16*
>(b)->value());
295 return Cmp<dods_int32, dods_int32>(op, d_buf,
static_cast<Int32*
>(b)->value());
297 return Cmp<dods_int32, dods_uint32>(op, d_buf,
static_cast<UInt32*
>(b)->value());
299 return Cmp<dods_int32, dods_int64>(op, d_buf,
static_cast<Int64*
>(b)->value());
301 return Cmp<dods_int32, dods_uint64>(op, d_buf,
static_cast<UInt64*
>(b)->value());
303 return Cmp<dods_int32, dods_float32>(op, d_buf,
static_cast<Float32*
>(b)->value());
305 return Cmp<dods_int32, dods_float64>(op, d_buf,
static_cast<Float64*
>(b)->value());
308 throw Error(malformed_expr,
"Relational operators can only compare compatible types (number, string).");
310 throw Error(malformed_expr,
"Relational operators only work with scalar types.");
325 strm << DapIndent::LMarg <<
"Int32::dump - (" 326 << (
void *)
this <<
")" << endl ;
327 DapIndent::Indent() ;
329 strm << DapIndent::LMarg <<
"value: " << d_buf << endl ;
330 DapIndent::UnIndent() ;
virtual bool read()
Read data into a local buffer.
Holds an 8-bit signed integer value.
Holds a64-bit signed integer.
virtual bool d4_ops(BaseType *b, int op)
virtual bool read_p()
Has this variable been read?
abstract base class used to unmarshall/deserialize dap data objects
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.
virtual void dump(ostream &strm) const
dumps information about this object
virtual void dump(ostream &strm) const
dumps information about this object
virtual bool ops(BaseType *b, int op)
Evaluate relational operators.
Read data from the stream made by D4StreamMarshaller.
virtual void compute_checksum(Crc32 &checksum)
include the data for this variable in the checksum DAP4 includes a checksum with every data response...
Holds an unsigned 16-bit integer.
BaseType(const string &n, const Type &t, bool is_dap4=false)
The BaseType constructor.
Holds a 32-bit floating point value.
top level DAP object to house generic methods
A class for software fault reporting.
virtual bool deserialize(UnMarshaller &um, DDS *dds, bool reuse=false)
Receive data from the net.
Marshaller that knows how to marshal/serialize dap data objects to a C++ iostream using DAP4's receiv...
Holds a 16-bit signed integer value.
virtual Type type() const
Returns the type of the class instance.
virtual void set_read_p(bool state)
Sets the value of the read_p property.
virtual BaseType * ptr_duplicate()
Holds a 64-bit unsigned integer.
void AddData(const uint8_t *pData, const uint32_t length)
Evaluate a constraint expression.
virtual void print_val(FILE *out, string space="", bool print_decl_p=true)
Prints the value of the variable.
The basic data type for the DODS DAP types.
abstract base class used to marshal/serialize dap data objects
virtual string type_name() const
Returns the type of the class instance as a string.
Holds a 64-bit (double precision) floating point value.
bool eval_selection(DDS &dds, const std::string &dataset)
Evaluate a boolean-valued constraint expression. This is main method for the evaluator and is called ...
A class for error processing.
virtual unsigned int buf2val(void **val)
Reads the class data.
Holds a 32-bit unsigned integer.
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...
virtual bool serialize(ConstraintEvaluator &eval, DDS &dds, Marshaller &m, bool ce_eval=true)
Move data to the net, then remove them from the object.
Holds a 32-bit signed integer.
virtual unsigned int val2buf(void *val, bool reuse=false)
Loads class data.
virtual string dataset() const
Returns the name of the dataset used to create this instance.