Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Changeset 8147 in orxonox.OLD for trunk/src/lib/network


Ignore:
Timestamp:
Jun 5, 2006, 12:09:15 PM (19 years ago)
Author:
bensch
Message:

orxonox/trunk: merged the network branche back here
merged with command:
svn merge -r8070:HEAD https://svn.orxonox.net/orxonox/branches/network .
no conflicts

Location:
trunk/src/lib/network
Files:
7 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/lib/network/message_manager.h

    r8068 r8147  
    2929{
    3030  TESTMESSAGEID = 1,
    31   MSGID_DELETESYNCHRONIZEABLE
     31  MSGID_DELETESYNCHRONIZEABLE,
     32  MSGID_PREFEREDTEAM
    3233};
    3334
  • trunk/src/lib/network/network_game_manager.cc

    r8068 r8147  
    5959 
    6060  MessageManager::getInstance()->registerMessageHandler( MSGID_DELETESYNCHRONIZEABLE, delSynchronizeableHandler, NULL );
     61  MessageManager::getInstance()->registerMessageHandler( MSGID_PREFEREDTEAM, preferedTeamHandler, NULL );
    6162 
    6263  this->gameState = 0;
     
    8687 
    8788  int team = rules.getTeamForNewUser();
    88   ClassID playableClassId = rules.getPlayableClassId( team );
    89   std::string playableModel = rules.getPlayableModelFileName( team, playableClassId );
     89  ClassID playableClassId = rules.getPlayableClassId( userId, team );
     90  std::string playableModel = rules.getPlayableModelFileName( userId, team, playableClassId );
    9091 
    9192  BaseObject * bo = Factory::fabricate( playableClassId );
     
    159160    if ( dynamic_cast<Synchronizeable*>(*it)->getUniqueID() == uniqueId )
    160161    {
     162      if ( (*it)->isA(CL_PLAYABLE) )
     163      {
     164        getInstance()->playablesToDelete.push_back( dynamic_cast<Playable*>(*it) );
     165        return true;
     166      }
     167       
    161168      delete dynamic_cast<Synchronizeable*>(*it);
    162169      return true;
     
    180187
    181188
    182 
    183 
    184 
     189/**
     190 * handler for MSGID_PREFEREDTEAM message
     191 * @param messageId
     192 * @param data
     193 * @param dataLength
     194 * @param someData
     195 * @param userId
     196 * @return
     197 */
     198bool NetworkGameManager::preferedTeamHandler( MessageId messageId, byte * data, int dataLength, void * someData, int userId )
     199{
     200  assert( NetworkGameManager::getInstance()->isServer() );
     201 
     202  int teamId = 0;
     203  int len = Converter::byteArrayToInt( data, &teamId );
     204 
     205  if ( len != dataLength )
     206  {
     207    PRINTF(2)("Recieved DeleteSynchronizeable message with incorrect size (%d) from client %d!\n", dataLength, userId);
     208    return true;
     209  }
     210 
     211  NetworkGameManager::getInstance()->setPreferedTeam( userId, teamId );
     212}
     213
     214void NetworkGameManager::setPreferedTeam( int userId, int teamId )
     215{
     216  if ( !PlayerStats::getStats( userId ) )
     217    return;
     218 
     219  PlayerStats & stats = *(PlayerStats::getStats( userId ));
     220 
     221  stats.setPreferedTeamId( teamId );
     222 
     223}
     224
     225/**
     226 * set prefered team for this host
     227 * @param teamId
     228 */
     229void NetworkGameManager::prefereTeam( int teamId )
     230{
     231  if ( isServer() )
     232    setPreferedTeam( getHostID(), teamId );
     233  else
     234  {
     235    byte buf[INTSIZE];
     236   
     237    assert( Converter::intToByteArray( teamId, buf, INTSIZE) == INTSIZE );
     238   
     239    MessageManager::getInstance()->sendMessage( MSGID_PREFEREDTEAM, buf, INTSIZE, RT_USER, 0, MP_HIGHBANDWIDTH );
     240  }
     241}
     242
     243/**
     244 * this function will be called periodically by networkManager
     245 * @param ds time elapsed since last call of tick
     246 */
     247void NetworkGameManager::tick( float ds )
     248{
     249  //delete playables if they are not assigned to local player anymore
     250  for ( std::list<Playable*>::iterator it = playablesToDelete.begin(); it != playablesToDelete.end();  )
     251  {
     252    if ( State::getPlayer()->getPlayable() != *it )
     253    {
     254      PRINTF(0)("Delete unused playable: %s owner: %d\n", (*it)->getClassName(), (*it)->getOwner() );
     255      std::list<Playable*>::iterator delit = it;
     256      it++;
     257      delete *delit;
     258      playablesToDelete.erase( delit );
     259      continue;
     260    }
     261    it++;
     262  }
     263}
     264
     265
     266
     267
  • trunk/src/lib/network/network_game_manager.h

    r8068 r8147  
    1212/* include base_object.h since all classes are derived from this one */
    1313#include "synchronizeable.h"
     14#include "playable.h"
    1415#include "message_manager.h"
    1516
     
    5657   
    5758    void removeSynchronizeable( int uniqueId );
     59   
     60    void prefereTeam( int teamId );
    5861
    5962    inline void setGameState( int gameState ){ this->gameState = gameState; }
    6063    inline int getGameState(){ return this->gameState; }
     64   
     65    void tick( float ds );
    6166
    6267  private:
     
    6469   
    6570    static bool delSynchronizeableHandler( MessageId messageId, byte * data, int dataLength, void * someData, int userId );
     71    static bool preferedTeamHandler( MessageId messageId, byte * data, int dataLength, void * someData, int userId );
     72   
     73    void setPreferedTeam( int userId, int teamId );
    6674
    6775    static NetworkGameManager*    singletonRef;
    6876   
    6977    int                           gameState;
     78   
     79    std::list<Playable*>          playablesToDelete;
    7080};
    7181
  • trunk/src/lib/network/network_manager.cc

    r7954 r8147  
    3030#include "preferences.h"
    3131#include "network_log.h"
     32#include "network_game_manager.h"
    3233
    3334
     
    149150        static_cast<NetworkStream*>(*stream)->processData();
    150151  }
     152 
     153  NetworkGameManager::getInstance()->tick( this->elapsedTime );
    151154}
    152155
  • trunk/src/lib/network/player_stats.cc

    r8068 r8147  
    8686   
    8787    PRINTF(0)("uniqueID changed %d %d\n", userId, getHostID());
    88    
    89     if ( userId == getHostID() )
    90       State::getPlayer()->setPlayable( getPlayable() );
    9188  }
    9289}
     
    10097{
    10198  const std::list<BaseObject*> * list = ClassList::getList( CL_PLAYER_STATS );
     99 
     100  if ( !list )
     101    return NULL;
    102102 
    103103  for ( std::list<BaseObject*>::const_iterator it = list->begin(); it != list->end(); it++ )
     
    121121  const std::list<BaseObject*> * list = ClassList::getList( CL_PLAYABLE );
    122122 
     123  if ( !list )
     124  {
     125    this->playableUniqueId = uniqueId;
     126    return;
     127  }
     128 
    123129  this->playable = NULL;
    124130  for ( std::list<BaseObject*>::const_iterator it = list->begin(); it != list->end(); it++ )
     
    130136    }
    131137  }
     138 
     139  if ( this->playable && userId == getHostID() )
     140    State::getPlayer()->setPlayable( this->playable );
    132141 
    133142  this->playableUniqueId = uniqueId;
  • trunk/src/lib/network/synchronizeable.cc

    r8068 r8147  
    108108
    109109  for ( SyncVarList::iterator it = syncVarList.begin(); it != syncVarList.end(); it++ )
     110  {
     111    //PRINTF(0)("SIZE = %d %s\n", (*it)->getSize(), (*it)->getName().c_str());
    110112    neededSize += (*it)->getSize();
     113  }
    111114
    112115  if ( !( neededSize <= maxLength ) )
     
    183186                    );
    184187   
    185     if ( ( hasPermission && (*it)->getPriority() >= priorityTH ) || sizeIter == stateFrom->sizeList.end() )
     188    if ( ( sizeIter != stateFrom->sizeList.end() && *sizeIter != (*it)->getSize() ) || ( hasPermission && (*it)->getPriority() >= priorityTH ) || sizeIter == stateFrom->sizeList.end() )
    186189    {
    187190      n = (*it)->writeToBuf( stateTo->data+i, stateTo->dataLength - i );
     
    209212  sentStates[userId].push_back( stateTo );
    210213 
    211   assert( i == neededSize );
     214  if ( i != neededSize )
     215  {
     216    PRINTF(0)("strange error: (%s) %d != %d\n", this->getClassName(), i, neededSize);
     217    assert(false);
     218  }
    212219
    213220  //write diff to data
  • trunk/src/lib/network/synchronizeable_var/synchronizeable_string.cc

    r7954 r8147  
    4848 
    4949  assert( res > 0 );
     50  assert( res == vPtrIn->length()+INTSIZE );
    5051 
    5152  return res;
Note: See TracChangeset for help on using the changeset viewer.