RSB  0.17.0
BusServerImpl.h
Go to the documentation of this file.
1 /* ============================================================
2  *
3  * This file is part of the RSB project
4  *
5  * Copyright (C) 2011, 2012, 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 #pragma once
28 
29 #include <boost/cstdint.hpp>
30 
31 #include <boost/shared_ptr.hpp>
32 
33 #include <boost/asio.hpp>
34 #include <boost/asio/ip/tcp.hpp>
35 
36 #include <rsc/logging/Logger.h>
37 
38 #include "BusServer.h"
39 
40 #include "rsb/rsbexports.h"
41 
42 namespace rsb {
43 namespace transport {
44 namespace socket {
45 
59 class RSB_EXPORT BusServerImpl : public BusServer,
60  public boost::enable_shared_from_this<BusServerImpl> {
61 public:
63  boost::uint16_t port,
64  bool tcpnodelay);
65 
66  virtual ~BusServerImpl();
67 
74  void activate();
75 
76  void deactivate();
77 
78  void handleIncoming(EventPtr event,
79  BusConnectionPtr connection);
80 
81  virtual const std::string getTransportURL() const;
82 protected:
83  typedef boost::shared_ptr<boost::asio::ip::tcp::socket> SocketPtr;
84 private:
85 
86  rsc::logging::LoggerPtr logger;
87 
88  boost::asio::ip::tcp::acceptor acceptor;
89 
90  volatile bool active;
91  volatile bool shutdown;
92 
93  // These two member functions have the additional ref parameter to
94  // ensure that the BusServerImpl object cannot be destroyed while
95  // callbacks are executed. This also means that
96  // BusServerImpl::activate only when there is a shared_ptr owning the
97  // BusServerImpl object. See BusServerImpl::activate().
98  void acceptOne(boost::shared_ptr<BusServerImpl> ref);
99 
100  void handleAccept(boost::shared_ptr<BusServerImpl> ref,
101  SocketPtr socket,
102  const boost::system::error_code& error);
103 
104 };
105 
106 }
107 }
108 }
boost::shared_ptr< boost::asio::ip::tcp::socket > SocketPtr
Definition: BusServerImpl.h:83
boost::shared_ptr< AsioServiceContext > AsioServiceContextPtr
boost::shared_ptr< BusConnection > BusConnectionPtr
rsc::logging::LoggerPtr logger
Definition: BusServerImpl.h:86
Instances of this class provide access to a socket-based bus for local and remote bus clients...
Definition: BusServer.h:54
boost::asio::ip::tcp::acceptor acceptor
Definition: BusServerImpl.h:88
Instances of this class provide access to a socket-based bus for local and remote bus clients...
Definition: BusServerImpl.h:59
boost::shared_ptr< Event > EventPtr
Definition: Event.h:264