NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.0: NDN, CCN, CCNx, content centric networks
API Documentation
unix-stream-transport.cpp
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
27 
28 namespace nfd {
29 namespace face {
30 
32  "UnixStreamTransport");
33 
34 UnixStreamTransport::UnixStreamTransport(protocol::socket&& socket)
35  : StreamTransport(std::move(socket))
36 {
37  static_assert(
38  std::is_same<std::remove_cv<protocol::socket::native_handle_type>::type, int>::value,
39  "The native handle type for UnixStreamTransport sockets must be 'int'"
40  );
41 
42  this->setLocalUri(FaceUri(m_socket.local_endpoint()));
43  this->setRemoteUri(FaceUri::fromFd(m_socket.native_handle()));
44  this->setScope(ndn::nfd::FACE_SCOPE_LOCAL);
45  this->setPersistency(ndn::nfd::FACE_PERSISTENCY_ON_DEMAND);
46  this->setLinkType(ndn::nfd::LINK_TYPE_POINT_TO_POINT);
47  this->setMtu(MTU_UNLIMITED);
48 
49  NFD_LOG_FACE_INFO("Creating transport");
50 }
51 
52 void
53 UnixStreamTransport::beforeChangePersistency(ndn::nfd::FacePersistency newPersistency)
54 {
55  if (newPersistency != ndn::nfd::FACE_PERSISTENCY_ON_DEMAND) {
56  BOOST_THROW_EXCEPTION(
57  std::invalid_argument("UnixStreamTransport supports only FACE_PERSISTENCY_ON_DEMAND"));
58  }
59 }
60 
61 } // namespace face
62 } // namespace nfd
const ssize_t MTU_UNLIMITED
indicates the transport has no limit on payload size
Definition: transport.hpp:95
represents the underlying protocol and address used by a Face
Definition: face-uri.hpp:44
STL namespace.
Implements Transport for stream-based protocols.
#define NFD_LOG_FACE_INFO(msg)
Log a message at INFO level.
Definition: face-log.hpp:80
Copyright (c) 2011-2015 Regents of the University of California.
Definition: ndn-common.hpp:40
#define NFD_LOG_INCLASS_TEMPLATE_SPECIALIZATION_DEFINE(cls, specialization, name)
Definition: logger.hpp:46
static FaceUri fromFd(int fd)
create fd FaceUri from file descriptor
Definition: face-uri.cpp:144