Merge pull request #520 from gierlachg/stream_pinning

Cleaning up stream pinning.
This commit is contained in:
Florian Gilcher 2019-11-13 15:56:48 +01:00 committed by GitHub
commit 6338341369
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
18 changed files with 5 additions and 49 deletions

View file

@ -12,8 +12,6 @@ impl<T: Ord> FromStream<T> for BinaryHeap<T> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = BinaryHeap::new(); let mut out = BinaryHeap::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -12,8 +12,6 @@ impl<K: Ord, V> FromStream<(K, V)> for BTreeMap<K, V> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = BTreeMap::new(); let mut out = BTreeMap::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -12,8 +12,6 @@ impl<T: Ord> FromStream<T> for BTreeSet<T> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = BTreeSet::new(); let mut out = BTreeSet::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -17,8 +17,6 @@ where
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = HashMap::with_hasher(Default::default()); let mut out = HashMap::with_hasher(Default::default());
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -17,8 +17,6 @@ where
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = HashSet::with_hasher(Default::default()); let mut out = HashSet::with_hasher(Default::default());
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -12,8 +12,6 @@ impl<T> FromStream<T> for LinkedList<T> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = LinkedList::new(); let mut out = LinkedList::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -12,8 +12,6 @@ impl<T> FromStream<T> for VecDeque<T> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = VecDeque::new(); let mut out = VecDeque::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -17,8 +17,6 @@ where
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
// Using `scan` here because it is able to stop the stream early // Using `scan` here because it is able to stop the stream early
// if a failure occurs // if a failure occurs
let mut found_error = false; let mut found_error = false;

View file

@ -39,8 +39,6 @@ where
where S: Stream<Item = Option<U>> + 'a where S: Stream<Item = Option<U>> + 'a
{ {
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
// Using `scan` here because it is able to stop the stream early // Using `scan` here because it is able to stop the stream early
// if a failure occurs // if a failure occurs
let mut found_none = false; let mut found_none = false;

View file

@ -34,8 +34,6 @@ where
where S: Stream<Item = Option<U>> + 'a where S: Stream<Item = Option<U>> + 'a
{ {
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
// Using `scan` here because it is able to stop the stream early // Using `scan` here because it is able to stop the stream early
// if a failure occurs // if a failure occurs
let mut found_none = false; let mut found_none = false;

View file

@ -342,10 +342,9 @@ impl<'b, P: AsRef<Path> + 'b> FromStream<P> for PathBuf {
fn from_stream<'a, S: IntoStream<Item = P> + 'a>( fn from_stream<'a, S: IntoStream<Item = P> + 'a>(
stream: S, stream: S,
) -> Pin<Box<dyn Future<Output = Self> + 'a>> { ) -> Pin<Box<dyn Future<Output = Self> + 'a>> {
Box::pin(async move {
let stream = stream.into_stream(); let stream = stream.into_stream();
pin_utils::pin_mut!(stream);
Box::pin(async move {
let mut out = Self::new(); let mut out = Self::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -17,8 +17,6 @@ where
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
// Using `scan` here because it is able to stop the stream early // Using `scan` here because it is able to stop the stream early
// if a failure occurs // if a failure occurs
let mut found_error = None; let mut found_error = None;

View file

@ -39,8 +39,6 @@ where
where S: Stream<Item = Result<U, E>> + 'a where S: Stream<Item = Result<U, E>> + 'a
{ {
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
// Using `scan` here because it is able to stop the stream early // Using `scan` here because it is able to stop the stream early
// if a failure occurs // if a failure occurs
let mut found_error = None; let mut found_error = None;

View file

@ -39,8 +39,6 @@ where
where S: Stream<Item = Result<U, E>> + 'a where S: Stream<Item = Result<U, E>> + 'a
{ {
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
// Using `scan` here because it is able to stop the stream early // Using `scan` here because it is able to stop the stream early
// if a failure occurs // if a failure occurs
let mut found_error = None; let mut found_error = None;

View file

@ -40,6 +40,7 @@ impl<F> Unpin for FromFn<F> {}
/// }); /// });
/// ///
/// pin_utils::pin_mut!(s); /// pin_utils::pin_mut!(s);
///
/// assert_eq!(s.next().await, Some(1)); /// assert_eq!(s.next().await, Some(1));
/// assert_eq!(s.next().await, Some(2)); /// assert_eq!(s.next().await, Some(2));
/// assert_eq!(s.next().await, Some(3)); /// assert_eq!(s.next().await, Some(3));

View file

@ -12,8 +12,6 @@ impl FromStream<char> for String {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = String::new(); let mut out = String::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out
@ -29,8 +27,6 @@ impl<'b> FromStream<&'b char> for String {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = String::new(); let mut out = String::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out
@ -46,8 +42,6 @@ impl<'b> FromStream<&'b str> for String {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = String::new(); let mut out = String::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out
@ -63,8 +57,6 @@ impl FromStream<String> for String {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = String::new(); let mut out = String::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out
@ -80,8 +72,6 @@ impl<'b> FromStream<Cow<'b, str>> for String {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = String::new(); let mut out = String::new();
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out

View file

@ -9,8 +9,10 @@ impl stream::Extend<()> for () {
stream: T, stream: T,
) -> Pin<Box<dyn Future<Output = ()> + 'a>> { ) -> Pin<Box<dyn Future<Output = ()> + 'a>> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream); pin_utils::pin_mut!(stream);
while let Some(_) = stream.next().await {} while let Some(_) = stream.next().await {}
}) })
} }

View file

@ -17,8 +17,6 @@ impl<T> FromStream<T> for Vec<T> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
let mut out = vec![]; let mut out = vec![];
stream::extend(&mut out, stream).await; stream::extend(&mut out, stream).await;
out out
@ -34,8 +32,6 @@ impl<'b, T: Clone> FromStream<T> for Cow<'b, [T]> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
Cow::Owned(FromStream::from_stream(stream).await) Cow::Owned(FromStream::from_stream(stream).await)
}) })
} }
@ -49,8 +45,6 @@ impl<T> FromStream<T> for Box<[T]> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
Vec::from_stream(stream).await.into_boxed_slice() Vec::from_stream(stream).await.into_boxed_slice()
}) })
} }
@ -64,8 +58,6 @@ impl<T> FromStream<T> for Rc<[T]> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
Vec::from_stream(stream).await.into() Vec::from_stream(stream).await.into()
}) })
} }
@ -79,8 +71,6 @@ impl<T> FromStream<T> for Arc<[T]> {
let stream = stream.into_stream(); let stream = stream.into_stream();
Box::pin(async move { Box::pin(async move {
pin_utils::pin_mut!(stream);
Vec::from_stream(stream).await.into() Vec::from_stream(stream).await.into()
}) })
} }