forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#128791 - compiler-errors:async-fn-unsafe, r…
…=lcnr Don't implement `AsyncFn` for `FnDef`/`FnPtr` that wouldnt implement `Fn` Due to unsafety, ABI, or the presence of target features, some `FnDef`/`FnPtr` types don't implement `Fn*`. Do the same for `AsyncFn*`. Noticed this due to rust-lang#128764, but this isn't really related to that ICE, which is fixed in rust-lang#128792.
- Loading branch information
Showing
4 changed files
with
125 additions
and
23 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
//@ edition: 2021 | ||
|
||
#![feature(async_closure, target_feature_11)] | ||
// `target_feature_11` just to test safe functions w/ target features. | ||
|
||
use std::pin::Pin; | ||
use std::future::Future; | ||
|
||
unsafe extern "Rust" { | ||
pub unsafe fn unsafety() -> Pin<Box<dyn Future<Output = ()> + 'static>>; | ||
} | ||
|
||
unsafe extern "C" { | ||
pub safe fn abi() -> Pin<Box<dyn Future<Output = ()> + 'static>>; | ||
} | ||
|
||
|
||
#[target_feature(enable = "sse2")] | ||
fn target_feature() -> Pin<Box<dyn Future<Output = ()> + 'static>> { todo!() } | ||
|
||
fn test(f: impl async Fn()) {} | ||
|
||
fn main() { | ||
test(unsafety); //~ ERROR the trait bound | ||
test(abi); //~ ERROR the trait bound | ||
test(target_feature); //~ ERROR the trait bound | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
error[E0277]: the trait bound `unsafe fn() -> Pin<Box<(dyn Future<Output = ()> + 'static)>> {unsafety}: AsyncFn<()>` is not satisfied | ||
--> $DIR/fn-exception.rs:24:10 | ||
| | ||
LL | test(unsafety); | ||
| ---- ^^^^^^^^ the trait `AsyncFn<()>` is not implemented for fn item `unsafe fn() -> Pin<Box<(dyn Future<Output = ()> + 'static)>> {unsafety}` | ||
| | | ||
| required by a bound introduced by this call | ||
| | ||
note: required by a bound in `test` | ||
--> $DIR/fn-exception.rs:21:17 | ||
| | ||
LL | fn test(f: impl async Fn()) {} | ||
| ^^^^^^^^^^ required by this bound in `test` | ||
|
||
error[E0277]: the trait bound `extern "C" fn() -> Pin<Box<(dyn Future<Output = ()> + 'static)>> {abi}: AsyncFn<()>` is not satisfied | ||
--> $DIR/fn-exception.rs:25:10 | ||
| | ||
LL | test(abi); | ||
| ---- ^^^ the trait `AsyncFn<()>` is not implemented for fn item `extern "C" fn() -> Pin<Box<(dyn Future<Output = ()> + 'static)>> {abi}` | ||
| | | ||
| required by a bound introduced by this call | ||
| | ||
note: required by a bound in `test` | ||
--> $DIR/fn-exception.rs:21:17 | ||
| | ||
LL | fn test(f: impl async Fn()) {} | ||
| ^^^^^^^^^^ required by this bound in `test` | ||
|
||
error[E0277]: the trait bound `fn() -> Pin<Box<(dyn Future<Output = ()> + 'static)>> {target_feature}: AsyncFn<()>` is not satisfied | ||
--> $DIR/fn-exception.rs:26:10 | ||
| | ||
LL | test(target_feature); | ||
| ---- ^^^^^^^^^^^^^^ the trait `AsyncFn<()>` is not implemented for fn item `fn() -> Pin<Box<(dyn Future<Output = ()> + 'static)>> {target_feature}` | ||
| | | ||
| required by a bound introduced by this call | ||
| | ||
note: required by a bound in `test` | ||
--> $DIR/fn-exception.rs:21:17 | ||
| | ||
LL | fn test(f: impl async Fn()) {} | ||
| ^^^^^^^^^^ required by this bound in `test` | ||
|
||
error: aborting due to 3 previous errors | ||
|
||
For more information about this error, try `rustc --explain E0277`. |