A Discrete-Event Network Simulator
API
packet-sink-helper.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 "packet-sink-helper.h"
22 #include "ns3/string.h"
23 #include "ns3/inet-socket-address.h"
24 #include "ns3/names.h"
25 
26 namespace ns3 {
27 
29 {
30  m_factory.SetTypeId ("ns3::PacketSink");
31  m_factory.Set ("Protocol", StringValue (protocol));
32  m_factory.Set ("Local", AddressValue (address));
33 }
34 
35 void
36 PacketSinkHelper::SetAttribute (std::string name, const AttributeValue &value)
37 {
38  m_factory.Set (name, value);
39 }
40 
43 {
44  return ApplicationContainer (InstallPriv (node));
45 }
46 
48 PacketSinkHelper::Install (std::string nodeName) const
49 {
50  Ptr<Node> node = Names::Find<Node> (nodeName);
51  return ApplicationContainer (InstallPriv (node));
52 }
53 
56 {
58  for (NodeContainer::Iterator i = c.Begin (); i != c.End (); ++i)
59  {
60  apps.Add (InstallPriv (*i));
61  }
62 
63  return apps;
64 }
65 
68 {
70  node->AddApplication (app);
71 
72  return app;
73 }
74 
75 } // namespace ns3
a polymophic address class
Definition: address.h:91
AttributeValue implementation for Address.
Definition: address.h:278
holds a vector of ns3::Application pointers.
void Add(ApplicationContainer other)
Append the contents of another ApplicationContainer to the end of this container.
The base class for all ns3 applications.
Definition: application.h:61
Hold a value for an Attribute.
Definition: attribute.h:69
keep track of a set of node pointers.
Iterator Begin(void) const
Get an iterator which refers to the first Node in the container.
Iterator End(void) const
Get an iterator which indicates past-the-last Node in the container.
std::vector< Ptr< Node > >::const_iterator Iterator
Node container iterator.
uint32_t AddApplication(Ptr< Application > application)
Associate an Application to this Node.
Definition: node.cc:159
void Set(const std::string &name, const AttributeValue &value, Args &&... args)
Set an attribute to be set during construction.
Ptr< Object > Create(void) const
Create an Object instance of the configured TypeId.
void SetTypeId(TypeId tid)
Set the TypeId of the Objects to be created by this factory.
void SetAttribute(std::string name, const AttributeValue &value)
Helper function used to set the underlying application attributes.
ApplicationContainer Install(NodeContainer c) const
Install an ns3::PacketSinkApplication on each node of the input container configured with all the att...
ObjectFactory m_factory
Object factory.
PacketSinkHelper(std::string protocol, Address address)
Create a PacketSinkHelper to make it easier to work with PacketSinkApplications.
Ptr< Application > InstallPriv(Ptr< Node > node) const
Install an ns3::PacketSink on the node configured with all the attributes set with SetAttribute.
Hold variables of type string.
Definition: string.h:41
address
Definition: first.py:44
Every class exported by the ns3 library is enclosed in the ns3 namespace.