From 9f234d4e45fdd1fcefdf1836f878ae18c0de9833 Mon Sep 17 00:00:00 2001 From: jam1garner <8260240+jam1garner@users.noreply.github.com> Date: Sat, 1 Aug 2020 17:49:12 -0400 Subject: [PATCH] Update improper_ctypes warning to add info about `extern "Rust"` --- src/librustc_lint/types.rs | 3 +++ src/test/ui/issues/issue-14309.stderr | 5 ++++ src/test/ui/issues/issue-16250.stderr | 1 + src/test/ui/lint/lint-ctypes-73249-2.stderr | 1 + src/test/ui/lint/lint-ctypes-73249-3.stderr | 1 + src/test/ui/lint/lint-ctypes-73249-5.stderr | 1 + src/test/ui/lint/lint-ctypes-73251-1.stderr | 1 + src/test/ui/lint/lint-ctypes-73251-2.stderr | 1 + src/test/ui/lint/lint-ctypes-enum.stderr | 9 +++++++ src/test/ui/lint/lint-ctypes-fn.stderr | 17 +++++++++++++ src/test/ui/lint/lint-ctypes.stderr | 24 +++++++++++++++++++ src/test/ui/lint/opaque-ty-ffi-unsafe.stderr | 1 + .../extern_crate_improper.stderr | 5 ++++ src/test/ui/union/union-repr-c.stderr | 1 + 14 files changed, 71 insertions(+) diff --git a/src/librustc_lint/types.rs b/src/librustc_lint/types.rs index de750010ed1e6..a8184706efc62 100644 --- a/src/librustc_lint/types.rs +++ b/src/librustc_lint/types.rs @@ -989,6 +989,9 @@ impl<'a, 'tcx> ImproperCTypesVisitor<'a, 'tcx> { diag.help(help); } diag.note(note); + diag.note( + r#"if intentionally using the unstable Rust ABI, specify it with `extern "Rust"`"#, + ); if let ty::Adt(def, _) = ty.kind { if let Some(sp) = self.cx.tcx.hir().span_if_local(def.did) { diag.span_note(sp, "the type is defined here"); diff --git a/src/test/ui/issues/issue-14309.stderr b/src/test/ui/issues/issue-14309.stderr index 799991f7ee4ba..5120fbbd9d665 100644 --- a/src/test/ui/issues/issue-14309.stderr +++ b/src/test/ui/issues/issue-14309.stderr @@ -11,6 +11,7 @@ LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/issue-14309.rs:4:1 | @@ -27,6 +28,7 @@ LL | fn bar(x: B); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/issue-14309.rs:4:1 | @@ -43,6 +45,7 @@ LL | fn qux(x: A2); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/issue-14309.rs:4:1 | @@ -59,6 +62,7 @@ LL | fn quux(x: B2); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/issue-14309.rs:4:1 | @@ -75,6 +79,7 @@ LL | fn fred(x: D); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/issue-14309.rs:4:1 | diff --git a/src/test/ui/issues/issue-16250.stderr b/src/test/ui/issues/issue-16250.stderr index 45f854f93ecb9..c123ba4409a49 100644 --- a/src/test/ui/issues/issue-16250.stderr +++ b/src/test/ui/issues/issue-16250.stderr @@ -12,6 +12,7 @@ LL | #![deny(warnings)] = note: `#[deny(improper_ctypes)]` implied by `#[deny(warnings)]` = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/issue-16250.rs:3:1 | diff --git a/src/test/ui/lint/lint-ctypes-73249-2.stderr b/src/test/ui/lint/lint-ctypes-73249-2.stderr index 36dbe3217d75a..a415509335d0d 100644 --- a/src/test/ui/lint/lint-ctypes-73249-2.stderr +++ b/src/test/ui/lint/lint-ctypes-73249-2.stderr @@ -10,6 +10,7 @@ note: the lint level is defined here LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = note: opaque types have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to previous error diff --git a/src/test/ui/lint/lint-ctypes-73249-3.stderr b/src/test/ui/lint/lint-ctypes-73249-3.stderr index 7d133287bd73e..814527bca3da9 100644 --- a/src/test/ui/lint/lint-ctypes-73249-3.stderr +++ b/src/test/ui/lint/lint-ctypes-73249-3.stderr @@ -10,6 +10,7 @@ note: the lint level is defined here LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = note: opaque types have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to previous error diff --git a/src/test/ui/lint/lint-ctypes-73249-5.stderr b/src/test/ui/lint/lint-ctypes-73249-5.stderr index d2780cb60e7dd..c32380b0bdd43 100644 --- a/src/test/ui/lint/lint-ctypes-73249-5.stderr +++ b/src/test/ui/lint/lint-ctypes-73249-5.stderr @@ -10,6 +10,7 @@ note: the lint level is defined here LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = note: opaque types have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to previous error diff --git a/src/test/ui/lint/lint-ctypes-73251-1.stderr b/src/test/ui/lint/lint-ctypes-73251-1.stderr index 0b4237bb96fb7..a0d6bfc2e4682 100644 --- a/src/test/ui/lint/lint-ctypes-73251-1.stderr +++ b/src/test/ui/lint/lint-ctypes-73251-1.stderr @@ -10,6 +10,7 @@ note: the lint level is defined here LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = note: opaque types have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to previous error diff --git a/src/test/ui/lint/lint-ctypes-73251-2.stderr b/src/test/ui/lint/lint-ctypes-73251-2.stderr index 43f7629b043a9..954f3277861af 100644 --- a/src/test/ui/lint/lint-ctypes-73251-2.stderr +++ b/src/test/ui/lint/lint-ctypes-73251-2.stderr @@ -10,6 +10,7 @@ note: the lint level is defined here LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = note: opaque types have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to previous error diff --git a/src/test/ui/lint/lint-ctypes-enum.stderr b/src/test/ui/lint/lint-ctypes-enum.stderr index 297ac2237a53f..b6c943727cbc8 100644 --- a/src/test/ui/lint/lint-ctypes-enum.stderr +++ b/src/test/ui/lint/lint-ctypes-enum.stderr @@ -11,6 +11,7 @@ LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes-enum.rs:9:1 | @@ -25,6 +26,7 @@ LL | fn bf(x: B); | = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes-enum.rs:10:1 | @@ -39,6 +41,7 @@ LL | fn tf(x: T); | = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes-enum.rs:11:1 | @@ -53,6 +56,7 @@ LL | fn unique(x: Option>); | = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `u128`, which is not FFI-safe --> $DIR/lint-ctypes-enum.rs:54:23 @@ -61,6 +65,7 @@ LL | fn nonzero_u128(x: Option); | ^^^^^^^^^^^^^^^^^^^^^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `i128`, which is not FFI-safe --> $DIR/lint-ctypes-enum.rs:61:23 @@ -69,6 +74,7 @@ LL | fn nonzero_i128(x: Option); | ^^^^^^^^^^^^^^^^^^^^^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `std::option::Option>`, which is not FFI-safe --> $DIR/lint-ctypes-enum.rs:66:28 @@ -78,6 +84,7 @@ LL | fn transparent_union(x: Option>); | = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `std::option::Option>`, which is not FFI-safe --> $DIR/lint-ctypes-enum.rs:68:20 @@ -87,6 +94,7 @@ LL | fn repr_rust(x: Option>); | = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `std::result::Result<(), std::num::NonZeroI32>`, which is not FFI-safe --> $DIR/lint-ctypes-enum.rs:69:20 @@ -96,6 +104,7 @@ LL | fn no_result(x: Result<(), num::NonZeroI32>); | = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to 9 previous errors diff --git a/src/test/ui/lint/lint-ctypes-fn.stderr b/src/test/ui/lint/lint-ctypes-fn.stderr index d0a449514e50e..c8f4941420392 100644 --- a/src/test/ui/lint/lint-ctypes-fn.stderr +++ b/src/test/ui/lint/lint-ctypes-fn.stderr @@ -11,6 +11,7 @@ LL | #![deny(improper_ctypes_definitions)] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ = help: consider using a raw pointer instead = note: slices have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `str`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:70:31 @@ -20,6 +21,7 @@ LL | pub extern "C" fn str_type(p: &str) { } | = help: consider using `*const u8` and a length instead = note: string slices have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `char`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:77:32 @@ -29,6 +31,7 @@ LL | pub extern "C" fn char_type(p: char) { } | = help: consider using `u32` or `libc::wchar_t` instead = note: the `char` type has no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `i128`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:80:32 @@ -37,6 +40,7 @@ LL | pub extern "C" fn i128_type(p: i128) { } | ^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `u128`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:83:32 @@ -45,6 +49,7 @@ LL | pub extern "C" fn u128_type(p: u128) { } | ^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `(i32, i32)`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:86:33 @@ -54,6 +59,7 @@ LL | pub extern "C" fn tuple_type(p: (i32, i32)) { } | = help: consider using a struct instead = note: tuples have unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `(i32, i32)`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:89:34 @@ -63,6 +69,7 @@ LL | pub extern "C" fn tuple_type2(p: I32Pair) { } | = help: consider using a struct instead = note: tuples have unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `ZeroSize`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:92:32 @@ -72,6 +79,7 @@ LL | pub extern "C" fn zero_size(p: ZeroSize) { } | = help: consider adding a member to this struct = note: this struct has no fields + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes-fn.rs:26:1 | @@ -85,6 +93,7 @@ LL | pub extern "C" fn zero_size_phantom(p: ZeroSizeWithPhantomData) { } | ^^^^^^^^^^^^^^^^^^^^^^^ not FFI-safe | = note: composed only of `PhantomData` + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes-fn.rs:61:1 | @@ -98,6 +107,7 @@ LL | pub extern "C" fn zero_size_phantom_toplevel() -> PhantomData { | ^^^^^^^^^^^^^^^^^ not FFI-safe | = note: composed only of `PhantomData` + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `fn()`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:103:30 @@ -107,6 +117,7 @@ LL | pub extern "C" fn fn_type(p: RustFn) { } | = help: consider using an `extern fn(...) -> ...` function pointer instead = note: this function pointer has Rust-specific calling convention + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `fn()`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:106:31 @@ -116,6 +127,7 @@ LL | pub extern "C" fn fn_type2(p: fn()) { } | = help: consider using an `extern fn(...) -> ...` function pointer instead = note: this function pointer has Rust-specific calling convention + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `i128`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:111:39 @@ -124,6 +136,7 @@ LL | pub extern "C" fn transparent_i128(p: TransparentI128) { } | ^^^^^^^^^^^^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `str`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:114:38 @@ -133,6 +146,7 @@ LL | pub extern "C" fn transparent_str(p: TransparentStr) { } | = help: consider using `*const u8` and a length instead = note: string slices have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `std::marker::PhantomData`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:160:43 @@ -141,6 +155,7 @@ LL | pub extern "C" fn unused_generic2() -> PhantomData { | ^^^^^^^^^^^^^^^^^ not FFI-safe | = note: composed only of `PhantomData` + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `std::vec::Vec`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:173:39 @@ -150,6 +165,7 @@ LL | pub extern "C" fn used_generic4(x: Vec) { } | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` fn uses type `std::vec::Vec`, which is not FFI-safe --> $DIR/lint-ctypes-fn.rs:176:41 @@ -159,6 +175,7 @@ LL | pub extern "C" fn used_generic5() -> Vec { | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to 17 previous errors diff --git a/src/test/ui/lint/lint-ctypes.stderr b/src/test/ui/lint/lint-ctypes.stderr index a54226a7fc4a2..bd7324abd6fe8 100644 --- a/src/test/ui/lint/lint-ctypes.stderr +++ b/src/test/ui/lint/lint-ctypes.stderr @@ -11,6 +11,7 @@ LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes.rs:25:1 | @@ -25,6 +26,7 @@ LL | pub fn ptr_type2(size: *const Foo); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes.rs:25:1 | @@ -39,6 +41,7 @@ LL | pub fn slice_type(p: &[u32]); | = help: consider using a raw pointer instead = note: slices have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `str`, which is not FFI-safe --> $DIR/lint-ctypes.rs:50:24 @@ -48,6 +51,7 @@ LL | pub fn str_type(p: &str); | = help: consider using `*const u8` and a length instead = note: string slices have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `std::boxed::Box`, which is not FFI-safe --> $DIR/lint-ctypes.rs:51:24 @@ -57,6 +61,7 @@ LL | pub fn box_type(p: Box); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `std::option::Option>`, which is not FFI-safe --> $DIR/lint-ctypes.rs:52:28 @@ -66,6 +71,7 @@ LL | pub fn opt_box_type(p: Option>); | = help: consider adding a `#[repr(C)]`, `#[repr(transparent)]`, or integer `#[repr(...)]` attribute to this enum = note: enum has no representation hint + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `char`, which is not FFI-safe --> $DIR/lint-ctypes.rs:54:25 @@ -75,6 +81,7 @@ LL | pub fn char_type(p: char); | = help: consider using `u32` or `libc::wchar_t` instead = note: the `char` type has no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `i128`, which is not FFI-safe --> $DIR/lint-ctypes.rs:55:25 @@ -83,6 +90,7 @@ LL | pub fn i128_type(p: i128); | ^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `u128`, which is not FFI-safe --> $DIR/lint-ctypes.rs:56:25 @@ -91,6 +99,7 @@ LL | pub fn u128_type(p: u128); | ^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `dyn Bar`, which is not FFI-safe --> $DIR/lint-ctypes.rs:57:26 @@ -99,6 +108,7 @@ LL | pub fn trait_type(p: &dyn Bar); | ^^^^^^^^ not FFI-safe | = note: trait objects have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `(i32, i32)`, which is not FFI-safe --> $DIR/lint-ctypes.rs:58:26 @@ -108,6 +118,7 @@ LL | pub fn tuple_type(p: (i32, i32)); | = help: consider using a struct instead = note: tuples have unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `(i32, i32)`, which is not FFI-safe --> $DIR/lint-ctypes.rs:59:27 @@ -117,6 +128,7 @@ LL | pub fn tuple_type2(p: I32Pair); | = help: consider using a struct instead = note: tuples have unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `ZeroSize`, which is not FFI-safe --> $DIR/lint-ctypes.rs:60:25 @@ -126,6 +138,7 @@ LL | pub fn zero_size(p: ZeroSize); | = help: consider adding a member to this struct = note: this struct has no fields + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes.rs:21:1 | @@ -139,6 +152,7 @@ LL | pub fn zero_size_phantom(p: ZeroSizeWithPhantomData); | ^^^^^^^^^^^^^^^^^^^^^^^ not FFI-safe | = note: composed only of `PhantomData` + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/lint-ctypes.rs:44:1 | @@ -152,6 +166,7 @@ LL | -> ::std::marker::PhantomData; | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ not FFI-safe | = note: composed only of `PhantomData` + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `fn()`, which is not FFI-safe --> $DIR/lint-ctypes.rs:65:23 @@ -161,6 +176,7 @@ LL | pub fn fn_type(p: RustFn); | = help: consider using an `extern fn(...) -> ...` function pointer instead = note: this function pointer has Rust-specific calling convention + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `fn()`, which is not FFI-safe --> $DIR/lint-ctypes.rs:66:24 @@ -170,6 +186,7 @@ LL | pub fn fn_type2(p: fn()); | = help: consider using an `extern fn(...) -> ...` function pointer instead = note: this function pointer has Rust-specific calling convention + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `std::boxed::Box`, which is not FFI-safe --> $DIR/lint-ctypes.rs:67:28 @@ -179,6 +196,7 @@ LL | pub fn fn_contained(p: RustBadRet); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `i128`, which is not FFI-safe --> $DIR/lint-ctypes.rs:68:32 @@ -187,6 +205,7 @@ LL | pub fn transparent_i128(p: TransparentI128); | ^^^^^^^^^^^^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `str`, which is not FFI-safe --> $DIR/lint-ctypes.rs:69:31 @@ -196,6 +215,7 @@ LL | pub fn transparent_str(p: TransparentStr); | = help: consider using `*const u8` and a length instead = note: string slices have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `std::boxed::Box`, which is not FFI-safe --> $DIR/lint-ctypes.rs:70:30 @@ -205,6 +225,7 @@ LL | pub fn transparent_fn(p: TransparentBadFn); | = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this struct = note: this struct has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `[u8; 8]`, which is not FFI-safe --> $DIR/lint-ctypes.rs:71:27 @@ -214,6 +235,7 @@ LL | pub fn raw_array(arr: [u8; 8]); | = help: consider passing a pointer to the array = note: passing raw arrays by value is not FFI-safe + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `u128`, which is not FFI-safe --> $DIR/lint-ctypes.rs:73:34 @@ -222,6 +244,7 @@ LL | pub static static_u128_type: u128; | ^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `u128`, which is not FFI-safe --> $DIR/lint-ctypes.rs:74:40 @@ -230,6 +253,7 @@ LL | pub static static_u128_array_type: [u128; 16]; | ^^^^^^^^^^ not FFI-safe | = note: 128-bit integers don't currently have a known stable ABI + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to 24 previous errors diff --git a/src/test/ui/lint/opaque-ty-ffi-unsafe.stderr b/src/test/ui/lint/opaque-ty-ffi-unsafe.stderr index 06dfb7b8fbeca..0e31cb6f4d560 100644 --- a/src/test/ui/lint/opaque-ty-ffi-unsafe.stderr +++ b/src/test/ui/lint/opaque-ty-ffi-unsafe.stderr @@ -10,6 +10,7 @@ note: the lint level is defined here LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = note: opaque types have no C equivalent + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to previous error diff --git a/src/test/ui/rfc-2008-non-exhaustive/improper_ctypes/extern_crate_improper.stderr b/src/test/ui/rfc-2008-non-exhaustive/improper_ctypes/extern_crate_improper.stderr index 4956226712d04..b2547ade66718 100644 --- a/src/test/ui/rfc-2008-non-exhaustive/improper_ctypes/extern_crate_improper.stderr +++ b/src/test/ui/rfc-2008-non-exhaustive/improper_ctypes/extern_crate_improper.stderr @@ -10,6 +10,7 @@ note: the lint level is defined here LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = note: this enum is non-exhaustive + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `types::NormalStruct`, which is not FFI-safe --> $DIR/extern_crate_improper.rs:14:44 @@ -18,6 +19,7 @@ LL | pub fn non_exhaustive_normal_struct(_: NormalStruct); | ^^^^^^^^^^^^ not FFI-safe | = note: this struct is non-exhaustive + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `types::UnitStruct`, which is not FFI-safe --> $DIR/extern_crate_improper.rs:16:42 @@ -26,6 +28,7 @@ LL | pub fn non_exhaustive_unit_struct(_: UnitStruct); | ^^^^^^^^^^ not FFI-safe | = note: this struct is non-exhaustive + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `types::TupleStruct`, which is not FFI-safe --> $DIR/extern_crate_improper.rs:18:43 @@ -34,6 +37,7 @@ LL | pub fn non_exhaustive_tuple_struct(_: TupleStruct); | ^^^^^^^^^^^ not FFI-safe | = note: this struct is non-exhaustive + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: `extern` block uses type `types::NonExhaustiveVariants`, which is not FFI-safe --> $DIR/extern_crate_improper.rs:20:38 @@ -42,6 +46,7 @@ LL | pub fn non_exhaustive_variant(_: NonExhaustiveVariants); | ^^^^^^^^^^^^^^^^^^^^^ not FFI-safe | = note: this enum has non-exhaustive variants + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` error: aborting due to 5 previous errors diff --git a/src/test/ui/union/union-repr-c.stderr b/src/test/ui/union/union-repr-c.stderr index ae84cc7811bb3..aae3ee42147d9 100644 --- a/src/test/ui/union/union-repr-c.stderr +++ b/src/test/ui/union/union-repr-c.stderr @@ -11,6 +11,7 @@ LL | #![deny(improper_ctypes)] | ^^^^^^^^^^^^^^^ = help: consider adding a `#[repr(C)]` or `#[repr(transparent)]` attribute to this union = note: this union has unspecified layout + = note: if intentionally using the unstable Rust ABI, specify it with `extern "Rust"` note: the type is defined here --> $DIR/union-repr-c.rs:9:1 |