Download this file

SingleDomainGenerator.h    59 lines (44 with data), 1.7 kB

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// 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 Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with this program. If not, see http://www.gnu.org/licenses/.
//
#ifndef SingleDomainGenerator_H_
#define SingleDomainGenerator_H_
#include <IntPDUFG.h>
#include <MiniTable/MiniTable.h>
#include <DomainRouting/Routing.h>
#include <map>
#include <set>
namespace SingleDomainGenerator {
typedef std::set<RMTPort*> PortsSet;
typedef std::map<std::string, PortsSet> NTable;
typedef PortsSet::iterator PortsSetIt;
typedef NTable::iterator NTableIt;
class SingleDomainGenerator: public IntPDUFG {
public:
// A new flow has been inserted/or removed
virtual void insertedFlow(const Address &addr, const unsigned short &qos, RMTPort * port);
virtual void removedFlow(const Address &addr, const unsigned short &qos, RMTPort * port);
//Routing has processes a routing update
virtual void routingUpdated();
protected:
// Called after initialize
virtual void onPolicyInit();
private:
DA * difA;
MiniTable::MiniTable * fwd;
DMRnms::Routing * rt;
NTable neighbours;
};
}
#endif /* STATICGENERATOR_H_ */