|
INET Framework for OMNeT++/OMNEST
|
00001 // 00002 // Copyright (C) 2006 Andras Varga 00003 // 00004 // This program is free software; you can redistribute it and/or 00005 // modify it under the terms of the GNU Lesser General Public License 00006 // as published by the Free Software Foundation; either version 2 00007 // of the License, or (at your option) any later version. 00008 // 00009 // This program is distributed in the hope that it will be useful, 00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00012 // GNU Lesser General Public License for more details. 00013 // 00014 // You should have received a copy of the GNU Lesser General Public License 00015 // along with this program; if not, see <http://www.gnu.org/licenses/>. 00016 // 00017 00018 #ifndef __INET_NETWORKCONFIGURATOR_H 00019 #define __INET_NETWORKCONFIGURATOR_H 00020 00021 #include <omnetpp.h> 00022 #include "INETDefs.h" 00023 #include "IPAddress.h" 00024 00025 class IInterfaceTable; 00026 class IRoutingTable; 00027 00028 00033 class INET_API NetworkConfigurator : public cSimpleModule 00034 { 00035 protected: 00036 struct NodeInfo { 00037 NodeInfo() {isIPNode=false;ift=NULL;rt=NULL;} 00038 bool isIPNode; 00039 IInterfaceTable *ift; 00040 IRoutingTable *rt; 00041 bool usesDefaultRoute; 00042 }; 00043 typedef std::vector<NodeInfo> NodeInfoVector; 00044 00045 protected: 00046 virtual int numInitStages() const {return 3;} 00047 virtual void initialize(int stage); 00048 virtual void handleMessage(cMessage *msg); 00049 00050 virtual void extractTopology(cTopology& topo, NodeInfoVector& nodeInfo); 00051 virtual void assignAddresses(cTopology& topo, NodeInfoVector& nodeInfo); 00052 virtual void addPointToPointPeerRoutes(cTopology& topo, NodeInfoVector& nodeInfo); 00053 virtual void addDefaultRoutes(cTopology& topo, NodeInfoVector& nodeInfo); 00054 virtual void setPeersParameter(const char *submodName, cTopology& topo, NodeInfoVector& nodeInfo); 00055 virtual void fillRoutingTables(cTopology& topo, NodeInfoVector& nodeInfo); 00056 00057 virtual void setDisplayString(cTopology& topo, NodeInfoVector& nodeInfo); 00058 }; 00059 00060 #endif 00061