mirror of
https://github.com/ihabunek/twitch-dl
synced 2024-08-30 18:32:25 +00:00
Make Progress work when file count is not known
This commit is contained in:
parent
42f7a9a1a5
commit
b6e7f8b36c
@ -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:
|
||||||
|
Loading…
Reference in New Issue
Block a user