RSB  0.17.0
OutConnector.cpp
Go to the documentation of this file.
1 /* ============================================================
2  *
3  * This file is part of the RSB project
4  *
5  * Copyright (C) 2011, 2012, 2013, 2015 Jan Moringen <jmoringe@techfak.uni-bielefeld.de>
6  *
7  * This file may be licensed under the terms of the
8  * GNU Lesser General Public License Version 3 (the ``LGPL''),
9  * or (at your option) any later version.
10  *
11  * Software distributed under the License is distributed
12  * on an ``AS IS'' basis, WITHOUT WARRANTY OF ANY KIND, either
13  * express or implied. See the LGPL for the specific language
14  * governing rights and limitations.
15  *
16  * You should have received a copy of the LGPL along with this
17  * program. If not, go to http://www.gnu.org/licenses/lgpl.html
18  * or write to the Free Software Foundation, Inc.,
19  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20  *
21  * The development of this software was supported by:
22  * CoR-Lab, Research Institute for Cognition and Robotics
23  * Bielefeld University
24  *
25  * ============================================================ */
26 
27 #include "OutConnector.h"
28 
29 #include <boost/format.hpp>
30 
31 #include <rsc/os/HostInfo.h>
32 #include <rsc/os/ProcessInfo.h>
33 
34 #include "../../MetaData.h"
35 
36 using namespace std;
37 
38 using namespace rsc::logging;
39 using namespace rsc::runtime;
40 
41 namespace rsb {
42 namespace transport{
43 namespace inprocess {
44 
45 OutConnector::OutConnector(BusPtr bus) :
46  bus(bus) {
47 }
48 
49 rsb::transport::OutConnector* OutConnector::create(const Properties& /*args*/) {
50  // Seems to have confused some users.
51  // See https://code.cor-lab.de/issues/649
52  // if (args.has("converters")) {
53  // RSCWARN(logger, "`converters' property found when constructing inprocess::OutConnector. This connector does not support (or require) converters.");
54  // }
55  return new OutConnector();
56 }
57 
58 void OutConnector::setScope(const Scope& /*scope*/) {
59 }
60 
61 // Overwrites method in rsb::transport::Connector.
62 const std::string OutConnector::getTransportURL() const {
63  return boost::str(boost::format("inprocess://%1%:%2%")
64  % rsc::os::currentHostname()
65  % rsc::os::currentProcessId());
66 }
67 
68 
70 }
71 
73 }
74 
76 }
77 
79  event->mutableMetaData().setSendTime();
80  this->bus->handle(event);
81 }
82 
83 }
84 }
85 }
Specification of desired quality of service settings for sending and receiving events.
void setScope(const Scope &scope)
Sets the scope this connector will send/receive events to/from.
void setQualityOfServiceSpecs(const QualityOfServiceSpec &specs)
Requests new QoS settings for publishing events.
STL namespace.
OutConnector(BusPtr bus=getDefaultBus())
virtual const std::string getTransportURL() const
Return an URL describing the transport kind and its configuration for this connector.
void handle(rsb::EventPtr e)
Handle event.
void activate()
Activates the connector.
boost::shared_ptr< Bus > BusPtr
Definition: Bus.h:81
static rsb::transport::OutConnector * create(const rsc::runtime::Properties &args)
Objects of classes which implement this interface can be used to send events by means of one transpor...
Definition: OutConnector.h:47
boost::shared_ptr< Event > EventPtr
Definition: Event.h:264
Scope is a descriptor for a hierarchical channel of the unified bus.
Definition: Scope.h:46