/* * CArtifactInstance.cpp, part of VCMI engine * * Authors: listed in file AUTHORS in main folder * * License: GNU General Public License v2.0 or later * Full text of license available in license.txt file, in main folder * */ #include "StdInc.h" #include "CArtifactInstance.h" #include "ArtifactUtils.h" #include "CArtHandler.h" #include "networkPacks/ArtifactLocation.h" VCMI_LIB_NAMESPACE_BEGIN void CCombinedArtifactInstance::addPart(CArtifactInstance * art, const ArtifactPosition & slot) { auto artInst = static_cast(this); assert(vstd::contains_if(artInst->artType->getConstituents(), [=](const CArtifact * partType) { return partType->getId() == art->getTypeId(); })); assert(art->getParentNodes().size() == 1 && art->getParentNodes().front() == art->artType); partsInfo.emplace_back(art, slot); artInst->attachTo(*art); } bool CCombinedArtifactInstance::isPart(const CArtifactInstance * supposedPart) const { if(supposedPart == this) return true; for(const PartInfo & constituent : partsInfo) { if(constituent.art == supposedPart) return true; } return false; } bool CCombinedArtifactInstance::hasParts() const { return !partsInfo.empty(); } const std::vector & CCombinedArtifactInstance::getPartsInfo() const { return partsInfo; } void CCombinedArtifactInstance::addPlacementMap(const CArtifactSet::ArtPlacementMap & placementMap) { if(!placementMap.empty()) for(auto & part : partsInfo) { if(placementMap.find(part.art) != placementMap.end()) part.slot = placementMap.at(part.art); } } SpellID CScrollArtifactInstance::getScrollSpellID() const { auto artInst = static_cast(this); const auto bonus = artInst->getFirstBonus(Selector::type()(BonusType::SPELL)); if(!bonus) return SpellID::NONE; return bonus->subtype.as(); } void CGrowingArtifactInstance::growingUp() { auto artInst = static_cast(this); if(artInst->artType->isGrowing()) { auto bonus = std::make_shared(); bonus->type = BonusType::LEVEL_COUNTER; bonus->val = 1; bonus->duration = BonusDuration::COMMANDER_KILLED; artInst->accumulateBonus(bonus); for(const auto & bonus : artInst->artType->getBonusesPerLevel()) { // Every n levels if(artInst->valOfBonuses(BonusType::LEVEL_COUNTER) % bonus.first == 0) { artInst->accumulateBonus(std::make_shared(bonus.second)); } } for(const auto & bonus : artInst->artType->getThresholdBonuses()) { // At n level if(artInst->valOfBonuses(BonusType::LEVEL_COUNTER) == bonus.first) { artInst->addNewBonus(std::make_shared(bonus.second)); } } } } void CArtifactInstance::init() { // Artifact to be randomized id = static_cast(ArtifactID::NONE); setNodeType(ARTIFACT_INSTANCE); } CArtifactInstance::CArtifactInstance(const CArtifact * art) { init(); setType(art); } CArtifactInstance::CArtifactInstance() { init(); } void CArtifactInstance::setType(const CArtifact * art) { artType = art; attachToSource(*art); } std::string CArtifactInstance::nodeName() const { return "Artifact instance of " + (artType ? artType->getJsonKey() : std::string("uninitialized")) + " type"; } ArtifactID CArtifactInstance::getTypeId() const { return artType->getId(); } ArtifactInstanceID CArtifactInstance::getId() const { return id; } void CArtifactInstance::setId(ArtifactInstanceID id) { this->id = id; } bool CArtifactInstance::canBePutAt(const CArtifactSet * artSet, ArtifactPosition slot, bool assumeDestRemoved) const { return artType->canBePutAt(artSet, slot, assumeDestRemoved); } bool CArtifactInstance::isCombined() const { return artType->isCombined(); } bool CArtifactInstance::isScroll() const { return artType->isScroll(); } void CArtifactInstance::deserializationFix() { setType(artType); for(PartInfo & part : partsInfo) attachTo(*part.art); } VCMI_LIB_NAMESPACE_END