Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/cpp11_v2/src/libraries/network/packet/FunctionIDs.cc @ 11006

Last change on this file since 11006 was 11006, checked in by landauf, 8 years ago

made some enums in network library strongly typed. for most other enums in network this isn't possible because they are often used like flags (converted to int and compared with binary operators).
packet::Type now uses uint8_t as underlying type which reduces the network traffic (by default the type was int)

  • Property svn:eol-style set to native
File size: 4.9 KB
Line 
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
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29#include "FunctionIDs.h"
30
31#include <cassert>
32#include <cstring>
33#include <queue>
34#include <string>
35
36#include "util/Output.h"
37#include "core/object/ObjectList.h"
38#include "network/NetworkFunction.h"
39#include "network/NetworkFunctionManager.h"
40
41namespace orxonox {
42namespace packet {
43
44
45#define PACKET_FLAGS_FUNCTIONIDS  PacketFlag::Reliable
46#define _PACKETID                 0
47
48
49FunctionIDs::FunctionIDs( ) : Packet()
50{
51  unsigned int nrOfFunctions=0;
52  unsigned int packetSize=2*sizeof(uint32_t); //space for the packetID and for the nroffunctions
53  uint32_t networkID;
54  flags_ = flags_ | PACKET_FLAGS_FUNCTIONIDS;
55  std::queue<std::pair<uint32_t, std::string>> tempQueue;
56
57  //calculate total needed size (for all strings and integers)
58  const std::set<NetworkFunctionBase*>& set = NetworkFunctionManager::getInstance().getAllFunctions();
59  std::set<NetworkFunctionBase*>::const_iterator it;
60  for (it = set.begin(); it != set.end(); ++it)
61  {
62    const std::string& functionname = (*it)->getName();
63    networkID = (*it)->getNetworkID();
64    // now push the network id and the classname to the stack
65    tempQueue.push( std::pair<unsigned int, std::string>(networkID, functionname) );
66    ++nrOfFunctions;
67    packetSize += (functionname.size()+1)+sizeof(uint32_t)+sizeof(uint32_t); // reserver size for the functionname string, the functionname length and the networkID
68  }
69
70  this->data_=new uint8_t[ packetSize ];
71  //set the appropriate packet id
72  assert(this->data_);
73  *(Type *)(this->data_ + _PACKETID ) = Type::FunctionIDs;
74
75  uint8_t *temp=data_+sizeof(uint32_t);
76  // save the number of all classes
77  *(uint32_t*)temp = nrOfFunctions;
78  temp += sizeof(uint32_t);
79
80  // now save all classids and classnames
81  std::pair<uint32_t, std::string> tempPair;
82  while( !tempQueue.empty() )
83  {
84    tempPair = tempQueue.front();
85    tempQueue.pop();
86    *(uint32_t*)temp = tempPair.first;
87    *(uint32_t*)(temp+sizeof(uint32_t)) = tempPair.second.size()+1;
88    memcpy(temp+2*sizeof(uint32_t), tempPair.second.c_str(), tempPair.second.size()+1);
89    temp+=2*sizeof(uint32_t)+tempPair.second.size()+1;
90  }
91
92  orxout(verbose_more, context::packets) << "FunctionIDs packetSize is " << packetSize << endl;
93
94}
95
96FunctionIDs::FunctionIDs( uint8_t* data, unsigned int clientID )
97  : Packet(data, clientID)
98{
99}
100
101FunctionIDs::~FunctionIDs()
102{
103}
104
105uint32_t FunctionIDs::getSize() const
106{
107  assert(this->data_);
108  uint8_t *temp = data_+sizeof(uint32_t); // packet identification
109  uint32_t totalsize = sizeof(uint32_t); // data size
110  uint32_t nrOfFunctions = *(uint32_t*)temp;
111  temp += sizeof(uint32_t);
112  totalsize += sizeof(uint32_t); // storage size for nr of all classes
113
114  for(unsigned int i=0; i<nrOfFunctions; i++){
115    totalsize += 2*sizeof(uint32_t) + *(uint32_t*)(temp + sizeof(uint32_t)); // for each network function add size for id, sizeof(string) and length of string itself to totalsize
116    temp += 2*sizeof(uint32_t) + *(uint32_t*)(temp + sizeof(uint32_t));
117  }
118  return totalsize;
119}
120
121
122bool FunctionIDs::process(orxonox::Host* host)
123{
124  int nrOfFunctions;
125  uint8_t *temp = data_+sizeof(uint32_t); //skip the packetid
126  uint32_t networkID;
127  uint32_t stringsize;
128  unsigned char *functionname;
129
130  //clear the map of network ids
131  NetworkFunctionManager::getInstance().clearNetworkIDs();
132
133  orxout(verbose, context::packets) << "=== processing functionids: " << endl;
134  std::pair<uint32_t, std::string> tempPair;
135  // read the total number of classes
136  nrOfFunctions = *(uint32_t*)temp;
137  temp += sizeof(uint32_t);
138
139  for( int i=0; i<nrOfFunctions; i++)
140  {
141    networkID = *(uint32_t*)temp;
142    stringsize = *(uint32_t*)(temp+sizeof(uint32_t));
143    functionname = temp+2*sizeof(uint32_t);
144    orxout(internal_info, context::packets) << "processing functionid: " << networkID << " name: " << functionname << endl;
145    NetworkFunctionManager::getInstance().getFunctionByName((const char*)functionname)->setNetworkID(networkID);
146    temp += 2*sizeof(uint32_t) + stringsize;
147  }
148  delete this;
149  return true;
150}
151
152
153} //namespace packet
154}//namespace orxonox
Note: See TracBrowser for help on using the repository browser.