A Discrete-Event Network Simulator
API
dsr-main-helper.cc
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2011 Yufei Cheng
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: Yufei Cheng <yfcheng@ittc.ku.edu>
19  *
20  * James P.G. Sterbenz <jpgs@ittc.ku.edu>, director
21  * ResiliNets Research Group http://wiki.ittc.ku.edu/resilinets
22  * Information and Telecommunication Technology Center (ITTC)
23  * and Department of Electrical Engineering and Computer Science
24  * The University of Kansas Lawrence, KS USA.
25  *
26  * Work supported in part by NSF FIND (Future Internet Design) Program
27  * under grant CNS-0626918 (Postmodern Internet Architecture),
28  * NSF grant CNS-1050226 (Multilayer Network Resilience Analysis and Experimentation on GENI),
29  * US Department of Defense (DoD), and ITTC at The University of Kansas.
30  */
31 
32 #include "dsr-main-helper.h"
33 #include "ns3/dsr-helper.h"
34 #include "ns3/dsr-routing.h"
35 #include "ns3/dsr-rcache.h"
36 #include "ns3/dsr-rreq-table.h"
37 #include "ns3/node-list.h"
38 #include "ns3/names.h"
39 #include "ns3/log.h"
40 #include "ns3/ptr.h"
41 #include "ns3/node.h"
42 
43 namespace ns3 {
44 
45 NS_LOG_COMPONENT_DEFINE ("DsrMainHelper");
46 
48  : m_dsrHelper (0)
49 {
50  NS_LOG_FUNCTION (this);
51 }
52 
54 {
55  NS_LOG_FUNCTION (this);
57 }
58 
60 {
61  NS_LOG_FUNCTION (this);
62  delete m_dsrHelper;
63 }
64 
67 {
68  if (this == &o)
69  {
70  return *this;
71  }
73  return *this;
74 }
75 
76 void
78 {
79  NS_LOG_DEBUG ("Passed node container");
80  delete m_dsrHelper;
81  m_dsrHelper = dsrHelper.Copy ();
82  for (NodeContainer::Iterator i = nodes.Begin (); i != nodes.End (); ++i)
83  {
84  Install (*i);
85  }
86 }
87 
88 void
90 {
91  NS_LOG_FUNCTION (node);
93 // Ptr<ns3::dsr::RouteCache> routeCache = CreateObject<ns3::dsr::RouteCache> ();
94 // Ptr<ns3::dsr::RreqTable> rreqTable = CreateObject<ns3::dsr::RreqTable> ();
95 // dsr->SetRouteCache (routeCache);
96 // dsr->SetRequestTable (rreqTable);
97  dsr->SetNode (node);
98 // node->AggregateObject (routeCache);
99 // node->AggregateObject (rreqTable);
100 }
101 
102 void
104 {
105  NS_LOG_FUNCTION (this);
106  delete m_dsrHelper;
107  m_dsrHelper = dsrHelper.Copy ();
108 }
109 
110 } // namespace ns3
DSR helper class to manage creation of DSR routing instance and to insert it on a node as a sublayer ...
Definition: dsr-helper.h:53
Ptr< ns3::dsr::DsrRouting > Create(Ptr< Node > node) const
Definition: dsr-helper.cc:75
DsrHelper * Copy(void) const
Definition: dsr-helper.cc:68
Helper class that adds DSR routing to nodes.
DsrMainHelper & operator=(const DsrMainHelper &o)
Assignment operator declared private and not implemented to disallow assignment and prevent the compi...
const DsrHelper * m_dsrHelper
helper class
void Install(DsrHelper &dsrHelper, NodeContainer nodes)
Install routing to the nodes.
void SetDsrHelper(DsrHelper &dsrHelper)
Set the helper class.
DsrMainHelper()
Create an DsrMainHelper that makes life easier for people who want to install DSR routing to nodes.
keep track of a set of node pointers.
std::vector< Ptr< Node > >::const_iterator Iterator
Node container iterator.
#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
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
nodes
Definition: first.py:32
Every class exported by the ns3 library is enclosed in the ns3 namespace.