mirror of
https://github.com/pesde-pkg/pesde.git
synced 2025-04-26 23:03:46 +01:00
Squashed commit of the following: commit5767042964
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Thu Jan 16 18:28:52 2025 +0100 fix(engines): correct engine detection on unix The `current_exe` function doesn't return the symlinked path on Unix, so the engine detection was failing there. This commit fixes that by using the 0th argument of the program to get the path of the executable on Unix. commitb51c9d9571
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Wed Jan 15 22:43:50 2025 +0100 refactor: print deprecated warning on CLI side Prints the deprecated warning on the CLI side which means it'll have a more consistent look with the rest of the CLI output. commit5ace844035
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Wed Jan 15 22:21:36 2025 +0100 feat: add alias validation Ensures aliases don't contain characters which could cause issues. They are now also forbidden from being the same as an engine name to avoid issues. commita33302aff9
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Wed Jan 15 21:23:40 2025 +0100 refactor: apply clippy lints commit2d534a534d
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Wed Jan 15 21:22:14 2025 +0100 feat(engines): print incompatibility warning for dependencies Adds a warning message when a dependency depends on an incompatible engine. commit4946a19f8b
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Wed Jan 15 18:33:38 2025 +0100 feat(engines): create linkers at install time Additionally fixes engines being executed as scripts, and fixes downloading pesde from GitHub. commite3177eeb75
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Tue Jan 14 14:33:26 2025 +0100 fix(engines): store & link engines correctly Fixes issues with how engines were stored which resulted in errors. Also makes outdated linkers get updated. commit037ead66bb
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Mon Jan 13 12:26:19 2025 +0100 docs: remove prerequisites commitddb496ff7d
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Mon Jan 13 12:25:53 2025 +0100 ci: remove tar builds commite9f0c25554
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Mon Jan 13 12:25:11 2025 +0100 chore(docs): update astro and starlight commitfc349e6f21
Author: daimond113 <72147841+daimond113@users.noreply.github.com> Date: Sun Jan 12 23:12:27 2025 +0100 feat: add engines Adds the initial implementation of the engines feature. Not tested yet. Requires documentation and more work for non-pesde engines to be usable.
97 lines
2.8 KiB
Rust
97 lines
2.8 KiB
Rust
//! Progress reporting
|
|
//!
|
|
//! Certain operations will ask for a progress reporter to be passed in, this
|
|
//! allows the caller to be notified of progress during the operation. This can
|
|
//! be used to show progress to the user.
|
|
//!
|
|
//! All reporter traits are implemented for `()`. These implementations do
|
|
//! nothing, and can be used to ignore progress reporting.
|
|
|
|
#![allow(unused_variables)]
|
|
|
|
use async_stream::stream;
|
|
use futures::StreamExt;
|
|
use std::sync::Arc;
|
|
use tokio::io::AsyncBufRead;
|
|
|
|
/// Reports downloads.
|
|
pub trait DownloadsReporter: Send + Sync {
|
|
/// The [`DownloadProgressReporter`] type associated with this reporter.
|
|
type DownloadProgressReporter: DownloadProgressReporter + 'static;
|
|
|
|
/// Starts a new download.
|
|
fn report_download(self: Arc<Self>, name: String) -> Self::DownloadProgressReporter;
|
|
}
|
|
|
|
impl DownloadsReporter for () {
|
|
type DownloadProgressReporter = ();
|
|
fn report_download(self: Arc<Self>, name: String) -> Self::DownloadProgressReporter {}
|
|
}
|
|
|
|
/// Reports the progress of a single download.
|
|
pub trait DownloadProgressReporter: Send + Sync {
|
|
/// Reports that the download has started.
|
|
fn report_start(&self) {}
|
|
|
|
/// Reports the progress of the download.
|
|
///
|
|
/// `total` is the total number of bytes to download, and `len` is the number
|
|
/// of bytes downloaded so far.
|
|
fn report_progress(&self, total: u64, len: u64) {}
|
|
|
|
/// Reports that the download is done.
|
|
fn report_done(&self) {}
|
|
}
|
|
|
|
impl DownloadProgressReporter for () {}
|
|
|
|
/// Reports the progress of applying patches.
|
|
pub trait PatchesReporter: Send + Sync {
|
|
/// The [`PatchProgressReporter`] type associated with this reporter.
|
|
type PatchProgressReporter: PatchProgressReporter + 'static;
|
|
|
|
/// Starts a new patch.
|
|
fn report_patch(self: Arc<Self>, name: String) -> Self::PatchProgressReporter;
|
|
}
|
|
|
|
impl PatchesReporter for () {
|
|
type PatchProgressReporter = ();
|
|
fn report_patch(self: Arc<Self>, name: String) -> Self::PatchProgressReporter {}
|
|
}
|
|
|
|
/// Reports the progress of a single patch.
|
|
pub trait PatchProgressReporter: Send + Sync {
|
|
/// Reports that the patch has been applied.
|
|
fn report_done(&self) {}
|
|
}
|
|
|
|
impl PatchProgressReporter for () {}
|
|
|
|
pub(crate) fn response_to_async_read<R: DownloadProgressReporter>(
|
|
response: reqwest::Response,
|
|
reporter: Arc<R>,
|
|
) -> impl AsyncBufRead {
|
|
let total_len = response.content_length().unwrap_or(0);
|
|
reporter.report_progress(total_len, 0);
|
|
|
|
let mut bytes_downloaded = 0;
|
|
let mut stream = response.bytes_stream();
|
|
let bytes = stream!({
|
|
while let Some(chunk) = stream.next().await {
|
|
let chunk = match chunk {
|
|
Ok(chunk) => chunk,
|
|
Err(err) => {
|
|
yield Err(std::io::Error::new(std::io::ErrorKind::Other, err));
|
|
continue;
|
|
}
|
|
};
|
|
bytes_downloaded += chunk.len() as u64;
|
|
reporter.report_progress(total_len, bytes_downloaded);
|
|
yield Ok(chunk);
|
|
}
|
|
|
|
reporter.report_done();
|
|
});
|
|
|
|
tokio_util::io::StreamReader::new(bytes)
|
|
}
|