Changeset 2309 for code/branches/network64/src/network/synchronisable
- Timestamp:
- Dec 2, 2008, 9:10:00 PM (16 years ago)
- Location:
- code/branches/network64/src/network/synchronisable
- Files:
-
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
code/branches/network64/src/network/synchronisable/CMakeLists.txt
r2307 r2309 1 1 SET( SRC_FILES 2 NetworkCallbackManager.cc 2 3 Synchronisable.cc 3 4 SynchronisableSpecialisations.cc -
code/branches/network64/src/network/synchronisable/NetworkCallback.h
r2211 r2309 1 /* 2 * ORXONOX - the hottest 3D action shooter ever to exist 3 * > www.orxonox.net < 4 * 5 * 6 * License notice: 7 * 8 * This program is free software; you can redistribute it and/or 9 * modify it under the terms of the GNU General Public License 10 * as published by the Free Software Foundation; either version 2 11 * of the License, or (at your option) any later version. 12 * 13 * This program is distributed in the hope that it will be useful, 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 * GNU General Public License for more details. 17 * 18 * You should have received a copy of the GNU General Public License 19 * along with this program; if not, write to the Free Software 20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 21 * 22 * Author: 23 * Oliver Scheuss, (C) 2008 24 * Co-authors: 25 * ... 26 * 27 */ 28 29 1 30 #ifndef _NETWORK_CALLBACK__ 2 31 #define _NETWORK_CALLBACK__ 3 32 4 33 #include "network/NetworkPrereqs.h" 34 #include "NetworkCallbackManager.h" 5 35 6 36 namespace orxonox{ 37 7 38 class _NetworkExport NetworkCallbackBase 8 39 { 9 40 public: 10 41 virtual void call() = 0; 11 virtual ~NetworkCallbackBase() {} 42 NetworkCallbackBase(){ NetworkCallbackManager::registerCallback( this ); } 43 virtual ~NetworkCallbackBase() {} 12 44 }; 13 45 … … 26 58 }; 27 59 28 29 60 } 30 61 -
code/branches/network64/src/network/synchronisable/Synchronisable.cc
r2307 r2309 55 55 56 56 57 std::map<u nsigned int, Synchronisable *> Synchronisable::objectMap_;58 std::queue<u nsigned int> Synchronisable::deletedObjects_;57 std::map<uint32_t, Synchronisable *> Synchronisable::objectMap_; 58 std::queue<uint32_t> Synchronisable::deletedObjects_; 59 59 60 60 uint8_t Synchronisable::state_=0x1; // detemines wheter we are server (default) or client … … 77 77 else 78 78 objectID=OBJECTID_UNKNOWN; 79 classID = (unsigned int)-1;79 classID = static_cast<uint32_t>(-1); 80 80 81 81 … … 122 122 // objectMap_.erase(objectID); 123 123 } 124 std::map<u nsigned int, Synchronisable*>::iterator it;124 std::map<uint32_t, Synchronisable*>::iterator it; 125 125 it = objectMap_.find(objectID); 126 126 if (it != objectMap_.end()) … … 199 199 * @return true/false 200 200 */ 201 bool Synchronisable::deleteObject(u nsigned int objectID){201 bool Synchronisable::deleteObject(uint32_t objectID){ 202 202 // assert(getSynchronisable(objectID)); 203 203 if(!getSynchronisable(objectID)) … … 218 218 * @return pointer to the Synchronisable with the objectID 219 219 */ 220 Synchronisable* Synchronisable::getSynchronisable(u nsigned int objectID){221 std::map<u nsigned int, Synchronisable*>::iterator it1;220 Synchronisable* Synchronisable::getSynchronisable(uint32_t objectID){ 221 std::map<uint32_t, Synchronisable*>::iterator it1; 222 222 it1 = objectMap_.find(objectID); 223 223 if (it1 != objectMap_.end()) … … 295 295 * @return true: if !doSync or if everything was successfully saved 296 296 */ 297 bool Synchronisable::getData(uint8_t*& mem, unsigned int id, uint8_t mode){297 bool Synchronisable::getData(uint8_t*& mem, int32_t id, uint8_t mode){ 298 298 if(mode==0x0) 299 299 mode=state_; … … 302 302 return true; 303 303 //std::cout << "inside getData" << std::endl; 304 u nsigned int tempsize = 0;304 uint32_t tempsize = 0; 305 305 if(classID==0) 306 306 COUT(3) << "classid 0 " << this->getIdentifier()->getName() << std::endl; 307 307 308 if (this->classID == (unsigned int)-1)308 if (this->classID == static_cast<uint32_t>(-1)) 309 309 this->classID = this->getIdentifier()->getNetworkID(); 310 310 … … 312 312 // this->classID=this->getIdentifier()->getNetworkID(); // TODO: correct this 313 313 std::list<SynchronisableVariableBase*>::iterator i; 314 u nsigned int size;314 uint32_t size; 315 315 size=getSize(id, mode); 316 316 … … 384 384 * @return amount of bytes 385 385 */ 386 uint32_t Synchronisable::getSize( unsigned int id, uint8_t mode){386 uint32_t Synchronisable::getSize(int32_t id, uint8_t mode){ 387 387 int tsize=sizeof(synchronisableHeader); 388 388 if(mode==0x0) … … 402 402 * @return true/false 403 403 */ 404 bool Synchronisable::doSync( unsigned int id, uint8_t mode){404 bool Synchronisable::doSync(int32_t id, uint8_t mode){ 405 405 if(mode==0x0) 406 406 mode=state_; … … 408 408 } 409 409 410 bool Synchronisable::doSelection( unsigned int id){410 bool Synchronisable::doSelection(int32_t id){ 411 411 return true; //TODO: change this 412 412 //return ( id==0 || id%objectFrequency_==objectID%objectFrequency_ ) && ((objectMode_&state_)!=0); -
code/branches/network64/src/network/synchronisable/Synchronisable.h
r2307 r2309 53 53 namespace orxonox 54 54 { 55 static const u nsigned int OBJECTID_UNKNOWN = (unsigned int)-1;55 static const uint32_t OBJECTID_UNKNOWN = static_cast<uint32_t>(-1); 56 56 57 57 namespace objectDirection{ … … 86 86 87 87 static Synchronisable *fabricate(uint8_t*& mem, uint8_t mode=0x0); 88 static bool deleteObject(u nsigned int objectID);89 static Synchronisable *getSynchronisable(u nsigned int objectID);88 static bool deleteObject(uint32_t objectID); 89 static Synchronisable *getSynchronisable(uint32_t objectID); 90 90 static unsigned int getNumberOfDeletedObject(){ return deletedObjects_.size(); } 91 static u nsigned int popDeletedObject(){ unsigned int i = deletedObjects_.front(); deletedObjects_.pop(); return i; }91 static uint32_t popDeletedObject(){ uint32_t i = deletedObjects_.front(); deletedObjects_.pop(); return i; } 92 92 93 inline u nsigned int getObjectID(){return objectID;}94 inline u nsigned int getClassID(){return classID;}93 inline uint32_t getObjectID(){return objectID;} 94 inline uint32_t getClassID(){return classID;} 95 95 protected: 96 96 Synchronisable(BaseObject* creator); … … 103 103 104 104 private: 105 bool getData(uint8_t*& men, unsigned int id, uint8_t mode=0x0);106 uint32_t getSize( unsigned int id, uint8_t mode=0x0);105 bool getData(uint8_t*& men, int32_t id, uint8_t mode=0x0); 106 uint32_t getSize(int32_t id, uint8_t mode=0x0); 107 107 bool updateData(uint8_t*& mem, uint8_t mode=0x0, bool forceCallback=false); 108 108 bool isMyData(uint8_t* mem); 109 bool doSelection( unsigned int id);110 bool doSync( unsigned int id, uint8_t mode=0x0);109 bool doSelection(int32_t id); 110 bool doSync(int32_t id, uint8_t mode=0x0); 111 111 112 u nsigned int objectID;113 u nsigned int creatorID;114 u nsigned int classID;112 uint32_t objectID; 113 uint32_t creatorID; 114 uint32_t classID; 115 115 116 116 std::list<SynchronisableVariableBase*> syncList; … … 119 119 unsigned int objectFrequency_; 120 120 int objectMode_; 121 static std::map<u nsigned int, Synchronisable *> objectMap_;122 static std::queue<u nsigned int> deletedObjects_;121 static std::map<uint32_t, Synchronisable *> objectMap_; 122 static std::queue<uint32_t> deletedObjects_; 123 123 }; 124 124 -
code/branches/network64/src/network/synchronisable/SynchronisableSpecialisations.cc
r2307 r2309 37 37 template <> void Synchronisable::registerVariable( const ColourValue& variable, uint8_t mode, NetworkCallbackBase* cb, bool bidirectional) 38 38 { 39 registerVariable(variable.r, mode, 0, bidirectional);40 registerVariable(variable.g, mode, 0, bidirectional);41 registerVariable(variable.b, mode, 0, bidirectional);39 registerVariable(variable.r, mode, cb, bidirectional); 40 registerVariable(variable.g, mode, cb, bidirectional); 41 registerVariable(variable.b, mode, cb, bidirectional); 42 42 registerVariable(variable.a, mode, cb, bidirectional); 43 43 } … … 49 49 template <> void Synchronisable::registerVariable( const Vector2& variable, uint8_t mode, NetworkCallbackBase* cb, bool bidirectional) 50 50 { 51 registerVariable(variable.x, mode, 0, bidirectional);51 registerVariable(variable.x, mode, cb, bidirectional); 52 52 registerVariable(variable.y, mode, cb, bidirectional); 53 53 } … … 59 59 template <> void Synchronisable::registerVariable( const Vector3& variable, uint8_t mode, NetworkCallbackBase* cb, bool bidirectional) 60 60 { 61 registerVariable(variable.x, mode, 0, bidirectional);62 registerVariable(variable.y, mode, 0, bidirectional);61 registerVariable(variable.x, mode, cb, bidirectional); 62 registerVariable(variable.y, mode, cb, bidirectional); 63 63 registerVariable(variable.z, mode, cb, bidirectional); 64 64 } … … 70 70 template <> void Synchronisable::registerVariable( const Vector4& variable, uint8_t mode, NetworkCallbackBase* cb, bool bidirectional) 71 71 { 72 registerVariable(variable.x, mode, 0, bidirectional);73 registerVariable(variable.y, mode, 0, bidirectional);74 registerVariable(variable.z, mode, 0, bidirectional);72 registerVariable(variable.x, mode, cb, bidirectional); 73 registerVariable(variable.y, mode, cb, bidirectional); 74 registerVariable(variable.z, mode, cb, bidirectional); 75 75 registerVariable(variable.w, mode, cb, bidirectional); 76 76 } … … 87 87 template <> void Synchronisable::registerVariable( const Quaternion& variable, uint8_t mode, NetworkCallbackBase* cb, bool bidirectional) 88 88 { 89 registerVariable(variable.w, mode, 0, bidirectional); 90 registerVariable(variable.x, mode, 0, bidirectional); 91 registerVariable(variable.y, mode, 0, bidirectional); 89 registerVariable(variable.x, mode, cb, bidirectional); 90 registerVariable(variable.y, mode, cb, bidirectional); 92 91 registerVariable(variable.z, mode, cb, bidirectional); 92 registerVariable(variable.w, mode, cb, bidirectional); 93 93 } 94 94 template <> void Synchronisable::registerVariable( Quaternion& variable, uint8_t mode, NetworkCallbackBase* cb, bool bidirectional) -
code/branches/network64/src/network/synchronisable/SynchronisableVariable.cc
r2255 r2309 64 64 } 65 65 66 // =========== char 67 68 template <> uint32_t SynchronisableVariable<const char>::returnSize() 69 { 70 return sizeof(uint8_t); 71 } 72 73 template <> void SynchronisableVariable<const char>::setAndIncrease( uint8_t*& mem ) 74 { 75 *(uint8_t*)(&this->variable_) = *static_cast<uint8_t*>(mem); 76 mem += SynchronisableVariable<const char>::returnSize(); 77 } 78 79 template <> void SynchronisableVariable<const char>::getAndIncrease( uint8_t*& mem ) 80 { 81 *static_cast<uint8_t*>(mem) = *(uint8_t*)(&this->variable_); 82 mem += SynchronisableVariable<const char>::returnSize(); 83 } 84 85 template <> bool SynchronisableVariable<const char>::checkEquality( uint8_t* mem ) 86 { 87 return *static_cast<uint8_t*>(mem) == *(uint8_t*)(&this->variable_); 88 } 89 66 90 // =========== unsigned char 67 91 -
code/branches/network64/src/network/synchronisable/SynchronisableVariable.h
r2307 r2309 39 39 #include "core/CoreIncludes.h" 40 40 #include "network/synchronisable/NetworkCallback.h" 41 #include "network/synchronisable/NetworkCallbackManager.h" 41 42 42 43 namespace orxonox{ … … 119 120 { 120 121 if (this->callback_ != 0) 121 delete this->callback_;122 NetworkCallbackManager::deleteCallback(this->callback_); //safe call for deletion 122 123 } 123 124 … … 146 147 // now do a callback if neccessary 147 148 if ( callback ) 148 this->callback_->call(); 149 NetworkCallbackManager::triggerCallback( this->callback_ ); 150 //this->callback_->call(); 149 151 } 150 152 … … 299 301 // now do a callback if neccessary 300 302 if ( callback ) 301 this->callback_->call(); 303 NetworkCallbackManager::triggerCallback( this->callback_ ); 304 //this->callback_->call(); 302 305 } 303 306
Note: See TracChangeset
for help on using the changeset viewer.