From 03feac8d679d78f34d414ad3d2030ce216ac138c Mon Sep 17 00:00:00 2001 From: Eli White Date: Tue, 26 Jul 2016 01:20:17 -0700 Subject: [PATCH 1/2] Refactor EvolveAll and InitialTransfer workers --- pokemongo_bot/__init__.py | 45 ++++--------------- .../cell_workers/evolve_all_worker.py | 38 ++++++++++++++-- 2 files changed, 43 insertions(+), 40 deletions(-) diff --git a/pokemongo_bot/__init__.py b/pokemongo_bot/__init__.py index eb851e8705..520cb06408 100644 --- a/pokemongo_bot/__init__.py +++ b/pokemongo_bot/__init__.py @@ -123,42 +123,17 @@ def work_on_cell(self, cell, position): # Check if session token has expired self.check_session(position) + if self.config.initial_transfer: + worker = InitialTransferWorker(self) + worker.work() + self.config.initial_transfer = False + if self.config.evolve_all: - # Will skip evolving if user wants to use an egg and there is none - skip_evolves = False - - # Pop lucky egg before evolving to maximize xp gain - use_lucky_egg = self.config.use_lucky_egg - lucky_egg_count = self.item_inventory_count(Item.ITEM_LUCKY_EGG.value) - - if use_lucky_egg and lucky_egg_count > 0: - logger.log('Using lucky egg ... you have {}' - .format(lucky_egg_count)) - response_dict_lucky_egg = self.use_lucky_egg() - if response_dict_lucky_egg and 'responses' in response_dict_lucky_egg and \ - 'USE_ITEM_XP_BOOST' in response_dict_lucky_egg['responses'] and \ - 'result' in response_dict_lucky_egg['responses']['USE_ITEM_XP_BOOST']: - result = response_dict_lucky_egg['responses']['USE_ITEM_XP_BOOST']['result'] - if result is 1: # Request success - logger.log('Successfully used lucky egg... ({} left!)' - .format(lucky_egg_count-1), 'green') - else: - logger.log('Failed to use lucky egg!', 'red') - skip_evolves = True - elif use_lucky_egg: #lucky_egg_count is 0 - # Skipping evolve so they aren't wasted - logger.log('No lucky eggs... skipping evolve!', 'yellow') - skip_evolves = True - - if not skip_evolves: - # Run evolve all once. - logger.log('Attempting to evolve all pokemons ...', 'cyan') - worker = EvolveAllWorker(self) - worker.work() - - # Flip the bit. + worker = EvolveAllWorker(self) + worker.work() self.config.evolve_all = [] + if (self.config.mode == "all" or self.config.mode == "poke") and 'catchable_pokemons' in cell and len(cell[ 'catchable_pokemons']) > 0: @@ -272,10 +247,6 @@ def _setup_api(self): self._print_character_info() - if self.config.initial_transfer: - worker = InitialTransferWorker(self) - worker.work() - logger.log('') self.update_inventory() # send empty map_cells and then our position diff --git a/pokemongo_bot/cell_workers/evolve_all_worker.py b/pokemongo_bot/cell_workers/evolve_all_worker.py index 4206540cbe..fb64a0d145 100644 --- a/pokemongo_bot/cell_workers/evolve_all_worker.py +++ b/pokemongo_bot/cell_workers/evolve_all_worker.py @@ -12,6 +12,9 @@ def __init__(self, bot): # self.position = bot.position def work(self): + if not self._should_run(): + return + self.api.get_inventory() response_dict = self.api.call() cache = {} @@ -26,7 +29,7 @@ def work(self): if self.config.evolve_all[0] != 'all': # filter out non-listed pokemons evolve_list = [x for x in evolve_list if str(x[1]) in self.config.evolve_all] - + # enable to limit number of pokemons to evolve. Useful for testing. # nn = 3 # if len(evolve_list) > nn: @@ -48,6 +51,35 @@ def work(self): )) self._release_evolved(release_cand_list_ids) + def _should_run(self): + # Will skip evolving if user wants to use an egg and there is none + skip_evolves = False + + # Pop lucky egg before evolving to maximize xp gain + use_lucky_egg = self.config.use_lucky_egg + lucky_egg_count = self.bot.item_inventory_count(Item.ITEM_LUCKY_EGG.value) + + if use_lucky_egg and lucky_egg_count > 0: + logger.log('Using lucky egg ... you have {}' + .format(lucky_egg_count)) + response_dict_lucky_egg = self.bot.use_lucky_egg() + if response_dict_lucky_egg and 'responses' in response_dict_lucky_egg and \ + 'USE_ITEM_XP_BOOST' in response_dict_lucky_egg['responses'] and \ + 'result' in response_dict_lucky_egg['responses']['USE_ITEM_XP_BOOST']: + result = response_dict_lucky_egg['responses']['USE_ITEM_XP_BOOST']['result'] + if result is 1: # Request success + logger.log('Successfully used lucky egg... ({} left!)' + .format(lucky_egg_count-1), 'green') + else: + logger.log('Failed to use lucky egg!', 'red') + skip_evolves = True + elif use_lucky_egg: #lucky_egg_count is 0 + # Skipping evolve so they aren't wasted + logger.log('No lucky eggs... skipping evolve!', 'yellow') + skip_evolves = True + + return skip_evolves + def _release_evolved(self, release_cand_list_ids): self.api.get_inventory() response_dict = self.api.call() @@ -131,7 +163,7 @@ def _execute_pokemon_evolve(self, pokemon, cache): # cache pokemons we can't evolve. Less server calls cache[pokemon_name] = 1 sleep(0.7) - + # TODO: move to utils. These methods are shared with other workers. def transfer_pokemon(self, pid): @@ -243,7 +275,7 @@ def _check_always_capture_exception_for(self, pokemon_name): def _compute_iv(self, pokemon): total_IV = 0.0 iv_stats = ['individual_attack', 'individual_defense', 'individual_stamina'] - + for individual_stat in iv_stats: try: total_IV += pokemon[individual_stat] From 508eb404835e9abdfe1d42bad2720db11cfab1a0 Mon Sep 17 00:00:00 2001 From: Eli White Date: Tue, 26 Jul 2016 01:59:47 -0700 Subject: [PATCH 2/2] Fixing Item import --- pokemongo_bot/cell_workers/evolve_all_worker.py | 1 + 1 file changed, 1 insertion(+) diff --git a/pokemongo_bot/cell_workers/evolve_all_worker.py b/pokemongo_bot/cell_workers/evolve_all_worker.py index fb64a0d145..982f521a1c 100644 --- a/pokemongo_bot/cell_workers/evolve_all_worker.py +++ b/pokemongo_bot/cell_workers/evolve_all_worker.py @@ -2,6 +2,7 @@ from pokemongo_bot import logger from pokemongo_bot.human_behaviour import sleep +from item_list import Item class EvolveAllWorker(object):