|  | @@ -3174,7 +3174,7 @@ bool CQuest::checkQuest (const CGHeroInstance * h) const
 | 
	
		
			
				|  |  |  			return true;
 | 
	
		
			
				|  |  |  			break;
 | 
	
		
			
				|  |  |  		case MISSION_KILL_HERO:
 | 
	
		
			
				|  |  | -			if (h->cb->getHero (m13489val)) //first we must check if the hero was ever alive
 | 
	
		
			
				|  |  | +			if (h->cb->gameState()->map->heroesToBeat[m13489val]->tempOwner < PLAYER_LIMIT)
 | 
	
		
			
				|  |  |  				return false; //if the pointer is not NULL
 | 
	
		
			
				|  |  |  			return true;
 | 
	
		
			
				|  |  |  			break;
 | 
	
	
		
			
				|  | @@ -3186,9 +3186,7 @@ bool CQuest::checkQuest (const CGHeroInstance * h) const
 | 
	
		
			
				|  |  |  		case MISSION_ART:
 | 
	
		
			
				|  |  |  			for (int i = 0; i < m5arts.size(); ++i)
 | 
	
		
			
				|  |  |  			{
 | 
	
		
			
				|  |  | -				if (vstd::contains(h->artifacts, m5arts[i]))
 | 
	
		
			
				|  |  | -					continue;
 | 
	
		
			
				|  |  | -				if (vstd::contains2(h->artifWorn, m5arts[i]))
 | 
	
		
			
				|  |  | +				if (h->hasArt(m5arts[i]))
 | 
	
		
			
				|  |  |  					continue;
 | 
	
		
			
				|  |  |  				return false; //if the artifact was not found
 | 
	
		
			
				|  |  |  			}
 | 
	
	
		
			
				|  | @@ -3220,7 +3218,7 @@ bool CQuest::checkQuest (const CGHeroInstance * h) const
 | 
	
		
			
				|  |  |  			return true;
 | 
	
		
			
				|  |  |  			break;
 | 
	
		
			
				|  |  |  		case MISSION_HERO:
 | 
	
		
			
				|  |  | -			if (m13489val == h->ID)
 | 
	
		
			
				|  |  | +			if (m13489val == h->type->ID)
 | 
	
		
			
				|  |  |  				return true;
 | 
	
		
			
				|  |  |  			return false;
 | 
	
		
			
				|  |  |  			break;
 | 
	
	
		
			
				|  | @@ -3233,7 +3231,6 @@ bool CQuest::checkQuest (const CGHeroInstance * h) const
 | 
	
		
			
				|  |  |  			return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  void CGSeerHut::initObj()
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	seerName = VLC->generaltexth->seerNames[ran()%VLC->generaltexth->seerNames.size()];
 | 
	
	
		
			
				|  | @@ -3253,6 +3250,7 @@ const std::string & CGSeerHut::getHoverText() const
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	hoverName = VLC->generaltexth->allTexts[347];
 | 
	
		
			
				|  |  |  	boost::algorithm::replace_first(hoverName,"%s", seerName);
 | 
	
		
			
				|  |  | +	if (progress){}//what does it seek for?
 | 
	
		
			
				|  |  |  	return hoverName;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -3309,8 +3307,12 @@ void CGSeerHut::onHeroVisit( const CGHeroInstance * h ) const
 | 
	
		
			
				|  |  |  				}
 | 
	
		
			
				|  |  |  					break;
 | 
	
		
			
				|  |  |  				case MISSION_KILL_HERO:
 | 
	
		
			
				|  |  | +					iw.components.push_back (Component (Component::HERO,
 | 
	
		
			
				|  |  | +						cb->gameState()->map->heroesToBeat[m13489val]->type->ID, 0, 0));
 | 
	
		
			
				|  |  | +					iw.text.addReplacement(cb->gameState()->map->heroesToBeat[m13489val]->name);
 | 
	
		
			
				|  |  | +					break;
 | 
	
		
			
				|  |  |  				case MISSION_HERO:
 | 
	
		
			
				|  |  | -					iw.components.push_back (Component (Component::HERO, 1, m13489val, 0));
 | 
	
		
			
				|  |  | +					iw.components.push_back (Component (Component::HERO, m13489val, 0, 0));
 | 
	
		
			
				|  |  |  					iw.text.addReplacement(VLC->heroh->heroes[m13489val]->name);
 | 
	
		
			
				|  |  |  					break;
 | 
	
		
			
				|  |  |  				case MISSION_KILL_CREATURE:
 | 
	
	
		
			
				|  | @@ -3321,6 +3323,10 @@ void CGSeerHut::onHeroVisit( const CGHeroInstance * h ) const
 | 
	
		
			
				|  |  |  						iw.text.addReplacement (MetaString::CRE_SING_NAMES, stack->first);
 | 
	
		
			
				|  |  |  					else
 | 
	
		
			
				|  |  |  						iw.text.addReplacement (MetaString::CRE_PL_NAMES, stack->first);
 | 
	
		
			
				|  |  | +					if (std::count(firstVisitText.begin(), firstVisitText.end(), '%') == 2) //say where is placed monster
 | 
	
		
			
				|  |  | +					{
 | 
	
		
			
				|  |  | +						iw.text.addReplacement (VLC->generaltexth->arraytxt[147+checkDirection()]);
 | 
	
		
			
				|  |  | +					}
 | 
	
		
			
				|  |  |  				}
 | 
	
		
			
				|  |  |  					break;
 | 
	
		
			
				|  |  |  				case MISSION_ART:
 | 
	
	
		
			
				|  | @@ -3421,7 +3427,6 @@ void CGSeerHut::onHeroVisit( const CGHeroInstance * h ) const
 | 
	
		
			
				|  |  |  						break;
 | 
	
		
			
				|  |  |  				}
 | 
	
		
			
				|  |  |  				cb->showBlockingDialog (&bd, boost::bind (&CGSeerHut::finishQuest, this, h, _1));
 | 
	
		
			
				|  |  | -				//cb->showBlockingDialog (&bd, boost::bind (&CGBorderGuard::openGate, this, h, _1));
 | 
	
		
			
				|  |  |  				return;
 | 
	
		
			
				|  |  |  			}
 | 
	
		
			
				|  |  |  		}
 | 
	
	
		
			
				|  | @@ -3429,10 +3434,42 @@ void CGSeerHut::onHeroVisit( const CGHeroInstance * h ) const
 | 
	
		
			
				|  |  |  	else
 | 
	
		
			
				|  |  |  	{
 | 
	
		
			
				|  |  |  		iw.text << VLC->generaltexth->seerEmpty[textOption];
 | 
	
		
			
				|  |  | -		iw.text.addReplacement(seerName);
 | 
	
		
			
				|  |  | +		if (ID == 83)
 | 
	
		
			
				|  |  | +			iw.text.addReplacement(seerName);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  	cb->showInfoDialog(&iw);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  | +int CGSeerHut::checkDirection() const
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	int3 cord = cb->gameState()->map->monsters[m13489val]->pos;
 | 
	
		
			
				|  |  | +	if ((double)cord.x/(double)cb->getMapSize().x < 0.34) //north
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +		if ((double)cord.y/(double)cb->getMapSize().y < 0.34) //northwest
 | 
	
		
			
				|  |  | +			return 8;
 | 
	
		
			
				|  |  | +		else if ((double)cord.y/(double)cb->getMapSize().y < 0.67) //north
 | 
	
		
			
				|  |  | +			return 1;
 | 
	
		
			
				|  |  | +		else //northeast
 | 
	
		
			
				|  |  | +			return 2;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +	else if ((double)cord.x/(double)cb->getMapSize().x < 0.67) //horizontal
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +		if ((double)cord.y/(double)cb->getMapSize().y < 0.34) //west
 | 
	
		
			
				|  |  | +			return 7;
 | 
	
		
			
				|  |  | +		else if ((double)cord.y/(double)cb->getMapSize().y < 0.67) //central
 | 
	
		
			
				|  |  | +			return 9;
 | 
	
		
			
				|  |  | +		else //east
 | 
	
		
			
				|  |  | +			return 3;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +	else //south
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +		if ((double)cord.y/(double)cb->getMapSize().y < 0.34) //southwest
 | 
	
		
			
				|  |  | +			return 6;
 | 
	
		
			
				|  |  | +		else if ((double)cord.y/(double)cb->getMapSize().y < 0.67) //south
 | 
	
		
			
				|  |  | +			return 5;
 | 
	
		
			
				|  |  | +		else //southeast
 | 
	
		
			
				|  |  | +			return 4;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  |  void CGSeerHut::finishQuest (const CGHeroInstance * h, ui32 accept) const
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	if (accept)
 | 
	
	
		
			
				|  | @@ -3455,15 +3492,78 @@ void CGSeerHut::finishQuest (const CGHeroInstance * h, ui32 accept) const
 | 
	
		
			
				|  |  |  			default:
 | 
	
		
			
				|  |  |  				break;
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  | +		completeQuest(h);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  | -void CGSeerHut::completeQuest (const CGHeroInstance * h) const
 | 
	
		
			
				|  |  | +void CGSeerHut::completeQuest (const CGHeroInstance * h) const //reward
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  | +	InfoWindow iw;
 | 
	
		
			
				|  |  | +	iw.player = h->getOwner();
 | 
	
		
			
				|  |  | +	switch (rewardType)
 | 
	
		
			
				|  |  | +	{
 | 
	
		
			
				|  |  | +		case 1: //experience
 | 
	
		
			
				|  |  | +			cb->changePrimSkill(h->id, 5, rVal, false);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::EXPERIENCE, 0, rVal, 0));
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 2: //mana points
 | 
	
		
			
				|  |  | +			cb->setManaPoints(h->id, h->mana+rVal);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::PRIM_SKILL, 5, rVal, 0));
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 3: case 4: //morale /luck
 | 
	
		
			
				|  |  | +		{
 | 
	
		
			
				|  |  | +			HeroBonus hb(HeroBonus::ONE_WEEK, (rewardType == 3 ? HeroBonus::MORALE : HeroBonus::LUCK),
 | 
	
		
			
				|  |  | +				HeroBonus::OBJECT, rVal, h->id, "", -1);
 | 
	
		
			
				|  |  | +			GiveBonus gb;
 | 
	
		
			
				|  |  | +			gb.hid = h->id;
 | 
	
		
			
				|  |  | +			gb.bonus = hb;
 | 
	
		
			
				|  |  | +			//gb.descr = "";
 | 
	
		
			
				|  |  | +			cb->giveHeroBonus(&gb);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (
 | 
	
		
			
				|  |  | +				(rewardType == 3 ? Component::MORALE : Component::LUCK), 0, rVal, 0));
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 5: //resources
 | 
	
		
			
				|  |  | +			cb->giveResource(h->getOwner(), rID, rVal);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::RESOURCE, rID, rVal, 0));
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 6: //main ability bonus (attak, defence etd.)
 | 
	
		
			
				|  |  | +			cb->changePrimSkill(h->id, rID, rVal, false);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::PRIM_SKILL, rID, rVal, 0));
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 7: // secondary ability gain
 | 
	
		
			
				|  |  | +			cb->changeSecSkill(h->id, rID, rVal, false);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::SEC_SKILL, rID, rVal, 0));
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 8: // artifact
 | 
	
		
			
				|  |  | +			cb->giveHeroArtifact(rID, h->id, -2);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::ARTIFACT, rID, 0, 0));
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 9:// spell
 | 
	
		
			
				|  |  | +		{
 | 
	
		
			
				|  |  | +			std::set<ui32> spell;
 | 
	
		
			
				|  |  | +			spell.insert (rID);
 | 
	
		
			
				|  |  | +			cb->changeSpells(h->id, true, spell);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::SPELL, rID, 0, 0));
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		case 10:// creature
 | 
	
		
			
				|  |  | +		{
 | 
	
		
			
				|  |  | +			CCreatureSet creatures;
 | 
	
		
			
				|  |  | +			creatures.setCreature (0, rID, rVal);
 | 
	
		
			
				|  |  | +			cb->giveCreatures (id, h,  creatures);
 | 
	
		
			
				|  |  | +			iw.components.push_back (Component (Component::CREATURE, rID, rVal, 0));
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +		default:
 | 
	
		
			
				|  |  | +			break;
 | 
	
		
			
				|  |  | +	}
 | 
	
		
			
				|  |  | +	cb->showInfoDialog(&iw);
 | 
	
		
			
				|  |  |  	cb->setObjProperty (id,11,0); //no more mission avaliable
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  void CGQuestGuard::initObj()
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  | +	blockVisit = true;
 | 
	
		
			
				|  |  |  	progress = 0;
 | 
	
		
			
				|  |  |  	textOption = ran()%3 + 3; //3-5
 | 
	
		
			
				|  |  |  	if (missionType)
 | 
	
	
		
			
				|  | @@ -3481,20 +3581,9 @@ const std::string & CGQuestGuard::getHoverText() const
 | 
	
		
			
				|  |  |  	if (progress){}//what does it seek for?
 | 
	
		
			
				|  |  |  	return hoverName;
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  | -void CGQuestGuard::onHeroVisit( const CGHeroInstance * h ) const
 | 
	
		
			
				|  |  | -{}
 | 
	
		
			
				|  |  | -void CGQuestGuard::completeQuest (const CGHeroInstance * h) const
 | 
	
		
			
				|  |  | +void CGQuestGuard::completeQuest(const CGHeroInstance *h) const
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  | -	BlockingDialog bd (true, false);
 | 
	
		
			
				|  |  | -	bd.player = h->getOwner();
 | 
	
		
			
				|  |  | -	bd.soundID = soundBase::QUEST;
 | 
	
		
			
				|  |  | -	bd.text << completedText;
 | 
	
		
			
				|  |  | -	cb->showBlockingDialog (&bd, boost::bind (&CGQuestGuard::openGate, this, h, _1));	
 | 
	
		
			
				|  |  | -}
 | 
	
		
			
				|  |  | -void CGQuestGuard::openGate(const CGHeroInstance *h, ui32 accept) const
 | 
	
		
			
				|  |  | -{
 | 
	
		
			
				|  |  | -	if (accept)
 | 
	
		
			
				|  |  | -		cb->removeObject(id);
 | 
	
		
			
				|  |  | +	cb->removeObject(id);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  void CGWitchHut::initObj()
 | 
	
		
			
				|  |  |  {
 |