Skip to content

Commit f4cfd87

Browse files
committed
Auto merge of rust-lang#120676 - Mark-Simulacrum:bootstrap-bump, r=clubby789
Bump bootstrap compiler to just-built 1.77 beta https://forge.rust-lang.org/release/process.html#master-bootstrap-update-t-2-day-tuesday
2 parents e28fae5 + 9a5034a commit f4cfd87

File tree

41 files changed

+485
-618
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

41 files changed

+485
-618
lines changed

compiler/rustc_feature/src/accepted.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -77,7 +77,7 @@ declare_features! (
7777
/// Allows empty structs and enum variants with braces.
7878
(accepted, braced_empty_structs, "1.8.0", Some(29720)),
7979
/// Allows `c"foo"` literals.
80-
(accepted, c_str_literals, "CURRENT_RUSTC_VERSION", Some(105723)),
80+
(accepted, c_str_literals, "1.77.0", Some(105723)),
8181
/// Allows `#[cfg_attr(predicate, multiple, attributes, here)]`.
8282
(accepted, cfg_attr_multi, "1.33.0", Some(54881)),
8383
/// Allows the use of `#[cfg(doctest)]`, set when rustdoc is collecting doctests.

compiler/rustc_feature/src/removed.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ declare_features! (
3333
// -------------------------------------------------------------------------
3434

3535
/// Allows using the `amdgpu-kernel` ABI.
36-
(removed, abi_amdgpu_kernel, "CURRENT_RUSTC_VERSION", Some(51575), None),
36+
(removed, abi_amdgpu_kernel, "1.77.0", Some(51575), None),
3737
(removed, advanced_slice_patterns, "1.0.0", Some(62254),
3838
Some("merged into `#![feature(slice_patterns)]`")),
3939
(removed, allocator, "1.0.0", None, None),

compiler/rustc_feature/src/unstable.rs

+4-4
Original file line numberDiff line numberDiff line change
@@ -356,7 +356,7 @@ declare_features! (
356356
/// Allows `#[track_caller]` on async functions.
357357
(unstable, async_fn_track_caller, "1.73.0", Some(110011)),
358358
/// Allows `for await` loops.
359-
(unstable, async_for_loop, "CURRENT_RUSTC_VERSION", Some(118898)),
359+
(unstable, async_for_loop, "1.77.0", Some(118898)),
360360
/// Allows builtin # foo() syntax
361361
(unstable, builtin_syntax, "1.71.0", Some(110680)),
362362
/// Treat `extern "C"` function as nounwind.
@@ -370,7 +370,7 @@ declare_features! (
370370
/// Allows the use of `#[cfg(sanitize = "option")]`; set when -Zsanitizer is used.
371371
(unstable, cfg_sanitize, "1.41.0", Some(39699)),
372372
/// Allows `cfg(sanitizer_cfi_generalize_pointers)` and `cfg(sanitizer_cfi_normalize_integers)`.
373-
(unstable, cfg_sanitizer_cfi, "CURRENT_RUSTC_VERSION", Some(89653)),
373+
(unstable, cfg_sanitizer_cfi, "1.77.0", Some(89653)),
374374
/// Allows `cfg(target_abi = "...")`.
375375
(unstable, cfg_target_abi, "1.55.0", Some(80970)),
376376
/// Allows `cfg(target(abi = "..."))`.
@@ -514,7 +514,7 @@ declare_features! (
514514
(unstable, marker_trait_attr, "1.30.0", Some(29864)),
515515
/// Allows exhaustive pattern matching on types that contain uninhabited types in cases that are
516516
/// unambiguously sound.
517-
(incomplete, min_exhaustive_patterns, "CURRENT_RUSTC_VERSION", Some(119612)),
517+
(incomplete, min_exhaustive_patterns, "1.77.0", Some(119612)),
518518
/// A minimal, sound subset of specialization intended to be used by the
519519
/// standard library until the soundness issues with specialization
520520
/// are fixed.
@@ -550,7 +550,7 @@ declare_features! (
550550
/// Allows using enums in offset_of!
551551
(unstable, offset_of_enum, "1.75.0", Some(120141)),
552552
/// Allows using multiple nested field accesses in offset_of!
553-
(unstable, offset_of_nested, "CURRENT_RUSTC_VERSION", Some(120140)),
553+
(unstable, offset_of_nested, "1.77.0", Some(120140)),
554554
/// Allows using `#[optimize(X)]`.
555555
(unstable, optimize_attribute, "1.34.0", Some(54882)),
556556
/// Allows macro attributes on expressions, statements and non-inline modules.

compiler/rustc_index_macros/src/lib.rs

+7-7
Original file line numberDiff line numberDiff line change
@@ -31,17 +31,17 @@ mod newtype;
3131
/// - `#[max = 0xFFFF_FFFD]`: specifies the max value, which allows niche
3232
/// optimizations. The default max value is 0xFFFF_FF00.
3333
/// - `#[gate_rustc_only]`: makes parts of the generated code nightly-only.
34-
///
35-
/// `SpecOptionPartialEq` is specialized by this macro, so using it requires enabling
36-
/// `#![feature(min_specialization)]` for the crate.
3734
#[proc_macro]
3835
#[cfg_attr(
3936
feature = "nightly",
40-
allow_internal_unstable(step_trait, rustc_attrs, trusted_step, spec_option_partial_eq)
37+
allow_internal_unstable(
38+
step_trait,
39+
rustc_attrs,
40+
trusted_step,
41+
spec_option_partial_eq,
42+
min_specialization
43+
)
4144
)]
42-
// FIXME: Remove the above comment about `min_specialization` once bootstrap is bumped,
43-
// and the corresponding one on SpecOptionPartialEq
44-
#[cfg_attr(all(feature = "nightly", not(bootstrap)), allow_internal_unstable(min_specialization))]
4545
pub fn newtype_index(input: TokenStream) -> TokenStream {
4646
newtype::newtype(input)
4747
}

compiler/rustc_lint/src/lib.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -34,7 +34,7 @@
3434
#![feature(if_let_guard)]
3535
#![feature(iter_order_by)]
3636
#![feature(let_chains)]
37-
#![cfg_attr(not(bootstrap), feature(trait_upcasting))]
37+
#![feature(trait_upcasting)]
3838
#![feature(min_specialization)]
3939
#![feature(rustc_attrs)]
4040
#![allow(internal_features)]

compiler/rustc_middle/src/lib.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,7 @@
4949
#![feature(associated_type_bounds)]
5050
#![feature(rustc_attrs)]
5151
#![feature(control_flow_enum)]
52-
#![cfg_attr(not(bootstrap), feature(trait_upcasting))]
52+
#![feature(trait_upcasting)]
5353
#![feature(try_blocks)]
5454
#![feature(decl_macro)]
5555
#![feature(extract_if)]

library/alloc/src/slice.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -51,7 +51,7 @@ pub use core::slice::{from_mut, from_ref};
5151
pub use core::slice::{from_mut_ptr_range, from_ptr_range};
5252
#[stable(feature = "rust1", since = "1.0.0")]
5353
pub use core::slice::{from_raw_parts, from_raw_parts_mut};
54-
#[stable(feature = "slice_group_by", since = "CURRENT_RUSTC_VERSION")]
54+
#[stable(feature = "slice_group_by", since = "1.77.0")]
5555
pub use core::slice::{ChunkBy, ChunkByMut};
5656
#[stable(feature = "rust1", since = "1.0.0")]
5757
pub use core::slice::{Chunks, Windows};

library/alloc/src/vec/cow.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,7 @@ impl<'a, T: Clone> From<&'a [T]> for Cow<'a, [T]> {
1515
}
1616
}
1717

18-
#[stable(feature = "cow_from_array_ref", since = "CURRENT_RUSTC_VERSION")]
18+
#[stable(feature = "cow_from_array_ref", since = "1.77.0")]
1919
impl<'a, T: Clone, const N: usize> From<&'a [T; N]> for Cow<'a, [T]> {
2020
/// Creates a [`Borrowed`] variant of [`Cow`]
2121
/// from a reference to an array.

library/core/src/array/mod.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -576,7 +576,7 @@ impl<T, const N: usize> [T; N] {
576576
/// // We can still access the original array: it has not been moved.
577577
/// assert_eq!(strings.len(), 3);
578578
/// ```
579-
#[stable(feature = "array_methods", since = "CURRENT_RUSTC_VERSION")]
579+
#[stable(feature = "array_methods", since = "1.77.0")]
580580
pub fn each_ref(&self) -> [&T; N] {
581581
from_trusted_iterator(self.iter())
582582
}
@@ -595,7 +595,7 @@ impl<T, const N: usize> [T; N] {
595595
/// assert_eq!(float_refs, [&mut 0.0, &mut 2.7, &mut -1.0]);
596596
/// assert_eq!(floats, [0.0, 2.7, -1.0]);
597597
/// ```
598-
#[stable(feature = "array_methods", since = "CURRENT_RUSTC_VERSION")]
598+
#[stable(feature = "array_methods", since = "1.77.0")]
599599
pub fn each_mut(&mut self) -> [&mut T; N] {
600600
from_trusted_iterator(self.iter_mut())
601601
}

library/core/src/async_iter/async_iter.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ pub trait AsyncIterator {
4747
/// Rust's usual rules apply: calls must never cause undefined behavior
4848
/// (memory corruption, incorrect use of `unsafe` functions, or the like),
4949
/// regardless of the async iterator's state.
50-
#[cfg_attr(not(bootstrap), lang = "async_iterator_poll_next")]
50+
#[lang = "async_iterator_poll_next"]
5151
fn poll_next(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Option<Self::Item>>;
5252

5353
/// Returns the bounds on the remaining length of the async iterator.
@@ -145,7 +145,7 @@ pub trait IntoAsyncIterator {
145145
type IntoAsyncIter: AsyncIterator<Item = Self::Item>;
146146

147147
/// Converts `self` into an async iterator
148-
#[cfg_attr(not(bootstrap), lang = "into_async_iter_into_iter")]
148+
#[lang = "into_async_iter_into_iter"]
149149
fn into_async_iter(self) -> Self::IntoAsyncIter;
150150
}
151151

library/core/src/intrinsics.rs

+1-10
Original file line numberDiff line numberDiff line change
@@ -947,7 +947,7 @@ extern "rust-intrinsic" {
947947
/// own, or if it does not enable any significant optimizations.
948948
///
949949
/// This intrinsic does not have a stable counterpart.
950-
#[rustc_const_stable(feature = "const_assume", since = "CURRENT_RUSTC_VERSION")]
950+
#[rustc_const_stable(feature = "const_assume", since = "1.77.0")]
951951
#[rustc_nounwind]
952952
pub fn assume(b: bool);
953953

@@ -2567,7 +2567,6 @@ extern "rust-intrinsic" {
25672567
/// matter what*.
25682568
#[rustc_const_unstable(feature = "is_val_statically_known", issue = "none")]
25692569
#[rustc_nounwind]
2570-
#[cfg(not(bootstrap))]
25712570
pub fn is_val_statically_known<T: Copy>(arg: T) -> bool;
25722571

25732572
#[rustc_const_unstable(feature = "delayed_debug_assertions", issue = "none")]
@@ -2582,14 +2581,6 @@ pub(crate) const fn debug_assertions() -> bool {
25822581
cfg!(debug_assertions)
25832582
}
25842583

2585-
// FIXME: Seems using `unstable` here completely ignores `rustc_allow_const_fn_unstable`
2586-
// and thus compiling stage0 core doesn't work.
2587-
#[rustc_const_stable(feature = "is_val_statically_known", since = "0.0.0")]
2588-
#[cfg(bootstrap)]
2589-
pub const unsafe fn is_val_statically_known<T: Copy>(_arg: T) -> bool {
2590-
false
2591-
}
2592-
25932584
// Some functions are defined here because they accidentally got made
25942585
// available in this module on stable. See <https://github.com/rust-lang/rust/issues/15702>.
25952586
// (`transmute` also falls into this category, but it cannot be wrapped due to the

library/core/src/intrinsics/mir.rs

-2
Original file line numberDiff line numberDiff line change
@@ -105,7 +105,6 @@
105105
//! }
106106
//!
107107
//! #[custom_mir(dialect = "runtime", phase = "optimized")]
108-
#![cfg_attr(bootstrap, doc = "#[cfg(any())]")] // disable the following function in doctests when `bootstrap` is set
109108
//! fn push_and_pop<T>(v: &mut Vec<T>, value: T) {
110109
//! mir!(
111110
//! let _unused;
@@ -357,7 +356,6 @@ define!("mir_unwind_resume",
357356

358357
define!("mir_storage_live", fn StorageLive<T>(local: T));
359358
define!("mir_storage_dead", fn StorageDead<T>(local: T));
360-
#[cfg(not(bootstrap))]
361359
define!("mir_assume", fn Assume(operand: bool));
362360
define!("mir_deinit", fn Deinit<T>(place: T));
363361
define!("mir_checked", fn Checked<T>(binop: T) -> (T, bool));

library/core/src/lib.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -111,7 +111,6 @@
111111
//
112112
// Library features:
113113
// tidy-alphabetical-start
114-
#![cfg_attr(not(bootstrap), feature(offset_of_nested))]
115114
#![feature(char_indices_offset)]
116115
#![feature(const_align_of_val)]
117116
#![feature(const_align_of_val_raw)]
@@ -181,6 +180,7 @@
181180
#![feature(maybe_uninit_uninit_array)]
182181
#![feature(non_null_convenience)]
183182
#![feature(offset_of_enum)]
183+
#![feature(offset_of_nested)]
184184
#![feature(panic_internals)]
185185
#![feature(ptr_alignment_type)]
186186
#![feature(ptr_metadata)]

library/core/src/marker.rs

-89
Original file line numberDiff line numberDiff line change
@@ -225,77 +225,6 @@ marker_impls! {
225225
{T: ?Sized} &T,
226226
}
227227

228-
/// Required trait for constants used in pattern matches.
229-
///
230-
/// Any type that derives `Eq` automatically implements this trait, *regardless*
231-
/// of whether its type parameters implement `Eq`.
232-
///
233-
/// This is a hack to work around a limitation in our type system.
234-
///
235-
/// # Background
236-
///
237-
/// We want to require that types of consts used in pattern matches
238-
/// have the attribute `#[derive(PartialEq, Eq)]`.
239-
///
240-
/// In a more ideal world, we could check that requirement by just checking that
241-
/// the given type implements both the `StructuralPartialEq` trait *and*
242-
/// the `Eq` trait. However, you can have ADTs that *do* `derive(PartialEq, Eq)`,
243-
/// and be a case that we want the compiler to accept, and yet the constant's
244-
/// type fails to implement `Eq`.
245-
///
246-
/// Namely, a case like this:
247-
///
248-
/// ```rust
249-
/// #[derive(PartialEq, Eq)]
250-
/// struct Wrap<X>(X);
251-
///
252-
/// fn higher_order(_: &()) { }
253-
///
254-
/// const CFN: Wrap<fn(&())> = Wrap(higher_order);
255-
///
256-
/// #[allow(pointer_structural_match)]
257-
/// fn main() {
258-
/// match CFN {
259-
/// CFN => {}
260-
/// _ => {}
261-
/// }
262-
/// }
263-
/// ```
264-
///
265-
/// (The problem in the above code is that `Wrap<fn(&())>` does not implement
266-
/// `PartialEq`, nor `Eq`, because `for<'a> fn(&'a _)` does not implement those
267-
/// traits.)
268-
///
269-
/// Therefore, we cannot rely on naive check for `StructuralPartialEq` and
270-
/// mere `Eq`.
271-
///
272-
/// As a hack to work around this, we use two separate traits injected by each
273-
/// of the two derives (`#[derive(PartialEq)]` and `#[derive(Eq)]`) and check
274-
/// that both of them are present as part of structural-match checking.
275-
#[unstable(feature = "structural_match", issue = "31434")]
276-
#[diagnostic::on_unimplemented(message = "the type `{Self}` does not `#[derive(Eq)]`")]
277-
#[lang = "structural_teq"]
278-
#[cfg(bootstrap)]
279-
pub trait StructuralEq {
280-
// Empty.
281-
}
282-
283-
// FIXME: Remove special cases of these types from the compiler pattern checking code and always check `T: StructuralEq` instead
284-
marker_impls! {
285-
#[unstable(feature = "structural_match", issue = "31434")]
286-
#[cfg(bootstrap)]
287-
StructuralEq for
288-
usize, u8, u16, u32, u64, u128,
289-
isize, i8, i16, i32, i64, i128,
290-
bool,
291-
char,
292-
str /* Technically requires `[u8]: StructuralEq` */,
293-
(),
294-
{T, const N: usize} [T; N],
295-
{T} [T],
296-
{T: ?Sized} &T,
297-
}
298-
299228
/// Types whose values can be duplicated simply by copying bits.
300229
///
301230
/// By default, variable bindings have 'move semantics.' In other
@@ -860,10 +789,6 @@ impl<T: ?Sized> Default for PhantomData<T> {
860789
#[unstable(feature = "structural_match", issue = "31434")]
861790
impl<T: ?Sized> StructuralPartialEq for PhantomData<T> {}
862791

863-
#[unstable(feature = "structural_match", issue = "31434")]
864-
#[cfg(bootstrap)]
865-
impl<T: ?Sized> StructuralEq for PhantomData<T> {}
866-
867792
/// Compiler-internal trait used to indicate the type of enum discriminants.
868793
///
869794
/// This trait is automatically implemented for every type and does not add any
@@ -1041,22 +966,8 @@ pub trait PointerLike {}
1041966
#[unstable(feature = "adt_const_params", issue = "95174")]
1042967
#[diagnostic::on_unimplemented(message = "`{Self}` can't be used as a const parameter type")]
1043968
#[allow(multiple_supertrait_upcastable)]
1044-
#[cfg(not(bootstrap))]
1045969
pub trait ConstParamTy: StructuralPartialEq + Eq {}
1046970

1047-
/// A marker for types which can be used as types of `const` generic parameters.
1048-
///
1049-
/// These types must have a proper equivalence relation (`Eq`) and it must be automatically
1050-
/// derived (`StructuralPartialEq`). There's a hard-coded check in the compiler ensuring
1051-
/// that all fields are also `ConstParamTy`, which implies that recursively, all fields
1052-
/// are `StructuralPartialEq`.
1053-
#[lang = "const_param_ty"]
1054-
#[unstable(feature = "adt_const_params", issue = "95174")]
1055-
#[rustc_on_unimplemented(message = "`{Self}` can't be used as a const parameter type")]
1056-
#[allow(multiple_supertrait_upcastable)]
1057-
#[cfg(bootstrap)]
1058-
pub trait ConstParamTy: StructuralEq + StructuralPartialEq + Eq {}
1059-
1060971
/// Derive macro generating an impl of the trait `ConstParamTy`.
1061972
#[rustc_builtin_macro]
1062973
#[unstable(feature = "adt_const_params", issue = "95174")]

library/core/src/mem/mod.rs

+1-11
Original file line numberDiff line numberDiff line change
@@ -1393,19 +1393,9 @@ impl<T> SizedTypeProperties for T {}
13931393
///
13941394
/// assert_eq!(mem::offset_of!(Option<&u8>, Some.0), 0);
13951395
/// ```
1396-
#[cfg(not(bootstrap))]
1397-
#[stable(feature = "offset_of", since = "CURRENT_RUSTC_VERSION")]
1396+
#[stable(feature = "offset_of", since = "1.77.0")]
13981397
#[allow_internal_unstable(builtin_syntax, hint_must_use)]
13991398
pub macro offset_of($Container:ty, $($fields:expr)+ $(,)?) {
14001399
// The `{}` is for better error messages
14011400
crate::hint::must_use({builtin # offset_of($Container, $($fields)+)})
14021401
}
1403-
1404-
#[cfg(bootstrap)]
1405-
#[stable(feature = "offset_of", since = "CURRENT_RUSTC_VERSION")]
1406-
#[allow_internal_unstable(builtin_syntax, hint_must_use)]
1407-
#[allow(missing_docs)]
1408-
pub macro offset_of($Container:ty, $($fields:tt).+ $(,)?) {
1409-
// The `{}` is for better error messages
1410-
crate::hint::must_use({builtin # offset_of($Container, $($fields).+)})
1411-
}

library/core/src/net/mod.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@
99
//! * [`SocketAddr`] represents socket addresses of either IPv4 or IPv6; [`SocketAddrV4`]
1010
//! and [`SocketAddrV6`] are respectively IPv4 and IPv6 socket addresses
1111
12-
#![stable(feature = "ip_in_core", since = "CURRENT_RUSTC_VERSION")]
12+
#![stable(feature = "ip_in_core", since = "1.77.0")]
1313

1414
#[stable(feature = "rust1", since = "1.0.0")]
1515
pub use self::ip_addr::{IpAddr, Ipv4Addr, Ipv6Addr, Ipv6MulticastScope};

library/core/src/num/nonzero.rs

-6
Original file line numberDiff line numberDiff line change
@@ -4,8 +4,6 @@ use crate::cmp::Ordering;
44
use crate::fmt;
55
use crate::hash::{Hash, Hasher};
66
use crate::intrinsics;
7-
#[cfg(bootstrap)]
8-
use crate::marker::StructuralEq;
97
use crate::marker::StructuralPartialEq;
108
use crate::ops::{BitOr, BitOrAssign, Div, Neg, Rem};
119
use crate::str::FromStr;
@@ -581,10 +579,6 @@ macro_rules! nonzero_integer {
581579
#[$stability]
582580
impl Eq for $Ty {}
583581

584-
#[unstable(feature = "structural_match", issue = "31434")]
585-
#[cfg(bootstrap)]
586-
impl StructuralEq for $Ty {}
587-
588582
#[$stability]
589583
impl PartialOrd for $Ty {
590584
#[inline]

0 commit comments

Comments
 (0)