mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-12 02:28:11 +02:00
* save/load partially working
* Arena and Witch Hut support * improved support for Resources * minor fixes and changes
This commit is contained in:
parent
645ed84978
commit
3474fdaf05
@ -1089,7 +1089,7 @@ void CHallInterface::close()
|
|||||||
delete this;
|
delete this;
|
||||||
LOCPLINT->castleInt->activate();
|
LOCPLINT->castleInt->activate();
|
||||||
}
|
}
|
||||||
void CHallInterface::show(SDL_Surface * to) //TODO use me
|
void CHallInterface::show(SDL_Surface * to)
|
||||||
{
|
{
|
||||||
blitAt(bg,pos);
|
blitAt(bg,pos);
|
||||||
resdatabar.show();
|
resdatabar.show();
|
||||||
@ -1460,7 +1460,7 @@ void CFortScreen::RecArea::clickLeft (tribool down)
|
|||||||
if(!down && pressedL)
|
if(!down && pressedL)
|
||||||
{
|
{
|
||||||
LOCPLINT->curint->deactivate();
|
LOCPLINT->curint->deactivate();
|
||||||
//CRecrutationWindow *rw = LOCPLINT->castleInt->showRecruitmentWindow(bid); //TODO use me
|
CRecrutationWindow *rw = LOCPLINT->castleInt->showRecruitmentWindow(bid); //do not touch me
|
||||||
}
|
}
|
||||||
ClickableL::clickLeft(down);
|
ClickableL::clickLeft(down);
|
||||||
}
|
}
|
||||||
@ -1530,7 +1530,7 @@ void CMageGuildScreen::close()
|
|||||||
LOCPLINT->castleInt->subInt = NULL;
|
LOCPLINT->castleInt->subInt = NULL;
|
||||||
LOCPLINT->castleInt->activate();
|
LOCPLINT->castleInt->activate();
|
||||||
}
|
}
|
||||||
void CMageGuildScreen::show(SDL_Surface * to) //TODO use me
|
void CMageGuildScreen::show(SDL_Surface * to)
|
||||||
{
|
{
|
||||||
blitAt(bg,pos);
|
blitAt(bg,pos);
|
||||||
resdatabar.show();
|
resdatabar.show();
|
||||||
|
@ -1,4 +1,24 @@
|
|||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "CGameInfo.h"
|
#include "CGameInfo.h"
|
||||||
|
#include "lib/VCMI_Lib.h"
|
||||||
|
|
||||||
CGameInfo * CGI;
|
CGameInfo * CGI;
|
||||||
|
|
||||||
|
CGameInfo::CGameInfo()
|
||||||
|
{
|
||||||
|
mh = NULL;
|
||||||
|
state = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CGameInfo::setFromLib()
|
||||||
|
{
|
||||||
|
generaltexth = VLC->generaltexth;
|
||||||
|
arth = VLC->arth;
|
||||||
|
creh = VLC->creh;
|
||||||
|
townh = VLC->townh;
|
||||||
|
heroh = VLC->heroh;
|
||||||
|
objh = VLC->objh;
|
||||||
|
spellh = VLC->spellh;
|
||||||
|
dobjinfo = VLC->dobjinfo;
|
||||||
|
buildh = VLC->buildh;
|
||||||
|
}
|
@ -61,6 +61,9 @@ public:
|
|||||||
CPathfinder * pathf;
|
CPathfinder * pathf;
|
||||||
CCursorHandler * curh;
|
CCursorHandler * curh;
|
||||||
CScreenHandler * screenh;
|
CScreenHandler * screenh;
|
||||||
|
|
||||||
|
CGameInfo();
|
||||||
|
void setFromLib();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -1122,10 +1122,16 @@ int CGameState::getDate(int mode) const
|
|||||||
CGameState::CGameState()
|
CGameState::CGameState()
|
||||||
{
|
{
|
||||||
mx = new boost::shared_mutex();
|
mx = new boost::shared_mutex();
|
||||||
|
map = NULL;
|
||||||
|
curB = NULL;
|
||||||
|
scenarioOps = NULL;
|
||||||
}
|
}
|
||||||
CGameState::~CGameState()
|
CGameState::~CGameState()
|
||||||
{
|
{
|
||||||
delete mx;
|
delete mx;
|
||||||
|
delete map;
|
||||||
|
delete curB;
|
||||||
|
delete scenarioOps;
|
||||||
}
|
}
|
||||||
void CGameState::init(StartInfo * si, Mapa * map, int Seed)
|
void CGameState::init(StartInfo * si, Mapa * map, int Seed)
|
||||||
{
|
{
|
||||||
|
13
CGameState.h
13
CGameState.h
@ -59,7 +59,6 @@ public:
|
|||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
h & color & serial & currentSelection & fogOfWarMap & resources;
|
h & color & serial & currentSelection & fogOfWarMap & resources;
|
||||||
//TODO: vectors of heroes/towns
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -187,8 +186,6 @@ private:
|
|||||||
|
|
||||||
boost::shared_mutex *mx;
|
boost::shared_mutex *mx;
|
||||||
|
|
||||||
CGameState();
|
|
||||||
~CGameState();
|
|
||||||
void init(StartInfo * si, Mapa * map, int Seed);
|
void init(StartInfo * si, Mapa * map, int Seed);
|
||||||
void loadTownDInfos();
|
void loadTownDInfos();
|
||||||
void applyNL(IPack * pack);
|
void applyNL(IPack * pack);
|
||||||
@ -210,6 +207,8 @@ private:
|
|||||||
float getMarketEfficiency(int player, int mode=0);
|
float getMarketEfficiency(int player, int mode=0);
|
||||||
std::set<int3> tilesToReveal(int3 pos, int radious, int player) const; //if player==-1 => adds all tiles in radious
|
std::set<int3> tilesToReveal(int3 pos, int radious, int player) const; //if player==-1 => adds all tiles in radious
|
||||||
public:
|
public:
|
||||||
|
CGameState();
|
||||||
|
~CGameState();
|
||||||
int getDate(int mode=0) const; //mode=0 - total days in game, mode=1 - day of week, mode=2 - current week, mode=3 - current month
|
int getDate(int mode=0) const; //mode=0 - total days in game, mode=1 - day of week, mode=2 - current week, mode=3 - current month
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
@ -217,6 +216,14 @@ public:
|
|||||||
if(!h.saving)
|
if(!h.saving)
|
||||||
{
|
{
|
||||||
loadTownDInfos();
|
loadTownDInfos();
|
||||||
|
|
||||||
|
//recreating towns/heroes vectors in players entries
|
||||||
|
for(int i=0; i<map->towns.size(); i++)
|
||||||
|
if(map->towns[i]->tempOwner < PLAYER_LIMIT)
|
||||||
|
players[map->towns[i]->tempOwner].towns.push_back(map->towns[i]);
|
||||||
|
for(int i=0; i<map->heroes.size(); i++)
|
||||||
|
if(map->heroes[i]->tempOwner < PLAYER_LIMIT)
|
||||||
|
players[map->heroes[i]->tempOwner].heroes.push_back(map->heroes[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -237,10 +237,10 @@ void CHeroWindow::setHero(const CGHeroInstance *Hero)
|
|||||||
{
|
{
|
||||||
secSkillAreas[g]->type = hero->secSkills[g].first;
|
secSkillAreas[g]->type = hero->secSkills[g].first;
|
||||||
secSkillAreas[g]->bonus = hero->secSkills[g].second;
|
secSkillAreas[g]->bonus = hero->secSkills[g].second;
|
||||||
std::string hlp = CGI->abilh->abilities[ hero->secSkills[g].first ]->infoTexts[hero->secSkills[g].second-1];
|
std::string hlp = CGI->generaltexth->skillInfoTexts[ hero->secSkills[g].first ][hero->secSkills[g].second-1];
|
||||||
secSkillAreas[g]->text = hlp.substr(1, hlp.size()-2);
|
secSkillAreas[g]->text = hlp.substr(1, hlp.size()-2);
|
||||||
|
|
||||||
sprintf(bufor, CGI->generaltexth->heroscrn[21].c_str(), CGI->abilh->levels[hero->secSkills[g].second-1].c_str(), CGI->abilh->abilities[hero->secSkills[g].first]->name.c_str());
|
sprintf(bufor, CGI->generaltexth->heroscrn[21].c_str(), CGI->generaltexth->levels[hero->secSkills[g].second-1].c_str(), CGI->generaltexth->skillName[hero->secSkills[g].first].c_str());
|
||||||
secSkillAreas[g]->hoverText = std::string(bufor);
|
secSkillAreas[g]->hoverText = std::string(bufor);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -615,50 +615,50 @@ void CHeroWindow::redrawCurBack()
|
|||||||
if(curHero->secSkills.size()>=1)
|
if(curHero->secSkills.size()>=1)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[0].first*3+3+curHero->secSkills[0].second-1].bitmap, 18, 276, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[0].first*3+3+curHero->secSkills[0].second-1].bitmap, 18, 276, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[0].second-1], 69, 279, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[0].second-1], 69, 279, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[0].first]->name, 69, 299, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[0].first], 69, 299, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
if(curHero->secSkills.size()>=2)
|
if(curHero->secSkills.size()>=2)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[1].first*3+3+curHero->secSkills[1].second-1].bitmap, 161, 276, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[1].first*3+3+curHero->secSkills[1].second-1].bitmap, 161, 276, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[1].second-1], 213, 279, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[1].second-1], 213, 279, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[1].first]->name, 213, 299, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[1].first], 213, 299, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
if(curHero->secSkills.size()>=3)
|
if(curHero->secSkills.size()>=3)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[2].first*3+3+curHero->secSkills[2].second-1].bitmap, 18, 324, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[2].first*3+3+curHero->secSkills[2].second-1].bitmap, 18, 324, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[2].second-1], 69, 327, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[2].second-1], 69, 327, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[2].first]->name, 69, 347, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[2].first], 69, 347, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
if(curHero->secSkills.size()>=4)
|
if(curHero->secSkills.size()>=4)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[3].first*3+3+curHero->secSkills[3].second-1].bitmap, 161, 324, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[3].first*3+3+curHero->secSkills[3].second-1].bitmap, 161, 324, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[3].second-1], 213, 327, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[3].second-1], 213, 327, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[3].first]->name, 213, 347, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[3].first], 213, 347, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
if(curHero->secSkills.size()>=5)
|
if(curHero->secSkills.size()>=5)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[4].first*3+3+curHero->secSkills[4].second-1].bitmap, 18, 372, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[4].first*3+3+curHero->secSkills[4].second-1].bitmap, 18, 372, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[4].second-1], 69, 375, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[4].second-1], 69, 375, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[4].first]->name, 69, 395, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[4].first], 69, 395, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
if(curHero->secSkills.size()>=6)
|
if(curHero->secSkills.size()>=6)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[5].first*3+3+curHero->secSkills[5].second-1].bitmap, 161, 372, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[5].first*3+3+curHero->secSkills[5].second-1].bitmap, 161, 372, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[5].second-1], 213, 375, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[5].second-1], 213, 375, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[5].first]->name, 213, 395, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[5].first], 213, 395, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
if(curHero->secSkills.size()>=7)
|
if(curHero->secSkills.size()>=7)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[6].first*3+3+curHero->secSkills[6].second-1].bitmap, 18, 420, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[6].first*3+3+curHero->secSkills[6].second-1].bitmap, 18, 420, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[6].second-1], 69, 423, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[6].second-1], 69, 423, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[6].first]->name, 69, 443, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[6].first], 69, 443, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
if(curHero->secSkills.size()>=8)
|
if(curHero->secSkills.size()>=8)
|
||||||
{
|
{
|
||||||
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[7].first*3+3+curHero->secSkills[7].second-1].bitmap, 161, 420, curBack);
|
blitAt(CGI->abilh->abils44->ourImages[curHero->secSkills[7].first*3+3+curHero->secSkills[7].second-1].bitmap, 161, 420, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->levels[curHero->secSkills[7].second-1], 213, 423, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->levels[curHero->secSkills[7].second-1], 213, 423, GEOR13, zwykly, curBack);
|
||||||
CSDL_Ext::printAt(CGI->abilh->abilities[curHero->secSkills[7].first]->name, 213, 443, GEOR13, zwykly, curBack);
|
CSDL_Ext::printAt(CGI->generaltexth->skillName[curHero->secSkills[7].first], 213, 443, GEOR13, zwykly, curBack);
|
||||||
}
|
}
|
||||||
|
|
||||||
//printing special ability
|
//printing special ability
|
||||||
|
106
CMT.cpp
106
CMT.cpp
@ -8,8 +8,6 @@
|
|||||||
#include <cmath>
|
#include <cmath>
|
||||||
#include <boost/algorithm/string.hpp>
|
#include <boost/algorithm/string.hpp>
|
||||||
#include "boost/filesystem/operations.hpp"
|
#include "boost/filesystem/operations.hpp"
|
||||||
#include <boost/interprocess/mapped_region.hpp>
|
|
||||||
#include <boost/interprocess/shared_memory_object.hpp>
|
|
||||||
#include <boost/thread.hpp>
|
#include <boost/thread.hpp>
|
||||||
#include <SDL_ttf.h>
|
#include <SDL_ttf.h>
|
||||||
#include <SDL_mixer.h>
|
#include <SDL_mixer.h>
|
||||||
@ -43,7 +41,6 @@
|
|||||||
#include "client/Client.h"
|
#include "client/Client.h"
|
||||||
#include "client/CConfigHandler.h"
|
#include "client/CConfigHandler.h"
|
||||||
#include "lib/Connection.h"
|
#include "lib/Connection.h"
|
||||||
#include "lib/Interprocess.h"
|
|
||||||
#include "lib/VCMI_Lib.h"
|
#include "lib/VCMI_Lib.h"
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
|
||||||
@ -54,7 +51,6 @@ extern SDL_Surface * CSDL_Ext::std32bppSurface;
|
|||||||
std::queue<SDL_Event> events;
|
std::queue<SDL_Event> events;
|
||||||
boost::mutex eventsM;
|
boost::mutex eventsM;
|
||||||
TTF_Font * TNRB16, *TNR, *GEOR13, *GEORXX, *GEORM, *GEOR16;
|
TTF_Font * TNRB16, *TNR, *GEOR13, *GEORXX, *GEORM, *GEOR16;
|
||||||
namespace intpr = boost::interprocess;
|
|
||||||
void processCommand(const std::string &message, CClient *&client);
|
void processCommand(const std::string &message, CClient *&client);
|
||||||
#ifndef __GNUC__
|
#ifndef __GNUC__
|
||||||
int _tmain(int argc, _TCHAR* argv[])
|
int _tmain(int argc, _TCHAR* argv[])
|
||||||
@ -115,15 +111,7 @@ int main(int argc, char** argv)
|
|||||||
cgi->bitmaph->init("Data" PATHSEPARATOR "H3bitmap.lod","Data");
|
cgi->bitmaph->init("Data" PATHSEPARATOR "H3bitmap.lod","Data");
|
||||||
tlog0<<"Loading .lod files: "<<tmh.getDif()<<std::endl;
|
tlog0<<"Loading .lod files: "<<tmh.getDif()<<std::endl;
|
||||||
initDLL(cgi->bitmaph,::console,logfile);
|
initDLL(cgi->bitmaph,::console,logfile);
|
||||||
CGI->generaltexth = VLC->generaltexth;
|
CGI->setFromLib();
|
||||||
CGI->arth = VLC->arth;
|
|
||||||
CGI->creh = VLC->creh;
|
|
||||||
CGI->townh = VLC->townh;
|
|
||||||
CGI->heroh = VLC->heroh;
|
|
||||||
CGI->objh = VLC->objh;
|
|
||||||
CGI->spellh = VLC->spellh;
|
|
||||||
CGI->dobjinfo = VLC->dobjinfo;
|
|
||||||
CGI->buildh = VLC->buildh;
|
|
||||||
tlog0<<"Initializing VCMI_Lib: "<<tmh.getDif()<<std::endl;
|
tlog0<<"Initializing VCMI_Lib: "<<tmh.getDif()<<std::endl;
|
||||||
pomtime.getDif();
|
pomtime.getDif();
|
||||||
cgi->curh = new CCursorHandler;
|
cgi->curh = new CCursorHandler;
|
||||||
@ -134,15 +122,13 @@ int main(int argc, char** argv)
|
|||||||
abilh->loadAbilities();
|
abilh->loadAbilities();
|
||||||
cgi->abilh = abilh;
|
cgi->abilh = abilh;
|
||||||
tlog0<<"\tAbility handler: "<<pomtime.getDif()<<std::endl;
|
tlog0<<"\tAbility handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
cgi->pathf = new CPathfinder();
|
||||||
|
tlog0<<"\tPathfinder: "<<pomtime.getDif()<<std::endl;
|
||||||
tlog0<<"Preparing first handlers: "<<tmh.getDif()<<std::endl;
|
tlog0<<"Preparing first handlers: "<<tmh.getDif()<<std::endl;
|
||||||
pomtime.getDif();
|
pomtime.getDif();
|
||||||
graphics = new Graphics();
|
graphics = new Graphics();
|
||||||
|
graphics->loadHeroAnim();
|
||||||
tlog0<<"\tMain graphics: "<<tmh.getDif()<<std::endl;
|
tlog0<<"\tMain graphics: "<<tmh.getDif()<<std::endl;
|
||||||
std::vector<CDefHandler **> animacje;
|
|
||||||
for(std::vector<CHeroClass *>::iterator i = cgi->heroh->heroClasses.begin();i!=cgi->heroh->heroClasses.end();i++)
|
|
||||||
animacje.push_back(&((*i)->*(&CHeroClass::moveAnim)));
|
|
||||||
graphics->loadHeroAnim(animacje);
|
|
||||||
tlog0<<"\tHero animations: "<<tmh.getDif()<<std::endl;
|
|
||||||
tlog0<<"Initializing game graphics: "<<tmh.getDif()<<std::endl;
|
tlog0<<"Initializing game graphics: "<<tmh.getDif()<<std::endl;
|
||||||
CMessage::init();
|
CMessage::init();
|
||||||
tlog0<<"Message handler: "<<tmh.getDif()<<std::endl;
|
tlog0<<"Message handler: "<<tmh.getDif()<<std::endl;
|
||||||
@ -152,52 +138,50 @@ int main(int argc, char** argv)
|
|||||||
cpg->mush = mush;
|
cpg->mush = mush;
|
||||||
|
|
||||||
StartInfo *options = new StartInfo(cpg->runLoop());
|
StartInfo *options = new StartInfo(cpg->runLoop());
|
||||||
tmh.getDif();
|
|
||||||
////////////////////////SERVER STARTING/////////////////////////////////////////////////
|
|
||||||
char portc[10]; SDL_itoa(conf.cc.port,portc,10);
|
|
||||||
intpr::shared_memory_object smo(intpr::open_or_create,"vcmi_memory",intpr::read_write);
|
|
||||||
smo.truncate(sizeof(ServerReady));
|
|
||||||
intpr::mapped_region mr(smo,intpr::read_write);
|
|
||||||
ServerReady *sr = new(mr.get_address())ServerReady();
|
|
||||||
std::string comm = std::string(SERVER_NAME) + " " + portc + " > server_log.txt";
|
|
||||||
boost::thread servthr(boost::bind(system,comm.c_str())); //runs server executable; //TODO: will it work on non-windows platforms?
|
|
||||||
tlog0<<"Preparing shared memory and starting server: "<<tmh.getDif()<<std::endl;
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////
|
|
||||||
tmh.getDif();pomtime.getDif();//reset timers
|
|
||||||
cgi->pathf = new CPathfinder();
|
|
||||||
tlog0<<"\tPathfinder: "<<pomtime.getDif()<<std::endl;
|
|
||||||
tlog0<<"Handlers initialization (together): "<<tmh.getDif()<<std::endl;
|
|
||||||
std::ofstream logs("client_log.txt");
|
|
||||||
|
|
||||||
CConnection *c=NULL;
|
CClient cl;
|
||||||
//wait until server is ready
|
if(options->mode == 0) //new game
|
||||||
tlog0<<"Waiting for server... ";
|
|
||||||
{
|
{
|
||||||
intpr::scoped_lock<intpr::interprocess_mutex> slock(sr->mutex);
|
tmh.getDif();
|
||||||
while(!sr->ready)
|
char portc[10];
|
||||||
|
SDL_itoa(conf.cc.port,portc,10);
|
||||||
|
CClient::runServer(portc);
|
||||||
|
tlog0<<"Preparing shared memory and starting server: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
tmh.getDif();pomtime.getDif();//reset timers
|
||||||
|
|
||||||
|
CConnection *c=NULL;
|
||||||
|
//wait until server is ready
|
||||||
|
tlog0<<"Waiting for server... ";
|
||||||
|
CClient::waitForServer();
|
||||||
|
tlog0 << tmh.getDif()<<std::endl;
|
||||||
|
while(!c)
|
||||||
{
|
{
|
||||||
sr->cond.wait(slock);
|
try
|
||||||
|
{
|
||||||
|
tlog0 << "Establishing connection...\n";
|
||||||
|
c = new CConnection(conf.cc.server,portc,NAME);
|
||||||
|
}
|
||||||
|
catch(...)
|
||||||
|
{
|
||||||
|
tlog1 << "\nCannot establish connection! Retrying within 2 seconds" <<std::endl;
|
||||||
|
SDL_Delay(2000);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
THC tlog0<<"\tConnecting to the server: "<<tmh.getDif()<<std::endl;
|
||||||
|
cl.newGame(c,options);
|
||||||
|
client = &cl;
|
||||||
|
boost::thread t(boost::bind(&CClient::run,&cl));
|
||||||
}
|
}
|
||||||
intpr::shared_memory_object::remove("vcmi_memory");
|
else //load game
|
||||||
tlog0 << tmh.getDif()<<std::endl;
|
|
||||||
while(!c)
|
|
||||||
{
|
{
|
||||||
try
|
std::string fname = options->mapname;
|
||||||
{
|
boost::algorithm::erase_last(fname,".vlgm1");
|
||||||
tlog0 << "Establishing connection...\n";
|
cl.load(fname);
|
||||||
c = new CConnection(conf.cc.server,portc,NAME,logs);
|
client = &cl;
|
||||||
}
|
boost::thread t(boost::bind(&CClient::run,&cl));
|
||||||
catch(...)
|
|
||||||
{
|
|
||||||
tlog1 << "\nCannot establish connection! Retrying within 2 seconds" <<std::endl;
|
|
||||||
SDL_Delay(2000);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
THC tlog0<<"\tConnecting to the server: "<<tmh.getDif()<<std::endl;
|
|
||||||
CClient cl(c,options);
|
|
||||||
client = &cl;
|
|
||||||
boost::thread t(boost::bind(&CClient::run,&cl));
|
|
||||||
SDL_Event ev;
|
SDL_Event ev;
|
||||||
while(1) //main SDL events loop
|
while(1) //main SDL events loop
|
||||||
{
|
{
|
||||||
@ -275,6 +259,12 @@ void processCommand(const std::string &message, CClient *&client)
|
|||||||
readed >> fname;
|
readed >> fname;
|
||||||
client->save(fname);
|
client->save(fname);
|
||||||
}
|
}
|
||||||
|
else if(cn=="load")
|
||||||
|
{
|
||||||
|
std::string fname;
|
||||||
|
readed >> fname;
|
||||||
|
client->load(fname);
|
||||||
|
}
|
||||||
else if(message=="get txt")
|
else if(message=="get txt")
|
||||||
{
|
{
|
||||||
boost::filesystem::create_directory("Extracted_txts");
|
boost::filesystem::create_directory("Extracted_txts");
|
||||||
@ -305,4 +295,4 @@ void processCommand(const std::string &message, CClient *&client)
|
|||||||
{
|
{
|
||||||
*client->serv << ui16(513) << message;
|
*client->serv << ui16(513) << message;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -646,9 +646,9 @@ void SComponent::init(Etype Type, int Subtype, int Val)
|
|||||||
oss << ((Val>0)?("+"):("-")) << Val << " " << CGI->generaltexth->primarySkillNames[Subtype];
|
oss << ((Val>0)?("+"):("-")) << Val << " " << CGI->generaltexth->primarySkillNames[Subtype];
|
||||||
subtitle = oss.str();
|
subtitle = oss.str();
|
||||||
break;
|
break;
|
||||||
case secskill44:
|
case secskill44: case secskill:
|
||||||
subtitle += CGI->abilh->levels[Val-1] + " " + CGI->abilh->abilities[Subtype]->name;
|
subtitle += CGI->generaltexth->levels[Val-1] + " " + CGI->generaltexth->skillName[Subtype];
|
||||||
description = CGI->abilh->abilities[Subtype]->infoTexts[Val-1];
|
description = CGI->generaltexth->skillInfoTexts[Subtype][Val-1];
|
||||||
break;
|
break;
|
||||||
case resource:
|
case resource:
|
||||||
description = CGI->generaltexth->allTexts[242];
|
description = CGI->generaltexth->allTexts[242];
|
||||||
|
197
CPreGame.cpp
197
CPreGame.cpp
@ -20,6 +20,7 @@
|
|||||||
#include <boost/thread.hpp>
|
#include <boost/thread.hpp>
|
||||||
#include <boost/bind.hpp>
|
#include <boost/bind.hpp>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
#include "lib/Connection.h"
|
||||||
|
|
||||||
extern SDL_Surface * screen;
|
extern SDL_Surface * screen;
|
||||||
extern SDL_Color tytulowy, tlo, zwykly ;
|
extern SDL_Color tytulowy, tlo, zwykly ;
|
||||||
@ -811,12 +812,10 @@ void Options::hide()
|
|||||||
MapSel::~MapSel()
|
MapSel::~MapSel()
|
||||||
{
|
{
|
||||||
SDL_FreeSurface(bg);
|
SDL_FreeSurface(bg);
|
||||||
for (size_t i=0; i < scenImgs.size(); ++i) {
|
for (size_t i=0; i < scenImgs.size(); ++i)
|
||||||
|
{
|
||||||
SDL_FreeSurface(scenImgs[i]);
|
SDL_FreeSurface(scenImgs[i]);
|
||||||
}
|
}
|
||||||
for (size_t i=0; i < scenList.size(); ++i) {
|
|
||||||
delete scenList[i];
|
|
||||||
}
|
|
||||||
delete sFlags;
|
delete sFlags;
|
||||||
}
|
}
|
||||||
int MapSel::countWL()
|
int MapSel::countWL()
|
||||||
@ -838,9 +837,9 @@ void MapSel::printMaps(int from, int to, int at, bool abs)
|
|||||||
if (true)//
|
if (true)//
|
||||||
{
|
{
|
||||||
int help=-1;
|
int help=-1;
|
||||||
for (size_t i=0; i < ourMaps.size(); ++i)
|
for (size_t i=0; i < curVector().size(); ++i)
|
||||||
{
|
{
|
||||||
if (sizeFilter && ((ourMaps[i].width) != sizeFilter)) {
|
if (sizeFilter && ((curVector()[i].width) != sizeFilter)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -857,7 +856,7 @@ void MapSel::printMaps(int from, int to, int at, bool abs)
|
|||||||
SDL_Color nasz;
|
SDL_Color nasz;
|
||||||
for (int i=at;i<to;i++)
|
for (int i=at;i<to;i++)
|
||||||
{
|
{
|
||||||
if ((i-at+from) > ourMaps.size()-1)
|
if ((i-at+from) > curVector().size()-1)
|
||||||
{
|
{
|
||||||
SDL_Surface * scenin = CSDL_Ext::newSurface(351,25);
|
SDL_Surface * scenin = CSDL_Ext::newSurface(351,25);
|
||||||
SDL_BlitSurface(bg,&genRect(25,351,22,(i-at)*25+115),scenin,NULL);
|
SDL_BlitSurface(bg,&genRect(25,351,22,(i-at)*25+115),scenin,NULL);
|
||||||
@ -867,12 +866,12 @@ void MapSel::printMaps(int from, int to, int at, bool abs)
|
|||||||
SDL_FreeSurface(scenin);
|
SDL_FreeSurface(scenin);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (sizeFilter && ((ourMaps[(i-at)+from].width) != sizeFilter))
|
if (sizeFilter && ((curVector()[(i-at)+from].width) != sizeFilter))
|
||||||
{
|
{
|
||||||
to++;
|
to++;
|
||||||
at++;
|
at++;
|
||||||
from++;
|
from++;
|
||||||
if (((i-at)+from)>ourMaps.size()-1) break;
|
if (((i-at)+from)>curVector().size()-1) break;
|
||||||
else continue;
|
else continue;
|
||||||
}
|
}
|
||||||
if ((i-at+from) == selected)
|
if ((i-at+from) == selected)
|
||||||
@ -881,10 +880,10 @@ void MapSel::printMaps(int from, int to, int at, bool abs)
|
|||||||
//SDL_Rect pier = genRect(25,351,24,126+(i*25));
|
//SDL_Rect pier = genRect(25,351,24,126+(i*25));
|
||||||
SDL_BlitSurface(bg,&genRect(25,351,22,(i-at)*25+115),scenin,NULL);
|
SDL_BlitSurface(bg,&genRect(25,351,22,(i-at)*25+115),scenin,NULL);
|
||||||
int temp=-1;
|
int temp=-1;
|
||||||
std::ostringstream ostr(std::ostringstream::out); ostr << ourMaps[(i-at)+from].playerAmnt << "/" << ourMaps[(i-at)+from].humenPlayers;
|
std::ostringstream ostr(std::ostringstream::out); ostr << curVector()[(i-at)+from].playerAmnt << "/" << curVector()[(i-at)+from].humenPlayers;
|
||||||
CSDL_Ext::printAt(ostr.str(),6,4,GEOR13,nasz,scenin, 2);
|
CSDL_Ext::printAt(ostr.str(),6,4,GEOR13,nasz,scenin, 2);
|
||||||
std::string temp2;
|
std::string temp2;
|
||||||
switch (ourMaps[(i-at)+from].width)
|
switch (curVector()[(i-at)+from].width)
|
||||||
{
|
{
|
||||||
case 36:
|
case 36:
|
||||||
temp2="S";
|
temp2="S";
|
||||||
@ -903,7 +902,7 @@ void MapSel::printMaps(int from, int to, int at, bool abs)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
CSDL_Ext::printAtMiddle(temp2,50,13,GEOR13,nasz,scenin, 2);
|
CSDL_Ext::printAtMiddle(temp2,50,13,GEOR13,nasz,scenin, 2);
|
||||||
switch (ourMaps[(i-at)+from].version)
|
switch (curVector()[(i-at)+from].version)
|
||||||
{
|
{
|
||||||
case RoE:
|
case RoE:
|
||||||
temp=0;
|
temp=0;
|
||||||
@ -918,21 +917,32 @@ void MapSel::printMaps(int from, int to, int at, bool abs)
|
|||||||
temp=3;
|
temp=3;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
blitAt(Dtypes->ourImages[temp].bitmap,67,2,scenin);
|
if (temp >= 0)
|
||||||
if (!(ourMaps[(i-at)+from].name.length()))
|
blitAt(Dtypes->ourImages[temp].bitmap,67,2,scenin);
|
||||||
ourMaps[(i-at)+from].name = "Unnamed";
|
else
|
||||||
CSDL_Ext::printAtMiddle(ourMaps[(i-at)+from].name,192,13,GEOR13,nasz,scenin, 2);
|
tlog2 << "Warning: " << curVector()[(i-at)+from].filename << " has wrong version!\n";
|
||||||
if (ourMaps[(i-at)+from].victoryCondition.condition == winStandard)
|
|
||||||
|
if(CPG->fromnewgame)
|
||||||
|
{
|
||||||
|
if (!(curVector()[(i-at)+from].name.length()))
|
||||||
|
curVector()[(i-at)+from].name = "Unnamed";
|
||||||
|
CSDL_Ext::printAtMiddle(curVector()[(i-at)+from].name,192,13,GEOR13,nasz,scenin, 2);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CSDL_Ext::printAtMiddle(curVector()[(i-at)+from].filename,192,13,GEOR13,nasz,scenin, 2);
|
||||||
|
}
|
||||||
|
if (curVector()[(i-at)+from].victoryCondition.condition == winStandard)
|
||||||
temp=11;
|
temp=11;
|
||||||
else
|
else
|
||||||
temp=ourMaps[(i-at)+from].victoryCondition.condition;
|
temp=curVector()[(i-at)+from].victoryCondition.condition;
|
||||||
|
|
||||||
blitAt(Dvic->ourImages[temp].bitmap,285,2,scenin);
|
blitAt(Dvic->ourImages[temp].bitmap,285,2,scenin);
|
||||||
|
|
||||||
if (ourMaps[(i-at)+from].lossCondition.typeOfLossCon == lossStandard)
|
if (curVector()[(i-at)+from].lossCondition.typeOfLossCon == lossStandard)
|
||||||
temp=3;
|
temp=3;
|
||||||
else
|
else
|
||||||
temp=ourMaps[(i-at)+from].lossCondition.typeOfLossCon;
|
temp=curVector()[(i-at)+from].lossCondition.typeOfLossCon;
|
||||||
|
|
||||||
blitAt(Dloss->ourImages[temp].bitmap,318,2,scenin);
|
blitAt(Dloss->ourImages[temp].bitmap,318,2,scenin);
|
||||||
|
|
||||||
@ -944,9 +954,9 @@ void MapSel::printMaps(int from, int to, int at, bool abs)
|
|||||||
int MapSel::whichWL(int nr)
|
int MapSel::whichWL(int nr)
|
||||||
{
|
{
|
||||||
int help=-1;
|
int help=-1;
|
||||||
for (int i=0;i<ourMaps.size();i++)
|
for (int i=0;i<curVector().size();i++)
|
||||||
{
|
{
|
||||||
if (sizeFilter && ((ourMaps[i].width) != sizeFilter))
|
if (sizeFilter && ((curVector()[i].width) != sizeFilter))
|
||||||
continue;
|
continue;
|
||||||
else help++;
|
else help++;
|
||||||
if (help==nr)
|
if (help==nr)
|
||||||
@ -1055,6 +1065,19 @@ void MapSel::processMaps(std::vector<std::string> &pliczkiTemp, int &index)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MapSel::processGames( std::vector<std::string> &pliczkiTemp, int &index )
|
||||||
|
{
|
||||||
|
ourGames.resize(pliczkiTemp.size());
|
||||||
|
|
||||||
|
for(int i=0; i<pliczkiTemp.size(); i++)
|
||||||
|
{
|
||||||
|
CLoadFile lf(pliczkiTemp[i]);
|
||||||
|
ui8 sign[8];
|
||||||
|
lf >> sign >> static_cast<CMapHeader&>(ourGames[i]);
|
||||||
|
ourGames[i].filename = pliczkiTemp[i];
|
||||||
|
ourGames[i].countPlayers();
|
||||||
|
}
|
||||||
|
}
|
||||||
void MapSel::init()
|
void MapSel::init()
|
||||||
{
|
{
|
||||||
//get map files names
|
//get map files names
|
||||||
@ -1146,16 +1169,29 @@ void MapSel::init()
|
|||||||
std::sort(ourMaps.begin(),ourMaps.end(),mapSorter(_name));
|
std::sort(ourMaps.begin(),ourMaps.end(),mapSorter(_name));
|
||||||
slid = new Slider(375,92,480,ourMaps.size(),18,true);
|
slid = new Slider(375,92,480,ourMaps.size(),18,true);
|
||||||
slid->fun = boost::bind(&CPreGame::printMapsFrom,CPG,_1);
|
slid->fun = boost::bind(&CPreGame::printMapsFrom,CPG,_1);
|
||||||
|
|
||||||
|
group.join_all();
|
||||||
|
pliczkiTemp.clear();
|
||||||
|
tie = fs::path( (fs::initial_path<fs::path>())/"/Games" );
|
||||||
|
for ( fs::directory_iterator dir (tie); dir!=end_iter; ++dir )
|
||||||
|
{
|
||||||
|
if (fs::is_regular_file(dir->status()));
|
||||||
|
{
|
||||||
|
if (boost::ends_with(dir->path().filename(),".vlgm1"))
|
||||||
|
pliczkiTemp.push_back("Games/"+(dir->path().leaf()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
processGames(pliczkiTemp,mapInd);
|
||||||
}
|
}
|
||||||
void MapSel::moveByOne(bool up)
|
void MapSel::moveByOne(bool up)
|
||||||
{
|
{
|
||||||
int help=selected;
|
int help=selected;
|
||||||
if (up) selected--;
|
if (up) selected--;
|
||||||
else selected ++;
|
else selected ++;
|
||||||
for (int i=selected;i<ourMaps.size() && i>=0;)
|
for (int i=selected;i<curVector().size() && i>=0;)
|
||||||
{
|
{
|
||||||
help=i;
|
help=i;
|
||||||
if (!(sizeFilter && ((ourMaps[i].width) != sizeFilter)))
|
if (!(sizeFilter && ((curVector()[i].width) != sizeFilter)))
|
||||||
break;
|
break;
|
||||||
if (up)
|
if (up)
|
||||||
{
|
{
|
||||||
@ -1172,9 +1208,11 @@ void MapSel::moveByOne(bool up)
|
|||||||
}
|
}
|
||||||
void MapSel::select(int which, bool updateMapsList, bool forceSettingsUpdate)
|
void MapSel::select(int which, bool updateMapsList, bool forceSettingsUpdate)
|
||||||
{
|
{
|
||||||
|
if(which < 0)
|
||||||
|
return;
|
||||||
bool dontSaveSettings = ((selected!=which) || (CPG->ret.playerInfos.size()==0) || forceSettingsUpdate);
|
bool dontSaveSettings = ((selected!=which) || (CPG->ret.playerInfos.size()==0) || forceSettingsUpdate);
|
||||||
selected = which;
|
selected = which;
|
||||||
CPG->ret.mapname = ourMaps[selected].filename;
|
CPG->ret.mapname = curVector()[selected].filename;
|
||||||
if(updateMapsList)
|
if(updateMapsList)
|
||||||
printMaps(slid->whereAreWe,18,0,true);
|
printMaps(slid->whereAreWe,18,0,true);
|
||||||
int serialC=0;
|
int serialC=0;
|
||||||
@ -1184,7 +1222,9 @@ void MapSel::select(int which, bool updateMapsList, bool forceSettingsUpdate)
|
|||||||
bool wasntpl = true;
|
bool wasntpl = true;
|
||||||
for (int i=0;i<PLAYER_LIMIT;i++)
|
for (int i=0;i<PLAYER_LIMIT;i++)
|
||||||
{
|
{
|
||||||
if (!(ourMaps[selected].players[i].canComputerPlay || ourMaps[selected].players[i].canComputerPlay))
|
if (!(curVector()[selected].players[i].canComputerPlay
|
||||||
|
|| curVector()[selected].players[i].canComputerPlay)
|
||||||
|
)
|
||||||
continue; // this caused some serious problems becouse of lack of simple bijection between two sets of player's numbers (one is returned by CPreGame, second is used in h3m)
|
continue; // this caused some serious problems becouse of lack of simple bijection between two sets of player's numbers (one is returned by CPreGame, second is used in h3m)
|
||||||
StartInfo::PlayerSettings pset;
|
StartInfo::PlayerSettings pset;
|
||||||
pset.color=(Ecolor)i;
|
pset.color=(Ecolor)i;
|
||||||
@ -1193,7 +1233,7 @@ void MapSel::select(int which, bool updateMapsList, bool forceSettingsUpdate)
|
|||||||
pset.bonus=brandom;
|
pset.bonus=brandom;
|
||||||
pset.castle=-2;
|
pset.castle=-2;
|
||||||
|
|
||||||
if (ourMaps[which].players[i].canHumanPlay && wasntpl)
|
if (curVector()[which].players[i].canHumanPlay && wasntpl)
|
||||||
{
|
{
|
||||||
pset.name=CGI->generaltexth->allTexts[434]; //Player
|
pset.name=CGI->generaltexth->allTexts[434]; //Player
|
||||||
pset.human = true;
|
pset.human = true;
|
||||||
@ -1211,7 +1251,7 @@ void MapSel::select(int which, bool updateMapsList, bool forceSettingsUpdate)
|
|||||||
|
|
||||||
for (int j=0;j<F_NUMBER;j++)
|
for (int j=0;j<F_NUMBER;j++)
|
||||||
{
|
{
|
||||||
if (((int)pow((double)2,j))&ourMaps[selected].players[i].allowedFactions)
|
if (((int)pow((double)2,j))&curVector()[selected].players[i].allowedFactions)
|
||||||
{
|
{
|
||||||
if (pset.castle>=0)
|
if (pset.castle>=0)
|
||||||
pset.castle=-1;
|
pset.castle=-1;
|
||||||
@ -1220,16 +1260,20 @@ void MapSel::select(int which, bool updateMapsList, bool forceSettingsUpdate)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
pset.heroPortrait=-1;
|
pset.heroPortrait=-1;
|
||||||
if (!((ourMaps[which].players[i].generateHeroAtMainTown && ourMaps[which].players[i].hasMainTown) || ourMaps[which].players[i].p8))
|
if (!
|
||||||
|
((curVector()[which].players[i].generateHeroAtMainTown
|
||||||
|
&& curVector()[which].players[i].hasMainTown)
|
||||||
|
|| curVector()[which].players[i].p8)
|
||||||
|
)
|
||||||
pset.hero=-2;
|
pset.hero=-2;
|
||||||
else
|
else
|
||||||
pset.hero=-1;
|
pset.hero=-1;
|
||||||
|
|
||||||
if(ourMaps[which].players[i].mainHeroName.length())
|
if(curVector()[which].players[i].mainHeroName.length())
|
||||||
{
|
{
|
||||||
pset.heroName = ourMaps[which].players[i].mainHeroName;
|
pset.heroName = curVector()[which].players[i].mainHeroName;
|
||||||
if((pset.heroPortrait = ourMaps[which].players[i].mainHeroPortrait)==255)
|
if((pset.heroPortrait = curVector()[which].players[i].mainHeroPortrait)==255)
|
||||||
pset.heroPortrait = ourMaps[which].players[i].p9;
|
pset.heroPortrait = curVector()[which].players[i].p9;
|
||||||
}
|
}
|
||||||
pset.handicap=0;
|
pset.handicap=0;
|
||||||
CPG->ret.playerInfos.push_back(pset);
|
CPG->ret.playerInfos.push_back(pset);
|
||||||
@ -1245,9 +1289,12 @@ void MapSel::printSelectedInfo()
|
|||||||
{
|
{
|
||||||
SDL_BlitSurface(CPG->ourScenSel->scenInf,&genRect(399,337,17,23),screen,&genRect(399,337,413,29));
|
SDL_BlitSurface(CPG->ourScenSel->scenInf,&genRect(399,337,17,23),screen,&genRect(399,337,413,29));
|
||||||
SDL_BlitSurface(CPG->ourScenSel->scenInf,&genRect(50,91,18,447),screen,&genRect(50,91,414,453));
|
SDL_BlitSurface(CPG->ourScenSel->scenInf,&genRect(50,91,18,447),screen,&genRect(50,91,414,453));
|
||||||
SDL_BlitSurface(CPG->ourScenSel->bScens.imgs->ourImages[0].bitmap,NULL,screen,&CPG->ourScenSel->bScens.pos);
|
if(CPG->fromnewgame)
|
||||||
SDL_BlitSurface(CPG->ourScenSel->bOptions.imgs->ourImages[0].bitmap,NULL,screen,&CPG->ourScenSel->bOptions.pos);
|
{
|
||||||
SDL_BlitSurface(CPG->ourScenSel->bRandom.imgs->ourImages[0].bitmap,NULL,screen,&CPG->ourScenSel->bRandom.pos);
|
SDL_BlitSurface(CPG->ourScenSel->bScens.imgs->ourImages[0].bitmap,NULL,screen,&CPG->ourScenSel->bScens.pos);
|
||||||
|
SDL_BlitSurface(CPG->ourScenSel->bOptions.imgs->ourImages[0].bitmap,NULL,screen,&CPG->ourScenSel->bOptions.pos);
|
||||||
|
SDL_BlitSurface(CPG->ourScenSel->bRandom.imgs->ourImages[0].bitmap,NULL,screen,&CPG->ourScenSel->bRandom.pos);
|
||||||
|
}
|
||||||
//blit texts
|
//blit texts
|
||||||
CSDL_Ext::printAt(CGI->generaltexth->zelp[21].second,420,25,GEOR13);
|
CSDL_Ext::printAt(CGI->generaltexth->zelp[21].second,420,25,GEOR13);
|
||||||
CSDL_Ext::printAt(CGI->generaltexth->allTexts[496],420,135,GEOR13);
|
CSDL_Ext::printAt(CGI->generaltexth->allTexts[496],420,135,GEOR13);
|
||||||
@ -1256,30 +1303,32 @@ void MapSel::printSelectedInfo()
|
|||||||
CSDL_Ext::printAt(CGI->generaltexth->allTexts[390],420,406,GEOR13,zwykly);
|
CSDL_Ext::printAt(CGI->generaltexth->allTexts[390],420,406,GEOR13,zwykly);
|
||||||
CSDL_Ext::printAt(CGI->generaltexth->allTexts[391],585,406,GEOR13,zwykly);
|
CSDL_Ext::printAt(CGI->generaltexth->allTexts[391],585,406,GEOR13,zwykly);
|
||||||
|
|
||||||
int temp = ourMaps[selected].victoryCondition.condition+1;
|
CMapInfo &selMap = selectedMap();
|
||||||
|
|
||||||
|
int temp = selMap.victoryCondition.condition+1;
|
||||||
if (temp>20) temp=0;
|
if (temp>20) temp=0;
|
||||||
std::string sss = CGI->generaltexth->victoryConditions[temp];
|
std::string sss = CGI->generaltexth->victoryConditions[temp];
|
||||||
if (temp && ourMaps[selected].victoryCondition.allowNormalVictory) sss+= "/" + CGI->generaltexth->victoryConditions[0];
|
if (temp && selMap.victoryCondition.allowNormalVictory) sss+= "/" + CGI->generaltexth->victoryConditions[0];
|
||||||
CSDL_Ext::printAt(sss,452,310,GEOR13,zwykly);
|
CSDL_Ext::printAt(sss,452,310,GEOR13,zwykly);
|
||||||
|
|
||||||
|
|
||||||
temp = ourMaps[selected].lossCondition.typeOfLossCon+1;
|
temp = selMap.lossCondition.typeOfLossCon+1;
|
||||||
if (temp>20) temp=0;
|
if (temp>20) temp=0;
|
||||||
sss = CGI->generaltexth->lossCondtions[temp];
|
sss = CGI->generaltexth->lossCondtions[temp];
|
||||||
CSDL_Ext::printAt(sss,452,370,GEOR13,zwykly);
|
CSDL_Ext::printAt(sss,452,370,GEOR13,zwykly);
|
||||||
|
|
||||||
//blit descrption
|
//blit descrption
|
||||||
std::vector<std::string> desc = *CMessage::breakText(ourMaps[selected].description,50);
|
std::vector<std::string> desc = *CMessage::breakText(selMap.description,50);
|
||||||
for (int i=0;i<desc.size();i++)
|
for (int i=0;i<desc.size();i++)
|
||||||
CSDL_Ext::printAt(desc[i],417,152+i*13,GEOR13,zwykly);
|
CSDL_Ext::printAt(desc[i],417,152+i*13,GEOR13,zwykly);
|
||||||
|
|
||||||
if ((selected < 0) || (selected >= ourMaps.size()))
|
if ((selected < 0) || (selected >= ourMaps.size()))
|
||||||
return;
|
return;
|
||||||
if (ourMaps[selected].name.length())
|
if (selMap.name.length())
|
||||||
CSDL_Ext::printAt(ourMaps[selected].name,420,41,GEORXX);
|
CSDL_Ext::printAt(selMap.name,420,41,GEORXX);
|
||||||
else CSDL_Ext::printAt("Unnamed",420,41,GEORXX);
|
else CSDL_Ext::printAt("Unnamed",420,41,GEORXX);
|
||||||
std::string diff;
|
std::string diff;
|
||||||
switch (ourMaps[selected].difficulty)
|
switch (selMap.difficulty)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
diff=gdiff(CGI->generaltexth->zelp[24].second);
|
diff=gdiff(CGI->generaltexth->zelp[24].second);
|
||||||
@ -1298,7 +1347,7 @@ void MapSel::printSelectedInfo()
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
temp=-1;
|
temp=-1;
|
||||||
switch (ourMaps[selected].width)
|
switch (selMap.width)
|
||||||
{
|
{
|
||||||
case 36:
|
case 36:
|
||||||
temp=0;
|
temp=0;
|
||||||
@ -1317,10 +1366,10 @@ void MapSel::printSelectedInfo()
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
blitAt(Dsizes->ourImages[temp].bitmap,714,28);
|
blitAt(Dsizes->ourImages[temp].bitmap,714,28);
|
||||||
temp = ourMaps[selected].victoryCondition.condition;
|
temp = selMap.victoryCondition.condition;
|
||||||
if (temp>12) temp=11;
|
if (temp>12) temp=11;
|
||||||
blitAt(Dvic->ourImages[temp].bitmap,420,308); //v
|
blitAt(Dvic->ourImages[temp].bitmap,420,308); //v
|
||||||
temp=ourMaps[selected].lossCondition.typeOfLossCon;
|
temp=selMap.lossCondition.typeOfLossCon;
|
||||||
if (temp>12) temp=3;
|
if (temp>12) temp=3;
|
||||||
blitAt(Dloss->ourImages[temp].bitmap,420,366); //l
|
blitAt(Dloss->ourImages[temp].bitmap,420,366); //l
|
||||||
|
|
||||||
@ -1331,15 +1380,16 @@ void MapSel::printSelectedInfo()
|
|||||||
}
|
}
|
||||||
void MapSel::printFlags()
|
void MapSel::printFlags()
|
||||||
{
|
{
|
||||||
|
CMapInfo &selMap = selectedMap();
|
||||||
int hy=405, fx=460, ex=640, myT;
|
int hy=405, fx=460, ex=640, myT;
|
||||||
if (ourMaps[selected].howManyTeams)
|
if (selMap.howManyTeams)
|
||||||
myT = ourMaps[selected].players[CPG->playerColor].team;
|
myT = selMap.players[CPG->playerColor].team;
|
||||||
else myT = -1;
|
else myT = -1;
|
||||||
for (int i=0;i<CPG->ret.playerInfos.size();i++)
|
for (int i=0;i<CPG->ret.playerInfos.size();i++)
|
||||||
{
|
{
|
||||||
if (myT>=0)
|
if (myT>=0)
|
||||||
{
|
{
|
||||||
if(ourMaps[selected].players[CPG->ret.playerInfos[i].color].team==myT)
|
if(selMap.players[CPG->ret.playerInfos[i].color].team==myT)
|
||||||
{
|
{
|
||||||
blitAtWR(sFlags->ourImages[CPG->ret.playerInfos[i].color].bitmap,fx,hy);
|
blitAtWR(sFlags->ourImages[CPG->ret.playerInfos[i].color].bitmap,fx,hy);
|
||||||
fx+=sFlags->ourImages[CPG->ret.playerInfos[i].color].bitmap->w;
|
fx+=sFlags->ourImages[CPG->ret.playerInfos[i].color].bitmap->w;
|
||||||
@ -1376,6 +1426,23 @@ std::string MapSel::gdiff(std::string ss)
|
|||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CMapInfo & MapSel::selectedMap()
|
||||||
|
{
|
||||||
|
if(CPG->fromnewgame)
|
||||||
|
return ourMaps[selected];
|
||||||
|
else
|
||||||
|
return ourGames[selected];
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<CMapInfo> & MapSel::curVector()
|
||||||
|
{
|
||||||
|
|
||||||
|
if (CPG->fromnewgame)
|
||||||
|
return ourMaps;
|
||||||
|
else
|
||||||
|
return ourGames;
|
||||||
|
}
|
||||||
void CPreGame::printRating()
|
void CPreGame::printRating()
|
||||||
{
|
{
|
||||||
SDL_BlitSurface(CPG->ourScenSel->scenInf,&genRect(47,83,271,449),screen,&genRect(47,83,666,455));
|
SDL_BlitSurface(CPG->ourScenSel->scenInf,&genRect(47,83,271,449),screen,&genRect(47,83,666,455));
|
||||||
@ -1460,6 +1527,7 @@ void CPreGame::initScenSel()
|
|||||||
void CPreGame::showScenSel()
|
void CPreGame::showScenSel()
|
||||||
{
|
{
|
||||||
state=ScenarioList;
|
state=ScenarioList;
|
||||||
|
ourScenSel->mapsel.slid->positionsAmnt = ourScenSel->mapsel.curVector().size();
|
||||||
SDL_BlitSurface(ourScenSel->background,NULL,screen,NULL);
|
SDL_BlitSurface(ourScenSel->background,NULL,screen,NULL);
|
||||||
SDL_BlitSurface(ourScenSel->scenInf,NULL,screen,&genRect(ourScenSel->scenInf->h,ourScenSel->scenInf->w,396,6));
|
SDL_BlitSurface(ourScenSel->scenInf,NULL,screen,&genRect(ourScenSel->scenInf->h,ourScenSel->scenInf->w,396,6));
|
||||||
CSDL_Ext::printAt(CGI->generaltexth->allTexts[494],427,438,GEOR13);//"Map Diff:"
|
CSDL_Ext::printAt(CGI->generaltexth->allTexts[494],427,438,GEOR13);//"Map Diff:"
|
||||||
@ -1482,14 +1550,19 @@ void CPreGame::showScenSel()
|
|||||||
//add buttons info
|
//add buttons info
|
||||||
if(first)
|
if(first)
|
||||||
{
|
{
|
||||||
btns.push_back(&ourScenSel->bEasy);
|
if(fromnewgame)
|
||||||
btns.push_back(&ourScenSel->bNormal);
|
{
|
||||||
btns.push_back(&ourScenSel->bHard);
|
btns.push_back(&ourScenSel->bEasy);
|
||||||
btns.push_back(&ourScenSel->bExpert);
|
btns.push_back(&ourScenSel->bNormal);
|
||||||
btns.push_back(&ourScenSel->bImpossible);
|
btns.push_back(&ourScenSel->bHard);
|
||||||
btns.push_back(&ourScenSel->bScens);
|
btns.push_back(&ourScenSel->bExpert);
|
||||||
btns.push_back(&ourScenSel->bRandom);
|
btns.push_back(&ourScenSel->bImpossible);
|
||||||
btns.push_back(&ourScenSel->bOptions);
|
btns.push_back(&ourScenSel->bScens);
|
||||||
|
btns.push_back(&ourScenSel->bRandom);
|
||||||
|
btns.push_back(&ourScenSel->bOptions);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ourScenSel->mapsel.show();
|
||||||
btns.push_back(&ourScenSel->bBegin);
|
btns.push_back(&ourScenSel->bBegin);
|
||||||
btns.push_back(&ourScenSel->bBack);
|
btns.push_back(&ourScenSel->bBack);
|
||||||
|
|
||||||
@ -1583,12 +1656,18 @@ void CPreGame::initNewMenu()
|
|||||||
}
|
}
|
||||||
void CPreGame::showNewMenu()
|
void CPreGame::showNewMenu()
|
||||||
{
|
{
|
||||||
|
if(state == ScenarioList && !fromnewgame)
|
||||||
|
{
|
||||||
|
showLoadMenu();
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (currentTab/*==&ourScenSel->mapsel*/)
|
if (currentTab/*==&ourScenSel->mapsel*/)
|
||||||
currentTab->hide();
|
currentTab->hide();
|
||||||
btns.clear();
|
btns.clear();
|
||||||
interested.clear();
|
interested.clear();
|
||||||
handleOther=NULL;
|
handleOther=NULL;
|
||||||
state = newGame;
|
state = newGame;
|
||||||
|
fromnewgame = true;
|
||||||
SDL_BlitSurface(ourNewMenu->background,NULL,screen,NULL);
|
SDL_BlitSurface(ourNewMenu->background,NULL,screen,NULL);
|
||||||
SDL_BlitSurface(ourNewMenu->newGame->ourImages[0].bitmap,NULL,screen,&ourNewMenu->lNewGame);
|
SDL_BlitSurface(ourNewMenu->newGame->ourImages[0].bitmap,NULL,screen,&ourNewMenu->lNewGame);
|
||||||
SDL_BlitSurface(ourNewMenu->loadGame->ourImages[0].bitmap,NULL,screen,&ourNewMenu->lLoadGame);
|
SDL_BlitSurface(ourNewMenu->loadGame->ourImages[0].bitmap,NULL,screen,&ourNewMenu->lLoadGame);
|
||||||
@ -2120,6 +2199,7 @@ StartInfo CPreGame::runLoop()
|
|||||||
CGI->curh->draw2();
|
CGI->curh->draw2();
|
||||||
SDL_Delay(20); //give time for other apps
|
SDL_Delay(20); //give time for other apps
|
||||||
}
|
}
|
||||||
|
ret.mode = !fromnewgame;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
std::string CPreGame::buttonText(int which)
|
std::string CPreGame::buttonText(int which)
|
||||||
@ -2233,6 +2313,7 @@ void CPreGame::showLoadMenu()
|
|||||||
interested.clear();
|
interested.clear();
|
||||||
handleOther=NULL;
|
handleOther=NULL;
|
||||||
state = loadGame;
|
state = loadGame;
|
||||||
|
fromnewgame = false;
|
||||||
SDL_BlitSurface(ourLoadMenu->background,NULL,screen,NULL);
|
SDL_BlitSurface(ourLoadMenu->background,NULL,screen,NULL);
|
||||||
SDL_BlitSurface(ourLoadMenu->newGame->ourImages[0].bitmap,NULL,screen,&ourLoadMenu->lNewGame);
|
SDL_BlitSurface(ourLoadMenu->newGame->ourImages[0].bitmap,NULL,screen,&ourLoadMenu->lNewGame);
|
||||||
SDL_BlitSurface(ourLoadMenu->loadGame->ourImages[0].bitmap,NULL,screen,&ourLoadMenu->lLoadGame);
|
SDL_BlitSurface(ourLoadMenu->loadGame->ourImages[0].bitmap,NULL,screen,&ourLoadMenu->lLoadGame);
|
||||||
|
@ -187,7 +187,6 @@ public:
|
|||||||
CDefHandler * Dtypes, * Dvic;
|
CDefHandler * Dtypes, * Dvic;
|
||||||
CDefHandler *Dsizes, * Dloss,
|
CDefHandler *Dsizes, * Dloss,
|
||||||
* sFlags;
|
* sFlags;
|
||||||
std::vector<Mapa*> scenList;
|
|
||||||
std::vector<SDL_Surface*> scenImgs;
|
std::vector<SDL_Surface*> scenImgs;
|
||||||
//int current;
|
//int current;
|
||||||
std::vector<CMapInfo> ourMaps;
|
std::vector<CMapInfo> ourMaps;
|
||||||
@ -208,6 +207,9 @@ public:
|
|||||||
void printSelectedInfo();
|
void printSelectedInfo();
|
||||||
void printFlags();
|
void printFlags();
|
||||||
void processMaps(std::vector<std::string> &pliczkiTemp, int &index);
|
void processMaps(std::vector<std::string> &pliczkiTemp, int &index);
|
||||||
|
void processGames(std::vector<std::string> &pliczkiTemp, int &index);
|
||||||
|
CMapInfo &selectedMap();
|
||||||
|
std::vector<CMapInfo> &curVector();
|
||||||
MapSel();
|
MapSel();
|
||||||
~MapSel();
|
~MapSel();
|
||||||
};
|
};
|
||||||
@ -241,6 +243,7 @@ public:
|
|||||||
StartInfo ret;
|
StartInfo ret;
|
||||||
bool run;
|
bool run;
|
||||||
bool first; //hasn't we showed the scensel
|
bool first; //hasn't we showed the scensel
|
||||||
|
bool fromnewgame;
|
||||||
std::vector<Slider *> interested;
|
std::vector<Slider *> interested;
|
||||||
CMusicHandler * mush;
|
CMusicHandler * mush;
|
||||||
std::vector<HighButton *> btns;
|
std::vector<HighButton *> btns;
|
||||||
@ -259,7 +262,7 @@ public:
|
|||||||
ttt fNewGame, fLoadGame, fHighScores, fCredits, fQuit;
|
ttt fNewGame, fLoadGame, fHighScores, fCredits, fQuit;
|
||||||
int highlighted;//0=none; 1=new game; 2=load game; 3=high score; 4=credits; 5=quit
|
int highlighted;//0=none; 1=new game; 2=load game; 3=high score; 4=credits; 5=quit
|
||||||
} * ourMainMenu, * ourNewMenu, * ourLoadMenu;
|
} * ourMainMenu, * ourNewMenu, * ourLoadMenu;
|
||||||
ScenSel * ourScenSel;
|
ScenSel *ourScenSel;
|
||||||
Options * ourOptions;
|
Options * ourOptions;
|
||||||
std::string map; //selected map
|
std::string map; //selected map
|
||||||
CPreGame(); //c-tor
|
CPreGame(); //c-tor
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
0.64 -> 0.next (???) [as for r672]
|
0.64 -> 0.next (???) [as for r679]
|
||||||
GENERAL:
|
GENERAL:
|
||||||
* move some settings to the config/settings.txt file
|
* move some settings to the config/settings.txt file
|
||||||
* partial support for new screen resolutions
|
* partial support for new screen resolutions
|
||||||
@ -7,6 +7,7 @@ GENERAL:
|
|||||||
* support for non-standard screen resolutions
|
* support for non-standard screen resolutions
|
||||||
|
|
||||||
ADVENTURE INTERFACE:
|
ADVENTURE INTERFACE:
|
||||||
|
* smooth map scrolling on hero movement
|
||||||
* added water animation
|
* added water animation
|
||||||
* speed of scrolling map and hero movement can be adjusted in the System Options Window
|
* speed of scrolling map and hero movement can be adjusted in the System Options Window
|
||||||
|
|
||||||
@ -44,6 +45,11 @@ BATTLES
|
|||||||
AI PLAYER:
|
AI PLAYER:
|
||||||
* Genius AI (first VCMI AI) will control computer creatures during the combat.
|
* Genius AI (first VCMI AI) will control computer creatures during the combat.
|
||||||
|
|
||||||
|
OBJECTS:
|
||||||
|
* Guardians property for resources is handled
|
||||||
|
* support for Witch Hut
|
||||||
|
* support for Arena
|
||||||
|
|
||||||
And a lot of minor fixes
|
And a lot of minor fixes
|
||||||
|
|
||||||
0.63 -> 0.64 (Nov 01 2008)
|
0.63 -> 0.64 (Nov 01 2008)
|
||||||
|
@ -18,7 +18,7 @@ struct StartInfo
|
|||||||
ui8 serial;
|
ui8 serial;
|
||||||
ui8 handicap;//0-no, 1-mild, 2-severe
|
ui8 handicap;//0-no, 1-mild, 2-severe
|
||||||
std::string name;
|
std::string name;
|
||||||
bool human;
|
ui8 human;
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
h & castle;
|
h & castle;
|
||||||
@ -33,6 +33,7 @@ struct StartInfo
|
|||||||
h & human;
|
h & human;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
ui8 mode; //0 - new game; 1 - load game
|
||||||
si32 difficulty; //0=easy; 4=impossible
|
si32 difficulty; //0=easy; 4=impossible
|
||||||
std::vector<PlayerSettings> playerInfos;
|
std::vector<PlayerSettings> playerInfos;
|
||||||
ui8 turnTime; //in minutes, 0=unlimited
|
ui8 turnTime; //in minutes, 0=unlimited
|
||||||
@ -48,6 +49,7 @@ struct StartInfo
|
|||||||
}
|
}
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
|
h & mode;
|
||||||
h & difficulty;
|
h & difficulty;
|
||||||
h & playerInfos;
|
h & playerInfos;
|
||||||
h & turnTime;
|
h & turnTime;
|
||||||
|
@ -5,9 +5,15 @@
|
|||||||
#include "../CPlayerInterface.h"
|
#include "../CPlayerInterface.h"
|
||||||
#include "../StartInfo.h"
|
#include "../StartInfo.h"
|
||||||
#include "../hch/CArtHandler.h"
|
#include "../hch/CArtHandler.h"
|
||||||
|
#include "../hch/CDefObjInfoHandler.h"
|
||||||
#include "../hch/CGeneralTextHandler.h"
|
#include "../hch/CGeneralTextHandler.h"
|
||||||
|
#include "../hch/CHeroHandler.h"
|
||||||
|
#include "../hch/CTownHandler.h"
|
||||||
#include "../hch/CObjectHandler.h"
|
#include "../hch/CObjectHandler.h"
|
||||||
|
#include "../hch/CBuildingHandler.h"
|
||||||
|
#include "../hch/CSpellHandler.h"
|
||||||
#include "../lib/Connection.h"
|
#include "../lib/Connection.h"
|
||||||
|
#include "../lib/Interprocess.h"
|
||||||
#include "../lib/NetPacks.h"
|
#include "../lib/NetPacks.h"
|
||||||
#include "../lib/VCMI_Lib.h"
|
#include "../lib/VCMI_Lib.h"
|
||||||
#include "../map.h"
|
#include "../map.h"
|
||||||
@ -20,75 +26,19 @@
|
|||||||
#include <boost/thread/shared_mutex.hpp>
|
#include <boost/thread/shared_mutex.hpp>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
CSharedCond<std::set<IPack*> > mess(new std::set<IPack*>);
|
CSharedCond<std::set<IPack*> > mess(new std::set<IPack*>);
|
||||||
|
extern std::string NAME;
|
||||||
|
namespace intpr = boost::interprocess;
|
||||||
|
SharedMem sm;
|
||||||
|
|
||||||
CClient::CClient(void)
|
CClient::CClient(void)
|
||||||
{
|
{
|
||||||
|
serv = NULL;
|
||||||
|
gs = NULL;
|
||||||
|
cb = NULL;
|
||||||
}
|
}
|
||||||
CClient::CClient(CConnection *con, StartInfo *si)
|
CClient::CClient(CConnection *con, StartInfo *si)
|
||||||
:serv(con)
|
{
|
||||||
{
|
newGame(con,si);
|
||||||
timeHandler tmh;
|
|
||||||
IObjectInterface::cb = this;
|
|
||||||
CGI->state = new CGameState();
|
|
||||||
tlog0 <<"\tGamestate: "<<tmh.getDif()<<std::endl;
|
|
||||||
CConnection &c(*con);
|
|
||||||
////////////////////////////////////////////////////
|
|
||||||
ui8 pom8;
|
|
||||||
c << ui8(2) << ui8(1); //new game; one client
|
|
||||||
c << *si;
|
|
||||||
c >> pom8;
|
|
||||||
if(pom8) throw "Server cannot open the map!";
|
|
||||||
c << ui8(si->playerInfos.size()+1); //number of players + neutral
|
|
||||||
for(size_t i=0;i<si->playerInfos.size();i++) {
|
|
||||||
c << ui8(si->playerInfos[i].color); //players
|
|
||||||
}
|
|
||||||
c << ui8(255); // neutrals
|
|
||||||
|
|
||||||
|
|
||||||
ui32 seed, sum;
|
|
||||||
std::string mapname;
|
|
||||||
c >> mapname >> sum >> seed;
|
|
||||||
tlog0 <<"\tSending/Getting info to/from the server: "<<tmh.getDif()<<std::endl;
|
|
||||||
|
|
||||||
Mapa * mapa = new Mapa(mapname);
|
|
||||||
tlog0 <<"Reading and detecting map file (together): "<<tmh.getDif()<<std::endl;
|
|
||||||
tlog0 << "\tServer checksum for "<<mapname <<": "<<sum << std::endl;
|
|
||||||
tlog0 << "\tOur checksum for the map: "<< mapa->checksum << std::endl;
|
|
||||||
|
|
||||||
if(mapa->checksum != sum)
|
|
||||||
{
|
|
||||||
tlog1 << "Wrong map checksum!!!" << std::endl;
|
|
||||||
throw std::string("Wrong checksum");
|
|
||||||
}
|
|
||||||
tlog0 << "\tUsing random seed: "<<seed << std::endl;
|
|
||||||
|
|
||||||
gs = CGI->state;
|
|
||||||
gs->scenarioOps = si;
|
|
||||||
gs->init(si,mapa,seed);
|
|
||||||
|
|
||||||
CGI->mh = new CMapHandler();
|
|
||||||
tlog0 <<"Initializing GameState (together): "<<tmh.getDif()<<std::endl;
|
|
||||||
CGI->mh->map = mapa;
|
|
||||||
tlog0 <<"Creating mapHandler: "<<tmh.getDif()<<std::endl;
|
|
||||||
CGI->mh->init();
|
|
||||||
tlog0 <<"Initializing mapHandler (together): "<<tmh.getDif()<<std::endl;
|
|
||||||
|
|
||||||
for (size_t i=0; i<CGI->state->scenarioOps->playerInfos.size();++i) //initializing interfaces for players
|
|
||||||
{
|
|
||||||
ui8 color = gs->scenarioOps->playerInfos[i].color;
|
|
||||||
CCallback *cb = new CCallback(gs,color,this);
|
|
||||||
if(!gs->scenarioOps->playerInfos[i].human) {
|
|
||||||
playerint[color] = static_cast<CGameInterface*>(CAIHandler::getNewAI(cb,conf.cc.defaultAI));
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
playerint[color] = new CPlayerInterface(color,i);
|
|
||||||
}
|
|
||||||
gs->currentPlayer = color;
|
|
||||||
playerint[color]->init(cb);
|
|
||||||
}
|
|
||||||
playerint[255] = CAIHandler::getNewAI(cb,conf.cc.defaultAI);
|
|
||||||
playerint[255]->init(new CCallback(gs,255,this));
|
|
||||||
|
|
||||||
}
|
}
|
||||||
CClient::~CClient(void)
|
CClient::~CClient(void)
|
||||||
{
|
{
|
||||||
@ -634,10 +584,13 @@ void CClient::run()
|
|||||||
|
|
||||||
void CClient::close()
|
void CClient::close()
|
||||||
{
|
{
|
||||||
|
if(!serv)
|
||||||
|
return;
|
||||||
|
|
||||||
tlog3 << "Connection has been requested to be closed.\n";
|
tlog3 << "Connection has been requested to be closed.\n";
|
||||||
boost::unique_lock<boost::mutex>(*serv->wmx);
|
boost::unique_lock<boost::mutex>(*serv->wmx);
|
||||||
*serv << ui16(99);
|
*serv << ui16(99);
|
||||||
tlog3 << "Sended closing signal to the server\n";
|
tlog3 << "Sent closing signal to the server\n";
|
||||||
serv->close();
|
serv->close();
|
||||||
tlog3 << "Our socket has been closed.\n";
|
tlog3 << "Our socket has been closed.\n";
|
||||||
}
|
}
|
||||||
@ -647,6 +600,96 @@ void CClient::save(const std::string & fname)
|
|||||||
*serv << ui16(98) << fname;
|
*serv << ui16(98) << fname;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CClient::load( const std::string & fname )
|
||||||
|
{
|
||||||
|
tlog0 <<"\n\nLoading procedure started!\n\n";
|
||||||
|
|
||||||
|
timeHandler tmh;
|
||||||
|
close(); //kill server
|
||||||
|
tlog0 <<"Sent kill signal to the server: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
VLC->clear(); //delete old handlers
|
||||||
|
delete CGI->mh;
|
||||||
|
delete CGI->state;
|
||||||
|
//TODO: del callbacks
|
||||||
|
|
||||||
|
for(std::map<ui8,CGameInterface *>::iterator i = playerint.begin(); i!=playerint.end(); i++)
|
||||||
|
{
|
||||||
|
delete i->second; //delete player interfaces
|
||||||
|
}
|
||||||
|
tlog0 <<"Deleting old data: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
char portc[10];
|
||||||
|
SDL_itoa(conf.cc.port,portc,10);
|
||||||
|
runServer(portc); //create new server
|
||||||
|
tlog0 <<"Restarting server: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
{
|
||||||
|
char sig[8];
|
||||||
|
CMapHeader dum;
|
||||||
|
CGI->mh = new CMapHandler();
|
||||||
|
|
||||||
|
CLoadFile lf(fname + ".vlgm1");
|
||||||
|
lf >> sig >> dum;
|
||||||
|
tlog0 <<"Reading save signature: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
lf >> *VLC;
|
||||||
|
CGI->setFromLib();
|
||||||
|
tlog0 <<"Reading handlers: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
lf >> gs;
|
||||||
|
tlog0 <<"Reading gamestate: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
CGI->state = gs;
|
||||||
|
CGI->mh->map = gs->map;
|
||||||
|
CGI->mh->init();
|
||||||
|
tlog0 <<"Initing maphandler: "<<tmh.getDif()<<std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
waitForServer();
|
||||||
|
tlog0 <<"Waiting for server: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
serv = new CConnection(conf.cc.server,portc,NAME);
|
||||||
|
tlog0 <<"Setting up connection: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
ui8 pom8;
|
||||||
|
*serv << ui8(3) << ui8(1); //load game; one client
|
||||||
|
*serv << fname;
|
||||||
|
*serv >> pom8;
|
||||||
|
if(pom8)
|
||||||
|
throw "Server cannot open the savegame!";
|
||||||
|
else
|
||||||
|
tlog0 << "Server opened savegame properly.\n";
|
||||||
|
|
||||||
|
*serv << ui8(gs->scenarioOps->playerInfos.size()+1); //number of players + neutral
|
||||||
|
for(size_t i=0;i<gs->scenarioOps->playerInfos.size();i++)
|
||||||
|
{
|
||||||
|
*serv << ui8(gs->scenarioOps->playerInfos[i].color); //players
|
||||||
|
}
|
||||||
|
*serv << ui8(255); // neutrals
|
||||||
|
tlog0 <<"Sent info to server: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
for (size_t i=0; i<gs->scenarioOps->playerInfos.size();++i) //initializing interfaces for players
|
||||||
|
{
|
||||||
|
ui8 color = gs->scenarioOps->playerInfos[i].color;
|
||||||
|
CCallback *cb = new CCallback(gs,color,this);
|
||||||
|
if(!gs->scenarioOps->playerInfos[i].human) {
|
||||||
|
playerint[color] = static_cast<CGameInterface*>(CAIHandler::getNewAI(cb,conf.cc.defaultAI));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
playerint[color] = new CPlayerInterface(color,i);
|
||||||
|
}
|
||||||
|
gs->currentPlayer = color;
|
||||||
|
playerint[color]->init(cb);
|
||||||
|
tlog0 <<"Setting up interface for player "<< (int)color <<": "<<tmh.getDif()<<std::endl;
|
||||||
|
}
|
||||||
|
playerint[255] = CAIHandler::getNewAI(cb,conf.cc.defaultAI);
|
||||||
|
playerint[255]->init(new CCallback(gs,255,this));
|
||||||
|
tlog0 <<"Setting up interface for neutral \"player\"" << tmh.getDif() << std::endl;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
int CClient::getCurrentPlayer()
|
int CClient::getCurrentPlayer()
|
||||||
{
|
{
|
||||||
return gs->currentPlayer;
|
return gs->currentPlayer;
|
||||||
@ -655,4 +698,92 @@ int CClient::getCurrentPlayer()
|
|||||||
int CClient::getSelectedHero()
|
int CClient::getSelectedHero()
|
||||||
{
|
{
|
||||||
return IGameCallback::getSelectedHero(getCurrentPlayer())->id;
|
return IGameCallback::getSelectedHero(getCurrentPlayer())->id;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CClient::newGame( CConnection *con, StartInfo *si )
|
||||||
|
{
|
||||||
|
timeHandler tmh;
|
||||||
|
IObjectInterface::cb = this;
|
||||||
|
CGI->state = new CGameState();
|
||||||
|
tlog0 <<"\tGamestate: "<<tmh.getDif()<<std::endl;
|
||||||
|
serv = con;
|
||||||
|
CConnection &c(*con);
|
||||||
|
////////////////////////////////////////////////////
|
||||||
|
ui8 pom8;
|
||||||
|
c << ui8(2) << ui8(1); //new game; one client
|
||||||
|
c << *si;
|
||||||
|
c >> pom8;
|
||||||
|
if(pom8)
|
||||||
|
throw "Server cannot open the map!";
|
||||||
|
else
|
||||||
|
tlog0 << "Server opened map properly.\n";
|
||||||
|
c << ui8(si->playerInfos.size()+1); //number of players + neutral
|
||||||
|
for(size_t i=0;i<si->playerInfos.size();i++)
|
||||||
|
{
|
||||||
|
c << ui8(si->playerInfos[i].color); //players
|
||||||
|
}
|
||||||
|
c << ui8(255); // neutrals
|
||||||
|
|
||||||
|
|
||||||
|
ui32 seed, sum;
|
||||||
|
std::string mapname;
|
||||||
|
c >> mapname >> sum >> seed;
|
||||||
|
tlog0 <<"\tSending/Getting info to/from the server: "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
Mapa * mapa = new Mapa(mapname);
|
||||||
|
tlog0 <<"Reading and detecting map file (together): "<<tmh.getDif()<<std::endl;
|
||||||
|
tlog0 << "\tServer checksum for "<<mapname <<": "<<sum << std::endl;
|
||||||
|
tlog0 << "\tOur checksum for the map: "<< mapa->checksum << std::endl;
|
||||||
|
|
||||||
|
if(mapa->checksum != sum)
|
||||||
|
{
|
||||||
|
tlog1 << "Wrong map checksum!!!" << std::endl;
|
||||||
|
throw std::string("Wrong checksum");
|
||||||
|
}
|
||||||
|
tlog0 << "\tUsing random seed: "<<seed << std::endl;
|
||||||
|
|
||||||
|
gs = CGI->state;
|
||||||
|
gs->scenarioOps = si;
|
||||||
|
gs->init(si,mapa,seed);
|
||||||
|
|
||||||
|
CGI->mh = new CMapHandler();
|
||||||
|
tlog0 <<"Initializing GameState (together): "<<tmh.getDif()<<std::endl;
|
||||||
|
CGI->mh->map = mapa;
|
||||||
|
tlog0 <<"Creating mapHandler: "<<tmh.getDif()<<std::endl;
|
||||||
|
CGI->mh->init();
|
||||||
|
tlog0 <<"Initializing mapHandler (together): "<<tmh.getDif()<<std::endl;
|
||||||
|
|
||||||
|
for (size_t i=0; i<CGI->state->scenarioOps->playerInfos.size();++i) //initializing interfaces for players
|
||||||
|
{
|
||||||
|
ui8 color = gs->scenarioOps->playerInfos[i].color;
|
||||||
|
CCallback *cb = new CCallback(gs,color,this);
|
||||||
|
if(!gs->scenarioOps->playerInfos[i].human) {
|
||||||
|
playerint[color] = static_cast<CGameInterface*>(CAIHandler::getNewAI(cb,conf.cc.defaultAI));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
playerint[color] = new CPlayerInterface(color,i);
|
||||||
|
}
|
||||||
|
gs->currentPlayer = color;
|
||||||
|
playerint[color]->init(cb);
|
||||||
|
}
|
||||||
|
playerint[255] = CAIHandler::getNewAI(cb,conf.cc.defaultAI);
|
||||||
|
playerint[255]->init(new CCallback(gs,255,this));
|
||||||
|
}
|
||||||
|
|
||||||
|
void CClient::runServer(const char * portc)
|
||||||
|
{
|
||||||
|
static std::string comm = std::string(SERVER_NAME) + " " + portc + " > server_log.txt"; //needs to be static, if not - will be probably destroyed before new thread reads it
|
||||||
|
boost::thread servthr(boost::bind(system,comm.c_str())); //runs server executable; //TODO: will it work on non-windows platforms?
|
||||||
|
}
|
||||||
|
|
||||||
|
void CClient::waitForServer()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
intpr::scoped_lock<intpr::interprocess_mutex> slock(sm.sr->mutex);
|
||||||
|
while(!sm.sr->ready)
|
||||||
|
{
|
||||||
|
sm.sr->cond.wait(slock);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
intpr::shared_memory_object::remove("vcmi_memory");
|
||||||
}
|
}
|
@ -51,7 +51,9 @@ public:
|
|||||||
~CClient(void);
|
~CClient(void);
|
||||||
|
|
||||||
void close();
|
void close();
|
||||||
|
void newGame(CConnection *con, StartInfo *si); //con - connection to server
|
||||||
void save(const std::string & fname);
|
void save(const std::string & fname);
|
||||||
|
void load(const std::string & fname);
|
||||||
void process(int what);
|
void process(int what);
|
||||||
void run();
|
void run();
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
@ -67,6 +69,7 @@ public:
|
|||||||
void setHoverName(int objid, MetaString * name){};
|
void setHoverName(int objid, MetaString * name){};
|
||||||
void setObjProperty(int objid, int prop, int val){};
|
void setObjProperty(int objid, int prop, int val){};
|
||||||
void changePrimSkill(int ID, int which, int val, bool abs=false){};
|
void changePrimSkill(int ID, int which, int val, bool abs=false){};
|
||||||
|
void changeSecSkill(int ID, int which, int val, bool abs=false){};
|
||||||
void showInfoDialog(InfoWindow *iw){};
|
void showInfoDialog(InfoWindow *iw){};
|
||||||
void showYesNoDialog(YesNoDialog *iw, const CFunctionList<void(ui32)> &callback){};
|
void showYesNoDialog(YesNoDialog *iw, const CFunctionList<void(ui32)> &callback){};
|
||||||
void showSelectionDialog(SelectionDialog *iw, const CFunctionList<void(ui32)> &callback){}; //returns question id
|
void showSelectionDialog(SelectionDialog *iw, const CFunctionList<void(ui32)> &callback){}; //returns question id
|
||||||
@ -82,6 +85,10 @@ public:
|
|||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
friend class CCallback; //handling players actions
|
friend class CCallback; //handling players actions
|
||||||
friend void processCommand(const std::string &message, CClient *&client); //handling console
|
friend void processCommand(const std::string &message, CClient *&client); //handling console
|
||||||
|
|
||||||
|
|
||||||
|
static void runServer(const char * portc);
|
||||||
|
static void waitForServer();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // __CLIENT_H__
|
#endif // __CLIENT_H__
|
||||||
|
@ -275,31 +275,32 @@ void Graphics::loadHeroPortraits()
|
|||||||
}
|
}
|
||||||
of.close();
|
of.close();
|
||||||
}
|
}
|
||||||
void Graphics::loadHeroAnim(std::vector<CDefHandler **> & anims)
|
void Graphics::loadHeroAnim()
|
||||||
{
|
{
|
||||||
|
heroAnims.resize(F_NUMBER * 2);
|
||||||
std::vector<std::pair<int,int> > rotations; //first - group number to be rotated1, second - group number after rotation1
|
std::vector<std::pair<int,int> > rotations; //first - group number to be rotated1, second - group number after rotation1
|
||||||
rotations += std::make_pair(6,10), std::make_pair(7,11), std::make_pair(8,12), std::make_pair(1,13),
|
rotations += std::make_pair(6,10), std::make_pair(7,11), std::make_pair(8,12), std::make_pair(1,13),
|
||||||
std::make_pair(2,14), std::make_pair(3,15);
|
std::make_pair(2,14), std::make_pair(3,15);
|
||||||
for(size_t i=0; i<anims.size(); ++i)
|
for(size_t i=0; i<heroAnims.size(); ++i)
|
||||||
{
|
{
|
||||||
std::stringstream nm;
|
std::stringstream nm;
|
||||||
nm << "AH" << std::setw(2) << std::setfill('0') << i << "_.DEF";
|
nm << "AH" << std::setw(2) << std::setfill('0') << i << "_.DEF";
|
||||||
std::string name = nm.str();
|
std::string name = nm.str();
|
||||||
(*anims[i]) = CDefHandler::giveDef(name);
|
heroAnims[i] = CDefHandler::giveDef(name);
|
||||||
int pom = 0; //how many groups has been rotated
|
int pom = 0; //how many groups has been rotated
|
||||||
for(int o=7; pom<6; ++o)
|
for(int o=7; pom<6; ++o)
|
||||||
{
|
{
|
||||||
for(int p=0;p<6;p++)
|
for(int p=0;p<6;p++)
|
||||||
{
|
{
|
||||||
if((*anims[i])->ourImages[o].groupNumber==rotations[p].first)
|
if(heroAnims[i]->ourImages[o].groupNumber==rotations[p].first)
|
||||||
{
|
{
|
||||||
for(int e=0; e<8; ++e)
|
for(int e=0; e<8; ++e)
|
||||||
{
|
{
|
||||||
Cimage nci;
|
Cimage nci;
|
||||||
nci.bitmap = CSDL_Ext::rotate01((*anims[i])->ourImages[o+e].bitmap);
|
nci.bitmap = CSDL_Ext::rotate01(heroAnims[i]->ourImages[o+e].bitmap);
|
||||||
nci.groupNumber = rotations[p].second;
|
nci.groupNumber = rotations[p].second;
|
||||||
nci.imName = std::string();
|
nci.imName = std::string();
|
||||||
(*anims[i])->ourImages.push_back(nci);
|
heroAnims[i]->ourImages.push_back(nci);
|
||||||
if(pom>2) //we need only one frame for groups 13/14/15
|
if(pom>2) //we need only one frame for groups 13/14/15
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -313,11 +314,11 @@ void Graphics::loadHeroAnim(std::vector<CDefHandler **> & anims)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(size_t ff=0; ff<(*anims[i])->ourImages.size(); ++ff)
|
for(size_t ff=0; ff<heroAnims[i]->ourImages.size(); ++ff)
|
||||||
{
|
{
|
||||||
CSDL_Ext::alphaTransform((*anims[i])->ourImages[ff].bitmap);
|
CSDL_Ext::alphaTransform(heroAnims[i]->ourImages[ff].bitmap);
|
||||||
}
|
}
|
||||||
(*anims[i])->alphaTransformed = true;
|
heroAnims[i]->alphaTransformed = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@ public:
|
|||||||
CDefHandler * un44; //many things
|
CDefHandler * un44; //many things
|
||||||
CDefHandler * smallIcons, *resources32; //resources 32x32
|
CDefHandler * smallIcons, *resources32; //resources 32x32
|
||||||
CDefHandler * flags;
|
CDefHandler * flags;
|
||||||
|
std::vector<CDefHandler *> heroAnims; // [class id: 0 - 17] //added group 10: up - left, 11 - left and 12 - left down // 13 - up-left standing; 14 - left standing; 15 - left down standing
|
||||||
//creatures
|
//creatures
|
||||||
std::map<int,SDL_Surface*> smallImgs; //creature ID -> small 32x32 img of creature; //ID=-2 is for blank (black) img; -1 for the border
|
std::map<int,SDL_Surface*> smallImgs; //creature ID -> small 32x32 img of creature; //ID=-2 is for blank (black) img; -1 for the border
|
||||||
std::map<int,SDL_Surface*> bigImgs; //creature ID -> big 58x64 img of creature; //ID=-2 is for blank (black) img; -1 for the border
|
std::map<int,SDL_Surface*> bigImgs; //creature ID -> big 58x64 img of creature; //ID=-2 is for blank (black) img; -1 for the border
|
||||||
@ -53,7 +54,7 @@ public:
|
|||||||
void loadPaletteAndColors();
|
void loadPaletteAndColors();
|
||||||
void loadHeroFlags();
|
void loadHeroFlags();
|
||||||
void loadHeroFlags(std::pair<std::vector<CDefHandler *> Graphics::*, std::vector<const char *> > &pr, bool mode);
|
void loadHeroFlags(std::pair<std::vector<CDefHandler *> Graphics::*, std::vector<const char *> > &pr, bool mode);
|
||||||
void loadHeroAnim(std::vector<CDefHandler **> & anims);
|
void loadHeroAnim();
|
||||||
void loadHeroPortraits();
|
void loadHeroPortraits();
|
||||||
SDL_Surface * drawHeroInfoWin(const CGHeroInstance * curh);
|
SDL_Surface * drawHeroInfoWin(const CGHeroInstance * curh);
|
||||||
SDL_Surface * drawPrimarySkill(const CGHeroInstance *curh, SDL_Surface *ret, int from=0, int to=PRIMARY_SKILLS);
|
SDL_Surface * drawPrimarySkill(const CGHeroInstance *curh, SDL_Surface *ret, int from=0, int to=PRIMARY_SKILLS);
|
||||||
|
@ -7,34 +7,8 @@
|
|||||||
|
|
||||||
void CAbilityHandler::loadAbilities()
|
void CAbilityHandler::loadAbilities()
|
||||||
{
|
{
|
||||||
std::string buf = CGI->bitmaph->getTextFile("SSTRAITS.TXT");
|
|
||||||
int it=0;
|
|
||||||
std::string dump;
|
|
||||||
for(int i=0; i<2; ++i)
|
|
||||||
{
|
|
||||||
loadToIt(dump,buf,it,3);
|
|
||||||
}
|
|
||||||
for (int i=0; i<SKILL_QUANTITY; i++)
|
|
||||||
{
|
|
||||||
CAbility * nab = new CAbility; //new skill, that will be read
|
|
||||||
nab->infoTexts.resize(3);
|
|
||||||
loadToIt(nab->name,buf,it,4);
|
|
||||||
loadToIt(nab->infoTexts[0],buf,it,4);
|
|
||||||
loadToIt(nab->infoTexts[1],buf,it,4);
|
|
||||||
loadToIt(nab->infoTexts[2],buf,it,3);
|
|
||||||
nab->idNumber = abilities.size();
|
|
||||||
abilities.push_back(nab);
|
|
||||||
}
|
|
||||||
abils32 = CDefHandler::giveDef("SECSK32.DEF");
|
abils32 = CDefHandler::giveDef("SECSK32.DEF");
|
||||||
abils44 = CDefHandler::giveDef("SECSKILL.DEF");
|
abils44 = CDefHandler::giveDef("SECSKILL.DEF");
|
||||||
abils82 = CDefHandler::giveDef("SECSK82.DEF");
|
abils82 = CDefHandler::giveDef("SECSK82.DEF");
|
||||||
|
|
||||||
buf = CGI->bitmaph->getTextFile("SKILLLEV.TXT");
|
|
||||||
it=0;
|
|
||||||
for(int i=0; i<6; ++i)
|
|
||||||
{
|
|
||||||
std::string buffo;
|
|
||||||
loadToIt(buffo,buf,it,3);
|
|
||||||
levels.push_back(buffo);
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -9,8 +9,6 @@ class CDefHandler;
|
|||||||
class CAbility
|
class CAbility
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
std::string name;
|
|
||||||
std::vector <std::string> infoTexts; //0 - basic; 2 - advanced
|
|
||||||
int idNumber;
|
int idNumber;
|
||||||
bool isAllowed; //true if we can use this hero's ability (map information)
|
bool isAllowed; //true if we can use this hero's ability (map information)
|
||||||
};
|
};
|
||||||
@ -20,7 +18,6 @@ class CAbilityHandler
|
|||||||
public:
|
public:
|
||||||
std::vector<CAbility *> abilities;
|
std::vector<CAbility *> abilities;
|
||||||
CDefHandler * abils32, * abils44, * abils82;
|
CDefHandler * abils32, * abils44, * abils82;
|
||||||
std::vector<std::string> levels;
|
|
||||||
void loadAbilities();
|
void loadAbilities();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -14,11 +14,8 @@ unsigned int readNr(std::string &in, int &it)
|
|||||||
if(in[last]=='\t' || in[last]=='\n' || in[last]==' ' || in[last]=='\r' || in[last]=='\n')
|
if(in[last]=='\t' || in[last]=='\n' || in[last]==' ' || in[last]=='\r' || in[last]=='\n')
|
||||||
break;
|
break;
|
||||||
if(last==in.size())
|
if(last==in.size())
|
||||||
#ifndef __GNUC__
|
throw std::string("Cannot read number...");
|
||||||
throw new std::exception("Cannot read number...");
|
|
||||||
#else
|
|
||||||
throw new std::exception();
|
|
||||||
#endif
|
|
||||||
std::stringstream ss(in.substr(it,last-it));
|
std::stringstream ss(in.substr(it,last-it));
|
||||||
it+=(1+last-it);
|
it+=(1+last-it);
|
||||||
ss >> last;
|
ss >> last;
|
||||||
@ -131,6 +128,12 @@ void CBuildingHandler::loadBuildings()
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CBuildingHandler::~CBuildingHandler()
|
||||||
|
{
|
||||||
|
for(std::map<int, std::map<int, CBuilding*> >::iterator i=buildings.begin(); i!=buildings.end(); i++)
|
||||||
|
for(std::map<int, CBuilding*>::iterator j=i->second.begin(); j!=i->second.end(); j++)
|
||||||
|
delete j->second;
|
||||||
|
}
|
||||||
const std::string & CBuilding::Name()
|
const std::string & CBuilding::Name()
|
||||||
{
|
{
|
||||||
if(name.length())
|
if(name.length())
|
||||||
|
@ -28,6 +28,7 @@ public:
|
|||||||
std::map<int, std::pair<std::string,std::vector< std::vector< std::vector<int> > > > > hall; //map<castle ID, pair<hall bg name, std::vector< std::vector<building id> >[5]> - external vector is the vector of buildings in the row, internal is the list of buildings for the specific slot
|
std::map<int, std::pair<std::string,std::vector< std::vector< std::vector<int> > > > > hall; //map<castle ID, pair<hall bg name, std::vector< std::vector<building id> >[5]> - external vector is the vector of buildings in the row, internal is the list of buildings for the specific slot
|
||||||
|
|
||||||
void loadBuildings(); //main loader
|
void loadBuildings(); //main loader
|
||||||
|
~CBuildingHandler();
|
||||||
|
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
|
@ -629,3 +629,7 @@ void CCreatureHandler::loadUnitAnimInfo(CCreature & unit, std::string & src, int
|
|||||||
}
|
}
|
||||||
i+=2;
|
i+=2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CCreatureHandler::~CCreatureHandler()
|
||||||
|
{
|
||||||
|
}
|
@ -67,6 +67,7 @@ public:
|
|||||||
void loadAnimationInfo();
|
void loadAnimationInfo();
|
||||||
void loadUnitAnimInfo(CCreature & unit, std::string & src, int & i);
|
void loadUnitAnimInfo(CCreature & unit, std::string & src, int & i);
|
||||||
CCreatureHandler();
|
CCreatureHandler();
|
||||||
|
~CCreatureHandler();
|
||||||
|
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
|
@ -18,6 +18,7 @@ bool CGDefInfo::isVisitable()
|
|||||||
}
|
}
|
||||||
CGDefInfo::CGDefInfo()
|
CGDefInfo::CGDefInfo()
|
||||||
{
|
{
|
||||||
|
handler = NULL;
|
||||||
serial = -1;
|
serial = -1;
|
||||||
visitDir = (8|16|32|64|128); //4,5,6,7,8 - any not-from-up direction
|
visitDir = (8|16|32|64|128); //4,5,6,7,8 - any not-from-up direction
|
||||||
}
|
}
|
||||||
@ -76,4 +77,11 @@ void CDefObjInfoHandler::load()
|
|||||||
if(nobj->id==98)
|
if(nobj->id==98)
|
||||||
castles[nobj->subid]=nobj;
|
castles[nobj->subid]=nobj;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CDefObjInfoHandler::~CDefObjInfoHandler()
|
||||||
|
{
|
||||||
|
for(std::map<int,std::map<int,CGDefInfo*> >::iterator i=gobjs.begin(); i!=gobjs.end(); i++)
|
||||||
|
for(std::map<int,CGDefInfo*>::iterator j=i->second.begin(); j!=i->second.end(); j++)
|
||||||
|
delete j->second;
|
||||||
}
|
}
|
@ -41,8 +41,9 @@ class DLL_EXPORT CDefObjInfoHandler
|
|||||||
public:
|
public:
|
||||||
std::map<int,std::map<int,CGDefInfo*> > gobjs;
|
std::map<int,std::map<int,CGDefInfo*> > gobjs;
|
||||||
std::map<int,CGDefInfo*> castles;
|
std::map<int,CGDefInfo*> castles;
|
||||||
void load();
|
|
||||||
|
|
||||||
|
void load();
|
||||||
|
~CDefObjInfoHandler();
|
||||||
|
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
|
@ -16,88 +16,6 @@ std::string readTo(std::string &in, int &it, char end)
|
|||||||
return in.substr(pom,last-pom);
|
return in.substr(pom,last-pom);
|
||||||
}
|
}
|
||||||
void CGeneralTextHandler::load()
|
void CGeneralTextHandler::load()
|
||||||
{
|
|
||||||
std::string buf = bitmaph->getTextFile("GENRLTXT.TXT"), tmp;
|
|
||||||
int andame = buf.size();
|
|
||||||
int i=0; //buf iterator
|
|
||||||
for(i; i<andame; ++i)
|
|
||||||
{
|
|
||||||
if(buf[i]=='\r')
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
i+=2;
|
|
||||||
std::string buflet;
|
|
||||||
for(int jj=0; jj<764; ++jj)
|
|
||||||
{
|
|
||||||
loadToIt(buflet, buf, i, 2);
|
|
||||||
if(buflet[0] == '"' && buflet[buflet.size()-1] == '"')
|
|
||||||
buflet = buflet.substr(1,buflet.size()-2);
|
|
||||||
allTexts.push_back(buflet);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string strs = bitmaph->getTextFile("ARRAYTXT.TXT");
|
|
||||||
|
|
||||||
int itr=0;
|
|
||||||
while(itr<strs.length()-1)
|
|
||||||
{
|
|
||||||
loadToIt(tmp, strs, itr, 3);
|
|
||||||
arraytxt.push_back(tmp);
|
|
||||||
}
|
|
||||||
|
|
||||||
itr = 0;
|
|
||||||
std::string strin = bitmaph->getTextFile("PRISKILL.TXT");
|
|
||||||
for(int hh=0; hh<4; ++hh)
|
|
||||||
{
|
|
||||||
loadToIt(tmp, strin, itr, 3);
|
|
||||||
primarySkillNames.push_back(tmp);
|
|
||||||
}
|
|
||||||
|
|
||||||
itr = 0;
|
|
||||||
std::string strin2 = bitmaph->getTextFile("JKTEXT.TXT");
|
|
||||||
for(int hh=0; hh<45; ++hh)
|
|
||||||
{
|
|
||||||
loadToIt(tmp, strin2, itr, 3);
|
|
||||||
jktexts.push_back(tmp);
|
|
||||||
}
|
|
||||||
|
|
||||||
itr = 0;
|
|
||||||
std::string strin3 = bitmaph->getTextFile("HEROSCRN.TXT");
|
|
||||||
for(int hh=0; hh<33; ++hh)
|
|
||||||
{
|
|
||||||
loadToIt(tmp, strin3, itr, 3);
|
|
||||||
heroscrn.push_back(tmp);
|
|
||||||
}
|
|
||||||
|
|
||||||
strin3 = bitmaph->getTextFile("ARTEVENT.TXT");
|
|
||||||
for(itr = 0; itr<strin3.size();itr++)
|
|
||||||
{
|
|
||||||
loadToIt(tmp, strin3, itr, 3);
|
|
||||||
artifEvents.push_back(tmp);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
std::string CGeneralTextHandler::getTitle(std::string text)
|
|
||||||
{
|
|
||||||
std::string ret;
|
|
||||||
int i=0;
|
|
||||||
while ((text[i++]!='{'));
|
|
||||||
while ((text[i]!='}') && (i<text.length()))
|
|
||||||
ret+=text[i++];
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
std::string CGeneralTextHandler::getDescr(std::string text)
|
|
||||||
{
|
|
||||||
std::string ret;
|
|
||||||
int i=0;
|
|
||||||
while ((text[i++]!='}'));
|
|
||||||
i+=2;
|
|
||||||
while ((text[i]!='"') && (i<text.length()))
|
|
||||||
ret+=text[i++];
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
void CGeneralTextHandler::loadTexts()
|
|
||||||
{
|
{
|
||||||
std::string buf1 = bitmaph->getTextFile("ZELP.TXT");
|
std::string buf1 = bitmaph->getTextFile("ZELP.TXT");
|
||||||
int itr=0, eol=-1, eolnext=-1, pom;
|
int itr=0, eol=-1, eolnext=-1, pom;
|
||||||
@ -335,7 +253,7 @@ void CGeneralTextHandler::loadTexts()
|
|||||||
loadToIt(temp,buf,it,3);
|
loadToIt(temp,buf,it,3);
|
||||||
restypes.push_back(temp);
|
restypes.push_back(temp);
|
||||||
}
|
}
|
||||||
|
|
||||||
tlog5 << "\t\tReading ZCRGN1 \n";
|
tlog5 << "\t\tReading ZCRGN1 \n";
|
||||||
buf = bitmaph->getTextFile("ZCRGN1.TXT");
|
buf = bitmaph->getTextFile("ZCRGN1.TXT");
|
||||||
it=0;
|
it=0;
|
||||||
@ -344,4 +262,115 @@ void CGeneralTextHandler::loadTexts()
|
|||||||
loadToIt(temp,buf,it,3);
|
loadToIt(temp,buf,it,3);
|
||||||
creGens.push_back(temp);
|
creGens.push_back(temp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
buf = bitmaph->getTextFile("GENRLTXT.TXT");
|
||||||
|
std::string tmp;
|
||||||
|
andame = buf.size();
|
||||||
|
i=0; //buf iterator
|
||||||
|
for(i; i<andame; ++i)
|
||||||
|
{
|
||||||
|
if(buf[i]=='\r')
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
i+=2;
|
||||||
|
std::string buflet;
|
||||||
|
for(int jj=0; jj<764; ++jj)
|
||||||
|
{
|
||||||
|
loadToIt(buflet, buf, i, 2);
|
||||||
|
if(buflet[0] == '"' && buflet[buflet.size()-1] == '"')
|
||||||
|
buflet = buflet.substr(1,buflet.size()-2);
|
||||||
|
allTexts.push_back(buflet);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string strs = bitmaph->getTextFile("ARRAYTXT.TXT");
|
||||||
|
|
||||||
|
itr=0;
|
||||||
|
while(itr<strs.length()-1)
|
||||||
|
{
|
||||||
|
loadToIt(tmp, strs, itr, 3);
|
||||||
|
arraytxt.push_back(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
itr = 0;
|
||||||
|
std::string strin = bitmaph->getTextFile("PRISKILL.TXT");
|
||||||
|
for(int hh=0; hh<4; ++hh)
|
||||||
|
{
|
||||||
|
loadToIt(tmp, strin, itr, 3);
|
||||||
|
primarySkillNames.push_back(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
itr = 0;
|
||||||
|
std::string strin2 = bitmaph->getTextFile("JKTEXT.TXT");
|
||||||
|
for(int hh=0; hh<45; ++hh)
|
||||||
|
{
|
||||||
|
loadToIt(tmp, strin2, itr, 3);
|
||||||
|
jktexts.push_back(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
itr = 0;
|
||||||
|
std::string strin3 = bitmaph->getTextFile("HEROSCRN.TXT");
|
||||||
|
for(int hh=0; hh<33; ++hh)
|
||||||
|
{
|
||||||
|
loadToIt(tmp, strin3, itr, 3);
|
||||||
|
heroscrn.push_back(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
strin3 = bitmaph->getTextFile("ARTEVENT.TXT");
|
||||||
|
for(itr = 0; itr<strin3.size();itr++)
|
||||||
|
{
|
||||||
|
loadToIt(tmp, strin3, itr, 3);
|
||||||
|
artifEvents.push_back(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
buf = bitmaph->getTextFile("SSTRAITS.TXT");
|
||||||
|
it=0;
|
||||||
|
|
||||||
|
for(int i=0; i<2; ++i)
|
||||||
|
loadToIt(dump,buf,it,3);
|
||||||
|
|
||||||
|
skillName.resize(SKILL_QUANTITY);
|
||||||
|
skillInfoTexts.resize(SKILL_QUANTITY);
|
||||||
|
for (int i=0; i<SKILL_QUANTITY; i++)
|
||||||
|
{
|
||||||
|
skillInfoTexts[i].resize(3);
|
||||||
|
loadToIt(skillName[i],buf,it,4);
|
||||||
|
loadToIt(skillInfoTexts[i][0],buf,it,4);
|
||||||
|
loadToIt(skillInfoTexts[i][1],buf,it,4);
|
||||||
|
loadToIt(skillInfoTexts[i][2],buf,it,3);
|
||||||
|
}
|
||||||
|
buf = bitmaph->getTextFile("SKILLLEV.TXT");
|
||||||
|
it=0;
|
||||||
|
for(int i=0; i<6; ++i)
|
||||||
|
{
|
||||||
|
std::string buffo;
|
||||||
|
loadToIt(buffo,buf,it,3);
|
||||||
|
levels.push_back(buffo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
std::string CGeneralTextHandler::getTitle(std::string text)
|
||||||
|
{
|
||||||
|
std::string ret;
|
||||||
|
int i=0;
|
||||||
|
while ((text[i++]!='{'));
|
||||||
|
while ((text[i]!='}') && (i<text.length()))
|
||||||
|
ret+=text[i++];
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
std::string CGeneralTextHandler::getDescr(std::string text)
|
||||||
|
{
|
||||||
|
std::string ret;
|
||||||
|
int i=0;
|
||||||
|
while ((text[i++]!='}'));
|
||||||
|
i+=2;
|
||||||
|
while ((text[i]!='"') && (i<text.length()))
|
||||||
|
ret+=text[i++];
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
CGeneralTextHandler::CGeneralTextHandler()
|
||||||
|
{
|
||||||
|
|
||||||
}
|
}
|
@ -1,42 +1,42 @@
|
|||||||
#ifndef __CGENERALTEXTHANDLER_H__
|
#ifndef __CGENERALTEXTHANDLER_H__
|
||||||
#define __CGENERALTEXTHANDLER_H__
|
#define __CGENERALTEXTHANDLER_H__
|
||||||
#include "../global.h"
|
#include "../global.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
DLL_EXPORT void loadToIt(std::string &dest, std::string &src, int &iter, int mode);
|
DLL_EXPORT void loadToIt(std::string &dest, std::string &src, int &iter, int mode);
|
||||||
std::string readTo(std::string &in, int &it, char end);
|
std::string readTo(std::string &in, int &it, char end);
|
||||||
class DLL_EXPORT CGeneralTextHandler //Handles general texts
|
class DLL_EXPORT CGeneralTextHandler //Handles general texts
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
class HeroTexts
|
class HeroTexts
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
std::string bonusName, shortBonus, longBonus; //for special abilities
|
std::string bonusName, shortBonus, longBonus; //for special abilities
|
||||||
std::string biography; //biography, of course
|
std::string biography; //biography, of course
|
||||||
};
|
};
|
||||||
|
|
||||||
std::vector<HeroTexts> hTxts;
|
std::vector<HeroTexts> hTxts;
|
||||||
std::vector<std::string> allTexts;
|
std::vector<std::string> allTexts;
|
||||||
|
|
||||||
std::vector<std::string> arraytxt;
|
std::vector<std::string> arraytxt;
|
||||||
std::vector<std::string> primarySkillNames;
|
std::vector<std::string> primarySkillNames;
|
||||||
std::vector<std::string> jktexts;
|
std::vector<std::string> jktexts;
|
||||||
std::vector<std::string> heroscrn;
|
std::vector<std::string> heroscrn;
|
||||||
|
|
||||||
//artifacts
|
//artifacts
|
||||||
std::vector<std::string> artifEvents;
|
std::vector<std::string> artifEvents;
|
||||||
std::vector<std::string> artifNames;
|
std::vector<std::string> artifNames;
|
||||||
std::vector<std::string> artifDescriptions;
|
std::vector<std::string> artifDescriptions;
|
||||||
|
|
||||||
//towns
|
//towns
|
||||||
std::vector<std::string> tcommands, hcommands; //texts for town screen and town hall screen
|
std::vector<std::string> tcommands, hcommands; //texts for town screen and town hall screen
|
||||||
std::vector<std::vector<std::string> > townNames; //[type id] => vec of names of instances
|
std::vector<std::vector<std::string> > townNames; //[type id] => vec of names of instances
|
||||||
std::vector<std::string> townTypes; //castle, rampart, tower, etc
|
std::vector<std::string> townTypes; //castle, rampart, tower, etc
|
||||||
std::map<int, std::map<int, std::pair<std::string, std::string> > > buildings; //map[town id][building id] => pair<name, description>
|
std::map<int, std::map<int, std::pair<std::string, std::string> > > buildings; //map[town id][building id] => pair<name, description>
|
||||||
|
|
||||||
std::vector<std::pair<std::string,std::string> > zelp;
|
std::vector<std::pair<std::string,std::string> > zelp;
|
||||||
std::string lossCondtions[4];
|
std::string lossCondtions[4];
|
||||||
std::string victoryConditions[14];
|
std::string victoryConditions[14];
|
||||||
|
|
||||||
//objects
|
//objects
|
||||||
std::vector<std::string> names; //vector of objects; i-th object in vector has subnumber i
|
std::vector<std::string> names; //vector of objects; i-th object in vector has subnumber i
|
||||||
@ -44,16 +44,21 @@ public:
|
|||||||
std::vector<std::string> advobtxt;
|
std::vector<std::string> advobtxt;
|
||||||
std::vector<std::string> xtrainfo;
|
std::vector<std::string> xtrainfo;
|
||||||
std::vector<std::string> restypes;
|
std::vector<std::string> restypes;
|
||||||
std::vector<std::pair<std::string,std::string> > mines; //first - name; second - event description
|
std::vector<std::pair<std::string,std::string> > mines; //first - name; second - event description
|
||||||
|
|
||||||
|
//sec skills
|
||||||
std::string getTitle(std::string text);
|
std::vector <std::string> skillName;
|
||||||
std::string getDescr(std::string text);
|
std::vector <std::vector <std::string> > skillInfoTexts; //[id][level] : level 0 - basic; 2 - advanced
|
||||||
|
std::vector<std::string> levels;
|
||||||
void loadTexts();
|
|
||||||
void load();
|
std::string getTitle(std::string text);
|
||||||
};
|
std::string getDescr(std::string text);
|
||||||
|
|
||||||
|
void loadTexts();
|
||||||
|
void load();
|
||||||
#endif // __CGENERALTEXTHANDLER_H__
|
CGeneralTextHandler();
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif // __CGENERALTEXTHANDLER_H__
|
||||||
|
@ -10,7 +10,6 @@ void loadToIt(std::string &dest, std::string &src, int &iter, int mode);
|
|||||||
CHeroClass::CHeroClass()
|
CHeroClass::CHeroClass()
|
||||||
{
|
{
|
||||||
skillLimit = 8;
|
skillLimit = 8;
|
||||||
moveAnim = NULL;
|
|
||||||
}
|
}
|
||||||
CHeroClass::~CHeroClass()
|
CHeroClass::~CHeroClass()
|
||||||
{
|
{
|
||||||
@ -35,7 +34,17 @@ int CHeroClass::chooseSecSkill(const std::set<int> & possibles) const //picks se
|
|||||||
}
|
}
|
||||||
|
|
||||||
CHeroHandler::~CHeroHandler()
|
CHeroHandler::~CHeroHandler()
|
||||||
|
{
|
||||||
|
for (int i = 0; i < heroes.size(); i++)
|
||||||
|
delete heroes[i];
|
||||||
|
|
||||||
|
for (int i = 0; i < heroClasses.size(); i++)
|
||||||
|
delete heroClasses[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
CHeroHandler::CHeroHandler()
|
||||||
{}
|
{}
|
||||||
|
|
||||||
void CHeroHandler::loadHeroes()
|
void CHeroHandler::loadHeroes()
|
||||||
{
|
{
|
||||||
VLC->heroh = this;
|
VLC->heroh = this;
|
||||||
|
@ -38,7 +38,6 @@ public:
|
|||||||
std::vector<int> proSec; //probabilities of gaining secondary skills (out of 112), in id order
|
std::vector<int> proSec; //probabilities of gaining secondary skills (out of 112), in id order
|
||||||
int selectionProbability[9]; //probability of selection in towns
|
int selectionProbability[9]; //probability of selection in towns
|
||||||
std::vector<int> terrCosts; //default costs of going through terrains: dirt, sand, grass, snow, swamp, rough, subterranean, lava, water, rock; -1 means terrain is imapassable
|
std::vector<int> terrCosts; //default costs of going through terrains: dirt, sand, grass, snow, swamp, rough, subterranean, lava, water, rock; -1 means terrain is imapassable
|
||||||
CDefHandler * moveAnim; //added group 10: up - left, 11 - left and 12 - left down // 13 - up-left standing; 14 - left standing; 15 - left down standing
|
|
||||||
|
|
||||||
int chooseSecSkill(const std::set<int> & possibles) const; //picks secondary skill out from given possibilities
|
int chooseSecSkill(const std::set<int> & possibles) const; //picks secondary skill out from given possibilities
|
||||||
CHeroClass();
|
CHeroClass();
|
||||||
@ -60,11 +59,13 @@ public:
|
|||||||
|
|
||||||
unsigned int level(unsigned int experience);
|
unsigned int level(unsigned int experience);
|
||||||
unsigned int reqExp(unsigned int level);
|
unsigned int reqExp(unsigned int level);
|
||||||
|
|
||||||
void loadHeroes();
|
void loadHeroes();
|
||||||
void loadHeroClasses();
|
void loadHeroClasses();
|
||||||
void initHeroClasses();
|
void initHeroClasses();
|
||||||
~CHeroHandler();
|
|
||||||
void initTerrainCosts();
|
void initTerrainCosts();
|
||||||
|
CHeroHandler();
|
||||||
|
~CHeroHandler();
|
||||||
|
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
|
@ -743,7 +743,7 @@ void CGVisitableOPH::onHeroVisit( const CGHeroInstance * h ) const
|
|||||||
if(visitors.find(h->id)==visitors.end())
|
if(visitors.find(h->id)==visitors.end())
|
||||||
{
|
{
|
||||||
onNAHeroVisit(h->id, false);
|
onNAHeroVisit(h->id, false);
|
||||||
if(ID != 102) //not tree
|
if(ID != 102 && ID!=4) //not tree nor arena
|
||||||
cb->setObjProperty(id,4,h->id); //add to the visitors
|
cb->setObjProperty(id,4,h->id); //add to the visitors
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -774,6 +774,9 @@ void CGVisitableOPH::onNAHeroVisit(int heroID, bool alreadyVisited) const
|
|||||||
int id=0, subid=0, ot=0, val=1;
|
int id=0, subid=0, ot=0, val=1;
|
||||||
switch(ID)
|
switch(ID)
|
||||||
{
|
{
|
||||||
|
case 4:
|
||||||
|
ot = 0;
|
||||||
|
break;
|
||||||
case 51:
|
case 51:
|
||||||
subid=0;
|
subid=0;
|
||||||
ot=80;
|
ot=80;
|
||||||
@ -806,6 +809,16 @@ void CGVisitableOPH::onNAHeroVisit(int heroID, bool alreadyVisited) const
|
|||||||
{
|
{
|
||||||
switch (ID)
|
switch (ID)
|
||||||
{
|
{
|
||||||
|
case 4: //arena
|
||||||
|
{
|
||||||
|
SelectionDialog sd;
|
||||||
|
sd.text << std::pair<ui8,ui32>(11,ot);
|
||||||
|
sd.components.push_back(Component(0,0,2,0));
|
||||||
|
sd.components.push_back(Component(0,1,2,0));
|
||||||
|
sd.player = cb->getOwner(heroID);
|
||||||
|
cb->showSelectionDialog(&sd,boost::bind(&CGVisitableOPH::arenaSelected,this,heroID,_1));
|
||||||
|
return;
|
||||||
|
}
|
||||||
case 51:
|
case 51:
|
||||||
case 23:
|
case 23:
|
||||||
case 61:
|
case 61:
|
||||||
@ -835,7 +848,7 @@ void CGVisitableOPH::onNAHeroVisit(int heroID, bool alreadyVisited) const
|
|||||||
val = VLC->heroh->reqExp(h->level+val) - VLC->heroh->reqExp(h->level);
|
val = VLC->heroh->reqExp(h->level+val) - VLC->heroh->reqExp(h->level);
|
||||||
if(!ttype)
|
if(!ttype)
|
||||||
{
|
{
|
||||||
cb->setObjProperty(id,4,heroID); //add to the visitors
|
cb->setObjProperty(this->id,4,heroID); //add to the visitors
|
||||||
InfoWindow iw;
|
InfoWindow iw;
|
||||||
iw.components.push_back(Component(id,subid,1,0));
|
iw.components.push_back(Component(id,subid,1,0));
|
||||||
iw.player = cb->getOwner(heroID);
|
iw.player = cb->getOwner(heroID);
|
||||||
@ -892,9 +905,12 @@ void CGVisitableOPH::onNAHeroVisit(int heroID, bool alreadyVisited) const
|
|||||||
|
|
||||||
const std::string & CGVisitableOPH::getHoverText() const
|
const std::string & CGVisitableOPH::getHoverText() const
|
||||||
{
|
{
|
||||||
int pom;
|
int pom = -1;
|
||||||
switch(ID)
|
switch(ID)
|
||||||
{
|
{
|
||||||
|
case 4:
|
||||||
|
pom = -1;
|
||||||
|
break;
|
||||||
case 51:
|
case 51:
|
||||||
pom = 8;
|
pom = 8;
|
||||||
break;
|
break;
|
||||||
@ -914,9 +930,11 @@ const std::string & CGVisitableOPH::getHoverText() const
|
|||||||
pom = 18;
|
pom = 18;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw "Wrong CGVisitableOPH object ID!\n";
|
throw std::string("Wrong CGVisitableOPH object ID!\n");
|
||||||
}
|
}
|
||||||
hoverName = VLC->generaltexth->names[ID] + " " + VLC->generaltexth->xtrainfo[pom];
|
hoverName = VLC->generaltexth->names[ID];
|
||||||
|
if(pom >= 0)
|
||||||
|
hoverName += (" " + VLC->generaltexth->xtrainfo[pom]);
|
||||||
const CGHeroInstance *h = cb->getSelectedHero(cb->getCurrentPlayer());
|
const CGHeroInstance *h = cb->getSelectedHero(cb->getCurrentPlayer());
|
||||||
if(h)
|
if(h)
|
||||||
{
|
{
|
||||||
@ -928,6 +946,12 @@ const std::string & CGVisitableOPH::getHoverText() const
|
|||||||
return hoverName;
|
return hoverName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CGVisitableOPH::arenaSelected( int heroID, int primSkill ) const
|
||||||
|
{
|
||||||
|
cb->setObjProperty(id,4,heroID); //add to the visitors
|
||||||
|
cb->changePrimSkill(heroID,primSkill,2);
|
||||||
|
}
|
||||||
|
|
||||||
bool CArmedInstance::needsLastStack() const
|
bool CArmedInstance::needsLastStack() const
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
@ -1053,19 +1077,38 @@ void CGResource::initObj()
|
|||||||
|
|
||||||
void CGResource::onHeroVisit( const CGHeroInstance * h ) const
|
void CGResource::onHeroVisit( const CGHeroInstance * h ) const
|
||||||
{
|
{
|
||||||
//TODO: handle guards (when battles are finished)
|
if(army.slots.size())
|
||||||
if(message.length())
|
|
||||||
{
|
{
|
||||||
InfoWindow iw;
|
if(message.size())
|
||||||
iw.player = h->tempOwner;
|
{
|
||||||
iw.text << message;
|
YesNoDialog ynd;
|
||||||
cb->showInfoDialog(&iw);
|
ynd.player = h->getOwner();
|
||||||
|
ynd.text << message;
|
||||||
|
cb->showYesNoDialog(&ynd,boost::bind(&CGResource::fightForRes,this,_1,h));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fightForRes(1,h);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(message.length())
|
||||||
|
{
|
||||||
|
InfoWindow iw;
|
||||||
|
iw.player = h->tempOwner;
|
||||||
|
iw.text << message;
|
||||||
|
cb->showInfoDialog(&iw);
|
||||||
|
}
|
||||||
|
collectRes(h->getOwner());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
cb->giveResource(h->tempOwner,subID,amount);
|
void CGResource::collectRes( int player ) const
|
||||||
|
{
|
||||||
|
cb->giveResource(player,subID,amount);
|
||||||
ShowInInfobox sii;
|
ShowInInfobox sii;
|
||||||
sii.player = h->tempOwner;
|
sii.player = player;
|
||||||
sii.c = Component(2,subID,amount,0);
|
sii.c = Component(2,subID,amount,0);
|
||||||
sii.text << std::pair<ui8,ui32>(11,113);
|
sii.text << std::pair<ui8,ui32>(11,113);
|
||||||
sii.text.replacements.push_back(VLC->generaltexth->restypes[subID]);
|
sii.text.replacements.push_back(VLC->generaltexth->restypes[subID]);
|
||||||
@ -1073,6 +1116,20 @@ void CGResource::onHeroVisit( const CGHeroInstance * h ) const
|
|||||||
cb->removeObject(id);
|
cb->removeObject(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CGResource::fightForRes(ui32 wantToFight, const CGHeroInstance *h) const
|
||||||
|
{
|
||||||
|
if(wantToFight)
|
||||||
|
return;
|
||||||
|
|
||||||
|
cb->startBattleI(h->id,army,pos,boost::bind(&CGResource::endBattle,this,_1,h));
|
||||||
|
}
|
||||||
|
|
||||||
|
void CGResource::endBattle( BattleResult *result, const CGHeroInstance *h ) const
|
||||||
|
{
|
||||||
|
if(result->winner == 0) //attacker won
|
||||||
|
collectRes(h->getOwner());
|
||||||
|
}
|
||||||
|
|
||||||
void CGVisitableOPW::newTurn() const
|
void CGVisitableOPW::newTurn() const
|
||||||
{
|
{
|
||||||
if (cb->getDate(1)==1) //first day of week
|
if (cb->getDate(1)==1) //first day of week
|
||||||
@ -1330,4 +1387,36 @@ void CGPickable::chosen( int which, int heroID ) const
|
|||||||
default:
|
default:
|
||||||
throw std::string("Unhandled treasure choice");
|
throw std::string("Unhandled treasure choice");
|
||||||
}
|
}
|
||||||
|
cb->removeObject(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CGWitchHut::initObj()
|
||||||
|
{
|
||||||
|
ability = allowedAbilities[ran()%allowedAbilities.size()];
|
||||||
|
}
|
||||||
|
|
||||||
|
void CGWitchHut::onHeroVisit( const CGHeroInstance * h ) const
|
||||||
|
{
|
||||||
|
InfoWindow iw;
|
||||||
|
iw.player = h->getOwner();
|
||||||
|
|
||||||
|
if(h->getSecSkillLevel(ability)) //you alredy know this skill
|
||||||
|
{
|
||||||
|
iw.text << std::pair<ui8,ui32>(11,172);
|
||||||
|
iw.text.replacements.push_back(VLC->generaltexth->skillName[ability]);
|
||||||
|
}
|
||||||
|
else if(h->secSkills.size() >= SKILL_PER_HERO) //already all skills slots used
|
||||||
|
{
|
||||||
|
iw.text << std::pair<ui8,ui32>(11,173);
|
||||||
|
iw.text.replacements.push_back(VLC->generaltexth->skillName[ability]);
|
||||||
|
}
|
||||||
|
else //give sec skill
|
||||||
|
{
|
||||||
|
iw.components.push_back(Component(1, ability, 1, 0));
|
||||||
|
iw.text << std::pair<ui8,ui32>(11,171);
|
||||||
|
iw.text.replacements.push_back(VLC->generaltexth->skillName[ability]);
|
||||||
|
cb->changeSecSkill(h->id,ability,1,true);
|
||||||
|
}
|
||||||
|
|
||||||
|
cb->showInfoDialog(&iw);
|
||||||
}
|
}
|
@ -306,6 +306,7 @@ public:
|
|||||||
void onNAHeroVisit(int heroID, bool alreadyVisited) const;
|
void onNAHeroVisit(int heroID, bool alreadyVisited) const;
|
||||||
void initObj();
|
void initObj();
|
||||||
void treeSelected(int heroID, int resType, int resVal, int expVal, ui32 result) const; //handle player's anwer to the Tree of Knowledge dialog
|
void treeSelected(int heroID, int resType, int resVal, int expVal, ui32 result) const; //handle player's anwer to the Tree of Knowledge dialog
|
||||||
|
void arenaSelected(int heroID, int primSkill) const;
|
||||||
|
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
@ -399,10 +400,14 @@ class DLL_EXPORT CGWitchHut : public CGObjectInstance
|
|||||||
public:
|
public:
|
||||||
std::vector<si32> allowedAbilities;
|
std::vector<si32> allowedAbilities;
|
||||||
|
|
||||||
|
ui32 ability;
|
||||||
|
|
||||||
|
void onHeroVisit(const CGHeroInstance * h) const;
|
||||||
|
void initObj();
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
h & static_cast<CGObjectInstance&>(*this);
|
h & static_cast<CGObjectInstance&>(*this);
|
||||||
h & allowedAbilities;
|
h & allowedAbilities & ability;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -457,7 +462,10 @@ public:
|
|||||||
std::string message;
|
std::string message;
|
||||||
|
|
||||||
void onHeroVisit(const CGHeroInstance * h) const;
|
void onHeroVisit(const CGHeroInstance * h) const;
|
||||||
|
void collectRes(int player) const;
|
||||||
void initObj();
|
void initObj();
|
||||||
|
void fightForRes(ui32 wantToFight, const CGHeroInstance *h) const;
|
||||||
|
void endBattle(BattleResult *result, const CGHeroInstance *h) const;
|
||||||
|
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
@ -572,8 +580,13 @@ public:
|
|||||||
class DLL_EXPORT CObjectHandler
|
class DLL_EXPORT CObjectHandler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
std::vector<int> cregens; //type 17. dwelling subid -> creature ID
|
std::vector<si32> cregens; //type 17. dwelling subid -> creature ID
|
||||||
void loadObjects();
|
void loadObjects();
|
||||||
|
|
||||||
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
|
{
|
||||||
|
h & cregens;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -32,13 +32,13 @@ void CConnection::init()
|
|||||||
//we got connection
|
//we got connection
|
||||||
(*this) << std::string("Aiya!\n") << name << myEndianess; //identify ourselves
|
(*this) << std::string("Aiya!\n") << name << myEndianess; //identify ourselves
|
||||||
(*this) >> pom >> pom >> contactEndianess;
|
(*this) >> pom >> pom >> contactEndianess;
|
||||||
out << "Established connection with "<<pom<<std::endl;
|
tlog0 << "Established connection with "<<pom<<std::endl;
|
||||||
wmx = new boost::mutex;
|
wmx = new boost::mutex;
|
||||||
rmx = new boost::mutex;
|
rmx = new boost::mutex;
|
||||||
}
|
}
|
||||||
|
|
||||||
CConnection::CConnection(std::string host, std::string port, std::string Name, std::ostream & Out)
|
CConnection::CConnection(std::string host, std::string port, std::string Name)
|
||||||
:io_service(new asio::io_service), name(Name), out(Out)//, send(this), rec(this)
|
:io_service(new asio::io_service), name(Name)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
boost::system::error_code error = asio::error::host_not_found;
|
boost::system::error_code error = asio::error::host_not_found;
|
||||||
@ -94,14 +94,14 @@ connerror1:
|
|||||||
}
|
}
|
||||||
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,
|
||||||
std::string Name,
|
std::string Name )
|
||||||
std::ostream & Out )
|
:socket(Socket),io_service(&Socket->io_service()), name(Name)//, send(this), rec(this)
|
||||||
:socket(Socket),io_service(&Socket->io_service()), out(Out), name(Name)//, send(this), rec(this)
|
|
||||||
{
|
{
|
||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
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)
|
CConnection::CConnection(boost::asio::basic_socket_acceptor<boost::asio::ip::tcp,boost::asio::socket_acceptor_service<boost::asio::ip::tcp> > * acceptor,
|
||||||
: out(Out), name(Name)//, send(this), rec(this)
|
boost::asio::io_service *Io_service, std::string Name)
|
||||||
|
: name(Name)//, send(this), rec(this)
|
||||||
{
|
{
|
||||||
boost::system::error_code error = asio::error::host_not_found;
|
boost::system::error_code error = asio::error::host_not_found;
|
||||||
socket = new tcp::socket(*io_service);
|
socket = new tcp::socket(*io_service);
|
||||||
|
@ -401,7 +401,6 @@ public:
|
|||||||
class DLL_EXPORT CConnection
|
class DLL_EXPORT CConnection
|
||||||
:public CISer<CConnection>, public COSer<CConnection>
|
:public CISer<CConnection>, public COSer<CConnection>
|
||||||
{
|
{
|
||||||
std::ostream &out;
|
|
||||||
CConnection(void);
|
CConnection(void);
|
||||||
void init();
|
void init();
|
||||||
public:
|
public:
|
||||||
@ -414,13 +413,13 @@ public:
|
|||||||
std::string name; //who uses this connection
|
std::string name; //who uses this connection
|
||||||
|
|
||||||
CConnection
|
CConnection
|
||||||
(std::string host, std::string port, std::string Name, std::ostream & Out);
|
(std::string host, std::string port, std::string Name);
|
||||||
CConnection
|
CConnection
|
||||||
(boost::asio::basic_socket_acceptor<boost::asio::ip::tcp, boost::asio::socket_acceptor_service<boost::asio::ip::tcp> > * acceptor,
|
(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);
|
boost::asio::io_service *Io_service, std::string Name);
|
||||||
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,
|
||||||
std::string Name, std::ostream & Out); //use immediately after accepting connection into socket
|
std::string Name); //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);
|
||||||
|
@ -42,6 +42,7 @@ public:
|
|||||||
virtual void setHoverName(int objid, MetaString * name)=0;
|
virtual void setHoverName(int objid, MetaString * name)=0;
|
||||||
virtual void setObjProperty(int objid, int prop, int val)=0;
|
virtual void setObjProperty(int objid, int prop, int val)=0;
|
||||||
virtual void changePrimSkill(int ID, int which, int val, bool abs=false)=0;
|
virtual void changePrimSkill(int ID, int which, int val, bool abs=false)=0;
|
||||||
|
virtual void changeSecSkill(int ID, int which, int val, bool abs=false)=0;
|
||||||
virtual void showInfoDialog(InfoWindow *iw)=0;
|
virtual void showInfoDialog(InfoWindow *iw)=0;
|
||||||
virtual void showYesNoDialog(YesNoDialog *iw, const CFunctionList<void(ui32)> &callback)=0;
|
virtual void showYesNoDialog(YesNoDialog *iw, const CFunctionList<void(ui32)> &callback)=0;
|
||||||
virtual void showSelectionDialog(SelectionDialog *iw, const CFunctionList<void(ui32)> &callback)=0; //returns question id
|
virtual void showSelectionDialog(SelectionDialog *iw, const CFunctionList<void(ui32)> &callback)=0; //returns question id
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
#include <boost/interprocess/sync/interprocess_mutex.hpp>
|
#include <boost/interprocess/sync/interprocess_mutex.hpp>
|
||||||
#include <boost/interprocess/sync/interprocess_condition.hpp>
|
#include <boost/interprocess/sync/interprocess_condition.hpp>
|
||||||
|
#include <boost/interprocess/mapped_region.hpp>
|
||||||
|
#include <boost/interprocess/shared_memory_object.hpp>
|
||||||
|
|
||||||
struct ServerReady
|
struct ServerReady
|
||||||
{
|
{
|
||||||
@ -20,3 +22,18 @@ struct ServerReady
|
|||||||
cond.notify_all();
|
cond.notify_all();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct SharedMem
|
||||||
|
{
|
||||||
|
boost::interprocess::shared_memory_object smo;
|
||||||
|
boost::interprocess::mapped_region mr;
|
||||||
|
ServerReady *sr;
|
||||||
|
|
||||||
|
SharedMem()
|
||||||
|
:smo(boost::interprocess::open_or_create,"vcmi_memory",boost::interprocess::read_write),
|
||||||
|
mr(smo,boost::interprocess::read_write)
|
||||||
|
{
|
||||||
|
smo.truncate(sizeof(ServerReady));
|
||||||
|
sr = new(mr.get_address())ServerReady();
|
||||||
|
};
|
||||||
|
};
|
109
lib/VCMI_Lib.cpp
109
lib/VCMI_Lib.cpp
@ -20,56 +20,15 @@ DLL_EXPORT CLogger<3> tlog3;
|
|||||||
DLL_EXPORT CLogger<4> tlog4;
|
DLL_EXPORT CLogger<4> tlog4;
|
||||||
DLL_EXPORT CLogger<5> tlog5;
|
DLL_EXPORT CLogger<5> tlog5;
|
||||||
DLL_EXPORT CConsoleHandler *console = NULL;
|
DLL_EXPORT CConsoleHandler *console = NULL;
|
||||||
DLL_EXPORT std::ostream *logfile = NULL;
|
DLL_EXPORT std::ostream *logfile = NULL
|
||||||
|
;
|
||||||
DLL_EXPORT void initDLL(CLodHandler *b, CConsoleHandler *Console, std::ostream *Logfile)
|
DLL_EXPORT void initDLL(CLodHandler *b, CConsoleHandler *Console, std::ostream *Logfile)
|
||||||
{
|
{
|
||||||
console = Console;
|
console = Console;
|
||||||
logfile = Logfile;
|
logfile = Logfile;
|
||||||
timeHandler pomtime;
|
|
||||||
bitmaph=b;
|
bitmaph=b;
|
||||||
VLC = new LibClasses;
|
VLC = new LibClasses;
|
||||||
|
VLC->init();
|
||||||
VLC->generaltexth = new CGeneralTextHandler;
|
|
||||||
VLC->generaltexth->loadTexts();
|
|
||||||
VLC->generaltexth->load();
|
|
||||||
tlog0<<"\tGeneral text handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
CHeroHandler * heroh = new CHeroHandler;
|
|
||||||
heroh->loadHeroes();
|
|
||||||
VLC->heroh = heroh;
|
|
||||||
tlog0 <<"\tHero handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
CArtHandler * arth = new CArtHandler;
|
|
||||||
arth->loadArtifacts();
|
|
||||||
VLC->arth = arth;
|
|
||||||
tlog0<<"\tArtifact handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
CCreatureHandler * creh = new CCreatureHandler();
|
|
||||||
creh->loadCreatures();
|
|
||||||
VLC->creh = creh;
|
|
||||||
tlog0<<"\tCreature handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
VLC->townh = new CTownHandler;
|
|
||||||
VLC->townh->loadNames();
|
|
||||||
tlog0<<"\tTown handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
CObjectHandler * objh = new CObjectHandler;
|
|
||||||
objh->loadObjects();
|
|
||||||
VLC->objh = objh;
|
|
||||||
tlog0<<"\tObject handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
VLC->dobjinfo = new CDefObjInfoHandler;
|
|
||||||
VLC->dobjinfo->load();
|
|
||||||
tlog0<<"\tDef information handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
VLC->buildh = new CBuildingHandler;
|
|
||||||
VLC->buildh->loadBuildings();
|
|
||||||
tlog0<<"\tBuilding handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
|
|
||||||
CSpellHandler * spellh = new CSpellHandler;
|
|
||||||
spellh->loadSpells();
|
|
||||||
VLC->spellh = spellh;
|
|
||||||
tlog0<<"\tSpell handler: "<<pomtime.getDif()<<std::endl;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DLL_EXPORT void loadToIt(std::string &dest, std::string &src, int &iter, int mode)
|
DLL_EXPORT void loadToIt(std::string &dest, std::string &src, int &iter, int mode)
|
||||||
@ -186,3 +145,65 @@ DLL_EXPORT void loadToIt(si32 &dest, std::string &src, int &iter, int mode)
|
|||||||
loadToIt(pom,src,iter,mode);
|
loadToIt(pom,src,iter,mode);
|
||||||
dest = atol(pom.c_str());
|
dest = atol(pom.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void LibClasses::init()
|
||||||
|
{
|
||||||
|
timeHandler pomtime;
|
||||||
|
generaltexth = new CGeneralTextHandler;
|
||||||
|
generaltexth->load();
|
||||||
|
tlog0<<"\tGeneral text handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
heroh = new CHeroHandler;
|
||||||
|
heroh->loadHeroes();
|
||||||
|
tlog0 <<"\tHero handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
arth = new CArtHandler;
|
||||||
|
arth->loadArtifacts();
|
||||||
|
tlog0<<"\tArtifact handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
creh = new CCreatureHandler();
|
||||||
|
creh->loadCreatures();
|
||||||
|
tlog0<<"\tCreature handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
townh = new CTownHandler;
|
||||||
|
townh->loadNames();
|
||||||
|
tlog0<<"\tTown handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
objh = new CObjectHandler;
|
||||||
|
objh->loadObjects();
|
||||||
|
tlog0<<"\tObject handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
dobjinfo = new CDefObjInfoHandler;
|
||||||
|
dobjinfo->load();
|
||||||
|
tlog0<<"\tDef information handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
buildh = new CBuildingHandler;
|
||||||
|
buildh->loadBuildings();
|
||||||
|
tlog0<<"\tBuilding handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
|
||||||
|
spellh = new CSpellHandler;
|
||||||
|
spellh->loadSpells();
|
||||||
|
tlog0<<"\tSpell handler: "<<pomtime.getDif()<<std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
void LibClasses::clear()
|
||||||
|
{
|
||||||
|
delete generaltexth;
|
||||||
|
delete heroh;
|
||||||
|
delete arth;
|
||||||
|
delete creh;
|
||||||
|
delete townh;
|
||||||
|
delete objh;
|
||||||
|
delete dobjinfo;
|
||||||
|
delete buildh;
|
||||||
|
delete spellh;
|
||||||
|
generaltexth = NULL;
|
||||||
|
heroh = NULL;
|
||||||
|
arth = NULL;
|
||||||
|
creh = NULL;
|
||||||
|
townh = NULL;
|
||||||
|
objh = NULL;
|
||||||
|
dobjinfo = NULL;
|
||||||
|
buildh = NULL;
|
||||||
|
spellh = NULL;
|
||||||
|
}
|
@ -20,7 +20,7 @@ class CGeneralTextHandler;
|
|||||||
//class CPathfinder;
|
//class CPathfinder;
|
||||||
//class CGameState;
|
//class CGameState;
|
||||||
|
|
||||||
class LibClasses
|
class DLL_EXPORT LibClasses
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CArtHandler * arth;
|
CArtHandler * arth;
|
||||||
@ -33,6 +33,19 @@ public:
|
|||||||
CTownHandler * townh;
|
CTownHandler * townh;
|
||||||
CGeneralTextHandler * generaltexth;
|
CGeneralTextHandler * generaltexth;
|
||||||
//CPathfinder * pathf;
|
//CPathfinder * pathf;
|
||||||
|
|
||||||
|
void init(); //uses standard config file
|
||||||
|
void clear(); //deletes all handlers and its data
|
||||||
|
|
||||||
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
|
{
|
||||||
|
if(!h.saving)
|
||||||
|
{
|
||||||
|
generaltexth = new CGeneralTextHandler;
|
||||||
|
generaltexth->load();
|
||||||
|
}
|
||||||
|
h & heroh & arth & creh & townh & objh & dobjinfo & buildh & spellh;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
extern DLL_EXPORT LibClasses * VLC;
|
extern DLL_EXPORT LibClasses * VLC;
|
||||||
|
39
map.cpp
39
map.cpp
@ -244,6 +244,7 @@ void CMapHeader::initFromMemory( unsigned char *bufor, int &i )
|
|||||||
}
|
}
|
||||||
void CMapHeader::loadPlayerInfo( int &pom, unsigned char * bufor, int &i )
|
void CMapHeader::loadPlayerInfo( int &pom, unsigned char * bufor, int &i )
|
||||||
{
|
{
|
||||||
|
players.resize(8);
|
||||||
for (pom=0;pom<8;pom++)
|
for (pom=0;pom<8;pom++)
|
||||||
{
|
{
|
||||||
players[pom].canHumanPlay = bufor[i++];
|
players[pom].canHumanPlay = bufor[i++];
|
||||||
@ -467,10 +468,7 @@ void Mapa::initFromBytes(unsigned char * bufor)
|
|||||||
readEvents(bufor, i);
|
readEvents(bufor, i);
|
||||||
tlog0<<"\tReading events: "<<th.getDif()<<std::endl;
|
tlog0<<"\tReading events: "<<th.getDif()<<std::endl;
|
||||||
|
|
||||||
//map readed, bufor no longer needed
|
//map readed, bufor no longer needed
|
||||||
delete[] bufor; bufor=NULL;
|
|
||||||
|
|
||||||
|
|
||||||
for(int f=0; f<objects.size(); ++f) //calculationg blocked / visitable positions
|
for(int f=0; f<objects.size(); ++f) //calculationg blocked / visitable positions
|
||||||
{
|
{
|
||||||
if(!objects[f]->defInfo)
|
if(!objects[f]->defInfo)
|
||||||
@ -552,12 +550,28 @@ Mapa::Mapa(std::string filename)
|
|||||||
checksum = result.checksum();
|
checksum = result.checksum();
|
||||||
tlog0 << "\tOur map checksum: "<<result.checksum() << std::endl;
|
tlog0 << "\tOur map checksum: "<<result.checksum() << std::endl;
|
||||||
initFromBytes(initTable);
|
initFromBytes(initTable);
|
||||||
|
delete [] initTable;
|
||||||
}
|
}
|
||||||
|
|
||||||
Mapa::Mapa()
|
Mapa::Mapa()
|
||||||
{
|
{
|
||||||
|
terrain = NULL;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Mapa::~Mapa()
|
||||||
|
{
|
||||||
|
if(terrain)
|
||||||
|
{
|
||||||
|
for (int ii=0;ii<width;ii++)
|
||||||
|
{
|
||||||
|
for(int jj=0;jj<height;jj++)
|
||||||
|
delete [] terrain[ii][jj];
|
||||||
|
delete [] terrain[ii];
|
||||||
|
}
|
||||||
|
delete [] terrain;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CGHeroInstance * Mapa::getHero(int ID, int mode)
|
CGHeroInstance * Mapa::getHero(int ID, int mode)
|
||||||
{
|
{
|
||||||
if (mode != 0)
|
if (mode != 0)
|
||||||
@ -1397,6 +1411,7 @@ void Mapa::readObjects( unsigned char * bufor, int &i)
|
|||||||
loadHero(nobj, bufor, i);
|
loadHero(nobj, bufor, i);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case 4: //arena
|
||||||
case 51: //Mercenary Camp
|
case 51: //Mercenary Camp
|
||||||
case 23: //Marletto Tower
|
case 23: //Marletto Tower
|
||||||
case 61: // Star Axis
|
case 61: // Star Axis
|
||||||
@ -1903,4 +1918,20 @@ void Mapa::loadQuest(CQuest * guard, unsigned char * bufor, int & i)
|
|||||||
guard->firstVisitText = readString(bufor,i);
|
guard->firstVisitText = readString(bufor,i);
|
||||||
guard->nextVisitText = readString(bufor,i);
|
guard->nextVisitText = readString(bufor,i);
|
||||||
guard->completedText = readString(bufor,i);
|
guard->completedText = readString(bufor,i);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CMapInfo::countPlayers()
|
||||||
|
{
|
||||||
|
playerAmnt=humenPlayers=0;
|
||||||
|
for (int i=0;i<PLAYER_LIMIT;i++)
|
||||||
|
{
|
||||||
|
if (players[i].canHumanPlay) {playerAmnt++;humenPlayers++;}
|
||||||
|
else if (players[i].canComputerPlay) {playerAmnt++;}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CMapInfo::CMapInfo( std::string fname, unsigned char *map )
|
||||||
|
:CMapHeader(map),filename(fname)
|
||||||
|
{
|
||||||
|
countPlayers();
|
||||||
}
|
}
|
28
map.h
28
map.h
@ -205,7 +205,7 @@ public:
|
|||||||
ui8 levelLimit;
|
ui8 levelLimit;
|
||||||
LossCondition lossCondition;
|
LossCondition lossCondition;
|
||||||
CVictoryCondition victoryCondition; //victory conditions
|
CVictoryCondition victoryCondition; //victory conditions
|
||||||
PlayerInfo players[8]; // info about players
|
std::vector<PlayerInfo> players; // info about players - size 8
|
||||||
std::vector<ui8> teams; // teams[i] = team of player no i
|
std::vector<ui8> teams; // teams[i] = team of player no i
|
||||||
ui8 howManyTeams;
|
ui8 howManyTeams;
|
||||||
void initFromMemory(unsigned char *bufor, int &i);
|
void initFromMemory(unsigned char *bufor, int &i);
|
||||||
@ -213,6 +213,13 @@ public:
|
|||||||
void loadPlayerInfo( int &pom, unsigned char * bufor, int &i);
|
void loadPlayerInfo( int &pom, unsigned char * bufor, int &i);
|
||||||
CMapHeader(unsigned char *map); //an argument is a reference to string described a map (unpacked)
|
CMapHeader(unsigned char *map); //an argument is a reference to string described a map (unpacked)
|
||||||
CMapHeader();
|
CMapHeader();
|
||||||
|
|
||||||
|
|
||||||
|
template <typename Handler> void serialize(Handler &h, const int Version)
|
||||||
|
{
|
||||||
|
h & version & name & description & width & height & twoLevel & difficulty & levelLimit & areAnyPLayers;
|
||||||
|
h & players & teams & lossCondition & victoryCondition & howManyTeams;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class DLL_EXPORT CMapInfo : public CMapHeader
|
class DLL_EXPORT CMapInfo : public CMapHeader
|
||||||
@ -220,15 +227,9 @@ class DLL_EXPORT CMapInfo : public CMapHeader
|
|||||||
public:
|
public:
|
||||||
std::string filename;
|
std::string filename;
|
||||||
int playerAmnt, humenPlayers;
|
int playerAmnt, humenPlayers;
|
||||||
CMapInfo(std::string fname, unsigned char *map):CMapHeader(map),filename(fname)
|
CMapInfo(){};
|
||||||
{
|
void countPlayers();
|
||||||
playerAmnt=humenPlayers=0;
|
CMapInfo(std::string fname, unsigned char *map);
|
||||||
for (int i=0;i<PLAYER_LIMIT;i++)
|
|
||||||
{
|
|
||||||
if (players[i].canHumanPlay) {playerAmnt++;humenPlayers++;}
|
|
||||||
else if (players[i].canComputerPlay) {playerAmnt++;}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -317,6 +318,7 @@ struct DLL_EXPORT Mapa : public CMapHeader
|
|||||||
void removeBlockVisTiles(CGObjectInstance * obj);
|
void removeBlockVisTiles(CGObjectInstance * obj);
|
||||||
Mapa(std::string filename); //creates map structure from .h3m file
|
Mapa(std::string filename); //creates map structure from .h3m file
|
||||||
Mapa();
|
Mapa();
|
||||||
|
~Mapa();
|
||||||
CGHeroInstance * getHero(int ID, int mode=0);
|
CGHeroInstance * getHero(int ID, int mode=0);
|
||||||
bool isInTheMap(int3 pos);
|
bool isInTheMap(int3 pos);
|
||||||
template <typename TObject, typename Handler> void serializeObj(Handler &h, const int version, TObject ** obj)
|
template <typename TObject, typename Handler> void serializeObj(Handler &h, const int version, TObject ** obj)
|
||||||
@ -325,10 +327,8 @@ struct DLL_EXPORT Mapa : public CMapHeader
|
|||||||
}
|
}
|
||||||
template <typename Handler> void serialize(Handler &h, const int formatVersion)
|
template <typename Handler> void serialize(Handler &h, const int formatVersion)
|
||||||
{
|
{
|
||||||
h & version & name & description & width & height & twoLevel & difficulty & levelLimit & areAnyPLayers & rumors;
|
h & static_cast<CMapHeader&>(*this);
|
||||||
|
h & rumors & allowedSpell & allowedAbilities & allowedArtifact & allowedHeroes & events & grailPos;
|
||||||
h & players & teams & lossCondition & victoryCondition & howManyTeams & allowedSpell
|
|
||||||
& allowedAbilities & allowedArtifact & allowedHeroes & events & grailPos;
|
|
||||||
|
|
||||||
//TODO: viccondetails
|
//TODO: viccondetails
|
||||||
if(h.saving)
|
if(h.saving)
|
||||||
|
@ -404,7 +404,16 @@ void processDef (CGDefInfo* def)
|
|||||||
{
|
{
|
||||||
if(def->id == 26)
|
if(def->id == 26)
|
||||||
return;
|
return;
|
||||||
def->handler=CDefHandler::giveDef(def->name);
|
if(def->name.size())
|
||||||
|
{
|
||||||
|
def->handler = CDefHandler::giveDef(def->name);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
tlog2 << "No def name for " << def->id << " " << def->subid << std::endl;
|
||||||
|
def->handler = NULL;
|
||||||
|
return;
|
||||||
|
}
|
||||||
def->width = def->handler->ourImages[0].bitmap->w/32;
|
def->width = def->handler->ourImages[0].bitmap->w/32;
|
||||||
def->height = def->handler->ourImages[0].bitmap->h/32;
|
def->height = def->handler->ourImages[0].bitmap->h/32;
|
||||||
CGDefInfo* pom = CGI->dobjinfo->gobjs[def->id][def->subid];
|
CGDefInfo* pom = CGI->dobjinfo->gobjs[def->id][def->subid];
|
||||||
@ -518,7 +527,7 @@ SDL_Surface * CMapHandler::terrainRect(int x, int y, int dx, int dy, int level,
|
|||||||
if(extRect) SDL_SetClipRect(su, extRect); //preventing blitting outside of that rect
|
if(extRect) SDL_SetClipRect(su, extRect); //preventing blitting outside of that rect
|
||||||
|
|
||||||
if (((dx+x)>((map->width+Woff)) || (dy+y)>((map->height+Hoff))) || ((x<-Woff)||(y<-Hoff) ) )
|
if (((dx+x)>((map->width+Woff)) || (dy+y)>((map->height+Hoff))) || ((x<-Woff)||(y<-Hoff) ) )
|
||||||
throw new std::string("terrainRect: out of range");
|
throw std::string("terrainRect: out of range");
|
||||||
////printing terrain
|
////printing terrain
|
||||||
for (int bx=0; bx<dx; bx++)
|
for (int bx=0; bx<dx; bx++)
|
||||||
{
|
{
|
||||||
@ -622,7 +631,7 @@ SDL_Surface * CMapHandler::terrainRect(int x, int y, int dx, int dy, int level,
|
|||||||
|
|
||||||
if(themp->type==NULL)
|
if(themp->type==NULL)
|
||||||
continue;
|
continue;
|
||||||
std::vector<Cimage> & iv = themp->type->heroClass->moveAnim->ourImages;
|
std::vector<Cimage> & iv = graphics->heroAnims[themp->type->heroType]->ourImages;
|
||||||
|
|
||||||
size_t gg;
|
size_t gg;
|
||||||
for(gg=0; gg<iv.size(); ++gg)
|
for(gg=0; gg<iv.size(); ++gg)
|
||||||
@ -645,7 +654,7 @@ SDL_Surface * CMapHandler::terrainRect(int x, int y, int dx, int dy, int level,
|
|||||||
|
|
||||||
if(themp->type==NULL)
|
if(themp->type==NULL)
|
||||||
continue;
|
continue;
|
||||||
std::vector<Cimage> & iv = themp->type->heroClass->moveAnim->ourImages;
|
std::vector<Cimage> & iv = graphics->heroAnims[themp->type->heroType]->ourImages;
|
||||||
|
|
||||||
size_t gg;
|
size_t gg;
|
||||||
for(gg=0; gg < iv.size(); ++gg)
|
for(gg=0; gg < iv.size(); ++gg)
|
||||||
@ -785,7 +794,7 @@ SDL_Surface * CMapHandler::terrainRectSmooth(int x, int y, int dx, int dy, int l
|
|||||||
if(extRect) SDL_SetClipRect(su, extRect); //preventing blitting outside of that rect
|
if(extRect) SDL_SetClipRect(su, extRect); //preventing blitting outside of that rect
|
||||||
|
|
||||||
if (((dx+x)>((map->width+Woff)) || (dy+y)>((map->height+Hoff))) || ((x<-Woff)||(y<-Hoff) ) )
|
if (((dx+x)>((map->width+Woff)) || (dy+y)>((map->height+Hoff))) || ((x<-Woff)||(y<-Hoff) ) )
|
||||||
throw new std::string("terrainRect: out of range");
|
throw std::string("terrainRect: out of range");
|
||||||
////printing terrain
|
////printing terrain
|
||||||
for (int bx= (moveX <= 0 ? 0 : -1); bx<dx+1; bx++)
|
for (int bx= (moveX <= 0 ? 0 : -1); bx<dx+1; bx++)
|
||||||
{
|
{
|
||||||
@ -889,7 +898,7 @@ SDL_Surface * CMapHandler::terrainRectSmooth(int x, int y, int dx, int dy, int l
|
|||||||
|
|
||||||
if(themp->type==NULL)
|
if(themp->type==NULL)
|
||||||
continue;
|
continue;
|
||||||
std::vector<Cimage> & iv = themp->type->heroClass->moveAnim->ourImages;
|
std::vector<Cimage> & iv = graphics->heroAnims[themp->type->heroType]->ourImages;
|
||||||
|
|
||||||
size_t gg;
|
size_t gg;
|
||||||
for(gg=0; gg<iv.size(); ++gg)
|
for(gg=0; gg<iv.size(); ++gg)
|
||||||
@ -912,7 +921,7 @@ SDL_Surface * CMapHandler::terrainRectSmooth(int x, int y, int dx, int dy, int l
|
|||||||
|
|
||||||
if(themp->type==NULL)
|
if(themp->type==NULL)
|
||||||
continue;
|
continue;
|
||||||
std::vector<Cimage> & iv = themp->type->heroClass->moveAnim->ourImages;
|
std::vector<Cimage> & iv = graphics->heroAnims[themp->type->heroType]->ourImages;
|
||||||
|
|
||||||
size_t gg;
|
size_t gg;
|
||||||
for(gg=0; gg < iv.size(); ++gg)
|
for(gg=0; gg < iv.size(); ++gg)
|
||||||
@ -1328,11 +1337,7 @@ std::string CMapHandler::getDefName(int id, int subid)
|
|||||||
CGDefInfo* temp = CGI->dobjinfo->gobjs[id][subid];
|
CGDefInfo* temp = CGI->dobjinfo->gobjs[id][subid];
|
||||||
if(temp)
|
if(temp)
|
||||||
return temp->name;
|
return temp->name;
|
||||||
#ifndef __GNUC__
|
throw std::string("Def not found.");
|
||||||
throw new std::exception("Def not found.");
|
|
||||||
#else
|
|
||||||
throw new std::exception();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CMapHandler::printObject(const CGObjectInstance *obj)
|
bool CMapHandler::printObject(const CGObjectInstance *obj)
|
||||||
@ -1415,11 +1420,7 @@ unsigned char CMapHandler::getHeroFrameNum(const unsigned char &dir, const bool
|
|||||||
case 8:
|
case 8:
|
||||||
return 11;
|
return 11;
|
||||||
default:
|
default:
|
||||||
#ifndef __GNUC__
|
throw std::string("Something very wrong1.");
|
||||||
throw std::exception("Something very wrong1.");
|
|
||||||
#else
|
|
||||||
throw std::exception();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else //if(isMoving)
|
else //if(isMoving)
|
||||||
@ -1443,11 +1444,7 @@ unsigned char CMapHandler::getHeroFrameNum(const unsigned char &dir, const bool
|
|||||||
case 8:
|
case 8:
|
||||||
return 14;
|
return 14;
|
||||||
default:
|
default:
|
||||||
#ifndef __GNUC__
|
throw std::string("Something very wrong2.");
|
||||||
throw std::exception("Something very wrong2.");
|
|
||||||
#else
|
|
||||||
throw std::exception();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1549,6 +1546,18 @@ void CMapHandler::updateWater() //shift colors in palettes of water tiles
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CMapHandler::~CMapHandler()
|
||||||
|
{
|
||||||
|
delete fullHide;
|
||||||
|
delete partialHide;
|
||||||
|
}
|
||||||
|
|
||||||
|
CMapHandler::CMapHandler()
|
||||||
|
{
|
||||||
|
fullHide = NULL;
|
||||||
|
partialHide = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
TerrainTile2::TerrainTile2()
|
TerrainTile2::TerrainTile2()
|
||||||
:terbitmap(0),tileInfo(0)
|
:terbitmap(0),tileInfo(0)
|
||||||
{}
|
{}
|
||||||
|
@ -85,6 +85,9 @@ public:
|
|||||||
|
|
||||||
std::vector<std::vector<std::vector<unsigned char> > > hideBitmap; //specifies number of graphic that should be used to fully hide a tile
|
std::vector<std::vector<std::vector<unsigned char> > > hideBitmap; //specifies number of graphic that should be used to fully hide a tile
|
||||||
|
|
||||||
|
CMapHandler();
|
||||||
|
~CMapHandler();
|
||||||
|
|
||||||
void loadDefs();
|
void loadDefs();
|
||||||
SDL_Surface * getVisBitmap(int x, int y, const std::vector< std::vector< std::vector<unsigned char> > > & visibilityMap, int lvl);
|
SDL_Surface * getVisBitmap(int x, int y, const std::vector< std::vector< std::vector<unsigned char> > > & visibilityMap, int lvl);
|
||||||
|
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
#include "../CGameState.h"
|
|
||||||
#include "../StartInfo.h"
|
#include "../StartInfo.h"
|
||||||
#include "../hch/CArtHandler.h"
|
#include "../hch/CArtHandler.h"
|
||||||
#include "../hch/CBuildingHandler.h"
|
#include "../hch/CBuildingHandler.h"
|
||||||
#include "../hch/CDefObjInfoHandler.h"
|
#include "../hch/CDefObjInfoHandler.h"
|
||||||
|
#include "../hch/CGeneralTextHandler.h"
|
||||||
#include "../hch/CHeroHandler.h"
|
#include "../hch/CHeroHandler.h"
|
||||||
#include "../hch/CObjectHandler.h"
|
#include "../hch/CObjectHandler.h"
|
||||||
#include "../hch/CSpellHandler.h"
|
#include "../hch/CSpellHandler.h"
|
||||||
#include "../hch/CTownHandler.h"
|
#include "../hch/CTownHandler.h"
|
||||||
|
#include "../CGameState.h"
|
||||||
#include "../lib/CondSh.h"
|
#include "../lib/CondSh.h"
|
||||||
#include "../lib/Connection.h"
|
#include "../lib/Connection.h"
|
||||||
#include "../lib/NetPacks.h"
|
#include "../lib/NetPacks.h"
|
||||||
@ -183,15 +184,16 @@ void callWith(std::vector<T> args, boost::function<void(T)> fun, ui32 which)
|
|||||||
fun(args[which]);
|
fun(args[which]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGameHandler::changeSecSkill(int ID, ui16 which, int val, bool abs)
|
void CGameHandler::changeSecSkill( int ID, int which, int val, bool abs/*=false*/ )
|
||||||
{
|
{
|
||||||
SetSecSkill sps;
|
SetSecSkill sss;
|
||||||
sps.id = ID;
|
sss.id = ID;
|
||||||
sps.which = which;
|
sss.which = which;
|
||||||
sps.abs = abs;
|
sss.val = val;
|
||||||
sps.val = val;
|
sss.abs = abs;
|
||||||
sendAndApply(&sps);
|
sendAndApply(&sss);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGameHandler::changePrimSkill(int ID, int which, int val, bool abs)
|
void CGameHandler::changePrimSkill(int ID, int which, int val, bool abs)
|
||||||
{
|
{
|
||||||
SetPrimSkill sps;
|
SetPrimSkill sps;
|
||||||
@ -413,18 +415,16 @@ void CGameHandler::handleConnection(std::set<int> players, CConnection &c)
|
|||||||
c >> fname;
|
c >> fname;
|
||||||
|
|
||||||
{
|
{
|
||||||
CSaveFile save(fname);
|
CSaveFile save(std::string("Games") + PATHSEPARATOR + fname + ".vlgm1");
|
||||||
save << gs->map;
|
char hlp[8] = "VCMISVG";
|
||||||
|
save << hlp << static_cast<CMapHeader&>(*gs->map) << *VLC << gs;
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
CLoadFile load(fname);
|
CSaveFile save(std::string("Games") + PATHSEPARATOR + fname + ".vsgm1");
|
||||||
load >> mapa;
|
save << *this;
|
||||||
}
|
}
|
||||||
//save << VLC->arth << VLC->buildh << VLC->creh << VLC->dobjinfo << VLC->heroh
|
|
||||||
// << VLC->spellh << VLC->townh << this;
|
|
||||||
|
|
||||||
//save << this;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 99: //end!
|
case 99: //end!
|
||||||
@ -1553,6 +1553,9 @@ void CGameHandler::init(StartInfo *si, int Seed)
|
|||||||
//}
|
//}
|
||||||
|
|
||||||
//delete lf;
|
//delete lf;
|
||||||
|
|
||||||
|
for(std::map<ui8,PlayerState>::iterator i = gs->players.begin(); i != gs->players.end(); i++)
|
||||||
|
states.addPlayer(i->first);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGameHandler::newTurn()
|
void CGameHandler::newTurn()
|
||||||
@ -1638,13 +1641,15 @@ void CGameHandler::newTurn()
|
|||||||
if(gs->map->objects[i])
|
if(gs->map->objects[i])
|
||||||
gs->map->objects[i]->newTurn();
|
gs->map->objects[i]->newTurn();
|
||||||
}
|
}
|
||||||
void CGameHandler::run()
|
void CGameHandler::run(bool resume)
|
||||||
{
|
{
|
||||||
BOOST_FOREACH(CConnection *cc, conns)
|
BOOST_FOREACH(CConnection *cc, conns)
|
||||||
{//init conn.
|
{//init conn.
|
||||||
ui8 quantity, pom;
|
ui8 quantity, pom;
|
||||||
//ui32 seed;
|
//ui32 seed;
|
||||||
(*cc) << gs->scenarioOps->mapname << gs->map->checksum << gs->seed;
|
if(!resume)
|
||||||
|
(*cc) << gs->scenarioOps->mapname << gs->map->checksum << gs->seed;
|
||||||
|
|
||||||
(*cc) >> quantity; //how many players will be handled at that client
|
(*cc) >> quantity; //how many players will be handled at that client
|
||||||
for(int i=0;i<quantity;i++)
|
for(int i=0;i<quantity;i++)
|
||||||
{
|
{
|
||||||
@ -1700,14 +1705,23 @@ void CGameHandler::run()
|
|||||||
//if(checkFunc(map->objects[i]->ID,temps))
|
//if(checkFunc(map->objects[i]->ID,temps))
|
||||||
// (*skrypty)[map->objects[i]->ID][temps]->newObject(map->objects[i]);
|
// (*skrypty)[map->objects[i]->ID][temps]->newObject(map->objects[i]);
|
||||||
//}
|
//}
|
||||||
for(std::map<ui8,PlayerState>::iterator i = gs->players.begin(); i != gs->players.end(); i++)
|
|
||||||
states.addPlayer(i->first);
|
|
||||||
|
|
||||||
while (!end2)
|
while (!end2)
|
||||||
{
|
{
|
||||||
newTurn();
|
|
||||||
for(std::map<ui8,PlayerState>::iterator i = gs->players.begin(); i != gs->players.end(); i++)
|
std::map<ui8,PlayerState>::iterator i;
|
||||||
|
if(!resume)
|
||||||
|
i = gs->players.begin();
|
||||||
|
else
|
||||||
|
i = gs->players.find(gs->currentPlayer);
|
||||||
|
|
||||||
|
for(; i != gs->players.end(); i++)
|
||||||
{
|
{
|
||||||
|
if(!resume)
|
||||||
|
newTurn();
|
||||||
|
else
|
||||||
|
resume = false;
|
||||||
|
|
||||||
if((i->second.towns.size()==0 && i->second.heroes.size()==0) || i->second.color<0 || i->first>=PLAYER_LIMIT ) continue; //players has not towns/castle - loser
|
if((i->second.towns.size()==0 && i->second.heroes.size()==0) || i->second.color<0 || i->first>=PLAYER_LIMIT ) continue; //players has not towns/castle - loser
|
||||||
states.setFlag(i->first,&PlayerStatus::makingTurn,true);
|
states.setFlag(i->first,&PlayerStatus::makingTurn,true);
|
||||||
gs->currentPlayer = i->first;
|
gs->currentPlayer = i->first;
|
||||||
|
@ -57,15 +57,11 @@ public:
|
|||||||
class CGameHandler : public IGameCallback
|
class CGameHandler : public IGameCallback
|
||||||
{
|
{
|
||||||
static ui32 QID;
|
static ui32 QID;
|
||||||
//std::set<CCPPObjectScript *> cppscripts; //C++ scripts
|
|
||||||
//std::map<int, std::map<std::string, CObjectScript*> > objscr; //non-C++ scripts
|
|
||||||
|
|
||||||
CVCMIServer *s;
|
CVCMIServer *s;
|
||||||
std::map<int,CConnection*> connections; //player color -> connection to clinet with interface of that player
|
std::map<int,CConnection*> connections; //player color -> connection to clinet with interface of that player
|
||||||
PlayerStatuses states; //player color -> player state
|
PlayerStatuses states; //player color -> player state
|
||||||
std::set<CConnection*> conns;
|
std::set<CConnection*> conns;
|
||||||
|
|
||||||
void changeSecSkill(int ID, ui16 which, int val, bool abs=false);
|
|
||||||
void giveSpells(const CGTownInstance *t, const CGHeroInstance *h);
|
void giveSpells(const CGTownInstance *t, const CGHeroInstance *h);
|
||||||
void moveStack(int stack, int dest);
|
void moveStack(int stack, int dest);
|
||||||
void startBattle(CCreatureSet army1, CCreatureSet army2, int3 tile, CGHeroInstance *hero1, CGHeroInstance *hero2, boost::function<void(BattleResult*)> cb); //use hero=NULL for no hero
|
void startBattle(CCreatureSet army1, CCreatureSet army2, int3 tile, CGHeroInstance *hero1, CGHeroInstance *hero2, boost::function<void(BattleResult*)> cb); //use hero=NULL for no hero
|
||||||
@ -93,6 +89,7 @@ public:
|
|||||||
void setHoverName(int objid, MetaString * name);
|
void setHoverName(int objid, MetaString * name);
|
||||||
void setObjProperty(int objid, int prop, int val);
|
void setObjProperty(int objid, int prop, int val);
|
||||||
void changePrimSkill(int ID, int which, int val, bool abs=false);
|
void changePrimSkill(int ID, int which, int val, bool abs=false);
|
||||||
|
void changeSecSkill(int ID, int which, int val, bool abs=false);
|
||||||
void showInfoDialog(InfoWindow *iw);
|
void showInfoDialog(InfoWindow *iw);
|
||||||
void showYesNoDialog(YesNoDialog *iw, const CFunctionList<void(ui32)> &callback);
|
void showYesNoDialog(YesNoDialog *iw, const CFunctionList<void(ui32)> &callback);
|
||||||
void showSelectionDialog(SelectionDialog *iw, const CFunctionList<void(ui32)> &callback); //returns question id
|
void showSelectionDialog(SelectionDialog *iw, const CFunctionList<void(ui32)> &callback); //returns question id
|
||||||
@ -111,7 +108,7 @@ public:
|
|||||||
void handleConnection(std::set<int> players, CConnection &c);
|
void handleConnection(std::set<int> players, CConnection &c);
|
||||||
template <typename Handler> void serialize(Handler &h, const int version)
|
template <typename Handler> void serialize(Handler &h, const int version)
|
||||||
{
|
{
|
||||||
h & QID & gs & states;
|
h & QID & states;
|
||||||
}
|
}
|
||||||
template <typename T> void applyAndAsk(Query<T> * sel, ui8 player, boost::function<void(ui32)> &callback)
|
template <typename T> void applyAndAsk(Query<T> * sel, ui8 player, boost::function<void(ui32)> &callback)
|
||||||
{
|
{
|
||||||
@ -157,7 +154,7 @@ public:
|
|||||||
gs->apply(info);
|
gs->apply(info);
|
||||||
sendToAllClients(info);
|
sendToAllClients(info);
|
||||||
}
|
}
|
||||||
void run();
|
void run(bool resume);
|
||||||
void newTurn();
|
void newTurn();
|
||||||
|
|
||||||
friend class CVCMIServer;
|
friend class CVCMIServer;
|
||||||
|
@ -3,6 +3,14 @@
|
|||||||
#include <boost/asio.hpp>
|
#include <boost/asio.hpp>
|
||||||
#include "../global.h"
|
#include "../global.h"
|
||||||
#include "../lib/Connection.h"
|
#include "../lib/Connection.h"
|
||||||
|
#include "../hch/CArtHandler.h"
|
||||||
|
#include "../hch/CDefObjInfoHandler.h"
|
||||||
|
#include "../hch/CGeneralTextHandler.h"
|
||||||
|
#include "../hch/CHeroHandler.h"
|
||||||
|
#include "../hch/CTownHandler.h"
|
||||||
|
#include "../hch/CObjectHandler.h"
|
||||||
|
#include "../hch/CBuildingHandler.h"
|
||||||
|
#include "../hch/CSpellHandler.h"
|
||||||
#include "zlib.h"
|
#include "zlib.h"
|
||||||
#ifndef __GNUC__
|
#ifndef __GNUC__
|
||||||
#include <tchar.h>
|
#include <tchar.h>
|
||||||
@ -87,12 +95,12 @@ void CVCMIServer::newGame(CConnection *c)
|
|||||||
i--;
|
i--;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
cc = new CConnection(s,NAME,std::cout);
|
cc = new CConnection(s,NAME);
|
||||||
}
|
}
|
||||||
gh.conns.insert(cc);
|
gh.conns.insert(cc);
|
||||||
}
|
}
|
||||||
|
|
||||||
gh.run();
|
gh.run(false);
|
||||||
}
|
}
|
||||||
void CVCMIServer::start()
|
void CVCMIServer::start()
|
||||||
{
|
{
|
||||||
@ -125,7 +133,7 @@ void CVCMIServer::start()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
tlog0<<"We've accepted someone... " << std::endl;
|
tlog0<<"We've accepted someone... " << std::endl;
|
||||||
CConnection *connection = new CConnection(s,NAME,std::cout);
|
CConnection *connection = new CConnection(s,NAME);
|
||||||
tlog0<<"Got connection!" << std::endl;
|
tlog0<<"Got connection!" << std::endl;
|
||||||
while(!end2)
|
while(!end2)
|
||||||
{
|
{
|
||||||
@ -144,10 +152,68 @@ void CVCMIServer::start()
|
|||||||
case 2:
|
case 2:
|
||||||
newGame(connection);
|
newGame(connection);
|
||||||
break;
|
break;
|
||||||
|
case 3:
|
||||||
|
loadGame(connection);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CVCMIServer::loadGame( CConnection *c )
|
||||||
|
{
|
||||||
|
std::string fname;
|
||||||
|
CGameHandler gh;
|
||||||
|
boost::system::error_code error;
|
||||||
|
ui8 clients;
|
||||||
|
*c >> clients >> fname; //how many clients should be connected - TODO: support more than one
|
||||||
|
|
||||||
|
{
|
||||||
|
char sig[8];
|
||||||
|
CMapHeader dum;
|
||||||
|
|
||||||
|
CLoadFile lf(fname + ".vlgm1");
|
||||||
|
lf >> sig >> dum;
|
||||||
|
tlog0 <<"Reading save signature"<<std::endl;
|
||||||
|
|
||||||
|
lf >> *VLC;
|
||||||
|
tlog0 <<"Reading handlers"<<std::endl;
|
||||||
|
|
||||||
|
lf >> (gh.gs);
|
||||||
|
tlog0 <<"Reading gamestate"<<std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
CLoadFile lf(fname + ".vsgm1");
|
||||||
|
lf >> gh;
|
||||||
|
}
|
||||||
|
|
||||||
|
*c << ui8(0);
|
||||||
|
|
||||||
|
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
|
||||||
|
{
|
||||||
|
tlog3<<"Cannot establish connection - retrying..." << std::endl;
|
||||||
|
i--;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
cc = new CConnection(s,NAME);
|
||||||
|
}
|
||||||
|
gh.conns.insert(cc);
|
||||||
|
}
|
||||||
|
|
||||||
|
gh.run(true);
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef __GNUC__
|
#ifndef __GNUC__
|
||||||
int _tmain(int argc, _TCHAR* argv[])
|
int _tmain(int argc, _TCHAR* argv[])
|
||||||
#else
|
#else
|
||||||
|
@ -29,6 +29,7 @@ public:
|
|||||||
~CVCMIServer();
|
~CVCMIServer();
|
||||||
void setUpConnection(CConnection *c, std::string mapname, si32 checksum);
|
void setUpConnection(CConnection *c, std::string mapname, si32 checksum);
|
||||||
void newGame(CConnection *c);
|
void newGame(CConnection *c);
|
||||||
|
void loadGame(CConnection *c);
|
||||||
void start();
|
void start();
|
||||||
};
|
};
|
||||||
#endif // __CVCMISERVER_H__
|
#endif // __CVCMISERVER_H__
|
||||||
|
Loading…
Reference in New Issue
Block a user