mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-10 00:43:59 +02:00
Fixes randomization of Witch Hut preconfigured in map editor
This commit is contained in:
parent
f5c2772f8d
commit
5d64da9b6c
@ -43,9 +43,10 @@ CGObjectInstance * CRewardableConstructor::create(IGameCallback * cb, std::share
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
Rewardable::Configuration CRewardableConstructor::generateConfiguration(IGameCallback * cb, vstd::RNG & rand, MapObjectID objectID) const
|
Rewardable::Configuration CRewardableConstructor::generateConfiguration(IGameCallback * cb, vstd::RNG & rand, MapObjectID objectID, const std::map<std::string, JsonNode> & presetVariables) const
|
||||||
{
|
{
|
||||||
Rewardable::Configuration result;
|
Rewardable::Configuration result;
|
||||||
|
result.variables.preset = presetVariables;
|
||||||
objectInfo.configureObject(result, rand, cb);
|
objectInfo.configureObject(result, rand, cb);
|
||||||
|
|
||||||
for(auto & rewardInfo : result.info)
|
for(auto & rewardInfo : result.info)
|
||||||
@ -67,7 +68,7 @@ void CRewardableConstructor::configureObject(CGObjectInstance * object, vstd::RN
|
|||||||
if (!rewardableObject)
|
if (!rewardableObject)
|
||||||
throw std::runtime_error("Object " + std::to_string(object->getObjGroupIndex()) + ", " + std::to_string(object->getObjTypeIndex()) + " is not a rewardable object!" );
|
throw std::runtime_error("Object " + std::to_string(object->getObjGroupIndex()) + ", " + std::to_string(object->getObjTypeIndex()) + " is not a rewardable object!" );
|
||||||
|
|
||||||
rewardableObject->configuration = generateConfiguration(object->cb, rng, object->ID);
|
rewardableObject->configuration = generateConfiguration(object->cb, rng, object->ID, rewardableObject->configuration.variables.preset);
|
||||||
rewardableObject->initializeGuards();
|
rewardableObject->initializeGuards();
|
||||||
|
|
||||||
if (rewardableObject->configuration.info.empty())
|
if (rewardableObject->configuration.info.empty())
|
||||||
|
@ -31,7 +31,7 @@ public:
|
|||||||
|
|
||||||
std::unique_ptr<IObjectInfo> getObjectInfo(std::shared_ptr<const ObjectTemplate> tmpl) const override;
|
std::unique_ptr<IObjectInfo> getObjectInfo(std::shared_ptr<const ObjectTemplate> tmpl) const override;
|
||||||
|
|
||||||
Rewardable::Configuration generateConfiguration(IGameCallback * cb, vstd::RNG & rand, MapObjectID objectID) const;
|
Rewardable::Configuration generateConfiguration(IGameCallback * cb, vstd::RNG & rand, MapObjectID objectID, const std::map<std::string, JsonNode> & presetVariables) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_END
|
VCMI_LIB_NAMESPACE_END
|
||||||
|
@ -329,7 +329,7 @@ void CRewardableObject::newTurn(vstd::RNG & rand) const
|
|||||||
if (configuration.resetParameters.rewards)
|
if (configuration.resetParameters.rewards)
|
||||||
{
|
{
|
||||||
auto handler = std::dynamic_pointer_cast<const CRewardableConstructor>(getObjectHandler());
|
auto handler = std::dynamic_pointer_cast<const CRewardableConstructor>(getObjectHandler());
|
||||||
auto newConfiguration = handler->generateConfiguration(cb, rand, ID);
|
auto newConfiguration = handler->generateConfiguration(cb, rand, ID, configuration.variables.preset);
|
||||||
cb->setRewardableObjectConfiguration(id, newConfiguration);
|
cb->setRewardableObjectConfiguration(id, newConfiguration);
|
||||||
}
|
}
|
||||||
if (configuration.resetParameters.visitors)
|
if (configuration.resetParameters.visitors)
|
||||||
|
Loading…
Reference in New Issue
Block a user