blob: 2325f497d8a6c7f9bc172765f362c48851acc00a [file] [log] [blame]
akmhoque3d06e792014-05-27 16:23:20 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
alvydce3f182015-04-09 11:23:30 -05003 * Copyright (c) 2014-2015, The University of Memphis,
4 * Regents of the University of California,
5 * Arizona Board of Regents.
akmhoque3d06e792014-05-27 16:23:20 -05006 *
7 * This file is part of NLSR (Named-data Link State Routing).
8 * See AUTHORS.md for complete list of NLSR authors and contributors.
9 *
10 * NLSR is free software: you can redistribute it and/or modify it under the terms
11 * of the GNU General Public License as published by the Free Software Foundation,
12 * either version 3 of the License, or (at your option) any later version.
13 *
14 * NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
15 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16 * PURPOSE. See the GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License along with
19 * NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
akmhoque3d06e792014-05-27 16:23:20 -050020 **/
alvydce3f182015-04-09 11:23:30 -050021
akmhoquefdbddb12014-05-02 18:35:19 -050022#ifndef NLSR_ADJACENCY_LIST_HPP
23#define NLSR_ADJACENCY_LIST_HPP
akmhoque53353462014-04-22 08:43:45 -050024
akmhoque53353462014-04-22 08:43:45 -050025#include <list>
akmhoquefdbddb12014-05-02 18:35:19 -050026#include <boost/cstdint.hpp>
27#include <ndn-cxx/common.hpp>
akmhoque53353462014-04-22 08:43:45 -050028
akmhoquec8a10f72014-04-25 18:42:55 -050029#include "adjacent.hpp"
30
akmhoque53353462014-04-22 08:43:45 -050031namespace nlsr {
32class Nlsr;
33
akmhoquec8a10f72014-04-25 18:42:55 -050034class AdjacencyList
akmhoque53353462014-04-22 08:43:45 -050035{
akmhoque53353462014-04-22 08:43:45 -050036public:
alvydce3f182015-04-09 11:23:30 -050037 typedef std::list<Adjacent>::const_iterator const_iterator;
38 typedef std::list<Adjacent>::iterator iterator;
39
akmhoquec8a10f72014-04-25 18:42:55 -050040 AdjacencyList();
41 ~AdjacencyList();
akmhoque53353462014-04-22 08:43:45 -050042
akmhoquefdbddb12014-05-02 18:35:19 -050043 int32_t
44 insert(Adjacent& adjacent);
akmhoque53353462014-04-22 08:43:45 -050045
Vince Lehmancb76ade2014-08-28 21:24:41 -050046 bool
47 updateAdjacentStatus(const ndn::Name& adjName, Adjacent::Status s);
akmhoque53353462014-04-22 08:43:45 -050048
akmhoquefdbddb12014-05-02 18:35:19 -050049 int32_t
akmhoque31d1d4b2014-05-05 22:08:14 -050050 updateAdjacentLinkCost(const ndn::Name& adjName, double lc);
akmhoque53353462014-04-22 08:43:45 -050051
52 std::list<Adjacent>&
53 getAdjList();
54
55 bool
akmhoque31d1d4b2014-05-05 22:08:14 -050056 isNeighbor(const ndn::Name& adjName);
akmhoque53353462014-04-22 08:43:45 -050057
58 void
akmhoque31d1d4b2014-05-05 22:08:14 -050059 incrementTimedOutInterestCount(const ndn::Name& neighbor);
akmhoque53353462014-04-22 08:43:45 -050060
akmhoquefdbddb12014-05-02 18:35:19 -050061 int32_t
akmhoque31d1d4b2014-05-05 22:08:14 -050062 getTimedOutInterestCount(const ndn::Name& neighbor);
akmhoque53353462014-04-22 08:43:45 -050063
Vince Lehmancb76ade2014-08-28 21:24:41 -050064 Adjacent::Status
akmhoque31d1d4b2014-05-05 22:08:14 -050065 getStatusOfNeighbor(const ndn::Name& neighbor);
akmhoque53353462014-04-22 08:43:45 -050066
67 void
Vince Lehmancb76ade2014-08-28 21:24:41 -050068 setStatusOfNeighbor(const ndn::Name& neighbor, Adjacent::Status status);
akmhoque53353462014-04-22 08:43:45 -050069
70 void
akmhoque31d1d4b2014-05-05 22:08:14 -050071 setTimedOutInterestCount(const ndn::Name& neighbor, uint32_t count);
akmhoque53353462014-04-22 08:43:45 -050072
73 void
akmhoquefdbddb12014-05-02 18:35:19 -050074 addAdjacents(AdjacencyList& adl);
akmhoque53353462014-04-22 08:43:45 -050075
76 bool
77 isAdjLsaBuildable(Nlsr& pnlsr);
78
akmhoquefdbddb12014-05-02 18:35:19 -050079 int32_t
akmhoque53353462014-04-22 08:43:45 -050080 getNumOfActiveNeighbor();
81
82 Adjacent
akmhoque31d1d4b2014-05-05 22:08:14 -050083 getAdjacent(const ndn::Name& adjName);
akmhoque53353462014-04-22 08:43:45 -050084
85 bool
akmhoquefdbddb12014-05-02 18:35:19 -050086 operator==(AdjacencyList& adl);
akmhoque53353462014-04-22 08:43:45 -050087
akmhoquefdbddb12014-05-02 18:35:19 -050088 size_t
akmhoque53353462014-04-22 08:43:45 -050089 getSize()
90 {
91 return m_adjList.size();
92 }
93
94 void
95 reset()
96 {
akmhoque157b0a42014-05-13 00:26:37 -050097 if (m_adjList.size() > 0) {
akmhoque53353462014-04-22 08:43:45 -050098 m_adjList.clear();
99 }
100 }
101
akmhoquec04e7272014-07-02 11:00:14 -0500102 Adjacent*
103 findAdjacent(const ndn::Name& adjName);
104
105 Adjacent*
106 findAdjacent(uint64_t faceId);
107
akmhoque102aea42014-08-04 10:22:12 -0500108 uint64_t
109 getFaceId(const std::string& faceUri);
110
akmhoque53353462014-04-22 08:43:45 -0500111 void
akmhoque674b0b12014-05-20 14:33:28 -0500112 writeLog();
113
alvydce3f182015-04-09 11:23:30 -0500114public:
115 const_iterator
116 begin() const
117 {
118 return m_adjList.begin();
119 }
120
121 const_iterator
122 end() const
123 {
124 return m_adjList.end();
125 }
126
akmhoque53353462014-04-22 08:43:45 -0500127private:
alvydce3f182015-04-09 11:23:30 -0500128 iterator
akmhoque31d1d4b2014-05-05 22:08:14 -0500129 find(const ndn::Name& adjName);
akmhoque53353462014-04-22 08:43:45 -0500130
131private:
132 std::list<Adjacent> m_adjList;
133};
134
135} //namespace nlsr
akmhoquefdbddb12014-05-02 18:35:19 -0500136#endif //NLSR_ADJACENCY_LIST_HPP