Update battle messages to Gen 5+ standards (#3240)
Co-authored-by: Eduardo Quezada <eduardo602002@gmail.com>
This commit is contained in:
parent
3205f377d5
commit
db24128ee3
265 changed files with 2888 additions and 2393 deletions
|
@ -413,6 +413,10 @@ B_DEF_TEAM1 = FD 3A
|
||||||
B_DEF_TEAM2 = FD 3B
|
B_DEF_TEAM2 = FD 3B
|
||||||
@ FD 3C - preiously gActiveBattler
|
@ FD 3C - preiously gActiveBattler
|
||||||
@ FD 3D - preiously gActiveBattler without Illusion Check
|
@ FD 3D - preiously gActiveBattler without Illusion Check
|
||||||
|
B_ATK_NAME_WITH_PREFIX2 = FD 3E
|
||||||
|
B_DEF_NAME_WITH_PREFIX2 = FD 3F
|
||||||
|
B_EFF_NAME_WITH_PREFIX2 = FD 40
|
||||||
|
B_SCR_ACTIVE_NAME_WITH_PREFIX2 = FD 41
|
||||||
|
|
||||||
@ indicates the end of a town/city name (before " TOWN" or " CITY")
|
@ indicates the end of a town/city name (before " TOWN" or " CITY")
|
||||||
NAME_END = FC 00
|
NAME_END = FC 00
|
||||||
|
|
|
@ -3094,7 +3094,7 @@ BattleScript_DreamEaterWorked:
|
||||||
healthbarupdate BS_ATTACKER
|
healthbarupdate BS_ATTACKER
|
||||||
datahpupdate BS_ATTACKER
|
datahpupdate BS_ATTACKER
|
||||||
jumpifmovehadnoeffect BattleScript_DreamEaterTryFaintEnd
|
jumpifmovehadnoeffect BattleScript_DreamEaterTryFaintEnd
|
||||||
printstring STRINGID_PKMNDREAMEATEN
|
printstring STRINGID_PKMNENERGYDRAINED
|
||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
BattleScript_DreamEaterTryFaintEnd:
|
BattleScript_DreamEaterTryFaintEnd:
|
||||||
tryfaintmon BS_TARGET
|
tryfaintmon BS_TARGET
|
||||||
|
@ -5962,7 +5962,7 @@ BattleScript_OverworldWeatherStarts::
|
||||||
end3
|
end3
|
||||||
|
|
||||||
BattleScript_OverworldTerrain::
|
BattleScript_OverworldTerrain::
|
||||||
printfromtable gTerrainStringIds
|
printfromtable gTerrainStartsStringIds
|
||||||
waitmessage B_WAIT_TIME_LONG
|
waitmessage B_WAIT_TIME_LONG
|
||||||
playanimation BS_BATTLER_0, B_ANIM_RESTORE_BG
|
playanimation BS_BATTLER_0, B_ANIM_RESTORE_BG
|
||||||
call BattleScript_ActivateTerrainEffects
|
call BattleScript_ActivateTerrainEffects
|
||||||
|
@ -9083,8 +9083,6 @@ BattleScript_BerryConfuseHealEnd2_Anim:
|
||||||
orword gHitMarker, HITMARKER_IGNORE_BIDE | HITMARKER_IGNORE_SUBSTITUTE | HITMARKER_PASSIVE_DAMAGE
|
orword gHitMarker, HITMARKER_IGNORE_BIDE | HITMARKER_IGNORE_SUBSTITUTE | HITMARKER_PASSIVE_DAMAGE
|
||||||
healthbarupdate BS_SCRIPTING
|
healthbarupdate BS_SCRIPTING
|
||||||
datahpupdate BS_SCRIPTING
|
datahpupdate BS_SCRIPTING
|
||||||
printstring STRINGID_FORXCOMMAYZ
|
|
||||||
waitmessage B_WAIT_TIME_LONG
|
|
||||||
seteffectprimary MOVE_EFFECT_CONFUSION | MOVE_EFFECT_AFFECTS_USER
|
seteffectprimary MOVE_EFFECT_CONFUSION | MOVE_EFFECT_AFFECTS_USER
|
||||||
removeitem BS_SCRIPTING
|
removeitem BS_SCRIPTING
|
||||||
end2
|
end2
|
||||||
|
@ -9101,8 +9099,6 @@ BattleScript_BerryConfuseHealRet_Anim:
|
||||||
orword gHitMarker, HITMARKER_IGNORE_BIDE | HITMARKER_IGNORE_SUBSTITUTE | HITMARKER_PASSIVE_DAMAGE
|
orword gHitMarker, HITMARKER_IGNORE_BIDE | HITMARKER_IGNORE_SUBSTITUTE | HITMARKER_PASSIVE_DAMAGE
|
||||||
healthbarupdate BS_SCRIPTING
|
healthbarupdate BS_SCRIPTING
|
||||||
datahpupdate BS_SCRIPTING
|
datahpupdate BS_SCRIPTING
|
||||||
printstring STRINGID_FORXCOMMAYZ
|
|
||||||
waitmessage B_WAIT_TIME_LONG
|
|
||||||
seteffectprimary MOVE_EFFECT_CONFUSION | MOVE_EFFECT_CERTAIN
|
seteffectprimary MOVE_EFFECT_CONFUSION | MOVE_EFFECT_CERTAIN
|
||||||
removeitem BS_TARGET
|
removeitem BS_TARGET
|
||||||
return
|
return
|
||||||
|
|
|
@ -44,7 +44,7 @@ SINGLE_BATTLE_TEST("Stun Spore inflicts paralysis")
|
||||||
TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
||||||
MESSAGE("Foe Wobbuffet is paralyzed! It may be unable to move!"); // 4
|
MESSAGE("The opposing Wobbuffet is paralyzed, so it may be unable to move!"); // 4
|
||||||
STATUS_ICON(opponent, paralysis: TRUE); // 4.
|
STATUS_ICON(opponent, paralysis: TRUE); // 4.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ SINGLE_BATTLE_TEST("Stun Spore does not affect Grass-types")
|
||||||
TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player); // 4.
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player); // 4.
|
||||||
MESSAGE("It doesn't affect Foe Oddish…"); // 5.
|
MESSAGE("It doesn't affect the opposing Oddish…"); // 5.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
@ -226,7 +226,7 @@ SINGLE_BATTLE_TEST("Paralysis has a 25% chance of skipping the turn")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE); }
|
TURN { MOVE(player, MOVE_CELEBRATE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wobbuffet is paralyzed! It can't move!");
|
MESSAGE("Wobbuffet couldn't move because it's paralyzed!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
@ -428,7 +428,7 @@ Spaces in pattern match newlines (\n, \l, and \p) in the message.
|
||||||
Often used to check that a battler took its turn but it failed, e.g.:
|
Often used to check that a battler took its turn but it failed, e.g.:
|
||||||
```
|
```
|
||||||
MESSAGE("Wobbuffet used Dream Eater!");
|
MESSAGE("Wobbuffet used Dream Eater!");
|
||||||
MESSAGE("Foe Wobbuffet wasn't affected!");
|
MESSAGE("The opposing Wobbuffet wasn't affected!");
|
||||||
```
|
```
|
||||||
|
|
||||||
### `STATUS_ICON`
|
### `STATUS_ICON`
|
||||||
|
@ -452,7 +452,7 @@ Causes the test to fail if the `SCENE` command succeeds before the following com
|
||||||
```
|
```
|
||||||
// Our Wobbuffet does not Celebrate before the foe's.
|
// Our Wobbuffet does not Celebrate before the foe's.
|
||||||
NOT MESSAGE("Wobbuffet used Celebrate!");
|
NOT MESSAGE("Wobbuffet used Celebrate!");
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
```
|
```
|
||||||
**NOTE**: If this condition fails, the viewable ROM freezes at the NOT command.
|
**NOTE**: If this condition fails, the viewable ROM freezes at the NOT command.
|
||||||
**WARNING: `NOT` is an alias of `NONE_OF`, so it behaves surprisingly when applied to multiple commands wrapped in braces.**
|
**WARNING: `NOT` is an alias of `NONE_OF`, so it behaves surprisingly when applied to multiple commands wrapped in braces.**
|
||||||
|
@ -467,7 +467,7 @@ Causes the test to fail unless one of the `SCENE` commands succeeds.
|
||||||
```
|
```
|
||||||
ONE_OF {
|
ONE_OF {
|
||||||
MESSAGE("Wobbuffet used Celebrate!");
|
MESSAGE("Wobbuffet used Celebrate!");
|
||||||
MESSAGE("Wobbuffet is paralyzed! It can't move!");
|
MESSAGE("Wobbuffet couldn't move because it's paralyzed!");
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -482,9 +482,9 @@ Causes the test to fail if one of the `SCENE` commands succeeds before the comma
|
||||||
// Our Wobbuffet does not move before the foe's.
|
// Our Wobbuffet does not move before the foe's.
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
MESSAGE("Wobbuffet used Celebrate!");
|
MESSAGE("Wobbuffet used Celebrate!");
|
||||||
MESSAGE("Wobbuffet is paralyzed! It can't move!");
|
MESSAGE("Wobbuffet couldn't move because it's paralyzed!");
|
||||||
}
|
}
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
```
|
```
|
||||||
|
|
||||||
### `PLAYER_PARTY`
|
### `PLAYER_PARTY`
|
||||||
|
|
|
@ -1,12 +1,15 @@
|
||||||
#ifndef GUARD_BATTLE_MESSAGE_H
|
#ifndef GUARD_BATTLE_MESSAGE_H
|
||||||
#define GUARD_BATTLE_MESSAGE_H
|
#define GUARD_BATTLE_MESSAGE_H
|
||||||
|
|
||||||
|
#include "constants/battle.h"
|
||||||
|
|
||||||
// This buffer can hold many different things. Some of the things it can hold
|
// This buffer can hold many different things. Some of the things it can hold
|
||||||
// that have explicit sizes are listed below to ensure it can contain them.
|
// that have explicit sizes are listed below to ensure it can contain them.
|
||||||
#define TEXT_BUFF_ARRAY_COUNT max(16, \
|
#define TEXT_BUFF_ARRAY_COUNT max(16, \
|
||||||
max(MOVE_NAME_LENGTH + 2, /* +2 to hold the "!" and EOS. */ \
|
max(MOVE_NAME_LENGTH + 2, /* +2 to hold the "!" and EOS. */ \
|
||||||
max(POKEMON_NAME_LENGTH + 1, \
|
max(POKEMON_NAME_LENGTH + 1, \
|
||||||
ABILITY_NAME_LENGTH + 1)))
|
ABILITY_NAME_LENGTH + 1)))
|
||||||
|
#define BATTLE_MSG_MAX_WIDTH 208
|
||||||
|
|
||||||
// for 0xFD
|
// for 0xFD
|
||||||
#define B_TXT_BUFF1 0x0
|
#define B_TXT_BUFF1 0x0
|
||||||
|
@ -71,20 +74,23 @@
|
||||||
#define B_TXT_DEF_TEAM2 0x3B // your/the opposing
|
#define B_TXT_DEF_TEAM2 0x3B // your/the opposing
|
||||||
// #define B_TXT_SELECTION_NAME 0x3C - removed
|
// #define B_TXT_SELECTION_NAME 0x3C - removed
|
||||||
// #define B_TXT_SELECTION_NAME2 0x3D no Illusion check - removed
|
// #define B_TXT_SELECTION_NAME2 0x3D no Illusion check - removed
|
||||||
|
#define B_TXT_ATK_NAME_WITH_PREFIX2 0x3E //lowercase
|
||||||
|
#define B_TXT_DEF_NAME_WITH_PREFIX2 0x3F //lowercase
|
||||||
|
#define B_TXT_EFF_NAME_WITH_PREFIX2 0x40 //lowercase
|
||||||
|
#define B_TXT_SCR_ACTIVE_NAME_WITH_PREFIX2 0x41 //lowercase
|
||||||
|
|
||||||
// for B_TXT_BUFF1, B_TXT_BUFF2 and B_TXT_BUFF3
|
#define B_BUFF_STRING 0
|
||||||
|
#define B_BUFF_NUMBER 1
|
||||||
#define B_BUFF_STRING 0
|
#define B_BUFF_MOVE 2
|
||||||
#define B_BUFF_NUMBER 1
|
#define B_BUFF_TYPE 3
|
||||||
#define B_BUFF_MOVE 2
|
#define B_BUFF_MON_NICK_WITH_PREFIX 4
|
||||||
#define B_BUFF_TYPE 3
|
#define B_BUFF_STAT 5
|
||||||
#define B_BUFF_MON_NICK_WITH_PREFIX 4
|
#define B_BUFF_SPECIES 6
|
||||||
#define B_BUFF_STAT 5
|
#define B_BUFF_MON_NICK 7
|
||||||
#define B_BUFF_SPECIES 6
|
#define B_BUFF_NEGATIVE_FLAVOR 8
|
||||||
#define B_BUFF_MON_NICK 7
|
#define B_BUFF_ABILITY 9
|
||||||
#define B_BUFF_NEGATIVE_FLAVOR 8
|
#define B_BUFF_ITEM 10
|
||||||
#define B_BUFF_ABILITY 9
|
#define B_BUFF_MON_NICK_WITH_PREFIX_LOWER 11 // lowercase prefix
|
||||||
#define B_BUFF_ITEM 10
|
|
||||||
|
|
||||||
#define B_BUFF_PLACEHOLDER_BEGIN 0xFD
|
#define B_BUFF_PLACEHOLDER_BEGIN 0xFD
|
||||||
#define B_BUFF_EOS 0xFF
|
#define B_BUFF_EOS 0xFF
|
||||||
|
@ -201,6 +207,15 @@
|
||||||
textVar[4] = B_BUFF_EOS; \
|
textVar[4] = B_BUFF_EOS; \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define PREPARE_MON_NICK_WITH_PREFIX_LOWER_BUFFER(textVar, battler, partyId) \
|
||||||
|
{ \
|
||||||
|
textVar[0] = B_BUFF_PLACEHOLDER_BEGIN; \
|
||||||
|
textVar[1] = B_BUFF_MON_NICK_WITH_PREFIX_LOWER; \
|
||||||
|
textVar[2] = battler; \
|
||||||
|
textVar[3] = partyId; \
|
||||||
|
textVar[4] = B_BUFF_EOS; \
|
||||||
|
}
|
||||||
|
|
||||||
#define PREPARE_MON_NICK_BUFFER(textVar, battler, partyId) \
|
#define PREPARE_MON_NICK_BUFFER(textVar, battler, partyId) \
|
||||||
{ \
|
{ \
|
||||||
textVar[0] = B_BUFF_PLACEHOLDER_BEGIN; \
|
textVar[0] = B_BUFF_PLACEHOLDER_BEGIN; \
|
||||||
|
@ -243,7 +258,7 @@ enum
|
||||||
|
|
||||||
void BufferStringBattle(u16 stringID, u32 battler);
|
void BufferStringBattle(u16 stringID, u32 battler);
|
||||||
u32 BattleStringExpandPlaceholdersToDisplayedString(const u8 *src);
|
u32 BattleStringExpandPlaceholdersToDisplayedString(const u8 *src);
|
||||||
u32 BattleStringExpandPlaceholders(const u8 *src, u8 *dst);
|
u32 BattleStringExpandPlaceholders(const u8 *src, u8 *dst, u32 dstSize);
|
||||||
void BattlePutTextOnWindow(const u8 *text, u8 windowId);
|
void BattlePutTextOnWindow(const u8 *text, u8 windowId);
|
||||||
void SetPpNumbersPaletteInMoveSelection(u32 battler);
|
void SetPpNumbersPaletteInMoveSelection(u32 battler);
|
||||||
u8 GetCurrentPpToMaxPpState(u8 currentPp, u8 maxPp);
|
u8 GetCurrentPpToMaxPpState(u8 currentPp, u8 maxPp);
|
||||||
|
@ -302,6 +317,9 @@ extern const u8 gText_Loss[];
|
||||||
extern const u8 gText_Draw[];
|
extern const u8 gText_Draw[];
|
||||||
extern const u8 gText_StatSharply[];
|
extern const u8 gText_StatSharply[];
|
||||||
extern const u8 gText_StatRose[];
|
extern const u8 gText_StatRose[];
|
||||||
|
extern const u8 sText_StatFell[];
|
||||||
|
extern const u8 sText_drastically[];
|
||||||
|
extern const u8 sText_severely[];
|
||||||
extern const u8 gText_DefendersStatRose[];
|
extern const u8 gText_DefendersStatRose[];
|
||||||
extern const u8 gText_PkmnGettingPumped[];
|
extern const u8 gText_PkmnGettingPumped[];
|
||||||
extern const u8 gText_PkmnShroudedInMist[];
|
extern const u8 gText_PkmnShroudedInMist[];
|
||||||
|
|
|
@ -716,8 +716,16 @@
|
||||||
#define STRINGID_POKEFLUTECATCHY 714
|
#define STRINGID_POKEFLUTECATCHY 714
|
||||||
#define STRINGID_POKEFLUTE 715
|
#define STRINGID_POKEFLUTE 715
|
||||||
#define STRINGID_MONHEARINGFLUTEAWOKE 716
|
#define STRINGID_MONHEARINGFLUTEAWOKE 716
|
||||||
|
#define STRINGID_SUNLIGHTISHARSH 717
|
||||||
|
#define STRINGID_ITISHAILING 718
|
||||||
|
#define STRINGID_ITISSNOWING 719
|
||||||
|
#define STRINGID_ISCOVEREDWITHGRASS 720
|
||||||
|
#define STRINGID_MISTSWIRLSAROUND 721
|
||||||
|
#define STRINGID_ELECTRICCURRENTISRUNNING 722
|
||||||
|
#define STRINGID_SEEMSWEIRD 723
|
||||||
|
#define STRINGID_WAGGLINGAFINGER 724
|
||||||
|
|
||||||
#define BATTLESTRINGS_COUNT 717
|
#define BATTLESTRINGS_COUNT 725
|
||||||
|
|
||||||
// This is the string id that gBattleStringsTable starts with.
|
// This is the string id that gBattleStringsTable starts with.
|
||||||
// String ids before this (e.g. STRINGID_INTROMSG) are not in the table,
|
// String ids before this (e.g. STRINGID_INTROMSG) are not in the table,
|
||||||
|
|
|
@ -21,6 +21,7 @@ u8 *StringAppend(u8 *dest, const u8 *src);
|
||||||
u8 *StringCopyN(u8 *dest, const u8 *src, u8 n);
|
u8 *StringCopyN(u8 *dest, const u8 *src, u8 n);
|
||||||
u8 *StringAppendN(u8 *dest, const u8 *src, u8 n);
|
u8 *StringAppendN(u8 *dest, const u8 *src, u8 n);
|
||||||
u16 StringLength(const u8 *str);
|
u16 StringLength(const u8 *str);
|
||||||
|
u16 StringLineLength(const u8 *str);
|
||||||
s32 StringCompare(const u8 *str1, const u8 *str2);
|
s32 StringCompare(const u8 *str1, const u8 *str2);
|
||||||
s32 StringCompareN(const u8 *str1, const u8 *str2, u32 n);
|
s32 StringCompareN(const u8 *str1, const u8 *str2, u32 n);
|
||||||
bool8 IsStringLengthAtLeast(const u8 *str, s32 n);
|
bool8 IsStringLengthAtLeast(const u8 *str, s32 n);
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
* TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
* TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
||||||
* } SCENE {
|
* } SCENE {
|
||||||
* ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
* ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
||||||
* MESSAGE("Foe Wobbuffet is paralyzed! It may be unable to move!"); // 4
|
* MESSAGE("The opposing Wobbuffet is paralyzed, so it may be unable to move!"); // 4
|
||||||
* STATUS_ICON(opponent, paralysis: TRUE); // 4.
|
* STATUS_ICON(opponent, paralysis: TRUE); // 4.
|
||||||
* }
|
* }
|
||||||
* }
|
* }
|
||||||
|
@ -95,7 +95,7 @@
|
||||||
* TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
* TURN { MOVE(player, MOVE_STUN_SPORE); } // 3.
|
||||||
* } SCENE {
|
* } SCENE {
|
||||||
* NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player); // 4.
|
* NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player); // 4.
|
||||||
* MESSAGE("It doesn't affect Foe Oddish…"); // 5.
|
* MESSAGE("It doesn't affect the opposing Oddish…"); // 5.
|
||||||
* }
|
* }
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
|
@ -256,7 +256,7 @@
|
||||||
* } WHEN {
|
* } WHEN {
|
||||||
* TURN { MOVE(player, MOVE_CELEBRATE); }
|
* TURN { MOVE(player, MOVE_CELEBRATE); }
|
||||||
* } SCENE {
|
* } SCENE {
|
||||||
* MESSAGE("Wobbuffet is paralyzed! It can't move!");
|
* MESSAGE("Wobbuffet is paralyzed, so it may be unable to move!");
|
||||||
* }
|
* }
|
||||||
* }
|
* }
|
||||||
* All BattleRandom calls involving tag will return the same number, so
|
* All BattleRandom calls involving tag will return the same number, so
|
||||||
|
@ -413,7 +413,7 @@
|
||||||
* Spaces in pattern match newlines (\n, \l, and \p) in the message.
|
* Spaces in pattern match newlines (\n, \l, and \p) in the message.
|
||||||
* Often used to check that a battler took its turn but it failed, e.g.:
|
* Often used to check that a battler took its turn but it failed, e.g.:
|
||||||
* MESSAGE("Wobbuffet used Dream Eater!");
|
* MESSAGE("Wobbuffet used Dream Eater!");
|
||||||
* MESSAGE("Foe Wobbuffet wasn't affected!");
|
* MESSAGE("The opposing Wobbuffet wasn't affected!");
|
||||||
*
|
*
|
||||||
* STATUS_ICON(battler, status1 | none: | sleep: | poison: | burn: | freeze: | paralysis:, badPoison:)
|
* STATUS_ICON(battler, status1 | none: | sleep: | poison: | burn: | freeze: | paralysis:, badPoison:)
|
||||||
* Causes the test to fail if the battler's status is not changed to the
|
* Causes the test to fail if the battler's status is not changed to the
|
||||||
|
@ -432,7 +432,7 @@
|
||||||
* following command succeeds.
|
* following command succeeds.
|
||||||
* // Our Wobbuffet does not Celebrate before the foe's.
|
* // Our Wobbuffet does not Celebrate before the foe's.
|
||||||
* NOT MESSAGE("Wobbuffet used Celebrate!");
|
* NOT MESSAGE("Wobbuffet used Celebrate!");
|
||||||
* MESSAGE("Foe Wobbuffet used Celebrate!");
|
* MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
* WARNING: NOT is an alias of NONE_OF, so it behaves surprisingly when
|
* WARNING: NOT is an alias of NONE_OF, so it behaves surprisingly when
|
||||||
* applied to multiple commands wrapped in braces.
|
* applied to multiple commands wrapped in braces.
|
||||||
*
|
*
|
||||||
|
@ -440,7 +440,7 @@
|
||||||
* Causes the test to fail unless one of the SCENE commands succeeds.
|
* Causes the test to fail unless one of the SCENE commands succeeds.
|
||||||
* ONE_OF {
|
* ONE_OF {
|
||||||
* MESSAGE("Wobbuffet used Celebrate!");
|
* MESSAGE("Wobbuffet used Celebrate!");
|
||||||
* MESSAGE("Wobbuffet is paralyzed! It can't move!");
|
* MESSAGE("Wobbuffet is paralyzed, so it may be unable to move!");
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
* NONE_OF
|
* NONE_OF
|
||||||
|
@ -449,9 +449,9 @@
|
||||||
* // Our Wobbuffet does not move before the foe's.
|
* // Our Wobbuffet does not move before the foe's.
|
||||||
* NONE_OF {
|
* NONE_OF {
|
||||||
* MESSAGE("Wobbuffet used Celebrate!");
|
* MESSAGE("Wobbuffet used Celebrate!");
|
||||||
* MESSAGE("Wobbuffet is paralyzed! It can't move!");
|
* MESSAGE("Wobbuffet is paralyzed, so it may be unable to move!");
|
||||||
* }
|
* }
|
||||||
* MESSAGE("Foe Wobbuffet used Celebrate!");
|
* MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
*
|
*
|
||||||
* PLAYER_PARTY and OPPONENT_PARTY
|
* PLAYER_PARTY and OPPONENT_PARTY
|
||||||
* Refer to the party members defined in GIVEN, e.g.:
|
* Refer to the party members defined in GIVEN, e.g.:
|
||||||
|
@ -1017,11 +1017,11 @@ void SendOut(u32 sourceLine, struct BattlePokemon *, u32 partyIndex);
|
||||||
MESSAGE(name ", good! Come back!"); \
|
MESSAGE(name ", good! Come back!"); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define SEND_IN_MESSAGE(name) ONE_OF { \
|
#define SEND_IN_MESSAGE(name) ONE_OF { \
|
||||||
MESSAGE("Go! " name "!"); \
|
MESSAGE("Go! " name "!"); \
|
||||||
MESSAGE("Do it! " name "!"); \
|
MESSAGE("You're in charge, " name "!"); \
|
||||||
MESSAGE("Go for it, " name "!"); \
|
MESSAGE("Go for it, " name "!"); \
|
||||||
MESSAGE("Your foe's weak! Get 'em, " name "!"); \
|
MESSAGE("Your opponent's weak! Get 'em, " name "!"); \
|
||||||
}
|
}
|
||||||
|
|
||||||
enum QueueGroupType
|
enum QueueGroupType
|
||||||
|
|
|
@ -157,7 +157,9 @@ bool32 TextPrinterWaitAutoMode(struct TextPrinter *textPrinter);
|
||||||
bool32 TextPrinterWaitWithDownArrow(struct TextPrinter *textPrinter);
|
bool32 TextPrinterWaitWithDownArrow(struct TextPrinter *textPrinter);
|
||||||
bool32 TextPrinterWait(struct TextPrinter *textPrinter);
|
bool32 TextPrinterWait(struct TextPrinter *textPrinter);
|
||||||
void DrawDownArrow(u8 windowId, u16 x, u16 y, u8 bgColor, bool32 drawArrow, u8 *counter, u8 *yCoordIndex);
|
void DrawDownArrow(u8 windowId, u16 x, u16 y, u8 bgColor, bool32 drawArrow, u8 *counter, u8 *yCoordIndex);
|
||||||
|
s32 GetGlyphWidth(u16 glyphId, bool32 isJapanese, u8 fontId);
|
||||||
s32 GetStringWidth(u8 fontId, const u8 *str, s16 letterSpacing);
|
s32 GetStringWidth(u8 fontId, const u8 *str, s16 letterSpacing);
|
||||||
|
s32 GetStringLineWidth(u8 fontId, const u8 *str, s16 letterSpacing, u32 lineNum, u32 strSize, bool32 printDebug);
|
||||||
u8 RenderTextHandleBold(u8 *pixels, u8 fontId, u8 *str);
|
u8 RenderTextHandleBold(u8 *pixels, u8 fontId, u8 *str);
|
||||||
u8 DrawKeypadIcon(u8 windowId, u8 keypadIconId, u16 x, u16 y);
|
u8 DrawKeypadIcon(u8 windowId, u8 keypadIconId, u16 x, u16 y);
|
||||||
u8 GetKeypadIconTileOffset(u8 keypadIconId);
|
u8 GetKeypadIconTileOffset(u8 keypadIconId);
|
||||||
|
|
1489
src/battle_message.c
1489
src/battle_message.c
File diff suppressed because it is too large
Load diff
|
@ -12770,8 +12770,8 @@ static void Cmd_metronome(void)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gCurrentMove = RandomUniformExcept(RNG_METRONOME, 1, moveCount - 1, InvalidMetronomeMove);
|
gCurrentMove = RandomUniformExcept(RNG_METRONOME, 1, moveCount - 1, InvalidMetronomeMove);
|
||||||
gHitMarker &= ~HITMARKER_ATTACKSTRING_PRINTED;
|
|
||||||
SetAtkCancellerForCalledMove();
|
SetAtkCancellerForCalledMove();
|
||||||
|
PrepareStringBattle(STRINGID_WAGGLINGAFINGER, gBattlerAttacker);
|
||||||
gBattlescriptCurrInstr = GET_MOVE_BATTLESCRIPT(gCurrentMove);
|
gBattlescriptCurrInstr = GET_MOVE_BATTLESCRIPT(gCurrentMove);
|
||||||
gBattlerTarget = GetMoveTarget(gCurrentMove, NO_TARGET_OVERRIDE);
|
gBattlerTarget = GetMoveTarget(gCurrentMove, NO_TARGET_OVERRIDE);
|
||||||
}
|
}
|
||||||
|
|
|
@ -4469,7 +4469,7 @@ u32 AbilityBattleEffects(u32 caseID, u32 battler, u32 ability, u32 special, u32
|
||||||
RecordAbilityBattle(chosenTarget, gLastUsedAbility); // Record the opposing battler has this ability
|
RecordAbilityBattle(chosenTarget, gLastUsedAbility); // Record the opposing battler has this ability
|
||||||
gBattlerAbility = battler;
|
gBattlerAbility = battler;
|
||||||
|
|
||||||
PREPARE_MON_NICK_WITH_PREFIX_BUFFER(gBattleTextBuff1, chosenTarget, gBattlerPartyIndexes[chosenTarget])
|
PREPARE_MON_NICK_WITH_PREFIX_LOWER_BUFFER(gBattleTextBuff1, chosenTarget, gBattlerPartyIndexes[chosenTarget])
|
||||||
PREPARE_ABILITY_BUFFER(gBattleTextBuff2, gLastUsedAbility)
|
PREPARE_ABILITY_BUFFER(gBattleTextBuff2, gLastUsedAbility)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "gba/defines.h"
|
#include "gba/defines.h"
|
||||||
#include "config/general.h"
|
#include "config/general.h"
|
||||||
#include "constants/characters.h"
|
#include "constants/characters.h"
|
||||||
|
#include "string_util.h"
|
||||||
|
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
|
|
||||||
|
|
|
@ -5925,7 +5925,7 @@ void SetMonPreventsSwitchingString(void)
|
||||||
|
|
||||||
PREPARE_MON_NICK_WITH_PREFIX_BUFFER(gBattleTextBuff2, gBattlerInMenuId, GetPartyIdFromBattlePartyId(gBattlerPartyIndexes[gBattlerInMenuId]))
|
PREPARE_MON_NICK_WITH_PREFIX_BUFFER(gBattleTextBuff2, gBattlerInMenuId, GetPartyIdFromBattlePartyId(gBattlerPartyIndexes[gBattlerInMenuId]))
|
||||||
|
|
||||||
BattleStringExpandPlaceholders(gText_PkmnsXPreventsSwitching, gStringVar4);
|
BattleStringExpandPlaceholders(gText_PkmnsXPreventsSwitching, gStringVar4, sizeof(gStringVar4));
|
||||||
}
|
}
|
||||||
|
|
||||||
static s32 GetWildMonTableIdInAlteringCave(u16 species)
|
static s32 GetWildMonTableIdInAlteringCave(u16 species)
|
||||||
|
|
|
@ -122,6 +122,28 @@ u16 StringLength(const u8 *str)
|
||||||
return length;
|
return length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u16 StringLineLength(const u8 *str)
|
||||||
|
{
|
||||||
|
u16 i = 0, length = 0;
|
||||||
|
|
||||||
|
while (str[length] != EOS)
|
||||||
|
{
|
||||||
|
switch (str[length])
|
||||||
|
{
|
||||||
|
case CHAR_PROMPT_SCROLL:
|
||||||
|
case CHAR_PROMPT_CLEAR:
|
||||||
|
case CHAR_NEWLINE:
|
||||||
|
return length;
|
||||||
|
default:
|
||||||
|
i++;
|
||||||
|
length++;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return length;
|
||||||
|
}
|
||||||
|
|
||||||
s32 StringCompare(const u8 *str1, const u8 *str2)
|
s32 StringCompare(const u8 *str1, const u8 *str2)
|
||||||
{
|
{
|
||||||
while (*str1 == *str2)
|
while (*str1 == *str2)
|
||||||
|
|
36
src/text.c
36
src/text.c
|
@ -1423,6 +1423,16 @@ static u32 (*GetFontWidthFunc(u8 fontId))(u16, bool32)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
s32 GetGlyphWidth(u16 glyphId, bool32 isJapanese, u8 fontId)
|
||||||
|
{
|
||||||
|
u32 (*func)(u16 fontId, bool32 isJapanese);
|
||||||
|
|
||||||
|
func = GetFontWidthFunc(fontId);
|
||||||
|
if (func == NULL)
|
||||||
|
return 0;
|
||||||
|
return func(glyphId, isJapanese);
|
||||||
|
}
|
||||||
|
|
||||||
s32 GetStringWidth(u8 fontId, const u8 *str, s16 letterSpacing)
|
s32 GetStringWidth(u8 fontId, const u8 *str, s16 letterSpacing)
|
||||||
{
|
{
|
||||||
bool32 isJapanese;
|
bool32 isJapanese;
|
||||||
|
@ -1595,6 +1605,32 @@ s32 GetStringWidth(u8 fontId, const u8 *str, s16 letterSpacing)
|
||||||
return width;
|
return width;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
s32 GetStringLineWidth(u8 fontId, const u8 *str, s16 letterSpacing, u32 lineNum, u32 strSize, bool32 printDebug)
|
||||||
|
{
|
||||||
|
u32 strWidth = 0, strLen, currLine;
|
||||||
|
u8 strCopy[strSize];
|
||||||
|
|
||||||
|
for (currLine = 1; currLine <= lineNum; currLine++)
|
||||||
|
{
|
||||||
|
strWidth = GetStringWidth(fontId, str, letterSpacing);
|
||||||
|
strLen = StringLineLength(str);
|
||||||
|
memset(strCopy, EOS, strSize);
|
||||||
|
if (currLine == lineNum && strLen != 0)
|
||||||
|
{
|
||||||
|
StringCopyN(strCopy, str, strLen);
|
||||||
|
strWidth = GetStringWidth(fontId, strCopy, letterSpacing);
|
||||||
|
strLen = StringLineLength(strCopy);
|
||||||
|
StringAppend(strCopy, gText_EmptyString3);
|
||||||
|
#ifndef NDEBUG
|
||||||
|
if (printDebug && strWidth != 0)
|
||||||
|
DebugPrintf(" Line %d, len:%d, width:%d, \"%S\"", currLine, strLen, strWidth, strCopy);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
str += strLen + 1;
|
||||||
|
}
|
||||||
|
return strWidth;
|
||||||
|
}
|
||||||
|
|
||||||
u8 RenderTextHandleBold(u8 *pixels, u8 fontId, u8 *str)
|
u8 RenderTextHandleBold(u8 *pixels, u8 fontId, u8 *str)
|
||||||
{
|
{
|
||||||
u8 shadowColor;
|
u8 shadowColor;
|
||||||
|
|
|
@ -11,7 +11,7 @@ SINGLE_BATTLE_TEST("Aftermath damages the attacker by 1/4th of its max HP if fai
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN {MOVE(opponent, MOVE_TACKLE);}
|
TURN {MOVE(opponent, MOVE_TACKLE);}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Tackle!");
|
MESSAGE("The opposing Wobbuffet used Tackle!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
MESSAGE("Voltorb fainted!");
|
MESSAGE("Voltorb fainted!");
|
||||||
ABILITY_POPUP(player, ABILITY_AFTERMATH);
|
ABILITY_POPUP(player, ABILITY_AFTERMATH);
|
||||||
|
|
|
@ -32,7 +32,7 @@ SINGLE_BATTLE_TEST("Anger Point does not trigger when already at maximum Attack
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_BELLY_DRUM, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_BELLY_DRUM, player);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Primeape cut its own HP and maximized ATTACK!");
|
MESSAGE("Primeape cut its own HP and maximized its Attack!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FROST_BREATH, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FROST_BREATH, opponent);
|
||||||
MESSAGE("A critical hit!");
|
MESSAGE("A critical hit!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
|
@ -58,7 +58,7 @@ SINGLE_BATTLE_TEST("Anger Point does not trigger when a substitute takes the hit
|
||||||
TURN { MOVE(player, MOVE_SUBSTITUTE); MOVE(opponent, MOVE_FROST_BREATH); }
|
TURN { MOVE(player, MOVE_SUBSTITUTE); MOVE(opponent, MOVE_FROST_BREATH); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUBSTITUTE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUBSTITUTE, player);
|
||||||
MESSAGE("Primeape made a SUBSTITUTE!");
|
MESSAGE("Primeape put in a substitute!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FROST_BREATH, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FROST_BREATH, opponent);
|
||||||
MESSAGE("A critical hit!");
|
MESSAGE("A critical hit!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
|
|
|
@ -15,13 +15,13 @@ SINGLE_BATTLE_TEST("Bad Dreams causes the sleeping enemy Pokemon to lose 1/8 of
|
||||||
} SCENE {
|
} SCENE {
|
||||||
if (status == STATUS1_SLEEP) {
|
if (status == STATUS1_SLEEP) {
|
||||||
ABILITY_POPUP(player, ABILITY_BAD_DREAMS);
|
ABILITY_POPUP(player, ABILITY_BAD_DREAMS);
|
||||||
MESSAGE("Foe Wobbuffet is tormented!");
|
MESSAGE("The opposing Wobbuffet is tormented!");
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_BAD_DREAMS);
|
ABILITY_POPUP(player, ABILITY_BAD_DREAMS);
|
||||||
MESSAGE("Foe Wobbuffet is tormented!");
|
MESSAGE("The opposing Wobbuffet is tormented!");
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -115,11 +115,11 @@ DOUBLE_BATTLE_TEST("Bad Dreams faints both sleeping Pokemon on opponent side")
|
||||||
TURN {SEND_OUT(opponentLeft, 2); SEND_OUT(opponentRight, 3);}
|
TURN {SEND_OUT(opponentLeft, 2); SEND_OUT(opponentRight, 3);}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_BAD_DREAMS);
|
ABILITY_POPUP(playerLeft, ABILITY_BAD_DREAMS);
|
||||||
MESSAGE("Foe Wobbuffet is tormented!");
|
MESSAGE("The opposing Wobbuffet is tormented!");
|
||||||
HP_BAR(opponentLeft);
|
HP_BAR(opponentLeft);
|
||||||
MESSAGE("Foe Wobbuffet fainted!");
|
MESSAGE("The opposing Wobbuffet fainted!");
|
||||||
MESSAGE("Foe Wobbuffet is tormented!");
|
MESSAGE("The opposing Wobbuffet is tormented!");
|
||||||
HP_BAR(opponentRight);
|
HP_BAR(opponentRight);
|
||||||
MESSAGE("Foe Wobbuffet fainted!");
|
MESSAGE("The opposing Wobbuffet fainted!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ SINGLE_BATTLE_TEST("Battle Bond does not transform species other than Greninja")
|
||||||
TURN { MOVE(player, MOVE_WATER_GUN); SEND_OUT(opponent, 1); }
|
TURN { MOVE(player, MOVE_WATER_GUN); SEND_OUT(opponent, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
MESSAGE("Foe Wobbuffet fainted!");
|
MESSAGE("The opposing Wobbuffet fainted!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_BATTLE_BOND);
|
ABILITY_POPUP(player, ABILITY_BATTLE_BOND);
|
||||||
MESSAGE("Wobbuffet became fully charged due to its bond with its trainer!");
|
MESSAGE("Wobbuffet became fully charged due to its bond with its trainer!");
|
||||||
|
@ -54,7 +54,7 @@ SINGLE_BATTLE_TEST("Battle Bond transforms player's Greninja - Singles")
|
||||||
|
|
||||||
} SCENE {
|
} SCENE {
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
MESSAGE("Foe Wobbuffet fainted!");
|
MESSAGE("The opposing Wobbuffet fainted!");
|
||||||
if (monsCountOpponent != 1) {
|
if (monsCountOpponent != 1) {
|
||||||
ABILITY_POPUP(player, ABILITY_BATTLE_BOND);
|
ABILITY_POPUP(player, ABILITY_BATTLE_BOND);
|
||||||
MESSAGE("Greninja became fully charged due to its bond with its trainer!");
|
MESSAGE("Greninja became fully charged due to its bond with its trainer!");
|
||||||
|
@ -104,12 +104,12 @@ SINGLE_BATTLE_TEST("Battle Bond transforms opponent's Greninja - Singles")
|
||||||
MESSAGE("Wobbuffet fainted!");
|
MESSAGE("Wobbuffet fainted!");
|
||||||
if (monsCountPlayer != 1) {
|
if (monsCountPlayer != 1) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_BATTLE_BOND);
|
ABILITY_POPUP(opponent, ABILITY_BATTLE_BOND);
|
||||||
MESSAGE("Foe Greninja became fully charged due to its bond with its trainer!");
|
MESSAGE("The opposing Greninja became fully charged due to its bond with its trainer!");
|
||||||
MESSAGE("Foe Greninja became Ash-Greninja!");
|
MESSAGE("The opposing Greninja became Ash-Greninja!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_BATTLE_BOND);
|
ABILITY_POPUP(opponent, ABILITY_BATTLE_BOND);
|
||||||
MESSAGE("Foe Greninja became fully charged due to its bond with its trainer!");
|
MESSAGE("The opposing Greninja became fully charged due to its bond with its trainer!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} FINALLY {
|
} FINALLY {
|
||||||
|
|
|
@ -70,6 +70,6 @@ SINGLE_BATTLE_TEST("Beads of Ruin's message displays correctly after all battler
|
||||||
SEND_IN_MESSAGE("Wobbuffet");
|
SEND_IN_MESSAGE("Wobbuffet");
|
||||||
MESSAGE("2 sent out Chi-Yu!");
|
MESSAGE("2 sent out Chi-Yu!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_BEADS_OF_RUIN);
|
ABILITY_POPUP(opponent, ABILITY_BEADS_OF_RUIN);
|
||||||
MESSAGE("Foe Chi-Yu's Beads of Ruin weakened the Sp. Def of all surrounding Pokémon!");
|
MESSAGE("The opposing Chi-Yu's Beads of Ruin weakened the Sp. Def of all surrounding Pokémon!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,11 +26,11 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke prevent intimid
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo's Full Metal Body prevents stat loss!");
|
MESSAGE("The opposing Solgaleo's Full Metal Body prevents stat loss!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal's White Smoke prevents stat loss!");
|
MESSAGE("The opposing Torkoal's White Smoke prevents stat loss!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang's Clear Body prevents stat loss!");
|
MESSAGE("The opposing Metang's Clear Body prevents stat loss!");
|
||||||
HP_BAR(player, captureDamage: &turnTwoHit);
|
HP_BAR(player, captureDamage: &turnTwoHit);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(turnOneHit, turnTwoHit);
|
EXPECT_EQ(turnOneHit, turnTwoHit);
|
||||||
|
@ -76,11 +76,11 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke prevent stat st
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo's Full Metal Body prevents stat loss!");
|
MESSAGE("The opposing Solgaleo's Full Metal Body prevents stat loss!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal's White Smoke prevents stat loss!");
|
MESSAGE("The opposing Torkoal's White Smoke prevents stat loss!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang's Clear Body prevents stat loss!");
|
MESSAGE("The opposing Metang's Clear Body prevents stat loss!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,11 +104,11 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke prevent Sticky
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo's Full Metal Body prevents stat loss!");
|
MESSAGE("The opposing Solgaleo's Full Metal Body prevents stat loss!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal's White Smoke prevents stat loss!");
|
MESSAGE("The opposing Torkoal's White Smoke prevents stat loss!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang's Clear Body prevents stat loss!");
|
MESSAGE("The opposing Metang's Clear Body prevents stat loss!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,9 +128,9 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke don't prevent s
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUPERPOWER, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUPERPOWER, opponent);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
MESSAGE("Foe Solgaleo's Full Metal Body prevents stat loss!");
|
MESSAGE("The opposing Solgaleo's Full Metal Body prevents stat loss!");
|
||||||
MESSAGE("Foe Torkoal's White Smoke prevents stat loss!");
|
MESSAGE("The opposing Torkoal's White Smoke prevents stat loss!");
|
||||||
MESSAGE("Foe Metang's Clear Body prevents stat loss!");
|
MESSAGE("The opposing Metang's Clear Body prevents stat loss!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -181,15 +181,15 @@ SINGLE_BATTLE_TEST("Mold Breaker, Teravolt, and Turboblaze ignore Clear Body and
|
||||||
if (ability == ABILITY_FULL_METAL_BODY){ // Full Metal Body can't be ignored by breaker abilities
|
if (ability == ABILITY_FULL_METAL_BODY){ // Full Metal Body can't be ignored by breaker abilities
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, move, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
MESSAGE("Foe Solgaleo's Full Metal Body prevents stat loss!");
|
MESSAGE("The opposing Solgaleo's Full Metal Body prevents stat loss!");
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
MESSAGE("Foe Solgaleo's Full Metal Body prevents stat loss!");
|
MESSAGE("The opposing Solgaleo's Full Metal Body prevents stat loss!");
|
||||||
MESSAGE("Foe Torkoal's White Smoke prevents stat loss!");
|
MESSAGE("The opposing Torkoal's White Smoke prevents stat loss!");
|
||||||
MESSAGE("Foe Metang's Clear Body prevents stat loss!");
|
MESSAGE("The opposing Metang's Clear Body prevents stat loss!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -220,18 +220,18 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke don't prevent S
|
||||||
if (heldItem == ITEM_IRON_BALL) {
|
if (heldItem == ITEM_IRON_BALL) {
|
||||||
MESSAGE("Wobbuffet used Celebrate!");
|
MESSAGE("Wobbuffet used Celebrate!");
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
} else {
|
} else {
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
MESSAGE("Wobbuffet used Celebrate!");
|
MESSAGE("Wobbuffet used Celebrate!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -253,22 +253,22 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke don't prevent S
|
||||||
TURN { MOVE(player, MOVE_THUNDER_WAVE); }
|
TURN { MOVE(player, MOVE_THUNDER_WAVE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
MESSAGE("Wobbuffet used Thunder Wave!");
|
MESSAGE("Wobbuffet used Thunder Wave!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_THUNDER_WAVE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_THUNDER_WAVE, player);
|
||||||
NOT ABILITY_POPUP(opponent, ability);
|
NOT ABILITY_POPUP(opponent, ability);
|
||||||
MESSAGE("Wobbuffet used Thunder Wave!");
|
MESSAGE("Wobbuffet used Thunder Wave!");
|
||||||
ONE_OF {
|
ONE_OF {
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
MESSAGE("Foe Metang is paralyzed! It can't move!");
|
MESSAGE("The opposing Metang couldn't move because it's paralyzed!");
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
MESSAGE("Foe Solgaleo is paralyzed! It can't move!");
|
MESSAGE("The opposing Solgaleo couldn't move because it's paralyzed!");
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
MESSAGE("Foe Torkoal is paralyzed! It can't move!");
|
MESSAGE("The opposing Torkoal couldn't move because it's paralyzed!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -319,11 +319,11 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke don't prevent r
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SCARY_FACE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SCARY_FACE, player);
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -351,16 +351,16 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke don't prevent T
|
||||||
NOT ABILITY_POPUP(opponent, ability);
|
NOT ABILITY_POPUP(opponent, ability);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOPSY_TURVY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOPSY_TURVY, player);
|
||||||
if (ability == ABILITY_FULL_METAL_BODY) {
|
if (ability == ABILITY_FULL_METAL_BODY) {
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
}
|
}
|
||||||
else if (ability == ABILITY_WHITE_SMOKE) {
|
else if (ability == ABILITY_WHITE_SMOKE) {
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
}
|
}
|
||||||
MESSAGE("Wobbuffet used Scary Face!");
|
MESSAGE("Wobbuffet used Scary Face!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_SCARY_FACE, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_SCARY_FACE, player);
|
||||||
|
@ -387,28 +387,28 @@ SINGLE_BATTLE_TEST("Clear Body, Full Metal Body, and White Smoke don't prevent S
|
||||||
TURN{ }
|
TURN{ }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo used Agility!");
|
MESSAGE("The opposing Solgaleo used Agility!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal used Agility!");
|
MESSAGE("The opposing Torkoal used Agility!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang used Agility!");
|
MESSAGE("The opposing Metang used Agility!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_AGILITY, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_AGILITY, opponent);
|
||||||
MESSAGE("Wobbuffet used Celebrate!");
|
MESSAGE("Wobbuffet used Celebrate!");
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
MESSAGE("Wobbuffet used Spectral Thief!");
|
MESSAGE("Wobbuffet used Spectral Thief!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPECTRAL_THIEF, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPECTRAL_THIEF, player);
|
||||||
NOT ABILITY_POPUP(opponent, ability);
|
NOT ABILITY_POPUP(opponent, ability);
|
||||||
MESSAGE("Wobbuffet used Celebrate!");
|
MESSAGE("Wobbuffet used Celebrate!");
|
||||||
if (ability == ABILITY_FULL_METAL_BODY)
|
if (ability == ABILITY_FULL_METAL_BODY)
|
||||||
MESSAGE("Foe Solgaleo used Celebrate!");
|
MESSAGE("The opposing Solgaleo used Celebrate!");
|
||||||
else if (ability == ABILITY_WHITE_SMOKE)
|
else if (ability == ABILITY_WHITE_SMOKE)
|
||||||
MESSAGE("Foe Torkoal used Celebrate!");
|
MESSAGE("The opposing Torkoal used Celebrate!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Metang used Celebrate!");
|
MESSAGE("The opposing Metang used Celebrate!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,16 +15,16 @@ SINGLE_BATTLE_TEST("Cloud Nine/Air Lock prevent basic weather effects, but witho
|
||||||
TURN {}
|
TURN {}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ability);
|
ABILITY_POPUP(player, ability);
|
||||||
MESSAGE("The effects of weather disappeared.");
|
MESSAGE("The effects of the weather disappeared.");
|
||||||
MESSAGE("Foe Wobbuffet used Sandstorm!");
|
MESSAGE("The opposing Wobbuffet used Sandstorm!");
|
||||||
MESSAGE("The sandstorm rages.");
|
MESSAGE("The sandstorm is raging.");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_SANDSTORM_CONTINUES);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_SANDSTORM_CONTINUES);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
MESSAGE("Foe Wobbuffet is buffeted by the sandstorm!");
|
MESSAGE("The opposing Wobbuffet is buffeted by the sandstorm!");
|
||||||
}
|
}
|
||||||
MESSAGE("The sandstorm rages.");
|
MESSAGE("The sandstorm is raging.");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_SANDSTORM_CONTINUES);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_SANDSTORM_CONTINUES);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,7 @@ SINGLE_BATTLE_TEST("Color Change changes the type of a Pokemon being hit by a mo
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, player);
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Wobbuffet's Color Change made it the Normal type!");
|
MESSAGE("The opposing Wobbuffet's Color Change made it the Normal type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,7 +26,7 @@ SINGLE_BATTLE_TEST("Color Change does not change the type when hit by a move tha
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Wobbuffet's Color Change made it the Normal type!");
|
MESSAGE("The opposing Wobbuffet's Color Change made it the Normal type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,7 @@ SINGLE_BATTLE_TEST("Color Change does not change the type of a dual-type Pokemon
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Xatu's Color Change made it the Psychic type!");
|
MESSAGE("The opposing Xatu's Color Change made it the Psychic type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@ SINGLE_BATTLE_TEST("Color Change does not change the type of a dual-type Pokemon
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Slowbro's Color Change made it the Psychic type!");
|
MESSAGE("The opposing Slowbro's Color Change made it the Psychic type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -73,7 +73,7 @@ SINGLE_BATTLE_TEST("Color Change changes the user to Electric type if hit by a m
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PSYCHO_CUT, player);
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Wobbuffet's Color Change made it the Electric type!");
|
MESSAGE("The opposing Wobbuffet's Color Change made it the Electric type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,9 +88,9 @@ SINGLE_BATTLE_TEST("Color Change changes the type when a Pokemon is hit by Futur
|
||||||
TURN { }
|
TURN { }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FUTURE_SIGHT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FUTURE_SIGHT, player);
|
||||||
MESSAGE("Foe Snorlax took the Future Sight attack!");
|
MESSAGE("The opposing Snorlax took the Future Sight attack!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Snorlax's Color Change made it the Psychic type!");
|
MESSAGE("The opposing Snorlax's Color Change made it the Psychic type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -105,9 +105,9 @@ SINGLE_BATTLE_TEST("Color Change changes the type when a Pokemon is hit by Doom
|
||||||
TURN { }
|
TURN { }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_DOOM_DESIRE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_DOOM_DESIRE, player);
|
||||||
MESSAGE("Foe Wobbuffet took the Doom Desire attack!");
|
MESSAGE("The opposing Wobbuffet took the Doom Desire attack!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Wobbuffet's Color Change made it the Steel type!");
|
MESSAGE("The opposing Wobbuffet's Color Change made it the Steel type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -123,10 +123,10 @@ SINGLE_BATTLE_TEST("Color Change changes the type to Electric when a Pokemon is
|
||||||
TURN { MOVE(opponent, MOVE_ELECTRIFY); }
|
TURN { MOVE(opponent, MOVE_ELECTRIFY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FUTURE_SIGHT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FUTURE_SIGHT, player);
|
||||||
MESSAGE("Foe Blastoise took the Future Sight attack!");
|
MESSAGE("The opposing Blastoise took the Future Sight attack!");
|
||||||
MESSAGE("It's super effective!");
|
MESSAGE("It's super effective!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Blastoise's Color Change made it the Electr type!");
|
MESSAGE("The opposing Blastoise's Color Change made it the Electr type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -141,8 +141,8 @@ SINGLE_BATTLE_TEST("Color Change changes the type to Normal when a Pokemon is hi
|
||||||
TURN { }
|
TURN { }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FUTURE_SIGHT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FUTURE_SIGHT, player);
|
||||||
MESSAGE("Foe Blastoise took the Future Sight attack!");
|
MESSAGE("The opposing Blastoise took the Future Sight attack!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
ABILITY_POPUP(opponent, ABILITY_COLOR_CHANGE);
|
||||||
MESSAGE("Foe Blastoise's Color Change made it the Normal type!");
|
MESSAGE("The opposing Blastoise's Color Change made it the Normal type!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,8 +45,8 @@ SINGLE_BATTLE_TEST("Comatose may be suppressed if pokemon transformed into a pok
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Komala is drowsing!");
|
MESSAGE("Komala is drowsing!");
|
||||||
MESSAGE("Komala used Gastro Acid!");
|
MESSAGE("Komala used Gastro Acid!");
|
||||||
MESSAGE("Foe Ditto used Transform!");
|
MESSAGE("The opposing Ditto used Transform!");
|
||||||
MESSAGE("Foe Ditto transformed into Komala!");
|
MESSAGE("The opposing Ditto transformed into Komala!");
|
||||||
|
|
||||||
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
if (move == MOVE_POISONPOWDER) { STATUS_ICON(opponent, poison: TRUE); }
|
if (move == MOVE_POISONPOWDER) { STATUS_ICON(opponent, poison: TRUE); }
|
||||||
|
|
|
@ -51,7 +51,7 @@ DOUBLE_BATTLE_TEST("Commander Tatsugiri avoids moves targetted towards it")
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentLeft);
|
||||||
MESSAGE("Foe Wobbuffet's attack missed!");
|
MESSAGE("The opposing Wobbuffet's attack missed!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_POUND, opponentRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_POUND, opponentRight);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -71,7 +71,7 @@ DOUBLE_BATTLE_TEST("Commander Tatsugiri will still take residual damage from a f
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_SAND_STREAM);
|
ABILITY_POPUP(opponentLeft, ABILITY_SAND_STREAM);
|
||||||
MESSAGE("Dondozo is buffeted by the sandstorm!");
|
MESSAGE("Dondozo is buffeted by the sandstorm!");
|
||||||
MESSAGE("Tatsugiri is buffeted by the sandstorm!");
|
MESSAGE("Tatsugiri is buffeted by the sandstorm!");
|
||||||
MESSAGE("Foe Wobbuffet is buffeted by the sandstorm!");
|
MESSAGE("The opposing Wobbuffet is buffeted by the sandstorm!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ DOUBLE_BATTLE_TEST("Commander Tatsugiri will still take poison damage if while i
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
MESSAGE("Tatsugiri is hurt by poison!");
|
MESSAGE("Tatsugiri was hurt by its poisoning!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,7 +104,7 @@ DOUBLE_BATTLE_TEST("Commander Tatsugiri still avoids moves even when the attacke
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentLeft);
|
||||||
MESSAGE("Foe Machamp's attack missed!");
|
MESSAGE("The opposing Machamp's attack missed!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ DOUBLE_BATTLE_TEST("Commander cannot affect a Dondozo that was previously affect
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
MESSAGE("Tatsugiri is hurt by poison!");
|
MESSAGE("Tatsugiri was hurt by its poisoning!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
|
@ -144,9 +144,9 @@ DOUBLE_BATTLE_TEST("Commander prevents Whirlwind from working against Dondozo or
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
MESSAGE("Foe Wobbuffet used Whirlwind!");
|
MESSAGE("The opposing Wobbuffet used Whirlwind!");
|
||||||
MESSAGE("But it failed!");
|
MESSAGE("But it failed!");
|
||||||
MESSAGE("Foe Wobbuffet used Whirlwind!");
|
MESSAGE("The opposing Wobbuffet used Whirlwind!");
|
||||||
MESSAGE("But it failed!");
|
MESSAGE("But it failed!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -250,7 +250,7 @@ DOUBLE_BATTLE_TEST("Commander doesn't prevent Imposter from working on a Command
|
||||||
ABILITY_POPUP(playerRight, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerRight, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_IMPOSTER);
|
ABILITY_POPUP(opponentRight, ABILITY_IMPOSTER);
|
||||||
MESSAGE("Foe Ditto transformed into Tatsugiri using Imposter!");
|
MESSAGE("The opposing Ditto transformed into Tatsugiri using Imposter!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -270,17 +270,17 @@ DOUBLE_BATTLE_TEST("Commander Tatsugiri is still affected by Perish Song while c
|
||||||
ABILITY_POPUP(playerRight, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerRight, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PERISH_SONG, opponentLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PERISH_SONG, opponentLeft);
|
||||||
MESSAGE("All affected POKéMON will faint in three turns!");
|
MESSAGE("All Pokémon that heard the song will faint in three turns!");
|
||||||
MESSAGE("Dondozo's PERISH count fell to 0!");
|
MESSAGE("Dondozo's perish count fell to 0!");
|
||||||
MESSAGE("Dondozo fainted!");
|
MESSAGE("Dondozo fainted!");
|
||||||
MESSAGE("Foe Wobbuffet's PERISH count fell to 0!");
|
MESSAGE("The opposing Wobbuffet's perish count fell to 0!");
|
||||||
MESSAGE("Foe Wobbuffet fainted!");
|
MESSAGE("The opposing Wobbuffet fainted!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
MESSAGE("Tatsugiri's PERISH count fell to 0!");
|
MESSAGE("Tatsugiri's perish count fell to 0!");
|
||||||
MESSAGE("Tatsugiri fainted!");
|
MESSAGE("Tatsugiri fainted!");
|
||||||
}
|
}
|
||||||
MESSAGE("Foe Wynaut's PERISH count fell to 0!");
|
MESSAGE("The opposing Wynaut's perish count fell to 0!");
|
||||||
MESSAGE("Foe Wynaut fainted!");
|
MESSAGE("The opposing Wynaut fainted!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -323,7 +323,7 @@ DOUBLE_BATTLE_TEST("Commander Attacker is kept (Dondozo Left Slot)")
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SURF, opponentLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SURF, opponentLeft);
|
||||||
HP_BAR(playerLeft);
|
HP_BAR(playerLeft);
|
||||||
MESSAGE("Foe Wobbuffet's attack missed!");
|
MESSAGE("The opposing Wobbuffet's attack missed!");
|
||||||
HP_BAR(opponentRight);
|
HP_BAR(opponentRight);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -344,7 +344,7 @@ DOUBLE_BATTLE_TEST("Commander Attacker is kept (Dondozo Right Slot)")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentRight);
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
ABILITY_POPUP(playerLeft, ABILITY_COMMANDER);
|
||||||
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
MESSAGE("Tatsugiri was swallowed by Dondozo and became Dondozo's commander!");
|
||||||
MESSAGE("Foe Wobbuffet's attack missed!");
|
MESSAGE("The opposing Wobbuffet's attack missed!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SURF, opponentLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SURF, opponentLeft);
|
||||||
HP_BAR(playerRight);
|
HP_BAR(playerRight);
|
||||||
HP_BAR(opponentRight);
|
HP_BAR(opponentRight);
|
||||||
|
|
|
@ -21,7 +21,7 @@ SINGLE_BATTLE_TEST("Contrary raises Attack when Intimidated in a single battle",
|
||||||
if (ability == ABILITY_CONTRARY) {
|
if (ability == ABILITY_CONTRARY) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Attack rose!");
|
MESSAGE("The opposing Spinda's Attack rose!");
|
||||||
}
|
}
|
||||||
HP_BAR(player, captureDamage: &results[i].damage);
|
HP_BAR(player, captureDamage: &results[i].damage);
|
||||||
}
|
}
|
||||||
|
@ -51,18 +51,18 @@ DOUBLE_BATTLE_TEST("Contrary raises Attack when Intimidated in a double battle",
|
||||||
if (abilityLeft == ABILITY_CONTRARY) {
|
if (abilityLeft == ABILITY_CONTRARY) {
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_CONTRARY);
|
ABILITY_POPUP(opponentLeft, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Spinda's Attack rose!");
|
MESSAGE("The opposing Spinda's Attack rose!");
|
||||||
} else {
|
} else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Mightyena's Intimidate cuts Foe Spinda's attack!");
|
MESSAGE("Mightyena's Intimidate cuts the opposing Spinda's attack!");
|
||||||
}
|
}
|
||||||
if (abilityRight == ABILITY_CONTRARY) {
|
if (abilityRight == ABILITY_CONTRARY) {
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_CONTRARY);
|
ABILITY_POPUP(opponentRight, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Spinda's Attack rose!");
|
MESSAGE("The opposing Spinda's Attack rose!");
|
||||||
} else {
|
} else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Mightyena's Intimidate cuts Foe Spinda's attack!");
|
MESSAGE("Mightyena's Intimidate cuts the opposing Spinda's attack!");
|
||||||
}
|
}
|
||||||
HP_BAR(playerLeft, captureDamage: &results[i].damageLeft);
|
HP_BAR(playerLeft, captureDamage: &results[i].damageLeft);
|
||||||
HP_BAR(playerRight, captureDamage: &results[i].damageRight);
|
HP_BAR(playerRight, captureDamage: &results[i].damageRight);
|
||||||
|
@ -90,28 +90,28 @@ SINGLE_BATTLE_TEST("Contrary raises stats after using a move which would normall
|
||||||
TURN { MOVE(opponent, MOVE_OVERHEAT); }
|
TURN { MOVE(opponent, MOVE_OVERHEAT); }
|
||||||
TURN { MOVE(opponent, MOVE_OVERHEAT); }
|
TURN { MOVE(opponent, MOVE_OVERHEAT); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Spinda used Overheat!");
|
MESSAGE("The opposing Spinda used Overheat!");
|
||||||
HP_BAR(player, captureDamage: &results[i].damageBefore);
|
HP_BAR(player, captureDamage: &results[i].damageBefore);
|
||||||
if (ability == ABILITY_CONTRARY) {
|
if (ability == ABILITY_CONTRARY) {
|
||||||
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Sp. Atk sharply rose!");
|
MESSAGE("The opposing Spinda's Sp. Atk sharply rose!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Sp. Atk harshly fell!");
|
MESSAGE("The opposing Spinda's Sp. Atk harshly fell!");
|
||||||
}
|
}
|
||||||
|
|
||||||
// MESSAGE("Foe Spinda used Overheat!");
|
// MESSAGE("The opposing Spinda used Overheat!");
|
||||||
HP_BAR(player, captureDamage: &results[i].damageAfter);
|
HP_BAR(player, captureDamage: &results[i].damageAfter);
|
||||||
if (ability == ABILITY_CONTRARY) {
|
if (ability == ABILITY_CONTRARY) {
|
||||||
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Sp. Atk sharply rose!");
|
MESSAGE("The opposing Spinda's Sp. Atk sharply rose!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Sp. Atk harshly fell!");
|
MESSAGE("The opposing Spinda's Sp. Atk harshly fell!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
FINALLY {
|
FINALLY {
|
||||||
|
@ -134,21 +134,21 @@ SINGLE_BATTLE_TEST("Contrary lowers a stat after using a move which would normal
|
||||||
TURN { MOVE(opponent, MOVE_SWORDS_DANCE); }
|
TURN { MOVE(opponent, MOVE_SWORDS_DANCE); }
|
||||||
TURN { MOVE(opponent, MOVE_TACKLE); }
|
TURN { MOVE(opponent, MOVE_TACKLE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Spinda used Tackle!");
|
MESSAGE("The opposing Spinda used Tackle!");
|
||||||
HP_BAR(player, captureDamage: &results[i].damageBefore);
|
HP_BAR(player, captureDamage: &results[i].damageBefore);
|
||||||
|
|
||||||
//MESSAGE("Foe Spinda used Swords Dance!");
|
//MESSAGE("The opposing Spinda used Swords Dance!");
|
||||||
if (ability == ABILITY_CONTRARY) {
|
if (ability == ABILITY_CONTRARY) {
|
||||||
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Attack harshly fell!");
|
MESSAGE("The opposing Spinda's Attack harshly fell!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Attack sharply rose!");
|
MESSAGE("The opposing Spinda's Attack sharply rose!");
|
||||||
}
|
}
|
||||||
|
|
||||||
// MESSAGE("Foe Spinda used Tackle!");
|
// MESSAGE("The opposing Spinda used Tackle!");
|
||||||
HP_BAR(player, captureDamage: &results[i].damageAfter);
|
HP_BAR(player, captureDamage: &results[i].damageAfter);
|
||||||
}
|
}
|
||||||
FINALLY {
|
FINALLY {
|
||||||
|
@ -173,14 +173,14 @@ SINGLE_BATTLE_TEST("Contrary raises a stat after using a move which would normal
|
||||||
if (ability == ABILITY_CONTRARY) {
|
if (ability == ABILITY_CONTRARY) {
|
||||||
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
// ABILITY_POPUP(opponent, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Attack rose!");
|
MESSAGE("The opposing Spinda's Attack rose!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda's Attack fell!");
|
MESSAGE("The opposing Spinda's Attack fell!");
|
||||||
}
|
}
|
||||||
|
|
||||||
MESSAGE("Foe Spinda used Tackle!");
|
MESSAGE("The opposing Spinda used Tackle!");
|
||||||
HP_BAR(player, captureDamage: &results[i].damage);
|
HP_BAR(player, captureDamage: &results[i].damage);
|
||||||
}
|
}
|
||||||
FINALLY {
|
FINALLY {
|
||||||
|
@ -202,16 +202,16 @@ SINGLE_BATTLE_TEST("Contrary lowers a stat after using a move which would normal
|
||||||
TURN { MOVE(opponent, MOVE_BELLY_DRUM); }
|
TURN { MOVE(opponent, MOVE_BELLY_DRUM); }
|
||||||
TURN { MOVE(opponent, MOVE_TACKLE); }
|
TURN { MOVE(opponent, MOVE_TACKLE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Spinda used Tackle!");
|
MESSAGE("The opposing Spinda used Tackle!");
|
||||||
HP_BAR(player, captureDamage: &results[i].damageBefore);
|
HP_BAR(player, captureDamage: &results[i].damageBefore);
|
||||||
|
|
||||||
if (ability == ABILITY_CONTRARY) {
|
if (ability == ABILITY_CONTRARY) {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda cut its own HP and maximized ATTACK!"); //Message stays the same
|
MESSAGE("The opposing Spinda cut its own HP and maximized its Attack!"); //Message stays the same
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Spinda cut its own HP and maximized ATTACK!");
|
MESSAGE("The opposing Spinda cut its own HP and maximized its Attack!");
|
||||||
}
|
}
|
||||||
|
|
||||||
HP_BAR(player, captureDamage: &results[i].damageAfter);
|
HP_BAR(player, captureDamage: &results[i].damageAfter);
|
||||||
|
@ -234,10 +234,10 @@ SINGLE_BATTLE_TEST("Sticky Web raises Speed by 1 for Contrary mon on switch-in")
|
||||||
TURN {}
|
TURN {}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_STICKY_WEB, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_STICKY_WEB, player);
|
||||||
MESSAGE("A sticky web spreads out on the ground around the opposing team!");
|
MESSAGE("A sticky web has been laid out on the ground around the opposing team!");
|
||||||
MESSAGE("2 sent out Snivy!");
|
MESSAGE("2 sent out Snivy!");
|
||||||
MESSAGE("Foe Snivy was caught in a Sticky Web!");
|
MESSAGE("The opposing Snivy was caught in a sticky web!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Snivy's Speed rose!");
|
MESSAGE("The opposing Snivy's Speed rose!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,12 +14,12 @@ DOUBLE_BATTLE_TEST("Costar copies an ally's stat stages upon entering battle")
|
||||||
TURN { SWITCH(opponentRight, 2); MOVE(playerLeft, MOVE_CELEBRATE); }
|
TURN { SWITCH(opponentRight, 2); MOVE(playerLeft, MOVE_CELEBRATE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
// Turn 1 - buff up
|
// Turn 1 - buff up
|
||||||
MESSAGE("Foe Wobbuffet used Swords Dance!");
|
MESSAGE("The opposing Wobbuffet used Swords Dance!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
// Turn 2 - Switch into Flamigo
|
// Turn 2 - Switch into Flamigo
|
||||||
MESSAGE("2 sent out Flamigo!");
|
MESSAGE("2 sent out Flamigo!");
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_COSTAR);
|
ABILITY_POPUP(opponentRight, ABILITY_COSTAR);
|
||||||
MESSAGE("Foe Flamigo copied Foe Wobbuffet's stat changes!");
|
MESSAGE("The opposing Flamigo copied the opposing Wobbuffet's stat changes!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponentRight->statStages[STAT_ATK], DEFAULT_STAT_STAGE + 2);
|
EXPECT_EQ(opponentRight->statStages[STAT_ATK], DEFAULT_STAT_STAGE + 2);
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,7 @@ DOUBLE_BATTLE_TEST("Cotton Down drops speed by one of all other battlers on the
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
MESSAGE("Wynaut's Speed fell!");
|
MESSAGE("Wynaut's Speed fell!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Wobbuffet's Speed fell!");
|
MESSAGE("The opposing Wobbuffet's Speed fell!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(playerLeft->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(playerLeft->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
||||||
EXPECT_EQ(playerRight->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(playerRight->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
||||||
|
|
|
@ -19,14 +19,14 @@ DOUBLE_BATTLE_TEST("Curious Medicine resets ally's stat stages upon entering bat
|
||||||
TURN { SWITCH(opponentRight, 2); MOVE(playerLeft, MOVE_CELEBRATE); }
|
TURN { SWITCH(opponentRight, 2); MOVE(playerLeft, MOVE_CELEBRATE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
// Turn 1 - buff up
|
// Turn 1 - buff up
|
||||||
MESSAGE("Foe Scolipede used Quiver Dance!");
|
MESSAGE("The opposing Scolipede used Quiver Dance!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
// Turn 2 - Switch into Slowking
|
// Turn 2 - Switch into Slowking
|
||||||
MESSAGE("2 sent out Slowking!");
|
MESSAGE("2 sent out Slowking!");
|
||||||
if (ability == ABILITY_CURIOUS_MEDICINE)
|
if (ability == ABILITY_CURIOUS_MEDICINE)
|
||||||
{
|
{
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_CURIOUS_MEDICINE);
|
ABILITY_POPUP(opponentRight, ABILITY_CURIOUS_MEDICINE);
|
||||||
MESSAGE("Foe Scolipede's stat changes were reset!");
|
MESSAGE("The opposing Scolipede's stat changes were removed!");
|
||||||
}
|
}
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponentLeft->statStages[STAT_ATK], (ability == ABILITY_CURIOUS_MEDICINE) ? DEFAULT_STAT_STAGE : DEFAULT_STAT_STAGE - 2);
|
EXPECT_EQ(opponentLeft->statStages[STAT_ATK], (ability == ABILITY_CURIOUS_MEDICINE) ? DEFAULT_STAT_STAGE : DEFAULT_STAT_STAGE - 2);
|
||||||
|
|
|
@ -12,6 +12,6 @@ SINGLE_BATTLE_TEST("Cursed Body triggers 30% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_AQUA_JET, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_AQUA_JET, player);
|
||||||
ABILITY_POPUP(opponent, ABILITY_CURSED_BODY);
|
ABILITY_POPUP(opponent, ABILITY_CURSED_BODY);
|
||||||
MESSAGE("Wobbuffet's Aqua Jet was disabled by Foe Frillish's Cursed Body!");
|
MESSAGE("Wobbuffet's Aqua Jet was disabled by the opposing Frillish's Cursed Body!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,14 +18,14 @@ SINGLE_BATTLE_TEST("Cute Charm inflicts infatuation on contact")
|
||||||
if (gMovesInfo[move].makesContact) {
|
if (gMovesInfo[move].makesContact) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_CUTE_CHARM);
|
ABILITY_POPUP(opponent, ABILITY_CUTE_CHARM);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_INFATUATION, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_INFATUATION, player);
|
||||||
MESSAGE("Foe Clefairy's Cute Charm infatuated Wobbuffet!");
|
MESSAGE("The opposing Clefairy's Cute Charm infatuated Wobbuffet!");
|
||||||
MESSAGE("Wobbuffet is in love with Foe Clefairy!");
|
MESSAGE("Wobbuffet is in love with the opposing Clefairy!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_CUTE_CHARM);
|
ABILITY_POPUP(opponent, ABILITY_CUTE_CHARM);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_INFATUATION, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_INFATUATION, player);
|
||||||
MESSAGE("Foe Clefairy's Cute Charm infatuated Wobbuffet!");
|
MESSAGE("The opposing Clefairy's Cute Charm infatuated Wobbuffet!");
|
||||||
MESSAGE("Wobbuffet is in love with Foe Clefairy!");
|
MESSAGE("Wobbuffet is in love with the opposing Clefairy!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -60,7 +60,7 @@ SINGLE_BATTLE_TEST("Cute Charm triggers 30% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_CUTE_CHARM);
|
ABILITY_POPUP(opponent, ABILITY_CUTE_CHARM);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_INFATUATION, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_INFATUATION, player);
|
||||||
MESSAGE("Foe Clefairy's Cute Charm infatuated Wobbuffet!");
|
MESSAGE("The opposing Clefairy's Cute Charm infatuated Wobbuffet!");
|
||||||
MESSAGE("Wobbuffet is in love with Foe Clefairy!");
|
MESSAGE("Wobbuffet is in love with the opposing Clefairy!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,7 +90,7 @@ SINGLE_BATTLE_TEST("Dancer doesn't trigger if the original user flinches")
|
||||||
TURN { MOVE(opponent, MOVE_FAKE_OUT); MOVE(player, MOVE_DRAGON_DANCE); }
|
TURN { MOVE(opponent, MOVE_FAKE_OUT); MOVE(player, MOVE_DRAGON_DANCE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, opponent);
|
||||||
MESSAGE("Wobbuffet flinched!");
|
MESSAGE("Wobbuffet flinched and couldn't move!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_DANCER);
|
ABILITY_POPUP(opponent, ABILITY_DANCER);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, opponent);
|
||||||
|
@ -114,14 +114,14 @@ DOUBLE_BATTLE_TEST("Dancer still triggers if another dancer flinches")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, playerRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, playerRight);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_DANCER);
|
ABILITY_POPUP(playerLeft, ABILITY_DANCER);
|
||||||
MESSAGE("Wobbuffet flinched!");
|
MESSAGE("Wobbuffet flinched and couldn't move!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
MESSAGE("Wobbuffet used Dragon Dance!");
|
MESSAGE("Wobbuffet used Dragon Dance!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, playerLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, playerLeft);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_DANCER);
|
ABILITY_POPUP(opponentLeft, ABILITY_DANCER);
|
||||||
MESSAGE("Foe Oricorio used Dragon Dance!");
|
MESSAGE("The opposing Oricorio used Dragon Dance!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, opponentLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_DRAGON_DANCE, opponentLeft);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ SINGLE_BATTLE_TEST("Dauntless Shield raises Defense by one stage")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zamazenta's Dauntless Shield raised its Defense!");
|
MESSAGE("The opposing Zamazenta's Dauntless Shield raised its Defense!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE + 1);
|
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE + 1);
|
||||||
}
|
}
|
||||||
|
@ -34,11 +34,11 @@ SINGLE_BATTLE_TEST("Dauntless Shield raises Defense by one stage only once per b
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zamazenta's Dauntless Shield raised its Defense!");
|
MESSAGE("The opposing Zamazenta's Dauntless Shield raised its Defense!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zamazenta's Dauntless Shield raised its Defense!");
|
MESSAGE("The opposing Zamazenta's Dauntless Shield raised its Defense!");
|
||||||
}
|
}
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
||||||
|
@ -55,12 +55,12 @@ SINGLE_BATTLE_TEST("Dauntless Shield activates when it's no longer effected by N
|
||||||
TURN { SWITCH(player, 1); }
|
TURN { SWITCH(player, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
||||||
MESSAGE("Neutralizing Gas filled the area!");
|
MESSAGE("Neutralizing gas filled the area!");
|
||||||
SWITCH_OUT_MESSAGE("Weezing");
|
SWITCH_OUT_MESSAGE("Weezing");
|
||||||
MESSAGE("The effects of Neutralizing Gas wore off!");
|
MESSAGE("The effects of the neutralizing gas wore off!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zamazenta's Dauntless Shield raised its Defense!");
|
MESSAGE("The opposing Zamazenta's Dauntless Shield raised its Defense!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,14 +21,14 @@ DOUBLE_BATTLE_TEST("Defiant sharply raises player's Attack after Intimidate")
|
||||||
//1st mon Intimidate
|
//1st mon Intimidate
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponentLeft, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
MESSAGE("Foe Gyarados's Intimidate cuts Mankey's attack!");
|
MESSAGE("The opposing Gyarados's Intimidate cuts Mankey's attack!");
|
||||||
if (abilityLeft == ABILITY_DEFIANT) {
|
if (abilityLeft == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_DEFIANT);
|
ABILITY_POPUP(playerLeft, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
MESSAGE("Mankey's Attack sharply rose!");
|
MESSAGE("Mankey's Attack sharply rose!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
MESSAGE("Foe Gyarados's Intimidate cuts Primeape's attack!");
|
MESSAGE("The opposing Gyarados's Intimidate cuts Primeape's attack!");
|
||||||
if (abilityRight == ABILITY_DEFIANT) {
|
if (abilityRight == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(playerRight, ABILITY_DEFIANT);
|
ABILITY_POPUP(playerRight, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
|
@ -38,14 +38,14 @@ DOUBLE_BATTLE_TEST("Defiant sharply raises player's Attack after Intimidate")
|
||||||
//2nd mon Intimidate
|
//2nd mon Intimidate
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponentRight, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
MESSAGE("Foe Arbok's Intimidate cuts Mankey's attack!");
|
MESSAGE("The opposing Arbok's Intimidate cuts Mankey's attack!");
|
||||||
if (abilityLeft == ABILITY_DEFIANT) {
|
if (abilityLeft == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_DEFIANT);
|
ABILITY_POPUP(playerLeft, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
MESSAGE("Mankey's Attack sharply rose!");
|
MESSAGE("Mankey's Attack sharply rose!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
MESSAGE("Foe Arbok's Intimidate cuts Primeape's attack!");
|
MESSAGE("The opposing Arbok's Intimidate cuts Primeape's attack!");
|
||||||
if (abilityRight == ABILITY_DEFIANT) {
|
if (abilityRight == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(playerRight, ABILITY_DEFIANT);
|
ABILITY_POPUP(playerRight, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
|
@ -79,35 +79,35 @@ DOUBLE_BATTLE_TEST("Defiant sharply raises opponent's Attack after Intimidate")
|
||||||
//1st mon Intimidate
|
//1st mon Intimidate
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(playerLeft, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Gyarados's Intimidate cuts Foe Mankey's attack!");
|
MESSAGE("Gyarados's Intimidate cuts the opposing Mankey's attack!");
|
||||||
if (abilityLeft == ABILITY_DEFIANT) {
|
if (abilityLeft == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_DEFIANT);
|
ABILITY_POPUP(opponentLeft, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Mankey's Attack sharply rose!");
|
MESSAGE("The opposing Mankey's Attack sharply rose!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Gyarados's Intimidate cuts Foe Primeape's attack!");
|
MESSAGE("Gyarados's Intimidate cuts the opposing Primeape's attack!");
|
||||||
if (abilityRight == ABILITY_DEFIANT) {
|
if (abilityRight == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_DEFIANT);
|
ABILITY_POPUP(opponentRight, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Primeape's Attack sharply rose!");
|
MESSAGE("The opposing Primeape's Attack sharply rose!");
|
||||||
}
|
}
|
||||||
|
|
||||||
//2nd mon Intimidate
|
//2nd mon Intimidate
|
||||||
ABILITY_POPUP(playerRight, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(playerRight, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Arbok's Intimidate cuts Foe Mankey's attack!");
|
MESSAGE("Arbok's Intimidate cuts the opposing Mankey's attack!");
|
||||||
if (abilityLeft == ABILITY_DEFIANT) {
|
if (abilityLeft == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_DEFIANT);
|
ABILITY_POPUP(opponentLeft, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Mankey's Attack sharply rose!");
|
MESSAGE("The opposing Mankey's Attack sharply rose!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Arbok's Intimidate cuts Foe Primeape's attack!");
|
MESSAGE("Arbok's Intimidate cuts the opposing Primeape's attack!");
|
||||||
if (abilityRight == ABILITY_DEFIANT) {
|
if (abilityRight == ABILITY_DEFIANT) {
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_DEFIANT);
|
ABILITY_POPUP(opponentRight, ABILITY_DEFIANT);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Primeape's Attack sharply rose!");
|
MESSAGE("The opposing Primeape's Attack sharply rose!");
|
||||||
}
|
}
|
||||||
} FINALLY {
|
} FINALLY {
|
||||||
// -2 from Intimidates and +4 from Defiants gets +2 total
|
// -2 from Intimidates and +4 from Defiants gets +2 total
|
||||||
|
@ -129,7 +129,7 @@ SINGLE_BATTLE_TEST("Defiant activates after Sticky Web lowers Speed")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_STICKY_WEB, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_STICKY_WEB, opponent);
|
||||||
// Switch-in - Sticky Web activates
|
// Switch-in - Sticky Web activates
|
||||||
SEND_IN_MESSAGE("Mankey");
|
SEND_IN_MESSAGE("Mankey");
|
||||||
MESSAGE("Mankey was caught in a Sticky Web!");
|
MESSAGE("Mankey was caught in a sticky web!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Mankey's Speed fell!");
|
MESSAGE("Mankey's Speed fell!");
|
||||||
// Defiant activates
|
// Defiant activates
|
||||||
|
@ -153,7 +153,7 @@ SINGLE_BATTLE_TEST("Defiant doesn't activate after Sticky Web lowers Speed if Co
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COURT_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COURT_CHANGE, opponent);
|
||||||
// Switch-in - Sticky Web activates
|
// Switch-in - Sticky Web activates
|
||||||
SEND_IN_MESSAGE("Mankey");
|
SEND_IN_MESSAGE("Mankey");
|
||||||
MESSAGE("Mankey was caught in a Sticky Web!");
|
MESSAGE("Mankey was caught in a sticky web!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Mankey's Speed fell!");
|
MESSAGE("Mankey's Speed fell!");
|
||||||
// Defiant doesn't activate
|
// Defiant doesn't activate
|
||||||
|
@ -180,7 +180,7 @@ SINGLE_BATTLE_TEST("Defiant correctly activates after Sticky Web lowers Speed if
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COURT_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COURT_CHANGE, opponent);
|
||||||
// Switch-in - Sticky Web activates
|
// Switch-in - Sticky Web activates
|
||||||
SEND_IN_MESSAGE("Mankey");
|
SEND_IN_MESSAGE("Mankey");
|
||||||
MESSAGE("Mankey was caught in a Sticky Web!");
|
MESSAGE("Mankey was caught in a sticky web!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Mankey's Speed fell!");
|
MESSAGE("Mankey's Speed fell!");
|
||||||
// Defiant doesn't activate
|
// Defiant doesn't activate
|
||||||
|
@ -225,7 +225,7 @@ DOUBLE_BATTLE_TEST("Defiant is activated by Cotton Down for non-ally pokemon")
|
||||||
MESSAGE("Mankey's Attack sharply rose!");
|
MESSAGE("Mankey's Attack sharply rose!");
|
||||||
|
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Mankey's Speed fell!");
|
MESSAGE("The opposing Mankey's Speed fell!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(playerLeft->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(playerLeft->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
||||||
EXPECT_EQ(playerRight->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(playerRight->statStages[STAT_SPEED], DEFAULT_STAT_STAGE - 1);
|
||||||
|
@ -257,11 +257,11 @@ SINGLE_BATTLE_TEST("Defiant activates before White Herb")
|
||||||
|
|
||||||
if (move == MOVE_LEER) {
|
if (move == MOVE_LEER) {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
||||||
MESSAGE("Mankey's White Herb restored its status!");
|
MESSAGE("Mankey returned its stats to normal using its White Herb!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
||||||
MESSAGE("Mankey's White Herb restored its status!");
|
MESSAGE("Mankey returned its stats to normal using its White Herb!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} THEN {
|
} THEN {
|
||||||
|
|
|
@ -16,13 +16,13 @@ SINGLE_BATTLE_TEST("Desolate Land blocks damaging Water-type moves")
|
||||||
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
||||||
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Water Gun!");
|
MESSAGE("The opposing Wobbuffet used Water Gun!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
||||||
MESSAGE("The Water-type attack evaporated in the harsh sunlight!");
|
MESSAGE("The Water-type attack evaporated in the extremely harsh sunlight!");
|
||||||
NOT HP_BAR(player);
|
NOT HP_BAR(player);
|
||||||
MESSAGE("Foe Wobbuffet used Water Gun!");
|
MESSAGE("The opposing Wobbuffet used Water Gun!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
||||||
MESSAGE("The Water-type attack evaporated in the harsh sunlight!");
|
MESSAGE("The Water-type attack evaporated in the extremely harsh sunlight!");
|
||||||
NOT HP_BAR(player);
|
NOT HP_BAR(player);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->hp, player->maxHP);
|
EXPECT_EQ(player->hp, player->maxHP);
|
||||||
|
@ -42,10 +42,10 @@ DOUBLE_BATTLE_TEST("Desolate Land blocks damaging Water-type moves and prints th
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponentLeft, MOVE_SURF); }
|
TURN { MOVE(opponentLeft, MOVE_SURF); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Surf!");
|
MESSAGE("The opposing Wobbuffet used Surf!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_SURF, opponentLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_SURF, opponentLeft);
|
||||||
MESSAGE("The Water-type attack evaporated in the harsh sunlight!");
|
MESSAGE("The Water-type attack evaporated in the extremely harsh sunlight!");
|
||||||
NOT MESSAGE("The Water-type attack evaporated in the harsh sunlight!");
|
NOT MESSAGE("The Water-type attack evaporated in the extremely harsh sunlight!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(playerLeft->hp, playerLeft->maxHP);
|
EXPECT_EQ(playerLeft->hp, playerLeft->maxHP);
|
||||||
EXPECT_EQ(playerRight->hp, playerRight->maxHP);
|
EXPECT_EQ(playerRight->hp, playerRight->maxHP);
|
||||||
|
@ -61,7 +61,7 @@ SINGLE_BATTLE_TEST("Desolate Land does not block a move if pokemon is asleep and
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NOT MESSAGE("The Water-type attack evaporated in the harsh sunlight!");
|
NOT MESSAGE("The Water-type attack evaporated in the extremely harsh sunlight!");
|
||||||
MESSAGE("Foe Wobbuffet is fast asleep.");
|
MESSAGE("The opposing Wobbuffet is fast asleep.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -98,7 +98,7 @@ SINGLE_BATTLE_TEST("Disguised Mimikyu takes damage from Rocky Helmet without bre
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
MESSAGE("Mimikyu was hurt by Foe Wobbuffet's Rocky Helmet!");
|
MESSAGE("Mimikyu was hurt by the opposing Wobbuffet's Rocky Helmet!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->species, SPECIES_MIMIKYU_DISGUISED);
|
EXPECT_EQ(player->species, SPECIES_MIMIKYU_DISGUISED);
|
||||||
}
|
}
|
||||||
|
@ -116,7 +116,7 @@ SINGLE_BATTLE_TEST("Disguised Mimikyu takes damage from Rough Skin without break
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
ABILITY_POPUP(opponent, ABILITY_ROUGH_SKIN);
|
ABILITY_POPUP(opponent, ABILITY_ROUGH_SKIN);
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
MESSAGE("Mimikyu was hurt by Foe Carvanha's Rough Skin!");
|
MESSAGE("Mimikyu was hurt by the opposing Carvanha's Rough Skin!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->species, SPECIES_MIMIKYU_DISGUISED);
|
EXPECT_EQ(player->species, SPECIES_MIMIKYU_DISGUISED);
|
||||||
}
|
}
|
||||||
|
@ -146,11 +146,11 @@ SINGLE_BATTLE_TEST("Disguised Mimikyu's types revert back to Ghost/Fairy when Di
|
||||||
TURN { MOVE(opponent, MOVE_TACKLE); }
|
TURN { MOVE(opponent, MOVE_TACKLE); }
|
||||||
TURN { MOVE(opponent, MOVE_SHADOW_CLAW); }
|
TURN { MOVE(opponent, MOVE_SHADOW_CLAW); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Soak!");
|
MESSAGE("The opposing Wobbuffet used Soak!");
|
||||||
MESSAGE("Mimikyu transformed into the Water type!");
|
MESSAGE("Mimikyu transformed into the Water type!");
|
||||||
MESSAGE("Foe Wobbuffet used Tackle!");
|
MESSAGE("The opposing Wobbuffet used Tackle!");
|
||||||
ABILITY_POPUP(player, ABILITY_DISGUISE);
|
ABILITY_POPUP(player, ABILITY_DISGUISE);
|
||||||
MESSAGE("Foe Wobbuffet used Shadow Claw!");
|
MESSAGE("The opposing Wobbuffet used Shadow Claw!");
|
||||||
MESSAGE("It's super effective!");
|
MESSAGE("It's super effective!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -167,7 +167,7 @@ SINGLE_BATTLE_TEST("Disguised Mimikyu blocks a move after getting Gastro Acid Ba
|
||||||
TURN { MOVE(opponent, MOVE_SHADOW_CLAW); }
|
TURN { MOVE(opponent, MOVE_SHADOW_CLAW); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_GASTRO_ACID, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_GASTRO_ACID, opponent);
|
||||||
MESSAGE("Wobbuffet's ability was suppressed!");
|
MESSAGE("Wobbuffet's Ability was suppressed!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_BATON_PASS, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_BATON_PASS, player);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SHADOW_CLAW, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SHADOW_CLAW, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_DISGUISE);
|
ABILITY_POPUP(player, ABILITY_DISGUISE);
|
||||||
|
|
|
@ -22,7 +22,7 @@ SINGLE_BATTLE_TEST("Download raises Attack if player has lower Def than Sp. Def"
|
||||||
{
|
{
|
||||||
ABILITY_POPUP(opponent, ABILITY_DOWNLOAD);
|
ABILITY_POPUP(opponent, ABILITY_DOWNLOAD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Porygon's Download raised its Attack!");
|
MESSAGE("The opposing Porygon's Download raised its Attack!");
|
||||||
}
|
}
|
||||||
HP_BAR(player, captureDamage: &results[i].damage);
|
HP_BAR(player, captureDamage: &results[i].damage);
|
||||||
} FINALLY {
|
} FINALLY {
|
||||||
|
@ -85,7 +85,7 @@ SINGLE_BATTLE_TEST("Download doesn't activate if target hasn't been sent out yet
|
||||||
{
|
{
|
||||||
ABILITY_POPUP(opponent, ABILITY_DOWNLOAD);
|
ABILITY_POPUP(opponent, ABILITY_DOWNLOAD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Porygon2's Download raised its Sp. Atk!");
|
MESSAGE("The opposing Porygon2's Download raised its Sp. Atk!");
|
||||||
}
|
}
|
||||||
|
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TRI_ATTACK, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TRI_ATTACK, opponent);
|
||||||
|
|
|
@ -19,13 +19,13 @@ SINGLE_BATTLE_TEST("Effect Spore only inflicts status on contact")
|
||||||
if (gMovesInfo[move].makesContact) {
|
if (gMovesInfo[move].makesContact) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
||||||
MESSAGE("Wobbuffet was poisoned by Foe Breloom's Effect Spore!");
|
MESSAGE("Wobbuffet was poisoned by the opposing Breloom's Effect Spore!");
|
||||||
STATUS_ICON(player, poison: TRUE);
|
STATUS_ICON(player, poison: TRUE);
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
||||||
MESSAGE("Wobbuffet was poisoned by Foe Breloom's Effect Spore!");
|
MESSAGE("Wobbuffet was poisoned by the opposing Breloom's Effect Spore!");
|
||||||
STATUS_ICON(player, poison: TRUE);
|
STATUS_ICON(player, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,7 @@ SINGLE_BATTLE_TEST("Effect Spore causes poison 9% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
||||||
MESSAGE("Wobbuffet was poisoned by Foe Breloom's Effect Spore!");
|
MESSAGE("Wobbuffet was poisoned by the opposing Breloom's Effect Spore!");
|
||||||
STATUS_ICON(player, poison: TRUE);
|
STATUS_ICON(player, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ SINGLE_BATTLE_TEST("Effect Spore causes paralysis 10% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
||||||
MESSAGE("Foe Breloom's Effect Spore paralyzed Wobbuffet! It may be unable to move!");
|
MESSAGE("The opposing Breloom's Effect Spore paralyzed Wobbuffet, so it may be unable to move!");
|
||||||
STATUS_ICON(player, paralysis: TRUE);
|
STATUS_ICON(player, paralysis: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -84,7 +84,7 @@ SINGLE_BATTLE_TEST("Effect Spore causes sleep 11% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
ABILITY_POPUP(opponent, ABILITY_EFFECT_SPORE);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_SLP, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_SLP, player);
|
||||||
MESSAGE("Foe Breloom's Effect Spore made Wobbuffet sleep!");
|
MESSAGE("The opposing Breloom's Effect Spore made Wobbuffet sleep!");
|
||||||
STATUS_ICON(player, sleep: TRUE);
|
STATUS_ICON(player, sleep: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,13 +20,13 @@ SINGLE_BATTLE_TEST("Embody Aspect raises a stat depending on the users form by o
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
if (ability == ABILITY_EMBODY_ASPECT_TEAL_MASK)
|
if (ability == ABILITY_EMBODY_ASPECT_TEAL_MASK)
|
||||||
MESSAGE("Foe Ogerpon's Embody Aspect raised its Speed!");
|
MESSAGE("The opposing Ogerpon's Embody Aspect raised its Speed!");
|
||||||
else if (ability == ABILITY_EMBODY_ASPECT_HEARTHFLAME_MASK)
|
else if (ability == ABILITY_EMBODY_ASPECT_HEARTHFLAME_MASK)
|
||||||
MESSAGE("Foe Ogerpon's Embody Aspect raised its Attack!");
|
MESSAGE("The opposing Ogerpon's Embody Aspect raised its Attack!");
|
||||||
else if (ability == ABILITY_EMBODY_ASPECT_WELLSPRING_MASK)
|
else if (ability == ABILITY_EMBODY_ASPECT_WELLSPRING_MASK)
|
||||||
MESSAGE("Foe Ogerpon's Embody Aspect raised its Sp. Def!");
|
MESSAGE("The opposing Ogerpon's Embody Aspect raised its Sp. Def!");
|
||||||
else if (ability == ABILITY_EMBODY_ASPECT_CORNERSTONE_MASK)
|
else if (ability == ABILITY_EMBODY_ASPECT_CORNERSTONE_MASK)
|
||||||
MESSAGE("Foe Ogerpon's Embody Aspect raised its Defense!");
|
MESSAGE("The opposing Ogerpon's Embody Aspect raised its Defense!");
|
||||||
} THEN {
|
} THEN {
|
||||||
if (ability == ABILITY_EMBODY_ASPECT_TEAL_MASK)
|
if (ability == ABILITY_EMBODY_ASPECT_TEAL_MASK)
|
||||||
EXPECT_EQ(opponent->statStages[STAT_SPEED], DEFAULT_STAT_STAGE + 1);
|
EXPECT_EQ(opponent->statStages[STAT_SPEED], DEFAULT_STAT_STAGE + 1);
|
||||||
|
@ -49,11 +49,11 @@ SINGLE_BATTLE_TEST("Embody Aspect activates when it's no longer effected by Neut
|
||||||
TURN { SWITCH(player, 1); }
|
TURN { SWITCH(player, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
||||||
MESSAGE("Neutralizing Gas filled the area!");
|
MESSAGE("Neutralizing gas filled the area!");
|
||||||
SWITCH_OUT_MESSAGE("Weezing");
|
SWITCH_OUT_MESSAGE("Weezing");
|
||||||
MESSAGE("The effects of Neutralizing Gas wore off!");
|
MESSAGE("The effects of the neutralizing gas wore off!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_EMBODY_ASPECT_TEAL_MASK);
|
ABILITY_POPUP(opponent, ABILITY_EMBODY_ASPECT_TEAL_MASK);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Ogerpon's Embody Aspect raised its Speed!");
|
MESSAGE("The opposing Ogerpon's Embody Aspect raised its Speed!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,13 +17,13 @@ SINGLE_BATTLE_TEST("Flame Body inflicts burn on contact")
|
||||||
if (gMovesInfo[move].makesContact) {
|
if (gMovesInfo[move].makesContact) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_FLAME_BODY);
|
ABILITY_POPUP(opponent, ABILITY_FLAME_BODY);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_BRN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_BRN, player);
|
||||||
MESSAGE("Foe Magmar's Flame Body burned Wobbuffet!");
|
MESSAGE("The opposing Magmar's Flame Body burned Wobbuffet!");
|
||||||
STATUS_ICON(player, burn: TRUE);
|
STATUS_ICON(player, burn: TRUE);
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_FLAME_BODY);
|
ABILITY_POPUP(opponent, ABILITY_FLAME_BODY);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_BRN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_BRN, player);
|
||||||
MESSAGE("Foe Magmar's Flame Body burned Wobbuffet!");
|
MESSAGE("The opposing Magmar's Flame Body burned Wobbuffet!");
|
||||||
STATUS_ICON(player, burn: TRUE);
|
STATUS_ICON(player, burn: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,7 @@ SINGLE_BATTLE_TEST("Flame Body triggers 30% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_FLAME_BODY);
|
ABILITY_POPUP(opponent, ABILITY_FLAME_BODY);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_BRN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_BRN, player);
|
||||||
MESSAGE("Foe Magmar's Flame Body burned Wobbuffet!");
|
MESSAGE("The opposing Magmar's Flame Body burned Wobbuffet!");
|
||||||
STATUS_ICON(player, burn: TRUE);
|
STATUS_ICON(player, burn: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -122,13 +122,13 @@ DOUBLE_BATTLE_TEST("Forecast transforms all Castforms present in weather")
|
||||||
MESSAGE("Castform transformed!");
|
MESSAGE("Castform transformed!");
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_FORECAST);
|
ABILITY_POPUP(opponentLeft, ABILITY_FORECAST);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Castform transformed!");
|
MESSAGE("The opposing Castform transformed!");
|
||||||
ABILITY_POPUP(playerRight, ABILITY_FORECAST);
|
ABILITY_POPUP(playerRight, ABILITY_FORECAST);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, playerRight);
|
||||||
MESSAGE("Castform transformed!");
|
MESSAGE("Castform transformed!");
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_FORECAST);
|
ABILITY_POPUP(opponentRight, ABILITY_FORECAST);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Castform transformed!");
|
MESSAGE("The opposing Castform transformed!");
|
||||||
} THEN {
|
} THEN {
|
||||||
switch (move)
|
switch (move)
|
||||||
{
|
{
|
||||||
|
|
|
@ -29,9 +29,9 @@ SINGLE_BATTLE_TEST("Frisk triggers in a Single Battle")
|
||||||
TURN { ; }
|
TURN { ; }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_FRISK);
|
ABILITY_POPUP(player, ABILITY_FRISK);
|
||||||
MESSAGE("Furret frisked Foe Sentret and found its Potion!");
|
MESSAGE("Furret frisked the opposing Sentret and found its Potion!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_FRISK);
|
ABILITY_POPUP(opponent, ABILITY_FRISK);
|
||||||
MESSAGE("Foe Sentret frisked Furret and found its Potion!");
|
MESSAGE("The opposing Sentret frisked Furret and found its Potion!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,10 +51,10 @@ DOUBLE_BATTLE_TEST("Frisk triggers for player in a Double Battle after switching
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponentLeft, MOVE_POUND, target: target); SEND_OUT(target, 2); }
|
TURN { MOVE(opponentLeft, MOVE_POUND, target: target); SEND_OUT(target, 2); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wynaut used Pound!");
|
MESSAGE("The opposing Wynaut used Pound!");
|
||||||
MESSAGE("Wobbuffet fainted!");
|
MESSAGE("Wobbuffet fainted!");
|
||||||
ABILITY_POPUP(target, ABILITY_FRISK);
|
ABILITY_POPUP(target, ABILITY_FRISK);
|
||||||
MESSAGE("Furret frisked Foe Wynaut and found its Potion!");
|
MESSAGE("Furret frisked the opposing Wynaut and found its Potion!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,8 +75,8 @@ DOUBLE_BATTLE_TEST("Frisk triggers for opponent in a Double Battle after switchi
|
||||||
TURN { MOVE(playerLeft, MOVE_POUND, target: target); SEND_OUT(target, 2); }
|
TURN { MOVE(playerLeft, MOVE_POUND, target: target); SEND_OUT(target, 2); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wynaut used Pound!");
|
MESSAGE("Wynaut used Pound!");
|
||||||
MESSAGE("Foe Wobbuffet fainted!");
|
MESSAGE("The opposing Wobbuffet fainted!");
|
||||||
ABILITY_POPUP(target, ABILITY_FRISK);
|
ABILITY_POPUP(target, ABILITY_FRISK);
|
||||||
MESSAGE("Foe Furret frisked Wynaut and found its Potion!");
|
MESSAGE("The opposing Furret frisked Wynaut and found its Potion!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,10 +16,10 @@ SINGLE_BATTLE_TEST("Gale Wings only grants priority at full HP")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
if (hp == 100) {
|
if (hp == 100) {
|
||||||
MESSAGE("Talonflame used Aerial Ace!");
|
MESSAGE("Talonflame used Aerial Ace!");
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
MESSAGE("Talonflame used Aerial Ace!");
|
MESSAGE("Talonflame used Aerial Ace!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,10 +41,10 @@ SINGLE_BATTLE_TEST("Gale Wings only grants priority to Flying-type moves")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
if (move == MOVE_AERIAL_ACE) {
|
if (move == MOVE_AERIAL_ACE) {
|
||||||
MESSAGE("Talonflame used Aerial Ace!");
|
MESSAGE("Talonflame used Aerial Ace!");
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
MESSAGE("Talonflame used Flare Blitz!");
|
MESSAGE("Talonflame used Flare Blitz!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -74,16 +74,16 @@ SINGLE_BATTLE_TEST("Gale Wings doesn't increase priority of Flying-type Natural
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wobbuffet used Celebrate!");
|
MESSAGE("Wobbuffet used Celebrate!");
|
||||||
if (move == MOVE_NATURAL_GIFT) {
|
if (move == MOVE_NATURAL_GIFT) {
|
||||||
MESSAGE("Foe Talonflame used Natural Gift!");
|
MESSAGE("The opposing Talonflame used Natural Gift!");
|
||||||
}
|
}
|
||||||
else if (move == MOVE_JUDGMENT) {
|
else if (move == MOVE_JUDGMENT) {
|
||||||
MESSAGE("Foe Talonflame used Judgment!");
|
MESSAGE("The opposing Talonflame used Judgment!");
|
||||||
}
|
}
|
||||||
else if (move == MOVE_HIDDEN_POWER) {
|
else if (move == MOVE_HIDDEN_POWER) {
|
||||||
MESSAGE("Foe Talonflame used Hidden Power!");
|
MESSAGE("The opposing Talonflame used Hidden Power!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
MESSAGE("Foe Talonflame used Tera Blast!");
|
MESSAGE("The opposing Talonflame used Tera Blast!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ SINGLE_BATTLE_TEST("Good as Gold protects from status moves")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
||||||
ABILITY_POPUP(opponent, ABILITY_GOOD_AS_GOLD);
|
ABILITY_POPUP(opponent, ABILITY_GOOD_AS_GOLD);
|
||||||
MESSAGE("It doesn't affect Foe Gholdengo…");
|
MESSAGE("It doesn't affect the opposing Gholdengo…");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ SINGLE_BATTLE_TEST("Good as Gold doesn't protect the user from it's own moves")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_NASTY_PLOT, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_NASTY_PLOT, opponent);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_GOOD_AS_GOLD);
|
ABILITY_POPUP(opponent, ABILITY_GOOD_AS_GOLD);
|
||||||
MESSAGE("It doesn't affect Foe Gholdengo…");
|
MESSAGE("It doesn't affect the opposing Gholdengo…");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -47,7 +47,7 @@ SINGLE_BATTLE_TEST("Good as Gold doesn't protect from moves that target the fiel
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_GOOD_AS_GOLD);
|
ABILITY_POPUP(opponent, ABILITY_GOOD_AS_GOLD);
|
||||||
MESSAGE("It doesn't affect Foe Gholdengo…");
|
MESSAGE("It doesn't affect the opposing Gholdengo…");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -65,6 +65,6 @@ DOUBLE_BATTLE_TEST("Good as Gold protects from partner's status moves")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_HELPING_HAND, opponentRight);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_HELPING_HAND, opponentRight);
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_GOOD_AS_GOLD);
|
ABILITY_POPUP(opponentLeft, ABILITY_GOOD_AS_GOLD);
|
||||||
MESSAGE("It doesn't affect Foe Gholdengo…");
|
MESSAGE("It doesn't affect the opposing Gholdengo…");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,8 +22,8 @@ DOUBLE_BATTLE_TEST("Grim Neigh raises Sp. Attack by one stage after directly cau
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
ONE_OF {
|
ONE_OF {
|
||||||
MESSAGE("Snorunt fainted!");
|
MESSAGE("Snorunt fainted!");
|
||||||
MESSAGE("Foe Glalie fainted!");
|
MESSAGE("The opposing Glalie fainted!");
|
||||||
MESSAGE("Foe Abra fainted!");
|
MESSAGE("The opposing Abra fainted!");
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(playerLeft, abilityPopUp);
|
ABILITY_POPUP(playerLeft, abilityPopUp);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
|
@ -57,8 +57,8 @@ DOUBLE_BATTLE_TEST("Grim Neigh does not trigger if Pokemon faint to indirect dam
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
ONE_OF {
|
ONE_OF {
|
||||||
MESSAGE("Snorunt fainted!");
|
MESSAGE("Snorunt fainted!");
|
||||||
MESSAGE("Foe Glalie fainted!");
|
MESSAGE("The opposing Glalie fainted!");
|
||||||
MESSAGE("Foe Abra fainted!");
|
MESSAGE("The opposing Abra fainted!");
|
||||||
}
|
}
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(playerLeft, abilityPopUp);
|
ABILITY_POPUP(playerLeft, abilityPopUp);
|
||||||
|
|
|
@ -89,7 +89,7 @@ SINGLE_BATTLE_TEST("(Gulp Missile) Transformed Cramorant deal 1/4 of damage oppo
|
||||||
ABILITY_POPUP(player, ABILITY_GULP_MISSILE);
|
ABILITY_POPUP(player, ABILITY_GULP_MISSILE);
|
||||||
HP_BAR(opponent, captureDamage: &gulpMissileDamage);
|
HP_BAR(opponent, captureDamage: &gulpMissileDamage);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Wobbuffet's Defense fell!");
|
MESSAGE("The opposing Wobbuffet's Defense fell!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(gulpMissileDamage, opponent->maxHP / 4);
|
EXPECT_EQ(gulpMissileDamage, opponent->maxHP / 4);
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ SINGLE_BATTLE_TEST("Hunger Switch switches Morpeko's forms at the end of the tur
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE); }
|
TURN { MOVE(player, MOVE_CELEBRATE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Morpeko used Celebrate!");
|
MESSAGE("Morpeko used Celebrate!");
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
} THEN {
|
} THEN {
|
||||||
if (species == SPECIES_MORPEKO_FULL_BELLY)
|
if (species == SPECIES_MORPEKO_FULL_BELLY)
|
||||||
|
|
|
@ -19,7 +19,7 @@ SINGLE_BATTLE_TEST("Hyper Cutter prevents intimidate")
|
||||||
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
||||||
NONE_OF { ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player); }
|
NONE_OF { ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player); }
|
||||||
ABILITY_POPUP(opponent, ABILITY_HYPER_CUTTER);
|
ABILITY_POPUP(opponent, ABILITY_HYPER_CUTTER);
|
||||||
MESSAGE("Foe Krabby's Hyper Cutter prevents Attack loss!");
|
MESSAGE("The opposing Krabby's Hyper Cutter prevents Attack loss!");
|
||||||
HP_BAR(player, captureDamage: &turnTwoHit);
|
HP_BAR(player, captureDamage: &turnTwoHit);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(turnOneHit, turnTwoHit);
|
EXPECT_EQ(turnOneHit, turnTwoHit);
|
||||||
|
@ -36,7 +36,7 @@ SINGLE_BATTLE_TEST("Hyper Cutter prevents Attack stage reduction from moves")
|
||||||
TURN { MOVE(player, MOVE_GROWL); }
|
TURN { MOVE(player, MOVE_GROWL); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_HYPER_CUTTER);
|
ABILITY_POPUP(opponent, ABILITY_HYPER_CUTTER);
|
||||||
MESSAGE("Foe Krabby's Hyper Cutter prevents Attack loss!");
|
MESSAGE("The opposing Krabby's Hyper Cutter prevents Attack loss!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ SINGLE_BATTLE_TEST("Hyper Cutter doesn't prevent Attack reduction from burn")
|
||||||
TURN { MOVE(player, MOVE_WILL_O_WISP); }
|
TURN { MOVE(player, MOVE_WILL_O_WISP); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_WILL_O_WISP, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_WILL_O_WISP, player);
|
||||||
MESSAGE("Foe Krabby was burned!");
|
MESSAGE("The opposing Krabby was burned!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE);
|
||||||
}
|
}
|
||||||
|
@ -68,10 +68,10 @@ SINGLE_BATTLE_TEST("Hyper Cutter is ignored by Mold Breaker")
|
||||||
ABILITY_POPUP(player, ABILITY_MOLD_BREAKER);
|
ABILITY_POPUP(player, ABILITY_MOLD_BREAKER);
|
||||||
MESSAGE("Pinsir breaks the mold!");
|
MESSAGE("Pinsir breaks the mold!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_GROWL, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_GROWL, player);
|
||||||
MESSAGE("Foe Krabby's Attack fell!");
|
MESSAGE("The opposing Krabby's Attack fell!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_HYPER_CUTTER);
|
ABILITY_POPUP(opponent, ABILITY_HYPER_CUTTER);
|
||||||
MESSAGE("Foe Krabby's Hyper Cutter prevents Attack loss!");
|
MESSAGE("The opposing Krabby's Hyper Cutter prevents Attack loss!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -87,8 +87,8 @@ SINGLE_BATTLE_TEST("Hyper Cutter doesn't prevent Attack stage reduction from mov
|
||||||
TURN {}
|
TURN {}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUPERPOWER, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUPERPOWER, opponent);
|
||||||
MESSAGE("Foe Krabby's Attack fell!");
|
MESSAGE("The opposing Krabby's Attack fell!");
|
||||||
MESSAGE("Foe Krabby's Defense fell!");
|
MESSAGE("The opposing Krabby's Defense fell!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE - 1);
|
||||||
}
|
}
|
||||||
|
@ -105,9 +105,9 @@ SINGLE_BATTLE_TEST("Hyper Cutter doesn't prevent Topsy-Turvy")
|
||||||
TURN { MOVE(opponent, MOVE_SWORDS_DANCE); MOVE(player, MOVE_TOPSY_TURVY); }
|
TURN { MOVE(opponent, MOVE_SWORDS_DANCE); MOVE(player, MOVE_TOPSY_TURVY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SWORDS_DANCE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SWORDS_DANCE, opponent);
|
||||||
MESSAGE("Foe Krabby's Attack sharply rose!");
|
MESSAGE("The opposing Krabby's Attack sharply rose!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOPSY_TURVY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOPSY_TURVY, player);
|
||||||
MESSAGE("Foe Krabby's stat changes were all reversed!");
|
MESSAGE("All stat changes on the opposing Krabby were inverted!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE - 2);
|
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE - 2);
|
||||||
}
|
}
|
||||||
|
@ -124,7 +124,7 @@ SINGLE_BATTLE_TEST("Hyper Cutter doesn't prevent Spectral Thief from resetting p
|
||||||
TURN { MOVE(opponent, MOVE_SWORDS_DANCE); MOVE(player, MOVE_SPECTRAL_THIEF); }
|
TURN { MOVE(opponent, MOVE_SWORDS_DANCE); MOVE(player, MOVE_SPECTRAL_THIEF); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SWORDS_DANCE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SWORDS_DANCE, opponent);
|
||||||
MESSAGE("Foe Krabby's Attack sharply rose!");
|
MESSAGE("The opposing Krabby's Attack sharply rose!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPECTRAL_THIEF, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPECTRAL_THIEF, player);
|
||||||
MESSAGE("Wobbuffet stole the target's boosted stats!");
|
MESSAGE("Wobbuffet stole the target's boosted stats!");
|
||||||
} THEN {
|
} THEN {
|
||||||
|
|
|
@ -26,7 +26,7 @@ SINGLE_BATTLE_TEST("Immunity prevents Toxic bad poison")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wobbuffet used Toxic!");
|
MESSAGE("Wobbuffet used Toxic!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_IMMUNITY);
|
ABILITY_POPUP(opponent, ABILITY_IMMUNITY);
|
||||||
MESSAGE("Foe Snorlax's Immunity prevents poisoning!");
|
MESSAGE("The opposing Snorlax's Immunity prevents poisoning!");
|
||||||
NOT STATUS_ICON(opponent, poison: TRUE);
|
NOT STATUS_ICON(opponent, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ SINGLE_BATTLE_TEST("Innards Out deal dmg on fainting equal to the amount of dmg
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_PSYCHIC); SEND_OUT(player, 1); if (hp == 100) { SEND_OUT(opponent, 1); } }
|
TURN { MOVE(opponent, MOVE_PSYCHIC); SEND_OUT(player, 1); if (hp == 100) { SEND_OUT(opponent, 1); } }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Psychic!");
|
MESSAGE("The opposing Wobbuffet used Psychic!");
|
||||||
HP_BAR(player, hp);
|
HP_BAR(player, hp);
|
||||||
ABILITY_POPUP(player, ABILITY_INNARDS_OUT);
|
ABILITY_POPUP(player, ABILITY_INNARDS_OUT);
|
||||||
HP_BAR(opponent, hp);
|
HP_BAR(opponent, hp);
|
||||||
|
@ -38,8 +38,8 @@ SINGLE_BATTLE_TEST("Innards Out does not trigger after Gastro Acid has been used
|
||||||
TURN { MOVE(opponent, MOVE_GASTRO_ACID); }
|
TURN { MOVE(opponent, MOVE_GASTRO_ACID); }
|
||||||
TURN { MOVE(opponent, MOVE_PSYCHIC); SEND_OUT(player, 1); }
|
TURN { MOVE(opponent, MOVE_PSYCHIC); SEND_OUT(player, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Gastro Acid!");
|
MESSAGE("The opposing Wobbuffet used Gastro Acid!");
|
||||||
MESSAGE("Foe Wobbuffet used Psychic!");
|
MESSAGE("The opposing Wobbuffet used Psychic!");
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_INNARDS_OUT);
|
ABILITY_POPUP(player, ABILITY_INNARDS_OUT);
|
||||||
|
@ -59,7 +59,7 @@ SINGLE_BATTLE_TEST("Innards Out does not damage Magic Guard Pokemon")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_PSYCHIC); SEND_OUT(player, 1); }
|
TURN { MOVE(opponent, MOVE_PSYCHIC); SEND_OUT(player, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Clefable used Psychic!");
|
MESSAGE("The opposing Clefable used Psychic!");
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
ABILITY_POPUP(player, ABILITY_INNARDS_OUT);
|
ABILITY_POPUP(player, ABILITY_INNARDS_OUT);
|
||||||
NOT HP_BAR(opponent);
|
NOT HP_BAR(opponent);
|
||||||
|
|
|
@ -20,7 +20,7 @@ SINGLE_BATTLE_TEST("Inner Focus prevents intimidate")
|
||||||
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
||||||
NONE_OF { ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player); }
|
NONE_OF { ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player); }
|
||||||
ABILITY_POPUP(opponent, ABILITY_INNER_FOCUS);
|
ABILITY_POPUP(opponent, ABILITY_INNER_FOCUS);
|
||||||
MESSAGE("Foe Zubat's Inner Focus prevents stat loss!");
|
MESSAGE("The opposing Zubat's Inner Focus prevents stat loss!");
|
||||||
HP_BAR(player, captureDamage: &turnTwoHit);
|
HP_BAR(player, captureDamage: &turnTwoHit);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(turnOneHit, turnTwoHit);
|
EXPECT_EQ(turnOneHit, turnTwoHit);
|
||||||
|
@ -38,7 +38,7 @@ SINGLE_BATTLE_TEST("Inner Focus prevents flinching")
|
||||||
}
|
}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, player);
|
||||||
NONE_OF { MESSAGE("Foe Zubat flinched!"); }
|
NONE_OF { MESSAGE("The opposing Zubat flinched and couldn't move!"); }
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -52,6 +52,6 @@ SINGLE_BATTLE_TEST("Inner Focus is ignored by Mold Breaker")
|
||||||
TURN { MOVE(player, MOVE_FAKE_OUT); }
|
TURN { MOVE(player, MOVE_FAKE_OUT); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, player);
|
||||||
MESSAGE("Foe Zubat flinched!");
|
MESSAGE("The opposing Zubat flinched and couldn't move!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,7 @@ SINGLE_BATTLE_TEST("Intimidate (opponent) lowers player's attack after switch ou
|
||||||
{
|
{
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Foe Arbok's Intimidate cuts Wobbuffet's attack!");
|
MESSAGE("The opposing Arbok's Intimidate cuts Wobbuffet's attack!");
|
||||||
}
|
}
|
||||||
HP_BAR(opponent, captureDamage: &results[i].damage);
|
HP_BAR(opponent, captureDamage: &results[i].damage);
|
||||||
} FINALLY {
|
} FINALLY {
|
||||||
|
@ -49,7 +49,7 @@ SINGLE_BATTLE_TEST("Intimidate (opponent) lowers player's attack after KO", s16
|
||||||
{
|
{
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Foe Arbok's Intimidate cuts Wobbuffet's attack!");
|
MESSAGE("The opposing Arbok's Intimidate cuts Wobbuffet's attack!");
|
||||||
}
|
}
|
||||||
HP_BAR(opponent, captureDamage: &results[i].damage);
|
HP_BAR(opponent, captureDamage: &results[i].damage);
|
||||||
} FINALLY {
|
} FINALLY {
|
||||||
|
@ -92,15 +92,15 @@ DOUBLE_BATTLE_TEST("Intimidate doesn't activate on an empty field in a double ba
|
||||||
// Intimidate activates after all battlers have been brought out
|
// Intimidate activates after all battlers have been brought out
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(playerLeft, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Ekans's Intimidate cuts Foe Arbok's attack!");
|
MESSAGE("Ekans's Intimidate cuts the opposing Arbok's attack!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Ekans's Intimidate cuts Foe Wynaut's attack!");
|
MESSAGE("Ekans's Intimidate cuts the opposing Wynaut's attack!");
|
||||||
|
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponentLeft, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
MESSAGE("Foe Arbok's Intimidate cuts Ekans's attack!");
|
MESSAGE("The opposing Arbok's Intimidate cuts Ekans's attack!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
MESSAGE("Foe Arbok's Intimidate cuts Abra's attack!");
|
MESSAGE("The opposing Arbok's Intimidate cuts Abra's attack!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -120,13 +120,13 @@ SINGLE_BATTLE_TEST("Intimidate and Eject Button force the opponent to Attack")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_QUICK_ATTACK, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_QUICK_ATTACK, player);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
||||||
MESSAGE("Foe Wobbuffet is switched out with the Eject Button!");
|
MESSAGE("The opposing Wobbuffet is switched out with the Eject Button!");
|
||||||
MESSAGE("2 sent out Hitmontop!");
|
MESSAGE("2 sent out Hitmontop!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
||||||
MESSAGE("Foe Hitmontop's Intimidate cuts Wobbuffet's attack!");
|
MESSAGE("The opposing Hitmontop's Intimidate cuts Wobbuffet's attack!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
MESSAGE("Foe Hitmontop used Tackle!");
|
MESSAGE("The opposing Hitmontop used Tackle!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -161,10 +161,10 @@ DOUBLE_BATTLE_TEST("Intimidate activates on an empty slot")
|
||||||
SEND_IN_MESSAGE("Hitmontop");
|
SEND_IN_MESSAGE("Hitmontop");
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(playerLeft, ABILITY_INTIMIDATE);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
MESSAGE("Hitmontop's Intimidate cuts Foe Ralts's attack!");
|
MESSAGE("Hitmontop's Intimidate cuts the opposing Ralts's attack!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Hitmontop's Intimidate cuts Foe Azurill's attack!");
|
MESSAGE("Hitmontop's Intimidate cuts the opposing Azurill's attack!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,9 +209,9 @@ SINGLE_BATTLE_TEST("Intimidate can not further lower opponents Atk stat if it is
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Foe Arbok's Intimidate cuts Wobbuffet's attack!");
|
MESSAGE("The opposing Arbok's Intimidate cuts Wobbuffet's attack!");
|
||||||
}
|
}
|
||||||
MESSAGE("Wobbuffet's Attack won't go lower!");
|
MESSAGE("Wobbuffet's Attack won't go any lower!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->statStages[STAT_ATK], MIN_STAT_STAGE);
|
EXPECT_EQ(player->statStages[STAT_ATK], MIN_STAT_STAGE);
|
||||||
}
|
}
|
||||||
|
@ -256,9 +256,9 @@ SINGLE_BATTLE_TEST("Intimidate activates when it's no longer effected by Neutral
|
||||||
TURN { SWITCH(player, 1); }
|
TURN { SWITCH(player, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
||||||
MESSAGE("Neutralizing Gas filled the area!");
|
MESSAGE("Neutralizing gas filled the area!");
|
||||||
SWITCH_OUT_MESSAGE("Weezing");
|
SWITCH_OUT_MESSAGE("Weezing");
|
||||||
MESSAGE("The effects of Neutralizing Gas wore off!");
|
MESSAGE("The effects of the neutralizing gas wore off!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
||||||
SEND_IN_MESSAGE("Wobbuffet");
|
SEND_IN_MESSAGE("Wobbuffet");
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ SINGLE_BATTLE_TEST("Intrepid Sword raises Attack by one stage")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zacian's Intrepid Sword raised its Attack!");
|
MESSAGE("The opposing Zacian's Intrepid Sword raised its Attack!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE + 1);
|
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE + 1);
|
||||||
}
|
}
|
||||||
|
@ -34,11 +34,11 @@ SINGLE_BATTLE_TEST("Intrepid Sword raises Attack by one stage only once per batt
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zacian's Intrepid Sword raised its Attack!");
|
MESSAGE("The opposing Zacian's Intrepid Sword raised its Attack!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zacian's Intrepid Sword raised its Attack!");
|
MESSAGE("The opposing Zacian's Intrepid Sword raised its Attack!");
|
||||||
}
|
}
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE);
|
||||||
|
@ -55,12 +55,12 @@ SINGLE_BATTLE_TEST("Intrepid Sword activates when it's no longer effected by Neu
|
||||||
TURN { SWITCH(player, 1); }
|
TURN { SWITCH(player, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
ABILITY_POPUP(player, ABILITY_NEUTRALIZING_GAS);
|
||||||
MESSAGE("Neutralizing Gas filled the area!");
|
MESSAGE("Neutralizing gas filled the area!");
|
||||||
SWITCH_OUT_MESSAGE("Weezing");
|
SWITCH_OUT_MESSAGE("Weezing");
|
||||||
MESSAGE("The effects of Neutralizing Gas wore off!");
|
MESSAGE("The effects of the neutralizing gas wore off!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zacian's Intrepid Sword raised its Attack!");
|
MESSAGE("The opposing Zacian's Intrepid Sword raised its Attack!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ SINGLE_BATTLE_TEST("Intrepid Sword and Dauntless Shield both can be Skill Swappe
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
ABILITY_POPUP(opponent, ABILITY_INTREPID_SWORD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zacian's Intrepid Sword raised its Attack!");
|
MESSAGE("The opposing Zacian's Intrepid Sword raised its Attack!");
|
||||||
|
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SKILL_SWAP, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SKILL_SWAP, player);
|
||||||
ABILITY_POPUP(player, ABILITY_INTREPID_SWORD);
|
ABILITY_POPUP(player, ABILITY_INTREPID_SWORD);
|
||||||
|
@ -86,7 +86,7 @@ SINGLE_BATTLE_TEST("Intrepid Sword and Dauntless Shield both can be Skill Swappe
|
||||||
|
|
||||||
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
ABILITY_POPUP(opponent, ABILITY_DAUNTLESS_SHIELD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Zamazenta's Dauntless Shield raised its Defense!");
|
MESSAGE("The opposing Zamazenta's Dauntless Shield raised its Defense!");
|
||||||
|
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SKILL_SWAP, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SKILL_SWAP, player);
|
||||||
ABILITY_POPUP(player, ABILITY_DAUNTLESS_SHIELD);
|
ABILITY_POPUP(player, ABILITY_DAUNTLESS_SHIELD);
|
||||||
|
|
|
@ -27,11 +27,11 @@ SINGLE_BATTLE_TEST("Keen Eye, Gen9+ Illuminate & Minds Eye prevent accuracy stag
|
||||||
ABILITY_POPUP(opponent, ability);
|
ABILITY_POPUP(opponent, ability);
|
||||||
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
if (species == SPECIES_HITMONCHAN)
|
if (species == SPECIES_HITMONCHAN)
|
||||||
MESSAGE("Foe Hitmonchan's Keen Eye prevents accuracy loss!");
|
MESSAGE("The opposing Hitmonchan's Keen Eye prevents accuracy loss!");
|
||||||
else if (species == SPECIES_STARYU)
|
else if (species == SPECIES_STARYU)
|
||||||
MESSAGE("Foe Staryu's Illuminate prevents accuracy loss!");
|
MESSAGE("The opposing Staryu's Illuminate prevents accuracy loss!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Ursaluna's Mind's Eye prevents accuracy loss!");
|
MESSAGE("The opposing Ursaluna's Mind's Eye prevents accuracy loss!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -111,22 +111,22 @@ SINGLE_BATTLE_TEST("Keen Eye, Gen9+ Illuminate & Minds Eye don't prevent Topsy-T
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_HONE_CLAWS, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_HONE_CLAWS, opponent);
|
||||||
if (species == SPECIES_HITMONCHAN) {
|
if (species == SPECIES_HITMONCHAN) {
|
||||||
MESSAGE("Foe Hitmonchan's Attack rose!");
|
MESSAGE("The opposing Hitmonchan's Attack rose!");
|
||||||
MESSAGE("Foe Hitmonchan's accuracy rose!");
|
MESSAGE("The opposing Hitmonchan's accuracy rose!");
|
||||||
} else if (species == SPECIES_STARYU) {
|
} else if (species == SPECIES_STARYU) {
|
||||||
MESSAGE("Foe Staryu's Attack rose!");
|
MESSAGE("The opposing Staryu's Attack rose!");
|
||||||
MESSAGE("Foe Staryu's accuracy rose!");
|
MESSAGE("The opposing Staryu's accuracy rose!");
|
||||||
} else {
|
} else {
|
||||||
MESSAGE("Foe Ursaluna's Attack rose!");
|
MESSAGE("The opposing Ursaluna's Attack rose!");
|
||||||
MESSAGE("Foe Ursaluna's accuracy rose!");
|
MESSAGE("The opposing Ursaluna's accuracy rose!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOPSY_TURVY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOPSY_TURVY, player);
|
||||||
if (species == SPECIES_HITMONCHAN)
|
if (species == SPECIES_HITMONCHAN)
|
||||||
MESSAGE("Foe Hitmonchan's stat changes were all reversed!");
|
MESSAGE("All stat changes on the opposing Hitmonchan were inverted!");
|
||||||
else if (species == SPECIES_STARYU)
|
else if (species == SPECIES_STARYU)
|
||||||
MESSAGE("Foe Staryu's stat changes were all reversed!");
|
MESSAGE("All stat changes on the opposing Staryu were inverted!");
|
||||||
else
|
else
|
||||||
MESSAGE("Foe Ursaluna's stat changes were all reversed!");
|
MESSAGE("All stat changes on the opposing Ursaluna were inverted!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_ACC], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(opponent->statStages[STAT_ACC], DEFAULT_STAT_STAGE - 1);
|
||||||
}
|
}
|
||||||
|
@ -183,13 +183,13 @@ SINGLE_BATTLE_TEST("Keen Eye & Gen9+ Illuminate don't prevent Spectral Thief fro
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_HONE_CLAWS, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_HONE_CLAWS, opponent);
|
||||||
if (species == SPECIES_HITMONCHAN)
|
if (species == SPECIES_HITMONCHAN)
|
||||||
{
|
{
|
||||||
MESSAGE("Foe Hitmonchan's Attack rose!");
|
MESSAGE("The opposing Hitmonchan's Attack rose!");
|
||||||
MESSAGE("Foe Hitmonchan's accuracy rose!");
|
MESSAGE("The opposing Hitmonchan's accuracy rose!");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
MESSAGE("Foe Staryu's Attack rose!");
|
MESSAGE("The opposing Staryu's Attack rose!");
|
||||||
MESSAGE("Foe Staryu's accuracy rose!");
|
MESSAGE("The opposing Staryu's accuracy rose!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPECTRAL_THIEF, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPECTRAL_THIEF, player);
|
||||||
MESSAGE("Wobbuffet stole the target's boosted stats!");
|
MESSAGE("Wobbuffet stole the target's boosted stats!");
|
||||||
|
|
|
@ -46,7 +46,7 @@ SINGLE_BATTLE_TEST("Leaf Guard prevents status conditions from Flame Orb and Tox
|
||||||
NONE_OF { MESSAGE("Leafeon was burned!"); STATUS_ICON(player, burn: TRUE); }
|
NONE_OF { MESSAGE("Leafeon was burned!"); STATUS_ICON(player, burn: TRUE); }
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
NONE_OF { MESSAGE("Leafeon is badly poisoned!"); STATUS_ICON(player, poison: TRUE); }
|
NONE_OF { MESSAGE("Leafeon was badly poisoned!"); STATUS_ICON(player, poison: TRUE); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,12 +17,12 @@ SINGLE_BATTLE_TEST("Lightning Rod absorbs Electric-type moves and increases the
|
||||||
};
|
};
|
||||||
ABILITY_POPUP(opponent, ABILITY_LIGHTNING_ROD);
|
ABILITY_POPUP(opponent, ABILITY_LIGHTNING_ROD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Raichu's Sp. Atk rose!");
|
MESSAGE("The opposing Raichu's Sp. Atk rose!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_LIGHTNING_ROD);
|
ABILITY_POPUP(opponent, ABILITY_LIGHTNING_ROD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Raichu's Sp. Atk rose!");
|
MESSAGE("The opposing Raichu's Sp. Atk rose!");
|
||||||
};
|
};
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_THUNDERBOLT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_THUNDERBOLT, player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
|
@ -54,10 +54,10 @@ DOUBLE_BATTLE_TEST("Lightning Rod forces single-target Electric-type moves to ta
|
||||||
};
|
};
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_LIGHTNING_ROD);
|
ABILITY_POPUP(opponentLeft, ABILITY_LIGHTNING_ROD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Raichu's Sp. Atk rose!");
|
MESSAGE("The opposing Raichu's Sp. Atk rose!");
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_LIGHTNING_ROD);
|
ABILITY_POPUP(opponentLeft, ABILITY_LIGHTNING_ROD);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Raichu's Sp. Atk rose!");
|
MESSAGE("The opposing Raichu's Sp. Atk rose!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
HP_BAR(opponentRight);
|
HP_BAR(opponentRight);
|
||||||
|
|
|
@ -13,7 +13,7 @@ SINGLE_BATTLE_TEST("Magic Bounce bounces back status moves")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
||||||
MESSAGE("Wynaut's Toxic was bounced back by Foe Espeon's Magic Bounce!");
|
MESSAGE("Wynaut's Toxic was bounced back by the opposing Espeon's Magic Bounce!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, opponent);
|
||||||
STATUS_ICON(player, badPoison: TRUE);
|
STATUS_ICON(player, badPoison: TRUE);
|
||||||
}
|
}
|
||||||
|
@ -31,7 +31,7 @@ SINGLE_BATTLE_TEST("Magic Bounce bounces back powder moves")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
||||||
MESSAGE("Wynaut's Stun Spore was bounced back by Foe Espeon's Magic Bounce!");
|
MESSAGE("Wynaut's Stun Spore was bounced back by the opposing Espeon's Magic Bounce!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, opponent);
|
||||||
STATUS_ICON(player, paralysis: TRUE);
|
STATUS_ICON(player, paralysis: TRUE);
|
||||||
}
|
}
|
||||||
|
@ -49,7 +49,7 @@ SINGLE_BATTLE_TEST("Magic Bounce cannot bounce back powder moves against Grass T
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
||||||
MESSAGE("Oddish's Stun Spore was bounced back by Foe Espeon's Magic Bounce!");
|
MESSAGE("Oddish's Stun Spore was bounced back by the opposing Espeon's Magic Bounce!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, opponent);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, opponent);
|
||||||
MESSAGE("It doesn't affect Oddish…");
|
MESSAGE("It doesn't affect Oddish…");
|
||||||
NOT STATUS_ICON(player, paralysis: TRUE);
|
NOT STATUS_ICON(player, paralysis: TRUE);
|
||||||
|
@ -70,7 +70,7 @@ DOUBLE_BATTLE_TEST("Magic Bounce bounces back moves hitting both foes at two foe
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_MAGIC_BOUNCE);
|
ABILITY_POPUP(opponentLeft, ABILITY_MAGIC_BOUNCE);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_LEER, playerLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_LEER, playerLeft);
|
||||||
MESSAGE("Abra's Leer was bounced back by Foe Espeon's Magic Bounce!");
|
MESSAGE("Abra's Leer was bounced back by the opposing Espeon's Magic Bounce!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_LEER, opponentLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_LEER, opponentLeft);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
MESSAGE("Abra's Defense fell!");
|
MESSAGE("Abra's Defense fell!");
|
||||||
|
@ -78,7 +78,7 @@ DOUBLE_BATTLE_TEST("Magic Bounce bounces back moves hitting both foes at two foe
|
||||||
MESSAGE("Kadabra's Defense fell!");
|
MESSAGE("Kadabra's Defense fell!");
|
||||||
// Also check if second original target gets hit by Leer as this was once bugged
|
// Also check if second original target gets hit by Leer as this was once bugged
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Wynaut's Defense fell!");
|
MESSAGE("The opposing Wynaut's Defense fell!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,10 +106,10 @@ DOUBLE_BATTLE_TEST("Magic Bounce bounces back moves hitting foes field")
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_MAGIC_BOUNCE);
|
ABILITY_POPUP(opponentRight, ABILITY_MAGIC_BOUNCE);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, playerLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, playerLeft);
|
||||||
if (abilityBattlerOne == ABILITY_MAGIC_BOUNCE) {
|
if (abilityBattlerOne == ABILITY_MAGIC_BOUNCE) {
|
||||||
MESSAGE("Abra's Stealth Rock was bounced back by Foe Natu's Magic Bounce!");
|
MESSAGE("Abra's Stealth Rock was bounced back by the opposing Natu's Magic Bounce!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, opponentLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, opponentLeft);
|
||||||
} else {
|
} else {
|
||||||
MESSAGE("Abra's Stealth Rock was bounced back by Foe Espeon's Magic Bounce!");
|
MESSAGE("Abra's Stealth Rock was bounced back by the opposing Espeon's Magic Bounce!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, opponentRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_STEALTH_ROCK, opponentRight);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -126,7 +126,7 @@ SINGLE_BATTLE_TEST("Magic Bounce bounced back status moves can not be bounced ba
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
ABILITY_POPUP(opponent, ABILITY_MAGIC_BOUNCE);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
||||||
MESSAGE("Espeon's Toxic was bounced back by Foe Espeon's Magic Bounce!");
|
MESSAGE("Espeon's Toxic was bounced back by the opposing Espeon's Magic Bounce!");
|
||||||
NOT ABILITY_POPUP(player, ABILITY_MAGIC_BOUNCE);
|
NOT ABILITY_POPUP(player, ABILITY_MAGIC_BOUNCE);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, opponent);
|
||||||
STATUS_ICON(player, badPoison: TRUE);
|
STATUS_ICON(player, badPoison: TRUE);
|
||||||
|
|
|
@ -15,15 +15,15 @@ SINGLE_BATTLE_TEST("Magician does not get self-damage recoil after stealing Life
|
||||||
// 1st turn
|
// 1st turn
|
||||||
MESSAGE("Delphox used Tackle!");
|
MESSAGE("Delphox used Tackle!");
|
||||||
ABILITY_POPUP(player, ABILITY_MAGICIAN);
|
ABILITY_POPUP(player, ABILITY_MAGICIAN);
|
||||||
MESSAGE("Delphox stole Foe Wobbuffet's Life Orb!");
|
MESSAGE("Delphox stole the opposing Wobbuffet's Life Orb!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
MESSAGE("Delphox was hurt by its Life Orb!");
|
MESSAGE("Delphox was hurt by the Life Orb!");
|
||||||
}
|
}
|
||||||
// 2nd turn - Life Orb recoil happens now
|
// 2nd turn - Life Orb recoil happens now
|
||||||
MESSAGE("Delphox used Tackle!");
|
MESSAGE("Delphox used Tackle!");
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
MESSAGE("Delphox was hurt by its Life Orb!");
|
MESSAGE("Delphox was hurt by the Life Orb!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@ SINGLE_BATTLE_TEST("Mind's Eye doesn't bypass a Ghost-type's Wonder Guard")
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(opponent, ABILITY_WONDER_GUARD);
|
ABILITY_POPUP(opponent, ABILITY_WONDER_GUARD);
|
||||||
MESSAGE("Foe Shedinja avoided damage with Wonder Guard!");
|
MESSAGE("The opposing Shedinja avoided damage with Wonder Guard!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,22 +23,22 @@ SINGLE_BATTLE_TEST("Mirror Armor lowers a stat of the attacking pokemon")
|
||||||
switch (statId)
|
switch (statId)
|
||||||
{
|
{
|
||||||
case STAT_DEF:
|
case STAT_DEF:
|
||||||
MESSAGE("Foe Wynaut's Defense fell!");
|
MESSAGE("The opposing Wynaut's Defense fell!");
|
||||||
break;
|
break;
|
||||||
case STAT_ATK:
|
case STAT_ATK:
|
||||||
MESSAGE("Foe Wynaut's Attack fell!");
|
MESSAGE("The opposing Wynaut's Attack fell!");
|
||||||
break;
|
break;
|
||||||
case STAT_EVASION:
|
case STAT_EVASION:
|
||||||
MESSAGE("Foe Wynaut's evasiveness harshly fell!");
|
MESSAGE("The opposing Wynaut's evasiveness harshly fell!");
|
||||||
break;
|
break;
|
||||||
case STAT_ACC:
|
case STAT_ACC:
|
||||||
MESSAGE("Foe Wynaut's accuracy fell!");
|
MESSAGE("The opposing Wynaut's accuracy fell!");
|
||||||
break;
|
break;
|
||||||
case STAT_SPATK:
|
case STAT_SPATK:
|
||||||
MESSAGE("Foe Wynaut's Sp. Atk fell!");
|
MESSAGE("The opposing Wynaut's Sp. Atk fell!");
|
||||||
break;
|
break;
|
||||||
case STAT_SPDEF:
|
case STAT_SPDEF:
|
||||||
MESSAGE("Foe Wynaut's Sp. Def harshly fell!");
|
MESSAGE("The opposing Wynaut's Sp. Def harshly fell!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} THEN {
|
} THEN {
|
||||||
|
@ -55,11 +55,11 @@ SINGLE_BATTLE_TEST("Mirror Armor triggers even if the attacking Pokemon also has
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_LEER); }
|
TURN { MOVE(opponent, MOVE_LEER); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Corviknight used Leer!");
|
MESSAGE("The opposing Corviknight used Leer!");
|
||||||
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
||||||
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Corviknight's Defense fell!");
|
MESSAGE("The opposing Corviknight's Defense fell!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
||||||
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE - 1);
|
||||||
|
@ -74,10 +74,10 @@ SINGLE_BATTLE_TEST("Mirror Armor doesn't lower the stats of an attacking Pokemon
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_LEER); }
|
TURN { MOVE(opponent, MOVE_LEER); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wynaut used Leer!");
|
MESSAGE("The opposing Wynaut used Leer!");
|
||||||
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
||||||
ABILITY_POPUP(opponent, ABILITY_CLEAR_BODY);
|
ABILITY_POPUP(opponent, ABILITY_CLEAR_BODY);
|
||||||
MESSAGE("Foe Wynaut's Clear Body prevents stat loss!");
|
MESSAGE("The opposing Wynaut's Clear Body prevents stat loss!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
||||||
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
||||||
|
@ -95,7 +95,7 @@ SINGLE_BATTLE_TEST("Mirror Armor lowers the Attack of Pokemon with Intimidate")
|
||||||
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(opponent, ABILITY_INTIMIDATE);
|
||||||
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Gyarados's Attack fell!");
|
MESSAGE("The opposing Gyarados's Attack fell!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->statStages[STAT_ATK], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(player->statStages[STAT_ATK], DEFAULT_STAT_STAGE);
|
||||||
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE - 1);
|
EXPECT_EQ(opponent->statStages[STAT_ATK], DEFAULT_STAT_STAGE - 1);
|
||||||
|
@ -113,9 +113,9 @@ SINGLE_BATTLE_TEST("Mirror Armor doesn't lower the stats of an attacking Pokemon
|
||||||
TURN { MOVE(opponent, MOVE_SUBSTITUTE); }
|
TURN { MOVE(opponent, MOVE_SUBSTITUTE); }
|
||||||
TURN { MOVE(opponent, MOVE_LEER); }
|
TURN { MOVE(opponent, MOVE_LEER); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wynaut used Substitute!");
|
MESSAGE("The opposing Wynaut used Substitute!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUBSTITUTE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUBSTITUTE, opponent);
|
||||||
MESSAGE("Foe Wynaut used Leer!");
|
MESSAGE("The opposing Wynaut used Leer!");
|
||||||
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
||||||
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
} THEN {
|
} THEN {
|
||||||
|
@ -132,10 +132,10 @@ SINGLE_BATTLE_TEST("Mirror Armor raises the stat of an attacking Pokemon with Co
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_LEER); }
|
TURN { MOVE(opponent, MOVE_LEER); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Shuckle used Leer!");
|
MESSAGE("The opposing Shuckle used Leer!");
|
||||||
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Shuckle's Defense rose!");
|
MESSAGE("The opposing Shuckle's Defense rose!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
||||||
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE + 1);
|
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE + 1);
|
||||||
|
@ -156,10 +156,10 @@ SINGLE_BATTLE_TEST("Mirror Armor doesn't lower the stat of the attacking Pokemon
|
||||||
MESSAGE("Corviknight used Screech!");
|
MESSAGE("Corviknight used Screech!");
|
||||||
MESSAGE("Corviknight used Screech!");
|
MESSAGE("Corviknight used Screech!");
|
||||||
MESSAGE("Corviknight used Screech!");
|
MESSAGE("Corviknight used Screech!");
|
||||||
MESSAGE("Foe Wynaut used Leer!");
|
MESSAGE("The opposing Wynaut used Leer!");
|
||||||
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
ABILITY_POPUP(player, ABILITY_MIRROR_ARMOR);
|
||||||
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
NOT ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Wynaut's Defense won't go lower!");
|
MESSAGE("The opposing Wynaut's Defense won't go any lower!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
EXPECT_EQ(player->statStages[STAT_DEF], DEFAULT_STAT_STAGE);
|
||||||
EXPECT_EQ(opponent->statStages[STAT_DEF], MIN_STAT_STAGE);
|
EXPECT_EQ(opponent->statStages[STAT_DEF], MIN_STAT_STAGE);
|
||||||
|
@ -186,10 +186,10 @@ DOUBLE_BATTLE_TEST("Mirror Armor lowers Speed of the partner Pokemon after Court
|
||||||
TURN { }
|
TURN { }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wobbuffet used Sticky Web!");
|
MESSAGE("Wobbuffet used Sticky Web!");
|
||||||
MESSAGE("Foe Wynaut used Court Change!");
|
MESSAGE("The opposing Wynaut used Court Change!");
|
||||||
MESSAGE("Foe Wynaut swapped the battle effects affecting each side!");
|
MESSAGE("The opposing Wynaut swapped the battle effects affecting each side of the field!");
|
||||||
SEND_IN_MESSAGE("Corviknight");
|
SEND_IN_MESSAGE("Corviknight");
|
||||||
MESSAGE("Corviknight was caught in a Sticky Web!");
|
MESSAGE("Corviknight was caught in a sticky web!");
|
||||||
ABILITY_POPUP(playerRight, ABILITY_MIRROR_ARMOR);
|
ABILITY_POPUP(playerRight, ABILITY_MIRROR_ARMOR);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
MESSAGE("Wobbuffet's Speed fell!");
|
MESSAGE("Wobbuffet's Speed fell!");
|
||||||
|
|
|
@ -23,8 +23,8 @@ DOUBLE_BATTLE_TEST("Moxie/Chilling Neigh raises Attack by one stage after direct
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
ONE_OF {
|
ONE_OF {
|
||||||
MESSAGE("Snorunt fainted!");
|
MESSAGE("Snorunt fainted!");
|
||||||
MESSAGE("Foe Glalie fainted!");
|
MESSAGE("The opposing Glalie fainted!");
|
||||||
MESSAGE("Foe Abra fainted!");
|
MESSAGE("The opposing Abra fainted!");
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(playerLeft, abilityPopUp);
|
ABILITY_POPUP(playerLeft, abilityPopUp);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
|
@ -61,8 +61,8 @@ DOUBLE_BATTLE_TEST("Moxie/Chilling Neigh does not trigger if Pokemon faint to in
|
||||||
for (i = 0; i < 3; i++) {
|
for (i = 0; i < 3; i++) {
|
||||||
ONE_OF {
|
ONE_OF {
|
||||||
MESSAGE("Snorunt fainted!");
|
MESSAGE("Snorunt fainted!");
|
||||||
MESSAGE("Foe Glalie fainted!");
|
MESSAGE("The opposing Glalie fainted!");
|
||||||
MESSAGE("Foe Abra fainted!");
|
MESSAGE("The opposing Abra fainted!");
|
||||||
}
|
}
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(playerLeft, abilityPopUp);
|
ABILITY_POPUP(playerLeft, abilityPopUp);
|
||||||
|
@ -95,13 +95,13 @@ SINGLE_BATTLE_TEST("Moxie/Chilling Neigh does not trigger when already at maximu
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_BELLY_DRUM, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_BELLY_DRUM, player);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
if (species == SPECIES_SALAMENCE)
|
if (species == SPECIES_SALAMENCE)
|
||||||
MESSAGE("Salamence cut its own HP and maximized ATTACK!");
|
MESSAGE("Salamence cut its own HP and maximized its Attack!");
|
||||||
else if (species == SPECIES_GLASTRIER)
|
else if (species == SPECIES_GLASTRIER)
|
||||||
MESSAGE("Glastrier cut its own HP and maximized ATTACK!");
|
MESSAGE("Glastrier cut its own HP and maximized its Attack!");
|
||||||
else
|
else
|
||||||
MESSAGE("Calyrex cut its own HP and maximized ATTACK!");
|
MESSAGE("Calyrex cut its own HP and maximized its Attack!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_QUICK_ATTACK, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_QUICK_ATTACK, player);
|
||||||
MESSAGE("Foe Snorunt fainted!");
|
MESSAGE("The opposing Snorunt fainted!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, abilityPopUp);
|
ABILITY_POPUP(player, abilityPopUp);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
|
|
|
@ -61,18 +61,18 @@ DOUBLE_BATTLE_TEST("Opportunist raises Attack only once when partner has Intimid
|
||||||
if (abilityLeft == ABILITY_CONTRARY) {
|
if (abilityLeft == ABILITY_CONTRARY) {
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_CONTRARY);
|
ABILITY_POPUP(opponentLeft, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Spinda's Attack rose!");
|
MESSAGE("The opposing Spinda's Attack rose!");
|
||||||
} else {
|
} else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Mightyena's Intimidate cuts Foe Spinda's attack!");
|
MESSAGE("Mightyena's Intimidate cuts the opposing Spinda's attack!");
|
||||||
}
|
}
|
||||||
if (abilityRight == ABILITY_CONTRARY) {
|
if (abilityRight == ABILITY_CONTRARY) {
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_CONTRARY);
|
ABILITY_POPUP(opponentRight, ABILITY_CONTRARY);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Foe Spinda's Attack rose!");
|
MESSAGE("The opposing Spinda's Attack rose!");
|
||||||
} else {
|
} else {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentRight);
|
||||||
MESSAGE("Mightyena's Intimidate cuts Foe Spinda's attack!");
|
MESSAGE("Mightyena's Intimidate cuts the opposing Spinda's attack!");
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((abilityLeft == ABILITY_CONTRARY && abilityRight != ABILITY_CONTRARY)
|
if ((abilityLeft == ABILITY_CONTRARY && abilityRight != ABILITY_CONTRARY)
|
||||||
|
|
|
@ -12,7 +12,7 @@ SINGLE_BATTLE_TEST("Overcoat blocks powder and spore moves")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_OVERCOAT);
|
ABILITY_POPUP(opponent, ABILITY_OVERCOAT);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_STUN_SPORE, player);
|
||||||
MESSAGE("It doesn't affect Foe Pineco…");
|
MESSAGE("It doesn't affect the opposing Pineco…");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,11 +13,11 @@ SINGLE_BATTLE_TEST("Own Tempo prevents Intimidate but no other stat down changes
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
||||||
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
||||||
MESSAGE("Foe Slowpoke's Own Tempo prevents stat loss!");
|
MESSAGE("The opposing Slowpoke's Own Tempo prevents stat loss!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SCARY_FACE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SCARY_FACE, player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
||||||
MESSAGE("Foe Slowpoke's Own Tempo prevents stat loss!");
|
MESSAGE("The opposing Slowpoke's Own Tempo prevents stat loss!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,7 @@ SINGLE_BATTLE_TEST("Own Tempo prevents confusion from moves by the opponent")
|
||||||
TURN { MOVE(player, MOVE_CONFUSE_RAY); }
|
TURN { MOVE(player, MOVE_CONFUSE_RAY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
||||||
MESSAGE("Foe Slowpoke's Own Tempo prevents confusion!");
|
MESSAGE("The opposing Slowpoke's Own Tempo prevents confusion!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ SINGLE_BATTLE_TEST("Own Tempo prevents confusion from moves by the user")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PETAL_DANCE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PETAL_DANCE, opponent);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PETAL_DANCE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PETAL_DANCE, opponent);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_PETAL_DANCE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_PETAL_DANCE, opponent);
|
||||||
NONE_OF { MESSAGE("Foe Slowpoke became confused due to fatigue!"); }
|
NONE_OF { MESSAGE("The opposing Slowpoke became confused due to fatigue!"); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,7 +68,7 @@ SINGLE_BATTLE_TEST("Own Tempo is ignored by Mold Breaker")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
||||||
MESSAGE("Foe Slowpoke's Own Tempo prevents confusion!");
|
MESSAGE("The opposing Slowpoke's Own Tempo prevents confusion!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -84,12 +84,12 @@ SINGLE_BATTLE_TEST("Own Tempo cures confusion obtained from an opponent with Mol
|
||||||
TURN { MOVE(player, MOVE_CONFUSE_RAY); }
|
TURN { MOVE(player, MOVE_CONFUSE_RAY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
||||||
MESSAGE("Foe Slowpoke became confused!");
|
MESSAGE("The opposing Slowpoke became confused!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
||||||
MESSAGE("Foe Slowpoke's Own Tempo cured its confusion problem!");
|
MESSAGE("The opposing Slowpoke's Own Tempo cured its confusion problem!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -107,10 +107,10 @@ SINGLE_BATTLE_TEST("Own Tempo cures confusion if it's obtained via Skill Swap")
|
||||||
}
|
}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
||||||
MESSAGE("Foe Wobbuffet became confused!");
|
MESSAGE("The opposing Wobbuffet became confused!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SKILL_SWAP, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SKILL_SWAP, player);
|
||||||
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
ABILITY_POPUP(opponent, ABILITY_OWN_TEMPO);
|
||||||
MESSAGE("Foe Wobbuffet's Own Tempo cured its confusion problem!");
|
MESSAGE("The opposing Wobbuffet's Own Tempo cured its confusion problem!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,7 +94,7 @@ DOUBLE_BATTLE_TEST("Parental Bond does not convert multi-target moves into a two
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_EARTHQUAKE, playerLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_EARTHQUAKE, playerLeft);
|
||||||
HP_BAR(opponentLeft);
|
HP_BAR(opponentLeft);
|
||||||
MESSAGE("It doesn't affect Pidgey…");
|
MESSAGE("It doesn't affect Pidgey…");
|
||||||
MESSAGE("It doesn't affect Foe Pidgey…");
|
MESSAGE("It doesn't affect the opposing Pidgey…");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, playerRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, playerRight);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponentLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponentLeft);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponentRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponentRight);
|
||||||
|
@ -149,7 +149,7 @@ SINGLE_BATTLE_TEST("Parental Bond has no affect on multi hit moves and they stil
|
||||||
MESSAGE("Kangaskhan has Mega Evolved into Mega Kangaskhan!");
|
MESSAGE("Kangaskhan has Mega Evolved into Mega Kangaskhan!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
MESSAGE("Hit 2 time(s)!");
|
MESSAGE("The Pokémon was hit 2 time(s)!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
||||||
}
|
}
|
||||||
THEN {
|
THEN {
|
||||||
|
@ -176,7 +176,7 @@ SINGLE_BATTLE_TEST("Parental Bond has no affect on multi hit moves and they stil
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
MESSAGE("Hit 3 time(s)!");
|
MESSAGE("The Pokémon was hit 3 time(s)!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
||||||
}
|
}
|
||||||
THEN {
|
THEN {
|
||||||
|
@ -204,7 +204,7 @@ SINGLE_BATTLE_TEST("Parental Bond has no affect on multi hit moves and they stil
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
MESSAGE("Hit 4 time(s)!");
|
MESSAGE("The Pokémon was hit 4 time(s)!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
||||||
}
|
}
|
||||||
THEN {
|
THEN {
|
||||||
|
@ -231,7 +231,7 @@ SINGLE_BATTLE_TEST("Parental Bond has no affect on multi hit moves and they stil
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_COMET_PUNCH, player);
|
||||||
MESSAGE("Hit 5 time(s)!");
|
MESSAGE("The Pokémon was hit 5 time(s)!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CELEBRATE, opponent);
|
||||||
}
|
}
|
||||||
THEN {
|
THEN {
|
||||||
|
@ -255,9 +255,9 @@ SINGLE_BATTLE_TEST("Parental Bond Smack Down effect triggers after 2nd hit")
|
||||||
MESSAGE("Kangaskhan has Mega Evolved into Mega Kangaskhan!");
|
MESSAGE("Kangaskhan has Mega Evolved into Mega Kangaskhan!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SMACK_DOWN, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SMACK_DOWN, player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
NOT MESSAGE("Foe Skarmory fell straight down!");
|
NOT MESSAGE("The opposing Skarmory fell straight down!");
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
MESSAGE("Foe Skarmory fell straight down!");
|
MESSAGE("The opposing Skarmory fell straight down!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->species, SPECIES_KANGASKHAN_MEGA);
|
EXPECT_EQ(player->species, SPECIES_KANGASKHAN_MEGA);
|
||||||
}
|
}
|
||||||
|
@ -277,7 +277,7 @@ SINGLE_BATTLE_TEST("Parental Bond Snore strikes twice while asleep")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SNORE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SNORE, player);
|
||||||
HP_BAR(opponent, captureDamage: &damage[0]);
|
HP_BAR(opponent, captureDamage: &damage[0]);
|
||||||
HP_BAR(opponent, captureDamage: &damage[1]);
|
HP_BAR(opponent, captureDamage: &damage[1]);
|
||||||
MESSAGE("Hit 2 time(s)!");
|
MESSAGE("The Pokémon was hit 2 time(s)!");
|
||||||
} THEN {
|
} THEN {
|
||||||
if (B_PARENTAL_BOND_DMG == GEN_6)
|
if (B_PARENTAL_BOND_DMG == GEN_6)
|
||||||
EXPECT_MUL_EQ(damage[0], Q_4_12(0.5), damage[1]);
|
EXPECT_MUL_EQ(damage[0], Q_4_12(0.5), damage[1]);
|
||||||
|
|
|
@ -44,7 +44,7 @@ SINGLE_BATTLE_TEST("Pastel Veil immediately cures Mold Breaker poison")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TOXIC, player);
|
||||||
STATUS_ICON(opponent, badPoison: TRUE);
|
STATUS_ICON(opponent, badPoison: TRUE);
|
||||||
ABILITY_POPUP(opponent, ABILITY_PASTEL_VEIL);
|
ABILITY_POPUP(opponent, ABILITY_PASTEL_VEIL);
|
||||||
MESSAGE("Foe Ponyta's Pastel Veil cured its poison problem!");
|
MESSAGE("The opposing Ponyta's Pastel Veil cured its poison problem!");
|
||||||
STATUS_ICON(opponent, none: TRUE);
|
STATUS_ICON(opponent, none: TRUE);
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
}
|
}
|
||||||
|
@ -78,7 +78,7 @@ SINGLE_BATTLE_TEST("Pastel Veil prevents Toxic bad poison")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wobbuffet used Toxic!");
|
MESSAGE("Wobbuffet used Toxic!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_PASTEL_VEIL);
|
ABILITY_POPUP(opponent, ABILITY_PASTEL_VEIL);
|
||||||
MESSAGE("Foe Ponyta is protected by a pastel veil!");
|
MESSAGE("The opposing Ponyta is protected by a pastel veil!");
|
||||||
NOT STATUS_ICON(opponent, badPoison: TRUE);
|
NOT STATUS_ICON(opponent, badPoison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -96,7 +96,7 @@ DOUBLE_BATTLE_TEST("Pastel Veil prevents Toxic bad poison on partner")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wobbuffet used Toxic!");
|
MESSAGE("Wobbuffet used Toxic!");
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_PASTEL_VEIL);
|
ABILITY_POPUP(opponentLeft, ABILITY_PASTEL_VEIL);
|
||||||
MESSAGE("Foe Wynaut is protected by a pastel veil!");
|
MESSAGE("The opposing Wynaut is protected by a pastel veil!");
|
||||||
NOT STATUS_ICON(opponentRight, badPoison: TRUE);
|
NOT STATUS_ICON(opponentRight, badPoison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -147,7 +147,7 @@ DOUBLE_BATTLE_TEST("Pastel Veil cures partner's poison on initial switch in")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("2 sent out Wobbuffet and Ponyta!");
|
MESSAGE("2 sent out Wobbuffet and Ponyta!");
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_PASTEL_VEIL);
|
ABILITY_POPUP(opponentRight, ABILITY_PASTEL_VEIL);
|
||||||
MESSAGE("Foe Wobbuffet was cured of its poisoning!");
|
MESSAGE("The opposing Wobbuffet was cured of its poisoning!");
|
||||||
STATUS_ICON(opponentLeft, none: TRUE);
|
STATUS_ICON(opponentLeft, none: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -165,7 +165,7 @@ DOUBLE_BATTLE_TEST("Pastel Veil cures partner's poison on switch in")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("2 sent out Ponyta!");
|
MESSAGE("2 sent out Ponyta!");
|
||||||
ABILITY_POPUP(opponentRight, ABILITY_PASTEL_VEIL);
|
ABILITY_POPUP(opponentRight, ABILITY_PASTEL_VEIL);
|
||||||
MESSAGE("Foe Wobbuffet was cured of its poisoning!");
|
MESSAGE("The opposing Wobbuffet was cured of its poisoning!");
|
||||||
STATUS_ICON(opponentLeft, none: TRUE);
|
STATUS_ICON(opponentLeft, none: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,13 +18,13 @@ SINGLE_BATTLE_TEST("Poison Point inflicts poison on contact")
|
||||||
if (gMovesInfo[move].makesContact) {
|
if (gMovesInfo[move].makesContact) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_POISON_POINT);
|
ABILITY_POPUP(opponent, ABILITY_POISON_POINT);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
||||||
MESSAGE("Wobbuffet was poisoned by Foe Nidoran♂'s Poison Point!");
|
MESSAGE("Wobbuffet was poisoned by the opposing Nidoran♂'s Poison Point!");
|
||||||
STATUS_ICON(player, poison: TRUE);
|
STATUS_ICON(player, poison: TRUE);
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_POISON_POINT);
|
ABILITY_POPUP(opponent, ABILITY_POISON_POINT);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
||||||
MESSAGE("Wobbuffet was poisoned by Foe Nidoran♂'s Poison Point!");
|
MESSAGE("Wobbuffet was poisoned by the opposing Nidoran♂'s Poison Point!");
|
||||||
STATUS_ICON(player, poison: TRUE);
|
STATUS_ICON(player, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ SINGLE_BATTLE_TEST("Poison Point triggers 30% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_POISON_POINT);
|
ABILITY_POPUP(opponent, ABILITY_POISON_POINT);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, player);
|
||||||
MESSAGE("Wobbuffet was poisoned by Foe Nidoran♂'s Poison Point!");
|
MESSAGE("Wobbuffet was poisoned by the opposing Nidoran♂'s Poison Point!");
|
||||||
STATUS_ICON(player, poison: TRUE);
|
STATUS_ICON(player, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ SINGLE_BATTLE_TEST("Poison Puppeteer confuses target if it was poisoned by a dam
|
||||||
STATUS_ICON(opponent, poison: TRUE);
|
STATUS_ICON(opponent, poison: TRUE);
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_PUPPETEER);
|
ABILITY_POPUP(player, ABILITY_POISON_PUPPETEER);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
||||||
MESSAGE("Foe Wobbuffet became confused!");
|
MESSAGE("The opposing Wobbuffet became confused!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ SINGLE_BATTLE_TEST("Poison Puppeteer confuses target if it was (badly) poisoned
|
||||||
STATUS_ICON(opponent, badPoison: TRUE);
|
STATUS_ICON(opponent, badPoison: TRUE);
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_PUPPETEER);
|
ABILITY_POPUP(player, ABILITY_POISON_PUPPETEER);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
||||||
MESSAGE("Foe Wobbuffet became confused!");
|
MESSAGE("The opposing Wobbuffet became confused!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ SINGLE_BATTLE_TEST("Poison Puppeteer does not trigger if poison is Toxic Spikes
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_PUPPETEER);
|
ABILITY_POPUP(player, ABILITY_POISON_PUPPETEER);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_CONFUSION, opponent);
|
||||||
MESSAGE("Foe Wobbuffet became confused!");
|
MESSAGE("The opposing Wobbuffet became confused!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,7 @@ SINGLE_BATTLE_TEST("Poison Touch has a 30% chance to poison when attacking with
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, player);
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet was poisoned by Grimer's Poison Touch!");
|
MESSAGE("The opposing Wobbuffet was poisoned by Grimer's Poison Touch!");
|
||||||
STATUS_ICON(opponent, poison: TRUE);
|
STATUS_ICON(opponent, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -38,13 +38,13 @@ SINGLE_BATTLE_TEST("Poison Touch only applies when using contact moves")
|
||||||
if (gMovesInfo[move].makesContact) {
|
if (gMovesInfo[move].makesContact) {
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet was poisoned by Grimer's Poison Touch!");
|
MESSAGE("The opposing Wobbuffet was poisoned by Grimer's Poison Touch!");
|
||||||
STATUS_ICON(opponent, poison: TRUE);
|
STATUS_ICON(opponent, poison: TRUE);
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet was poisoned by Grimer's Poison Touch!");
|
MESSAGE("The opposing Wobbuffet was poisoned by Grimer's Poison Touch!");
|
||||||
STATUS_ICON(opponent, poison: TRUE);
|
STATUS_ICON(opponent, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -65,13 +65,13 @@ SINGLE_BATTLE_TEST("Poison Touch applies between multi-hit move hits")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_ARM_THRUST, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_ARM_THRUST, player);
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet was poisoned by Grimer's Poison Touch!");
|
MESSAGE("The opposing Wobbuffet was poisoned by Grimer's Poison Touch!");
|
||||||
STATUS_ICON(opponent, poison: TRUE);
|
STATUS_ICON(opponent, poison: TRUE);
|
||||||
MESSAGE("Foe Wobbuffet's Pecha Berry cured poison!");
|
MESSAGE("The opposing Wobbuffet's Pecha Berry cured its poison!");
|
||||||
STATUS_ICON(opponent, poison: FALSE);
|
STATUS_ICON(opponent, poison: FALSE);
|
||||||
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
ABILITY_POPUP(player, ABILITY_POISON_TOUCH);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet was poisoned by Grimer's Poison Touch!");
|
MESSAGE("The opposing Wobbuffet was poisoned by Grimer's Poison Touch!");
|
||||||
STATUS_ICON(opponent, poison: TRUE);
|
STATUS_ICON(opponent, poison: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -77,11 +77,11 @@ DOUBLE_BATTLE_TEST("Prankster-affected moves called via Instruct do not affect D
|
||||||
}
|
}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, playerLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, playerLeft);
|
||||||
MESSAGE("It doesn't affect Foe Umbreon…");
|
MESSAGE("It doesn't affect the opposing Umbreon…");
|
||||||
MESSAGE("Wobbuffet used Instruct!");
|
MESSAGE("Wobbuffet used Instruct!");
|
||||||
MESSAGE("Volbeat used Confuse Ray!");
|
MESSAGE("Volbeat used Confuse Ray!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, playerLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, playerLeft);
|
||||||
MESSAGE("It doesn't affect Foe Umbreon…");
|
MESSAGE("It doesn't affect the opposing Umbreon…");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,7 +114,7 @@ DOUBLE_BATTLE_TEST("Moves called via Prankster-affected After you affect Dark-ty
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_AFTER_YOU, playerLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_AFTER_YOU, playerLeft);
|
||||||
MESSAGE("Wobbuffet used Confuse Ray!");
|
MESSAGE("Wobbuffet used Confuse Ray!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, playerRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, playerRight);
|
||||||
MESSAGE("Foe Umbreon became confused!");
|
MESSAGE("The opposing Umbreon became confused!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -156,10 +156,10 @@ SINGLE_BATTLE_TEST("Prankster-affected moves can still be bounced back by Dark-t
|
||||||
TURN { MOVE(player, MOVE_MAGIC_COAT); MOVE(opponent, MOVE_CONFUSE_RAY); }
|
TURN { MOVE(player, MOVE_MAGIC_COAT); MOVE(opponent, MOVE_CONFUSE_RAY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_MAGIC_COAT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_MAGIC_COAT, player);
|
||||||
MESSAGE("Foe Volbeat used Confuse Ray!");
|
MESSAGE("The opposing Volbeat used Confuse Ray!");
|
||||||
MESSAGE("Foe Volbeat's Confuse Ray was bounced back by MAGIC COAT!");
|
MESSAGE("Umbreon bounced the Confuse Ray back!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
||||||
MESSAGE("Foe Volbeat became confused!");
|
MESSAGE("The opposing Volbeat became confused!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -178,14 +178,14 @@ SINGLE_BATTLE_TEST("Prankster-affected moves which are reflected by Magic Coat c
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Sableye used Magic Coat!");
|
MESSAGE("Sableye used Magic Coat!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_MAGIC_COAT, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_MAGIC_COAT, player);
|
||||||
MESSAGE("Foe Murkrow used Confuse Ray!");
|
MESSAGE("The opposing Murkrow used Confuse Ray!");
|
||||||
MESSAGE("Foe Murkrow's Confuse Ray was bounced back by MAGIC COAT!");
|
MESSAGE("Sableye bounced the Confuse Ray back!");
|
||||||
if (sableyeAbility == ABILITY_PRANKSTER) {
|
if (sableyeAbility == ABILITY_PRANKSTER) {
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
||||||
MESSAGE("It doesn't affect Foe Murkrow…");
|
MESSAGE("It doesn't affect the opposing Murkrow…");
|
||||||
} else {
|
} else {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
||||||
MESSAGE("Foe Murkrow became confused!");
|
MESSAGE("The opposing Murkrow became confused!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -198,7 +198,7 @@ SINGLE_BATTLE_TEST("Prankster-affected moves can still be bounced back by a Dark
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_MEGA); MOVE(opponent, MOVE_CONFUSE_RAY); }
|
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_MEGA); MOVE(opponent, MOVE_CONFUSE_RAY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Volbeat's Confuse Ray was bounced back by Absol's Magic Bounce!");
|
MESSAGE("The opposing Volbeat's Confuse Ray was bounced back by Absol's Magic Bounce!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -211,9 +211,9 @@ SINGLE_BATTLE_TEST("Prankster-affected moves that are bounced back by Magic Boun
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_MEGA); MOVE(opponent, MOVE_CONFUSE_RAY); }
|
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_MEGA); MOVE(opponent, MOVE_CONFUSE_RAY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Murkrow's Confuse Ray was bounced back by Absol's Magic Bounce!");
|
MESSAGE("The opposing Murkrow's Confuse Ray was bounced back by Absol's Magic Bounce!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_CONFUSE_RAY, player);
|
||||||
MESSAGE("Foe Murkrow became confused!");
|
MESSAGE("The opposing Murkrow became confused!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,13 +16,13 @@ SINGLE_BATTLE_TEST("Primordial Sea blocks damaging Fire-type moves")
|
||||||
TURN { MOVE(opponent, MOVE_EMBER); }
|
TURN { MOVE(opponent, MOVE_EMBER); }
|
||||||
TURN { MOVE(opponent, MOVE_EMBER); }
|
TURN { MOVE(opponent, MOVE_EMBER); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Ember!");
|
MESSAGE("The opposing Wobbuffet used Ember!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_EMBER, opponent);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_EMBER, opponent);
|
||||||
MESSAGE("The Fire-type attack fizzled out\nin the heavy rain!");
|
MESSAGE("The Fire-type attack fizzled out in the heavy rain!");
|
||||||
NOT HP_BAR(player);
|
NOT HP_BAR(player);
|
||||||
MESSAGE("Foe Wobbuffet used Ember!");
|
MESSAGE("The opposing Wobbuffet used Ember!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_EMBER, opponent);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_EMBER, opponent);
|
||||||
MESSAGE("The Fire-type attack fizzled out\nin the heavy rain!");
|
MESSAGE("The Fire-type attack fizzled out in the heavy rain!");
|
||||||
NOT HP_BAR(player);
|
NOT HP_BAR(player);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->hp, player->maxHP);
|
EXPECT_EQ(player->hp, player->maxHP);
|
||||||
|
@ -42,10 +42,10 @@ DOUBLE_BATTLE_TEST("Primordial Sea blocks damaging Fire-type moves and prints th
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponentLeft, MOVE_ERUPTION); }
|
TURN { MOVE(opponentLeft, MOVE_ERUPTION); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Eruption!");
|
MESSAGE("The opposing Wobbuffet used Eruption!");
|
||||||
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_ERUPTION, opponentLeft);
|
NOT ANIMATION(ANIM_TYPE_MOVE, MOVE_ERUPTION, opponentLeft);
|
||||||
MESSAGE("The Fire-type attack fizzled out\nin the heavy rain!");
|
MESSAGE("The Fire-type attack fizzled out in the heavy rain!");
|
||||||
NOT MESSAGE("The Fire-type attack fizzled out\nin the heavy rain!");
|
NOT MESSAGE("The Fire-type attack fizzled out in the heavy rain!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(playerLeft->hp, playerLeft->maxHP);
|
EXPECT_EQ(playerLeft->hp, playerLeft->maxHP);
|
||||||
EXPECT_EQ(playerRight->hp, playerRight->maxHP);
|
EXPECT_EQ(playerRight->hp, playerRight->maxHP);
|
||||||
|
@ -60,7 +60,7 @@ SINGLE_BATTLE_TEST("Primordial Sea does not block a move if pokemon is asleep an
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_EMBER); }
|
TURN { MOVE(opponent, MOVE_EMBER); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NOT MESSAGE("The Fire-type attack fizzled out\nin the heavy rain!");
|
NOT MESSAGE("The Fire-type attack fizzled out in the heavy rain!");
|
||||||
MESSAGE("Foe Wobbuffet is fast asleep.");
|
MESSAGE("The opposing Wobbuffet is fast asleep.");
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -20,15 +20,15 @@ SINGLE_BATTLE_TEST("Protean changes the type of the user only once per switch in
|
||||||
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
TURN { MOVE(opponent, MOVE_WATER_GUN); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_PROTEAN);
|
ABILITY_POPUP(opponent, ABILITY_PROTEAN);
|
||||||
MESSAGE("Foe Kecleon transformed into the Water type!");
|
MESSAGE("The opposing Kecleon transformed into the Water type!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_PROTEAN);
|
ABILITY_POPUP(opponent, ABILITY_PROTEAN);
|
||||||
MESSAGE("Foe Kecleon transformed into the Normal type!");
|
MESSAGE("The opposing Kecleon transformed into the Normal type!");
|
||||||
}
|
}
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
ABILITY_POPUP(opponent, ABILITY_PROTEAN);
|
ABILITY_POPUP(opponent, ABILITY_PROTEAN);
|
||||||
MESSAGE("Foe Kecleon transformed into the Water type!");
|
MESSAGE("The opposing Kecleon transformed into the Water type!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, opponent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ SINGLE_BATTLE_TEST("Quick Draw has a 30% chance of going first")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_QUICK_DRAW);
|
ABILITY_POPUP(player, ABILITY_QUICK_DRAW);
|
||||||
MESSAGE("Slowbro used Tackle!");
|
MESSAGE("Slowbro used Tackle!");
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,7 +26,7 @@ SINGLE_BATTLE_TEST("Quick Draw does not activate 70% of the time")
|
||||||
TURN { MOVE(opponent, MOVE_CELEBRATE); MOVE(player, MOVE_TACKLE); }
|
TURN { MOVE(opponent, MOVE_CELEBRATE); MOVE(player, MOVE_TACKLE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NOT ABILITY_POPUP(player, ABILITY_QUICK_DRAW);
|
NOT ABILITY_POPUP(player, ABILITY_QUICK_DRAW);
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
MESSAGE("Slowbro used Tackle!");
|
MESSAGE("Slowbro used Tackle!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,22 +32,22 @@ SINGLE_BATTLE_TEST("Rattled boosts speed by 1 when hit by Bug, Dark or Ghost typ
|
||||||
if (move != MOVE_TACKLE) {
|
if (move != MOVE_TACKLE) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Sudowoodo's Speed rose!");
|
MESSAGE("The opposing Sudowoodo's Speed rose!");
|
||||||
}
|
}
|
||||||
MESSAGE("Foe Sudowoodo used Celebrate!");
|
MESSAGE("The opposing Sudowoodo used Celebrate!");
|
||||||
// Sudowoodo is now faster
|
// Sudowoodo is now faster
|
||||||
if (move != MOVE_TACKLE){
|
if (move != MOVE_TACKLE){
|
||||||
MESSAGE("Foe Sudowoodo used Celebrate!");
|
MESSAGE("The opposing Sudowoodo used Celebrate!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Sudowoodo's Speed rose!");
|
MESSAGE("The opposing Sudowoodo's Speed rose!");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
MESSAGE("Foe Sudowoodo used Celebrate!");
|
MESSAGE("The opposing Sudowoodo used Celebrate!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -63,10 +63,10 @@ SINGLE_BATTLE_TEST("Rattled boosts speed by 1 when affected by Intimidate")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Gyarados's Intimidate cuts Foe Sudowoodo's attack!");
|
MESSAGE("Gyarados's Intimidate cuts the opposing Sudowoodo's attack!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Sudowoodo's Speed rose!");
|
MESSAGE("The opposing Sudowoodo's Speed rose!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ SINGLE_BATTLE_TEST("Rattled triggers correctly when hit by U-Turn") // Specific
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
ABILITY_POPUP(opponent, ABILITY_RATTLED);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Sudowoodo's Speed rose!");
|
MESSAGE("The opposing Sudowoodo's Speed rose!");
|
||||||
SEND_IN_MESSAGE("Wynaut");
|
SEND_IN_MESSAGE("Wynaut");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,14 +67,14 @@ SINGLE_BATTLE_TEST("Sap Sipper blocks multi-hit grass type moves")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_BULLET_SEED); }
|
TURN { MOVE(opponent, MOVE_BULLET_SEED); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Shellder used Bullet Seed!");
|
MESSAGE("The opposing Shellder used Bullet Seed!");
|
||||||
ABILITY_POPUP(player, ABILITY_SAP_SIPPER);
|
ABILITY_POPUP(player, ABILITY_SAP_SIPPER);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Marill's Attack rose!");
|
MESSAGE("Marill's Attack rose!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_BULLET_SEED, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_BULLET_SEED, opponent);
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
MESSAGE("Hit 5 time(s)!");
|
MESSAGE("The Pokémon was hit 5 time(s)!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@ SINGLE_BATTLE_TEST("Schooling switches Level 20+ Wishiwashi's form when HP is 25
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
}
|
}
|
||||||
MESSAGE("Wishiwashi used Celebrate!");
|
MESSAGE("Wishiwashi used Celebrate!");
|
||||||
MESSAGE("Foe Wobbuffet used Super Fang!");
|
MESSAGE("The opposing Wobbuffet used Super Fang!");
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
if (level >= 20)
|
if (level >= 20)
|
||||||
{
|
{
|
||||||
|
@ -64,7 +64,7 @@ SINGLE_BATTLE_TEST("Schooling switches Level 20+ Wishiwashi's form when HP is ov
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_FORM_CHANGE, player);
|
||||||
}
|
}
|
||||||
MESSAGE("Wishiwashi used Celebrate!");
|
MESSAGE("Wishiwashi used Celebrate!");
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
} THEN {
|
} THEN {
|
||||||
if (level >= 20 && overQuarterHP)
|
if (level >= 20 && overQuarterHP)
|
||||||
EXPECT_EQ(player->species, SPECIES_WISHIWASHI_SCHOOL);
|
EXPECT_EQ(player->species, SPECIES_WISHIWASHI_SCHOOL);
|
||||||
|
@ -92,7 +92,7 @@ SINGLE_BATTLE_TEST("Schooling switches Level 20+ Wishiwashi's form when HP is he
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE); MOVE(opponent, MOVE_HEAL_PULSE); }
|
TURN { MOVE(player, MOVE_CELEBRATE); MOVE(opponent, MOVE_HEAL_PULSE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Wishiwashi used Celebrate!");
|
MESSAGE("Wishiwashi used Celebrate!");
|
||||||
MESSAGE("Foe Wobbuffet used Heal Pulse!");
|
MESSAGE("The opposing Wobbuffet used Heal Pulse!");
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
if (level >= 20)
|
if (level >= 20)
|
||||||
{
|
{
|
||||||
|
|
|
@ -20,7 +20,7 @@ SINGLE_BATTLE_TEST("Scrappy prevents intimidate")
|
||||||
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
ABILITY_POPUP(player, ABILITY_INTIMIDATE);
|
||||||
NONE_OF { ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player); }
|
NONE_OF { ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player); }
|
||||||
ABILITY_POPUP(opponent, ABILITY_SCRAPPY);
|
ABILITY_POPUP(opponent, ABILITY_SCRAPPY);
|
||||||
MESSAGE("Foe Kangaskhan's Scrappy prevents stat loss!");
|
MESSAGE("The opposing Kangaskhan's Scrappy prevents stat loss!");
|
||||||
HP_BAR(player, captureDamage: &turnTwoHit);
|
HP_BAR(player, captureDamage: &turnTwoHit);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(turnOneHit, turnTwoHit);
|
EXPECT_EQ(turnOneHit, turnTwoHit);
|
||||||
|
@ -61,6 +61,6 @@ SINGLE_BATTLE_TEST("Scrappy doesn't bypass a Ghost-type's Wonder Guard")
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
}
|
}
|
||||||
ABILITY_POPUP(opponent, ABILITY_WONDER_GUARD);
|
ABILITY_POPUP(opponent, ABILITY_WONDER_GUARD);
|
||||||
MESSAGE("Foe Shedinja avoided damage with Wonder Guard!");
|
MESSAGE("The opposing Shedinja avoided damage with Wonder Guard!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@ SINGLE_BATTLE_TEST("Seed Sower sets up Grassy Terrain when hit by an attack")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_TACKLE); }
|
TURN { MOVE(opponent, MOVE_TACKLE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Tackle!");
|
MESSAGE("The opposing Wobbuffet used Tackle!");
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
ABILITY_POPUP(player);
|
ABILITY_POPUP(player);
|
||||||
MESSAGE("Grass grew to cover the battlefield!");
|
MESSAGE("Grass grew to cover the battlefield!");
|
||||||
|
|
|
@ -13,7 +13,7 @@ SINGLE_BATTLE_TEST("Shed Skin triggers 30% of the time")
|
||||||
TURN;
|
TURN;
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_SHED_SKIN);
|
ABILITY_POPUP(opponent, ABILITY_SHED_SKIN);
|
||||||
MESSAGE("Foe Arbok's Shed Skin cured its poison problem!");
|
MESSAGE("The opposing Arbok's Shed Skin cured its poison problem!");
|
||||||
STATUS_ICON(opponent, poison: FALSE);
|
STATUS_ICON(opponent, poison: FALSE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,13 +51,13 @@ SINGLE_BATTLE_TEST("Sheer Force boosts power, but removes secondary effects of m
|
||||||
STATUS_ICON(opponent, STATUS1_TOXIC_POISON);
|
STATUS_ICON(opponent, STATUS1_TOXIC_POISON);
|
||||||
STATUS_ICON(opponent, STATUS1_PARALYSIS);
|
STATUS_ICON(opponent, STATUS1_PARALYSIS);
|
||||||
MESSAGE("Wobbuffet is confused!");
|
MESSAGE("Wobbuffet is confused!");
|
||||||
MESSAGE("Wobbuffet flinched!");
|
MESSAGE("Wobbuffet flinched and couldn't move!");
|
||||||
}
|
}
|
||||||
// Volt Tackle/Flare Blitz edge case: recoil happens, but target isn't statused
|
// Volt Tackle/Flare Blitz edge case: recoil happens, but target isn't statused
|
||||||
if (gMovesInfo[move].recoil > 0)
|
if (gMovesInfo[move].recoil > 0)
|
||||||
{
|
{
|
||||||
HP_BAR(player);
|
HP_BAR(player);
|
||||||
MESSAGE("Tauros is hit with recoil!");
|
MESSAGE("Tauros was damaged by the recoil!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} FINALLY {
|
} FINALLY {
|
||||||
|
|
|
@ -28,12 +28,12 @@ SINGLE_BATTLE_TEST("Shield Dust blocks secondary effects")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
ANIMATION(ANIM_TYPE_MOVE, move, player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
MESSAGE("Foe Vivillon is paralyzed! It may be unable to move!");
|
MESSAGE("The opposing Vivillon is paralyzed, so it may be unable to move!");
|
||||||
MESSAGE("Foe Vivillon was burned!");
|
MESSAGE("The opposing Vivillon was burned!");
|
||||||
MESSAGE("Foe Vivillon was poisoned!");
|
MESSAGE("The opposing Vivillon was poisoned!");
|
||||||
MESSAGE("Foe Vivillon flinched!");
|
MESSAGE("The opposing Vivillon flinched and couldn't move!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Vivillon was prevented from healing!");
|
MESSAGE("The opposing Vivillon was prevented from healing!");
|
||||||
}
|
}
|
||||||
} THEN { // Can't find good way to test trapping
|
} THEN { // Can't find good way to test trapping
|
||||||
EXPECT(!(opponent->status2 & STATUS2_ESCAPE_PREVENTION));
|
EXPECT(!(opponent->status2 & STATUS2_ESCAPE_PREVENTION));
|
||||||
|
@ -64,16 +64,16 @@ SINGLE_BATTLE_TEST("Shield Dust does not block primary effects")
|
||||||
switch (move)
|
switch (move)
|
||||||
{
|
{
|
||||||
case MOVE_INFESTATION:
|
case MOVE_INFESTATION:
|
||||||
MESSAGE("Foe Vivillon has been afflicted with an infestation by Wobbuffet!");
|
MESSAGE("The opposing Vivillon has been afflicted with an infestation by Wobbuffet!");
|
||||||
break;
|
break;
|
||||||
case MOVE_THOUSAND_ARROWS:
|
case MOVE_THOUSAND_ARROWS:
|
||||||
MESSAGE("Foe Vivillon fell straight down!");
|
MESSAGE("The opposing Vivillon fell straight down!");
|
||||||
break;
|
break;
|
||||||
case MOVE_JAW_LOCK:
|
case MOVE_JAW_LOCK:
|
||||||
MESSAGE("Neither Pokémon can run away!");
|
MESSAGE("Neither Pokémon can run away!");
|
||||||
break;
|
break;
|
||||||
case MOVE_PAY_DAY:
|
case MOVE_PAY_DAY:
|
||||||
MESSAGE("Coins scattered everywhere!");
|
MESSAGE("Coins were scattered everywhere!");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} THEN { // Can't find good way to test trapping
|
} THEN { // Can't find good way to test trapping
|
||||||
|
@ -137,11 +137,11 @@ DOUBLE_BATTLE_TEST("Shield Dust does or does not block Sparkling Aria depending
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPARKLING_ARIA, playerLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPARKLING_ARIA, playerLeft);
|
||||||
if (moveToUse == MOVE_TACKLE) {
|
if (moveToUse == MOVE_TACKLE) {
|
||||||
MESSAGE("Foe Vivillon's burn was healed.");
|
MESSAGE("The opposing Vivillon's burn was cured!");
|
||||||
STATUS_ICON(opponentLeft, none: TRUE);
|
STATUS_ICON(opponentLeft, none: TRUE);
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
MESSAGE("Foe Vivillon's burn was healed.");
|
MESSAGE("The opposing Vivillon's burn was cured!");
|
||||||
STATUS_ICON(opponentLeft, none: TRUE);
|
STATUS_ICON(opponentLeft, none: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -159,7 +159,7 @@ SINGLE_BATTLE_TEST("Shield Dust blocks Sparkling Aria in singles")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPARKLING_ARIA, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SPARKLING_ARIA, player);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
MESSAGE("Foe Vivillon's burn was healed.");
|
MESSAGE("The opposing Vivillon's burn was cured!");
|
||||||
STATUS_ICON(opponent, none: TRUE);
|
STATUS_ICON(opponent, none: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,11 +10,11 @@ SINGLE_BATTLE_TEST("Speed Boost gradually boosts Speed")
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE); MOVE(opponent, MOVE_CELEBRATE); }
|
TURN { MOVE(player, MOVE_CELEBRATE); MOVE(opponent, MOVE_CELEBRATE); }
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE); MOVE(opponent, MOVE_CELEBRATE); }
|
TURN { MOVE(player, MOVE_CELEBRATE); MOVE(opponent, MOVE_CELEBRATE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
MESSAGE("Torchic used Celebrate!");
|
MESSAGE("Torchic used Celebrate!");
|
||||||
ABILITY_POPUP(player, ABILITY_SPEED_BOOST);
|
ABILITY_POPUP(player, ABILITY_SPEED_BOOST);
|
||||||
MESSAGE("Torchic's Speed Boost raised its SPEED!");
|
MESSAGE("Torchic's Speed Boost raised its Speed!");
|
||||||
MESSAGE("Torchic used Celebrate!");
|
MESSAGE("Torchic used Celebrate!");
|
||||||
MESSAGE("Foe Wobbuffet used Celebrate!");
|
MESSAGE("The opposing Wobbuffet used Celebrate!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ DOUBLE_BATTLE_TEST("Stalwart stops Lightning Rod and Storm Drain from redirectin
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponentLeft, ability);
|
ABILITY_POPUP(opponentLeft, ability);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Raichu's Sp. Atk rose!");
|
MESSAGE("The opposing Raichu's Sp. Atk rose!");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
HP_BAR(opponentRight);
|
HP_BAR(opponentRight);
|
||||||
|
|
|
@ -98,8 +98,8 @@ SINGLE_BATTLE_TEST("Stamina activates for every hit of a multi hit move")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_DOUBLE_KICK, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_DOUBLE_KICK, player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
STAMINA_STAT_RAISE(opponent, "Foe Mudbray's Defense rose!");
|
STAMINA_STAT_RAISE(opponent, "The opposing Mudbray's Defense rose!");
|
||||||
STAMINA_STAT_RAISE(opponent, "Foe Mudbray's Defense rose!");
|
STAMINA_STAT_RAISE(opponent, "The opposing Mudbray's Defense rose!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE + 2);
|
EXPECT_EQ(opponent->statStages[STAT_DEF], DEFAULT_STAT_STAGE + 2);
|
||||||
}
|
}
|
||||||
|
@ -114,7 +114,7 @@ SINGLE_BATTLE_TEST("Stamina is not activated by users own Substitute")
|
||||||
TURN { MOVE(player, MOVE_SUBSTITUTE); }
|
TURN { MOVE(player, MOVE_SUBSTITUTE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUBSTITUTE, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_SUBSTITUTE, player);
|
||||||
MESSAGE("Mudbray made a SUBSTITUTE!");
|
MESSAGE("Mudbray put in a substitute!");
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_STAMINA);
|
ABILITY_POPUP(player, ABILITY_STAMINA);
|
||||||
MESSAGE("Mudbray's Defense rose!");
|
MESSAGE("Mudbray's Defense rose!");
|
||||||
|
|
|
@ -17,13 +17,13 @@ SINGLE_BATTLE_TEST("Static inflicts paralysis on contact")
|
||||||
if (gMovesInfo[move].makesContact) {
|
if (gMovesInfo[move].makesContact) {
|
||||||
ABILITY_POPUP(opponent, ABILITY_STATIC);
|
ABILITY_POPUP(opponent, ABILITY_STATIC);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
||||||
MESSAGE("Foe Pikachu's Static paralyzed Wobbuffet! It may be unable to move!");
|
MESSAGE("The opposing Pikachu's Static paralyzed Wobbuffet, so it may be unable to move!");
|
||||||
STATUS_ICON(player, paralysis: TRUE);
|
STATUS_ICON(player, paralysis: TRUE);
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_STATIC);
|
ABILITY_POPUP(opponent, ABILITY_STATIC);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
||||||
MESSAGE("Foe Pikachu's Static paralyzed Wobbuffet! It may be unable to move!");
|
MESSAGE("The opposing Pikachu's Static paralyzed Wobbuffet, so it may be unable to move!");
|
||||||
STATUS_ICON(player, paralysis: TRUE);
|
STATUS_ICON(player, paralysis: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,7 @@ SINGLE_BATTLE_TEST("Static triggers 30% of the time")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_STATIC);
|
ABILITY_POPUP(opponent, ABILITY_STATIC);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PRZ, player);
|
||||||
MESSAGE("Foe Pikachu's Static paralyzed Wobbuffet! It may be unable to move!");
|
MESSAGE("The opposing Pikachu's Static paralyzed Wobbuffet, so it may be unable to move!");
|
||||||
STATUS_ICON(player, paralysis: TRUE);
|
STATUS_ICON(player, paralysis: TRUE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,7 @@ SINGLE_BATTLE_TEST("Stench has a 10% chance to flinch")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(player, MOVE_TACKLE); MOVE(opponent, MOVE_CELEBRATE); }
|
TURN { MOVE(player, MOVE_TACKLE); MOVE(opponent, MOVE_CELEBRATE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet flinched!");
|
MESSAGE("The opposing Wobbuffet flinched and couldn't move!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ SINGLE_BATTLE_TEST("Stench does not stack with King's Rock")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(player, MOVE_TACKLE); MOVE(opponent, MOVE_CELEBRATE); }
|
TURN { MOVE(player, MOVE_TACKLE); MOVE(opponent, MOVE_CELEBRATE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet flinched!");
|
MESSAGE("The opposing Wobbuffet flinched and couldn't move!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ DOUBLE_BATTLE_TEST("Stench only triggers if target takes damage")
|
||||||
MOVE(playerRight, MOVE_TACKLE, target: opponentRight);
|
MOVE(playerRight, MOVE_TACKLE, target: opponentRight);
|
||||||
}
|
}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
NONE_OF { MESSAGE("Wynaut flinched!"); }
|
NONE_OF { MESSAGE("Wynaut flinched and couldn't move!"); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,9 +72,9 @@ DOUBLE_BATTLE_TEST("Stench doesn't trigger if partner uses a move")
|
||||||
}
|
}
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, playerLeft);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FAKE_OUT, playerLeft);
|
||||||
MESSAGE("Foe Grimer flinched!");
|
MESSAGE("The opposing Grimer flinched and couldn't move!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponentRight);
|
||||||
NOT MESSAGE("Wynaut flinched!");
|
NOT MESSAGE("Wynaut flinched and couldn't move!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, playerRight);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, playerRight);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ SINGLE_BATTLE_TEST("Sticky Hold prevents item theft")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Ursaluna used Thief!");
|
MESSAGE("Ursaluna used Thief!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_STICKY_HOLD);
|
ABILITY_POPUP(opponent, ABILITY_STICKY_HOLD);
|
||||||
MESSAGE("Foe Gastrodon's Sticky Hold made Thief ineffective!");
|
MESSAGE("The opposing Gastrodon's Sticky Hold made Thief ineffective!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,12 +17,12 @@ SINGLE_BATTLE_TEST("Storm Drain absorbs Water-type moves and increases the Sp. A
|
||||||
};
|
};
|
||||||
ABILITY_POPUP(opponent, ABILITY_STORM_DRAIN);
|
ABILITY_POPUP(opponent, ABILITY_STORM_DRAIN);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Gastrodon's Sp. Atk rose!");
|
MESSAGE("The opposing Gastrodon's Sp. Atk rose!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(opponent, ABILITY_STORM_DRAIN);
|
ABILITY_POPUP(opponent, ABILITY_STORM_DRAIN);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Gastrodon's Sp. Atk rose!");
|
MESSAGE("The opposing Gastrodon's Sp. Atk rose!");
|
||||||
};
|
};
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, player);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_WATER_GUN, player);
|
||||||
HP_BAR(opponent);
|
HP_BAR(opponent);
|
||||||
|
@ -54,10 +54,10 @@ DOUBLE_BATTLE_TEST("Storm Drain forces single-target Water-type moves to target
|
||||||
};
|
};
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_STORM_DRAIN);
|
ABILITY_POPUP(opponentLeft, ABILITY_STORM_DRAIN);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Gastrodon's Sp. Atk rose!");
|
MESSAGE("The opposing Gastrodon's Sp. Atk rose!");
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_STORM_DRAIN);
|
ABILITY_POPUP(opponentLeft, ABILITY_STORM_DRAIN);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponentLeft);
|
||||||
MESSAGE("Foe Gastrodon's Sp. Atk rose!");
|
MESSAGE("The opposing Gastrodon's Sp. Atk rose!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
HP_BAR(opponentRight);
|
HP_BAR(opponentRight);
|
||||||
|
|
|
@ -10,7 +10,7 @@ SINGLE_BATTLE_TEST("Sturdy prevents OHKO moves")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_FISSURE); }
|
TURN { MOVE(opponent, MOVE_FISSURE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Fissure!");
|
MESSAGE("The opposing Wobbuffet used Fissure!");
|
||||||
ABILITY_POPUP(player, ABILITY_STURDY);
|
ABILITY_POPUP(player, ABILITY_STURDY);
|
||||||
MESSAGE("Geodude was protected by Sturdy!");
|
MESSAGE("Geodude was protected by Sturdy!");
|
||||||
} THEN {
|
} THEN {
|
||||||
|
|
|
@ -12,7 +12,7 @@ SINGLE_BATTLE_TEST("Supersweet Syrup lowers evasion once per battle by one stage
|
||||||
TURN { SWITCH(opponent, 0); }
|
TURN { SWITCH(opponent, 0); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponent, ABILITY_SUPERSWEET_SYRUP);
|
ABILITY_POPUP(opponent, ABILITY_SUPERSWEET_SYRUP);
|
||||||
MESSAGE("A supersweet aroma is wafting from the syrup covering Foe Dipplin!");
|
MESSAGE("A supersweet aroma is wafting from the syrup covering the opposing Dipplin!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("2 withdrew Dipplin!");
|
MESSAGE("2 withdrew Dipplin!");
|
||||||
MESSAGE("2 withdrew Wobbuffet!");
|
MESSAGE("2 withdrew Wobbuffet!");
|
||||||
|
@ -37,7 +37,7 @@ DOUBLE_BATTLE_TEST("Supersweet Syrup lowers evasion of both opposing mon's in ba
|
||||||
TURN { }
|
TURN { }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(opponentLeft, ABILITY_SUPERSWEET_SYRUP);
|
ABILITY_POPUP(opponentLeft, ABILITY_SUPERSWEET_SYRUP);
|
||||||
MESSAGE("A supersweet aroma is wafting from the syrup covering Foe Dipplin!");
|
MESSAGE("A supersweet aroma is wafting from the syrup covering the opposing Dipplin!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerLeft);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, playerRight);
|
||||||
} THEN {
|
} THEN {
|
||||||
|
@ -66,7 +66,7 @@ SINGLE_BATTLE_TEST("Supersweet Syrup can not further lower opponents evasion if
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, player);
|
||||||
MESSAGE("Oddish's evasiveness fell!");
|
MESSAGE("Oddish's evasiveness fell!");
|
||||||
}
|
}
|
||||||
MESSAGE("Oddish's evasiveness won't go lower!");
|
MESSAGE("Oddish's evasiveness won't go any lower!");
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT_EQ(player->statStages[STAT_EVASION], MIN_STAT_STAGE);
|
EXPECT_EQ(player->statStages[STAT_EVASION], MIN_STAT_STAGE);
|
||||||
}
|
}
|
||||||
|
|
|
@ -130,6 +130,6 @@ SINGLE_BATTLE_TEST("Supreme Overlord's message displays correctly after all batt
|
||||||
SEND_IN_MESSAGE("Wobbuffet");
|
SEND_IN_MESSAGE("Wobbuffet");
|
||||||
MESSAGE("2 sent out Kingambit!");
|
MESSAGE("2 sent out Kingambit!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_SUPREME_OVERLORD);
|
ABILITY_POPUP(opponent, ABILITY_SUPREME_OVERLORD);
|
||||||
MESSAGE("Foe Kingambit gained strength from the fallen!");
|
MESSAGE("The opposing Kingambit gained strength from the fallen!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,6 +70,6 @@ SINGLE_BATTLE_TEST("Sword of Ruin's message displays correctly after all battler
|
||||||
SEND_IN_MESSAGE("Wobbuffet");
|
SEND_IN_MESSAGE("Wobbuffet");
|
||||||
MESSAGE("2 sent out Chien-Pao!");
|
MESSAGE("2 sent out Chien-Pao!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_SWORD_OF_RUIN);
|
ABILITY_POPUP(opponent, ABILITY_SWORD_OF_RUIN);
|
||||||
MESSAGE("Foe Chien-Pao's Sword of Ruin weakened the Defense of all surrounding Pokémon!");
|
MESSAGE("The opposing Chien-Pao's Sword of Ruin weakened the Defense of all surrounding Pokémon!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,6 +70,6 @@ SINGLE_BATTLE_TEST("Tablets of Ruin's message displays correctly after all battl
|
||||||
SEND_IN_MESSAGE("Wobbuffet");
|
SEND_IN_MESSAGE("Wobbuffet");
|
||||||
MESSAGE("2 sent out Wo-Chien!");
|
MESSAGE("2 sent out Wo-Chien!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_TABLETS_OF_RUIN);
|
ABILITY_POPUP(opponent, ABILITY_TABLETS_OF_RUIN);
|
||||||
MESSAGE("Foe Wo-Chien's Tablets of Ruin weakened the Attack of all surrounding Pokémon!");
|
MESSAGE("The opposing Wo-Chien's Tablets of Ruin weakened the Attack of all surrounding Pokémon!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,7 +27,7 @@ SINGLE_BATTLE_TEST("Tangling Hair drops opposing mon's speed if ability user got
|
||||||
if (move == MOVE_TACKLE) {
|
if (move == MOVE_TACKLE) {
|
||||||
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
|
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Wynaut's Speed fell!");
|
MESSAGE("The opposing Wynaut's Speed fell!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -44,9 +44,9 @@ SINGLE_BATTLE_TEST("Tangling Hair does not cause Rocky Helmet miss activation")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
|
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Wynaut's Speed fell!");
|
MESSAGE("The opposing Wynaut's Speed fell!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
||||||
MESSAGE("Foe Wynaut was hurt by Dugtrio's Rocky Helmet!");
|
MESSAGE("The opposing Wynaut was hurt by Dugtrio's Rocky Helmet!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,10 +61,10 @@ SINGLE_BATTLE_TEST("Tangling Hair Speed stat drop triggers defiant and keeps ori
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
|
ABILITY_POPUP(player, ABILITY_TANGLING_HAIR);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_STATS_CHANGE, opponent);
|
||||||
MESSAGE("Foe Pawniard's Speed fell!");
|
MESSAGE("The opposing Pawniard's Speed fell!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_DEFIANT);
|
ABILITY_POPUP(opponent, ABILITY_DEFIANT);
|
||||||
MESSAGE("Foe Pawniard's Attack sharply rose!");
|
MESSAGE("The opposing Pawniard's Attack sharply rose!");
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, player);
|
||||||
MESSAGE("Foe Pawniard was hurt by Dugtrio's Rocky Helmet!");
|
MESSAGE("The opposing Pawniard was hurt by Dugtrio's Rocky Helmet!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ SINGLE_BATTLE_TEST("Tera Shell makes all moves against Terapagos not very effect
|
||||||
TURN { MOVE(opponent, MOVE_TACKLE); }
|
TURN { MOVE(opponent, MOVE_TACKLE); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
if (hp == 100) {
|
if (hp == 100) {
|
||||||
MESSAGE("Foe Wobbuffet used Tackle!");
|
MESSAGE("The opposing Wobbuffet used Tackle!");
|
||||||
ABILITY_POPUP(player, ABILITY_TERA_SHELL);
|
ABILITY_POPUP(player, ABILITY_TERA_SHELL);
|
||||||
MESSAGE("Terapagos made its shell gleam! It's distorting type matchups!");
|
MESSAGE("Terapagos made its shell gleam! It's distorting type matchups!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
|
@ -40,7 +40,7 @@ SINGLE_BATTLE_TEST("Tera Shell makes all hits of multi-hit moves against Terapag
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_DOUBLE_HIT); }
|
TURN { MOVE(opponent, MOVE_DOUBLE_HIT); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Double Hit!");
|
MESSAGE("The opposing Wobbuffet used Double Hit!");
|
||||||
ABILITY_POPUP(player, ABILITY_TERA_SHELL);
|
ABILITY_POPUP(player, ABILITY_TERA_SHELL);
|
||||||
MESSAGE("Terapagos made its shell gleam! It's distorting type matchups!");
|
MESSAGE("Terapagos made its shell gleam! It's distorting type matchups!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_DOUBLE_HIT, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_DOUBLE_HIT, opponent);
|
||||||
|
|
|
@ -46,7 +46,7 @@ SINGLE_BATTLE_TEST("Teraform Zero can be replaced")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(opponent, MOVE_WORRY_SEED); MOVE(player, MOVE_REST, gimmick: GIMMICK_TERA); }
|
TURN { MOVE(opponent, MOVE_WORRY_SEED); MOVE(player, MOVE_REST, gimmick: GIMMICK_TERA); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Whimsicott used Worry Seed!");
|
MESSAGE("The opposing Whimsicott used Worry Seed!");
|
||||||
MESSAGE("Terapagos acquired Insomnia!");
|
MESSAGE("Terapagos acquired Insomnia!");
|
||||||
MESSAGE("Terapagos used Rest!");
|
MESSAGE("Terapagos used Rest!");
|
||||||
ABILITY_POPUP(player, ABILITY_INSOMNIA);
|
ABILITY_POPUP(player, ABILITY_INSOMNIA);
|
||||||
|
@ -63,7 +63,7 @@ SINGLE_BATTLE_TEST("Teraform Zero cannot be swapped")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_TERA); MOVE(opponent, MOVE_SKILL_SWAP); }
|
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_TERA); MOVE(opponent, MOVE_SKILL_SWAP); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Skill Swap!");
|
MESSAGE("The opposing Wobbuffet used Skill Swap!");
|
||||||
MESSAGE("But it failed!");
|
MESSAGE("But it failed!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -77,7 +77,7 @@ SINGLE_BATTLE_TEST("Teraform Zero cannot be copied")
|
||||||
} WHEN {
|
} WHEN {
|
||||||
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_TERA); MOVE(opponent, MOVE_ROLE_PLAY); }
|
TURN { MOVE(player, MOVE_CELEBRATE, gimmick: GIMMICK_TERA); MOVE(opponent, MOVE_ROLE_PLAY); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
MESSAGE("Foe Wobbuffet used Role Play!");
|
MESSAGE("The opposing Wobbuffet used Role Play!");
|
||||||
MESSAGE("But it failed!");
|
MESSAGE("But it failed!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ SINGLE_BATTLE_TEST("Toxic Chain inflicts bad poison when attacking")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet is badly poisoned!");
|
MESSAGE("The opposing Wobbuffet was badly poisoned!");
|
||||||
STATUS_ICON(opponent, badPoison: TRUE);
|
STATUS_ICON(opponent, badPoison: TRUE);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT(opponent->status1 & STATUS1_TOXIC_POISON);
|
EXPECT(opponent->status1 & STATUS1_TOXIC_POISON);
|
||||||
|
@ -35,13 +35,13 @@ SINGLE_BATTLE_TEST("Toxic Chain inflicts bad poison on any hit of a multi-hit mo
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet is badly poisoned!");
|
MESSAGE("The opposing Wobbuffet was badly poisoned!");
|
||||||
STATUS_ICON(opponent, badPoison: TRUE);
|
STATUS_ICON(opponent, badPoison: TRUE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
||||||
STATUS_ICON(opponent, badPoison: FALSE);
|
STATUS_ICON(opponent, badPoison: FALSE);
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet is badly poisoned!");
|
MESSAGE("The opposing Wobbuffet was badly poisoned!");
|
||||||
STATUS_ICON(opponent, badPoison: TRUE);
|
STATUS_ICON(opponent, badPoison: TRUE);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT(opponent->status1 & STATUS1_TOXIC_POISON);
|
EXPECT(opponent->status1 & STATUS1_TOXIC_POISON);
|
||||||
|
@ -64,12 +64,12 @@ DOUBLE_BATTLE_TEST("Toxic Chain can inflict bad poison on both foes")
|
||||||
HP_BAR(opponentLeft);
|
HP_BAR(opponentLeft);
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_TOXIC_CHAIN);
|
ABILITY_POPUP(playerLeft, ABILITY_TOXIC_CHAIN);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponentLeft);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponentLeft);
|
||||||
MESSAGE("Foe Wobbuffet is badly poisoned!");
|
MESSAGE("The opposing Wobbuffet was badly poisoned!");
|
||||||
STATUS_ICON(opponentLeft, badPoison: TRUE);
|
STATUS_ICON(opponentLeft, badPoison: TRUE);
|
||||||
HP_BAR(opponentRight);
|
HP_BAR(opponentRight);
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_TOXIC_CHAIN);
|
ABILITY_POPUP(playerLeft, ABILITY_TOXIC_CHAIN);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponentRight);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponentRight);
|
||||||
MESSAGE("Foe Wynaut is badly poisoned!");
|
MESSAGE("The opposing Wynaut was badly poisoned!");
|
||||||
STATUS_ICON(opponentRight, badPoison: TRUE);
|
STATUS_ICON(opponentRight, badPoison: TRUE);
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT(opponentLeft->status1 & STATUS1_TOXIC_POISON);
|
EXPECT(opponentLeft->status1 & STATUS1_TOXIC_POISON);
|
||||||
|
@ -97,14 +97,14 @@ SINGLE_BATTLE_TEST("Toxic Chain makes Lum/Pecha Berry trigger before being knock
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
ABILITY_POPUP(player, ABILITY_TOXIC_CHAIN);
|
||||||
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
ANIMATION(ANIM_TYPE_STATUS, B_ANIM_STATUS_PSN, opponent);
|
||||||
MESSAGE("Foe Wobbuffet is badly poisoned!");
|
MESSAGE("The opposing Wobbuffet was badly poisoned!");
|
||||||
STATUS_ICON(opponent, badPoison: TRUE);
|
STATUS_ICON(opponent, badPoison: TRUE);
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_HELD_ITEM_EFFECT, opponent);
|
||||||
STATUS_ICON(opponent, badPoison: FALSE);
|
STATUS_ICON(opponent, badPoison: FALSE);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_ITEM_KNOCKOFF);
|
ANIMATION(ANIM_TYPE_GENERAL, B_ANIM_ITEM_KNOCKOFF);
|
||||||
MESSAGE("Okidogi knocked off Foe Wobbuffet's Pecha Berry!");
|
MESSAGE("Okidogi knocked off the opposing Wobbuffet's Pecha Berry!");
|
||||||
MESSAGE("Okidogi knocked off Foe Wobbuffet's Lum Berry!");
|
MESSAGE("Okidogi knocked off the opposing Wobbuffet's Lum Berry!");
|
||||||
}
|
}
|
||||||
} THEN {
|
} THEN {
|
||||||
EXPECT(opponent->status1 == 0);
|
EXPECT(opponent->status1 == 0);
|
||||||
|
|
|
@ -22,11 +22,11 @@ SINGLE_BATTLE_TEST("Toxic Debris sets Toxic Spikes on the opposing side if hit b
|
||||||
} SCENE {
|
} SCENE {
|
||||||
if (move == MOVE_TACKLE) {
|
if (move == MOVE_TACKLE) {
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
} else {
|
} else {
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -44,14 +44,14 @@ SINGLE_BATTLE_TEST("Toxic Debris does not activate if two layers of Toxic Spikes
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -69,7 +69,7 @@ SINGLE_BATTLE_TEST("If a Substitute is hit, Toxic Debris does not set Toxic Spik
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
NONE_OF {
|
NONE_OF {
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -84,10 +84,10 @@ SINGLE_BATTLE_TEST("Each hit of a Multi Hit move activates Toxic Debris")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FURY_SWIPES, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FURY_SWIPES, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_FURY_SWIPES, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_FURY_SWIPES, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,7 +102,7 @@ SINGLE_BATTLE_TEST("Toxic Debris activates if user faints after physical hit")
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
MESSAGE("Glimmora fainted!");
|
MESSAGE("Glimmora fainted!");
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,7 +116,7 @@ SINGLE_BATTLE_TEST("Air Balloon is popped after Toxic Debris activates")
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_TACKLE, opponent);
|
||||||
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
ABILITY_POPUP(player, ABILITY_TOXIC_DEBRIS);
|
||||||
MESSAGE("Poison Spikes were scattered all around the opposing team's feet!");
|
MESSAGE("Poison spikes were scattered on the ground all around the opposing team!");
|
||||||
MESSAGE("Glimmora's Air Balloon popped!");
|
MESSAGE("Glimmora's Air Balloon popped!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ SINGLE_BATTLE_TEST("Trace copies opponents ability")
|
||||||
TURN { }
|
TURN { }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_TRACE);
|
ABILITY_POPUP(player, ABILITY_TRACE);
|
||||||
MESSAGE("Ralts TRACED Foe Torchic's Blaze!");
|
MESSAGE("It traced the opposing Torchic's Blaze!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ SINGLE_BATTLE_TEST("Trace copies opponents ability on switch-in")
|
||||||
TURN { SWITCH(player, 1); }
|
TURN { SWITCH(player, 1); }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(player, ABILITY_TRACE);
|
ABILITY_POPUP(player, ABILITY_TRACE);
|
||||||
MESSAGE("Ralts TRACED Foe Torchic's Blaze!");
|
MESSAGE("It traced the opposing Torchic's Blaze!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ SINGLE_BATTLE_TEST("Trace copies opponents ability on switch-in even if opponent
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ANIMATION(ANIM_TYPE_MOVE, MOVE_MISTY_EXPLOSION);
|
ANIMATION(ANIM_TYPE_MOVE, MOVE_MISTY_EXPLOSION);
|
||||||
ABILITY_POPUP(player, ABILITY_TRACE);
|
ABILITY_POPUP(player, ABILITY_TRACE);
|
||||||
MESSAGE("Ralts TRACED Foe Torchic's Blaze!");
|
MESSAGE("It traced the opposing Torchic's Blaze!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,7 +61,7 @@ DOUBLE_BATTLE_TEST("Trace copies opponents ability randomly")
|
||||||
TURN { }
|
TURN { }
|
||||||
} SCENE {
|
} SCENE {
|
||||||
ABILITY_POPUP(playerLeft, ABILITY_TRACE);
|
ABILITY_POPUP(playerLeft, ABILITY_TRACE);
|
||||||
MESSAGE("Ralts TRACED Foe Torchic's Blaze!");
|
MESSAGE("It traced the opposing Torchic's Blaze!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ SINGLE_BATTLE_TEST("Trace will copy an opponent's ability whenever it has the ch
|
||||||
} SCENE {
|
} SCENE {
|
||||||
// TURN 2
|
// TURN 2
|
||||||
ABILITY_POPUP(player, ABILITY_TRACE);
|
ABILITY_POPUP(player, ABILITY_TRACE);
|
||||||
MESSAGE("Ralts TRACED Foe Torchic's Blaze!");
|
MESSAGE("It traced the opposing Torchic's Blaze!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -70,6 +70,6 @@ SINGLE_BATTLE_TEST("Vessel of Ruin's message displays correctly after all battle
|
||||||
SEND_IN_MESSAGE("Wobbuffet");
|
SEND_IN_MESSAGE("Wobbuffet");
|
||||||
MESSAGE("2 sent out Ting-Lu!");
|
MESSAGE("2 sent out Ting-Lu!");
|
||||||
ABILITY_POPUP(opponent, ABILITY_VESSEL_OF_RUIN);
|
ABILITY_POPUP(opponent, ABILITY_VESSEL_OF_RUIN);
|
||||||
MESSAGE("Foe Ting-Lu's Vessel of Ruin weakened the Sp. Atk of all surrounding Pokémon!");
|
MESSAGE("The opposing Ting-Lu's Vessel of Ruin weakened the Sp. Atk of all surrounding Pokémon!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue