Switch to unified view

a b/src/DAF/IRM/ConnectionTable.h
1
//
2
// This program is free software: you can redistribute it and/or modify
3
// it under the terms of the GNU Lesser General Public License as published by
4
// the Free Software Foundation, either version 3 of the License, or
5
// (at your option) any later version.
6
// 
7
// This program is distributed in the hope that it will be useful,
8
// but WITHOUT ANY WARRANTY; without even the implied warranty of
9
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10
// GNU Lesser General Public License for more details.
11
// 
12
// You should have received a copy of the GNU Lesser General Public License
13
// along with this program.  If not, see http://www.gnu.org/licenses/.
14
// 
15
16
#ifndef __RINA_CONNECTIONTABLE_H_
17
#define __RINA_CONNECTIONTABLE_H_
18
19
//Standard libraries
20
#include <omnetpp.h>
21
//RINASim libraries
22
#include <ConnectionTableEntry.h>
23
24
typedef std::list<ConnectionTableEntry> TConTable;
25
typedef TConTable::iterator TCTIter;
26
typedef TConTable::const_iterator TCTConstIter;
27
28
class ConnectionTable : public cSimpleModule
29
{
30
  public:
31
    std::string info() const;
32
33
    void insertNew(Flow* flow);
34
    void insertNew(Flow* flow, cGate* nIn, cGate* nOut);
35
    void insert(const ConnectionTableEntry& entry);
36
    void remove();
37
38
    ConnectionTableEntry* findEntryByFlow(Flow* flow);
39
40
    cGate* findOutputGate(cGate* input);
41
42
    bool setSouthGates(Flow* flow, cGate* sIn, cGate* sOut);
43
    bool setNorthGates(Flow* flow, cGate* nIn, cGate* nOut);
44
    bool setFa(Flow* flow, FABase* fa);
45
46
    FABase* getFa(Flow* flow);
47
48
  protected:
49
    virtual void initialize();
50
    virtual void handleMessage(cMessage *msg);
51
52
  private:
53
    TConTable ConTable;
54
};
55
56
#endif