Fix for issue #290, Post-processing issues

This commit is contained in:
echel0n 2014-05-01 15:53:37 -07:00
parent 74c6bec150
commit 85a9a81f4e
3 changed files with 23 additions and 22 deletions

View file

@ -942,7 +942,7 @@ def _check_against_names(name, show):
return False return False
def get_show_by_name(name, checkExceptions=False, checkIndexers=False): def get_show_by_name(name, checkIndexers=False):
in_cache = False in_cache = False
foundResult = None foundResult = None
@ -973,18 +973,17 @@ def get_show_by_name(name, checkExceptions=False, checkIndexers=False):
u"Database lookup found Indexer ID:" + str( u"Database lookup found Indexer ID:" + str(
foundResult.indexerid) + ", using that for " + name, logger.DEBUG) foundResult.indexerid) + ", using that for " + name, logger.DEBUG)
if not foundResult and checkExceptions: if not foundResult:
if not foundResult: logger.log(
logger.log( u"Checking the scene exceptions list for:" + str(name),
u"Checking the scene exceptions list for:" + str(name), logger.DEBUG)
logger.DEBUG)
for show in sickbeard.showList: for show in sickbeard.showList:
if _check_against_names(name, show): if _check_against_names(name, show):
logger.log( logger.log(
u"Scene exceptions lookup found Indexer ID:" + str(show.indexerid) + ", using that for " + name, u"Scene exceptions lookup found Indexer ID:" + str(show.indexerid) + ", using that for " + name,
logger.DEBUG) logger.DEBUG)
foundResult = show foundResult = show
if not foundResult and checkIndexers: if not foundResult and checkIndexers:
logger.log( logger.log(
@ -1003,7 +1002,7 @@ def get_show_by_name(name, checkExceptions=False, checkIndexers=False):
continue continue
if showObj: if showObj:
foundResult = findCertainShow(sickbeard.showList, int(showObj["id"])) foundResult = findCertainShow(sickbeard.showList, int(showObj[0]['id']))
if foundResult: if foundResult:
logger.log( logger.log(
u"Indexers lookup found Indexer ID:" + str( u"Indexers lookup found Indexer ID:" + str(

View file

@ -239,7 +239,6 @@ class NameParser(object):
final_result.air_date = self._combine_results(file_name_result, dir_name_result, 'air_date') final_result.air_date = self._combine_results(file_name_result, dir_name_result, 'air_date')
# sports event title # sports event title
final_result.sports_event_title = self._combine_results(file_name_result, dir_name_result, 'sports_event_title')
final_result.sports_event_date = self._combine_results(file_name_result, dir_name_result, 'sports_event_date') final_result.sports_event_date = self._combine_results(file_name_result, dir_name_result, 'sports_event_date')
if not final_result.air_date: if not final_result.air_date:
@ -248,6 +247,9 @@ class NameParser(object):
# if the dirname has a release group/show name I believe it over the filename # if the dirname has a release group/show name I believe it over the filename
final_result.series_name = self._combine_results(dir_name_result, file_name_result, 'series_name') final_result.series_name = self._combine_results(dir_name_result, file_name_result, 'series_name')
if final_result.sports:
final_result.series_name = str(final_result.series_name).partition(" ")[0]
final_result.extra_info = self._combine_results(dir_name_result, file_name_result, 'extra_info') final_result.extra_info = self._combine_results(dir_name_result, file_name_result, 'extra_info')
final_result.release_group = self._combine_results(dir_name_result, file_name_result, 'release_group') final_result.release_group = self._combine_results(dir_name_result, file_name_result, 'release_group')
@ -320,8 +322,6 @@ class ParseResult(object):
return False return False
if self.air_date != other.air_date: if self.air_date != other.air_date:
return False return False
if self.sports_event_title != other.sports_event_title:
return False
if self.sports_event_date != other.sports_event_date: if self.sports_event_date != other.sports_event_date:
return False return False
@ -341,7 +341,6 @@ class ParseResult(object):
if self.air_by_date: if self.air_by_date:
to_return += str(self.air_date) to_return += str(self.air_date)
if self.sports: if self.sports:
to_return += str(self.sports_event_title)
to_return += str(self.sports_event_date) to_return += str(self.sports_event_date)
if self.extra_info: if self.extra_info:
@ -410,14 +409,14 @@ class NameParserCache(object):
_previous_parsed = {} _previous_parsed = {}
_cache_size = 100 _cache_size = 100
def add(self, name, parse_result, convert=False): def add(self, name, parse_result):
self._previous_parsed[name] = parse_result self._previous_parsed[name] = parse_result
self._previous_parsed_list.append(name) self._previous_parsed_list.append(name)
while len(self._previous_parsed_list) > self._cache_size: while len(self._previous_parsed_list) > self._cache_size:
del_me = self._previous_parsed_list.pop(0) del_me = self._previous_parsed_list.pop(0)
self._previous_parsed.pop(del_me) self._previous_parsed.pop(del_me)
def get(self, name, convert=False): def get(self, name):
if name in self._previous_parsed: if name in self._previous_parsed:
logger.log("Using cached parse result for: " + name, logger.DEBUG) logger.log("Using cached parse result for: " + name, logger.DEBUG)
return self._previous_parsed[name] return self._previous_parsed[name]

View file

@ -464,6 +464,9 @@ class PostProcessor(object):
if parse_result.air_by_date: if parse_result.air_by_date:
season = -1 season = -1
episodes = [parse_result.air_date] episodes = [parse_result.air_date]
elif parse_result.sports:
season = -1
episodes = [parse_result.sports_event_date]
else: else:
season = parse_result.season_number season = parse_result.season_number
episodes = parse_result.episode_numbers episodes = parse_result.episode_numbers
@ -506,7 +509,7 @@ class PostProcessor(object):
# for each possible interpretation of that scene name # for each possible interpretation of that scene name
for cur_name in name_list: for cur_name in name_list:
showObj = helpers.get_show_by_name(cur_name) showObj = helpers.get_show_by_name(cur_name, checkIndexers=True)
if showObj: if showObj:
_finalize(parse_result) _finalize(parse_result)
return (showObj.indexerid, season, episodes) return (showObj.indexerid, season, episodes)
@ -624,7 +627,7 @@ class PostProcessor(object):
season = 1 season = 1
if indexer_id and season and episodes: if indexer_id and season and episodes:
return (indexer_id, season, episodes) break
return (indexer_id, season, episodes) return (indexer_id, season, episodes)
@ -817,7 +820,7 @@ class PostProcessor(object):
# try to find the file info # try to find the file info
(indexer_id, season, episodes) = self._find_info() (indexer_id, season, episodes) = self._find_info()
if not (indexer_id and season and len(episodes)): if not (indexer_id and season and len(episodes)):
self._log(u"Can't find the show on any of the Indexers, skipping", self._log(u"Unable to find enough info to post-process this show, skipping",
logger.WARNING) logger.WARNING)
return False return False