Auto merge of #119263 - matthiaskrgr:rollup-zxok9fb, r=matthiaskrgr
Rollup of 5 pull requests Successful merges: - #112936 (Add illumos aarch64 target for rust.) - #119153 (stabilize `file_create_new`) - #119246 ([rustdoc] Add `is_object_safe` information for traits in JSON output) - #119254 (Remove an unused diagnostic struct) - #119255 (add a test for ICE #112822) r? `@ghost` `@rustbot` modify labels: rollup
This commit is contained in:
commit
2d7be73931
@ -628,11 +628,3 @@ fn try_fold_const(&mut self, c: Const<'tcx>) -> Result<Const<'tcx>, ()> {
|
|||||||
c.try_super_fold_with(self)
|
c.try_super_fold_with(self)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Diagnostic)]
|
|
||||||
#[diag(middle_const_not_used_in_type_alias)]
|
|
||||||
pub(super) struct ConstNotUsedTraitAlias {
|
|
||||||
pub ct: String,
|
|
||||||
#[primary_span]
|
|
||||||
pub span: Span,
|
|
||||||
}
|
|
||||||
|
@ -1591,6 +1591,7 @@ fn $module() {
|
|||||||
("sparcv9-sun-solaris", sparcv9_sun_solaris),
|
("sparcv9-sun-solaris", sparcv9_sun_solaris),
|
||||||
|
|
||||||
("x86_64-unknown-illumos", x86_64_unknown_illumos),
|
("x86_64-unknown-illumos", x86_64_unknown_illumos),
|
||||||
|
("aarch64-unknown-illumos", aarch64_unknown_illumos),
|
||||||
|
|
||||||
("x86_64-pc-windows-gnu", x86_64_pc_windows_gnu),
|
("x86_64-pc-windows-gnu", x86_64_pc_windows_gnu),
|
||||||
("i686-pc-windows-gnu", i686_pc_windows_gnu),
|
("i686-pc-windows-gnu", i686_pc_windows_gnu),
|
||||||
|
@ -0,0 +1,19 @@
|
|||||||
|
use crate::spec::{base, Cc, LinkerFlavor, SanitizerSet, Target};
|
||||||
|
|
||||||
|
pub fn target() -> Target {
|
||||||
|
let mut base = base::illumos::opts();
|
||||||
|
base.add_pre_link_args(LinkerFlavor::Unix(Cc::Yes), &["-std=c99"]);
|
||||||
|
base.max_atomic_width = Some(128);
|
||||||
|
base.supported_sanitizers = SanitizerSet::ADDRESS | SanitizerSet::CFI;
|
||||||
|
base.features = "+v8a".into();
|
||||||
|
|
||||||
|
Target {
|
||||||
|
// LLVM does not currently have a separate illumos target,
|
||||||
|
// so we still pass Solaris to it
|
||||||
|
llvm_target: "aarch64-unknown-solaris2.11".into(),
|
||||||
|
pointer_width: 64,
|
||||||
|
data_layout: "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128".into(),
|
||||||
|
arch: "aarch64".into(),
|
||||||
|
options: base,
|
||||||
|
}
|
||||||
|
}
|
@ -411,8 +411,6 @@ pub fn create<P: AsRef<Path>>(path: P) -> io::Result<File> {
|
|||||||
/// # Examples
|
/// # Examples
|
||||||
///
|
///
|
||||||
/// ```no_run
|
/// ```no_run
|
||||||
/// #![feature(file_create_new)]
|
|
||||||
///
|
|
||||||
/// use std::fs::File;
|
/// use std::fs::File;
|
||||||
/// use std::io::Write;
|
/// use std::io::Write;
|
||||||
///
|
///
|
||||||
@ -422,7 +420,7 @@ pub fn create<P: AsRef<Path>>(path: P) -> io::Result<File> {
|
|||||||
/// Ok(())
|
/// Ok(())
|
||||||
/// }
|
/// }
|
||||||
/// ```
|
/// ```
|
||||||
#[unstable(feature = "file_create_new", issue = "105135")]
|
#[stable(feature = "file_create_new", since = "CURRENT_RUSTC_VERSION")]
|
||||||
pub fn create_new<P: AsRef<Path>>(path: P) -> io::Result<File> {
|
pub fn create_new<P: AsRef<Path>>(path: P) -> io::Result<File> {
|
||||||
OpenOptions::new().read(true).write(true).create_new(true).open(path.as_ref())
|
OpenOptions::new().read(true).write(true).create_new(true).open(path.as_ref())
|
||||||
}
|
}
|
||||||
|
@ -230,6 +230,7 @@ target | std | host | notes
|
|||||||
[`aarch64-unknown-nto-qnx710`](platform-support/nto-qnx.md) | ✓ | | ARM64 QNX Neutrino 7.1 RTOS |
|
[`aarch64-unknown-nto-qnx710`](platform-support/nto-qnx.md) | ✓ | | ARM64 QNX Neutrino 7.1 RTOS |
|
||||||
`aarch64-unknown-freebsd` | ✓ | ✓ | ARM64 FreeBSD
|
`aarch64-unknown-freebsd` | ✓ | ✓ | ARM64 FreeBSD
|
||||||
[`aarch64-unknown-hermit`](platform-support/hermit.md) | ✓ | | ARM64 Hermit
|
[`aarch64-unknown-hermit`](platform-support/hermit.md) | ✓ | | ARM64 Hermit
|
||||||
|
`aarch64-unknown-illumos` | ✓ | ✓ | ARM64 illumos
|
||||||
`aarch64-unknown-linux-gnu_ilp32` | ✓ | ✓ | ARM64 Linux (ILP32 ABI)
|
`aarch64-unknown-linux-gnu_ilp32` | ✓ | ✓ | ARM64 Linux (ILP32 ABI)
|
||||||
[`aarch64-unknown-netbsd`](platform-support/netbsd.md) | ✓ | ✓ | ARM64 NetBSD
|
[`aarch64-unknown-netbsd`](platform-support/netbsd.md) | ✓ | ✓ | ARM64 NetBSD
|
||||||
[`aarch64-unknown-openbsd`](platform-support/openbsd.md) | ✓ | ✓ | ARM64 OpenBSD
|
[`aarch64-unknown-openbsd`](platform-support/openbsd.md) | ✓ | ✓ | ARM64 OpenBSD
|
||||||
|
@ -648,10 +648,12 @@ impl FromWithTcx<clean::Trait> for Trait {
|
|||||||
fn from_tcx(trait_: clean::Trait, tcx: TyCtxt<'_>) -> Self {
|
fn from_tcx(trait_: clean::Trait, tcx: TyCtxt<'_>) -> Self {
|
||||||
let is_auto = trait_.is_auto(tcx);
|
let is_auto = trait_.is_auto(tcx);
|
||||||
let is_unsafe = trait_.unsafety(tcx) == rustc_hir::Unsafety::Unsafe;
|
let is_unsafe = trait_.unsafety(tcx) == rustc_hir::Unsafety::Unsafe;
|
||||||
|
let is_object_safe = trait_.is_object_safe(tcx);
|
||||||
let clean::Trait { items, generics, bounds, .. } = trait_;
|
let clean::Trait { items, generics, bounds, .. } = trait_;
|
||||||
Trait {
|
Trait {
|
||||||
is_auto,
|
is_auto,
|
||||||
is_unsafe,
|
is_unsafe,
|
||||||
|
is_object_safe,
|
||||||
items: ids(items, tcx),
|
items: ids(items, tcx),
|
||||||
generics: generics.into_tcx(tcx),
|
generics: generics.into_tcx(tcx),
|
||||||
bounds: bounds.into_tcx(tcx),
|
bounds: bounds.into_tcx(tcx),
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
|
||||||
/// rustdoc format-version.
|
/// rustdoc format-version.
|
||||||
pub const FORMAT_VERSION: u32 = 27;
|
pub const FORMAT_VERSION: u32 = 28;
|
||||||
|
|
||||||
/// A `Crate` is the root of the emitted JSON blob. It contains all type/documentation information
|
/// A `Crate` is the root of the emitted JSON blob. It contains all type/documentation information
|
||||||
/// about the language items in the local crate, as well as info about external items to allow
|
/// about the language items in the local crate, as well as info about external items to allow
|
||||||
@ -634,6 +634,7 @@ pub struct FnDecl {
|
|||||||
pub struct Trait {
|
pub struct Trait {
|
||||||
pub is_auto: bool,
|
pub is_auto: bool,
|
||||||
pub is_unsafe: bool,
|
pub is_unsafe: bool,
|
||||||
|
pub is_object_safe: bool,
|
||||||
pub items: Vec<Id>,
|
pub items: Vec<Id>,
|
||||||
pub generics: Generics,
|
pub generics: Generics,
|
||||||
pub bounds: Vec<GenericBound>,
|
pub bounds: Vec<GenericBound>,
|
||||||
|
19
tests/rustdoc-json/traits/is_object_safe.rs
Normal file
19
tests/rustdoc-json/traits/is_object_safe.rs
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
#![no_std]
|
||||||
|
|
||||||
|
// @has "$.index[*][?(@.name=='FooUnsafe')]"
|
||||||
|
// @is "$.index[*][?(@.name=='FooUnsafe')].inner.trait.is_object_safe" false
|
||||||
|
pub trait FooUnsafe {
|
||||||
|
fn foo() -> Self;
|
||||||
|
}
|
||||||
|
|
||||||
|
// @has "$.index[*][?(@.name=='BarUnsafe')]"
|
||||||
|
// @is "$.index[*][?(@.name=='BarUnsafe')].inner.trait.is_object_safe" false
|
||||||
|
pub trait BarUnsafe<T> {
|
||||||
|
fn foo(i: T);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @has "$.index[*][?(@.name=='FooSafe')]"
|
||||||
|
// @is "$.index[*][?(@.name=='FooSafe')].inner.trait.is_object_safe" true
|
||||||
|
pub trait FooSafe {
|
||||||
|
fn foo(&self);
|
||||||
|
}
|
@ -22,6 +22,6 @@ pub trait Safe {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// @has 'foo/struct.Foo.html'
|
// @has 'foo/struct.Foo.html'
|
||||||
// @!has - '//*[@class="object-safety-info"]' ''
|
// @count - '//*[@class="object-safety-info"]' 0
|
||||||
// @!has - '//*[@id="object-safety"]' ''
|
// @count - '//*[@id="object-safety"]' 0
|
||||||
pub struct Foo;
|
pub struct Foo;
|
||||||
|
@ -0,0 +1,16 @@
|
|||||||
|
#![feature(const_trait_impl, effects)]
|
||||||
|
|
||||||
|
const fn test() -> impl ~const Fn() { //~ ERROR ~const can only be applied to `#[const_trait]` traits
|
||||||
|
const move || { //~ ERROR const closures are experimental
|
||||||
|
let sl: &[u8] = b"foo";
|
||||||
|
|
||||||
|
match sl {
|
||||||
|
[first, remainder @ ..] => {
|
||||||
|
assert_eq!(first, &b'f');
|
||||||
|
}
|
||||||
|
[] => panic!(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {}
|
@ -0,0 +1,18 @@
|
|||||||
|
error[E0658]: const closures are experimental
|
||||||
|
--> $DIR/ice-112822-expected-type-for-param.rs:4:5
|
||||||
|
|
|
||||||
|
LL | const move || {
|
||||||
|
| ^^^^^
|
||||||
|
|
|
||||||
|
= note: see issue #106003 <https://github.com/rust-lang/rust/issues/106003> for more information
|
||||||
|
= help: add `#![feature(const_closures)]` to the crate attributes to enable
|
||||||
|
|
||||||
|
error: ~const can only be applied to `#[const_trait]` traits
|
||||||
|
--> $DIR/ice-112822-expected-type-for-param.rs:3:32
|
||||||
|
|
|
||||||
|
LL | const fn test() -> impl ~const Fn() {
|
||||||
|
| ^^^^
|
||||||
|
|
||||||
|
error: aborting due to 2 previous errors
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0658`.
|
Loading…
Reference in New Issue
Block a user