bes Updated for version 3.21.1
The Backend Server (BES) is the lower two tiers of the Hyrax data server
|
#include <AggMemberDatasetSharedDDSWrapper.h>
Public Member Functions | |
void | addPreDeleteCB (UseCountHitZeroCB *pCB) |
AggMemberDatasetSharedDDSWrapper (const AggMemberDatasetSharedDDSWrapper &proto) | |
AggMemberDatasetSharedDDSWrapper (const DDSAccessRCInterface *pDDSHolder) | |
virtual void | fillDimensionCacheByUsingDDS () |
virtual void | flushDimensionCache () |
virtual unsigned int | getCachedDimensionSize (const std::string &dimName) const |
const libdap::DDS * | getDDS () override |
const std::string & | getLocation () const |
virtual int | getRefCount () const |
virtual bool | isDimensionCached (const std::string &dimName) const |
virtual void | loadDimensionCache (std::istream &istr) |
AggMemberDatasetSharedDDSWrapper & | operator= (const AggMemberDatasetSharedDDSWrapper &that) |
virtual int | ref () const |
virtual void | removeFromPool () const |
void | removePreDeleteCB (UseCountHitZeroCB *pCB) |
virtual void | saveDimensionCache (std::ostream &ostr) |
virtual void | setDimensionCacheFor (const Dimension &dim, bool throwIfFound) |
virtual std::string | toString () const |
virtual int | unref () const |
class AggMemberDatasetSharedDDSWrapper: concrete subclass of AggMemberDataset designed to hold a ref-counted reference to an object containing a DataDDS (DDSAccessRCInterface).
This allows an object containing an aggregated DDS (DDSAccessRCInterface) to exist outside of its normal scope by letting the wrapper hold a strong (counted) reference to it until the aggregation serialization is complete.
The wrapped DDSAccessRCInterface will be ref() upon construction or being added into this by assignment or copy construction and will be unref() upon destruction or loss of reference via assignment operator.
Definition at line 54 of file AggMemberDatasetSharedDDSWrapper.h.
agg_util::AggMemberDatasetSharedDDSWrapper::AggMemberDatasetSharedDDSWrapper | ( | ) |
Definition at line 36 of file AggMemberDatasetSharedDDSWrapper.cc.
|
explicit |
Definition at line 41 of file AggMemberDatasetSharedDDSWrapper.cc.
|
override |
Definition at line 49 of file AggMemberDatasetSharedDDSWrapper.cc.
agg_util::AggMemberDatasetSharedDDSWrapper::AggMemberDatasetSharedDDSWrapper | ( | const AggMemberDatasetSharedDDSWrapper & | proto | ) |
Definition at line 55 of file AggMemberDatasetSharedDDSWrapper.cc.
|
inherited |
Add uniquely. If it is added agan, the second time is ignored.
|
virtualinherited |
Uses the getDDS() call in order to find all named dimensions within it and to seed them into the dimension cache table for faster later lookups. Potentially slow!
Implements agg_util::AggMemberDataset.
Definition at line 146 of file AggMemberDatasetWithDimensionCacheBase.cc.
|
virtualinherited |
Flush out any cache for the Dimensions so that it will have to be loaded.
Implements agg_util::AggMemberDataset.
Definition at line 161 of file AggMemberDatasetWithDimensionCacheBase.cc.
|
virtualinherited |
Get the size of the given dimension named dimName cached within the dataset. If not found in cache, throws.
If a cached value exists from a prior load of the DDS using loadDimensionCacheFromDDS() or from a call to setDimensionCacheFor(), return that.
Otherwise, this must load the DDS to get the values.
Implementation is left up to subclasses for efficiency.
agg_util::DimensionNotFoundException | if not located via any means. |
Implements agg_util::AggMemberDataset.
Definition at line 102 of file AggMemberDatasetWithDimensionCacheBase.cc.
|
overridevirtual |
Access via the wrapped DDSAccessRCInterface. If the wrapped DDS is NOT a DataDDS, we return NULL!
Implements agg_util::AggMemberDataset.
Definition at line 77 of file AggMemberDatasetSharedDDSWrapper.cc.
|
inherited |
The location to which the AggMemberDataset refers Note: this could be "" for some subclasses if they are virtual or nested
|
virtualinherited |
Get the current reference count
Implements agg_util::RCObjectInterface.
|
virtualinherited |
Return whether the dimension is already cached, or would have to be loaded to be found.
Implements agg_util::AggMemberDataset.
Definition at line 116 of file AggMemberDatasetWithDimensionCacheBase.cc.
|
virtualinherited |
Load the values in the dimension cache from the input stream
Implements agg_util::AggMemberDataset.
Definition at line 173 of file AggMemberDatasetWithDimensionCacheBase.cc.
AggMemberDatasetSharedDDSWrapper & agg_util::AggMemberDatasetSharedDDSWrapper::operator= | ( | const AggMemberDatasetSharedDDSWrapper & | that | ) |
Definition at line 62 of file AggMemberDatasetSharedDDSWrapper.cc.
|
virtualinherited |
Increase the reference count by one. const since we do not consider the ref count part of the semantic constness of the rep
Implements agg_util::RCObjectInterface.
|
virtualinherited |
If the object is in an auto-delete pool, remove it from the pool and force it to only delete when it's ref count goes to 0. Useful when we desire a particular object stay around outside of the pool's lifetime.
Implements agg_util::RCObjectInterface.
|
inherited |
Remove it exists. If not, this unchanged.
|
virtualinherited |
Append the values in the dimension cache to the output stream
Implements agg_util::AggMemberDataset.
Definition at line 167 of file AggMemberDatasetWithDimensionCacheBase.cc.
|
virtualinherited |
Seed the dimension cache using the given dimension, so that later calls to getDimensionSize for dim.name will return the dim.size immediately without checking or loading the actual DDS.
If it already exists and throwIfFound then will throw an AggregationException.
If it exists and !throwIfFound, will replace the old one.
dim | the dimension to seed |
if | true, throw if name take. Else replace original. |
Implements agg_util::AggMemberDataset.
Definition at line 122 of file AggMemberDatasetWithDimensionCacheBase.cc.
|
virtualinherited |
Just prints the count and address
Implements agg_util::RCObjectInterface.
Reimplemented in ncml_module::AggregationElement, ncml_module::AttributeElement, ncml_module::DimensionElement, ncml_module::ExplicitElement, ncml_module::NCMLElement, ncml_module::NetcdfElement, ncml_module::ReadMetadataElement, ncml_module::RemoveElement, ncml_module::ScanElement, ncml_module::ValuesElement, ncml_module::VariableAggElement, and ncml_module::VariableElement.
|
virtualinherited |
Decrease the reference count by one. If it goes from 1 to 0, delete this and this is no longer valid.
It is illegal to unref() an object with a count of 0. We don't throw to allow use in dtors, so the caller is assumed not to do it!
const since the reference count is not part of the semantic constness of the rep
Implements agg_util::RCObjectInterface.