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:
parent
4af28657af
commit
65eda93b2b
@ -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
|
||||||
|
@ -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:
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user