summaryrefslogtreecommitdiffstats
path: root/third_party/rust/tokio-io/src/io/shutdown.rs
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/rust/tokio-io/src/io/shutdown.rs')
-rw-r--r--third_party/rust/tokio-io/src/io/shutdown.rs44
1 files changed, 44 insertions, 0 deletions
diff --git a/third_party/rust/tokio-io/src/io/shutdown.rs b/third_party/rust/tokio-io/src/io/shutdown.rs
new file mode 100644
index 0000000000..d963a813ad
--- /dev/null
+++ b/third_party/rust/tokio-io/src/io/shutdown.rs
@@ -0,0 +1,44 @@
+use std::io;
+
+use futures::{Async, Future, Poll};
+
+use AsyncWrite;
+
+/// A future used to fully shutdown an I/O object.
+///
+/// Resolves to the underlying I/O object once the shutdown operation is
+/// complete.
+///
+/// Created by the [`shutdown`] function.
+///
+/// [`shutdown`]: fn.shutdown.html
+#[derive(Debug)]
+pub struct Shutdown<A> {
+ a: Option<A>,
+}
+
+/// Creates a future which will entirely shutdown an I/O object and then yield
+/// the object itself.
+///
+/// This function will consume the object provided if an error happens, and
+/// otherwise it will repeatedly call `shutdown` until it sees `Ok(())`,
+/// scheduling a retry if `WouldBlock` is seen along the way.
+pub fn shutdown<A>(a: A) -> Shutdown<A>
+where
+ A: AsyncWrite,
+{
+ Shutdown { a: Some(a) }
+}
+
+impl<A> Future for Shutdown<A>
+where
+ A: AsyncWrite,
+{
+ type Item = A;
+ type Error = io::Error;
+
+ fn poll(&mut self) -> Poll<A, io::Error> {
+ try_ready!(self.a.as_mut().unwrap().shutdown());
+ Ok(Async::Ready(self.a.take().unwrap()))
+ }
+}