frepple::Calendar Class Reference

This is the class used to represent variables that are varying over time. More...

#include <model.h>

Inheritance diagram for frepple::Calendar:
frepple::utils::HasName< Calendar > frepple::utils::Object frepple::utils::NonCopyable frepple::utils::Tree::TreeNode frepple::CalendarPointer< Operation > frepple::CalendarValue< bool > frepple::CalendarValue< double > frepple::CalendarValue< int > frepple::CalendarValue< string > frepple::CalendarPointer< T > frepple::CalendarValue< T > frepple::CalendarVoid

List of all members.

Classes

class  Bucket
 This class represents a time bucket as a part of a calendar. More...
class  BucketIterator
 An iterator class to go through all buckets of the calendar. More...
class  EventIterator
 An iterator class to go through all dates where the calendar value changes. More...

Public Member Functions

BucketaddBucket (Date, Date, string)
BucketIterator beginBuckets () const
void beginElement (XMLInput &, const Attribute &)
 Calendar (const string &n)
BucketcreateBucket (const AttributeList &)
BucketIterator endBuckets () const
void endElement (XMLInput &pIn, const Attribute &pAttr, const DataElement &pElement)
BucketfindBucket (const string &) const
BucketfindBucket (Date d, bool fwd=true) const
virtual bool getBool () const
virtual size_t getSize () const
virtual const MetaClassgetType () const
void removeBucket (Bucket *bkt)
void writeElement (XMLOutput *, const Keyword &, mode=DEFAULT) const
 ~Calendar ()

Static Public Attributes

static const MetaCategorymetadata

Protected Member Functions

int lowestPriority () const

Detailed Description

This is the class used to represent variables that are varying over time.

Some example usages for calendars:

Definition at line 93 of file model.h.


Constructor & Destructor Documentation

frepple::Calendar::Calendar ( const string &  n  )  [inline]

Default constructor.

Definition at line 232 of file model.h.

frepple::Calendar::~Calendar (  ) 

Destructor, which cleans up the buckets too and all references to the calendar from the core model.

Definition at line 42 of file calendar.cpp.


Member Function Documentation

Calendar::Bucket * frepple::Calendar::addBucket ( Date  start,
Date  end,
string  name 
)

Adds a new bucket to the list.

Definition at line 81 of file calendar.cpp.

BucketIterator frepple::Calendar::beginBuckets (  )  const [inline]

Returns an iterator to go through the list of buffers.

Definition at line 322 of file model.h.

void frepple::Calendar::beginElement ( XMLInput ,
const Attribute  
) [virtual]

Called while restoring the model from an XML-file.
This is called for each element within the "this" element, for which the "this" element is immediate parent.
It is called when the open element tag is encountered.

Reimplemented from frepple::utils::Object.

Reimplemented in frepple::CalendarPointer< T >.

Definition at line 260 of file calendar.cpp.

Calendar::Bucket * frepple::Calendar::createBucket ( const AttributeList atts  ) 

This is a factory method that creates a new bucket using the start date as the key field. The fields are passed as an array of character pointers.
This method is intended to be used to create objects when reading XML input data.

Definition at line 200 of file calendar.cpp.

BucketIterator frepple::Calendar::endBuckets (  )  const [inline]

Returns an iterator to go through the list of buffers.

Definition at line 325 of file model.h.

void frepple::Calendar::endElement ( XMLInput ,
const Attribute ,
const DataElement  
) [inline, virtual]

Called while restoring the model from an XML-file.
This is called when the corresponding close element tag is encountered, and the Data() member of pElement is valid.

Implements frepple::utils::Object.

Reimplemented in frepple::CalendarValue< T >, and frepple::CalendarPointer< T >.

Definition at line 328 of file model.h.

Calendar::Bucket * frepple::Calendar::findBucket ( const string &  d  )  const

Returns the bucket with a certain name. A NULL pointer is returned in case no bucket can be found with the given name.

Definition at line 166 of file calendar.cpp.

Calendar::Bucket * frepple::Calendar::findBucket ( Date  d,
bool  fwd = true 
) const

Returns the bucket where a certain date belongs to. A bucket will always be returned, i.e. the data structure is such that we all dates between infinitePast and infiniteFuture match with one (and only one) bucket.

Definition at line 142 of file calendar.cpp.

virtual bool frepple::Calendar::getBool (  )  const [inline, virtual]
virtual size_t frepple::Calendar::getSize (  )  const [inline, virtual]

Return the memory size of the object in bytes.

Implements frepple::utils::Object.

Reimplemented in frepple::CalendarString.

Definition at line 334 of file model.h.

virtual const MetaClass& frepple::Calendar::getType (  )  const [inline, virtual]
int frepple::Calendar::lowestPriority (  )  const [inline, protected]

Find the lowest priority of any bucket.

Definition at line 344 of file model.h.

void frepple::Calendar::removeBucket ( Calendar::Bucket bkt  ) 

Removes a bucket from the list.

Definition at line 115 of file calendar.cpp.

void frepple::Calendar::writeElement ( XMLOutput ,
const Keyword ,
mode  = DEFAULT 
) const [virtual]

Called while writing the model into an XML-file. The user class should write itself out, using the IOutStream members for its "simple" members and calling writeElement recursively for any contained objects. Not all classes are expected to implement this method. In instances of such a class can be created but can't be persisted. E.g. Command

Reimplemented from frepple::utils::Object.

Reimplemented in frepple::CalendarValue< T >, and frepple::CalendarPointer< T >.

Definition at line 174 of file calendar.cpp.


Member Data Documentation


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

Generated on 25 Sep 2009 for frePPLe by  doxygen 1.6.1