2007-03-18 14:06:51 -07:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2007 INRIA
|
|
|
|
|
*
|
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
|
* published by the Free Software Foundation;
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
*
|
2022-06-05 21:01:11 -07:00
|
|
|
* Authors:
|
2007-03-18 14:06:51 -07:00
|
|
|
* Mathieu Lacage <mathieu.lacage@sophia.inria.fr>,
|
|
|
|
|
*/
|
|
|
|
|
#ifndef NODE_LIST_H
|
|
|
|
|
#define NODE_LIST_H
|
|
|
|
|
|
2007-05-09 16:56:33 -04:00
|
|
|
#include "ns3/ptr.h"
|
2007-03-18 14:06:51 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
|
|
namespace ns3
|
|
|
|
|
{
|
2007-03-18 14:06:51 -07:00
|
|
|
|
2007-06-04 16:17:01 +02:00
|
|
|
class Node;
|
2007-08-27 13:36:40 +02:00
|
|
|
class CallbackBase;
|
2007-08-06 17:19:13 +02:00
|
|
|
|
2007-05-13 11:51:01 +02:00
|
|
|
/**
|
2011-05-10 17:56:47 -07:00
|
|
|
* \ingroup network
|
2008-05-30 10:36:02 -07:00
|
|
|
*
|
2007-05-13 11:51:01 +02:00
|
|
|
* \brief the list of simulation nodes.
|
|
|
|
|
*
|
2007-06-04 16:17:01 +02:00
|
|
|
* Every Node created is automatically added to this list.
|
2007-05-13 11:51:01 +02:00
|
|
|
*/
|
2007-03-18 14:06:51 -07:00
|
|
|
class NodeList
|
|
|
|
|
{
|
2022-10-07 20:08:35 +00:00
|
|
|
public:
|
|
|
|
|
/// Node container iterator
|
|
|
|
|
typedef std::vector<Ptr<Node>>::const_iterator Iterator;
|
2007-03-18 14:06:51 -07:00
|
|
|
|
2022-10-07 20:08:35 +00:00
|
|
|
/**
|
|
|
|
|
* \param node node to add
|
|
|
|
|
* \returns index of node in list.
|
|
|
|
|
*
|
|
|
|
|
* This method is called automatically from Node::Node so
|
|
|
|
|
* the user has little reason to call it himself.
|
|
|
|
|
*/
|
|
|
|
|
static uint32_t Add(Ptr<Node> node);
|
|
|
|
|
/**
|
|
|
|
|
* \returns a C++ iterator located at the beginning of this
|
|
|
|
|
* list.
|
|
|
|
|
*/
|
|
|
|
|
static Iterator Begin();
|
|
|
|
|
/**
|
|
|
|
|
* \returns a C++ iterator located at the end of this
|
|
|
|
|
* list.
|
|
|
|
|
*/
|
|
|
|
|
static Iterator End();
|
|
|
|
|
/**
|
|
|
|
|
* \param n index of requested node.
|
|
|
|
|
* \returns the Node associated to index n.
|
|
|
|
|
*/
|
|
|
|
|
static Ptr<Node> GetNode(uint32_t n);
|
|
|
|
|
/**
|
|
|
|
|
* \returns the number of nodes currently in the list.
|
|
|
|
|
*/
|
|
|
|
|
static uint32_t GetNNodes();
|
2007-03-18 14:06:51 -07:00
|
|
|
};
|
|
|
|
|
|
2011-08-02 17:43:32 -04:00
|
|
|
} // namespace ns3
|
2007-03-18 14:06:51 -07:00
|
|
|
|
|
|
|
|
#endif /* NODE_LIST_H */
|