OrocosComponentLibrary
2.9.0
|
A component which writes data reports to a tcp/ip socket. More...
#include <TcpReporting.hpp>
Public Types | |
typedef RTT::DataFlowInterface::Ports | Ports |
Public Member Functions | |
TcpReporting (std::string fr_name="ReportingComponent") | |
Create a reporting component which starts up a server. More... | |
bool | configureHook () |
Implementation of base::TaskCore::configureHook(). More... | |
bool | startHook () |
void | stopHook () |
const RTT::PropertyBag * | getReport () |
Return a property bag. | |
bool | addMarshaller (RTT::marsh::MarshallInterface *headerM, RTT::marsh::MarshallInterface *bodyM) |
Adds a Plugin to receive incomming data. More... | |
bool | removeMarshallers () |
Remove and delete all added Marshallers. | |
Script Methods | |
virtual void | cleanupHook () |
Implementation of base::TaskCore::cleanupHook(). More... | |
virtual bool | screenComponent (const std::string &comp) |
Write state information of a component. More... | |
bool | reportComponent (const std::string &component) |
Report all the data ports of a component. | |
bool | unreportComponent (const std::string &component) |
Unreport the data ports of a component. | |
bool | reportPort (const std::string &component, const std::string &port) |
Report a specific data port of a component. | |
bool | unreportPort (const std::string &component, const std::string &port) |
Unreport a specific data port of a component. | |
bool | reportData (const std::string &component, const std::string &dataname) |
Report a specific data source of a component. | |
bool | unreportData (const std::string &component, const std::string &datasource) |
Unreport a specific data source of a component. | |
bool | copydata () |
This real-time function makes copies of the data to be reported. More... | |
void | snapshot () |
Copy the reported data and trigger the generation of a sampling line. | |
void | cleanReport () |
Implementation of base::TaskCore::configureHook(). More... | |
Protected Types | |
enum | T_Types { T_QualName = 0, T_PortDS, T_DataType, T_Property, T_Port, T_NewData, T_Tracked } |
Use these to index DTupple objects. | |
typedef boost::tuple< std::string, RTT::base::DataSourceBase::shared_ptr, std::string, RTT::base::PropertyBase *, RTT::base::InputPortInterface *, bool, bool > | DTupple |
tuple that describes each sample. More... | |
typedef std::vector< DTupple > | Reports |
Stores the 'datasource' of all reported items as properties. | |
typedef std::vector< std::pair< boost::shared_ptr< RTT::marsh::MarshallInterface >, boost::shared_ptr< RTT::marsh::MarshallInterface > > > | Marshallers |
Protected Member Functions | |
bool | screenImpl (const std::string &comp, std::ostream &output) |
This method writes out the status of a component's interface. | |
bool | reportDataSource (std::string tag, std::string type, RTT::base::DataSourceBase::shared_ptr origm, RTT::base::InputPortInterface *ipi, bool) |
bool | unreportDataSource (std::string tag) |
void | makeReport2 () |
virtual void | updateHook () |
This not real-time function processes the copied data. | |
Protected Attributes | |
RTT::SocketMarshaller * | fbody |
marsh::MarshallInterface | |
Reports | root |
Marshallers | marshallers |
RTT::PropertyBag | report |
bool | snapshotted |
Used to communicate between snapshot() and updateHook() if updateHook needs to make a copy. | |
RTT::Property< std::string > | config |
RTT::Property< bool > | writeHeader |
RTT::Property< bool > | decompose |
RTT::Property< bool > | insnapshot |
RTT::Property< bool > | synchronize_with_logging |
RTT::Property< PropertyBag > | report_data |
RTT::ConnPolicy | report_policy |
bool | onlyNewData |
RTT::os::TimeService::ticks | starttime |
RTT::Property< RTT::os::TimeService::Seconds > | timestamp |
RTT::internal::DataSource< bool >::shared_ptr | mchecker |
If false, a sequence size has changed. | |
A component which writes data reports to a tcp/ip socket.
It can serve different clients. It uses a ASCI-based protocol.
The server accepts different kinds of commands. Before these commands are available for the client, the client has to authenticate itself.
"VERSION 1.0\n"
"101 OK\n"
"106 not supported\n"
The client can get the available commands
"HELP\n"
"Use HELP <command>\n CommandName1\n CommandName2\n ... CommandNameN\n."
and the syntax for each command.
"HELP CommandName\n"
"Name: CommandName\n Usage: CommandName CommandSyntax\n"
The client can get the names of all the available data.
"HEADERS\n"
"305 DataName1\n 305 DataName2\n ... 305 DataNameN\n 306 End of list\n"
The client has to send the server the names of the available data he wants to get. Only the subscribed data will be send to the client.
"SUBSCRIBE DataNameX\n"
"302 DataNameX\n"
"301 DataNameX\n"
The client can cancel a subscription.
"UNSUBSCRIBE DataNameX\n"
"303 DataNameX\n"
"304 DataNameX\n"
The client can ask for the subscriptions he has made.
"SUBS\n"
"305 DataNameX1\n 305 DataNameX2\n ... 305 DataNameXN\n 306 End of list\n"
The client can start and stop the streaming of the subscribed data.
"SILENCE OFF\n"-To stop:
"SILENCE ON\n"
"107 SILENCE ON/OFF\n"
The client can close the connection with the server.
"QUIT\n"or
"EXIT\n"
"104 Bye Bye\n"
When an error occurs because of wrong syntax the server will answer with an error message.
"102 Syntax: CommandNameX CommandSyntaxX\n"
When the streaming is started the server will send the following message at each timeframe.
"201 framenr --- begin of frame\n 202 DataNameX1\n 205 DataValueX1\n 202 DataNameX2\n 205 DataValueX2\n ... 202 DataNameXN\n 205 DataValueXN\n 203 framenr --- end of frame\n"
Definition at line 170 of file TcpReporting.hpp.
|
protectedinherited |
tuple that describes each sample.
Uses get<N>() to read it: @0 The qualified name of the data (componentname.portname) @1 The data source of the data. Always returns the last value. @2 A copy command to copy from this data source to another one @3 The target data source for the copy operation @4 The type of the data, "Data" (props and attrs) or "Port". @5 'newdata': The new data flag. Flags if the DataSource contains new data. @6 'tracked': True if this source may lead to additional data. If false, the source in itself will not cause to a re-scan. Used in copydata() to allow ports to be rescanned, while props and attrs never cause this (they always have newdata, but this is ignored).
Definition at line 204 of file ReportingComponent.hpp.
TcpReporting | ( | std::string | fr_name = "ReportingComponent" | ) |
Create a reporting component which starts up a server.
fr_name | Name of the TCP reporting component. |
port | Port to listen on. |
Definition at line 214 of file TcpReporting.cpp.
|
inherited |
Adds a Plugin to receive incomming data.
The marshallers become owned by this component.
header | A marshaller which writes out a header when this component is started. May be null (0). |
body | A marshaller wich will get periodically a serialisation request to process incomming data. May be null(0). |
example: addMarshaller( new HeaderMarshaller(), new ContentsMarshaller() );
Definition at line 216 of file ReportingComponent.cpp.
Referenced by TcpReporting::configureHook(), and ConsoleReporting::ConsoleReporting().
|
inherited |
Implementation of base::TaskCore::configureHook().
Calls load().
Definition at line 643 of file ReportingComponent.cpp.
Referenced by ReportingComponent::updateHook().
|
virtualinherited |
Implementation of base::TaskCore::cleanupHook().
Calls store() and clears the reporting configuration.
Definition at line 237 of file ReportingComponent.cpp.
|
virtual |
Implementation of base::TaskCore::configureHook().
Calls load().
Reimplemented from ReportingComponent.
Definition at line 232 of file TcpReporting.cpp.
References ReportingComponent::addMarshaller(), TcpReporting::fbody, and ReportingComponent::removeMarshallers().
|
inherited |
This real-time function makes copies of the data to be reported.
Definition at line 597 of file ReportingComponent.cpp.
References ReportingComponent::mchecker, and OCL::memberDecomposition().
Referenced by ReportingComponent::unreportData(), and ReportingComponent::updateHook().
|
virtualinherited |
Write state information of a component.
This method must be overridden by a subclass to be useful.
Reimplemented in FileReporting, and ConsoleReporting.
Definition at line 301 of file ReportingComponent.cpp.
Referenced by ReportingComponent::ReportingComponent().