mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-07 10:33:38 +00:00
Change to consolidate scene exceptions and name cache code
This commit is contained in:
parent
0e7c9656b9
commit
fb5e3ba952
8 changed files with 38 additions and 45 deletions
|
@ -35,6 +35,7 @@
|
||||||
* Change py2 exception clauses to py2/3 compatible clauses
|
* Change py2 exception clauses to py2/3 compatible clauses
|
||||||
* Change py2 print statements to py2/3 compatible functions
|
* Change py2 print statements to py2/3 compatible functions
|
||||||
* Change Kodi notifier to use requests as opposed to urllib
|
* Change Kodi notifier to use requests as opposed to urllib
|
||||||
|
* Change to consolidate scene exceptions and name cache code
|
||||||
|
|
||||||
[develop changelog]
|
[develop changelog]
|
||||||
* Update Requests library 2.7.0 (ab1f493) to 2.7.0 (8b5e457)
|
* Update Requests library 2.7.0 (ab1f493) to 2.7.0 (8b5e457)
|
||||||
|
|
|
@ -135,7 +135,7 @@ PROXY_INDEXERS = True
|
||||||
|
|
||||||
LOCALHOST_IP = None
|
LOCALHOST_IP = None
|
||||||
|
|
||||||
CPU_PRESET = None
|
CPU_PRESET = 'NORMAL'
|
||||||
|
|
||||||
ANON_REDIRECT = None
|
ANON_REDIRECT = None
|
||||||
|
|
||||||
|
|
|
@ -23,18 +23,19 @@ nameCache = {}
|
||||||
nameCacheLock = threading.Lock()
|
nameCacheLock = threading.Lock()
|
||||||
|
|
||||||
|
|
||||||
def addNameToCache(name, indexer_id=0):
|
def addNameToCache(name, indexer_id=0, season=-1):
|
||||||
"""Adds the show & tvdb id to the namecache
|
"""Adds the show & tvdb id to the namecache
|
||||||
|
|
||||||
:param name: the show name to cache
|
:param name: the show name to cache
|
||||||
:param indexer_id: the TVDB and TVRAGE id that this show should be cached with (can be None/0 for unknown)
|
:param indexer_id: the TVDB and TVRAGE id that this show should be cached with (can be None/0 for unknown)
|
||||||
|
:param season: the season the the name exception belongs to. -1 for generic exception
|
||||||
"""
|
"""
|
||||||
global nameCache
|
global nameCache
|
||||||
|
|
||||||
# standardize the name we're using to account for small differences in providers
|
# standardize the name we're using to account for small differences in providers
|
||||||
name = sickbeard.helpers.full_sanitizeSceneName(name)
|
name = sickbeard.helpers.full_sanitizeSceneName(name)
|
||||||
if name not in nameCache:
|
if name not in nameCache:
|
||||||
nameCache[name] = int(indexer_id)
|
nameCache[name] = [int(indexer_id), season]
|
||||||
|
|
||||||
|
|
||||||
def retrieveNameFromCache(name):
|
def retrieveNameFromCache(name):
|
||||||
|
@ -47,7 +48,7 @@ def retrieveNameFromCache(name):
|
||||||
|
|
||||||
name = sickbeard.helpers.full_sanitizeSceneName(name)
|
name = sickbeard.helpers.full_sanitizeSceneName(name)
|
||||||
if name in nameCache:
|
if name in nameCache:
|
||||||
return int(nameCache[name])
|
return int(nameCache[name][0])
|
||||||
|
|
||||||
|
|
||||||
def buildNameCache(show=None):
|
def buildNameCache(show=None):
|
||||||
|
@ -64,26 +65,27 @@ def buildNameCache(show=None):
|
||||||
nameCache = dict((k, v) for k, v in nameCache.items() if v != show.indexerid)
|
nameCache = dict((k, v) for k, v in nameCache.items() if v != show.indexerid)
|
||||||
|
|
||||||
# add standard indexer name to namecache
|
# add standard indexer name to namecache
|
||||||
nameCache[show.name] = show.indexerid
|
nameCache[sickbeard.helpers.full_sanitizeSceneName(show.name)] = [show.indexerid, -1]
|
||||||
else:
|
else:
|
||||||
# generate list of indexer ids to look up in cache.db
|
# generate list of indexer ids to look up in cache.db
|
||||||
indexer_ids = [x.indexerid for x in sickbeard.showList if x]
|
indexer_ids = [x.indexerid for x in sickbeard.showList if x]
|
||||||
|
|
||||||
# add all standard show indexer names to namecache
|
# add all standard show indexer names to namecache
|
||||||
nameCache = dict(
|
nameCache = dict(
|
||||||
(sickbeard.helpers.full_sanitizeSceneName(x.name), x.indexerid) for x in sickbeard.showList if x)
|
(sickbeard.helpers.full_sanitizeSceneName(x.name), [x.indexerid, -1]) for x in sickbeard.showList if x)
|
||||||
|
|
||||||
cacheDB = db.DBConnection('cache.db')
|
cacheDB = db.DBConnection('cache.db')
|
||||||
|
|
||||||
cache_results = cacheDB.select(
|
cache_results = cacheDB.select(
|
||||||
'SELECT show_name, indexer_id FROM scene_exceptions WHERE indexer_id IN (%s)' % ','.join(
|
'SELECT show_name, indexer_id, season FROM scene_exceptions WHERE indexer_id IN (%s)' % ','.join(
|
||||||
['?'] * len(indexer_ids)), indexer_ids)
|
['?'] * len(indexer_ids)), indexer_ids)
|
||||||
|
|
||||||
if cache_results:
|
if cache_results:
|
||||||
for cache_result in cache_results:
|
for cache_result in cache_results:
|
||||||
indexer_id = int(cache_result['indexer_id'])
|
indexer_id = int(cache_result['indexer_id'])
|
||||||
|
season = int(cache_result['season'])
|
||||||
name = sickbeard.helpers.full_sanitizeSceneName(cache_result['show_name'])
|
name = sickbeard.helpers.full_sanitizeSceneName(cache_result['show_name'])
|
||||||
nameCache[name] = indexer_id
|
nameCache[name] = [indexer_id, season]
|
||||||
|
|
||||||
|
|
||||||
def remove_from_namecache(indexer_id):
|
def remove_from_namecache(indexer_id):
|
||||||
|
|
|
@ -29,6 +29,7 @@ import sickbeard
|
||||||
from sickbeard import logger, helpers, scene_numbering, common, scene_exceptions, encodingKludge as ek, db
|
from sickbeard import logger, helpers, scene_numbering, common, scene_exceptions, encodingKludge as ek, db
|
||||||
from dateutil import parser
|
from dateutil import parser
|
||||||
from sickbeard.exceptions import ex
|
from sickbeard.exceptions import ex
|
||||||
|
from sickbeard.common import cpu_presets
|
||||||
|
|
||||||
|
|
||||||
class NameParser(object):
|
class NameParser(object):
|
||||||
|
@ -215,7 +216,7 @@ class NameParser(object):
|
||||||
if bestResult.show and bestResult.show.is_anime and len(self.compiled_regexes[1]) > 1 and regex != 1:
|
if bestResult.show and bestResult.show.is_anime and len(self.compiled_regexes[1]) > 1 and regex != 1:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
# if this is a naming pattern test or result doesn't have a show object then return best result
|
# if this is a naming pattern test then return best result
|
||||||
if not bestResult.show or self.naming_pattern:
|
if not bestResult.show or self.naming_pattern:
|
||||||
return bestResult
|
return bestResult
|
||||||
|
|
||||||
|
@ -340,9 +341,9 @@ class NameParser(object):
|
||||||
logger.DEBUG)
|
logger.DEBUG)
|
||||||
|
|
||||||
# CPU sleep
|
# CPU sleep
|
||||||
time.sleep(0.02)
|
time.sleep(cpu_presets[sickbeard.CPU_PRESET])
|
||||||
|
|
||||||
return bestResult
|
return bestResult
|
||||||
|
|
||||||
def _combine_results(self, first, second, attr):
|
def _combine_results(self, first, second, attr):
|
||||||
# if the first doesn't exist then return the second or nothing
|
# if the first doesn't exist then return the second or nothing
|
||||||
|
|
|
@ -220,7 +220,7 @@ anime_regexes = [
|
||||||
(?P<ep_ab_num>\d{1,3}) # E01
|
(?P<ep_ab_num>\d{1,3}) # E01
|
||||||
(-(?P<extra_ab_ep_num>\d{1,3}))? # E02
|
(-(?P<extra_ab_ep_num>\d{1,3}))? # E02
|
||||||
(v(?P<version>[0-9]))? # version
|
(v(?P<version>[0-9]))? # version
|
||||||
[ ._-]+\[(?P<extra_info>\d{3,4}[xp]?\d{0,4}[\.\w\s-]*)\] # Source_Quality_Etc-
|
[ ._-]+\[(?P<extra_info>\d{3,4}[xp]?\d{0,4}.+?)\] # Source_Quality_Etc-
|
||||||
(\[(?P<crc>\w{8})\])? # CRC
|
(\[(?P<crc>\w{8})\])? # CRC
|
||||||
.*? # Separator and EOL
|
.*? # Separator and EOL
|
||||||
'''),
|
'''),
|
||||||
|
|
|
@ -128,34 +128,11 @@ def get_scene_exception_by_name_multiple(show_name):
|
||||||
Given a show name, return the indexerid of the exception, None if no exception
|
Given a show name, return the indexerid of the exception, None if no exception
|
||||||
is present.
|
is present.
|
||||||
"""
|
"""
|
||||||
|
try:
|
||||||
# try the obvious case first
|
exception_result = name_cache.nameCache[helpers.full_sanitizeSceneName(show_name)]
|
||||||
myDB = db.DBConnection('cache.db')
|
return [exception_result]
|
||||||
exception_result = myDB.select(
|
except:
|
||||||
"SELECT indexer_id, season FROM scene_exceptions WHERE LOWER(show_name) = ? ORDER BY season ASC",
|
return [[None, None]]
|
||||||
[show_name.lower()])
|
|
||||||
if exception_result:
|
|
||||||
return [(int(x["indexer_id"]), int(x["season"])) for x in exception_result]
|
|
||||||
|
|
||||||
out = []
|
|
||||||
all_exception_results = myDB.select("SELECT show_name, indexer_id, season FROM scene_exceptions")
|
|
||||||
|
|
||||||
for cur_exception in all_exception_results:
|
|
||||||
|
|
||||||
cur_exception_name = cur_exception["show_name"]
|
|
||||||
cur_indexer_id = int(cur_exception["indexer_id"])
|
|
||||||
cur_season = int(cur_exception["season"])
|
|
||||||
|
|
||||||
if show_name.lower() in (
|
|
||||||
cur_exception_name.lower(),
|
|
||||||
sickbeard.helpers.sanitizeSceneName(cur_exception_name).lower().replace('.', ' ')):
|
|
||||||
logger.log(u"Scene exception lookup got indexer id " + str(cur_indexer_id) + u", using that", logger.DEBUG)
|
|
||||||
out.append((cur_indexer_id, cur_season))
|
|
||||||
|
|
||||||
if out:
|
|
||||||
return out
|
|
||||||
else:
|
|
||||||
return [(None, None)]
|
|
||||||
|
|
||||||
|
|
||||||
def retrieve_exceptions():
|
def retrieve_exceptions():
|
||||||
|
|
|
@ -132,7 +132,12 @@ simple_test_cases = {
|
||||||
'[UTW]_Fractal_-_01_[h264-720p][96D3F1BF]': parser.ParseResult(None, 'Fractal', None, [], 'h264-720p', 'UTW', None, [1]),
|
'[UTW]_Fractal_-_01_[h264-720p][96D3F1BF]': parser.ParseResult(None, 'Fractal', None, [], 'h264-720p', 'UTW', None, [1]),
|
||||||
'[a-s]_inuyasha_-_028_rs2_[BFDDF9F2]': parser.ParseResult(None, 'inuyasha', None, [], 'BFDDF9F2', 'a-s', None, [28]),
|
'[a-s]_inuyasha_-_028_rs2_[BFDDF9F2]': parser.ParseResult(None, 'inuyasha', None, [], 'BFDDF9F2', 'a-s', None, [28]),
|
||||||
'[HorribleSubs] Fairy Tail S2 - 37 [1080p]': parser.ParseResult(None,'Fairy Tail S2', None, [], '1080p', 'HorribleSubs', None, [37]),
|
'[HorribleSubs] Fairy Tail S2 - 37 [1080p]': parser.ParseResult(None,'Fairy Tail S2', None, [], '1080p', 'HorribleSubs', None, [37]),
|
||||||
'[HorribleSubs] Sword Art Online II - 23 [720p]': parser.ParseResult(None, 'Sword Art Online II', None, [], '720p', 'HorribleSubs', None, [23])
|
'[HorribleSubs] Sword Art Online II - 23 [720p]': parser.ParseResult(None, 'Sword Art Online II', None, [], '720p', 'HorribleSubs', None, [23]),
|
||||||
|
},
|
||||||
|
|
||||||
|
'anime_standard': {
|
||||||
|
'[Cthuko] Shirobako - 05v2 [720p H264 AAC][80C9B09B]': parser.ParseResult(None, 'Shirobako', None, [], '720p H264 AAC', 'Cthuko', None, [5]),
|
||||||
|
'[Ayako]_Minami-ke_Okaeri_-_01v2_[1024x576 H264+AAC][B1912CD8]': parser.ParseResult(None, 'Minami-ke Okaeri', None, [], '1024x576 H264+AAC', 'Ayako', None, [1]),
|
||||||
},
|
},
|
||||||
|
|
||||||
'anime_ep_name': {
|
'anime_ep_name': {
|
||||||
|
@ -432,6 +437,10 @@ class BasicTests(test.SickbeardTestDBCase):
|
||||||
np = parser.NameParser(False, TVShow(is_anime=True), testing=True)
|
np = parser.NameParser(False, TVShow(is_anime=True), testing=True)
|
||||||
self._test_names(np, 'anime_ultimate')
|
self._test_names(np, 'anime_ultimate')
|
||||||
|
|
||||||
|
def test_anime_standard(self):
|
||||||
|
np = parser.NameParser(False, TVShow(is_anime=True), testing=True)
|
||||||
|
self._test_names(np, 'anime_standard')
|
||||||
|
|
||||||
def test_anime_ep_name(self):
|
def test_anime_ep_name(self):
|
||||||
np = parser.NameParser(False, TVShow(is_anime=True), testing=True)
|
np = parser.NameParser(False, TVShow(is_anime=True), testing=True)
|
||||||
self._test_names(np, 'anime_ep_name')
|
self._test_names(np, 'anime_ep_name')
|
||||||
|
|
|
@ -50,7 +50,10 @@ class SceneExceptionTestCase(test.SickbeardTestDBCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(SceneExceptionTestCase, self).setUp()
|
super(SceneExceptionTestCase, self).setUp()
|
||||||
|
|
||||||
|
sickbeard.showList = [Show(1, 70726), Show(1, 164451)]
|
||||||
scene_exceptions.retrieve_exceptions()
|
scene_exceptions.retrieve_exceptions()
|
||||||
|
name_cache.buildNameCache()
|
||||||
|
|
||||||
def test_sceneExceptionsEmpty(self):
|
def test_sceneExceptionsEmpty(self):
|
||||||
self.assertEqual(scene_exceptions.get_scene_exceptions(0), [])
|
self.assertEqual(scene_exceptions.get_scene_exceptions(0), [])
|
||||||
|
@ -59,12 +62,12 @@ class SceneExceptionTestCase(test.SickbeardTestDBCase):
|
||||||
self.assertEqual(sorted(scene_exceptions.get_scene_exceptions(70726)), ['Babylon 5', 'Babylon5'])
|
self.assertEqual(sorted(scene_exceptions.get_scene_exceptions(70726)), ['Babylon 5', 'Babylon5'])
|
||||||
|
|
||||||
def test_sceneExceptionByName(self):
|
def test_sceneExceptionByName(self):
|
||||||
self.assertEqual(scene_exceptions.get_scene_exception_by_name('Babylon5'), (70726, -1))
|
self.assertEqual(scene_exceptions.get_scene_exception_by_name('Babylon5'), [70726, -1])
|
||||||
self.assertEqual(scene_exceptions.get_scene_exception_by_name('babylon 5'), (70726, -1))
|
self.assertEqual(scene_exceptions.get_scene_exception_by_name('babylon 5'), [70726, -1])
|
||||||
self.assertEqual(scene_exceptions.get_scene_exception_by_name('Carlos 2010'), (164451, -1))
|
self.assertEqual(scene_exceptions.get_scene_exception_by_name('Carlos 2010'), [164451, -1])
|
||||||
|
|
||||||
def test_sceneExceptionByNameEmpty(self):
|
def test_sceneExceptionByNameEmpty(self):
|
||||||
self.assertEqual(scene_exceptions.get_scene_exception_by_name('nothing useful'), (None, None))
|
self.assertEqual(scene_exceptions.get_scene_exception_by_name('nothing useful'), [None, None])
|
||||||
|
|
||||||
def test_sceneExceptionsResetNameCache(self):
|
def test_sceneExceptionsResetNameCache(self):
|
||||||
# clear the exceptions
|
# clear the exceptions
|
||||||
|
|
Loading…
Reference in a new issue