From 2e168d07314c38adbe25a046a06c8f62e5e33c6e Mon Sep 17 00:00:00 2001 From: Benedikt Peetz Date: Fri, 23 Aug 2024 13:01:28 +0200 Subject: fix(yt_dlp/lib): Standardize the formatting of bytes with the new `bytes` crate --- yt_dlp/Cargo.lock | 5 +++++ yt_dlp/Cargo.toml | 1 + yt_dlp/src/lib.rs | 19 +++++-------------- 3 files changed, 11 insertions(+), 14 deletions(-) diff --git a/yt_dlp/Cargo.lock b/yt_dlp/Cargo.lock index 4082d62..cb8d7c9 100644 --- a/yt_dlp/Cargo.lock +++ b/yt_dlp/Cargo.lock @@ -14,6 +14,10 @@ version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cf4b9d6a944f767f8e5e0db018570623c85f3d925ac718db4e06d0187adb21c1" +[[package]] +name = "bytes" +version = "1.0.0" + [[package]] name = "cfg-if" version = "1.0.0" @@ -589,6 +593,7 @@ dependencies = [ name = "yt_dlp" version = "0.1.0" dependencies = [ + "bytes", "log", "pyo3", "serde", diff --git a/yt_dlp/Cargo.toml b/yt_dlp/Cargo.toml index 590c422..e5f2efc 100644 --- a/yt_dlp/Cargo.toml +++ b/yt_dlp/Cargo.toml @@ -22,3 +22,4 @@ pyo3 = { version = "0.21.2", features = ["auto-initialize", "gil-refs"] } serde = { version = "1.0.203", features = ["derive"] } serde_json = "1.0.117" url = { version = "2.5.0", features = ["serde"] } +bytes = {path = "./crates/bytes"} diff --git a/yt_dlp/src/lib.rs b/yt_dlp/src/lib.rs index e0cb590..37d0945 100644 --- a/yt_dlp/src/lib.rs +++ b/yt_dlp/src/lib.rs @@ -14,6 +14,7 @@ use std::{path::PathBuf, sync::Once}; use crate::{duration::Duration, logging::setup_logging, wrapper::info_json::InfoJson}; +use bytes::Bytes; use log::{info, warn}; use pyo3::types::{PyString, PyTuple, PyTupleMethods}; use pyo3::{ @@ -151,23 +152,13 @@ pub fn progress_hook<'a>(py: Python, input: Bound<'_, PyDict>) -> PyResult<()> { } fn format_bytes(bytes: u64) -> String { - if bytes >= 1_000_000 { - format!("{} MB", bytes / 1_000_000) - } else if bytes >= 1_000 { - format!("{} KB", bytes / 1_000) - } else { - format!("{} B", bytes) - } + let bytes = Bytes::new(bytes); + bytes.to_string() } fn format_speed(speed: f64) -> String { - if speed > 1_000_000.0 { - format!("{:.02} MB/s", speed / 1_000_000.0) - } else if speed > 1_000.0 { - format!("{:.02} KB/s", speed / 1_000.0) - } else { - format!("{:.02} B/s", speed) - } + let bytes = Bytes::new(speed.floor() as u64); + format!("{}/s", bytes) } let get_title = |add_extension: bool| -> String { -- cgit 1.4.1