2022-12-11 02:49:07 -05:00
|
|
|
error[E0308]: `if` and `else` have incompatible types
|
|
|
|
--> $DIR/fn-pointer-mismatch.rs:11:43
|
|
|
|
|
|
|
|
|
LL | let g = if n % 2 == 0 { &foo } else { &bar };
|
2023-01-02 18:00:33 -08:00
|
|
|
| ---- ^^^^ expected `&fn(u32) -> u32 {foo}`, found `&fn(u32) -> u32 {bar}`
|
2022-12-11 02:49:07 -05:00
|
|
|
| |
|
|
|
|
| expected because of this
|
|
|
|
|
|
|
|
|
= note: expected reference `&fn(u32) -> u32 {foo}`
|
|
|
|
found reference `&fn(u32) -> u32 {bar}`
|
|
|
|
= note: different fn items have unique types, even if their signatures are the same
|
2023-01-25 17:10:26 +00:00
|
|
|
= help: consider casting both fn items to fn pointers using `as fn(u32) -> u32`
|
2022-12-11 02:49:07 -05:00
|
|
|
|
|
|
|
error[E0308]: mismatched types
|
|
|
|
--> $DIR/fn-pointer-mismatch.rs:23:9
|
|
|
|
|
|
|
|
|
LL | let mut a = foo;
|
|
|
|
| --- expected due to this value
|
|
|
|
LL | a = bar;
|
|
|
|
| ^^^ expected fn item, found a different fn item
|
|
|
|
|
|
|
|
|
= note: expected fn item `fn(_) -> _ {foo}`
|
|
|
|
found fn item `fn(_) -> _ {bar}`
|
|
|
|
= note: different fn items have unique types, even if their signatures are the same
|
2023-01-25 17:10:26 +00:00
|
|
|
= help: consider casting both fn items to fn pointers using `as fn(u32) -> u32`
|
2022-12-11 02:49:07 -05:00
|
|
|
|
|
|
|
error[E0308]: mismatched types
|
|
|
|
--> $DIR/fn-pointer-mismatch.rs:31:18
|
|
|
|
|
|
|
|
|
LL | b = Box::new(bar);
|
|
|
|
| -------- ^^^ expected fn item, found a different fn item
|
|
|
|
| |
|
|
|
|
| arguments to this function are incorrect
|
|
|
|
|
|
|
|
|
= note: expected fn item `fn(_) -> _ {foo}`
|
|
|
|
found fn item `fn(_) -> _ {bar}`
|
|
|
|
= note: different fn items have unique types, even if their signatures are the same
|
|
|
|
note: associated function defined here
|
|
|
|
--> $SRC_DIR/alloc/src/boxed.rs:LL:COL
|
2023-01-25 17:10:26 +00:00
|
|
|
= help: consider casting both fn items to fn pointers using `as fn(u32) -> u32`
|
2022-12-11 02:49:07 -05:00
|
|
|
|
|
|
|
error[E0308]: mismatched types
|
|
|
|
--> $DIR/fn-pointer-mismatch.rs:36:29
|
|
|
|
|
|
|
|
|
LL | let c: fn(u32) -> u32 = &foo;
|
2023-01-30 21:55:25 +00:00
|
|
|
| -------------- ^^^^ expected fn pointer, found `&fn(u32) -> u32 {foo}`
|
|
|
|
| |
|
2022-12-11 02:49:07 -05:00
|
|
|
| expected due to this
|
|
|
|
|
|
|
|
|
= note: expected fn pointer `fn(u32) -> u32`
|
|
|
|
found reference `&fn(u32) -> u32 {foo}`
|
2023-01-30 21:55:25 +00:00
|
|
|
help: consider removing the reference
|
|
|
|
|
|
|
|
|
LL | let c: fn(u32) -> u32 = foo;
|
|
|
|
| ~~~
|
2022-12-11 02:49:07 -05:00
|
|
|
|
|
|
|
error[E0308]: mismatched types
|
|
|
|
--> $DIR/fn-pointer-mismatch.rs:42:30
|
|
|
|
|
|
|
|
|
LL | let d: &fn(u32) -> u32 = foo;
|
2023-01-30 21:55:25 +00:00
|
|
|
| --------------- ^^^ expected `&fn(u32) -> u32`, found fn item
|
|
|
|
| |
|
2022-12-11 02:49:07 -05:00
|
|
|
| expected due to this
|
|
|
|
|
|
|
|
|
= note: expected reference `&fn(u32) -> u32`
|
|
|
|
found fn item `fn(u32) -> u32 {foo}`
|
2023-01-30 21:55:25 +00:00
|
|
|
help: consider using a reference
|
|
|
|
|
|
|
|
|
LL | let d: &fn(u32) -> u32 = &foo;
|
|
|
|
| ~~~~
|
2022-12-11 02:49:07 -05:00
|
|
|
|
|
|
|
error[E0308]: mismatched types
|
|
|
|
--> $DIR/fn-pointer-mismatch.rs:48:30
|
|
|
|
|
|
|
|
|
LL | let e: &fn(u32) -> u32 = &foo;
|
2023-01-30 21:55:25 +00:00
|
|
|
| --------------- ^^^^ expected `&fn(u32) -> u32`, found `&fn(u32) -> u32 {foo}`
|
|
|
|
| |
|
2022-12-11 02:49:07 -05:00
|
|
|
| expected due to this
|
|
|
|
|
|
|
|
|
= note: expected reference `&fn(u32) -> u32`
|
|
|
|
found reference `&fn(u32) -> u32 {foo}`
|
|
|
|
= note: fn items are distinct from fn pointers
|
2023-01-06 20:15:10 +00:00
|
|
|
= note: when the arguments and return types match, functions can be coerced to function pointers
|
2023-01-30 21:55:25 +00:00
|
|
|
help: consider casting to a fn pointer
|
|
|
|
|
|
|
|
|
LL | let e: &fn(u32) -> u32 = &(foo as fn(u32) -> u32);
|
|
|
|
| ~~~~~~~~~~~~~~~~~~~~~~~~
|
2022-12-11 02:49:07 -05:00
|
|
|
|
|
|
|
error: aborting due to 6 previous errors
|
|
|
|
|
|
|
|
For more information about this error, try `rustc --explain E0308`.
|