A ValueDataSource of which individual parts can be updated using an index. More...
#include <rtt/DataSources.hpp>
Public Types | |
typedef boost::intrusive_ptr < IndexedValueDataSource< T, Index, SetType, IPred, APred > > | shared_ptr |
Use this type to store a pointer to an AssignableDataSource. | |
typedef DataSource< T >::value_t | value_t |
The bare type of T is extracted into value_t. | |
typedef boost::call_traits < value_t >::param_type | param_t |
typedef boost::call_traits < value_t >::reference | reference_t |
typedef boost::call_traits < value_t >::const_reference | const_reference_t |
typedef boost::remove_const < typename boost::call_traits < value_t >::param_type > ::type | copy_t |
typedef boost::intrusive_ptr < const AssignableDataSource < T > > | const_ptr |
Use this type to store a const pointer to a DataSourceBase. | |
typedef T | result_t |
Public Member Functions | |
IndexedValueDataSource (T idata) | |
CommandInterface * | updateCommand (DataSourceBase *other) |
Generate a CommandInterface object which will update this DataSource with the value of another DataSource when execute()'ed. | |
CommandInterface * | updatePartCommand (DataSourceBase *index, DataSourceBase *rhs) |
Generate a CommandInterface object which will partially update this DataSource with the value of another DataSource when execute()'ed. | |
IndexedValueDataSource< T, Index, SetType, IPred, APred > * | clone () const |
Return a shallow clone of this DataSource. | |
IndexedValueDataSource< T, Index, SetType, IPred, APred > * | copy (std::map< const DataSourceBase *, DataSourceBase * > &replace) const |
Create a deep copy of this DataSource, unless it is already cloned. | |
DataSource< T >::result_t | get () const |
Return the data as type T. | |
DataSource< T >::result_t | value () const |
Return the result of the last evaluate() function. | |
void | set (typename AssignableDataSource< T >::param_t t) |
AssignableDataSource< T > ::reference_t | set () |
Get a reference (or null) to the value of this DataSource. | |
template<> | |
RTT_API void | set (AssignableDataSource< std::string >::param_t t) |
virtual void | set (param_t t)=0 |
Set this DataSource with a value. | |
AssignableDataSource< T > ::const_reference_t | rvalue () const |
Get a const reference (or null) to the value of this DataSource. | |
virtual bool | update (DataSourceBase *other) |
Update the value of this DataSource with the value of an other DataSource. | |
virtual bool | updateBlob (int protocol, const void *data) |
Updates the value of this DataSource with the value of a transportable data object. | |
virtual void * | server (int protocol, void *data) |
Create an object server which 'mirrors' this DataSource. | |
virtual bool | evaluate () const |
Force an evaluation of the DataSourceBase. | |
template<> | |
RTT_API bool | evaluate () const |
Force an evaluation of the DataSourceBase. | |
virtual std::string | getType () const |
Return useful type info in a human readable format. | |
virtual const TypeInfo * | getTypeInfo () const |
Return the Orocos type info object. | |
virtual std::string | getTypeName () const |
Return the Orocos type name, without const, pointer or reference qualifiers. | |
void | ref () const |
Increase the reference count by one. | |
void | deref () const |
Decrease the reference count by one and delete this on zero. | |
virtual void | reset () |
Reset the data to initial values. | |
virtual void | updated () |
In case the DataSource returns a 'reference' type, call this method to notify it that the data was updated in the course of an invocation of get(). | |
virtual bool | updatePart (DataSourceBase *part, DataSourceBase *other) |
Update part of the value of this DataSource with the value of an other DataSource. | |
std::ostream & | write (std::ostream &os) |
Stream the contents of this object. | |
std::string | toString () |
Get the contents of this object as a string. | |
bool | decomposeType (PropertyBag &targetbag) |
Decompose the contents of this object into properties. | |
bool | composeType (DataSourceBase::shared_ptr source) |
Compose the contents of this object from another datasource. | |
virtual void * | createBlob (int protocol) |
Creates a transportable data object with the current value of this DataSource. | |
virtual void * | getBlob (int protocol) |
Creates a transportable data object with the current value of this DataSource. | |
virtual int | serverProtocol () const |
Inspect if this DataSource is a proxy for a remote server object. | |
virtual void * | method (int protocol, MethodC *orig, void *arg) |
Create an object server which 'mirrors' this DataSource. | |
Static Public Member Functions | |
static AssignableDataSource< T > * | narrow (DataSourceBase *db) |
This method narrows a DataSourceBase to a typeded AssignableDataSource, possibly returning a new object. | |
static std::string | GetType () |
Return usefull type info in a human readable format. | |
static const TypeInfo * | GetTypeInfo () |
Return the Orocos type info. | |
static std::string | GetTypeName () |
Return the Orocos type name, without const, pointer or reference qualifiers. | |
Protected Attributes | |
DataSource< T >::value_t | mdata |
OS::AtomicInt | refcount |
We keep the refcount ourselves. |
A ValueDataSource of which individual parts can be updated using an index.
T | The type of the container. | |
Index | The type of the index into the container. | |
SetType | The type of an element of the container. | |
IPred | A predicate which checks if the index is valid. | |
APred | A predicate which checks if the container may be assigned to another container. |
Definition at line 214 of file DataSources.hpp.
IndexedValueDataSource<T, Index, SetType,IPred,APred>* RTT::IndexedValueDataSource< T, Index, SetType, IPred, APred >::clone | ( | ) | const [inline, virtual] |
Return a shallow clone of this DataSource.
This method returns a duplicate of this instance which re-uses the DataSources this DataSource holds reference to. The clone() function is thus a non-deep copy.
Reimplemented from RTT::ValueDataSource< T >.
Definition at line 265 of file DataSources.hpp.
bool RTT::DataSourceBase::composeType | ( | DataSourceBase::shared_ptr | source | ) | [inherited] |
Compose the contents of this object from another datasource.
IndexedValueDataSource<T, Index, SetType,IPred,APred>* RTT::IndexedValueDataSource< T, Index, SetType, IPred, APred >::copy | ( | std::map< const DataSourceBase *, DataSourceBase * > & | alreadyCloned | ) | const [inline, virtual] |
Create a deep copy of this DataSource, unless it is already cloned.
Places the association (parent, clone) in alreadyCloned. If the DataSource is non-copyable (for example it represents the Property of a Task ), this may be returned.
Reimplemented from RTT::ValueDataSource< T >.
Definition at line 270 of file DataSources.hpp.
virtual void* RTT::DataSourceBase::createBlob | ( | int | protocol | ) | [virtual, inherited] |
Creates a transportable data object with the current value of this DataSource.
This does not trigger the evaluation() of this data source.
Reimplemented in RTT::Corba::ExpressionProxy.
Referenced by RTT::Corba::CorbaDataObjectProxy< T >::Set().
bool RTT::DataSourceBase::decomposeType | ( | PropertyBag & | targetbag | ) | [inherited] |
Decompose the contents of this object into properties.
RTT_API bool RTT::DataSource< bool >::evaluate | ( | ) | const [inline, virtual, inherited] |
Force an evaluation of the DataSourceBase.
Implements RTT::DataSourceBase.
bool RTT::DataSource< T >::evaluate | ( | ) | const [inline, virtual, inherited] |
Force an evaluation of the DataSourceBase.
Implements RTT::DataSourceBase.
Reimplemented in RTT::detail::DataSourceAdaptor< From, To >, RTT::detail::DataSourceAdaptor< TFrom &, TFrom >, RTT::detail::DataSourceAdaptor< const TFrom &, const TFrom >, RTT::detail::DataSourceAdaptor< TFrom &, TFrom & >, RTT::detail::DataSourceAdaptor< TFrom, const TFrom & >, RTT::detail::DataSourceAdaptor< const TFrom, const TFrom & >, RTT::detail::AssignableDataSourceAdaptor< From, To >, RTT::detail::AssignableDataSourceAdaptor< From, const From & >, and RTT::detail::AssignableDataSourceAdaptor< To const &, To >.
Definition at line 52 of file DataSource.inl.
Referenced by RTT::detail::AssignableDataSourceAdaptor< To const &, To >::evaluate(), RTT::detail::AssignableDataSourceAdaptor< From, const From & >::evaluate(), RTT::detail::AssignableDataSourceAdaptor< From, To >::evaluate(), RTT::detail::DataSourceAdaptor< const TFrom, const TFrom & >::evaluate(), RTT::detail::DataSourceAdaptor< TFrom, const TFrom & >::evaluate(), RTT::detail::DataSourceAdaptor< TFrom &, TFrom & >::evaluate(), RTT::detail::DataSourceAdaptor< const TFrom &, const TFrom >::evaluate(), RTT::detail::DataSourceAdaptor< TFrom &, TFrom >::evaluate(), RTT::detail::DataSourceAdaptor< From, To >::evaluate(), and RTT::detail::AssignableDataSourceAdaptor< From, const From & >::get().
virtual void* RTT::DataSourceBase::getBlob | ( | int | protocol | ) | [virtual, inherited] |
Creates a transportable data object with the current value of this DataSource.
This does trigger the evaluation() of this data source. Equivalent to this->evaluate(); this->createBlob();
Reimplemented in RTT::Corba::ExpressionProxy.
virtual void* RTT::DataSourceBase::method | ( | int | protocol, | |
MethodC * | orig, | |||
void * | arg | |||
) | [virtual, inherited] |
Create an object server which 'mirrors' this DataSource.
Reimplemented in RTT::Corba::ExpressionProxy.
AssignableDataSource<T>::const_reference_t RTT::ValueDataSource< T >::rvalue | ( | ) | const [inline, virtual, inherited] |
Get a const reference (or null) to the value of this DataSource.
Getting a reference to an internal data structure is not thread-safe. DataSources which wish to protect their data from concurrent access may return the null reference with this method. All calls to rvalue() must first check whether they do not return null.
Implements RTT::AssignableDataSource< T >.
Definition at line 94 of file DataSources.hpp.
void * RTT::AssignableDataSource< T >::server | ( | int | protocol, | |
void * | arg | |||
) | [inline, virtual, inherited] |
Create an object server which 'mirrors' this DataSource.
Reimplemented from RTT::DataSourceBase.
Reimplemented in RTT::Corba::CORBAAssignableExpression< T >.
Definition at line 79 of file DataSource.inl.
References RTT::TypeInfo::getProtocol(), RTT::DataSource< T >::getTypeInfo(), and RTT::detail::TypeTransporter::server().
virtual int RTT::DataSourceBase::serverProtocol | ( | ) | const [virtual, inherited] |
Inspect if this DataSource is a proxy for a remote server object.
Reimplemented in RTT::Corba::AnyDataSource, RTT::Corba::CORBAExpression< T >, RTT::Corba::CORBAExpression< void >, RTT::Corba::CORBAAssignableExpression< T >, and RTT::Corba::ExpressionProxy.
Referenced by RTT::AssignableDataSource< T >::narrow(), and RTT::DataSource< T >::narrow().
RTT_API void RTT::ValueDataSource< std::string >::set | ( | AssignableDataSource< std::string >::param_t | t | ) | [inline, inherited] |
.. ) is called.
AssignableDataSource<T>::reference_t RTT::ValueDataSource< T >::set | ( | ) | [inline, virtual, inherited] |
Get a reference (or null) to the value of this DataSource.
Getting a reference to an internal data structure is not thread-safe. DataSources which wish to protect their data from concurrent access may return the null reference with this method. All calls to set() must first check whether they do not return null.
Implements RTT::AssignableDataSource< T >.
Definition at line 89 of file DataSources.hpp.
std::string RTT::DataSourceBase::toString | ( | ) | [inherited] |
Get the contents of this object as a string.
bool RTT::AssignableDataSource< T >::update | ( | DataSourceBase * | other | ) | [inline, virtual, inherited] |
Update the value of this DataSource with the value of an other DataSource.
Update does a full update of the value, adding extra information if necessary.
Reimplemented from RTT::DataSourceBase.
Definition at line 131 of file DataSource.inl.
References RTT::DataSource< T >::get().
bool RTT::AssignableDataSource< T >::updateBlob | ( | int | protocol, | |
const void * | data | |||
) | [inline, virtual, inherited] |
Updates the value of this DataSource with the value of a transportable data object.
any | The value to update to. |
Reimplemented from RTT::DataSourceBase.
Definition at line 67 of file DataSource.inl.
References RTT::TypeInfo::getProtocol(), RTT::DataSource< T >::getTypeInfo(), and RTT::detail::TypeTransporter::updateBlob().
Referenced by RTT::Corba::CorbaBufferProxy< T >::front(), RTT::Corba::CorbaDataObjectProxy< T >::Get(), RTT::Corba::ExpressionProxy::NarrowAssignableDataSource(), and RTT::Corba::ExpressionProxy::NarrowDataSource().
CommandInterface* RTT::IndexedValueDataSource< T, Index, SetType, IPred, APred >::updateCommand | ( | DataSourceBase * | other | ) | [inline, virtual] |
Generate a CommandInterface object which will update this DataSource with the value of another DataSource when execute()'ed.
Reimplemented from RTT::AssignableDataSource< T >.
Definition at line 226 of file DataSources.hpp.
virtual bool RTT::DataSourceBase::updatePart | ( | DataSourceBase * | part, | |
DataSourceBase * | other | |||
) | [virtual, inherited] |
Update part of the value of this DataSource with the value of an other DataSource.
Update does a partial update of the value, according to part, which is most likely an index or hash value of some type.
Reimplemented in RTT::detail::AssignableDataSourceAdaptor< To const &, To >.
Referenced by RTT::detail::AssignableDataSourceAdaptor< To const &, To >::updatePart().
CommandInterface* RTT::IndexedValueDataSource< T, Index, SetType, IPred, APred >::updatePartCommand | ( | DataSourceBase * | part, | |
DataSourceBase * | other | |||
) | [inline, virtual] |
Generate a CommandInterface object which will partially update this DataSource with the value of another DataSource when execute()'ed.
part is an index or hash value of some type.
Reimplemented from RTT::DataSourceBase.
Definition at line 241 of file DataSources.hpp.
std::ostream& RTT::DataSourceBase::write | ( | std::ostream & | os | ) | [inherited] |
Stream the contents of this object.
OS::AtomicInt RTT::DataSourceBase::refcount [mutable, protected, inherited] |
We keep the refcount ourselves.
We aren't using boost::shared_ptr, because boost::intrusive_ptr is better, exactly because it can be used with refcounts that are stored in the class itself. Advantages are that the shared_ptr's for derived classes use the same refcount, which is of course very much desired, and that refcounting happens in an efficient way, which is also nice :)
Definition at line 89 of file DataSourceBase.hpp.