From 6f817c0c5cc63a1a2ec538ecbacf6433425fc44f Mon Sep 17 00:00:00 2001 From: echel0n Date: Mon, 21 Jul 2014 08:38:56 -0700 Subject: [PATCH] Quality sorting fixed for provider results. Reverted newznab search strings being confined to just season till we can find a better way of correcting the issue with Usenet Crawler. --- sickbeard/providers/generic.py | 16 +++++++++++----- sickbeard/providers/newznab.py | 2 -- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/sickbeard/providers/generic.py b/sickbeard/providers/generic.py index b2b8f5bd..ae073bd1 100644 --- a/sickbeard/providers/generic.py +++ b/sickbeard/providers/generic.py @@ -275,8 +275,11 @@ class GenericProvider: if quality == Quality.UNKNOWN: itemsUnknown += item else: - items[quality] = item - itemList = [items.pop(k) for k in sorted(items, reverse=True)] + itemsUnknown + if quality not in items: + items[quality] = [item] + else: + items[quality].append(item) + itemList = [x[0] for x in [items.pop(k) for k in sorted(items, reverse=True)] + itemsUnknown] # filter results for item in itemList: @@ -297,6 +300,9 @@ class GenericProvider: quality = parse_result.quality release_group = parse_result.release_group + actual_season = None + actual_episodes = None + if not (showObj.air_by_date or showObj.sports): if search_mode == 'sponly' and len(parse_result.episode_numbers): logger.log( @@ -305,13 +311,13 @@ class GenericProvider: continue if not len(parse_result.episode_numbers) and ( - parse_result.season_number and parse_result.season_number != season) or ( - not parse_result.season_number and season != 1): + parse_result.season_number and parse_result.season_number != season) or ( + not parse_result.season_number and season != 1): logger.log(u"The result " + title + " doesn't seem to be a valid season that we want, ignoring", logger.DEBUG) continue elif len(parse_result.episode_numbers) and ( - parse_result.season_number != season or not [item for ep in episodes if + parse_result.season_number != season or not [ep for ep in episodes if ep.scene_episode in parse_result.episode_numbers]): logger.log(u"The result " + title + " doesn't seem to be a valid episode that we want, ignoring", logger.DEBUG) diff --git a/sickbeard/providers/newznab.py b/sickbeard/providers/newznab.py index 7dcdd7a8..33850f78 100755 --- a/sickbeard/providers/newznab.py +++ b/sickbeard/providers/newznab.py @@ -114,8 +114,6 @@ class NewznabProvider(generic.NZBProvider): return to_return def _get_episode_search_strings(self, ep_obj, add_string=''): - return self._get_season_search_strings(ep_obj) - to_return = [] params = {}