Changeset d05086b in network-game
- Timestamp:
- Aug 1, 2013, 1:56:17 AM (12 years ago)
- Branches:
- master
- Children:
- 8271c78
- Parents:
- b35b2b2
- Files:
- 
      - 6 edited
 
 - 
          
  common/Common.cpp (modified) (3 diffs)
- 
          
  common/Common.h (modified) (3 diffs)
- 
          
  common/MessageProcessor.cpp (modified) (8 diffs)
- 
          
  common/MessageProcessor.h (modified) (1 diff)
- 
          
  server/.gitignore (modified) (1 diff)
- 
          
  server/server.cpp (modified) (33 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      common/Common.cpprb35b2b2 rd05086b 1 1 #include "Common.h" 2 2 3 #include < iostream>3 #include <sstream> 4 4 #include <cmath> 5 5 … … 7 7 #include <Windows.h> 8 8 #elif defined LINUX 9 #include < time.h>9 #include <ctime> 10 10 #endif 11 11 12 12 using namespace std; 13 14 /*15 FLOAT_POSITION POSITION::toFloat() {16 FLOAT_POSITION floatPosition;17 floatPosition.x = x;18 floatPosition.y = y;19 20 return floatPosition;21 }22 */23 13 24 14 void set_nonblock(int sock) … … 51 41 } 52 42 43 string getCurrentDateTimeString() { 44 time_t millis = time(NULL); 45 struct tm *time = localtime(&millis); 46 47 ostringstream timeString; 48 timeString << time->tm_hour << ":" << time->tm_min << ":"<< time->tm_sec << " " << (time->tm_mon+1) << "/" << time->tm_mday << "/" << (time->tm_year+1900); 49 50 return timeString.str(); 51 } 52 53 53 float posDistance(FLOAT_POSITION pos1, FLOAT_POSITION pos2) { 54 54 float xDiff = pos2.x - pos1.x; 
- 
      common/Common.hrb35b2b2 rd05086b 12 12 #endif 13 13 14 #include <string> 15 16 using namespace std; 17 14 18 typedef struct 15 19 { … … 22 26 int x; 23 27 int y; 24 //FLOAT_POSITION toFloat();25 28 FLOAT_POSITION toFloat() { 26 29 FLOAT_POSITION floatPosition; … … 34 37 void set_nonblock(int sock); 35 38 unsigned long long getCurrentMillis(); 39 string getCurrentDateTimeString(); 36 40 float posDistance(FLOAT_POSITION pos1, FLOAT_POSITION pos2); 37 41 
- 
      common/MessageProcessor.cpprb35b2b2 rd05086b 2 2 3 3 #include <iostream> 4 #include <fstream> 4 5 5 6 #include "Common.h" … … 12 13 } 13 14 14 int MessageProcessor::sendMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *dest ) {15 int MessageProcessor::sendMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *dest, ofstream* outputLog) { 15 16 cout << "Sending message of type " << msg->type << endl; 16 17 17 18 msg->id = ++lastUsedId; 18 19 MessageContainer message(*msg, *dest); 19 sentMessages[msg->id][dest->sin_addr.s_addr] = message; 20 21 if (outputLog) 22 (*outputLog) << "Sending message (id " << msg->id << ") of type " << MessageContainer::getMsgTypeString(msg->type) << endl; 20 23 21 24 sentMessages[msg->id][dest->sin_addr.s_addr] = message; … … 26 29 } 27 30 28 int MessageProcessor::receiveMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *source ) {31 int MessageProcessor::receiveMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *source, ofstream* outputLog) { 29 32 socklen_t socklen = sizeof(struct sockaddr_in); 30 33 … … 40 43 sentMessages[msg->id][source->sin_addr.s_addr].setAcked(true); 41 44 sentMessages[msg->id][source->sin_addr.s_addr].setTimeAcked(getCurrentMillis()); 45 if (outputLog) 46 (*outputLog) << "Received ack for message id " << msg->id << endl; 42 47 } 43 48 … … 49 54 isDuplicate = true; 50 55 cout << "Got duplicate of type " << msg->type << endl; 51 }else 56 }else { 52 57 cout << "Got message of type " << msg->type << endl; 58 if (outputLog) 59 (*outputLog) << "Received message (id " << msg->id << ") of type " << MessageContainer::getMsgTypeString(msg->type) << endl; 60 } 53 61 54 62 ackedMessages[msg->id] = MessageContainer(*msg, *source); … … 69 77 } 70 78 71 void MessageProcessor::resendUnackedMessages(int sock ) {79 void MessageProcessor::resendUnackedMessages(int sock, ofstream* outputLog) { 72 80 map<unsigned int, map<unsigned long, MessageContainer> >::iterator it; 73 81 map<unsigned long, MessageContainer>::iterator it2; … … 84 92 } 85 93 86 void MessageProcessor::cleanAckedMessages( ) {94 void MessageProcessor::cleanAckedMessages(ofstream* outputLog) { 87 95 map<unsigned int, map<unsigned long, MessageContainer> >::iterator it = sentMessages.begin(); 88 96 map<unsigned long, MessageContainer>::iterator it2; … … 92 100 while (it2 != it->second.end()) { 93 101 if (it2->second.getAcked()) { 94 if ((getCurrentMillis() - it2->second.getTimeAcked()) > 1000) 102 if ((getCurrentMillis() - it2->second.getTimeAcked()) > 1000) { 103 if (outputLog) 104 (*outputLog) << "Removing id " << it2->second.getMessage()->id << " from the acked record" << endl; 95 105 it->second.erase(it2++); 96 else106 }else 97 107 it2++; 98 108 }else 
- 
      common/MessageProcessor.hrb35b2b2 rd05086b 24 24 ~MessageProcessor(); 25 25 26 int sendMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *dest );27 int receiveMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *dest );28 void resendUnackedMessages(int sock );29 void cleanAckedMessages( );26 int sendMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *dest, ofstream* outputLog = NULL); 27 int receiveMessage(NETWORK_MSG *msg, int sock, struct sockaddr_in *dest, ofstream* outputLog = NULL); 28 void resendUnackedMessages(int sock, ofstream* outputLog = NULL); 29 void cleanAckedMessages(ofstream* outputLog = NULL); 30 30 31 31 map<unsigned int, map<unsigned long, MessageContainer> >& getSentMessages(); 
- 
      server/.gitignorerb35b2b2 rd05086b 1 1 server 2 2 *.o 3 *.log 
- 
      server/server.cpprb35b2b2 rd05086b 5 5 #include <iostream> 6 6 #include <sstream> 7 #include <fstream> 7 8 #include <cstring> 8 9 #include <cmath> … … 10 11 #include <vector> 11 12 #include <map> 13 14 #include <csignal> 12 15 13 16 #include <sys/time.h> … … 37 40 using namespace std; 38 41 42 bool done; 43 39 44 // from used to be const. Removed that so I could take a reference 40 45 // and use it to send messages 41 bool processMessage(const NETWORK_MSG &clientMsg, struct sockaddr_in &from, MessageProcessor &msgProcessor, map<unsigned int, Player>& mapPlayers, WorldMap* gameMap, unsigned int& unusedPlayerId, NETWORK_MSG &serverMsg, int sock, int &scoreBlue, int &scoreRed );46 bool processMessage(const NETWORK_MSG &clientMsg, struct sockaddr_in &from, MessageProcessor &msgProcessor, map<unsigned int, Player>& mapPlayers, WorldMap* gameMap, unsigned int& unusedPlayerId, NETWORK_MSG &serverMsg, int sock, int &scoreBlue, int &scoreRed, ofstream& outputLog); 42 47 43 48 void updateUnusedPlayerId(unsigned int& id, map<unsigned int, Player>& mapPlayers); … … 45 50 void damagePlayer(Player *p, int damage); 46 51 47 void addObjectToMap(WorldMap::ObjectType objectType, int x, int y, WorldMap* gameMap, map<unsigned int, Player>& mapPlayers, MessageProcessor &msgProcessor, int sock );52 void addObjectToMap(WorldMap::ObjectType objectType, int x, int y, WorldMap* gameMap, map<unsigned int, Player>& mapPlayers, MessageProcessor &msgProcessor, int sock, ofstream& outputLog); 48 53 49 54 // this should probably go somewhere in the common folder … … 79 84 80 85 return NULL; 86 } 87 88 void quit(int sig) { 89 done = true; 81 90 } 82 91 … … 92 101 unsigned int unusedPlayerId = 1, unusedProjectileId = 1; 93 102 int scoreBlue, scoreRed; 103 ofstream outputLog; 104 105 done = false; 94 106 95 107 scoreBlue = 0; 96 108 scoreRed = 0; 109 110 signal(SIGINT, quit); 97 111 98 112 //SSL_load_error_strings(); … … 104 118 exit(1); 105 119 } 120 121 outputLog.open("server.log", ios::app); 122 outputLog << "Started server on " << getCurrentDateTimeString() << endl; 106 123 107 124 WorldMap* gameMap = WorldMap::loadMapFromFile("../data/map.txt"); … … 138 155 timespec ts; 139 156 int timeLastUpdated = 0, curTime = 0, timeLastBroadcast = 0; 140 while ( true) {157 while (!done) { 141 158 142 159 usleep(5000); … … 150 167 timeLastUpdated = curTime; 151 168 152 msgProcessor.cleanAckedMessages( );153 msgProcessor.resendUnackedMessages(sock );169 msgProcessor.cleanAckedMessages(&outputLog); 170 msgProcessor.resendUnackedMessages(sock, &outputLog); 154 171 155 172 map<unsigned int, Player>::iterator it; … … 191 208 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 192 209 { 193 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )210 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 194 211 error("sendMessage"); 195 212 } … … 206 223 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 207 224 { 208 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )225 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 209 226 error("sendMessage"); 210 227 } … … 319 336 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 320 337 { 321 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )338 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 322 339 error("sendMessage"); 323 340 } … … 329 346 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 330 347 { 331 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )348 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 332 349 error("sendMessage"); 333 350 } … … 370 387 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 371 388 { 372 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )389 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 373 390 error("sendMessage"); 374 391 } … … 383 400 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 384 401 { 385 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )402 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 386 403 error("sendMessage"); 387 404 } … … 404 421 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 405 422 { 406 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )423 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 407 424 error("sendMessage"); 408 425 } … … 422 439 423 440 if (flagType != WorldMap::OBJECT_NONE) { 424 addObjectToMap(flagType, target->pos.x, target->pos.y, gameMap, mapPlayers, msgProcessor, sock );441 addObjectToMap(flagType, target->pos.x, target->pos.y, gameMap, mapPlayers, msgProcessor, sock, outputLog); 425 442 } 426 443 } … … 452 469 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 453 470 { 454 if (msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )471 if (msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 455 472 error("sendMessage"); 456 473 } … … 474 491 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 475 492 { 476 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )493 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 477 494 error("sendMessage"); 478 495 } … … 492 509 493 510 if (flagType != WorldMap::OBJECT_NONE) { 494 addObjectToMap(flagType, target->pos.x, target->pos.y, gameMap, mapPlayers, msgProcessor, sock );511 addObjectToMap(flagType, target->pos.x, target->pos.y, gameMap, mapPlayers, msgProcessor, sock, outputLog); 495 512 } 496 513 } … … 502 519 for (it2 = mapPlayers.begin(); it2 != mapPlayers.end(); it2++) 503 520 { 504 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr) ) < 0 )521 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it2->second.addr), &outputLog) < 0 ) 505 522 error("sendMessage"); 506 523 } … … 510 527 } 511 528 512 n = msgProcessor.receiveMessage(&clientMsg, sock, &from );529 n = msgProcessor.receiveMessage(&clientMsg, sock, &from, &outputLog); 513 530 514 531 if (n >= 0) { 515 broadcastResponse = processMessage(clientMsg, from, msgProcessor, mapPlayers, gameMap, unusedPlayerId, serverMsg, sock, scoreBlue, scoreRed );532 broadcastResponse = processMessage(clientMsg, from, msgProcessor, mapPlayers, gameMap, unusedPlayerId, serverMsg, sock, scoreBlue, scoreRed, outputLog); 516 533 517 534 if (broadcastResponse) … … 523 540 { 524 541 cout << "Sent message back to " << it->second.name << endl; 525 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr) ) < 0 )542 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr), &outputLog) < 0 ) 526 543 error("sendMessage"); 527 544 } … … 531 548 cout << "Should be sending back the message" << endl; 532 549 533 if ( msgProcessor.sendMessage(&serverMsg, sock, &from ) < 0 )550 if ( msgProcessor.sendMessage(&serverMsg, sock, &from, &outputLog) < 0 ) 534 551 error("sendMessage"); 535 552 } 536 553 } 537 554 } 555 556 outputLog << "Stopped server on " << getCurrentDateTimeString() << endl; 557 outputLog.close(); 538 558 539 559 return 0; 540 560 } 541 561 542 bool processMessage(const NETWORK_MSG &clientMsg, struct sockaddr_in &from, MessageProcessor &msgProcessor, map<unsigned int, Player>& mapPlayers, WorldMap* gameMap, unsigned int& unusedPlayerId, NETWORK_MSG &serverMsg, int sock, int &scoreBlue, int &scoreRed )562 bool processMessage(const NETWORK_MSG &clientMsg, struct sockaddr_in &from, MessageProcessor &msgProcessor, map<unsigned int, Player>& mapPlayers, WorldMap* gameMap, unsigned int& unusedPlayerId, NETWORK_MSG &serverMsg, int sock, int &scoreBlue, int &scoreRed, ofstream& outputLog) 543 563 { 544 564 DataAccess da; … … 630 650 cout << "sending info about " << it->second.name << endl; 631 651 cout << "sending id " << it->second.id << endl; 632 if ( msgProcessor.sendMessage(&serverMsg, sock, &from ) < 0 )652 if ( msgProcessor.sendMessage(&serverMsg, sock, &from, &outputLog) < 0 ) 633 653 error("sendMessage"); 634 654 } … … 643 663 itObjects->serialize(serverMsg.buffer); 644 664 cout << "sending item id " << itObjects->id << endl; 645 if ( msgProcessor.sendMessage(&serverMsg, sock, &from ) < 0 )665 if ( msgProcessor.sendMessage(&serverMsg, sock, &from, &outputLog) < 0 ) 646 666 error("sendMessage"); 647 667 } … … 651 671 memcpy(serverMsg.buffer, &scoreBlue, 4); 652 672 memcpy(serverMsg.buffer+4, &scoreRed, 4); 653 if ( msgProcessor.sendMessage(&serverMsg, sock, &from ) < 0 )673 if ( msgProcessor.sendMessage(&serverMsg, sock, &from, &outputLog) < 0 ) 654 674 error("sendMessage"); 655 675 … … 661 681 { 662 682 cout << "Sent message back to " << it->second.name << endl; 663 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr) ) < 0 )683 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr), &outputLog) < 0 ) 664 684 error("sendMessage"); 665 685 } … … 701 721 702 722 if (flagType != WorldMap::OBJECT_NONE) { 703 addObjectToMap(flagType, p->pos.x, p->pos.y, gameMap, mapPlayers, msgProcessor, sock );723 addObjectToMap(flagType, p->pos.x, p->pos.y, gameMap, mapPlayers, msgProcessor, sock, outputLog); 704 724 } 705 725 } … … 826 846 for (it = mapPlayers.begin(); it != mapPlayers.end(); it++) 827 847 { 828 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr) ) < 0 )848 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr), &outputLog) < 0 ) 829 849 error("sendMessage"); 830 850 } … … 862 882 flagType = WorldMap::OBJECT_RED_FLAG; 863 883 864 addObjectToMap(flagType, mapPlayers[id].pos.x, mapPlayers[id].pos.y, gameMap, mapPlayers, msgProcessor, sock );884 addObjectToMap(flagType, mapPlayers[id].pos.x, mapPlayers[id].pos.y, gameMap, mapPlayers, msgProcessor, sock, outputLog); 865 885 866 886 mapPlayers[id].hasBlueFlag = false; … … 942 962 } 943 963 944 void addObjectToMap(WorldMap::ObjectType objectType, int x, int y, WorldMap* gameMap, map<unsigned int, Player>& mapPlayers, MessageProcessor &msgProcessor, int sock ) {964 void addObjectToMap(WorldMap::ObjectType objectType, int x, int y, WorldMap* gameMap, map<unsigned int, Player>& mapPlayers, MessageProcessor &msgProcessor, int sock, ofstream& outputLog) { 945 965 NETWORK_MSG serverMsg; 946 966 … … 954 974 for (it = mapPlayers.begin(); it != mapPlayers.end(); it++) 955 975 { 956 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr) ) < 0 )976 if ( msgProcessor.sendMessage(&serverMsg, sock, &(it->second.addr), &outputLog) < 0 ) 957 977 error("sendMessage"); 958 978 } 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  ![(please configure the [header_logo] section in trac.ini)](/medieval/chrome/site/your_project_logo.png)
