mirror of
https://github.com/moparisthebest/SickRage
synced 2025-01-11 22:08:02 -05:00
Changed Releasegroup handling in Renamer
- Added a check for release_group field in db - Added a check for location field in db (filename, requires qual-RLSGROUP convention to be succesful) - If release_group field in db empty and the releasegroup was found in either release_name or location fields, then updates the db with the releasegroup. Except when releasegroup is 'SiCKRAGE' - If release_name is empty, and SR wants to replace it with a generic one, it will now use the releasegroup if found, and otherwise replace with SiCKRAGE.
This commit is contained in:
parent
91cb8d885c
commit
5088e06e28
@ -2126,7 +2126,27 @@ class TVEpisode(object):
|
||||
show_name = re.sub("\(\d+\)$", "", self.show.name).rstrip()
|
||||
else:
|
||||
show_name = self.show.name
|
||||
|
||||
|
||||
#try to get the release group
|
||||
rel_grp = {};
|
||||
rel_grp["SiCKRAGE"] = 'SiCKRAGE';
|
||||
if hasattr(self, 'location'): #from the location name
|
||||
rel_grp['location'] = release_group(self.show, self.location);
|
||||
if (rel_grp['location'] == ''): del rel_grp['location']
|
||||
if hasattr(self, '_release_group'): #from the release group field in db
|
||||
rel_grp['database'] = self._release_group;
|
||||
if (rel_grp['database'] == ''): del rel_grp['database']
|
||||
if hasattr(self, 'release_name'): #from the release name field in db
|
||||
rel_grp['release_name'] = release_group(self.show, self.release_name);
|
||||
if (rel_grp['release_name'] == ''): del rel_grp['release_name']
|
||||
|
||||
# use release_group, release_name, location in that order
|
||||
if ('database' in rel_grp): relgrp = 'database'
|
||||
elif ('release_name' in rel_grp): relgrp = 'release_name'
|
||||
elif ('location' in rel_grp): relgrp = 'location'
|
||||
else: relgrp = 'SiCKRAGE'
|
||||
|
||||
|
||||
return {
|
||||
'%SN': show_name,
|
||||
'%S.N': dot(show_name),
|
||||
@ -2148,7 +2168,7 @@ class TVEpisode(object):
|
||||
'%AB': '%(#)03d' % {'#': self.absolute_number},
|
||||
'%XAB': '%(#)03d' % {'#': self.scene_absolute_number},
|
||||
'%RN': release_name(self.release_name),
|
||||
'%RG': release_group(self.show, self.release_name),
|
||||
'%RG': rel_grp[relgrp],
|
||||
'%AD': str(self.airdate).replace('-', ' '),
|
||||
'%A.D': str(self.airdate).replace('-', '.'),
|
||||
'%A_D': us(str(self.airdate)),
|
||||
@ -2193,21 +2213,30 @@ class TVEpisode(object):
|
||||
replace_map = self._replace_map()
|
||||
|
||||
result_name = pattern
|
||||
|
||||
# if there's no release group then replace it with a reasonable facsimile
|
||||
|
||||
# if there's no release group in the db, let the user know we replaced it
|
||||
if (not hasattr(self, '_release_group') and (not replace_map['%RG'] == 'SiCKRAGE')):
|
||||
logger.log(u"Episode has no release group, replacing it with '" + replace_map['%RG'] + "'", logger.DEBUG);
|
||||
self._release_group = replace_map['%RG'] #if release_group is not in the db, put it there
|
||||
elif ((self._release_group == '') and (not replace_map['%RG'] == 'SiCKRAGE')):
|
||||
logger.log(u"Episode has no release group, replacing it with '" + replace_map['%RG'] + "'", logger.DEBUG);
|
||||
self._release_group = replace_map['%RG'] #if release_group is not in the db, put it there
|
||||
|
||||
# if there's no release name then replace it with a reasonable facsimile
|
||||
if not replace_map['%RN']:
|
||||
if self.show.air_by_date or self.show.sports:
|
||||
result_name = result_name.replace('%RN', '%S.N.%A.D.%E.N-SiCKRAGE')
|
||||
result_name = result_name.replace('%rn', '%s.n.%A.D.%e.n-sickrage')
|
||||
elif anime_type != 3:
|
||||
result_name = result_name.replace('%RN', '%S.N.%AB.%E.N-SiCKRAGE')
|
||||
result_name = result_name.replace('%rn', '%s.n.%ab.%e.n-sickrage')
|
||||
else:
|
||||
result_name = result_name.replace('%RN', '%S.N.S%0SE%0E.%E.N-SiCKRAGE')
|
||||
result_name = result_name.replace('%rn', '%s.n.s%0se%0e.%e.n-sickrage')
|
||||
|
||||
result_name = result_name.replace('%RG', 'SICKRAGE')
|
||||
result_name = result_name.replace('%rg', 'sickrage')
|
||||
if self.show.air_by_date or self.show.sports:
|
||||
result_name = result_name.replace('%RN', '%S.N.%A.D.%E.N-' + replace_map['%RG'])
|
||||
result_name = result_name.replace('%rn', '%s.n.%A.D.%e.n-' + replace_map['%RG'].lower())
|
||||
|
||||
elif anime_type != 3:
|
||||
result_name = result_name.replace('%RN', '%S.N.%AB.%E.N-' + replace_map['%RG'])
|
||||
result_name = result_name.replace('%rn', '%s.n.%ab.%e.n-' + replace_map['%RG'].lower())
|
||||
|
||||
else:
|
||||
result_name = result_name.replace('%RN', '%S.N.S%0SE%0E.%E.N-' + replace_map['%RG'])
|
||||
result_name = result_name.replace('%rn', '%s.n.s%0se%0e.%e.n-' + replace_map['%RG'].lower())
|
||||
|
||||
logger.log(u"Episode has no release name, replacing it with a generic one: " + result_name, logger.DEBUG)
|
||||
|
||||
if not replace_map['%RT']:
|
||||
|
Loading…
Reference in New Issue
Block a user