X-Git-Url: https://plomlompom.com/repos/berlin_corona.txt?a=blobdiff_plain;f=plomrogue%2Fthings.py;h=2146c1a222f48a78b4e3abe9187e09aa86909ba2;hb=0329d62bfc40ef8d54d9df8f5d9119515a871cf6;hp=fe7d57ef3229265ab50ebb64465b6d48b6631a13;hpb=9316d59ddce7a7b8ee70d2b4e111330f1a691e37;p=plomrogue2 diff --git a/plomrogue/things.py b/plomrogue/things.py index fe7d57e..2146c1a 100644 --- a/plomrogue/things.py +++ b/plomrogue/things.py @@ -70,12 +70,46 @@ class Thing_SpawnPointSpawner(ThingSpawner): class Thing_SpawnPoint(Thing): symbol_hint = 's' portable = True - name = ' ' + name = 'username' + + + +class Thing_DoorSpawner(ThingSpawner): + child_type = 'Door' + + + +class Thing_Door(Thing): + symbol_hint = 'D' + blocking = False + portable = True + + def open(self): + self.blocking = False + self.portable = True + del self.thing_char + + def close(self): + self.blocking = True + self.portable = False + self.thing_char = '#' + + + +class Thing_Consumable(Thing): + symbol_hint = 'B' + portable = True + + + +class Thing_ConsumableSpawner(ThingSpawner): + child_type = 'Consumable' class ThingAnimate(Thing): blocking = True + drunk = 0 def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) @@ -101,11 +135,17 @@ class ThingAnimate(Thing): return None def proceed(self): + self.drunk -= 1 + if self.drunk == 0: + for c_id in self.game.sessions: + if self.game.sessions[c_id]['thing_id'] == self.id_: + self.game.io.send('DEFAULT_COLORS', c_id) + self.game.io.send('CHAT "You sober up."', c_id) + self.game.changed = True self._fov = None if self.task is None: self.task = self.get_next_task() return - try: self.task.check() except GameError as e: @@ -122,8 +162,8 @@ class ThingAnimate(Thing): if self._fov: return self._fov fov_map_class = self.game.map_geometry.fov_map_class - self._fov = fov_map_class(self.game.maps, self.position, 12, - self.game.get_map) + self._fov = fov_map_class(self.game.things, self.game.maps, self.position, + 12, self.game.get_map) return self._fov def fov_test(self, big_yx, little_yx):