mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-24 03:47:18 +02:00
Remove copy-pasted code in rewardable town building leading to hero not
registered as visitor
This commit is contained in:
parent
d1e7cb72c2
commit
c55a75cc4e
@ -95,19 +95,7 @@ void CRewardableObject::blockingDialogAnswered(const CGHeroInstance * hero, int3
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (answer == 0)
|
onBlockingDialogAnswered(hero, answer);
|
||||||
return; //Player refused
|
|
||||||
|
|
||||||
if(answer > 0 && answer - 1 < configuration.info.size())
|
|
||||||
{
|
|
||||||
auto list = getAvailableRewards(hero, Rewardable::EEventType::EVENT_FIRST_VISIT);
|
|
||||||
markAsVisited(hero);
|
|
||||||
grantReward(list[answer - 1], hero);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw std::runtime_error("Unhandled choice");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,21 +131,7 @@ void TownRewardableBuildingInstance::heroLevelUpDone(const CGHeroInstance *hero)
|
|||||||
|
|
||||||
void TownRewardableBuildingInstance::blockingDialogAnswered(const CGHeroInstance *hero, int32_t answer) const
|
void TownRewardableBuildingInstance::blockingDialogAnswered(const CGHeroInstance *hero, int32_t answer) const
|
||||||
{
|
{
|
||||||
if(answer == 0)
|
onBlockingDialogAnswered(hero, answer);
|
||||||
return; // player refused
|
|
||||||
|
|
||||||
if(visitors.find(hero->id) != visitors.end())
|
|
||||||
return; // query not for this building
|
|
||||||
|
|
||||||
if(answer > 0 && answer-1 < configuration.info.size())
|
|
||||||
{
|
|
||||||
auto list = getAvailableRewards(hero, Rewardable::EEventType::EVENT_FIRST_VISIT);
|
|
||||||
grantReward(list[answer - 1], hero);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
throw std::runtime_error("Unhandled choice");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void TownRewardableBuildingInstance::grantReward(ui32 rewardID, const CGHeroInstance * hero) const
|
void TownRewardableBuildingInstance::grantReward(ui32 rewardID, const CGHeroInstance * hero) const
|
||||||
|
@ -366,4 +366,21 @@ void Rewardable::Interface::doHeroVisit(const CGHeroInstance *h) const
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Rewardable::Interface::onBlockingDialogAnswered(const CGHeroInstance * hero, int32_t answer) const
|
||||||
|
{
|
||||||
|
if (answer == 0)
|
||||||
|
return; //Player refused
|
||||||
|
|
||||||
|
if(answer > 0 && answer - 1 < configuration.info.size())
|
||||||
|
{
|
||||||
|
auto list = getAvailableRewards(hero, Rewardable::EEventType::EVENT_FIRST_VISIT);
|
||||||
|
markAsVisited(hero);
|
||||||
|
grantReward(list[answer - 1], hero);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw std::runtime_error("Unhandled choice");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_END
|
VCMI_LIB_NAMESPACE_END
|
||||||
|
@ -48,6 +48,8 @@ protected:
|
|||||||
virtual void markAsVisited(const CGHeroInstance * hero) const = 0;
|
virtual void markAsVisited(const CGHeroInstance * hero) const = 0;
|
||||||
virtual void markAsScouted(const CGHeroInstance * hero) const = 0;
|
virtual void markAsScouted(const CGHeroInstance * hero) const = 0;
|
||||||
virtual void grantReward(ui32 rewardID, const CGHeroInstance * hero) const = 0;
|
virtual void grantReward(ui32 rewardID, const CGHeroInstance * hero) const = 0;
|
||||||
|
|
||||||
|
void onBlockingDialogAnswered(const CGHeroInstance * hero, int32_t answer) const;
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/// filters list of visit info and returns rewards that can be granted to current hero
|
/// filters list of visit info and returns rewards that can be granted to current hero
|
||||||
|
Loading…
x
Reference in New Issue
Block a user