bes Updated for version 3.21.1
The Backend Server (BES) is the lower two tiers of the Hyrax data server
agg_util::AggMemberDatasetUsingLocationRef Class Reference

#include <AggMemberDatasetUsingLocationRef.h>

Inheritance diagram for agg_util::AggMemberDatasetUsingLocationRef:
Inheritance graph
Collaboration diagram for agg_util::AggMemberDatasetUsingLocationRef:
Collaboration graph

Public Member Functions

void addPreDeleteCB (UseCountHitZeroCB *pCB)
 
 AggMemberDatasetUsingLocationRef (const AggMemberDatasetUsingLocationRef &proto)
 
 AggMemberDatasetUsingLocationRef (const std::string &locationToLoad, const agg_util::DDSLoader &loaderToUse)
 
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)
 
AggMemberDatasetUsingLocationRefoperator= (const AggMemberDatasetUsingLocationRef &rhs)
 
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
 

Detailed Description

class AggMemberDatasetUsingLocationRef: Concrete subclass of AggMemberDataset for lazy-loading a location (file) if the DDS for the given dataset is needed.

Note: assignment and copy construction do not copy any loaded DDS, merely the location. Therefore, if getDDS() is used for one of these and modified, a copy of this will see the ORIGINAL dataset (will reload it) and NOT any changes to the version it copied from!

TODO Consider if we want to change the above by using an external reference count on the loaded object state...

Definition at line 61 of file AggMemberDatasetUsingLocationRef.h.

Constructor & Destructor Documentation

◆ AggMemberDatasetUsingLocationRef() [1/2]

agg_util::AggMemberDatasetUsingLocationRef::AggMemberDatasetUsingLocationRef ( const std::string & locationToLoad,
const agg_util::DDSLoader & loaderToUse )

Definition at line 49 of file AggMemberDatasetUsingLocationRef.cc.

◆ AggMemberDatasetUsingLocationRef() [2/2]

agg_util::AggMemberDatasetUsingLocationRef::AggMemberDatasetUsingLocationRef ( const AggMemberDatasetUsingLocationRef & proto)

Definition at line 60 of file AggMemberDatasetUsingLocationRef.cc.

◆ ~AggMemberDatasetUsingLocationRef()

agg_util::AggMemberDatasetUsingLocationRef::~AggMemberDatasetUsingLocationRef ( )
override

Definition at line 55 of file AggMemberDatasetUsingLocationRef.cc.

Member Function Documentation

◆ addPreDeleteCB()

void agg_util::RCObject::addPreDeleteCB ( UseCountHitZeroCB * pCB)
inherited

Add uniquely. If it is added agan, the second time is ignored.

◆ fillDimensionCacheByUsingDDS()

void agg_util::AggMemberDatasetWithDimensionCacheBase::fillDimensionCacheByUsingDDS ( )
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.

◆ flushDimensionCache()

void agg_util::AggMemberDatasetWithDimensionCacheBase::flushDimensionCache ( )
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.

◆ getCachedDimensionSize()

unsigned int agg_util::AggMemberDatasetWithDimensionCacheBase::getCachedDimensionSize ( const std::string & dimName) const
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.

Returns
the size of the dimension if found
Exceptions
agg_util::DimensionNotFoundExceptionif not located via any means.

Implements agg_util::AggMemberDataset.

Definition at line 102 of file AggMemberDatasetWithDimensionCacheBase.cc.

◆ getDDS()

const libdap::DDS * agg_util::AggMemberDatasetUsingLocationRef::getDDS ( )
overridevirtual

If not loaded yet, loads the DDS response, then returns it.

Returns
the DDS for the location.

Implements agg_util::AggMemberDataset.

Definition at line 79 of file AggMemberDatasetUsingLocationRef.cc.

◆ getLocation()

const std::string & agg_util::AggMemberDataset::getLocation ( ) const
inherited

The location to which the AggMemberDataset refers Note: this could be "" for some subclasses if they are virtual or nested

◆ getRefCount()

virtual int agg_util::RCObject::getRefCount ( ) const
virtualinherited

Get the current reference count

Implements agg_util::RCObjectInterface.

◆ isDimensionCached()

bool agg_util::AggMemberDatasetWithDimensionCacheBase::isDimensionCached ( const std::string & dimName) const
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.

◆ loadDimensionCache()

void agg_util::AggMemberDatasetWithDimensionCacheBase::loadDimensionCache ( std::istream & istr)
virtualinherited

Load the values in the dimension cache from the input stream

Implements agg_util::AggMemberDataset.

Definition at line 173 of file AggMemberDatasetWithDimensionCacheBase.cc.

◆ operator=()

AggMemberDatasetUsingLocationRef & agg_util::AggMemberDatasetUsingLocationRef::operator= ( const AggMemberDatasetUsingLocationRef & rhs)

Definition at line 66 of file AggMemberDatasetUsingLocationRef.cc.

◆ ref()

virtual int agg_util::RCObject::ref ( ) const
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.

◆ removeFromPool()

virtual void agg_util::RCObject::removeFromPool ( ) const
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.

◆ removePreDeleteCB()

void agg_util::RCObject::removePreDeleteCB ( UseCountHitZeroCB * pCB)
inherited

Remove it exists. If not, this unchanged.

◆ saveDimensionCache()

void agg_util::AggMemberDatasetWithDimensionCacheBase::saveDimensionCache ( std::ostream & ostr)
virtualinherited

Append the values in the dimension cache to the output stream

Implements agg_util::AggMemberDataset.

Definition at line 167 of file AggMemberDatasetWithDimensionCacheBase.cc.

◆ setDimensionCacheFor()

void agg_util::AggMemberDatasetWithDimensionCacheBase::setDimensionCacheFor ( const Dimension & dim,
bool throwIfFound )
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.

Parameters
dimthe dimension to seed
iftrue, throw if name take. Else replace original.

Implements agg_util::AggMemberDataset.

Definition at line 122 of file AggMemberDatasetWithDimensionCacheBase.cc.

◆ toString()

◆ unref()

virtual int agg_util::RCObject::unref ( ) const
virtualinherited

Decrease the reference count by one. If it goes from 1 to 0, delete this and this is no longer valid.

Returns
the new ref count. If it is 0, the caller knows the object was deleted.

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.


The documentation for this class was generated from the following files: