Browse Source

Renamer now really renames files

pull/51/merge
Ruud 14 years ago
parent
commit
a76160397c
  1. 25
      couchpotato/core/plugins/renamer/main.py

25
couchpotato/core/plugins/renamer/main.py

@ -18,13 +18,14 @@ class Renamer(Plugin):
def __init__(self):
addEvent('renamer.scan', self.scan)
#addEvent('app.load', self.scan)
addEvent('app.load', self.scan)
#fireEvent('schedule.interval', 'renamer.scan', self.scan, minutes = self.conf('run_every'))
fireEvent('schedule.interval', 'renamer.scan', self.scan, minutes = self.conf('run_every'))
def scan(self):
groups = fireEvent('scanner.scan', folder = self.conf('from'), single = True)
if groups is None: return
destination = self.conf('to')
folder_name = self.conf('folder_name')
@ -151,11 +152,13 @@ class Renamer(Plugin):
# Before renaming, remove the lower quality files
db = get_session()
library = db.query(Library).filter_by(identifier = group['library']['identifier']).first()
done_status = fireEvent('status.get', 'done', single = True)
for movie in library.movies:
for release in movie.releases:
if release.quality.order < group['meta_data']['quality']['order']:
log.info('Removing older release for %s, with quality %s' % (movie.library.titles[0].title, release.quality.label))
elif release.quality.order is group['meta_data']['quality']['order']:
elif release.status_id is done_status.get('id'):
if release.quality.order is group['meta_data']['quality']['order']:
log.info('Same quality release already exists for %s, with quality %s. Assuming repack.' % (movie.library.titles[0].title, release.quality.label))
else:
log.info('Better quality release already exists for %s, with quality %s' % (movie.library.titles[0].title, release.quality.label))
@ -176,17 +179,25 @@ class Renamer(Plugin):
log.info('Removing "%s"' % file.path)
# Rename
for rename_me in rename_files:
if rename_files[rename_me]:
log.info('Renaming "%s" to "%s"' % (rename_me, rename_files[rename_me]))
for src in rename_files:
if rename_files[src]:
dst = rename_files[src]
log.info('Renaming "%s" to "%s"' % (src, dst))
path = os.path.dirname(rename_files[rename_me])
path = os.path.dirname(dst)
try:
if not os.path.isdir(path): os.makedirs(path)
except:
log.error('Failed creating dir %s: %s' % (path, traceback.format_exc()))
continue
try:
shutil.move(src, dst)
except:
log.error('Failed moving the file "%s" : %s' % (os.path.basename(src), traceback.format_exc()))
#print rename_me, rename_files[rename_me]
# Search for trailers

Loading…
Cancel
Save