A Discrete-Event Network Simulator
Home
Tutorials ▼
English
Portuguese
Docs ▼
Wiki
Manual
Models
Develop ▼
API
Bugs
API
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Groups
Pages
watchdog.cc
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2007 INRIA
4
*
5
* This program is free software; you can redistribute it and/or modify
6
* it under the terms of the GNU General Public License version 2 as
7
* published by the Free Software Foundation;
8
*
9
* This program is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
13
*
14
* You should have received a copy of the GNU General Public License
15
* along with this program; if not, write to the Free Software
16
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17
*
18
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
19
*/
20
#include "
watchdog.h
"
21
#include "
log.h
"
22
23
NS_LOG_COMPONENT_DEFINE
(
"Watchdog"
);
24
25
namespace
ns3 {
26
27
Watchdog::Watchdog
()
28
: m_impl (0),
29
m_event (),
30
m_end (
MicroSeconds
(0))
31
{
32
NS_LOG_FUNCTION_NOARGS
();
33
}
34
35
Watchdog::~Watchdog
()
36
{
37
NS_LOG_FUNCTION
(
this
);
38
delete
m_impl
;
39
}
40
41
void
42
Watchdog::Ping
(
Time
delay)
43
{
44
NS_LOG_FUNCTION
(
this
<< delay);
45
Time
end =
Simulator::Now
() + delay;
46
m_end
= std::max (
m_end
, end);
47
if
(
m_event
.
IsRunning
())
48
{
49
return
;
50
}
51
m_event
=
Simulator::Schedule
(
m_end
-
Now
(), &
Watchdog::Expire
,
this
);
52
}
53
54
void
55
Watchdog::Expire
(
void
)
56
{
57
NS_LOG_FUNCTION
(
this
);
58
if
(
m_end
==
Simulator::Now
())
59
{
60
m_impl
->
Invoke
();
61
}
62
else
63
{
64
m_event
=
Simulator::Schedule
(
m_end
-
Now
(), &
Watchdog::Expire
,
this
);
65
}
66
}
67
68
}
// namespace ns3
69
ns3::Time
Simulation virtual time values and global simulation resolution.
Definition:
nstime.h:95
NS_LOG_FUNCTION
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by "...
Definition:
log-macros-enabled.h:207
ns3::Watchdog::m_end
Time m_end
Definition:
watchdog.h:132
ns3::Watchdog::Ping
void Ping(Time delay)
Definition:
watchdog.cc:42
NS_LOG_COMPONENT_DEFINE
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition:
log.h:170
ns3::Watchdog::m_event
EventId m_event
Definition:
watchdog.h:131
ns3::EventId::IsRunning
bool IsRunning(void) const
This method is syntactic sugar for the ns3::Simulator::isExpired method.
Definition:
event-id.cc:59
NS_LOG_FUNCTION_NOARGS
#define NS_LOG_FUNCTION_NOARGS()
Output the name of the function.
Definition:
log-macros-enabled.h:170
ns3::Simulator::Schedule
static EventId Schedule(Time const &time, MEM mem_ptr, OBJ obj)
Schedule an event to expire at the relative time "time" is reached.
Definition:
simulator.h:825
watchdog.h
ns3::Watchdog::Watchdog
Watchdog()
Definition:
watchdog.cc:27
ns3::Watchdog::~Watchdog
~Watchdog()
Definition:
watchdog.cc:35
ns3::Simulator::Now
static Time Now(void)
Return the "current simulation time".
Definition:
simulator.cc:180
ns3::Watchdog::m_impl
TimerImpl * m_impl
Definition:
watchdog.h:130
ns3::Now
Time Now(void)
create an ns3::Time instance which contains the current simulation time.
Definition:
simulator.cc:287
ns3::TimerImpl::Invoke
virtual void Invoke(void)=0
ns3::MicroSeconds
Time MicroSeconds(uint64_t value)
Construct a Time in the indicated unit.
Definition:
nstime.h:861
log.h
ns3::Watchdog::Expire
void Expire(void)
Definition:
watchdog.cc:55
src
core
model
watchdog.cc
Generated on Wed Sep 17 2014 23:33:23 for ns-3 by
1.8.6