1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
use futures::{SinkExt, StreamExt};
use crate::Pair;
use std::fmt::Debug;
pub fn debug<S, R, E>(label: &str, p: impl Pair<S, R, E>) -> impl Pair<S, R, E>
where
S: Debug + Send,
R: Debug + Send,
E: Debug + Send,
{
let label = label.to_owned();
let label2 = label.to_owned();
p.map(move |a| {
tracing::debug!("{}:out: {:?}", label, a);
a
})
.with(move |a| {
let label = label2.clone();
async move {
tracing::debug!("{}:in: {:?}", label, a);
Ok(a)
}
})
}