X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=naja%2Factions.py;h=f62b4637174621c3a29e541d4c445e4ece66f715;hb=2a46865fc69e2e90e28bc13255a762279e7a1b29;hp=32ac03509c88527cf8d5205d0bfa0a490456c674;hpb=3beea676f3bd4fc9101e9de1c24e8007011e952b;p=naja.git diff --git a/naja/actions.py b/naja/actions.py index 32ac035..f62b463 100644 --- a/naja/actions.py +++ b/naja/actions.py @@ -7,6 +7,7 @@ class LocationAction(object): """ TEXT = None + USES_MSB = False def __init__(self, required_bits, **data): bits = set() @@ -43,7 +44,8 @@ class DoNothing(LocationAction): class LoseHealthOrMSB(LocationAction): - TEXT = "Lose health. If MSB is set, it will be cleared instead." + TEXT = "Lose health or MSB." + USES_MSB = True def perform_action(self, board, location): if not self.check_and_clear_MSB(board.player): @@ -62,3 +64,35 @@ class ToggleBits(LocationAction): def perform_action(self, board, location): board.player.bits.toggle_bits(location.bitwise_operand) + + +class LoseHealthOrMSBAndSetBits(LocationAction): + TEXT = "Lose health or MSB, then set bits specified by this location." + USES_MSB = True + + def perform_action(self, board, location): + if not self.check_and_clear_MSB(board.player): + board.lose_health() + board.player.bits.set_bits(location.bitwise_operand) + + +class AcquireWinToken(LocationAction): + TEXT = "Acquire a win token, then clear all high bits." + USES_MSB = True + + def perform_action(self, board, location): + if self.check_and_clear_MSB(board.player): + board.acquire_win_token() + board.player.bits.clear_bits(set([ + BITS.CYAN, BITS.MAGENTA, BITS.YELLOW, + ])) + + +class GainHealthAndClearBitsOrMSB(LocationAction): + TEXT = "Gain health, then clear bits specified by this location or MSB." + USES_MSB = True + + def perform_action(self, board, location): + board.gain_health() + if not self.check_and_clear_MSB(board.player): + board.player.bits.clear_bits(location.bitwise_operand)