소스 검색

* refactoring

mateuszb 12 년 전
부모
커밋
d03dbf64a6

+ 8 - 8
AI/VCAI/VCAI.cpp

@@ -1279,7 +1279,7 @@ bool VCAI::tryBuildStructure(const CGTownInstance * t, int building, unsigned in
 
 	BOOST_FOREACH(int buildID, toBuild)
 	{
-		int canBuild = cb->canBuildStructure(t, buildID);
+		EBuildingState::EBuildingState canBuild = cb->canBuildStructure(t, buildID);
 		if (canBuild == EBuildingState::HAVE_CAPITAL
 		 || canBuild == EBuildingState::FORBIDDEN
 		 || canBuild == EBuildingState::NO_WATER)
@@ -1297,7 +1297,7 @@ bool VCAI::tryBuildStructure(const CGTownInstance * t, int building, unsigned in
 	{
 		const CBuilding *b = t->town->buildings[buildID];
 
-		int canBuild = cb->canBuildStructure(t, buildID);
+		EBuildingState::EBuildingState canBuild = cb->canBuildStructure(t, buildID);
 		if(canBuild == EBuildingState::ALLOWED)
 		{
 			if(!containsSavedRes(b->resources))
@@ -1962,14 +1962,14 @@ void VCAI::tryRealize(CGoal g)
 		break;
 
 	case COLLECT_RES: //TODO: use piles and mines?
-		if(cb->getResourceAmount(g.resID) >= g.value)
+		if(cb->getResourceAmount(static_cast<Res::ERes>(g.resID)) >= g.value)
 			throw cannotFulfillGoalException("Goal is already fulfilled!");
 
 		if(const CGObjectInstance *obj = cb->getObj(g.objid, false))
 		{
 			if(const IMarket *m = IMarket::castFrom(obj, false))
 			{
-				for (int i = 0; i < ACTUAL_RESOURCE_COUNT; i++)
+				for (Res::ERes i = Res::WOOD; i <= Res::GOLD; vstd::advance(i, 1))
 				{
 					if(i == g.resID) continue;
 					int toGive, toGet;
@@ -1977,7 +1977,7 @@ void VCAI::tryRealize(CGoal g)
 					toGive = toGive * (cb->getResourceAmount(i) / toGive);
 					//TODO trade only as much as needed
 					cb->trade(obj, EMarketMode::RESOURCE_RESOURCE, i, g.resID, toGive);
-					if(cb->getResourceAmount(g.resID) >= g.value)
+					if(cb->getResourceAmount(static_cast<Res::ERes>(g.resID)) >= g.value)
 						return;
 				} 
 
@@ -2814,7 +2814,7 @@ TSubgoal CGoal::whatToDoToAchieve()
 			case EVictoryConditionType::CAPTURECITY:
 				return CGoal(GET_OBJ).setobjid(vc.obj->id);
 			case EVictoryConditionType::GATHERRESOURCE:
-                return CGoal(COLLECT_RES).setresID(vc.objectId).setvalue(vc.count);
+                return CGoal(COLLECT_RES).setresID(static_cast<Res::ERes>(vc.objectId)).setvalue(vc.count);
 				//TODO mines? piles? marketplace?
 				//save?
 				break;
@@ -3168,7 +3168,7 @@ TSubgoal CGoal::whatToDoToAchieve()
 				const IMarket *m = markets.back();
 				//attempt trade at back (best prices)
 				int howManyCanWeBuy = 0;
-				for(int i = 0; i < ACTUAL_RESOURCE_COUNT; i++)
+				for(Res::ERes i = Res::WOOD; i <= Res::GOLD; vstd::advance(i, 1))
 				{
 					if(i == resID) continue;
 					int toGive = -1, toReceive = -1;
@@ -3177,7 +3177,7 @@ TSubgoal CGoal::whatToDoToAchieve()
 					howManyCanWeBuy += toReceive * (cb->getResourceAmount(i) / toGive);
 				}
 
-				if(howManyCanWeBuy + cb->getResourceAmount(resID) >= value)
+				if(howManyCanWeBuy + cb->getResourceAmount(static_cast<Res::ERes>(resID)) >= value)
 				{
 					auto backObj = backOrNull(cb->getVisitableObjs(m->o->visitablePos())); //it'll be a hero if we have one there; otherwise marketplace
 					assert(backObj);

+ 1 - 1
client/AdventureMapClasses.cpp

@@ -758,7 +758,7 @@ void CInfoBar::CVisibleInfo::loadGameStatus()
 	//generate list of allies and enemies
 	for(int i = 0; i < GameConstants::PLAYER_LIMIT; i++)
 	{
-		if(LOCPLINT->cb->getPlayerStatus(i) == PlayerState::INGAME)
+		if(LOCPLINT->cb->getPlayerStatus(i) == EPlayerStatus::INGAME)
 		{
 			if (LOCPLINT->cb->getPlayerRelations(LOCPLINT->playerID, i) != PlayerRelations::ENEMIES)
 				allies.push_back(i);

+ 1 - 1
client/CAdvmapInterface.cpp

@@ -335,7 +335,7 @@ CResDataBar::~CResDataBar()
 void CResDataBar::draw(SDL_Surface * to)
 {
 	blitAt(bg,pos.x,pos.y,to);
-	for (int i=0;i<7;i++)
+	for (auto i=Res::WOOD; i<=Res::GOLD; vstd::advance(i, 1))
 	{
 		std::string text = boost::lexical_cast<std::string>(LOCPLINT->cb->getResourceAmount(i));
 

+ 1 - 1
client/CPlayerInterface.cpp

@@ -2067,7 +2067,7 @@ void CPlayerInterface::gameOver(ui8 player, bool victory )
 
 	else
 	{
-		if(!victory && cb->getPlayerStatus(playerID) == PlayerState::INGAME) //enemy has lost
+		if(!victory && cb->getPlayerStatus(playerID) == EPlayerStatus::INGAME) //enemy has lost
 		{
 			std::string txt = CGI->generaltexth->allTexts[5]; //%s has been vanquished!
 			boost::algorithm::replace_first(txt, "%s", CGI->generaltexth->capColors[player]);

+ 8 - 8
client/GUIClasses.cpp

@@ -1753,7 +1753,7 @@ void CMinorResDataBar::show(SDL_Surface * to)
 void CMinorResDataBar::showAll(SDL_Surface * to)
 {
 	blitAt(bg,pos.x,pos.y,to);
-	for (int i=0;i<7;i++)
+	for (Res::ERes i=Res::WOOD; i<=Res::GOLD; vstd::advance(i, 1))
 	{
 		std::string text = boost::lexical_cast<std::string>(LOCPLINT->cb->getResourceAmount(i));
 
@@ -2361,7 +2361,7 @@ std::vector<int> *CTradeWindow::getItemsIds(bool Left)
 		case PLAYER:
 			ids = new std::vector<int>;
 			for(int i = 0; i < GameConstants::PLAYER_LIMIT; i++)
-				if(i != LOCPLINT->playerID && LOCPLINT->cb->getPlayerStatus(i) == PlayerState::INGAME)
+				if(i != LOCPLINT->playerID && LOCPLINT->cb->getPlayerStatus(i) == EPlayerStatus::INGAME)
 					ids->push_back(i);
 			break;
 
@@ -2426,7 +2426,7 @@ void CTradeWindow::initSubs(bool Left)
 				t->subtitle = boost::lexical_cast<std::string>(hero->getStackCount(t->serial));
 				break;
 			case RESOURCE:
-				t->subtitle = boost::lexical_cast<std::string>(LOCPLINT->cb->getResourceAmount(t->serial));
+				t->subtitle = boost::lexical_cast<std::string>(LOCPLINT->cb->getResourceAmount(static_cast<Res::ERes>(t->serial)));
 				break;
 			}
 		}
@@ -2756,7 +2756,7 @@ void CMarketplaceWindow::selectionChanged(bool side)
 		{
 			int newAmount = -1;
 			if(itemsType[1] == RESOURCE)
-				newAmount = LOCPLINT->cb->getResourceAmount(soldItemId);
+				newAmount = LOCPLINT->cb->getResourceAmount(static_cast<Res::ERes>(soldItemId));
 			else if(itemsType[1] ==  CREATURE)
 				newAmount = hero->getStackCount(hLeft->serial) - (hero->Slots().size() == 1  &&  hero->needsLastStack());
 			else
@@ -2769,7 +2769,7 @@ void CMarketplaceWindow::selectionChanged(bool side)
 		}
 		else if(itemsType[1] == RESOURCE) //buying -> check if we can afford transaction
 		{
-			deal->block(LOCPLINT->cb->getResourceAmount(soldItemId) < r1);
+			deal->block(LOCPLINT->cb->getResourceAmount(static_cast<Res::ERes>(soldItemId)) < r1);
 		}
 		else
 			deal->block(false);
@@ -3672,7 +3672,7 @@ CTavernWindow::CTavernWindow(const CGObjectInstance *TavernObj):
 	recruit = new CAdventureMapButton("", "", boost::bind(&CTavernWindow::recruitb, this), 272, 355, "TPTAV01.DEF", SDLK_RETURN);
 	thiefGuild = new CAdventureMapButton(CGI->generaltexth->tavernInfo[5],"", boost::bind(&CTavernWindow::thievesguildb, this), 22, 428, "TPTAV02.DEF", SDLK_t);
 
-	if(LOCPLINT->cb->getResourceAmount(6) < 2500) //not enough gold
+	if(LOCPLINT->cb->getResourceAmount(Res::GOLD) < 2500) //not enough gold
 	{
 		recruit->hoverTexts[0] = CGI->generaltexth->tavernInfo[0]; //Cannot afford a Hero
 		recruit->block(2);
@@ -5204,7 +5204,7 @@ CShipyardWindow::CShipyardWindow(const std::vector<si32> &cost, int state, int b
 	build = new CAdventureMapButton(CGI->generaltexth->allTexts[598], "", boost::bind(&CShipyardWindow::close, this), 42, 312, "IBUY30", SDLK_RETURN);
 	build->callback += onBuy;
 
-	for(size_t i = 0; i < cost.size(); i++)
+	for(Res::ERes i = Res::WOOD; i <= Res::GOLD; vstd::advance(i, 1))
 	{
 		if(cost[i] > LOCPLINT->cb->getResourceAmount(i))
 		{
@@ -5384,7 +5384,7 @@ void CUniversityWindow::CItem::clickLeft(tribool down, bool previousState)
 	{
 		if ( state() != 2 )
 			return;
-		CUnivConfirmWindow *win = new CUnivConfirmWindow(parent, ID, LOCPLINT->cb->getResourceAmount(6) >= 2000);
+		CUnivConfirmWindow *win = new CUnivConfirmWindow(parent, ID, LOCPLINT->cb->getResourceAmount(Res::GOLD) >= 2000);
 		GH.pushInt(win);
 	}
 }

+ 3 - 3
lib/CBattleCallback.cpp

@@ -299,7 +299,7 @@ int CBattleInfoEssentials::battleCastSpells(ui8 side) const
 	return getBattle()->castSpells[side];
 }
 
-ESpellCastProblem::ESpellCastProblem CBattleInfoCallback::battleCanCastSpell(int player, ECastingMode::ECastingMode mode) const
+ESpellCastProblem::ESpellCastProblem CBattleInfoCallback::battleCanCastSpell(TPlayerColor player, ECastingMode::ECastingMode mode) const
 {
 	RETURN_IF_NOT_BATTLE(ESpellCastProblem::INVALID);
 	const ui8 side = playerToSide(player);
@@ -1535,7 +1535,7 @@ ESpellCastProblem::ESpellCastProblem CBattleInfoCallback::battleIsImmune(const C
 	return ESpellCastProblem::OK;
 }
 
-ESpellCastProblem::ESpellCastProblem CBattleInfoCallback::battleCanCastThisSpell( int player, const CSpell * spell, ECastingMode::ECastingMode mode ) const
+ESpellCastProblem::ESpellCastProblem CBattleInfoCallback::battleCanCastThisSpell( TPlayerColor player, const CSpell * spell, ECastingMode::ECastingMode mode ) const
 {
 	RETURN_IF_NOT_BATTLE(ESpellCastProblem::INVALID);
 	const ui8 side = playerToSide(player);
@@ -1735,7 +1735,7 @@ ui32 CBattleInfoCallback::battleGetSpellCost(const CSpell * sp, const CGHeroInst
 	return ret - manaReduction + manaIncrease;
 }
 
-ESpellCastProblem::ESpellCastProblem CBattleInfoCallback::battleCanCastThisSpellHere( int player, const CSpell * spell, ECastingMode::ECastingMode mode, BattleHex dest ) const
+ESpellCastProblem::ESpellCastProblem CBattleInfoCallback::battleCanCastThisSpellHere( TPlayerColor player, const CSpell * spell, ECastingMode::ECastingMode mode, BattleHex dest ) const
 {
 	RETURN_IF_NOT_BATTLE(ESpellCastProblem::INVALID);
 	ESpellCastProblem::ESpellCastProblem moreGeneralProblem = battleCanCastThisSpell(player, spell, mode);

+ 3 - 3
lib/CBattleCallback.h

@@ -250,9 +250,9 @@ public:
 	//*** MAGIC 
 	si8 battleMaxSpellLevel() const; //calculates minimum spell level possible to be cast on battlefield - takes into account artifacts of both heroes; if no effects are set, 0 is returned
 	ui32 battleGetSpellCost(const CSpell * sp, const CGHeroInstance * caster) const; //returns cost of given spell
-	ESpellCastProblem::ESpellCastProblem battleCanCastSpell(int player, ECastingMode::ECastingMode mode) const; //returns true if there are no general issues preventing from casting a spell
-	ESpellCastProblem::ESpellCastProblem battleCanCastThisSpell(int player, const CSpell * spell, ECastingMode::ECastingMode mode) const; //checks if given player can cast given spell
-	ESpellCastProblem::ESpellCastProblem battleCanCastThisSpellHere(int player, const CSpell * spell, ECastingMode::ECastingMode mode, BattleHex dest) const; //checks if given player can cast given spell at given tile in given mode
+	ESpellCastProblem::ESpellCastProblem battleCanCastSpell(TPlayerColor player, ECastingMode::ECastingMode mode) const; //returns true if there are no general issues preventing from casting a spell
+	ESpellCastProblem::ESpellCastProblem battleCanCastThisSpell(TPlayerColor player, const CSpell * spell, ECastingMode::ECastingMode mode) const; //checks if given player can cast given spell
+	ESpellCastProblem::ESpellCastProblem battleCanCastThisSpellHere(TPlayerColor player, const CSpell * spell, ECastingMode::ECastingMode mode, BattleHex dest) const; //checks if given player can cast given spell at given tile in given mode
 	ESpellCastProblem::ESpellCastProblem battleCanCreatureCastThisSpell(const CSpell * spell, BattleHex destination) const; //determines if creature can cast a spell here
 	std::vector<BattleHex> battleGetPossibleTargets(int player, const CSpell *spell) const;
 	ui32 calculateSpellBonus(ui32 baseDamage, const CSpell * sp, const CGHeroInstance * caster, const CStack * affectedCreature) const;

+ 2 - 2
lib/CGameState.cpp

@@ -2352,7 +2352,7 @@ ui8 CGameState::checkForStandardWin() const
 	TPlayerColor supposedWinner = 255, winnerTeam = 255;
 	for(auto i = players.begin(); i != players.end(); i++)
 	{
-		if(i->second.status == PlayerState::INGAME && i->first < GameConstants::PLAYER_LIMIT)
+		if(i->second.status == EPlayerStatus::INGAME && i->first < GameConstants::PLAYER_LIMIT)
 		{
 			if(supposedWinner == 255)
 			{
@@ -2760,7 +2760,7 @@ void CGPath::convert( ui8 mode )
 
 PlayerState::PlayerState()
  : color(-1), currentSelection(0xffffffff), enteredWinningCheatCode(0),
-   enteredLosingCheatCode(0), status(INGAME), daysWithoutCastle(0)
+   enteredLosingCheatCode(0), status(EPlayerStatus::INGAME), daysWithoutCastle(0)
 {
 	setNodeType(PLAYER);
 }

+ 3 - 4
lib/CGameState.h

@@ -163,9 +163,8 @@ struct DLL_LINKAGE SThievesGuildInfo
 struct DLL_LINKAGE PlayerState : public CBonusSystemNode
 {
 public:
-	enum EStatus {WRONG = -1, INGAME, LOSER, WINNER};
 	TPlayerColor color;
-	ui8 human; //true if human controlled player, false for AI
+	bool human; //true if human controlled player, false for AI
 	ui32 currentSelection; //id of hero/town, 0xffffffff if none
 	ui8 team;
 	TResources resources;
@@ -175,8 +174,8 @@ public:
 	std::vector<ConstTransitivePtr<CGDwelling> > dwellings; //used for town growth
 	std::vector<QuestInfo> quests; //store info about all received quests
 
-	ui8 enteredWinningCheatCode, enteredLosingCheatCode; //if true, this player has entered cheat codes for loss / victory
-	EStatus status;
+	bool enteredWinningCheatCode, enteredLosingCheatCode; //if true, this player has entered cheat codes for loss / victory
+	EPlayerStatus::EStatus status;
 	ui8 daysWithoutCastle;
 
 	PlayerState();

+ 7 - 7
lib/CObjectHandler.cpp

@@ -442,7 +442,7 @@ void CGObjectInstance::hideTiles(int ourplayer, int radius) const
 		if ( !vstd::contains(i->second.players, ourplayer ))//another team
 		{
 			for (auto j = i->second.players.begin(); j != i->second.players.end(); j++)
-				if ( cb->getPlayer(*j)->status == PlayerState::INGAME )//seek for living player (if any)
+				if ( cb->getPlayer(*j)->status == EPlayerStatus::INGAME )//seek for living player (if any)
 				{
 					FoWChange fw;
 					fw.mode = 0;
@@ -2694,7 +2694,7 @@ void CGVisitableOPH::onNAHeroVisit(int heroID, bool alreadyVisited) const
 				}
 				else
 				{
-					ui32 res;
+					Res::ERes res;
 					si32 resval;
 					if(ttype==1)
 					{
@@ -2748,7 +2748,7 @@ void CGVisitableOPH::onNAHeroVisit(int heroID, bool alreadyVisited) const
 		case Obj::SCHOOL_OF_WAR:
 			{
 				int skill = (ID==Obj::SCHOOL_OF_MAGIC ? 2 : 0);
-				if(cb->getResource(cb->getOwner(heroID),6) < 1000) //not enough resources
+				if(cb->getResource(cb->getOwner(heroID), Res::GOLD) < 1000) //not enough resources
 				{
 					showInfoDialog(heroID,ot+2,sound);
 				}
@@ -3259,7 +3259,7 @@ void CGCreature::joinDecision(const CGHeroInstance *h, int cost, ui32 accept) co
 	}
 	else //accepted
 	{
-		if (cb->getResource(h->tempOwner,6) < cost) //player don't have enough gold!
+		if (cb->getResource(h->tempOwner, Res::GOLD) < cost) //player don't have enough gold!
 		{
 			InfoWindow iw;
 			iw.player = h->tempOwner;
@@ -4154,7 +4154,7 @@ bool CQuest::checkQuest (const CGHeroInstance * h) const
 			}
 			return true;
 		case MISSION_RESOURCES:
-			for (int i = 0; i < 7; ++i) //including Mithril ?
+			for (Res::ERes i = Res::WOOD; i <= Res::GOLD; vstd::advance(i, +1)) //including Mithril ?
 			{	//Quest has no direct access to callback
 				if (h->cb->getResource (h->tempOwner, i) < m7resources[i])
 					return false;
@@ -6013,7 +6013,7 @@ void CBank::newTurn() const
 			cb->setObjProperty (id, 11, 1); //daycounter++
 	}
 }
-bool CBank::wasVisited (ui8 player) const
+bool CBank::wasVisited (TPlayerColor player) const
 {
 	return !bc;
 }
@@ -6642,7 +6642,7 @@ void CCartographer::onHeroVisit( const CGHeroInstance * h ) const
 {
 	if (!wasVisited (h->getOwner()) ) //if hero has not visited yet this cartographer
 	{
-		if (cb->getResource(h->tempOwner, 6) >= 1000) //if he can afford a map
+		if (cb->getResource(h->tempOwner, Res::GOLD) >= 1000) //if he can afford a map
 		{
 			//ask if he wants to buy one
 			int text=0;

+ 1 - 1
lib/CObjectHandler.h

@@ -1210,7 +1210,7 @@ class DLL_LINKAGE CBank : public CArmedInstance
 	void initialize() const;
 	void reset(ui16 var1);
 	void newTurn() const override;
-	bool wasVisited (ui8 player) const override;
+	bool wasVisited (TPlayerColor player) const override;
 	void onHeroVisit(const CGHeroInstance * h) const override;
 
 	virtual void fightGuards (const CGHeroInstance *h, ui32 accept) const;

+ 6 - 1
lib/GameConstants.h

@@ -195,7 +195,7 @@ namespace EBuildingState
 	enum EBuildingState
 	{
 		HAVE_CAPITAL, NO_WATER, FORBIDDEN, ADD_MAGES_GUILD, ALREADY_PRESENT, CANT_BUILD_TODAY,
-		NO_RESOURCES, ALLOWED, PREREQUIRES, BUILDING_ERROR
+		NO_RESOURCES, ALLOWED, PREREQUIRES, BUILDING_ERROR, TOWN_NOT_OWNED
 	};
 }
 
@@ -479,6 +479,11 @@ namespace BFieldType
 	};
 }
 
+namespace EPlayerStatus
+{
+	enum EStatus {WRONG = -1, INGAME, LOSER, WINNER};
+}
+
 namespace PlayerRelations
 {
 	enum PlayerRelations {ENEMIES, ALLIES, SAME_PLAYER};

+ 11 - 11
lib/IGameCallback.cpp

@@ -48,7 +48,7 @@ int CGameInfoCallback::getOwner(int heroID) const
 	return gs->map->objects[heroID]->tempOwner;
 }
 
-int CGameInfoCallback::getResource(int Player, int which) const
+int CGameInfoCallback::getResource(TPlayerColor Player, Res::ERes which) const
 {
 	const PlayerState *p = getPlayer(Player);
 	ERROR_RET_VAL_IF(!p, "No player info!", -1);
@@ -56,7 +56,7 @@ int CGameInfoCallback::getResource(int Player, int which) const
 	return p->resources[which];
 }
 
-const CGHeroInstance* CGameInfoCallback::getSelectedHero( int Player ) const
+const CGHeroInstance* CGameInfoCallback::getSelectedHero( TPlayerColor Player ) const
 {
 	const PlayerState *p = getPlayer(Player);
 	ERROR_RET_VAL_IF(!p, "No player info!", NULL);
@@ -68,7 +68,7 @@ const CGHeroInstance* CGameInfoCallback::getSelectedHero() const
 	return getSelectedHero(gs->currentPlayer);
 }
 
-const PlayerSettings * CGameInfoCallback::getPlayerSettings(int color) const
+const PlayerSettings * CGameInfoCallback::getPlayerSettings(TPlayerColor color) const
 {
 	return &gs->scenarioOps->getIthPlayersSettings(color);
 }
@@ -224,7 +224,7 @@ inline TerrainTile * CNonConstInfoCallback::getTile( int3 pos )
 	return &gs->map->getTile(pos);
 }
 
-const PlayerState * CGameInfoCallback::getPlayer(int color, bool verbose) const
+const PlayerState * CGameInfoCallback::getPlayer(TPlayerColor color, bool verbose) const
 {
 	ERROR_VERBOSE_OR_NOT_RET_VAL_IF(!hasAccess(color), verbose, "Cannot access player " << color << "info!", NULL);
 	ERROR_VERBOSE_OR_NOT_RET_VAL_IF(!vstd::contains(gs->players,color), verbose, "Cannot find player " << color << "info!", NULL);
@@ -524,9 +524,9 @@ const TerrainTile * CGameInfoCallback::getTile( int3 tile, bool verbose) const
 	return &gs->map->getTile(tile);
 }
 
-int CGameInfoCallback::canBuildStructure( const CGTownInstance *t, int ID )
+EBuildingState::EBuildingState CGameInfoCallback::canBuildStructure( const CGTownInstance *t, int ID )
 {
-	ERROR_RET_VAL_IF(!canGetFullInfo(t), "Town is not owned!", -1);
+	ERROR_RET_VAL_IF(!canGetFullInfo(t), "Town is not owned!", EBuildingState::TOWN_NOT_OWNED);
 
 	CBuilding * pom = t->town->buildings[ID];
 
@@ -561,7 +561,7 @@ int CGameInfoCallback::canBuildStructure( const CGTownInstance *t, int ID )
 	if (notAllBuilt)
 		return EBuildingState::PREREQUIRES;
 
-	if(ID == 13) //capitol
+	if(ID == EBuilding::CAPITOL)
 	{
 		const PlayerState *ps = getPlayer(t->tempOwner);
 		if(ps)
@@ -575,7 +575,7 @@ int CGameInfoCallback::canBuildStructure( const CGTownInstance *t, int ID )
 			}
 		}
 	}
-	else if(ID == 6) //shipyard
+	else if(ID == EBuilding::SHIPYARD)
 	{
 		const TerrainTile *tile = getTile(t->bestLocation(), false);
 		
@@ -630,10 +630,10 @@ bool CGameInfoCallback::hasAccess(int playerId) const
 	return player < 0 || gs->getPlayerRelations( playerId, player ) != PlayerRelations::ENEMIES;
 }
 
-int CGameInfoCallback::getPlayerStatus(int player) const
+EPlayerStatus::EStatus CGameInfoCallback::getPlayerStatus(TPlayerColor player) const
 {
 	const PlayerState *ps = gs->getPlayer(player, false);
-	ERROR_RET_VAL_IF(!ps, "No such player!", -1);
+	ERROR_RET_VAL_IF(!ps, "No such player!", EPlayerStatus::WRONG);
 
 	return ps->status;
 }
@@ -836,7 +836,7 @@ const CGTownInstance* CPlayerSpecificInfoCallback::getTownBySerial(int serialId)
 	return p->towns[serialId];
 }
 
-int CPlayerSpecificInfoCallback::getResourceAmount(int type) const
+int CPlayerSpecificInfoCallback::getResourceAmount(Res::ERes type) const
 {
 	//boost::shared_lock<boost::shared_mutex> lock(*gs->mx);
 	ERROR_RET_VAL_IF(player == -1, "Applicable only for player callbacks", -1);

+ 8 - 8
lib/IGameCallback.h

@@ -80,15 +80,15 @@ public:
 	bool isAllowed(int type, int id); //type: 0 - spell; 1- artifact; 2 - secondary skill
 
 	//player
-	const PlayerState * getPlayer(int color, bool verbose = true) const;
-	int getResource(int Player, int which) const;
+	const PlayerState * getPlayer(TPlayerColor color, bool verbose = true) const;
+	int getResource(TPlayerColor Player, Res::ERes which) const;
 	bool isVisible(int3 pos) const;
 	PlayerRelations::PlayerRelations getPlayerRelations(TPlayerColor color1, TPlayerColor color2) const;
 	void getThievesGuildInfo(SThievesGuildInfo & thi, const CGObjectInstance * obj); //get thieves' guild info obtainable while visiting given object
-	int getPlayerStatus(int player) const; //-1 if no such player
+	EPlayerStatus::EStatus getPlayerStatus(TPlayerColor player) const; //-1 if no such player
 	int getCurrentPlayer() const; //player that currently makes move // TODO synchronous turns
 	virtual int getLocalPlayer() const; //player that is currently owning given client (if not a client, then returns current player)
-	const PlayerSettings * getPlayerSettings(int color) const;
+	const PlayerSettings * getPlayerSettings(TPlayerColor color) const;
 
 
 	//armed object
@@ -101,7 +101,7 @@ public:
 	bool getHeroInfo(const CGObjectInstance *hero, InfoAboutHero &dest) const;
 	int getSpellCost(const CSpell * sp, const CGHeroInstance * caster) const; //when called during battle, takes into account creatures' spell cost reduction
 	int estimateSpellDamage(const CSpell * sp, const CGHeroInstance * hero) const; //estimates damage of given spell; returns 0 if spell causes no dmg
-	const CGHeroInstance* getSelectedHero(int player) const; //NULL if no hero is selected
+	const CGHeroInstance* getSelectedHero(TPlayerColor player) const; //NULL if no hero is selected
 	const CGHeroInstance* getSelectedHero() const; //of current (active) player
 
 	//objects
@@ -127,7 +127,7 @@ public:
 	const CGTownInstance * getTownInfo(int val, bool mode)const; //mode = 0 -> val = player town serial; mode = 1 -> val = object id (serial)
 	std::vector<const CGHeroInstance *> getAvailableHeroes(const CGObjectInstance * townOrTavern) const; //heroes that can be recruited
 	std::string getTavernGossip(const CGObjectInstance * townOrTavern) const; 
-	int canBuildStructure(const CGTownInstance *t, int ID);//// 0 - no more than one capitol, 1 - lack of water, 2 - forbidden, 3 - Add another level to Mage Guild, 4 - already built, 5 - cannot build, 6 - cannot afford, 7 - build, 8 - lack of requirements
+	EBuildingState::EBuildingState canBuildStructure(const CGTownInstance *t, int ID);//// 0 - no more than one capitol, 1 - lack of water, 2 - forbidden, 3 - Add another level to Mage Guild, 4 - already built, 5 - cannot build, 6 - cannot afford, 7 - build, 8 - lack of requirements
 	std::set<int> getBuildingRequiments(const CGTownInstance *t, int ID);
 	virtual bool getTownInfo(const CGObjectInstance *town, InfoAboutTown &dest) const;
 	const CTown *getNativeTown(int color) const;
@@ -136,7 +136,7 @@ public:
 	const TeamState *getTeam(ui8 teamID) const;
 	const TeamState *getPlayerTeam(ui8 color) const;
 	std::set<int> getBuildingRequiments(const CGTownInstance *t, int ID) const;
-	int canBuildStructure(const CGTownInstance *t, int ID) const;// 0 - no more than one capitol, 1 - lack of water, 2 - forbidden, 3 - Add another level to Mage Guild, 4 - already built, 5 - cannot build, 6 - cannot afford, 7 - build, 8 - lack of requirements
+	EBuildingState::EBuildingState canBuildStructure(const CGTownInstance *t, int ID) const;// 0 - no more than one capitol, 1 - lack of water, 2 - forbidden, 3 - Add another level to Mage Guild, 4 - already built, 5 - cannot build, 6 - cannot afford, 7 - build, 8 - lack of requirements
 };
 
 
@@ -157,7 +157,7 @@ public:
 	std::vector <const CGObjectInstance * > getMyObjects() const; //returns all objects flagged by belonging player
 	std::vector <QuestInfo> getMyQuests() const;
 
-	int getResourceAmount(int type)const;
+	int getResourceAmount(Res::ERes type) const;
 	TResources getResourceAmount() const;
 	const std::vector< std::vector< std::vector<ui8> > > & getVisibilityMap()const; //returns visibility map 
 	const PlayerSettings * getPlayerSettings(int color) const;

+ 1 - 1
lib/NetPacksLib.cpp

@@ -248,7 +248,7 @@ DLL_LINKAGE void ChangeObjPos::applyGs( CGameState *gs )
 DLL_LINKAGE void PlayerEndsGame::applyGs( CGameState *gs )
 {
 	PlayerState *p = gs->getPlayer(player);
-	p->status = victory ? PlayerState::WINNER : PlayerState::LOSER;
+	p->status = victory ? EPlayerStatus::WINNER : EPlayerStatus::LOSER;
 }
 
 DLL_LINKAGE void RemoveBonus::applyGs( CGameState *gs )

+ 1 - 1
server/CGameHandler.cpp

@@ -3162,7 +3162,7 @@ bool CGameHandler::transformInUndead(const IMarket *market, const CGHeroInstance
 bool CGameHandler::sendResources(ui32 val, TPlayerColor player, Res::ERes r1, TPlayerColor r2)
 {
 	const PlayerState *p2 = gs->getPlayer(r2, false);
-	if(!p2  ||  p2->status != PlayerState::INGAME)
+	if(!p2  ||  p2->status != EPlayerStatus::INGAME)
 	{
 		complain("Dest player must be in game!");
 		return false;