1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-26 03:52:01 +02:00

Base for netcode

This commit is contained in:
Michał W. Urbańczyk 2008-07-09 17:22:28 +00:00
parent 9422b0d9ca
commit 358ab062eb
10 changed files with 345 additions and 95 deletions

View File

@ -119,7 +119,7 @@ void CMinimap::draw()
} }
} }
} }
blitAt(FoW[LOCPLINT->adventureInt->position.z],0,0,temps); //blitAt(FoW[LOCPLINT->adventureInt->position.z],0,0,temps);
//draw radar //draw radar
int bx = (((float)LOCPLINT->adventureInt->position.x)/(((float)CGI->mh->sizes.x)))*pos.w, int bx = (((float)LOCPLINT->adventureInt->position.x)/(((float)CGI->mh->sizes.x)))*pos.w,

View File

@ -106,6 +106,7 @@ public:
friend CScriptCallback; friend CScriptCallback;
friend void handleCPPObjS(std::map<int,CCPPObjectScript*> * mapa, CCPPObjectScript * script); friend void handleCPPObjS(std::map<int,CCPPObjectScript*> * mapa, CCPPObjectScript * script);
friend class CMapHandler; friend class CMapHandler;
friend class CVCMIServer;
}; };
#endif //CGAMESTATE_H #endif //CGAMESTATE_H

79
CMT.cpp
View File

@ -1,7 +1,6 @@
// CMT.cpp : Defines the entry point for the console application. // CMT.cpp : Defines the entry point for the console application.
// //
#include "stdafx.h" #include "stdafx.h"
#include "SDL.h"
#include "SDL_TTF.h" #include "SDL_TTF.h"
#include "hch/CVideoHandler.h" #include "hch/CVideoHandler.h"
#include "SDL_mixer.h" #include "SDL_mixer.h"
@ -44,6 +43,7 @@
#include "client/Graphics.h" #include "client/Graphics.h"
#include <boost/thread.hpp> #include <boost/thread.hpp>
#include "lib/Connection.h" #include "lib/Connection.h"
#include <boost/crc.hpp>
std::string NAME = NAME_VER + std::string(" (client)"); std::string NAME = NAME_VER + std::string(" (client)");
DLL_EXPORT void initDLL(CLodHandler *b); DLL_EXPORT void initDLL(CLodHandler *b);
SDL_Surface * screen, * screen2; SDL_Surface * screen, * screen2;
@ -62,9 +62,6 @@ int _tmain(int argc, _TCHAR* argv[])
{ {
//boost::thread servthr(boost::bind(system,"VCMI_server.exe")); //runs server executable; //boost::thread servthr(boost::bind(system,"VCMI_server.exe")); //runs server executable;
//TODO: add versions for other platforms //TODO: add versions for other platforms
CConnection c("localhost","3030",NAME,std::cout);
int r;
c >> r;
std::cout << NAME << std::endl; std::cout << NAME << std::endl;
srand ( time(NULL) ); srand ( time(NULL) );
@ -150,7 +147,7 @@ int _tmain(int argc, _TCHAR* argv[])
THC std::cout<<"Initialization of VCMI (togeter): "<<total.getDif()<<std::endl; THC std::cout<<"Initialization of VCMI (togeter): "<<total.getDif()<<std::endl;
cpg->mush = mush; cpg->mush = mush;
StartInfo *options = new StartInfo(cpg->runLoop()); StartInfo *options = new StartInfo(cpg->runLoop());
///////////////////////////////////////////////////////////////////////////////////////
cgi->dobjinfo = new CDefObjInfoHandler; cgi->dobjinfo = new CDefObjInfoHandler;
cgi->dobjinfo->load(); cgi->dobjinfo->load();
THC std::cout<<"\tDef information handler: "<<pomtime.getDif()<<std::endl; THC std::cout<<"\tDef information handler: "<<pomtime.getDif()<<std::endl;
@ -192,7 +189,9 @@ int _tmain(int argc, _TCHAR* argv[])
cgi->consoleh->runConsole(); cgi->consoleh->runConsole();
THC std::cout<<"\tCallback and console: "<<pomtime.getDif()<<std::endl; THC std::cout<<"\tCallback and console: "<<pomtime.getDif()<<std::endl;
THC std::cout<<"Handlers initialization (together): "<<tmh.getDif()<<std::endl; THC std::cout<<"Handlers initialization (together): "<<tmh.getDif()<<std::endl;
//////////////////////////////////loading map and connecting
CConnection c("localhost","3030",NAME,std::cout);
THC std::cout<<"\tConnecting to the server: "<<tmh.getDif()<<std::endl;
std::string mapname = cpg->ourScenSel->mapsel.ourMaps[cpg->ourScenSel->mapsel.selected].filename; std::string mapname = cpg->ourScenSel->mapsel.ourMaps[cpg->ourScenSel->mapsel.selected].filename;
std::cout<<"Opening map file: "<<mapname<<"\t\t"<<std::flush; std::cout<<"Opening map file: "<<mapname<<"\t\t"<<std::flush;
gzFile map = gzopen(mapname.c_str(),"rb"); gzFile map = gzopen(mapname.c_str(),"rb");
@ -208,9 +207,25 @@ int _tmain(int argc, _TCHAR* argv[])
initTable[ss] = mapstr[ss]; initTable[ss] = mapstr[ss];
} }
std::cout<<"done."<<std::endl; std::cout<<"done."<<std::endl;
////////////////////////////////////////////////////
ui8 pom8;
c << uint8_t(2) << uint8_t(1) << mapname;
c >> pom8;
if(pom8) throw "Server cannot open the map!";
c < *options;
c << ui8(options->playerInfos.size());
for(int i=0;i<options->playerInfos.size();i++)
c << ui8(options->playerInfos[i].color);
boost::crc_32_type result;
result.process_bytes(initTable,mapstr.size());
std::cout << "\tMap checksum: "<<result.checksum();
std::cout << "\t" << sizeof(result.checksum());
THC std::cout<<"\tSending info to the server: "<<tmh.getDif()<<std::endl;
Mapa * mapa = new Mapa(initTable); Mapa * mapa = new Mapa(initTable);
THC std::cout<<"Reading and detecting map file (together): "<<tmh.getDif()<<std::endl;
THC std::cout<<"Reading and detecting map file (together): "<<tmh.getDif()<<std::endl;
cgi->state->init(options,mapa,8); cgi->state->init(options,mapa,8);
CMapHandler * mh = cgi->mh = new CMapHandler(); CMapHandler * mh = cgi->mh = new CMapHandler();
@ -236,36 +251,36 @@ int _tmain(int argc, _TCHAR* argv[])
} }
///claculating FoWs for minimap ///claculating FoWs for minimap
/****************************Minimaps' FoW******************************************/ /****************************Minimaps' FoW******************************************/
for(int g=0; g<cgi->playerint.size(); ++g) //for(int g=0; g<cgi->playerint.size(); ++g)
{ //{
if(!cgi->playerint[g]->human) // if(!cgi->playerint[g]->human)
continue; // continue;
CMinimap & mm = ((CPlayerInterface*)cgi->playerint[g])->adventureInt->minimap; // CMinimap & mm = ((CPlayerInterface*)cgi->playerint[g])->adventureInt->minimap;
int mw = mm.map[0]->w, mh = mm.map[0]->h, // int mw = mm.map[0]->w, mh = mm.map[0]->h,
wo = mw/CGI->mh->sizes.x, ho = mh/CGI->mh->sizes.y; // wo = mw/CGI->mh->sizes.x, ho = mh/CGI->mh->sizes.y;
for(int d=0; d<cgi->mh->map->twoLevel+1; ++d) // for(int d=0; d<cgi->mh->map->twoLevel+1; ++d)
{ // {
SDL_Surface * pt = CSDL_Ext::newSurface(mm.pos.w, mm.pos.h, CSDL_Ext::std32bppSurface); // SDL_Surface * pt = CSDL_Ext::newSurface(mm.pos.w, mm.pos.h, CSDL_Ext::std32bppSurface);
for (int i=0; i<mw; i++) // for (int i=0; i<mw; i++)
{ // {
for (int j=0; j<mh; j++) // for (int j=0; j<mh; j++)
{ // {
int3 pp( ((i*CGI->mh->sizes.x)/mw), ((j*CGI->mh->sizes.y)/mh), d ); // int3 pp( ((i*CGI->mh->sizes.x)/mw), ((j*CGI->mh->sizes.y)/mh), d );
if ( !((CPlayerInterface*)cgi->playerint[g])->cb->isVisible(pp) ) // if ( !((CPlayerInterface*)cgi->playerint[g])->cb->isVisible(pp) )
{ // {
CSDL_Ext::SDL_PutPixelWithoutRefresh(pt,i,j,0,0,0); // CSDL_Ext::SDL_PutPixelWithoutRefresh(pt,i,j,0,0,0);
} // }
} // }
} // }
CSDL_Ext::update(pt); // CSDL_Ext::update(pt);
mm.FoW.push_back(pt); // mm.FoW.push_back(pt);
} // }
} //}
while(1) //main game loop, one execution per turn while(1) //main game loop, one execution per turn
{ {

Binary file not shown.

View File

@ -10,26 +10,47 @@ struct StartInfo
{ {
struct PlayerSettings struct PlayerSettings
{ {
int castle, hero, //ID, if -1 then random, if -2 then none si32 castle, hero, //ID, if -1 then random, if -2 then none
heroPortrait; //-1 if default, else ID heroPortrait; //-1 if default, else ID
std::string heroName; std::string heroName;
Ebonus bonus; si8 bonus; //usees enum type Ebonus
Ecolor color; //from 0 - ui8 color; //from 0 -
int serial; ui8 serial;
int handicap;//0-no, 1-mild, 2-severe ui8 handicap;//0-no, 1-mild, 2-severe
std::string name; std::string name;
bool human; bool human;
template <typename Handler> void serialize(Handler &h, const int version)
{
h && castle;
h && hero;
h && heroPortrait;
h && heroName;
h && bonus;
h && color;
h && serial;
h && handicap;
h && name;
h && human;
}
}; };
int difficulty; //0=easy; 4=impossible si32 difficulty; //0=easy; 4=impossible
std::vector<PlayerSettings> playerInfos; std::vector<PlayerSettings> playerInfos;
int turnTime; //in minutes, 0=unlimited ui8 turnTime; //in minutes, 0=unlimited
std::string mapname;
PlayerSettings & getIthPlayersSettings(int no) PlayerSettings & getIthPlayersSettings(int no)
{ {
for(int i=0; i<playerInfos.size(); ++i) for(unsigned int i=0; i<playerInfos.size(); ++i)
if(playerInfos[i].color == no) if(playerInfos[i].color == no)
return playerInfos[i]; return playerInfos[i];
throw new std::exception("Cannot find info about player"); throw new std::exception("Cannot find info about player");
} }
template <typename Handler> void serialize(Handler &h, const int version)
{
h && difficulty;
h & playerInfos;
h && turnTime;
h && mapname;
}
}; };
#endif #endif

View File

@ -1,11 +1,18 @@
#ifndef GLOBAL_H #ifndef GLOBAL_H
#define GLOBAL_H #define GLOBAL_H
#include <iostream>
#include <boost/logic/tribool.hpp>
#include <boost/cstdint.hpp>
typedef boost::uint32_t ui32; //unsigned int 32 bits (4 bytes)
typedef boost::uint16_t ui16; //unsigned int 16 bits (2 bytes)
typedef boost::uint8_t ui8; //unsigned int 8 bits (1 byte)
typedef boost::int32_t si32; //signed int 32 bits (4 bytes)
typedef boost::int16_t si16; //signed int 16 bits (2 bytes)
typedef boost::int8_t si8; //signed int 8 bits (1 byte)
#include "int3.h"
#define CHECKTIME 1 #define CHECKTIME 1
#if CHECKTIME #if CHECKTIME
#include "timeHandler.h" #include "timeHandler.h"
#include <boost/logic/tribool.hpp>
#include <iostream>
#include "int3.h"
#define THC #define THC
#endif #endif

View File

@ -1,4 +1,5 @@
#define VCMI_DLL #define VCMI_DLL
#pragma warning(disable:4355)
#include "Connection.h" #include "Connection.h"
#include <boost/asio.hpp> #include <boost/asio.hpp>
using namespace boost; using namespace boost;
@ -17,41 +18,48 @@ using namespace boost::asio::ip;
#define LIL_ENDIAN #define LIL_ENDIAN
#endif #endif
void CConnection::init()
CConnection::CConnection(std::string host, std::string port, std::string Name, std::ostream & Out)
:io_service(new asio::io_service), name(Name), out(Out)
{ {
#ifdef LIL_ENDIAN #ifdef LIL_ENDIAN
myEndianess = true; myEndianess = true;
#else #else
myEndianess = false; myEndianess = false;
#endif #endif
connected = true;
std::string pom;
//we got connection
(*this) << std::string("Aiya!\n") << name << myEndianess; //identify ourselves
(*this) >> pom >> pom >> contactEndianess;
out << "Established connection with "<<pom<<std::endl;
}
CConnection::CConnection(std::string host, std::string port, std::string Name, std::ostream & Out)
:io_service(new asio::io_service), name(Name), out(Out), send(this), rec(this)
{
system::error_code error = asio::error::host_not_found; system::error_code error = asio::error::host_not_found;
socket = new tcp::socket(*io_service); socket = new tcp::socket(*io_service);
tcp::resolver resolver(*io_service); tcp::resolver resolver(*io_service);
tcp::resolver::iterator endpoint_iterator = resolver.resolve(tcp::resolver::query(host,port)); tcp::resolver::iterator endpoint_iterator = resolver.resolve(tcp::resolver::query(host,port));
socket->connect(*endpoint_iterator, error); socket->connect(*endpoint_iterator, error);
if(error) if (error){ delete socket; throw "Can't establish connection :("; }
{ init();
connected = false;
return;
}
std::string pom;
//we got connection
(*this) << std::string("Aiya!\n") << name << myEndianess; //identify ourselves
(*this) >> pom >> pom >> contactEndianess;
} }
CConnection::CConnection( CConnection::CConnection(
boost::asio::basic_stream_socket<boost::asio::ip::tcp , boost::asio::stream_socket_service<boost::asio::ip::tcp> > * Socket, boost::asio::basic_stream_socket<boost::asio::ip::tcp , boost::asio::stream_socket_service<boost::asio::ip::tcp> > * Socket,
boost::asio::io_service *Io_service,
std::string Name, std::string Name,
std::ostream & Out ) std::ostream & Out )
:socket(Socket),io_service(Io_service), out(Out), name(Name) :socket(Socket),io_service(Socket->io_service()), out(Out), name(Name), send(this), rec(this)
{ {
std::string pom; init();
//we start with just connected socket }
(*this) << std::string("Aiya!\n") << name << myEndianess; //identify ourselves CConnection::CConnection(boost::asio::basic_socket_acceptor<boost::asio::ip::tcp, boost::asio::socket_acceptor_service<boost::asio::ip::tcp> > * acceptor, boost::asio::io_service *Io_service, std::string Name, std::ostream & Out)
(*this) >> pom >> pom >> contactEndianess; : out(Out), name(Name), send(this), rec(this)
{
system::error_code error = asio::error::host_not_found;
socket = new tcp::socket(*io_service);
acceptor->accept(*socket,error);
if (error){ delete socket; throw "Can't establish connection :("; }
init();
} }
int CConnection::write(const void * data, unsigned size) int CConnection::write(const void * data, unsigned size)
{ {
@ -68,5 +76,7 @@ int CConnection::read(void * data, unsigned size)
CConnection::~CConnection(void) CConnection::~CConnection(void)
{ {
delete io_service; delete io_service;
if(socket)
socket->close();
delete socket; delete socket;
} }

View File

@ -1,7 +1,11 @@
#pragma once #pragma once
#include "../global.h" #include "../global.h"
#include <boost/cstdint.hpp>
#include <string> #include <string>
#include <vector>
#include <set>
const int version = 63;
class CConnection;
namespace boost namespace boost
{ {
namespace asio namespace asio
@ -13,17 +17,55 @@ namespace boost
class io_service; class io_service;
template <typename Protocol> class stream_socket_service; template <typename Protocol> class stream_socket_service;
template <typename Protocol, template <typename Protocol,typename StreamSocketService>
typename StreamSocketService>
class basic_stream_socket; class basic_stream_socket;
template <typename Protocol> class socket_acceptor_service;
template <typename Protocol,typename SocketAcceptorService>
class basic_socket_acceptor;
} }
}; };
class CSender
{
public:
CConnection* c;
CSender(CConnection* C):c(C){};
template <typename T> CSender & operator&&(T &data) //send built-in type
{
*c << data;
return *this;
}
template <typename T> CSender & operator&(T &data) //send serializable type
{
*c < data;
return *this;
}
};
class CReceiver
{
public:
CConnection *c;
CReceiver(CConnection* C):c(C){};
template <typename T> CReceiver & operator&&(T &data) //get built-in type
{
*c >> data;
return *this;
}
template <typename T> CReceiver & operator&(T &data) //get serializable type
{
*c > data;
return *this;
}
};
class DLL_EXPORT CConnection class DLL_EXPORT CConnection
{ {
std::ostream &out; std::ostream &out;
CConnection(void); CConnection(void);
void init();
public: public:
CSender send;
CReceiver rec;
boost::asio::basic_stream_socket < boost::asio::ip::tcp , boost::asio::stream_socket_service<boost::asio::ip::tcp> > * socket; boost::asio::basic_stream_socket < boost::asio::ip::tcp , boost::asio::stream_socket_service<boost::asio::ip::tcp> > * socket;
bool logging; bool logging;
bool connected; bool connected;
@ -31,8 +73,14 @@ public:
boost::asio::io_service *io_service; boost::asio::io_service *io_service;
std::string name; //who uses this connection std::string name; //who uses this connection
CConnection(std::string host, std::string port, std::string Name, std::ostream & Out); CConnection
CConnection(boost::asio::basic_stream_socket < boost::asio::ip::tcp , boost::asio::stream_socket_service<boost::asio::ip::tcp> > * Socket, boost::asio::io_service *Io_service, std::string Name, std::ostream & Out); //use immediately after accepting connection into socket (std::string host, std::string port, std::string Name, std::ostream & Out);
CConnection
(boost::asio::basic_socket_acceptor<boost::asio::ip::tcp, boost::asio::socket_acceptor_service<boost::asio::ip::tcp> > * acceptor,
boost::asio::io_service *Io_service, std::string Name, std::ostream & Out);
CConnection
(boost::asio::basic_stream_socket < boost::asio::ip::tcp , boost::asio::stream_socket_service<boost::asio::ip::tcp> > * Socket,
std::string Name, std::ostream & Out); //use immediately after accepting connection into socket
int write(const void * data, unsigned size); int write(const void * data, unsigned size);
int read(void * data, unsigned size); int read(void * data, unsigned size);
int readLine(void * data, unsigned maxSize); int readLine(void * data, unsigned maxSize);
@ -53,7 +101,7 @@ CConnection & operator>>(CConnection &c, std::string &data)
{ {
boost::uint32_t length; boost::uint32_t length;
c >> length; c >> length;
data.reserve(length); data.resize(length);
c.read((void*)data.c_str(),length); c.read((void*)data.c_str(),length);
return c; return c;
} }
@ -68,10 +116,49 @@ CConnection & operator>>(CConnection &c, char * &data)
{ {
boost::uint32_t length; boost::uint32_t length;
c >> length; c >> length;
std::cout <<"Alokujemy " <<length << " bajtow."<<std::endl;
data = new char[length]; data = new char[length];
c.read(data,length); c.read(data,length);
return c; return c;
} }
template <typename T> CConnection & operator<<(CConnection &c, std::vector<T> &data)
{
boost::uint32_t length = data.size();
c << length;
for(ui32 i=0;i<length;i++)
c << data[i];
return c;
}
template <typename T> CConnection & operator>>(CConnection &c, std::vector<T> &data)
{
boost::uint32_t length;
c >> length;
data.resize(length);
for(ui32 i=0;i<length;i++)
c >> data[i];
return c;
}
//template <typename T> CConnection & operator<<(CConnection &c, std::set<T> &data)
//{
// boost::uint32_t length = data.size();
// c << length;
// for(std::set<T>::iterator i=data.begin();i!=data.end();i++)
// c << *i;
// return c;
//}
//template <typename T> CConnection & operator>>(CConnection &c, std::set<T> &data)
//{
// boost::uint32_t length;
// c >> length;
// data.resize(length);
// T pom;
// for(int i=0;i<length;i++)
// {
// c >> pom;
// data.insert(pom);
// }
// return c;
//}
template <typename T> CConnection & operator<<(CConnection &c, const T &data) template <typename T> CConnection & operator<<(CConnection &c, const T &data)
{ {
c.write(&data,sizeof(data)); c.write(&data,sizeof(data));
@ -81,4 +168,31 @@ template <typename T> CConnection & operator>>(CConnection &c, T &data)
{ {
c.read(&data,sizeof(data)); c.read(&data,sizeof(data));
return c; return c;
}
template <typename T> CConnection & operator<(CConnection &c, std::vector<T> &data)
{
boost::uint32_t length = data.size();
c << length;
for(ui32 i=0;i<length;i++)
data[i].serialize(c.send,version);
return c;
}
template <typename T> CConnection & operator>(CConnection &c, std::vector<T> &data)
{
boost::uint32_t length;
c >> length;
data.resize(length);
for(ui32 i=0;i<length;i++)
data[i].serialize(c.rec,version);
return c;
}
template <typename T> CConnection & operator<(CConnection &c, T &data)
{
data.serialize(c.send,version);
return c;
}
template <typename T> CConnection & operator>(CConnection &c, T &data)
{
data.serialize(c.rec,version);
return c;
} }

View File

@ -20,7 +20,7 @@
OutputDirectory="$(SolutionDir)" OutputDirectory="$(SolutionDir)"
IntermediateDirectory="$(ConfigurationName)" IntermediateDirectory="$(ConfigurationName)"
ConfigurationType="1" ConfigurationType="1"
CharacterSet="2" CharacterSet="1"
> >
<Tool <Tool
Name="VCPreBuildEventTool" Name="VCPreBuildEventTool"
@ -45,6 +45,7 @@
RuntimeLibrary="3" RuntimeLibrary="3"
WarningLevel="3" WarningLevel="3"
DebugInformationFormat="4" DebugInformationFormat="4"
DisableSpecificWarnings="4251"
/> />
<Tool <Tool
Name="VCManagedResourceCompilerTool" Name="VCManagedResourceCompilerTool"
@ -57,7 +58,7 @@
/> />
<Tool <Tool
Name="VCLinkerTool" Name="VCLinkerTool"
AdditionalDependencies="VCMI_lib.lib" AdditionalDependencies="VCMI_lib.lib zdll.lib"
AdditionalLibraryDirectories="G:\vcmt\repa\libs" AdditionalLibraryDirectories="G:\vcmt\repa\libs"
GenerateDebugInformation="true" GenerateDebugInformation="true"
TargetMachine="1" TargetMachine="1"
@ -127,7 +128,7 @@
/> />
<Tool <Tool
Name="VCLinkerTool" Name="VCLinkerTool"
AdditionalDependencies="VCMI_lib.lib" AdditionalDependencies="VCMI_lib.lib zdll.lib"
AdditionalLibraryDirectories="G:\vcmt\repa\libs" AdditionalLibraryDirectories="G:\vcmt\repa\libs"
GenerateDebugInformation="true" GenerateDebugInformation="true"
OptimizeReferences="2" OptimizeReferences="2"

View File

@ -4,58 +4,139 @@
#include <boost/asio.hpp> #include <boost/asio.hpp>
#include "../global.h" #include "../global.h"
#include "../lib/Connection.h" #include "../lib/Connection.h"
#include "../CGameState.h"
#include "zlib.h"
#include <boost/thread.hpp>
#include <boost/crc.hpp>
#include <boost/serialization/split_member.hpp>
#include "../StartInfo.h"
std::string NAME = NAME_VER + std::string(" (server)"); std::string NAME = NAME_VER + std::string(" (server)");
using boost::asio::ip::tcp; using boost::asio::ip::tcp;
using namespace boost; using namespace boost;
using namespace boost::asio; using namespace boost::asio;
using namespace boost::asio::ip; using namespace boost::asio::ip;
mutex smx1;
class CVCMIServer class CVCMIServer
{ {
CGameState *gs;
tcp::acceptor acceptor; tcp::acceptor acceptor;
std::vector<CConnection*> connections; std::map<int,CConnection*> connections;
std::set<CConnection*> conns;
ui32 seed;
public: public:
CVCMIServer(io_service& io_service) CVCMIServer(io_service& io_service)
: acceptor(io_service, tcp::endpoint(tcp::v4(), 3030)) : acceptor(io_service, tcp::endpoint(tcp::v4(), 3030))
{ {
start_accept(); start();
} }
private: void setUpConnection(CConnection *c, std::string mapname, si32 checksum)
void start_accept() {
ui8 quantity, pom;
(*c) << mapname << checksum << seed;
(*c) >> quantity;
for(int i=0;i<quantity;i++)
{
(*c) >> pom;
smx1.lock();
connections[pom] = c;
conns.insert(c);
smx1.unlock();
}
}
void newGame(CConnection &c)
{ {
boost::system::error_code error; boost::system::error_code error;
std::cout<<"Listening for connections at port " << acceptor.local_endpoint().port() << std::endl; StartInfo *si = new StartInfo;
tcp::socket s(acceptor.io_service()); ui8 clients;
acceptor.accept(s,error); std::string mapname;
if (!error) c >> clients;
c >> mapname;
//getting map
gzFile map = gzopen(mapname.c_str(),"rb");
if(!map){ c << int8_t(1); return; }
std::vector<unsigned char> mapstr; int pom;
while((pom=gzgetc(map))>=0)
{ {
CConnection *connection = new CConnection(&s,&s.io_service(),NAME,std::cout); mapstr.push_back(pom);
std::cout<<"Got connection!" << std::endl;
} }
else gzclose(map);
//map is decompressed
c << int8_t(0); //OK!
gs = new CGameState();
gs->scenarioOps = si;
c > *si; //get start options
boost::crc_32_type result;
result.process_bytes(&(*mapstr.begin()),mapstr.size());
int checksum = result.checksum();
std::cout << "Checksum:" << checksum << std::endl;
CConnection* cc; tcp::socket * ss;
for(int i=0; i<clients; i++)
{
if(!i)
{
cc=&c;
}
else
{
tcp::socket * s = new tcp::socket(acceptor.io_service());
acceptor.accept(*s,error);
if(error) //retry
{
std::cout<<"Cannot establish connection - retrying..." << std::endl;
i--;
continue;
}
cc = new CConnection(s,NAME,std::cout);
}
setUpConnection(cc,mapname,checksum);
}
//TODO: wait for other connections
}
void start()
{
srand ( time(NULL) );
seed = rand();
boost::system::error_code error;
std::cout<<"Listening for connections at port " << acceptor.local_endpoint().port() << std::endl;
tcp::socket * s = new tcp::socket(acceptor.io_service());
acceptor.accept(*s,error);
if (error)
{ {
std::cout<<"Got connection but there is an error " << std::endl; std::cout<<"Got connection but there is an error " << std::endl;
return;
}
CConnection connection(s,NAME,std::cout);
std::cout<<"Got connection!" << std::endl;
while(1)
{
uint8_t mode;
connection >> mode;
switch (mode)
{
case 0:
connection.socket->close();
exit(0);
break;
case 1:
connection.socket->close();
return;
break;
case 2:
newGame(connection);
break;
}
} }
//asio::write(s,asio::buffer("570"));
//new_connection->witaj();
//acceptor.async_accept(s,
// boost::bind(&CVCMIServer::gotConnection, this, &s,
// placeholders::error));
} }
void gotConnection(tcp::socket *s,const boost::system::error_code& error)
{
}
}; };
int main() int _tmain(int argc, _TCHAR* argv[])
{ {
try try
{ {
io_service io_service; io_service io_service;
CVCMIServer server(io_service); CVCMIServer server(io_service);
while(1)
server.start();
io_service.run(); io_service.run();
} }
catch (std::exception& e) catch (std::exception& e)