Orocos Real-Time Toolkit
2.5.0
|
Base class for all properties. More...
#include <rtt/base/PropertyBase.hpp>
Public Member Functions | |
virtual | ~PropertyBase () |
The default destructor. | |
PropertyBase (std::string name, std::string description) | |
The constructor. | |
PropertyBase () | |
Create an uninitialised PropertyBase. | |
const std::string & | getName () const |
Get the name of the property. | |
void | setName (const std::string &name) |
Set the name of the property. | |
const std::string & | getDescription () const |
Get a description of the property. | |
void | setDescription (const std::string &desc) |
Set the description of the property. | |
bool | ready () const |
Inspect if this Property is correctly initialised and ready for usage. | |
virtual void | identify (PropertyIntrospection *pi)=0 |
A call on this method will lead to a call to the PropertyIntrospection interface identifying this Property's proper type. | |
virtual void | identify (PropertyBagVisitor *pi) |
A call on this method will lead to a call to the PropertyBagIntrospection interface identifying this Property's proper type. | |
virtual bool | update (const PropertyBase *other)=0 |
Update the value of this Property with the value of an other Property. | |
virtual bool | refresh (const PropertyBase *other)=0 |
Refresh the value of this Property with the value of an other Property. | |
virtual bool | copy (const PropertyBase *other)=0 |
Copy an other Property onto this property. | |
virtual bool | compose (const PropertyBag &source) |
Composes the data of this property with information found in a PropertyBag. | |
virtual PropertyBase * | clone () const =0 |
Deliver an identical clone of this PropertyBase. | |
virtual PropertyBase * | create () const =0 |
Create a new default instance of the PropertyBase. | |
virtual DataSourceBase::shared_ptr | getDataSource () const =0 |
Get a internal::DataSource through which this PropertyBase can be manipulated. | |
virtual std::string | getType () const =0 |
Returns the type of this PropertyBase. | |
virtual const types::TypeInfo * | getTypeInfo () const =0 |
Returns the types::TypeInfo object of this Property. | |
Protected Attributes | |
std::string | _name |
A short name for this PropertyBase. | |
std::string | _description |
A lengthy description for this PropertyBase. |
Base class for all properties.
Definition at line 56 of file PropertyBase.hpp.
RTT::PropertyBase::PropertyBase | ( | std::string | name, |
std::string | description | ||
) |
The constructor.
name | The name which will be used to refer to this property. |
description | A more elaborate description of the property. |
Definition at line 55 of file PropertyBase.cpp.
virtual PropertyBase* RTT::base::PropertyBase::clone | ( | ) | const [pure virtual] |
Deliver an identical clone of this PropertyBase.
The original may be deleted and the clone can be transparantly used in its place or vice versa.
Implemented in RTT::Property< T >, and RTT::Property< bool >.
Referenced by RTT::marsh::PropertyBagIntrospector::introspect(), and RTT::PropertyBag::PropertyBag().
bool RTT::PropertyBase::compose | ( | const PropertyBag & | source | ) | [virtual] |
Composes the data of this property with information found in a PropertyBag.
This only works for data types that defined a compose/decompose function in their type info structure.
Definition at line 80 of file PropertyBase.cpp.
References getDataSource(), and RTT::base::DataSourceBase::ref().
virtual bool RTT::base::PropertyBase::copy | ( | const PropertyBase * | other | ) | [pure virtual] |
Copy an other Property onto this property.
Copy does a full update of the name, description and value, adding extra information if necessary, or in case of a Property<PropertyBag> adding all Properties.
Copy only works on properties that are ready() and both have the same data type T.
Implemented in RTT::Property< T >, and RTT::Property< bool >.
Referenced by RTT::copyProperties().
virtual PropertyBase* RTT::base::PropertyBase::create | ( | ) | const [pure virtual] |
Create a new default instance of the PropertyBase.
This is a factory method to 'make something of the same type'. The new PropertyBase has the same name and description as this.
Implemented in RTT::Property< T >, and RTT::Property< bool >.
Referenced by RTT::copyProperties(), RTT::updateProperties(), and RTT::updateProperty().
const std::string& RTT::base::PropertyBase::getDescription | ( | ) | const [inline] |
Get a description of the property.
Definition at line 94 of file PropertyBase.hpp.
Referenced by RTT::types::composePropertyBag(), RTT::Property< bool >::copy(), RTT::types::decomposePropertyBag(), RTT::marsh::PropertyBagIntrospector::introspect(), RTT::base::PropertyBagVisitor::introspectAndDecompose(), RTT::Property< bool >::operator=(), RTT::Property< bool >::update(), and RTT::updateProperties().
const std::string& RTT::base::PropertyBase::getName | ( | ) | const [inline] |
Get the name of the property.
Definition at line 82 of file PropertyBase.hpp.
Referenced by RTT::ConfigurationInterface::addProperty(), RTT::types::composeProperty(), RTT::types::composePropertyBag(), RTT::Property< bool >::copy(), RTT::types::decomposePropertyBag(), RTT::flattenPropertyBag(), RTT::marsh::PropertyBagIntrospector::introspect(), RTT::base::PropertyBagVisitor::introspectAndDecompose(), RTT::operator<<(), RTT::Property< bool >::operator=(), RTT::Property< bool >::Property(), RTT::refreshProperties(), RTT::refreshProperty(), RTT::ConfigurationInterface::removeProperty(), RTT::updateProperties(), and RTT::updateProperty().
virtual std::string RTT::base::PropertyBase::getType | ( | ) | const [pure virtual] |
Returns the type of this PropertyBase.
Uses the naming scheme of DataSourceTypeInfo.
Implemented in RTT::Property< T >, and RTT::Property< bool >.
Referenced by RTT::types::composeProperty(), RTT::extras::composeProperty(), RTT::types::composePropertyBag(), RTT::types::decomposePropertyBag(), and RTT::refreshProperties().
virtual void RTT::base::PropertyBase::identify | ( | PropertyIntrospection * | pi | ) | [pure virtual] |
A call on this method will lead to a call to the PropertyIntrospection interface identifying this Property's proper type.
Implemented in RTT::Property< T >, and RTT::Property< bool >.
Referenced by RTT::Property< T >::identify().
void RTT::PropertyBase::identify | ( | PropertyBagVisitor * | pi | ) | [virtual] |
A call on this method will lead to a call to the PropertyBagIntrospection interface identifying this Property's proper type.
Reimplemented in RTT::Property< T >, RTT::Property< T >, RTT::Property< bool >, and RTT::Property< T >.
Definition at line 47 of file Property.cpp.
References RTT::base::PropertyBagVisitor::introspect().
bool RTT::base::PropertyBase::ready | ( | ) | const [inline] |
Inspect if this Property is correctly initialised and ready for usage.
A Property may only be used when ready() returns true, otherwise, an exception is thrown.
Definition at line 108 of file PropertyBase.hpp.
Referenced by RTT::PropertyBag::addProperty(), RTT::ConfigurationInterface::addProperty(), RTT::types::composePropertyBag(), RTT::Property< bool >::copy(), RTT::types::decomposePropertyBag(), RTT::PropertyBag::findValue(), RTT::PropertyBag::ownProperty(), RTT::Property< bool >::refresh(), RTT::removeProperty(), and RTT::Property< bool >::update().
virtual bool RTT::base::PropertyBase::refresh | ( | const PropertyBase * | other | ) | [pure virtual] |
Refresh the value of this Property with the value of an other Property.
Refresh does only the minimal update of the value, not adding extra information, or in case of a Property<PropertyBag> not adding extra Properties.
Refresh only works on properties that are ready() and both have the same data type T.
Implemented in RTT::Property< T >, and RTT::Property< bool >.
Referenced by RTT::refreshProperty().
void RTT::PropertyBase::setDescription | ( | const std::string & | desc | ) |
Set the description of the property.
desc | The description of the property. |
Definition at line 64 of file PropertyBase.cpp.
References _description.
Referenced by RTT::Property< bool >::doc(), and RTT::Property< bool >::operator=().
void RTT::PropertyBase::setName | ( | const std::string & | name | ) |
Set the name of the property.
name | The name of the property. |
Definition at line 59 of file PropertyBase.cpp.
References _name.
Referenced by RTT::ConfigurationInterface::addProperty(), and RTT::Property< bool >::operator=().
virtual bool RTT::base::PropertyBase::update | ( | const PropertyBase * | other | ) | [pure virtual] |
Update the value of this Property with the value of an other Property.
Update does a full update of the value, adding extra information if necessary, or in case of a Property<PropertyBag> adding missing Properties.
Update only works on properties that are ready() and both have the same data type T.
Implemented in RTT::Property< T >, and RTT::Property< bool >.
Referenced by RTT::updateProperties().