A Discrete-Event Network Simulator
API
application-container.cc
Go to the documentation of this file.
1/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/*
3 * Copyright (c) 2008 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
21#include "ns3/names.h"
22#include "ns3/log.h"
24
25namespace ns3 {
26
27NS_LOG_COMPONENT_DEFINE ("ApplicationContainer");
28
30{
31}
32
34{
35 m_applications.push_back (app);
36}
37
39{
40 Ptr<Application> app = Names::Find<Application> (name);
41 m_applications.push_back (app);
42}
43
44
47{
48 return m_applications.begin ();
49}
52{
53 return m_applications.end ();
54}
55
58{
59 return m_applications.size ();
60}
63{
64 return m_applications[i];
65}
66void
68{
69 for (Iterator i = other.Begin (); i != other.End (); i++)
70 {
71 m_applications.push_back (*i);
72 }
73}
74void
76{
77 m_applications.push_back (application);
78}
79void
80ApplicationContainer::Add (std::string name)
81{
82 Ptr<Application> application = Names::Find<Application> (name);
83 m_applications.push_back (application);
84}
85
86void
88{
89 for (Iterator i = Begin (); i != End (); ++i)
90 {
91 Ptr<Application> app = *i;
92 app->SetStartTime (start);
93 }
94}
95void
97{
98 for (Iterator i = Begin (); i != End (); ++i)
99 {
100 Ptr<Application> app = *i;
101 double value = rv->GetValue ();
102 NS_LOG_DEBUG ("Start application at time " << start.GetSeconds () + value << "s");
103 app->SetStartTime (start + Seconds (value));
104 }
105}
106void
108{
109 for (Iterator i = Begin (); i != End (); ++i)
110 {
111 Ptr<Application> app = *i;
112 app->SetStopTime (stop);
113 }
114}
115
116
117} // namespace ns3
holds a vector of ns3::Application pointers.
std::vector< Ptr< Application > > m_applications
Applications smart pointers.
std::vector< Ptr< Application > >::const_iterator Iterator
Application container iterator.
ApplicationContainer()
Create an empty ApplicationContainer.
Iterator Begin(void) const
Get an iterator which refers to the first Application in the container.
Ptr< Application > Get(uint32_t i) const
Get the Ptr<Application> stored in this container at a given index.
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter.
Iterator End(void) const
Get an iterator which indicates past-the-last Application in the container.
void StartWithJitter(Time start, Ptr< RandomVariableStream > rv)
Start all of the Applications in this container at the start time given as a parameter,...
void Add(ApplicationContainer other)
Append the contents of another ApplicationContainer to the end of this container.
void Stop(Time stop)
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter.
uint32_t GetN(void) const
Get the number of Ptr<Application> stored in this container.
void SetStopTime(Time stop)
Specify application stop time.
Definition: application.cc:75
void SetStartTime(Time start)
Specify application start time.
Definition: application.cc:69
virtual double GetValue(void)=0
Get the next random value as a double drawn from the distribution.
Simulation virtual time values and global simulation resolution.
Definition: nstime.h:103
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:205
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
Definition: log.h:273
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1244
Every class exported by the ns3 library is enclosed in the ns3 namespace.
def start()
Definition: core.py:1853