X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;f=new%2Fplomrogue%2Ftasks.py;h=1be5b6da40b2c757fccd08541fbea6002f6809aa;hb=65e83c99b95a619afc79e8984e6f5027bc7aac1b;hp=a2c041b06aeb0807ab095f3f07f914ea705e26f2;hpb=e530d9faf68b4057322f5cc61aa0e3b76f8db3f6;p=plomrogue2-experiments diff --git a/new/plomrogue/tasks.py b/new/plomrogue/tasks.py index a2c041b..1be5b6d 100644 --- a/new/plomrogue/tasks.py +++ b/new/plomrogue/tasks.py @@ -11,12 +11,6 @@ class Task: self.args = args self.todo = 3 - @property - def name(self): - prefix = 'Task_' - class_name = self.__class__.__name__ - return class_name[len(prefix):] - def check(self): pass @@ -46,9 +40,50 @@ class Task_MOVE(Task): if self.thing.world.map_[test_pos] != '.': raise GameError('%s would move into illegal terrain' % self.thing.id_) for t in self.thing.world.things: - if t.position == test_pos: + if t.blocking and t.position == test_pos: raise GameError('%s would move into other thing' % self.thing.id_) def do(self): self.thing.position = self.thing.world.map_.move(self.thing.position, self.args[0]) + for id_ in self.thing.inventory: + t = self.thing.world.get_thing(id_) + t.position = self.thing.position + + + +class Task_PICKUP(Task): + argtypes = 'int:nonneg' + + def check(self): + to_pick_up = self.thing.world.get_thing(self.args[0], + create_unfound=False) + if to_pick_up is None or \ + to_pick_up.in_inventory or \ + to_pick_up == self.thing or \ + self.thing.position != to_pick_up.position: + raise GameError('thing of ID %s not in reach to pick up' + % self.args[0]) + + def do(self): + to_pick_up = self.thing.world.get_thing(self.args[0]) + self.thing.inventory += [self.args[0]] + to_pick_up.in_inventory = True + + + +class Task_DROP(Task): + argtypes = 'int:nonneg' + + def check(self): + to_drop = self.thing.world.get_thing(self.args[0], create_unfound=False) + if to_drop is None: + raise GameError('no thing of ID %s to drop' % self.args[0]) + if to_drop.id_ not in self.thing.inventory: + raise GameError('no thing of ID %s to drop in inventory' + % self.args[0]) + + def do(self): + to_drop = self.thing.world.get_thing(self.args[0]) + del self.thing.inventory[self.thing.inventory.index(to_drop.id_)] + to_drop.in_inventory = False