mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-13 04:54:23 +00:00
Fix #229 add 'date added' column, with patch from Lajnold
This commit is contained in:
parent
a2a3bd2148
commit
e5cbca13dc
@ -68,7 +68,7 @@ STATUS_KEYS = ['active_time', 'compact', 'distributed_copies', 'download_payload
|
|||||||
'move_on_completed_path', 'name', 'next_announce', 'num_files', 'num_peers', 'num_pieces',
|
'move_on_completed_path', 'name', 'next_announce', 'num_files', 'num_peers', 'num_pieces',
|
||||||
'num_seeds', 'paused', 'peers', 'piece_length', 'prioritize_first_last', 'private', 'progress',
|
'num_seeds', 'paused', 'peers', 'piece_length', 'prioritize_first_last', 'private', 'progress',
|
||||||
'queue', 'ratio', 'remove_at_ratio', 'save_path', 'seed_rank', 'seeding_time', 'state', 'stop_at_ratio',
|
'queue', 'ratio', 'remove_at_ratio', 'save_path', 'seed_rank', 'seeding_time', 'state', 'stop_at_ratio',
|
||||||
'stop_ratio', 'total_done', 'total_payload_download', 'total_payload_upload', 'total_peers',
|
'stop_ratio', 'time_added', 'total_done', 'total_payload_download', 'total_payload_upload', 'total_peers',
|
||||||
'total_seeds', 'total_size', 'total_uploaded', 'total_wanted', 'tracker', 'tracker_host',
|
'total_seeds', 'total_size', 'total_uploaded', 'total_wanted', 'tracker', 'tracker_host',
|
||||||
'tracker_status', 'trackers', 'upload_payload_rate']
|
'tracker_status', 'trackers', 'upload_payload_rate']
|
||||||
|
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
"""Internal Torrent class"""
|
"""Internal Torrent class"""
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
import time
|
||||||
from urlparse import urlparse
|
from urlparse import urlparse
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@ -198,6 +199,11 @@ class Torrent:
|
|||||||
# The tracker status
|
# The tracker status
|
||||||
self.tracker_status = ""
|
self.tracker_status = ""
|
||||||
|
|
||||||
|
if state:
|
||||||
|
self.time_added = state.time_added
|
||||||
|
else:
|
||||||
|
self.time_added = time.time()
|
||||||
|
|
||||||
log.debug("Torrent object created.")
|
log.debug("Torrent object created.")
|
||||||
|
|
||||||
## Options methods ##
|
## Options methods ##
|
||||||
@ -566,7 +572,8 @@ class Torrent:
|
|||||||
"stop_at_ratio": self.options["stop_at_ratio"],
|
"stop_at_ratio": self.options["stop_at_ratio"],
|
||||||
"remove_at_ratio": self.options["remove_at_ratio"],
|
"remove_at_ratio": self.options["remove_at_ratio"],
|
||||||
"move_on_completed": self.options["move_completed"],
|
"move_on_completed": self.options["move_completed"],
|
||||||
"move_on_completed_path": self.options["move_completed_path"]
|
"move_on_completed_path": self.options["move_completed_path"],
|
||||||
|
"time_added": self.time_added
|
||||||
}
|
}
|
||||||
|
|
||||||
def ti_name():
|
def ti_name():
|
||||||
|
@ -75,7 +75,8 @@ class TorrentState:
|
|||||||
stop_ratio=2.00,
|
stop_ratio=2.00,
|
||||||
stop_at_ratio=False,
|
stop_at_ratio=False,
|
||||||
remove_at_ratio=False,
|
remove_at_ratio=False,
|
||||||
magnet=None
|
magnet=None,
|
||||||
|
time_added=-1
|
||||||
):
|
):
|
||||||
self.torrent_id = torrent_id
|
self.torrent_id = torrent_id
|
||||||
self.filename = filename
|
self.filename = filename
|
||||||
@ -84,6 +85,7 @@ class TorrentState:
|
|||||||
self.queue = queue
|
self.queue = queue
|
||||||
self.is_finished = is_finished
|
self.is_finished = is_finished
|
||||||
self.magnet = magnet
|
self.magnet = magnet
|
||||||
|
self.time_added = time_added
|
||||||
|
|
||||||
# Options
|
# Options
|
||||||
self.compact = compact
|
self.compact = compact
|
||||||
@ -538,7 +540,8 @@ class TorrentManager(component.Component):
|
|||||||
torrent.options["stop_ratio"],
|
torrent.options["stop_ratio"],
|
||||||
torrent.options["stop_at_ratio"],
|
torrent.options["stop_at_ratio"],
|
||||||
torrent.options["remove_at_ratio"],
|
torrent.options["remove_at_ratio"],
|
||||||
torrent.magnet
|
torrent.magnet,
|
||||||
|
torrent.time_added
|
||||||
)
|
)
|
||||||
state.torrents.append(torrent_state)
|
state.torrents.append(torrent_state)
|
||||||
|
|
||||||
@ -778,4 +781,3 @@ class TorrentManager(component.Component):
|
|||||||
log.debug("on_alert_metadata_received")
|
log.debug("on_alert_metadata_received")
|
||||||
torrent = self.torrents[str(alert.handle.info_hash())]
|
torrent = self.torrents[str(alert.handle.info_hash())]
|
||||||
torrent.write_torrentfile()
|
torrent.write_torrentfile()
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -34,6 +34,7 @@
|
|||||||
|
|
||||||
import cPickle
|
import cPickle
|
||||||
import os.path
|
import os.path
|
||||||
|
import time
|
||||||
|
|
||||||
import pygtk
|
import pygtk
|
||||||
pygtk.require('2.0')
|
pygtk.require('2.0')
|
||||||
@ -88,6 +89,14 @@ def cell_data_ratio(column, cell, model, row, data):
|
|||||||
|
|
||||||
cell.set_property('text', ratio_str)
|
cell.set_property('text', ratio_str)
|
||||||
|
|
||||||
|
def cell_data_date(column, cell, model, row, data):
|
||||||
|
"""Display value as date, eg 2008/05/05"""
|
||||||
|
time_val = model.get_value(row, data)
|
||||||
|
time_str = ""
|
||||||
|
if time_val > -1:
|
||||||
|
time_str = time.strftime("%d/%m/%y", time.localtime(time_val))
|
||||||
|
cell.set_property('text', time_str)
|
||||||
|
|
||||||
class ListViewColumnState:
|
class ListViewColumnState:
|
||||||
"""Used for saving/loading column state"""
|
"""Used for saving/loading column state"""
|
||||||
def __init__(self, name, position, width, visible, sort, sort_order):
|
def __init__(self, name, position, width, visible, sort, sort_order):
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
# statement from all source files in the program, then also delete it here.
|
# statement from all source files in the program, then also delete it here.
|
||||||
|
|
||||||
import gtk, gtk.glade
|
import gtk, gtk.glade
|
||||||
|
import time
|
||||||
|
|
||||||
from deluge.ui.client import aclient as client
|
from deluge.ui.client import aclient as client
|
||||||
import deluge.component as component
|
import deluge.component as component
|
||||||
@ -60,6 +61,11 @@ def fspeed(value, max_value=-1):
|
|||||||
else:
|
else:
|
||||||
return deluge.common.fspeed(value)
|
return deluge.common.fspeed(value)
|
||||||
|
|
||||||
|
def fdate(value):
|
||||||
|
if value < 0:
|
||||||
|
return ""
|
||||||
|
return time.strftime("%d/%m/%y", time.localtime(value))
|
||||||
|
|
||||||
class StatisticsTab(Tab):
|
class StatisticsTab(Tab):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
Tab.__init__(self)
|
Tab.__init__(self)
|
||||||
@ -88,7 +94,8 @@ class StatisticsTab(Tab):
|
|||||||
(glade.get_widget("summary_seed_time"), deluge.common.ftime, ("seeding_time",)),
|
(glade.get_widget("summary_seed_time"), deluge.common.ftime, ("seeding_time",)),
|
||||||
(glade.get_widget("summary_seed_rank"), str, ("seed_rank",)),
|
(glade.get_widget("summary_seed_rank"), str, ("seed_rank",)),
|
||||||
(glade.get_widget("summary_auto_managed"), str, ("is_auto_managed",)),
|
(glade.get_widget("summary_auto_managed"), str, ("is_auto_managed",)),
|
||||||
(glade.get_widget("progressbar"), fpcnt, ("progress",))
|
(glade.get_widget("progressbar"), fpcnt, ("progress",)),
|
||||||
|
(glade.get_widget("summary_date_added"), fdate, ("time_added",))
|
||||||
]
|
]
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
@ -110,7 +117,7 @@ class StatisticsTab(Tab):
|
|||||||
"total_seeds", "eta", "ratio", "next_announce",
|
"total_seeds", "eta", "ratio", "next_announce",
|
||||||
"tracker_status", "max_connections", "max_upload_slots",
|
"tracker_status", "max_connections", "max_upload_slots",
|
||||||
"max_upload_speed", "max_download_speed", "active_time",
|
"max_upload_speed", "max_download_speed", "active_time",
|
||||||
"seeding_time", "seed_rank", "is_auto_managed"]
|
"seeding_time", "seed_rank", "is_auto_managed", "time_added"]
|
||||||
|
|
||||||
client.get_torrent_status(
|
client.get_torrent_status(
|
||||||
self._on_get_torrent_status, selected, status_keys)
|
self._on_get_torrent_status, selected, status_keys)
|
||||||
|
@ -180,6 +180,10 @@ class TorrentView(listview.ListView, component.Component):
|
|||||||
listview.cell_data_ratio,
|
listview.cell_data_ratio,
|
||||||
[float],
|
[float],
|
||||||
status_field=["distributed_copies"])
|
status_field=["distributed_copies"])
|
||||||
|
self.add_func_column(_("Added"),
|
||||||
|
listview.cell_data_date,
|
||||||
|
[float],
|
||||||
|
status_field=["time_added"])
|
||||||
self.add_text_column(_("Tracker"), status_field=["tracker_host"])
|
self.add_text_column(_("Tracker"), status_field=["tracker_host"])
|
||||||
|
|
||||||
# Set filter to None for now
|
# Set filter to None for now
|
||||||
|
Loading…
x
Reference in New Issue
Block a user