|  | @@ -2772,14 +2772,14 @@ bool CGameHandler::recruitCreatures(ObjectInstanceID objid, ObjectInstanceID dst
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		switch(crid)
 |  |  		switch(crid)
 | 
											
												
													
														|  |  		{
 |  |  		{
 | 
											
												
													
														|  | -		case 146:
 |  | 
 | 
											
												
													
														|  | -			giveHeroNewArtifact(h, VLC->arth->artifacts[4], ArtifactPosition::MACH1);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		case CreatureID::BALLISTA:
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(h, VLC->arth->artifacts[ArtifactID::BALLISTA], ArtifactPosition::MACH1);
 | 
											
												
													
														|  |  			break;
 |  |  			break;
 | 
											
												
													
														|  | -		case 147:
 |  | 
 | 
											
												
													
														|  | -			giveHeroNewArtifact(h, VLC->arth->artifacts[6], ArtifactPosition::MACH3);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		case CreatureID::FIRST_AID_TENT:
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(h, VLC->arth->artifacts[ArtifactID::FIRST_AID_TENT], ArtifactPosition::MACH3);
 | 
											
												
													
														|  |  			break;
 |  |  			break;
 | 
											
												
													
														|  | -		case 148:
 |  | 
 | 
											
												
													
														|  | -			giveHeroNewArtifact(h, VLC->arth->artifacts[5], ArtifactPosition::MACH2);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		case CreatureID::AMMO_CART:
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(h, VLC->arth->artifacts[ArtifactID::AMMO_CART], ArtifactPosition::MACH2);
 | 
											
												
													
														|  |  			break;
 |  |  			break;
 | 
											
												
													
														|  |  		default:
 |  |  		default:
 | 
											
												
													
														|  |  			complain("This war machine cannot be recruited!");
 |  |  			complain("This war machine cannot be recruited!");
 | 
											
										
											
												
													
														|  | @@ -2998,7 +2998,7 @@ bool CGameHandler::assembleArtifacts (ObjectInstanceID heroID, ArtifactPosition
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if(assemble)
 |  |  	if(assemble)
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  | -		CArtifact *combinedArt = VLC->arth->artifacts.at(assembleTo);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		CArtifact *combinedArt = VLC->arth->artifacts[assembleTo];
 | 
											
												
													
														|  |  		if(!combinedArt->constituents)
 |  |  		if(!combinedArt->constituents)
 | 
											
												
													
														|  |  			COMPLAIN_RET("assembleArtifacts: Artifact being attempted to assemble is not a combined artifacts!");
 |  |  			COMPLAIN_RET("assembleArtifacts: Artifact being attempted to assemble is not a combined artifacts!");
 | 
											
												
													
														|  |  		if(!vstd::contains(destArtifact->assemblyPossibilities(hero), combinedArt))
 |  |  		if(!vstd::contains(destArtifact->assemblyPossibilities(hero), combinedArt))
 | 
											
										
											
												
													
														|  | @@ -3042,7 +3042,7 @@ bool CGameHandler::buyArtifact( ObjectInstanceID hid, ArtifactID aid )
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if(aid < 7  &&  aid > 3) //war machine
 |  |  	else if(aid < 7  &&  aid > 3) //war machine
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  | -		int price = VLC->arth->artifacts.at(aid)->price;
 |  | 
 | 
											
												
													
														|  | 
 |  | +		int price = VLC->arth->artifacts[aid]->price;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		if(( hero->getArt(ArtifactPosition(9+aid)) && complain("Hero already has this machine!"))
 |  |  		if(( hero->getArt(ArtifactPosition(9+aid)) && complain("Hero already has this machine!"))
 | 
											
												
													
														|  |  		 || (gs->getPlayer(hero->getOwner())->resources.at(Res::GOLD) < price && complain("Not enough gold!")))
 |  |  		 || (gs->getPlayer(hero->getOwner())->resources.at(Res::GOLD) < price && complain("Not enough gold!")))
 | 
											
										
											
												
													
														|  | @@ -3053,7 +3053,7 @@ bool CGameHandler::buyArtifact( ObjectInstanceID hid, ArtifactID aid )
 | 
											
												
													
														|  |  		 || ((town->hasBuilt(BuildingID::BALLISTA_YARD, ETownType::STRONGHOLD)) && aid == ArtifactID::BALLISTA))
 |  |  		 || ((town->hasBuilt(BuildingID::BALLISTA_YARD, ETownType::STRONGHOLD)) && aid == ArtifactID::BALLISTA))
 | 
											
												
													
														|  |  		{
 |  |  		{
 | 
											
												
													
														|  |  			giveResource(hero->getOwner(),Res::GOLD,-price);
 |  |  			giveResource(hero->getOwner(),Res::GOLD,-price);
 | 
											
												
													
														|  | -			giveHeroNewArtifact(hero, VLC->arth->artifacts.at(aid), ArtifactPosition(9+aid));
 |  | 
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(hero, VLC->arth->artifacts[aid], ArtifactPosition(9+aid));
 | 
											
												
													
														|  |  			return true;
 |  |  			return true;
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  |  		else
 |  |  		else
 | 
											
										
											
												
													
														|  | @@ -3110,7 +3110,7 @@ bool CGameHandler::buyArtifact(const IMarket *m, const CGHeroInstance *h, Res::E
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	sendAndApply(&saa);
 |  |  	sendAndApply(&saa);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	giveHeroNewArtifact(h, VLC->arth->artifacts.at(aid), ArtifactPosition::FIRST_AVAILABLE);
 |  | 
 | 
											
												
													
														|  | 
 |  | +	giveHeroNewArtifact(h, VLC->arth->artifacts[aid], ArtifactPosition::FIRST_AVAILABLE);
 | 
											
												
													
														|  |  	return true;
 |  |  	return true;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -3962,7 +3962,7 @@ void CGameHandler::playerMessage( PlayerColor player, const std::string &message
 | 
											
												
													
														|  |  		sm.absolute = true;
 |  |  		sm.absolute = true;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		if(!h->hasSpellbook()) //hero doesn't have spellbook
 |  |  		if(!h->hasSpellbook()) //hero doesn't have spellbook
 | 
											
												
													
														|  | -			giveHeroNewArtifact(h, VLC->arth->artifacts.at(0), ArtifactPosition::SPELLBOOK); //give spellbook
 |  | 
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(h, VLC->arth->artifacts[ArtifactID::SPELLBOOK], ArtifactPosition::SPELLBOOK); //give spellbook
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		sendAndApply(&sm);
 |  |  		sendAndApply(&sm);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
										
											
												
													
														|  | @@ -4015,18 +4015,18 @@ void CGameHandler::playerMessage( PlayerColor player, const std::string &message
 | 
											
												
													
														|  |  		if(!hero) return;
 |  |  		if(!hero) return;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		if(!hero->getArt(ArtifactPosition::MACH1))
 |  |  		if(!hero->getArt(ArtifactPosition::MACH1))
 | 
											
												
													
														|  | -			giveHeroNewArtifact(hero, VLC->arth->artifacts.at(4), ArtifactPosition::MACH1);
 |  | 
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(hero, VLC->arth->artifacts[ArtifactID::BALLISTA], ArtifactPosition::MACH1);
 | 
											
												
													
														|  |  		if(!hero->getArt(ArtifactPosition::MACH2))
 |  |  		if(!hero->getArt(ArtifactPosition::MACH2))
 | 
											
												
													
														|  | -			giveHeroNewArtifact(hero, VLC->arth->artifacts.at(5), ArtifactPosition::MACH2);
 |  | 
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(hero, VLC->arth->artifacts[ArtifactID::AMMO_CART], ArtifactPosition::MACH2);
 | 
											
												
													
														|  |  		if(!hero->getArt(ArtifactPosition::MACH3))
 |  |  		if(!hero->getArt(ArtifactPosition::MACH3))
 | 
											
												
													
														|  | -			giveHeroNewArtifact(hero, VLC->arth->artifacts.at(6), ArtifactPosition::MACH3);
 |  | 
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(hero, VLC->arth->artifacts[ArtifactID::FIRST_AID_TENT], ArtifactPosition::MACH3);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (message == "vcmiforgeofnoldorking") //hero gets all artifacts except war machines, spell scrolls and spell book
 |  |  	else if (message == "vcmiforgeofnoldorking") //hero gets all artifacts except war machines, spell scrolls and spell book
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		CGHeroInstance *hero = gs->getHero(currObj);
 |  |  		CGHeroInstance *hero = gs->getHero(currObj);
 | 
											
												
													
														|  |  		if(!hero) return;
 |  |  		if(!hero) return;
 | 
											
												
													
														|  |  		for (int g = 7; g < VLC->arth->artifacts.size(); ++g) //including artifacts from mods
 |  |  		for (int g = 7; g < VLC->arth->artifacts.size(); ++g) //including artifacts from mods
 | 
											
												
													
														|  | -			giveHeroNewArtifact(hero, VLC->arth->artifacts.at(g), ArtifactPosition::PRE_FIRST);
 |  | 
 | 
											
												
													
														|  | 
 |  | +			giveHeroNewArtifact(hero, VLC->arth->artifacts[g], ArtifactPosition::PRE_FIRST);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if(message == "vcmiglorfindel") //selected hero gains a new level
 |  |  	else if(message == "vcmiglorfindel") //selected hero gains a new level
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
										
											
												
													
														|  | @@ -4900,14 +4900,14 @@ bool CGameHandler::dig( const CGHeroInstance *h )
 | 
											
												
													
														|  |  	if(gs->map->grailPos == h->getPosition())
 |  |  	if(gs->map->grailPos == h->getPosition())
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		iw.text.addTxt(MetaString::GENERAL_TXT, 58); //"Congratulations! After spending many hours digging here, your hero has uncovered the "
 |  |  		iw.text.addTxt(MetaString::GENERAL_TXT, 58); //"Congratulations! After spending many hours digging here, your hero has uncovered the "
 | 
											
												
													
														|  | -		iw.text.addTxt(MetaString::ART_NAMES, 2);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		iw.text.addTxt(MetaString::ART_NAMES, ArtifactID::GRAIL);
 | 
											
												
													
														|  |  		iw.soundID = soundBase::ULTIMATEARTIFACT;
 |  |  		iw.soundID = soundBase::ULTIMATEARTIFACT;
 | 
											
												
													
														|  | -		giveHeroNewArtifact(h, VLC->arth->artifacts.at(2), ArtifactPosition::PRE_FIRST); //give grail
 |  | 
 | 
											
												
													
														|  | 
 |  | +		giveHeroNewArtifact(h, VLC->arth->artifacts[ArtifactID::GRAIL], ArtifactPosition::PRE_FIRST); //give grail
 | 
											
												
													
														|  |  		sendAndApply(&iw);
 |  |  		sendAndApply(&iw);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		iw.soundID = soundBase::invalid;
 |  |  		iw.soundID = soundBase::invalid;
 | 
											
												
													
														|  |  		iw.text.clear();
 |  |  		iw.text.clear();
 | 
											
												
													
														|  | -		iw.text.addTxt(MetaString::ART_DESCR, 2);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		iw.text.addTxt(MetaString::ART_DESCR, ArtifactID::GRAIL);
 | 
											
												
													
														|  |  		sendAndApply(&iw);
 |  |  		sendAndApply(&iw);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else
 |  |  	else
 |