Skip to content

Commit e5f1a29

Browse files
committed
Auto merge of #1257 - RalfJung:rustup, r=RalfJung
Rustup
2 parents db49339 + 9091811 commit e5f1a29

File tree

3 files changed

+13
-23
lines changed

3 files changed

+13
-23
lines changed

rust-version

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
8ff785011be6625e32afceee3a08e5cff7470feb
1+
1edd389cc4c7b5be7a3dd4fe4b986f6017018e54

src/stacked_borrows.rs

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -194,11 +194,10 @@ impl GlobalState {
194194

195195
/// Error reporting
196196
fn err_sb_ub(msg: String) -> InterpError<'static> {
197-
// FIXME: use `err_machine_stop!` macro, once that exists.
198-
InterpError::MachineStop(Box::new(TerminationInfo::ExperimentalUb {
197+
err_machine_stop!(TerminationInfo::ExperimentalUb {
199198
msg,
200199
url: format!("https://github.com/rust-lang/unsafe-code-guidelines/blob/master/wip/stacked-borrows.md"),
201-
}))
200+
})
202201
}
203202

204203
// # Stacked Borrows Core Begin

tests/run-pass/async-fn.rs

Lines changed: 10 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,9 @@
11
#![feature(never_type)]
2+
#![feature(wake_trait)]
23

3-
use std::{future::Future, pin::Pin, task::Poll, ptr};
4-
use std::task::{Waker, RawWaker, RawWakerVTable, Context};
4+
use std::{future::Future, pin::Pin, task::Poll};
5+
use std::task::{Wake, Waker, Context};
6+
use std::sync::Arc;
57

68
// See if we can run a basic `async fn`
79
pub async fn foo(x: &u32, y: u32) -> u32 {
@@ -47,25 +49,14 @@ async fn partial_init(x: u32) -> u32 {
4749
}
4850

4951
fn run_fut(mut fut: impl Future<Output=u32>, output: u32) {
50-
fn raw_waker_clone(_this: *const ()) -> RawWaker {
51-
panic!("unimplemented");
52+
struct MyWaker;
53+
impl Wake for MyWaker {
54+
fn wake(self: Arc<Self>) {
55+
unimplemented!()
56+
}
5257
}
53-
fn raw_waker_wake(_this: *const ()) {
54-
panic!("unimplemented");
55-
}
56-
fn raw_waker_wake_by_ref(_this: *const ()) {
57-
panic!("unimplemented");
58-
}
59-
fn raw_waker_drop(_this: *const ()) {}
60-
61-
static RAW_WAKER: RawWakerVTable = RawWakerVTable::new(
62-
raw_waker_clone,
63-
raw_waker_wake,
64-
raw_waker_wake_by_ref,
65-
raw_waker_drop,
66-
);
6758

68-
let waker = unsafe { Waker::from_raw(RawWaker::new(ptr::null(), &RAW_WAKER)) };
59+
let waker = Waker::from(Arc::new(MyWaker));
6960
let mut context = Context::from_waker(&waker);
7061
assert_eq!(unsafe { Pin::new_unchecked(&mut fut) }.poll(&mut context), Poll::Ready(output));
7162
}

0 commit comments

Comments
 (0)