2011-09-20 22:40:27 +00:00
|
|
|
# Created On: 2011/09/20
|
|
|
|
# Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
|
|
|
#
|
|
|
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
|
|
|
# which should be included with this package. The terms are also available at
|
|
|
|
# http://www.hardcoded.net/licenses/bsd_license
|
|
|
|
|
2011-11-01 19:44:18 +00:00
|
|
|
from hscommon.trans import trget
|
2011-09-21 17:55:26 +00:00
|
|
|
from hscommon.util import format_size, format_time
|
2011-11-26 15:55:14 +00:00
|
|
|
from hscommon.gui.column import Column
|
2011-09-21 14:26:58 +00:00
|
|
|
|
2011-11-26 15:55:14 +00:00
|
|
|
from core.app import (DupeGuru as DupeGuruBase, format_timestamp,
|
2011-09-21 14:26:58 +00:00
|
|
|
format_perc, format_words, format_dupe_count, cmp_value)
|
|
|
|
from . import prioritize
|
2011-09-21 14:35:34 +00:00
|
|
|
from . import __appname__
|
2011-09-21 18:04:41 +00:00
|
|
|
from . import scanner, fs
|
2011-09-21 14:26:58 +00:00
|
|
|
|
2011-11-01 19:44:18 +00:00
|
|
|
coltr = trget('columns')
|
2011-09-20 22:40:27 +00:00
|
|
|
|
|
|
|
class DupeGuru(DupeGuruBase):
|
2011-09-21 14:35:34 +00:00
|
|
|
NAME = __appname__
|
2011-09-21 14:26:58 +00:00
|
|
|
COLUMNS = [
|
2011-11-26 15:55:14 +00:00
|
|
|
Column('marked', ''),
|
2011-11-01 19:44:18 +00:00
|
|
|
Column('name', coltr("Filename")),
|
2011-11-26 15:55:14 +00:00
|
|
|
Column('folder_path', coltr("Folder"), visible=False, optional=True),
|
|
|
|
Column('size', coltr("Size (MB)"), optional=True),
|
|
|
|
Column('duration', coltr("Time"), optional=True),
|
|
|
|
Column('bitrate', coltr("Bitrate"), optional=True),
|
|
|
|
Column('samplerate', coltr("Sample Rate"), visible=False, optional=True),
|
|
|
|
Column('extension', coltr("Kind"), optional=True),
|
|
|
|
Column('mtime', coltr("Modification"), visible=False, optional=True),
|
|
|
|
Column('title', coltr("Title"), visible=False, optional=True),
|
|
|
|
Column('artist', coltr("Artist"), visible=False, optional=True),
|
|
|
|
Column('album', coltr("Album"), visible=False, optional=True),
|
|
|
|
Column('genre', coltr("Genre"), visible=False, optional=True),
|
|
|
|
Column('year', coltr("Year"), visible=False, optional=True),
|
|
|
|
Column('track', coltr("Track Number"), visible=False, optional=True),
|
|
|
|
Column('comment', coltr("Comment"), visible=False, optional=True),
|
|
|
|
Column('percentage', coltr("Match %"), optional=True),
|
|
|
|
Column('words', coltr("Words Used"), visible=False, optional=True),
|
|
|
|
Column('dupe_count', coltr("Dupe Count"), visible=False, optional=True),
|
2011-09-21 14:26:58 +00:00
|
|
|
]
|
|
|
|
DELTA_COLUMNS = {2, 3, 4, 5, 7}
|
|
|
|
METADATA_TO_READ = ['size', 'mtime', 'duration', 'bitrate', 'samplerate', 'title', 'artist',
|
|
|
|
'album', 'genre', 'year', 'track', 'comment']
|
|
|
|
MATCHPERC_COL = 15
|
|
|
|
DUPECOUNT_COL = 17
|
|
|
|
|
2011-09-20 22:40:27 +00:00
|
|
|
def __init__(self, view, appdata):
|
2011-09-21 14:26:58 +00:00
|
|
|
DupeGuruBase.__init__(self, view, appdata)
|
2011-09-21 18:04:41 +00:00
|
|
|
self.scanner = scanner.ScannerME()
|
|
|
|
self.directories.fileclasses = [fs.MusicFile]
|
2011-09-21 14:26:58 +00:00
|
|
|
|
|
|
|
def _get_display_info(self, dupe, group, delta):
|
|
|
|
size = dupe.size
|
|
|
|
duration = dupe.duration
|
|
|
|
bitrate = dupe.bitrate
|
|
|
|
samplerate = dupe.samplerate
|
|
|
|
mtime = dupe.mtime
|
|
|
|
m = group.get_match_of(dupe)
|
|
|
|
if m:
|
|
|
|
percentage = m.percentage
|
|
|
|
dupe_count = 0
|
|
|
|
if delta:
|
|
|
|
r = group.ref
|
|
|
|
size -= r.size
|
|
|
|
duration -= r.duration
|
|
|
|
bitrate -= r.bitrate
|
|
|
|
samplerate -= r.samplerate
|
|
|
|
mtime -= r.mtime
|
|
|
|
else:
|
|
|
|
percentage = group.percentage
|
|
|
|
dupe_count = len(group.dupes)
|
2011-11-26 15:55:14 +00:00
|
|
|
return {
|
|
|
|
'name': dupe.name,
|
|
|
|
'folder_path': str(dupe.folder_path),
|
|
|
|
'size': format_size(size, 2, 2, False),
|
|
|
|
'duration': format_time(duration, with_hours=False),
|
|
|
|
'bitrate': str(bitrate),
|
|
|
|
'samplerate': str(samplerate),
|
|
|
|
'extension': dupe.extension,
|
|
|
|
'mtime': format_timestamp(mtime,delta and m),
|
|
|
|
'title': dupe.title,
|
|
|
|
'artist': dupe.artist,
|
|
|
|
'album': dupe.album,
|
|
|
|
'genre': dupe.genre,
|
|
|
|
'year': dupe.year,
|
|
|
|
'track': str(dupe.track),
|
|
|
|
'comment': dupe.comment,
|
|
|
|
'percentage': format_perc(percentage),
|
|
|
|
'words': format_words(dupe.words) if hasattr(dupe, 'words') else '',
|
|
|
|
'dupe_count': format_dupe_count(dupe_count),
|
|
|
|
}
|
2011-09-21 14:26:58 +00:00
|
|
|
|
|
|
|
def _get_dupe_sort_key(self, dupe, get_group, key, delta):
|
|
|
|
if key == self.MATCHPERC_COL:
|
|
|
|
m = get_group().get_match_of(dupe)
|
|
|
|
return m.percentage
|
|
|
|
if key == self.DUPECOUNT_COL:
|
|
|
|
return 0
|
2011-09-22 16:29:56 +00:00
|
|
|
r = cmp_value(dupe, self.COLUMNS[key])
|
2011-09-21 14:26:58 +00:00
|
|
|
if delta and (key in self.DELTA_COLUMNS):
|
2011-09-22 16:29:56 +00:00
|
|
|
r -= cmp_value(get_group().ref, self.COLUMNS[key])
|
2011-09-21 14:26:58 +00:00
|
|
|
return r
|
|
|
|
|
|
|
|
def _get_group_sort_key(self, group, key):
|
|
|
|
if key == self.MATCHPERC_COL:
|
|
|
|
return group.percentage
|
|
|
|
if key == self.DUPECOUNT_COL:
|
|
|
|
return len(group)
|
2011-09-22 16:29:56 +00:00
|
|
|
return cmp_value(group.ref, self.COLUMNS[key])
|
2011-09-21 14:26:58 +00:00
|
|
|
|
|
|
|
def _prioritization_categories(self):
|
|
|
|
return prioritize.all_categories()
|
2011-09-20 22:40:27 +00:00
|
|
|
|