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:
parent
9422b0d9ca
commit
358ab062eb
@ -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,
|
||||||
|
@ -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
79
CMT.cpp
@ -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
|
||||||
{
|
{
|
||||||
|
BIN
CPreGame.cpp
BIN
CPreGame.cpp
Binary file not shown.
37
StartInfo.h
37
StartInfo.h
@ -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
|
13
global.h
13
global.h
@ -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
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
126
lib/Connection.h
126
lib/Connection.h
@ -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;
|
||||||
}
|
}
|
@ -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"
|
||||||
|
@ -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)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user