1
Fork 0

bless the tests and add a new one

This commit is contained in:
Orion Gonzalez 2024-11-27 15:37:27 +01:00
parent b36dcc1a38
commit 1e4817cd33
7 changed files with 51 additions and 9 deletions

View file

@ -800,6 +800,8 @@ pub(crate) struct PassToVariadicFunction<'a, 'tcx> {
#[derive(Diagnostic)] #[derive(Diagnostic)]
#[diag(hir_typeck_fn_item_to_variadic_function, code = E0617)] #[diag(hir_typeck_fn_item_to_variadic_function, code = E0617)]
#[help]
#[note]
pub(crate) struct PassFnItemToVariadicFunction { pub(crate) struct PassFnItemToVariadicFunction {
#[primary_span] #[primary_span]
pub span: Span, pub span: Span,

View file

@ -0,0 +1,13 @@
// https://github.com/rust-lang/rust/issues/69232
extern "C" {
fn foo(x: usize, ...);
}
fn test() -> u8 {
127
}
fn main() {
unsafe { foo(1, test) }; //~ ERROR can't pass a function item to a variadic function
}

View file

@ -0,0 +1,16 @@
error[E0617]: can't pass a function item to a variadic function
--> $DIR/fn-item-diagnostic-issue-69232.rs:12:21
|
LL | unsafe { foo(1, test) };
| ^^^^
|
= help: a function item is zero-sized and needs to be cast into a function pointer to be used in FFI
= note: for more information on function items, visit https://doc.rust-lang.org/reference/types/function-item.html
help: use a function pointer instead
|
LL | unsafe { foo(1, test as fn() -> u8) };
| +++++++++++++
error: aborting due to 1 previous error
For more information about this error, try `rustc --explain E0617`.

View file

@ -7,7 +7,8 @@ fn bar(_: *const u8) {}
fn main() { fn main() {
unsafe { unsafe {
foo(0, bar); foo(0, bar);
//~^ ERROR can't pass `fn(*const u8) {bar}` to variadic function //~^ ERROR can't pass a function item to a variadic function
//~| HELP cast the value to `fn(*const u8)` //~| HELP a function item is zero-sized and needs to be cast into a function pointer to be used in FFI
////~| HELP use a function pointer instead
} }
} }

View file

@ -1,8 +1,15 @@
error[E0617]: can't pass `fn(*const u8) {bar}` to variadic function error[E0617]: can't pass a function item to a variadic function
--> $DIR/issue-32201.rs:9:16 --> $DIR/issue-32201.rs:9:16
| |
LL | foo(0, bar); LL | foo(0, bar);
| ^^^ help: cast the value to `fn(*const u8)`: `bar as fn(*const u8)` | ^^^
|
= help: a function item is zero-sized and needs to be cast into a function pointer to be used in FFI
= note: for more information on function items, visit https://doc.rust-lang.org/reference/types/function-item.html
help: use a function pointer instead
|
LL | foo(0, bar as fn(*const u8));
| ++++++++++++++++
error: aborting due to 1 previous error error: aborting due to 1 previous error

View file

@ -20,7 +20,8 @@ fn main() {
//~^ ERROR can't pass `u16` to variadic function //~^ ERROR can't pass `u16` to variadic function
//~| HELP cast the value to `c_uint` //~| HELP cast the value to `c_uint`
printf(::std::ptr::null(), printf); printf(::std::ptr::null(), printf);
//~^ ERROR can't pass `unsafe extern "C" fn(*const i8, ...) {printf}` to variadic function //~^ ERROR can't pass a function item to a variadic function
//~| HELP cast the value to `unsafe extern "C" fn(*const i8, ...)` //~| HELP a function item is zero-sized and needs to be cast into a function pointer to be used in FFI
//~| HELP use a function pointer instead
} }
} }

View file

@ -28,16 +28,18 @@ error[E0617]: can't pass `u16` to variadic function
LL | printf(::std::ptr::null(), 0u16); LL | printf(::std::ptr::null(), 0u16);
| ^^^^ help: cast the value to `c_uint`: `0u16 as c_uint` | ^^^^ help: cast the value to `c_uint`: `0u16 as c_uint`
error[E0617]: can't pass `unsafe extern "C" fn(*const i8, ...) {printf}` to variadic function error[E0617]: can't pass a function item to a variadic function
--> $DIR/E0617.rs:22:36 --> $DIR/E0617.rs:22:36
| |
LL | printf(::std::ptr::null(), printf); LL | printf(::std::ptr::null(), printf);
| ^^^^^^ | ^^^^^^
| |
help: cast the value to `unsafe extern "C" fn(*const i8, ...)` = help: a function item is zero-sized and needs to be cast into a function pointer to be used in FFI
= note: for more information on function items, visit https://doc.rust-lang.org/reference/types/function-item.html
help: use a function pointer instead
| |
LL | printf(::std::ptr::null(), printf as unsafe extern "C" fn(*const i8, ...)); LL | printf(::std::ptr::null(), printf as unsafe extern "C" fn(*const i8, ...));
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | +++++++++++++++++++++++++++++++++++++++
error: aborting due to 6 previous errors error: aborting due to 6 previous errors