From 21decfd74a4f550f4758d8583620110baee72aed Mon Sep 17 00:00:00 2001 From: Simon Cross Date: Sat, 17 May 2014 22:13:27 +0200 Subject: [PATCH] Optional sanity check for actions. --- naja/actions.py | 13 +++++++++++++ naja/gameboard.py | 3 +++ 2 files changed, 16 insertions(+) diff --git a/naja/actions.py b/naja/actions.py index ff5bdba..395a1f5 100644 --- a/naja/actions.py +++ b/naja/actions.py @@ -16,6 +16,9 @@ class LocationAction(object): self.required_bits = required_bits self.data = data + def sanity_check(self, location): + pass + def get_glyphs(self): return self.GLYPHS @@ -153,6 +156,16 @@ class GenericBits(LocationAction): self.acquire_win = self.data.get('acquire_win', False) self.lose_health = self.data.get('lose_health', False) + def sanity_check(self, location): + missing_bits = set() + missing_bits.update(self.set_bits - set(location.bitwise_operand)) + missing_bits.update(self.clear_bits - set(location.bitwise_operand)) + missing_bits.update(self.toggle_bits - set(location.bitwise_operand)) + if missing_bits: + raise ValueError( + "Location %s missing bits %r" + % (location.card_name, sorted(list(missing_bits)))) + def perform_action(self, board, location): bits = board.player.bits bits.set_bits(self.set_bits) diff --git a/naja/gameboard.py b/naja/gameboard.py index 52d1323..689c3fd 100644 --- a/naja/gameboard.py +++ b/naja/gameboard.py @@ -305,6 +305,9 @@ class LocationCard(object): self.actions = location_actions self.max_number = max_number self.replacement_time = replacement_time + if options.debug: + for action in self.actions: + action.sanity_check(self) @classmethod def import_location(cls, state): -- 2.34.1