-
Notifications
You must be signed in to change notification settings - Fork 785
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
BUG // Propaganda asks to pay again infinitly #10372
Comments
[[Propaganda]] |
Propaganda - (Gatherer) (Scryfall) (EDHREC)
|
Has been reported again on discord. |
Discord story has copies of propaganda. Topic starter also used a copy by [[Mirrormade]]. |
Mirrormade - (Gatherer) (Scryfall) (EDHREC)
|
Oh I tried with tokens, not actual copy. Could be ability ids being lost somewhere maybe? |
Trying to wrap my head around this. It looks like, from my experimentation, that the issue is how the screenshotted code above (
The question of how to solve this seems rough to me. We can't just not generate a new ID for this ability. Could we replace this UUID randomization with a deterministic UUID generation, for example by simply adding together the UUIDs of the ability to copy and the permanent receiving the copied ability? That way. every time Propaganda's ability is copied with Another idea is to add a property to abilities with which to retrieve the information about a copied ability, enough to distinguish between otherwise identical copies that are from different effects: Probably the UUID of the ability it copied from and the UUID of the effect causing the copy. Then, `ContinuousEffects.replaceEvent' would need to look for that info, further deepening an already convoluted loop. |
It sounds similar to the bug #8363 with Whipgrass Entangler, for which a card-specific solution was implemented in #10802. But this manifestation is broader and I don't think can be solved in the same way. Deterministic UUID generation for copy effects is an interesting idea. It seems like it has the potential to be the cleanest solution, haven't thought about it enough yet though. See #11077 for potential related scope as well |
Deterministic UUID generation could also potentially be a solution to #12752, as the linked subability could find the new ID of its linked ability by running the same algorithm whenever its own new ID function is called. |
Omg, looks like I miss #10802. That hacks smells very bad. Try to look at custom cost implementation — it has full control over payed status and all related data (e.g. you can have already payed cost without real pay). And it used all around xmage. Ability’s original id also can help (it’s same after copy). Like that: original id + source id + attacking id. Just a theory. |
I'm not sure this would address the root cause. needing to tap lands and that causing the loop is incidental to this issue, no? |
Due bug description — copy/gain ability generates unique instances on each game cycle. And that instances must keep payed status, but it lost it. Manual control of payed status can help with it.
For PR. It’s force data change in reverse order (effect trying to change ability). E.g. List’s item trying to change that List from itself. It’s replace root methods logic (id generation), but for special use cases only. It’s require to replace pack of standard commands by alternatives (instead fully replace/fix it - see copy ability code). Also it’s not finished, e.g. added to 1 of 10 places, see #11077. |
I tried to pinpoint the bug and came to conclusion it must be Propaganda itself. I'll just explain the situation:
My Opponent has 2 Propaganda's. One Original and one Mirrormade Copy. I cast obliterate. Other 2 Players scoop. 1 opponent left. The 2 Propagandas are the only Permaments left on his side. Next Turn i flip my The Kami War into O-Kagachi Made Manifest. The next turn I have Sol ring and mana crypt on the bf, I try to attack with O-Kagachi but after i paid 2 for each Propaganda it asks me again. I also tried to play another creature, it still asks more then once for each Propaganda. I destroyed one of his Propaganda (The original) and with 6 Mana open i tried to attack with a third creature (only with that single creature). Still the same: After I click yes and pay the (2) the Yes/no buttons turn up immediatly again and ask me if i want to Pay to attack.
First i thought it my have something to do with O-Kagachi being a Saga and a relativly new Card, but after i tried the other creatures i m sure it has to do with either Propaganda Or Mirrormade. Maybe it started bugging after the last update; i m not sure. I will edit if i run into Propaganda again.
The text was updated successfully, but these errors were encountered: