about summary refs log tree commit diff
path: root/src/liballoc
diff options
context:
space:
mode:
authorWim Looman <wim@nemo157.com>2018-10-04 20:49:38 +0200
committerWim Looman <wim@nemo157.com>2019-01-27 22:58:53 +0100
commita3fdee9a7523a72a5ee72cdb4c1cf3c2cec444bc (patch)
tree127e574840d4994b33fcfc41a1b452bf5976829c /src/liballoc
parent8611577360e66f90470bd40c498cf8d194f67926 (diff)
downloadrust-a3fdee9a7523a72a5ee72cdb4c1cf3c2cec444bc.tar.gz
rust-a3fdee9a7523a72a5ee72cdb4c1cf3c2cec444bc.zip
Change generator trait to use pinning
Diffstat (limited to 'src/liballoc')
-rw-r--r--src/liballoc/boxed.rs13
1 files changed, 6 insertions, 7 deletions
diff --git a/src/liballoc/boxed.rs b/src/liballoc/boxed.rs
index 1c459f5c425..1fd8aa98cc3 100644
--- a/src/liballoc/boxed.rs
+++ b/src/liballoc/boxed.rs
@@ -873,13 +873,12 @@ impl<T: ?Sized> AsMut<T> for Box<T> {
 impl<T: ?Sized> Unpin for Box<T> { }
 
 #[unstable(feature = "generator_trait", issue = "43122")]
-impl<T> Generator for Box<T>
-    where T: Generator + ?Sized
-{
-    type Yield = T::Yield;
-    type Return = T::Return;
-    unsafe fn resume(&mut self) -> GeneratorState<Self::Yield, Self::Return> {
-        (**self).resume()
+impl<G: ?Sized + Generator + Unpin> Generator for Box<G> {
+    type Yield = G::Yield;
+    type Return = G::Return;
+
+    fn resume(mut self: Pin<&mut Self>) -> GeneratorState<Self::Yield, Self::Return> {
+        G::resume(Pin::new(&mut *self))
     }
 }