57#include "Marshaller.h"
58#include "UnMarshaller.h"
60#include "D4StreamMarshaller.h"
61#include "D4StreamUnMarshaller.h"
64#include "InternalErr.h"
66#include "dods-limits.h"
103 BaseType::operator=(rhs);
109#if USE_LOCAL_TIMEOUT_SCHEME
115 if (ce_eval && !eval.eval_selection(dds,
dataset()))
117#if USE_LOCAL_TIMEOUT_SCHEME
120 m.put_float32(d_buf);
126 um.get_float32(d_buf);
131void Float32::compute_checksum(Crc32 &checksum) {
132 checksum.
AddData(
reinterpret_cast<uint8_t *
>(&d_buf),
sizeof(d_buf));
147 m.put_float32(d_buf);
152unsigned int Float32::val2buf(
void *val,
bool) {
159 throw InternalErr(__FILE__, __LINE__,
"The incoming pointer does not contain any data.");
161 d_buf = *(dods_float32 *)val;
166unsigned int Float32::buf2val(
void **val) {
170 throw InternalErr(__FILE__, __LINE__,
"NULL pointer.");
173 *val =
new dods_float32;
175 *(dods_float32 *)*val = d_buf;
180bool Float32::set_value(dods_float32 f) {
194void Float32::print_val(FILE *out,
string space,
bool print_decl_p) {
197 fwrite(oss.str().data(),
sizeof(
char), oss.str().length(), out);
200void Float32::print_val(ostream &out,
string space,
bool print_decl_p) {
205 print_decl(out, space,
false);
206 out <<
" = " << std::setprecision(6) << d_buf <<
";\n";
208 out << std::setprecision(6) << d_buf;
211bool Float32::ops(BaseType *b,
int op) {
213 if (!
read_p() && !read()) {
218 throw InternalErr(__FILE__, __LINE__,
"This value not read!");
222 if (!b || !(b->read_p() || b->read())) {
223 throw InternalErr(__FILE__, __LINE__,
"This value not read!");
233 DBG(cerr <<
"b->typename(): " << b->type_name() << endl);
255 DBG(cerr <<
"arg1: " << d_buf <<
" " << op <<
" arg2: " <<
static_cast<Float64 *
>(b)->
value() << endl);
260 throw Error(malformed_expr,
"Relational operators can only compare compatible types (number, string).");
262 throw Error(malformed_expr,
"Relational operators only work with scalar types.");
275 strm << DapIndent::LMarg <<
"Float32::dump - (" << (
void *)
this <<
")" << endl;
277 BaseType::dump(strm);
278 strm << DapIndent::LMarg <<
"value: " << d_buf << endl;
279 DapIndent::UnIndent();
void AddData(const uint8_t *pData, const uint32_t length)
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.
A class for error processing.
Holds a 32-bit floating point value.
bool d4_ops(BaseType *b, int op) override
void dump(ostream &strm) const override
dumps information about this object
virtual dods_float32 value() const
Holds a 64-bit (double precision) floating point value.
Holds a 16-bit signed integer value.
Holds a 32-bit signed integer.
Holds a64-bit signed integer.
Holds an 8-bit signed integer value.
abstract base class used to marshal/serialize dap data objects
Holds an unsigned 16-bit integer.
Holds a 32-bit unsigned integer.
Holds a 64-bit unsigned integer.
abstract base class used to unmarshall/deserialize dap data objects
top level DAP object to house generic methods
virtual bool read_p()
Has this variable been read?
bool Cmp(int op, T1 v1, T2 v2)
virtual void print_val(FILE *out, string space="", bool print_decl_p=true)
Prints the value of the variable.
virtual string dataset() const
Returns the name of the dataset used to create this instance.