|
@@ -750,7 +750,7 @@ void BattleActionsController::actionRealize(PossiblePlayerBattleAction action, B
|
|
|
|
|
|
if (!spellcastingModeActive())
|
|
if (!spellcastingModeActive())
|
|
{
|
|
{
|
|
- if (action.spell().toSpell())
|
|
|
|
|
|
+ if (action.spell().hasValue())
|
|
{
|
|
{
|
|
owner.giveCommand(EActionType::MONSTER_SPELL, targetHex, action.spell());
|
|
owner.giveCommand(EActionType::MONSTER_SPELL, targetHex, action.spell());
|
|
}
|
|
}
|
|
@@ -887,17 +887,17 @@ void BattleActionsController::tryActivateStackSpellcasting(const CStack *casterS
|
|
{
|
|
{
|
|
// faerie dragon can cast only one, randomly selected spell until their next move
|
|
// faerie dragon can cast only one, randomly selected spell until their next move
|
|
//TODO: faerie dragon type spell should be selected by server
|
|
//TODO: faerie dragon type spell should be selected by server
|
|
- const auto * spellToCast = owner.getBattle()->getRandomCastedSpell(CRandomGenerator::getDefault(), casterStack).toSpell();
|
|
|
|
|
|
+ const auto spellToCast = owner.getBattle()->getRandomCastedSpell(CRandomGenerator::getDefault(), casterStack);
|
|
|
|
|
|
- if (spellToCast)
|
|
|
|
- creatureSpells.push_back(spellToCast);
|
|
|
|
|
|
+ if (spellToCast.hasValue())
|
|
|
|
+ creatureSpells.push_back(spellToCast.toSpell());
|
|
}
|
|
}
|
|
|
|
|
|
TConstBonusListPtr bl = casterStack->getBonuses(Selector::type()(BonusType::SPELLCASTER));
|
|
TConstBonusListPtr bl = casterStack->getBonuses(Selector::type()(BonusType::SPELLCASTER));
|
|
|
|
|
|
for(const auto & bonus : *bl)
|
|
for(const auto & bonus : *bl)
|
|
{
|
|
{
|
|
- if (bonus->additionalInfo[0] <= 0)
|
|
|
|
|
|
+ if (bonus->additionalInfo[0] <= 0 && bonus->subtype.as<SpellID>().hasValue())
|
|
creatureSpells.push_back(bonus->subtype.as<SpellID>().toSpell());
|
|
creatureSpells.push_back(bonus->subtype.as<SpellID>().toSpell());
|
|
}
|
|
}
|
|
}
|
|
}
|