1
0
mirror of https://github.com/moparisthebest/SickRage synced 2025-01-07 11:58:01 -05:00

Fixed high CPU usage during searches, adding conditional check to prevent un-needed name parsing of search results when search result was previously already parsed and checked during filtering of bad releases

This commit is contained in:
echel0n 2014-09-06 17:25:07 -07:00
parent 4af28657af
commit 65eda93b2b
4 changed files with 7 additions and 23 deletions

View File

@ -149,7 +149,7 @@ class ProperFinder():
logger.DEBUG) logger.DEBUG)
continue continue
if not show_name_helpers.filterBadReleases(curProper.name): if not show_name_helpers.filterBadReleases(curProper.name, parse=False):
logger.log(u"Proper " + curProper.name + " isn't a valid scene release that we want, ignoring it", logger.log(u"Proper " + curProper.name + " isn't a valid scene release that we want, ignoring it",
logger.DEBUG) logger.DEBUG)
continue continue

View File

@ -319,23 +319,6 @@ def isFirstBestMatch(result):
return False return False
def filterSearchResults(show, season, results):
foundResults = {}
# make a list of all the results for this provider
for curEp in results:
# skip non-tv crap
results[curEp] = filter(
lambda x: show_name_helpers.filterBadReleases(x.name) and x.show == show,results[curEp])
if curEp in foundResults:
foundResults[curEp] += results[curEp]
else:
foundResults[curEp] = results[curEp]
return foundResults
def searchForNeededEpisodes(): def searchForNeededEpisodes():
foundResults = {} foundResults = {}
@ -468,7 +451,7 @@ def searchProviders(show, season, episodes, manualSearch=False):
for curEp in searchResults: for curEp in searchResults:
# skip non-tv crap # skip non-tv crap
searchResults[curEp] = filter( searchResults[curEp] = filter(
lambda x: show_name_helpers.filterBadReleases(x.name) and x.show == show, searchResults[curEp]) lambda x: show_name_helpers.filterBadReleases(x.name, parse=False) and x.show == show, searchResults[curEp])
if curEp in foundResults: if curEp in foundResults:
foundResults[curProvider.name][curEp] += searchResults[curEp] foundResults[curProvider.name][curEp] += searchResults[curEp]
@ -554,7 +537,7 @@ def searchProviders(show, season, episodes, manualSearch=False):
individualResults = nzbSplitter.splitResult(bestSeasonResult) individualResults = nzbSplitter.splitResult(bestSeasonResult)
individualResults = filter( individualResults = filter(
lambda x: show_name_helpers.filterBadReleases(x.name) and x.show == show, individualResults) lambda x: show_name_helpers.filterBadReleases(x.name, parse=False) and x.show == show, individualResults)
for curResult in individualResults: for curResult in individualResults:
if len(curResult.episodes) == 1: if len(curResult.episodes) == 1:

View File

@ -36,7 +36,7 @@ resultFilters = ["sub(bed|ed|pack|s)", "(dk|fin|heb|kor|nor|nordic|pl|swe)sub(be
"(dir|sample|sub|nfo)fix", "sample", "(dvd)?extras", "(dir|sample|sub|nfo)fix", "sample", "(dvd)?extras",
"dub(bed)?"] "dub(bed)?"]
def filterBadReleases(name): def filterBadReleases(name, parse=True):
""" """
Filters out non-english and just all-around stupid releases by comparing them Filters out non-english and just all-around stupid releases by comparing them
to the resultFilters contents. to the resultFilters contents.
@ -47,7 +47,8 @@ def filterBadReleases(name):
""" """
try: try:
NameParser().parse(name) if parse:
NameParser().parse(name)
except InvalidNameException: except InvalidNameException:
logger.log(u"Unable to parse the filename " + name + " into a valid episode", logger.DEBUG) logger.log(u"Unable to parse the filename " + name + " into a valid episode", logger.DEBUG)
return False return False

View File

@ -309,7 +309,7 @@ class TVCache():
for curResult in sqlResults: for curResult in sqlResults:
# skip non-tv crap # skip non-tv crap
if not show_name_helpers.filterBadReleases(curResult["name"]): if not show_name_helpers.filterBadReleases(curResult["name"], parse=False):
continue continue
# get the show object, or if it's not one of our shows then ignore it # get the show object, or if it's not one of our shows then ignore it