It is currently 25 Oct 2025, 07:01
   
Text Size

Hanmac's Refactoring Thread

Post MTG Forge Related Programming Questions Here

Moderators: timmermac, Agetian, friarsol, Blacksmith, KrazyTheFox, CCGHQ Admins

Re: Hanmac's Refactoring Thread

Postby Hanmac » 30 Dec 2016, 15:13

I commited the Second Part of my changes with Damage.
as you can see, CardDamageMap is used everywhere through the whole damage functions.

i also added a few test cases for:
  • Damage + Lifelink
  • Damage + Lifelink Multiplication (Gisela, Blade of Goldnight)
  • Damage + Lifelink Redirection (Palisade Giant)
  • Damage + Lifelink Multiple Damages Sources (Cone of Flame)

they all pass for now.

now i try the Fixed Amount Replacement, for that i might need a new Effect (and maybe a new Effect for the whole thing instead of a EffectEffect)

PS: hm maybe i do need to refactor getPreventNextDamage and getPreventNextDamageWithEffect but for that i am unsure yet.
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby friarsol » 07 Jan 2017, 02:57

Hanmac with your recent Damage changes is there an easy way to lookup which Players have received Combat Damage in a turn for Tymna the Weaver?
friarsol
Global Moderator
 
Posts: 7593
Joined: 15 May 2010, 04:20
Has thanked: 243 times
Been thanked: 965 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 07 Jan 2017, 03:02

There isnt already a way for that? Curious.
That should be added to xCount and is not connected to my other changes with damage. Just using DanageHistory might work.
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby friarsol » 07 Jan 2017, 03:22

I didn't notice one, but haven't had that much IDE time. I think DamageHistory is only on Cards, not GameEntity. So it'd be awkward to handle that.
friarsol
Global Moderator
 
Posts: 7593
Joined: 15 May 2010, 04:20
Has thanked: 243 times
Been thanked: 965 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 07 Jan 2017, 03:26

Hm okay. I will check it out later today, and if not add a variable for that. (I thought there was already a variable for CombatDamaged on Player)

Currently i don't have changes in player yet so I can easy include this fix.
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby friarsol » 07 Jan 2017, 03:31

Yea I wasn't saying you needed to, just figured I'd ask since you were looking at that section recently.
friarsol
Global Moderator
 
Posts: 7593
Joined: 15 May 2010, 04:20
Has thanked: 243 times
Been thanked: 965 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 07 Jan 2017, 04:20

@friarsol: i added wasDealtCombatDamageThisTurn to Player
then i noticed that Tymna does want all Players, even the ones that might lose the game already, so i added RegisteredOpponents

so for Tymna it probably should be
PlayerCountRegisteredOpponents$HasPropertywasDealtCombatDamageThisTurn
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 07 Jan 2017, 16:19

while going through all Damage Replacement cards with Damage Redirection and Damage splitting i found Glarecaster.
in most of the cases it does work as it should, but when damage is done to both the creature and the player, the Effect currently does not work correct.
Specially if a Spell does deal damage in two different lines.

@friarsol: what would be correct way how the card should work? and maybe an idea for that to fix that?
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby friarsol » 07 Jan 2017, 16:27

Hanmac wrote:while going through all Damage Replacement cards with Damage Redirection and Damage splitting i found Glarecaster.
in most of the cases it does work as it should, but when damage is done to both the creature and the player, the Effect currently does not work correct.
Specially if a Spell does deal damage in two different lines.

@friarsol: what would be correct way how the card should work? and maybe an idea for that to fix that?
Rulings
10/4/2004 If both you and this card would be dealt damage at the same time, or if either you or this card would be dealt damage from multiple sources at the same time, the redirection will apply to both chunks of damage.

This includes combat damage
friarsol
Global Moderator
 
Posts: 7593
Joined: 15 May 2010, 04:20
Has thanked: 243 times
Been thanked: 965 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 07 Jan 2017, 16:32

yeah the problem is that currently "The next time" effects does exile them selves when they are done.

means that if a Damage source would deal X damage to the creature and you, only one of them is redirected.

what my problem is are Damage spells where the damage could not be done in one Effect, like X damage to creature and Y damage to you.
I think for that it might be even more complicated ...
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby friarsol » 07 Jan 2017, 16:41

Ah.. I see what you mean. I'll think about the best way to handle that. Is there a way to delay the exiling of an effect is resolving until it finishes resolving?
friarsol
Global Moderator
 
Posts: 7593
Joined: 15 May 2010, 04:20
Has thanked: 243 times
Been thanked: 965 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 07 Jan 2017, 16:46

currently there is no way to delay it ...
but i was thinking of adding a "OnlyOnce$ True" Param for the ReplacementEffect
with that the ReplacementHandler can "handle" that if the effect is not needed anymore. (and in case the host is a "Effect" can exile/remove it)

Edit:
another card to think about:
Channel Harm

One Spell does deal damage to multiple targets, Channel Harm does prevent them all and does deal them to target creature.

The problem there, does channel harm only deals one damage or for each of the prevented ones?
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 07 Jan 2017, 17:32

FINISH!

i commited all my changes to the Cards with DamageDoneReplacement to DealDamage effects.

all tests does pass, and i even added new ones (right place for that?)
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

Re: Hanmac's Refactoring Thread

Postby Agetian » 07 Jan 2017, 18:00

Congrats, Hanmac! It's an important milestone! :D

- Agetian
Agetian
Programmer
 
Posts: 3490
Joined: 14 Mar 2011, 05:58
Has thanked: 684 times
Been thanked: 572 times

Re: Hanmac's Refactoring Thread

Postby Hanmac » 08 Jan 2017, 08:39

did a chat with chat.magicjudges.org/mtgrules

Two Problems:

First again Damage and lifelink
Cone of Flame while doing damage to three targets, only count as one damage Effect and causes only one lifegain
Fiery Confluence & Collective Defiance & Savage Alliance & Clan Defiance &Incendiary Command and only Charm spells (for now?) does cause multiple damage effects and multiple lifegain events

for Incite Rebellion i currently don't know.

for that i need to rewrite the Damage Effects again ... specially with thinking about the Prevention Effects.
(so first if its not part of a charm spell, combine the Damage Effects and then order them because of Prevention, and then deal the Damage at once with one DamageMap)


Aetherborn Marauder and similar like Spike Cannibal only causes one put counter effect. thats important because Hardened Scales only should add one extra counter, not one per creature.
For that i will need to extend the MoveCounter logic.
for Aetherborn Marauder probably:
Code: Select all
MoveCounter | ValidSource$ Permanent.YouCtrl+Other | Defined$ Self | CounterNum$ Any | CounterType$ P1P1
for Spike Cannibal:
Code: Select all
MoveCounter | ValidSource$ Creature | Defined$ Self | CounterNum$ All | CounterType$ P1P1
Hanmac
 
Posts: 954
Joined: 06 May 2013, 18:44
Has thanked: 229 times
Been thanked: 158 times

PreviousNext

Return to Developer's Corner

Who is online

Users browsing this forum: No registered users and 51 guests

Main Menu

User Menu

Our Partners


Who is online

In total there are 51 users online :: 0 registered, 0 hidden and 51 guests (based on users active over the past 10 minutes)
Most users ever online was 9298 on 10 Oct 2025, 12:54

Users browsing this forum: No registered users and 51 guests

Login Form