Make Progress work when file count is not known

This commit is contained in:
Ivan Habunek 2024-08-28 14:38:17 +02:00
parent 42f7a9a1a5
commit b6e7f8b36c
No known key found for this signature in database
GPG Key ID: 01DB3DD0D824504C

View File

@ -32,7 +32,7 @@ class Sample(NamedTuple):
class Progress: class Progress:
def __init__(self, vod_count: int): def __init__(self, file_count: Optional[int] = None):
self.downloaded: int = 0 self.downloaded: int = 0
self.estimated_total: Optional[int] = None self.estimated_total: Optional[int] = None
self.last_printed: Optional[float] = None self.last_printed: Optional[float] = None
@ -42,8 +42,8 @@ class Progress:
self.samples: Deque[Sample] = deque(maxlen=1000) self.samples: Deque[Sample] = deque(maxlen=1000)
self.speed: Optional[float] = None self.speed: Optional[float] = None
self.tasks: Dict[TaskId, Task] = {} self.tasks: Dict[TaskId, Task] = {}
self.vod_count = vod_count self.file_count = file_count
self.vod_downloaded_count: int = 0 self.downloaded_count: int = 0
def start(self, task_id: int, size: int): def start(self, task_id: int, size: int):
if task_id in self.tasks: if task_id in self.tasks:
@ -68,7 +68,7 @@ class Progress:
self.tasks[task_id] = Task(task_id, size) self.tasks[task_id] = Task(task_id, size)
self.progress_bytes += size self.progress_bytes += size
self.vod_downloaded_count += 1 self.downloaded_count += 1
self.print() self.print()
def abort(self, task_id: int): def abort(self, task_id: int):
@ -89,13 +89,15 @@ class Progress:
f"Taks {task_id} ended with {task.downloaded}b downloaded, expected {task.size}b." f"Taks {task_id} ended with {task.downloaded}b downloaded, expected {task.size}b."
) )
self.vod_downloaded_count += 1 self.downloaded_count += 1
self.print() self.print()
def _recalculate(self): def _recalculate(self):
self.estimated_total = ( if self.tasks and self.file_count:
int(mean(t.size for t in self.tasks.values()) * self.vod_count) if self.tasks else None self.estimated_total = int(mean(t.size for t in self.tasks.values()) * self.file_count)
) else:
self.estimated_total = None
self.speed = self._calculate_speed() self.speed = self._calculate_speed()
self.progress_perc = ( self.progress_perc = (
int(100 * self.progress_bytes / self.estimated_total) if self.estimated_total else 0 int(100 * self.progress_bytes / self.estimated_total) if self.estimated_total else 0
@ -128,7 +130,8 @@ class Progress:
self._recalculate() self._recalculate()
clear_line() clear_line()
click.echo(f"Downloaded {self.vod_downloaded_count}/{self.vod_count} VODs", nl=False) total_label = f"/{self.file_count}" if self.file_count else ""
click.echo(f"Downloaded {self.downloaded_count}{total_label}", nl=False)
click.secho(f" {self.progress_perc}%", fg="blue", nl=False) click.secho(f" {self.progress_perc}%", fg="blue", nl=False)
if self.estimated_total is not None: if self.estimated_total is not None: