1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-04 00:15:53 +02:00

Merge pull request #275 from dydzio0614/RangedRetaliation

Okay, let's try this.
This commit is contained in:
DjWarmonger 2017-02-05 20:55:51 +01:00 committed by GitHub
commit ba9ea84718
3 changed files with 28 additions and 0 deletions

View File

@ -42,6 +42,12 @@
"description": "Enemy cannot Retaliate"
},
"BLOCKS_RANGED_RETALIATION":
{
"name": "No ranged retaliation",
"description": "Enemy cannot Retaliate by shooting"
},
"CATAPULT":
{
"name": "Catapult",
@ -300,6 +306,12 @@
"description": "Can cast random spell"
},
"RANGED_RETALIATION":
{
"name": "Ranged retaliation",
"description": "Can perform ranged counterattack"
},
"RECEPTIVE":
{
"name": "Receptive",

View File

@ -220,6 +220,8 @@ public:
BONUS_NAME(TRANSMUTATION) /*val - chance to trigger in %, subtype = 0 - resurrection based on HP, 1 - based on unit count, additional info - target creature ID (attacker default)*/\
BONUS_NAME(SUMMON_GUARDIANS) /*val - amount in % of stack count, subtype = creature ID*/\
BONUS_NAME(CATAPULT_EXTRA_SHOTS) /*val - number of additional shots, requires CATAPULT bonus to work*/\
BONUS_NAME(RANGED_RETALIATION) /*allows shooters to perform ranged retaliation*/\
BONUS_NAME(BLOCKS_RANGED_RETALIATION) /*disallows ranged retaliation for shooter unit, BLOCKS_RETALIATION bonus is for melee retaliation only*/\
/* end of list */

View File

@ -3993,6 +3993,20 @@ bool CGameHandler::makeBattleAction(BattleAction &ba)
handleAfterAttackCasting(bat);
}
//ranged counterattack
if (destinationStack
&& destinationStack->hasBonusOfType(Bonus::RANGED_RETALIATION)
&& !stack->hasBonusOfType(Bonus::BLOCKS_RANGED_RETALIATION)
&& destinationStack->ableToRetaliate()
&& stack->alive()) //attacker may have died (fire shield)
{
BattleAttack bat;
prepareAttack(bat, destinationStack, stack, 0, stack->position);
bat.flags |= BattleAttack::COUNTER | BattleAttack::SHOT;
sendAndApply(&bat);
handleAfterAttackCasting(bat);
}
//second shot for ballista, only if hero has advanced artillery
const CGHeroInstance * attackingHero = gs->curB->battleGetFightingHero(ba.side);