2009-10-23 08:19:48 +00:00
|
|
|
# Created By: Virgil Dupras
|
|
|
|
# Created On: 2006/03/15
|
2011-04-12 08:04:01 +00:00
|
|
|
# Copyright 2011 Hardcoded Software (http://www.hardcoded.net)
|
2009-10-23 08:19:48 +00:00
|
|
|
#
|
2010-09-30 10:17:41 +00:00
|
|
|
# This software is licensed under the "BSD" License as described in the "LICENSE" file,
|
2009-10-23 08:19:48 +00:00
|
|
|
# which should be included with this package. The terms are also available at
|
2010-09-30 10:17:41 +00:00
|
|
|
# http://www.hardcoded.net/licenses/bsd_license
|
2009-10-23 08:19:48 +00:00
|
|
|
|
2011-01-11 12:36:05 +00:00
|
|
|
from hscommon.util import format_size
|
2011-01-26 12:06:54 +00:00
|
|
|
from hscommon.trans import tr as trbase
|
2011-06-15 15:58:33 +00:00
|
|
|
from core.data import (format_timestamp, format_words, format_perc, format_dupe_count, cmp_value,
|
|
|
|
Column)
|
2011-09-16 22:01:56 +00:00
|
|
|
from core import prioritize
|
2009-10-23 08:19:48 +00:00
|
|
|
|
2011-01-26 12:06:54 +00:00
|
|
|
tr = lambda s: trbase(s, 'columns')
|
|
|
|
|
2009-10-23 08:19:48 +00:00
|
|
|
COLUMNS = [
|
2011-01-29 10:07:33 +00:00
|
|
|
Column('name', tr("Filename")),
|
2011-06-15 15:58:33 +00:00
|
|
|
Column('folder_path', tr("Folder")),
|
2011-01-29 10:07:33 +00:00
|
|
|
Column('size', tr("Size (KB)")),
|
|
|
|
Column('extension', tr("Kind")),
|
|
|
|
Column('mtime', tr("Modification")),
|
|
|
|
Column('percentage', tr("Match %")),
|
|
|
|
Column('words', tr("Words Used")),
|
|
|
|
Column('dupe_count', tr("Dupe Count")),
|
2009-10-23 08:19:48 +00:00
|
|
|
]
|
|
|
|
|
2010-10-04 08:01:52 +00:00
|
|
|
MATCHPERC_COL = 5
|
|
|
|
DUPECOUNT_COL = 7
|
2011-01-29 10:07:33 +00:00
|
|
|
DELTA_COLUMNS = {2, 4}
|
2010-10-04 08:01:52 +00:00
|
|
|
|
2010-08-13 07:26:38 +00:00
|
|
|
METADATA_TO_READ = ['size', 'mtime']
|
2009-10-23 08:19:48 +00:00
|
|
|
|
|
|
|
def GetDisplayInfo(dupe, group, delta):
|
|
|
|
size = dupe.size
|
|
|
|
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
|
|
|
|
mtime -= r.mtime
|
|
|
|
else:
|
|
|
|
percentage = group.percentage
|
|
|
|
dupe_count = len(group.dupes)
|
|
|
|
return [
|
|
|
|
dupe.name,
|
2011-06-15 15:58:33 +00:00
|
|
|
str(dupe.folder_path),
|
2009-10-23 08:19:48 +00:00
|
|
|
format_size(size, 0, 1, False),
|
|
|
|
dupe.extension,
|
|
|
|
format_timestamp(mtime, delta and m),
|
|
|
|
format_perc(percentage),
|
|
|
|
format_words(dupe.words) if hasattr(dupe, 'words') else '',
|
|
|
|
format_dupe_count(dupe_count)
|
|
|
|
]
|
|
|
|
|
|
|
|
def GetDupeSortKey(dupe, get_group, key, delta):
|
2010-10-04 08:01:52 +00:00
|
|
|
if key == MATCHPERC_COL:
|
2009-10-23 08:19:48 +00:00
|
|
|
m = get_group().get_match_of(dupe)
|
|
|
|
return m.percentage
|
2010-10-04 08:01:52 +00:00
|
|
|
if key == DUPECOUNT_COL:
|
2009-10-23 08:19:48 +00:00
|
|
|
return 0
|
2011-01-29 10:07:33 +00:00
|
|
|
r = cmp_value(getattr(dupe, COLUMNS[key].attr, ''))
|
2011-01-29 10:20:19 +00:00
|
|
|
if delta and (key in DELTA_COLUMNS):
|
2011-01-29 10:07:33 +00:00
|
|
|
r -= cmp_value(getattr(get_group().ref, COLUMNS[key].attr, ''))
|
2009-10-23 08:19:48 +00:00
|
|
|
return r
|
|
|
|
|
|
|
|
def GetGroupSortKey(group, key):
|
2010-10-04 08:01:52 +00:00
|
|
|
if key == MATCHPERC_COL:
|
2009-10-23 08:19:48 +00:00
|
|
|
return group.percentage
|
2010-10-04 08:01:52 +00:00
|
|
|
if key == DUPECOUNT_COL:
|
2009-10-23 08:19:48 +00:00
|
|
|
return len(group)
|
2011-01-29 10:07:33 +00:00
|
|
|
return cmp_value(getattr(group.ref, COLUMNS[key].attr, ''))
|
2011-09-16 22:01:56 +00:00
|
|
|
|
|
|
|
def prioritization_categories():
|
|
|
|
return prioritize.all_categories()
|