From a82bf1f876b702eeb9a8c04ee2acb6a32d61fc78 Mon Sep 17 00:00:00 2001 From: Christian Heller Date: Sun, 21 Apr 2019 21:27:53 +0200 Subject: [PATCH] Make AI logic clearer in code. --- new/plomrogue/things.py | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/new/plomrogue/things.py b/new/plomrogue/things.py index f4cc2ae..31a389a 100644 --- a/new/plomrogue/things.py +++ b/new/plomrogue/things.py @@ -47,7 +47,7 @@ class ThingAnimate(Thing): self._last_task_result = None self._stencil = None - def move_towards_target(self, target): + def move_towards_position(self, target): dijkstra_map = type(self.world.map_)(self.world.map_.size) n_max = 256 dijkstra_map.terrain = [n_max for i in range(dijkstra_map.size_i)] @@ -78,7 +78,7 @@ class ThingAnimate(Thing): if target_direction: self.set_task('MOVE', (target_direction,)) - def decide_task(self): + def hunt_player(self): visible_things = self.get_visible_things() target = None for t in visible_things: @@ -87,11 +87,15 @@ class ThingAnimate(Thing): break if target is not None: try: - self.move_towards_target(target) - return + self.move_towards_position(target) + return True except GameError: pass - self.set_task('WAIT') + return False + + def decide_task(self): + if not self.hunt_player(): + self.set_task('WAIT') def set_task(self, task_name, args=()): task_class = self.world.game.tasks[task_name] -- 2.30.2