From c053f0d398bac1587b743295dad47a167d6b9d66 Mon Sep 17 00:00:00 2001 From: viciousMind Date: Tue, 26 Jul 2016 14:18:04 +0200 Subject: [PATCH] [BUGFIX] Catch Pokemon while walking to fort Resolves: #821 --- pokemongo_bot/__init__.py | 19 +++++++++++-------- .../cell_workers/move_to_fort_worker.py | 2 ++ 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/pokemongo_bot/__init__.py b/pokemongo_bot/__init__.py index 9285bd9dbb..dc52d7d574 100644 --- a/pokemongo_bot/__init__.py +++ b/pokemongo_bot/__init__.py @@ -22,10 +22,10 @@ class PokemonGoBot(object): - + @property - def position(self): - return (i2f(self.api._position_lat), i2f(self.api._position_lng), 0) + def current_coordinates_as_float(self): + return i2f(self.api._position_lat), i2f(self.api._position_lng) def __init__(self, config): self.config = config @@ -40,10 +40,13 @@ def start(self): def take_step(self): location = self.navigator.take_step() - cells = self.find_close_cells(*self.position[0:2]) + self.process_cells(work_on_forts=True) + def process_cells(self, work_on_forts=True): + location = self.current_coordinates_as_float + cells = self.find_close_cells(*location) for cell in cells: - self.work_on_cell(cell, location) + self.work_on_cell(cell, location, work_on_forts) def update_web_location(self, cells=[], lat=None, lng=None, alt=None): # we can call the function with no arguments and still get the position and map_cells @@ -131,7 +134,7 @@ def find_close_cells(self, lat, lng): self.update_web_location(map_cells) return map_cells - def work_on_cell(self, cell, position): + def work_on_cell(self, cell, position, work_on_forts=1): # Check if session token has expired self.check_session(position) @@ -201,8 +204,8 @@ def work_on_cell(self, cell, position): for pokemon in cell['wild_pokemons']: if self.catch_pokemon(pokemon) == PokemonCatchWorker.NO_POKEBALLS: break - if (self.config.mode == "all" or - self.config.mode == "farm"): + if ((self.config.mode == "all" or + self.config.mode == "farm") and work_on_forts): if 'forts' in cell: # Only include those with a lat/long forts = [fort diff --git a/pokemongo_bot/cell_workers/move_to_fort_worker.py b/pokemongo_bot/cell_workers/move_to_fort_worker.py index 58f6d10846..b5e4f2eb6f 100644 --- a/pokemongo_bot/cell_workers/move_to_fort_worker.py +++ b/pokemongo_bot/cell_workers/move_to_fort_worker.py @@ -41,6 +41,8 @@ def work(self): while distance(i2f(self.api._position_lat), i2f(self.api._position_lng), lat, lng) > 10: if step_walker.step(): break + else: + self.bot.process_cells(work_on_forts=False) else: self.api.set_position(*position)