def check(self):
test_yxyx = self._get_move_target()
+ move_blockers = self.thing.game.get_movement_blockers()
if test_yxyx in [t.position for t in self.thing.game.things
if t.blocking]:
raise PlayError('blocked by other thing')
- elif self.thing.game.maps[test_yxyx[0]][test_yxyx[1]] != '.':
+ elif self.thing.game.maps[test_yxyx[0]][test_yxyx[1]] in move_blockers:
raise PlayError('blocked by impassable tile')
def do(self):
self.thing.position).values()):
if not self.thing.game.can_do_tile_with_pw(*yxyx, self.args[0]):
continue
- self.thing.game.maps[yxyx[0]][yxyx[1]] = '.'
+ self.thing.game.maps[yxyx[0]][yxyx[1]] = self.thing.game.get_flatland()
self.thing.game.record_fov_change(yxyx)
to_pick_up.position = self.thing.position[:]
self.thing.carrying = to_pick_up
to_pick_up.carried = True
+ # FIXME: pseudo-FOV-change actually
+ self.thing.game.record_fov_change(self.thing.position)
target_position = self._get_move_target()
dropped = self.thing.uncarry()
dropped.position = target_position
- if dropped.type_ == 'Bottle' and not dropped.full:
+ over_cookie_spawner = None
+ for t in [t for t in self.thing.game.things
+ if t.type_ == 'CookieSpawner'
+ and t.position == dropped.position]:
+ over_cookie_spawner = t
+ break
+ if over_cookie_spawner:
+ over_cookie_spawner.accept(dropped)
+ self.thing.game.remove_thing(dropped)
+ elif dropped.type_ == 'Bottle' and not dropped.full:
for t in [t for t in self.thing.game.things
if t.type_ == 'BottleDeposit'
and t.position == dropped.position]:
and t.position == dropped.position]:
t.accept(dropped)
break
+ # FIXME: pseudo-FOV-change actually
+ self.thing.game.record_fov_change(self.thing.position)
def check(self):
if self.thing.carrying is None:
raise PlayError('carrying nothing to drink from')
- if self.thing.carrying.type_ != 'Bottle':
- raise PlayError('cannot drink from non-bottle')
- if not self.thing.carrying.full:
+ if self.thing.carrying.type_ not in {'Bottle', 'Cookie'}:
+ raise PlayError('cannot consume this kind of thing')
+ if self.thing.carrying.type_ == 'Bottle' and\
+ not self.thing.carrying.full:
raise PlayError('bottle is empty')
def do(self):
- self.thing.carrying.full = False
- self.thing.carrying.empty()
- self.thing.send_msg('RANDOM_COLORS')
- self.thing.send_msg('CHAT "You are drunk now."')
- self.thing.drunk = 10000
- self.thing.invalidate_map_view()
+ if self.thing.carrying.type_ == 'Bottle':
+ self.thing.carrying.full = False
+ self.thing.carrying.empty()
+ self.thing.send_msg('RANDOM_COLORS')
+ self.thing.send_msg('CHAT "You are drunk now."')
+ self.thing.drunk = 10000
+ # FIXME: pseudo-FOV-change actually
+ self.thing.game.record_fov_change(self.thing.position)
+ elif self.thing.carrying.type_ == 'Cookie':
+ self.thing.send_msg('CHAT ' + quote('You eat a cookie and gain the ability to draw the following character: "%s"' % self.thing.carrying.thing_char))
+ self.thing.add_cookie_char(self.thing.carrying.thing_char)
+ eaten = self.thing.uncarry()
+ self.thing.game.remove_thing(eaten)
class Task_INSTALL(Task):
+ argtypes = 'string'
def _get_uninstallables(self):
return [t for t in self.thing.game.things
and t.position == self.thing.position]
def check(self):
+ if not self.thing.game.can_do_tile_with_pw(*self.thing.position,
+ self.args[0]):
+ raise GameError('wrong password for tile')
if self.thing.carrying:
if not hasattr(self.thing.carrying, 'installable')\
or not self.thing.carrying.installable:
else:
self._get_uninstallables()[0].uninstall()
self.thing.send_msg('CHAT "You uninstall the thing here."')
+ # FIXME: pseudo-FOV-change actually
+ self.thing.game.record_fov_change(self.thing.position)
self.thing.game.hats[self.thing.name] =\
self.thing.carrying.design
self.thing.send_msg('CHAT "You put on a hat."')
- self.thing.game.remove_thing(self.thing.carrying)
- self.thing.carrying = None
+ dropped = self.uncarry()
+ self.thing.game.remove_thing(dropped)
+ # FIXME: pseudo-FOV-change actually
+ self.thing.game.record_fov_change(self.thing.position)
def do(self):
self.thing.carrying.spin()
+ self.thing.send_msg('CHAT "You spin this object."')