2
0
Fork 0
mirror of https://git.asonix.dog/asonix/pict-rs synced 2024-12-22 19:31:35 +00:00

No more follows-from for process

This commit is contained in:
Aode (lion) 2021-12-06 21:11:43 -06:00
parent bf4c544df4
commit e209a282d9
3 changed files with 15 additions and 17 deletions

2
Cargo.lock generated
View file

@ -1347,7 +1347,7 @@ dependencies = [
[[package]]
name = "pict-rs"
version = "0.3.0-beta.10"
version = "0.3.0-beta.11"
dependencies = [
"actix-form-data",
"actix-rt",

View file

@ -1,7 +1,7 @@
[package]
name = "pict-rs"
description = "A simple image hosting service"
version = "0.3.0-beta.10"
version = "0.3.0-beta.11"
authors = ["asonix <asonix@asonix.dog>"]
license = "AGPL-3.0"
readme = "README.md"

View file

@ -45,18 +45,22 @@ impl Process {
fn spawn_span(&self) -> Span {
let span = tracing::info_span!(parent: None, "Spawned command writer",);
span.follows_from(self.span.clone());
span
}
#[tracing::instrument(name = "Spawning Command")]
pub(crate) fn spawn(cmd: &mut Command) -> std::io::Result<Self> {
let cmd = cmd.stdin(Stdio::piped()).stdout(Stdio::piped());
cmd.spawn().map(|child| Process {
child,
span: Span::current(),
})
let span = tracing::info_span!(
"Spawning Command",
command = &tracing::field::debug(&cmd),
exception.message = &tracing::field::Empty,
exception.details = &tracing::field::Empty,
);
cmd.spawn().map(|child| Process { child, span })
}
pub(crate) async fn wait(mut self) -> std::io::Result<()> {
@ -100,7 +104,7 @@ impl Process {
Some(ProcessRead {
inner: stdout,
span: body_span(self.span),
span: self.span,
err_recv: rx,
err_closed: false,
handle: DropHandle { inner: handle },
@ -133,7 +137,7 @@ impl Process {
Some(ProcessRead {
inner: stdout,
span: body_span(self.span),
span: self.span,
err_recv: rx,
err_closed: false,
handle: DropHandle { inner: handle },
@ -177,7 +181,7 @@ impl Process {
Some(ProcessRead {
inner: stdout,
span: body_span(self.span),
span: self.span,
err_recv: rx,
err_closed: false,
handle: DropHandle { inner: handle },
@ -185,12 +189,6 @@ impl Process {
}
}
fn body_span(following: Span) -> Span {
let span = tracing::info_span!(parent: None, "Processing Command");
span.follows_from(following);
span
}
impl<I> AsyncRead for ProcessRead<I>
where
I: AsyncRead,
@ -202,10 +200,10 @@ where
) -> Poll<std::io::Result<()>> {
let this = self.as_mut().project();
let span = this.span;
let err_recv = this.err_recv;
let err_closed = this.err_closed;
let inner = this.inner;
let span = this.span;
span.in_scope(|| {
if !*err_closed {