49 #ifndef _constructor_h 50 #include "Constructor.h" 53 #ifndef base_type_factory_h 54 #include "BaseTypeFactory.h" 67 #include "Keywords2.h" 72 #include "XMLWriter.h" 190 string d_container_name;
196 string d_dap_version;
197 string d_request_xml_base;
202 vector<BaseType *> vars;
211 long d_max_response_size;
213 friend class DDSTest;
216 void duplicate(
const DDS &dds);
217 BaseType *leaf_match(
const string &name, BaseType::btp_stack *s = 0);
218 BaseType *exact_match(
const string &name, BaseType::btp_stack *s = 0);
221 typedef std::vector<BaseType *>::const_iterator Vars_citer ;
222 typedef std::vector<BaseType *>::iterator Vars_iter ;
223 typedef std::vector<BaseType *>::reverse_iterator Vars_riter ;
231 DDS & operator=(
const DDS &rhs);
271 string get_dap_version()
const {
return d_dap_version; }
272 string get_dmr_version()
const {
return "1.0"; }
282 Keywords &get_keywords() {
return d_keywords;}
318 BaseType *
var(
const string &n, BaseType::btp_stack &s);
319 BaseType *
var(
const string &n, BaseType::btp_stack *s = 0);
325 Vars_citer var_cbegin()
const {
return vars.cbegin(); }
333 Vars_citer var_cend()
const {
return vars.cend(); }
348 void del_var(Vars_iter i1, Vars_iter i2);
357 void set_timeout(
int t);
362 void parse(
string fname);
364 void parse(FILE *in = stdin);
367 void print(FILE *out);
369 void print_xml(FILE *out,
bool constrained,
const string &blob =
"");
372 void print(ostream &out);
374 void print_xml(ostream &out,
bool constrained,
const string &blob =
"");
377 void print_xml_writer(ostream &out,
bool constrained,
const string &blob =
"");
380 void print_dmr(ostream &out,
bool constrained);
387 bool mark(
const string &name,
bool state);
392 virtual void dump(ostream &strm)
const ;
void print(FILE *out)
Print the entire DDS to the specified file.
void insert_var_nocopy(Vars_iter i, BaseType *ptr)
Contains the attributes for a dataset.
Vars_iter get_vars_iter(int i)
Get an iterator.
void set_response_limit(long size)
void insert_var(Vars_iter i, BaseType *ptr)
Insert a variable before the referenced element.
Vars_iter var_begin()
Return an iterator to the first variable.
long get_response_limit()
Get the maximum response size, in Bytes. Zero indicates no limit.
DDS(BaseTypeFactory *factory, const string &name="")
int get_request_size(bool constrained)
Get the estimated response size.
BaseType * var(const string &n, BaseType::btp_stack &s)
virtual void transfer_attributes(DAS *das)
void print_xml(FILE *out, bool constrained, const string &blob="")
void print_xml_writer(ostream &out, bool constrained, const string &blob="")
void add_var_nocopy(BaseType *bt)
Adds the variable to the DDS.
Holds a structure (aggregate) type.
Vars_riter var_rend()
Return a reverse iterator.
string get_dataset_name() const
int num_var()
Returns the number of variables in the DDS.
DAS * get_das()
Get a DAS object.
top level DAP object to house generic methods
bool mark(const string &name, bool state)
Mark the send_p flag of the named variable to state.
void parse(string fname)
Parse a DDS from a file with the given d_name.
void mark_all(bool state)
void print_das(ostream &out)
write the DAS response given the attribute information in the DDS
void print_dmr(ostream &out, bool constrained)
Print the DAP4 DMR object using a DDS.
virtual AttrTable & get_attr_table()
BaseType * get_var_index(int i)
Get a variable.
bool check_semantics(bool all=false)
Check the semantics of each of the variables represented in the DDS.
int get_dap_major() const
Get the DAP major version as sent by the client.
string get_request_xml_base() const
Get the URL that will return this DDS/DDX/DataThing.
virtual void dump(ostream &strm) const
dumps information about this object
string get_namespace() const
Get the namespace associated with the DDS - likely set only by DDX responses.
BaseTypeFactory * set_factory(BaseTypeFactory *factory)
bool has_dap2_attributes(AttrTable &a)
Vars_iter var_end()
Return an iterator.
void set_namespace(const string &ns)
Set the namespace for this DDS/DDX object/response.
void tag_nested_sequences()
Traverse DDS, set Sequence leaf nodes.
void set_dap_minor(int p)
void set_dataset_name(const string &n)
The basic data type for the DODS DAP types.
libdap base object for common functionality of libdap objects
void del_var(const string &n)
Removes a variable from the DDS.
Vars_riter var_rbegin()
Return a reverse iterator.
Hold attribute data for a DAP2 dataset.
BaseTypeFactory * get_factory() const
int get_dap_minor() const
Get the DAP minor version as sent by the client.
void set_dap_major(int p)
void print_constrained(FILE *out)
Print a constrained DDS to the specified file.
void set_dap_version(const string &version_string="2.0")
void add_var(BaseType *bt)
Adds a copy of the variable to the DDS. Using the ptr_duplicate() method, perform a deep copy on the ...
void set_request_xml_base(const string &xb)