NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
global.hpp
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2014-2021 Regents of the University of California,
4
* Arizona Board of Regents,
5
* Colorado State University,
6
* University Pierre & Marie Curie, Sorbonne University,
7
* Washington University in St. Louis,
8
* Beijing Institute of Technology
9
*
10
* This file is part of NFD (Named Data Networking Forwarding Daemon).
11
* See AUTHORS.md for complete list of NFD authors and contributors.
12
*
13
* NFD is free software: you can redistribute it and/or modify it under the terms
14
* of the GNU General Public License as published by the Free Software Foundation,
15
* either version 3 of the License, or (at your option) any later version.
16
*
17
* NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
18
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
19
* PURPOSE. See the GNU General Public License for more details.
20
*
21
* You should have received a copy of the GNU General Public License along with
22
* NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
23
**/
24
25
#ifndef NFD_DAEMON_COMMON_GLOBAL_HPP
26
#define NFD_DAEMON_COMMON_GLOBAL_HPP
27
28
#include "
core/common.hpp
"
29
30
namespace
nfd
{
31
32
namespace
detail {
33
37
class
SimulatorIo
38
{
39
public
:
40
void
41
post
(
const
std::function<
void
()>& callback);
42
43
void
44
dispatch
(
const
std::function<
void
()>& callback);
45
};
46
47
}
// namespace detail
48
51
detail::SimulatorIo
&
52
getGlobalIoService
();
53
56
Scheduler&
57
getScheduler
();
58
59
detail::SimulatorIo
&
60
getMainIoService
();
61
62
detail::SimulatorIo
&
63
getRibIoService
();
64
67
void
68
runOnMainIoService
(
const
std::function<
void
()>& f);
69
72
void
73
runOnRibIoService
(
const
std::function<
void
()>& f);
74
75
void
76
resetGlobalScheduler
();
77
78
}
// namespace nfd
79
80
#endif // NFD_DAEMON_COMMON_GLOBAL_HPP
nfd::runOnRibIoService
void runOnRibIoService(const std::function< void()> &f)
Run a function on the RIB io_service instance.
Definition:
global.cpp:86
nfd::resetGlobalScheduler
void resetGlobalScheduler()
Definition:
global.cpp:92
nfd::getGlobalIoService
detail::SimulatorIo & getGlobalIoService()
Returns the global io_service instance for the calling thread.
Definition:
global.cpp:49
nfd::getRibIoService
detail::SimulatorIo & getRibIoService()
Definition:
global.cpp:63
nfd::runOnMainIoService
void runOnMainIoService(const std::function< void()> &f)
Run a function on the main io_service instance.
Definition:
global.cpp:80
common.hpp
nfd::getScheduler
Scheduler & getScheduler()
Returns the global Scheduler instance for the calling thread.
Definition:
global.cpp:70
nfd
Copyright (c) 2011-2015 Regents of the University of California.
Definition:
ndn-common.hpp:39
nfd::detail::SimulatorIo::post
void post(const std::function< void()> &callback)
Definition:
global.cpp:35
nfd::detail::SimulatorIo
Simulator-based IO that implements a few interfaces from boost::asio::io_service. ...
Definition:
global.hpp:37
nfd::getMainIoService
detail::SimulatorIo & getMainIoService()
Definition:
global.cpp:56
nfd::detail::SimulatorIo::dispatch
void dispatch(const std::function< void()> &callback)
Definition:
global.cpp:41
ndnSIM
NFD
daemon
common
global.hpp
Generated on Fri May 6 2022 12:34:13 for ndnSIM by
1.8.13