X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=naja%2Factions.py;h=9f3b221b3af18cf033093465d0306a9ec1ddab93;hb=0d7c75c57d85f809aad2db5c740341e2c3db011c;hp=7ed4c6b7fae55a7d49d2ec2d229ff0a05d36c422;hpb=71af434ace227205b92cf92330fd22ee1183f439;p=naja.git diff --git a/naja/actions.py b/naja/actions.py index 7ed4c6b..9f3b221 100644 --- a/naja/actions.py +++ b/naja/actions.py @@ -19,7 +19,11 @@ class LocationAction(object): def get_text(self, location=None): substitutions = self.data.copy() - if 'direction' in self.data: + if 'shift' in self.data: + substitutions['shift'] = self.data['shift'] + substitutions['shift_glyph'] = ('{SHIFT_%s}' + % self.data['direction'].upper()) + elif 'direction' in self.data: substitutions['rowcol'] = { 'NORTH': 'column', 'SOUTH': 'column', @@ -78,6 +82,7 @@ class LoseHealthOrMSB(LocationAction): def perform_action(self, board, location): if not self.check_and_clear_MSB(board.player): + sound.play_sound('awwww.ogg') board.lose_health() @@ -97,6 +102,18 @@ class ToggleBits(LocationAction): board.player.bits.toggle_bits(location.bitwise_operand) +class ShiftBits(LocationAction): + TEXT = "Barrel-shift player bits %(shift_glyph)s %(shift)s." + GLYPHS = (ACTION_GLYPHS.SHIFT_LEFT,) + + def perform_action(self, board, location): + shift = self.data['shift'] + if self.data['direction'] == 'left': + board.player.bits.shift_bits_left(shift) + else: + board.player.bits.shift_bits_right(shift) + + class LoseHealthOrMSBAndSetBits(LocationAction): TEXT = "Lose {HEALTH} or {MSB}, then set %(location_bits)s." GLYPHS = (ACTION_GLYPHS.SET_BITS,) @@ -104,6 +121,7 @@ class LoseHealthOrMSBAndSetBits(LocationAction): def perform_action(self, board, location): if not self.check_and_clear_MSB(board.player): + sound.play_sound('awwww.ogg') board.lose_health() board.player.bits.set_bits(location.bitwise_operand) @@ -113,6 +131,7 @@ class AcquireWinToken(LocationAction): GLYPHS = (ACTION_GLYPHS.WINTOKEN,) def perform_action(self, board, location): + sound.play_sound('yipee.ogg') board.acquire_win_token() board.player.bits.clear_bits(set([ BITS.RED, BITS.GREEN, BITS.BLUE, @@ -124,6 +143,7 @@ class GainHealth(LocationAction): GLYPHS = (ACTION_GLYPHS.HEAL,) def perform_action(self, board, location): + sound.play_sound('aha.ogg') board.gain_health() @@ -133,6 +153,7 @@ class GainHealthAndClearBitsOrMSB(LocationAction): MSB_GLYPH = ACTION_GLYPHS.CLEAR_BITS def perform_action(self, board, location): + sound.play_sound('aha.ogg') board.gain_health() if not self.check_and_clear_MSB(board.player): board.player.bits.clear_bits(location.bitwise_operand)