a transport using Unix stream socket
More...
#include <ndn-cxx/transport/unix-transport.hpp>
a transport using Unix stream socket
Definition at line 41 of file unix-transport.hpp.
◆ ErrorCallback
◆ ReceiveCallback
◆ UnixTransport()
ndn::UnixTransport::UnixTransport |
( |
const std::string & |
unixSocket | ) |
|
|
explicit |
◆ ~UnixTransport()
ndn::UnixTransport::~UnixTransport |
( |
| ) |
|
|
overridedefault |
◆ close()
void ndn::UnixTransport::close |
( |
| ) |
|
|
overridevirtual |
◆ connect()
void ndn::UnixTransport::connect |
( |
boost::asio::io_service & |
ioService, |
|
|
ReceiveCallback |
receiveCallback |
|
) |
| |
|
overridevirtual |
Asynchronously open the connection.
- Parameters
-
ioService | io_service to create socket on |
receiveCallback | callback function when a TLV block is received; must not be empty |
- Exceptions
-
boost::system::system_error | connection cannot be established |
Reimplemented from ndn::Transport.
Definition at line 76 of file unix-transport.cpp.
◆ create()
shared_ptr< UnixTransport > ndn::UnixTransport::create |
( |
const std::string & |
uri | ) |
|
|
static |
Create transport with parameters defined in URI.
- Exceptions
-
Definition at line 70 of file unix-transport.cpp.
◆ isConnected()
bool ndn::Transport::isConnected |
( |
| ) |
const |
|
inlinenoexceptinherited |
- Return values
-
true | connection has been established |
false | connection is not yet established or has been closed |
Definition at line 98 of file transport.hpp.
◆ isReceiving()
bool ndn::Transport::isReceiving |
( |
| ) |
const |
|
inlinenoexceptinherited |
- Return values
-
true | incoming packets are expected, the receive callback will be invoked |
false | incoming packets are not expected, the receive callback will not be invoked |
Definition at line 107 of file transport.hpp.
◆ pause()
void ndn::UnixTransport::pause |
( |
| ) |
|
|
overridevirtual |
pause the transport
- Postcondition
- the receive callback will not be invoked
- Note
- This operation has no effect if transport has been paused, or when connection is being established.
Implements ndn::Transport.
Definition at line 112 of file unix-transport.cpp.
◆ resume()
void ndn::UnixTransport::resume |
( |
| ) |
|
|
overridevirtual |
resume the transport
- Postcondition
- the receive callback will be invoked
- Note
- This operation has no effect if transport is not paused, or when connection is being established.
Implements ndn::Transport.
Definition at line 121 of file unix-transport.cpp.
◆ send() [1/2]
void ndn::UnixTransport::send |
( |
const Block & |
wire | ) |
|
|
overridevirtual |
◆ send() [2/2]
void ndn::UnixTransport::send |
( |
const Block & |
header, |
|
|
const Block & |
payload |
|
) |
| |
|
overridevirtual |
send two memory blocks through the transport
Scatter/gather API is utilized to send two non-consecutive memory blocks together (as part of the same message in datagram-oriented transports).
Implements ndn::Transport.
Definition at line 96 of file unix-transport.cpp.
◆ m_ioService
boost::asio::io_service* ndn::Transport::m_ioService = nullptr |
|
protectedinherited |
◆ m_isConnected
bool ndn::Transport::m_isConnected = false |
|
protectedinherited |
◆ m_isReceiving
bool ndn::Transport::m_isReceiving = false |
|
protectedinherited |
◆ m_receiveCallback