00001 // 00002 // Copyright (C) 2006 Institut fuer Telematik, Universitaet Karlsruhe (TH) 00003 // 00004 // This program is free software; you can redistribute it and/or 00005 // modify it under the terms of the GNU 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 General Public License for more details. 00013 // 00014 // You should have received a copy of the GNU General Public License 00015 // along with this program; if not, write to the Free Software 00016 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 00017 // 00018 00024 #ifndef __GLOBALCOORDINATOR_H__ 00025 #define __GLOBALCOORDINATOR_H__ 00026 00027 #include <omnetpp.h> 00028 #include <Vector2D.h> 00029 #include <NodeHandle.h> 00030 #include <time.h> 00031 00032 class GlobalCoordinator : public cSimpleModule 00033 { 00034 public: 00035 virtual void initialize(); 00036 virtual void handleMessage(cMessage* msg); 00037 virtual ~GlobalCoordinator(); 00038 00039 void increasePositionSize(); 00040 void increasePeerCount(); 00041 int getPeerCount(); 00042 Vector2D& getPosition(int k); 00043 void setPosition(int k, const Vector2D& Position); 00044 unsigned int getSeed(); 00045 00046 protected: 00047 // ptr to an vector array 00048 Vector2D *Position; 00049 int PositionSize, PeerCount; 00050 unsigned int Seed; 00051 }; 00052 00053 #endif