OverSim
PastryNeighborhoodSet.h
Go to the documentation of this file.
1 //
2 // Copyright (C) 2006 Institut fuer Telematik, Universitaet Karlsruhe (TH)
3 //
4 // This program is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU General Public License
6 // as published by the Free Software Foundation; either version 2
7 // of the License, or (at your option) any later version.
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 
24 #ifndef __PASTRYNEIGHBORHOODSET_H
25 #define __PASTRYNEIGHBORHOODSET_H
26 
27 
28 #include <vector>
29 
30 #include <omnetpp.h>
31 
32 #include <NodeHandle.h>
33 
34 #include "PastryStateObject.h"
35 #include "PastryTypes.h"
36 #include "PastryMessage_m.h"
37 
47 {
48  public:
49 
57  void initializeSet(uint32_t numberOfNeighbors,
58  uint32_t bitsPerDigit,
59  const NodeHandle& owner);
60 
66  virtual void dumpToStateMessage(PastryStateMessage* msg) const;
67 
79  virtual const NodeHandle& findCloserNode(const OverlayKey& destination,
80  bool optimize = false);
81 
82  void findCloserNodes(const OverlayKey& destination,
83  NodeVector* nodes);
84 
92  virtual bool mergeNode(const NodeHandle& node, simtime_t prox);
93 
101  virtual void dumpToVector(std::vector<TransportAddress>& affected) const;
102 
108  virtual const TransportAddress& failedNode(const TransportAddress& failed);
109 
110  private:
111 
113  std::vector<PastryExtendedNode> neighbors;
114  virtual void earlyInit(void);
115 };
116 
121 std::ostream& operator<<(std::ostream& os, const PastryExtendedNode& n);
122 
123 
124 #endif