Rollup merge of #130101 - RalfJung:const-cleanup, r=fee1-dead
some const cleanup: remove unnecessary attributes, add const-hack indications I learned that we use `FIXME(const-hack)` on top of the "const-hack" label. That seems much better since it marks the right place in the code and moves around with the code. So I went through the PRs with that label and added appropriate FIXMEs in the code. IMO this means we can then remove the label -- Cc ``@rust-lang/wg-const-eval.`` I also noticed some const stability attributes that don't do anything useful, and removed them. r? ``@fee1-dead``
This commit is contained in:
commit
4428d6f363
@ -42,7 +42,7 @@ fn to_profiler_name(type_name: &'static str) -> &'static str {
|
|||||||
|
|
||||||
// const wrapper for `if let Some((_, tail)) = name.rsplit_once(':') { tail } else { name }`
|
// const wrapper for `if let Some((_, tail)) = name.rsplit_once(':') { tail } else { name }`
|
||||||
const fn c_name(name: &'static str) -> &'static str {
|
const fn c_name(name: &'static str) -> &'static str {
|
||||||
// FIXME Simplify the implementation once more `str` methods get const-stable.
|
// FIXME(const-hack) Simplify the implementation once more `str` methods get const-stable.
|
||||||
// and inline into call site
|
// and inline into call site
|
||||||
let bytes = name.as_bytes();
|
let bytes = name.as_bytes();
|
||||||
let mut i = bytes.len();
|
let mut i = bytes.len();
|
||||||
@ -61,7 +61,7 @@ const fn c_name(name: &'static str) -> &'static str {
|
|||||||
/// loop that goes over each available MIR and applies `run_pass`.
|
/// loop that goes over each available MIR and applies `run_pass`.
|
||||||
pub(super) trait MirPass<'tcx> {
|
pub(super) trait MirPass<'tcx> {
|
||||||
fn name(&self) -> &'static str {
|
fn name(&self) -> &'static str {
|
||||||
// FIXME Simplify the implementation once more `str` methods get const-stable.
|
// FIXME(const-hack) Simplify the implementation once more `str` methods get const-stable.
|
||||||
// See copypaste in `MirLint`
|
// See copypaste in `MirLint`
|
||||||
const {
|
const {
|
||||||
let name = std::any::type_name::<Self>();
|
let name = std::any::type_name::<Self>();
|
||||||
@ -89,7 +89,7 @@ fn is_mir_dump_enabled(&self) -> bool {
|
|||||||
/// disabled (via the `Lint` adapter).
|
/// disabled (via the `Lint` adapter).
|
||||||
pub(super) trait MirLint<'tcx> {
|
pub(super) trait MirLint<'tcx> {
|
||||||
fn name(&self) -> &'static str {
|
fn name(&self) -> &'static str {
|
||||||
// FIXME Simplify the implementation once more `str` methods get const-stable.
|
// FIXME(const-hack) Simplify the implementation once more `str` methods get const-stable.
|
||||||
// See copypaste in `MirPass`
|
// See copypaste in `MirPass`
|
||||||
const {
|
const {
|
||||||
let name = std::any::type_name::<Self>();
|
let name = std::any::type_name::<Self>();
|
||||||
|
@ -554,8 +554,8 @@ impl<T> VecDeque<T> {
|
|||||||
#[rustc_const_stable(feature = "const_vec_deque_new", since = "1.68.0")]
|
#[rustc_const_stable(feature = "const_vec_deque_new", since = "1.68.0")]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub const fn new() -> VecDeque<T> {
|
pub const fn new() -> VecDeque<T> {
|
||||||
// FIXME: This should just be `VecDeque::new_in(Global)` once that hits stable.
|
// FIXME(const-hack): This should just be `VecDeque::new_in(Global)` once that hits stable.
|
||||||
VecDeque { head: 0, len: 0, buf: RawVec::NEW }
|
VecDeque { head: 0, len: 0, buf: RawVec::new() }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates an empty deque with space for at least `capacity` elements.
|
/// Creates an empty deque with space for at least `capacity` elements.
|
||||||
|
@ -96,13 +96,6 @@ struct RawVecInner<A: Allocator = Global> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<T> RawVec<T, Global> {
|
impl<T> RawVec<T, Global> {
|
||||||
/// HACK(Centril): This exists because stable `const fn` can only call stable `const fn`, so
|
|
||||||
/// they cannot call `Self::new()`.
|
|
||||||
///
|
|
||||||
/// If you change `RawVec<T>::new` or dependencies, please take care to not introduce anything
|
|
||||||
/// that would truly const-call something unstable.
|
|
||||||
pub const NEW: Self = Self::new();
|
|
||||||
|
|
||||||
/// Creates the biggest possible `RawVec` (on the system heap)
|
/// Creates the biggest possible `RawVec` (on the system heap)
|
||||||
/// without allocating. If `T` has positive size, then this makes a
|
/// without allocating. If `T` has positive size, then this makes a
|
||||||
/// `RawVec` with capacity `0`. If `T` is zero-sized, then it makes a
|
/// `RawVec` with capacity `0`. If `T` is zero-sized, then it makes a
|
||||||
@ -111,7 +104,7 @@ impl<T> RawVec<T, Global> {
|
|||||||
#[must_use]
|
#[must_use]
|
||||||
#[rustc_const_stable(feature = "raw_vec_internals_const", since = "1.81")]
|
#[rustc_const_stable(feature = "raw_vec_internals_const", since = "1.81")]
|
||||||
pub const fn new() -> Self {
|
pub const fn new() -> Self {
|
||||||
Self { inner: RawVecInner::new::<T>(), _marker: PhantomData }
|
Self::new_in(Global)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates a `RawVec` (on the system heap) with exactly the
|
/// Creates a `RawVec` (on the system heap) with exactly the
|
||||||
@ -149,12 +142,6 @@ pub fn with_capacity_zeroed(capacity: usize) -> Self {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl RawVecInner<Global> {
|
impl RawVecInner<Global> {
|
||||||
#[must_use]
|
|
||||||
#[rustc_const_stable(feature = "raw_vec_internals_const", since = "1.81")]
|
|
||||||
const fn new<T>() -> Self {
|
|
||||||
Self::new_in(Global, core::mem::align_of::<T>())
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(any(no_global_oom_handling, test)))]
|
#[cfg(not(any(no_global_oom_handling, test)))]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -191,7 +191,7 @@ const fn in_place_collectible<DEST, SRC>(
|
|||||||
|
|
||||||
const fn needs_realloc<SRC, DEST>(src_cap: usize, dst_cap: usize) -> bool {
|
const fn needs_realloc<SRC, DEST>(src_cap: usize, dst_cap: usize) -> bool {
|
||||||
if const { mem::align_of::<SRC>() != mem::align_of::<DEST>() } {
|
if const { mem::align_of::<SRC>() != mem::align_of::<DEST>() } {
|
||||||
// FIXME: use unreachable! once that works in const
|
// FIXME(const-hack): use unreachable! once that works in const
|
||||||
panic!("in_place_collectible() prevents this");
|
panic!("in_place_collectible() prevents this");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,7 +142,7 @@ pub(super) fn forget_allocation_drop_remaining(&mut self) {
|
|||||||
// struct and then overwriting &mut self.
|
// struct and then overwriting &mut self.
|
||||||
// this creates less assembly
|
// this creates less assembly
|
||||||
self.cap = 0;
|
self.cap = 0;
|
||||||
self.buf = RawVec::NEW.non_null();
|
self.buf = RawVec::new().non_null();
|
||||||
self.ptr = self.buf;
|
self.ptr = self.buf;
|
||||||
self.end = self.buf.as_ptr();
|
self.end = self.buf.as_ptr();
|
||||||
|
|
||||||
|
@ -419,7 +419,7 @@ impl<T> Vec<T> {
|
|||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub const fn new() -> Self {
|
pub const fn new() -> Self {
|
||||||
Vec { buf: RawVec::NEW, len: 0 }
|
Vec { buf: RawVec::new(), len: 0 }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Constructs a new, empty `Vec<T>` with at least the specified capacity.
|
/// Constructs a new, empty `Vec<T>` with at least the specified capacity.
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#[must_use]
|
#[must_use]
|
||||||
#[inline]
|
#[inline]
|
||||||
pub(super) const fn from_u32(i: u32) -> Option<char> {
|
pub(super) const fn from_u32(i: u32) -> Option<char> {
|
||||||
// FIXME: once Result::ok is const fn, use it here
|
// FIXME(const-hack): once Result::ok is const fn, use it here
|
||||||
match char_try_from_u32(i) {
|
match char_try_from_u32(i) {
|
||||||
Ok(c) => Some(c),
|
Ok(c) => Some(c),
|
||||||
Err(_) => None,
|
Err(_) => None,
|
||||||
|
@ -383,7 +383,7 @@ pub const fn to_digit(self, radix: u32) -> Option<u32> {
|
|||||||
// Force the 6th bit to be set to ensure ascii is lower case.
|
// Force the 6th bit to be set to ensure ascii is lower case.
|
||||||
digit = (self as u32 | 0b10_0000).wrapping_sub('a' as u32).saturating_add(10);
|
digit = (self as u32 | 0b10_0000).wrapping_sub('a' as u32).saturating_add(10);
|
||||||
}
|
}
|
||||||
// FIXME: once then_some is const fn, use it here
|
// FIXME(const-hack): once then_some is const fn, use it here
|
||||||
if digit < radix { Some(digit) } else { None }
|
if digit < radix { Some(digit) } else { None }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,7 +149,6 @@
|
|||||||
#![feature(const_size_of_val_raw)]
|
#![feature(const_size_of_val_raw)]
|
||||||
#![feature(const_slice_from_raw_parts_mut)]
|
#![feature(const_slice_from_raw_parts_mut)]
|
||||||
#![feature(const_slice_from_ref)]
|
#![feature(const_slice_from_ref)]
|
||||||
#![feature(const_slice_index)]
|
|
||||||
#![feature(const_slice_split_at_mut)]
|
#![feature(const_slice_split_at_mut)]
|
||||||
#![feature(const_str_from_utf8_unchecked_mut)]
|
#![feature(const_str_from_utf8_unchecked_mut)]
|
||||||
#![feature(const_strict_overflow_ops)]
|
#![feature(const_strict_overflow_ops)]
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
use crate::ub_checks::assert_unsafe_precondition;
|
use crate::ub_checks::assert_unsafe_precondition;
|
||||||
use crate::{ascii, intrinsics, mem};
|
use crate::{ascii, intrinsics, mem};
|
||||||
|
|
||||||
// Used because the `?` operator is not allowed in a const context.
|
// FIXME(const-hack): Used because the `?` operator is not allowed in a const context.
|
||||||
macro_rules! try_opt {
|
macro_rules! try_opt {
|
||||||
($e:expr) => {
|
($e:expr) => {
|
||||||
match $e {
|
match $e {
|
||||||
|
@ -739,6 +739,7 @@ pub const fn as_mut(&mut self) -> Option<&mut T> {
|
|||||||
#[stable(feature = "pin", since = "1.33.0")]
|
#[stable(feature = "pin", since = "1.33.0")]
|
||||||
#[rustc_const_unstable(feature = "const_option_ext", issue = "91930")]
|
#[rustc_const_unstable(feature = "const_option_ext", issue = "91930")]
|
||||||
pub const fn as_pin_ref(self: Pin<&Self>) -> Option<Pin<&T>> {
|
pub const fn as_pin_ref(self: Pin<&Self>) -> Option<Pin<&T>> {
|
||||||
|
// FIXME(const-hack): use `map` once that is possible
|
||||||
match Pin::get_ref(self).as_ref() {
|
match Pin::get_ref(self).as_ref() {
|
||||||
// SAFETY: `x` is guaranteed to be pinned because it comes from `self`
|
// SAFETY: `x` is guaranteed to be pinned because it comes from `self`
|
||||||
// which is pinned.
|
// which is pinned.
|
||||||
@ -758,6 +759,7 @@ pub const fn as_pin_mut(self: Pin<&mut Self>) -> Option<Pin<&mut T>> {
|
|||||||
// SAFETY: `get_unchecked_mut` is never used to move the `Option` inside `self`.
|
// SAFETY: `get_unchecked_mut` is never used to move the `Option` inside `self`.
|
||||||
// `x` is guaranteed to be pinned because it comes from `self` which is pinned.
|
// `x` is guaranteed to be pinned because it comes from `self` which is pinned.
|
||||||
unsafe {
|
unsafe {
|
||||||
|
// FIXME(const-hack): use `map` once that is possible
|
||||||
match Pin::get_unchecked_mut(self).as_mut() {
|
match Pin::get_unchecked_mut(self).as_mut() {
|
||||||
Some(x) => Some(Pin::new_unchecked(x)),
|
Some(x) => Some(Pin::new_unchecked(x)),
|
||||||
None => None,
|
None => None,
|
||||||
@ -1290,10 +1292,7 @@ pub fn as_deref(&self) -> Option<&T::Target>
|
|||||||
where
|
where
|
||||||
T: Deref,
|
T: Deref,
|
||||||
{
|
{
|
||||||
match self.as_ref() {
|
self.as_ref().map(|t| t.deref())
|
||||||
Some(t) => Some(t.deref()),
|
|
||||||
None => None,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Converts from `Option<T>` (or `&mut Option<T>`) to `Option<&mut T::Target>`.
|
/// Converts from `Option<T>` (or `&mut Option<T>`) to `Option<&mut T::Target>`.
|
||||||
@ -1316,10 +1315,7 @@ pub fn as_deref_mut(&mut self) -> Option<&mut T::Target>
|
|||||||
where
|
where
|
||||||
T: DerefMut,
|
T: DerefMut,
|
||||||
{
|
{
|
||||||
match self.as_mut() {
|
self.as_mut().map(|t| t.deref_mut())
|
||||||
Some(t) => Some(t.deref_mut()),
|
|
||||||
None => None,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
@ -1632,13 +1628,7 @@ pub fn insert(&mut self, value: T) -> &mut T {
|
|||||||
#[inline]
|
#[inline]
|
||||||
#[stable(feature = "option_entry", since = "1.20.0")]
|
#[stable(feature = "option_entry", since = "1.20.0")]
|
||||||
pub fn get_or_insert(&mut self, value: T) -> &mut T {
|
pub fn get_or_insert(&mut self, value: T) -> &mut T {
|
||||||
if let None = *self {
|
self.get_or_insert_with(|| value)
|
||||||
*self = Some(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
// SAFETY: a `None` variant for `self` would have been replaced by a `Some`
|
|
||||||
// variant in the code above.
|
|
||||||
unsafe { self.as_mut().unwrap_unchecked() }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Inserts the default value into the option if it is [`None`], then
|
/// Inserts the default value into the option if it is [`None`], then
|
||||||
@ -1724,7 +1714,7 @@ pub fn get_or_insert_with<F>(&mut self, f: F) -> &mut T
|
|||||||
#[stable(feature = "rust1", since = "1.0.0")]
|
#[stable(feature = "rust1", since = "1.0.0")]
|
||||||
#[rustc_const_unstable(feature = "const_option", issue = "67441")]
|
#[rustc_const_unstable(feature = "const_option", issue = "67441")]
|
||||||
pub const fn take(&mut self) -> Option<T> {
|
pub const fn take(&mut self) -> Option<T> {
|
||||||
// FIXME replace `mem::replace` by `mem::take` when the latter is const ready
|
// FIXME(const-hack) replace `mem::replace` by `mem::take` when the latter is const ready
|
||||||
mem::replace(self, None)
|
mem::replace(self, None)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -199,7 +199,6 @@ fn from(align: Alignment) -> usize {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_const_unstable(feature = "const_alloc_layout", issue = "67521")]
|
|
||||||
#[unstable(feature = "ptr_alignment_type", issue = "102070")]
|
#[unstable(feature = "ptr_alignment_type", issue = "102070")]
|
||||||
impl cmp::Ord for Alignment {
|
impl cmp::Ord for Alignment {
|
||||||
#[inline]
|
#[inline]
|
||||||
@ -208,7 +207,6 @@ fn cmp(&self, other: &Self) -> cmp::Ordering {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_const_unstable(feature = "const_alloc_layout", issue = "67521")]
|
|
||||||
#[unstable(feature = "ptr_alignment_type", issue = "102070")]
|
#[unstable(feature = "ptr_alignment_type", issue = "102070")]
|
||||||
impl cmp::PartialOrd for Alignment {
|
impl cmp::PartialOrd for Alignment {
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -31,12 +31,12 @@ fn index_mut(&mut self, index: I) -> &mut I::Output {
|
|||||||
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
||||||
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
const fn slice_start_index_len_fail(index: usize, len: usize) -> ! {
|
const fn slice_start_index_len_fail(index: usize, len: usize) -> ! {
|
||||||
|
// FIXME(const-hack): once integer formatting in panics is possible, we
|
||||||
|
// should use the same implementation at compiletime and runtime.
|
||||||
const_eval_select((index, len), slice_start_index_len_fail_ct, slice_start_index_len_fail_rt)
|
const_eval_select((index, len), slice_start_index_len_fail_ct, slice_start_index_len_fail_rt)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME const-hack
|
|
||||||
#[inline]
|
#[inline]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
fn slice_start_index_len_fail_rt(index: usize, len: usize) -> ! {
|
fn slice_start_index_len_fail_rt(index: usize, len: usize) -> ! {
|
||||||
@ -52,12 +52,12 @@ const fn slice_start_index_len_fail_ct(_: usize, _: usize) -> ! {
|
|||||||
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
||||||
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
const fn slice_end_index_len_fail(index: usize, len: usize) -> ! {
|
const fn slice_end_index_len_fail(index: usize, len: usize) -> ! {
|
||||||
|
// FIXME(const-hack): once integer formatting in panics is possible, we
|
||||||
|
// should use the same implementation at compiletime and runtime.
|
||||||
const_eval_select((index, len), slice_end_index_len_fail_ct, slice_end_index_len_fail_rt)
|
const_eval_select((index, len), slice_end_index_len_fail_ct, slice_end_index_len_fail_rt)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME const-hack
|
|
||||||
#[inline]
|
#[inline]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
fn slice_end_index_len_fail_rt(index: usize, len: usize) -> ! {
|
fn slice_end_index_len_fail_rt(index: usize, len: usize) -> ! {
|
||||||
@ -73,12 +73,12 @@ const fn slice_end_index_len_fail_ct(_: usize, _: usize) -> ! {
|
|||||||
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
#[cfg_attr(not(feature = "panic_immediate_abort"), inline(never), cold)]
|
||||||
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
#[cfg_attr(feature = "panic_immediate_abort", inline)]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
const fn slice_index_order_fail(index: usize, end: usize) -> ! {
|
const fn slice_index_order_fail(index: usize, end: usize) -> ! {
|
||||||
|
// FIXME(const-hack): once integer formatting in panics is possible, we
|
||||||
|
// should use the same implementation at compiletime and runtime.
|
||||||
const_eval_select((index, end), slice_index_order_fail_ct, slice_index_order_fail_rt)
|
const_eval_select((index, end), slice_index_order_fail_ct, slice_index_order_fail_rt)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME const-hack
|
|
||||||
#[inline]
|
#[inline]
|
||||||
#[track_caller]
|
#[track_caller]
|
||||||
fn slice_index_order_fail_rt(index: usize, end: usize) -> ! {
|
fn slice_index_order_fail_rt(index: usize, end: usize) -> ! {
|
||||||
@ -246,7 +246,6 @@ pub unsafe trait SliceIndex<T: ?Sized>: private_slice_index::Sealed {
|
|||||||
|
|
||||||
/// The methods `index` and `index_mut` panic if the index is out of bounds.
|
/// The methods `index` and `index_mut` panic if the index is out of bounds.
|
||||||
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl<T> SliceIndex<[T]> for usize {
|
unsafe impl<T> SliceIndex<[T]> for usize {
|
||||||
type Output = T;
|
type Output = T;
|
||||||
|
|
||||||
@ -386,7 +385,6 @@ fn index_mut(self, slice: &mut [T]) -> &mut [T] {
|
|||||||
/// - the start of the range is greater than the end of the range or
|
/// - the start of the range is greater than the end of the range or
|
||||||
/// - the end of the range is out of bounds.
|
/// - the end of the range is out of bounds.
|
||||||
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl<T> SliceIndex<[T]> for ops::Range<usize> {
|
unsafe impl<T> SliceIndex<[T]> for ops::Range<usize> {
|
||||||
type Output = [T];
|
type Output = [T];
|
||||||
|
|
||||||
@ -522,7 +520,6 @@ fn index_mut(self, slice: &mut [T]) -> &mut [T] {
|
|||||||
|
|
||||||
/// The methods `index` and `index_mut` panic if the end of the range is out of bounds.
|
/// The methods `index` and `index_mut` panic if the end of the range is out of bounds.
|
||||||
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl<T> SliceIndex<[T]> for ops::RangeTo<usize> {
|
unsafe impl<T> SliceIndex<[T]> for ops::RangeTo<usize> {
|
||||||
type Output = [T];
|
type Output = [T];
|
||||||
|
|
||||||
@ -561,7 +558,6 @@ fn index_mut(self, slice: &mut [T]) -> &mut [T] {
|
|||||||
|
|
||||||
/// The methods `index` and `index_mut` panic if the start of the range is out of bounds.
|
/// The methods `index` and `index_mut` panic if the start of the range is out of bounds.
|
||||||
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl<T> SliceIndex<[T]> for ops::RangeFrom<usize> {
|
unsafe impl<T> SliceIndex<[T]> for ops::RangeFrom<usize> {
|
||||||
type Output = [T];
|
type Output = [T];
|
||||||
|
|
||||||
@ -644,7 +640,6 @@ fn index_mut(self, slice: &mut [T]) -> &mut [T] {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
#[stable(feature = "slice_get_slice_impls", since = "1.15.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl<T> SliceIndex<[T]> for ops::RangeFull {
|
unsafe impl<T> SliceIndex<[T]> for ops::RangeFull {
|
||||||
type Output = [T];
|
type Output = [T];
|
||||||
|
|
||||||
@ -684,7 +679,6 @@ fn index_mut(self, slice: &mut [T]) -> &mut [T] {
|
|||||||
/// - the start of the range is greater than the end of the range or
|
/// - the start of the range is greater than the end of the range or
|
||||||
/// - the end of the range is out of bounds.
|
/// - the end of the range is out of bounds.
|
||||||
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl<T> SliceIndex<[T]> for ops::RangeInclusive<usize> {
|
unsafe impl<T> SliceIndex<[T]> for ops::RangeInclusive<usize> {
|
||||||
type Output = [T];
|
type Output = [T];
|
||||||
|
|
||||||
@ -766,7 +760,6 @@ fn index_mut(self, slice: &mut [T]) -> &mut [T] {
|
|||||||
|
|
||||||
/// The methods `index` and `index_mut` panic if the end of the range is out of bounds.
|
/// The methods `index` and `index_mut` panic if the end of the range is out of bounds.
|
||||||
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl<T> SliceIndex<[T]> for ops::RangeToInclusive<usize> {
|
unsafe impl<T> SliceIndex<[T]> for ops::RangeToInclusive<usize> {
|
||||||
type Output = [T];
|
type Output = [T];
|
||||||
|
|
||||||
|
@ -51,7 +51,6 @@ const fn memchr_naive(x: u8, text: &[u8]) -> Option<usize> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_allow_const_fn_unstable(const_cmp)]
|
#[rustc_allow_const_fn_unstable(const_cmp)]
|
||||||
#[rustc_allow_const_fn_unstable(const_slice_index)]
|
|
||||||
#[rustc_allow_const_fn_unstable(const_align_offset)]
|
#[rustc_allow_const_fn_unstable(const_align_offset)]
|
||||||
#[rustc_const_stable(feature = "const_memchr", since = "1.65.0")]
|
#[rustc_const_stable(feature = "const_memchr", since = "1.65.0")]
|
||||||
const fn memchr_aligned(x: u8, text: &[u8]) -> Option<usize> {
|
const fn memchr_aligned(x: u8, text: &[u8]) -> Option<usize> {
|
||||||
|
@ -529,7 +529,7 @@ pub const fn split_last_chunk_mut<const N: usize>(
|
|||||||
None
|
None
|
||||||
} else {
|
} else {
|
||||||
// SAFETY: We manually verified the bounds of the slice.
|
// SAFETY: We manually verified the bounds of the slice.
|
||||||
// FIXME: Without const traits, we need this instead of `get_unchecked`.
|
// FIXME(const-hack): Without const traits, we need this instead of `get_unchecked`.
|
||||||
let last = unsafe { self.split_at_unchecked(self.len() - N).1 };
|
let last = unsafe { self.split_at_unchecked(self.len() - N).1 };
|
||||||
|
|
||||||
// SAFETY: We explicitly check for the correct number of elements,
|
// SAFETY: We explicitly check for the correct number of elements,
|
||||||
@ -563,7 +563,7 @@ pub const fn split_last_chunk_mut<const N: usize>(
|
|||||||
None
|
None
|
||||||
} else {
|
} else {
|
||||||
// SAFETY: We manually verified the bounds of the slice.
|
// SAFETY: We manually verified the bounds of the slice.
|
||||||
// FIXME: Without const traits, we need this instead of `get_unchecked`.
|
// FIXME(const-hack): Without const traits, we need this instead of `get_unchecked`.
|
||||||
let last = unsafe { self.split_at_mut_unchecked(self.len() - N).1 };
|
let last = unsafe { self.split_at_mut_unchecked(self.len() - N).1 };
|
||||||
|
|
||||||
// SAFETY: We explicitly check for the correct number of elements,
|
// SAFETY: We explicitly check for the correct number of elements,
|
||||||
@ -1952,7 +1952,7 @@ pub const fn split_at_mut(&mut self, mid: usize) -> (&mut [T], &mut [T]) {
|
|||||||
#[inline]
|
#[inline]
|
||||||
#[must_use]
|
#[must_use]
|
||||||
pub const unsafe fn split_at_unchecked(&self, mid: usize) -> (&[T], &[T]) {
|
pub const unsafe fn split_at_unchecked(&self, mid: usize) -> (&[T], &[T]) {
|
||||||
// HACK: the const function `from_raw_parts` is used to make this
|
// FIXME(const-hack): the const function `from_raw_parts` is used to make this
|
||||||
// function const; previously the implementation used
|
// function const; previously the implementation used
|
||||||
// `(self.get_unchecked(..mid), self.get_unchecked(mid..))`
|
// `(self.get_unchecked(..mid), self.get_unchecked(mid..))`
|
||||||
|
|
||||||
|
@ -85,7 +85,7 @@
|
|||||||
#[rustc_allow_const_fn_unstable(str_internals)]
|
#[rustc_allow_const_fn_unstable(str_internals)]
|
||||||
#[rustc_diagnostic_item = "str_from_utf8"]
|
#[rustc_diagnostic_item = "str_from_utf8"]
|
||||||
pub const fn from_utf8(v: &[u8]) -> Result<&str, Utf8Error> {
|
pub const fn from_utf8(v: &[u8]) -> Result<&str, Utf8Error> {
|
||||||
// FIXME: This should use `?` again, once it's `const`
|
// FIXME(const-hack): This should use `?` again, once it's `const`
|
||||||
match run_utf8_validation(v) {
|
match run_utf8_validation(v) {
|
||||||
Ok(_) => {
|
Ok(_) => {
|
||||||
// SAFETY: validation succeeded.
|
// SAFETY: validation succeeded.
|
||||||
@ -129,7 +129,7 @@ pub const fn from_utf8(v: &[u8]) -> Result<&str, Utf8Error> {
|
|||||||
#[rustc_const_unstable(feature = "const_str_from_utf8", issue = "91006")]
|
#[rustc_const_unstable(feature = "const_str_from_utf8", issue = "91006")]
|
||||||
#[rustc_diagnostic_item = "str_from_utf8_mut"]
|
#[rustc_diagnostic_item = "str_from_utf8_mut"]
|
||||||
pub const fn from_utf8_mut(v: &mut [u8]) -> Result<&mut str, Utf8Error> {
|
pub const fn from_utf8_mut(v: &mut [u8]) -> Result<&mut str, Utf8Error> {
|
||||||
// This should use `?` again, once it's `const`
|
// FIXME(const-hack): This should use `?` again, once it's `const`
|
||||||
match run_utf8_validation(v) {
|
match run_utf8_validation(v) {
|
||||||
Ok(_) => {
|
Ok(_) => {
|
||||||
// SAFETY: validation succeeded.
|
// SAFETY: validation succeeded.
|
||||||
|
@ -100,7 +100,7 @@ pub const fn valid_up_to(&self) -> usize {
|
|||||||
#[must_use]
|
#[must_use]
|
||||||
#[inline]
|
#[inline]
|
||||||
pub const fn error_len(&self) -> Option<usize> {
|
pub const fn error_len(&self) -> Option<usize> {
|
||||||
// FIXME: This should become `map` again, once it's `const`
|
// FIXME(const-hack): This should become `map` again, once it's `const`
|
||||||
match self.error_len {
|
match self.error_len {
|
||||||
Some(len) => Some(len as usize),
|
Some(len) => Some(len as usize),
|
||||||
None => None,
|
None => None,
|
||||||
|
@ -92,7 +92,6 @@ const fn str_index_overflow_fail() -> ! {
|
|||||||
///
|
///
|
||||||
/// Equivalent to `&self[0 .. len]` or `&mut self[0 .. len]`.
|
/// Equivalent to `&self[0 .. len]` or `&mut self[0 .. len]`.
|
||||||
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl SliceIndex<str> for ops::RangeFull {
|
unsafe impl SliceIndex<str> for ops::RangeFull {
|
||||||
type Output = str;
|
type Output = str;
|
||||||
#[inline]
|
#[inline]
|
||||||
@ -157,7 +156,6 @@ fn index_mut(self, slice: &mut str) -> &mut Self::Output {
|
|||||||
/// // &s[3 .. 100];
|
/// // &s[3 .. 100];
|
||||||
/// ```
|
/// ```
|
||||||
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl SliceIndex<str> for ops::Range<usize> {
|
unsafe impl SliceIndex<str> for ops::Range<usize> {
|
||||||
type Output = str;
|
type Output = str;
|
||||||
#[inline]
|
#[inline]
|
||||||
@ -429,7 +427,6 @@ fn index_mut(self, slice: &mut str) -> &mut str {
|
|||||||
/// Panics if `end` does not point to the starting byte offset of a
|
/// Panics if `end` does not point to the starting byte offset of a
|
||||||
/// character (as defined by `is_char_boundary`), or if `end > len`.
|
/// character (as defined by `is_char_boundary`), or if `end > len`.
|
||||||
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl SliceIndex<str> for ops::RangeTo<usize> {
|
unsafe impl SliceIndex<str> for ops::RangeTo<usize> {
|
||||||
type Output = str;
|
type Output = str;
|
||||||
#[inline]
|
#[inline]
|
||||||
@ -498,7 +495,6 @@ fn index_mut(self, slice: &mut str) -> &mut Self::Output {
|
|||||||
/// Panics if `begin` does not point to the starting byte offset of
|
/// Panics if `begin` does not point to the starting byte offset of
|
||||||
/// a character (as defined by `is_char_boundary`), or if `begin > len`.
|
/// a character (as defined by `is_char_boundary`), or if `begin > len`.
|
||||||
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
#[stable(feature = "str_checked_slicing", since = "1.20.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl SliceIndex<str> for ops::RangeFrom<usize> {
|
unsafe impl SliceIndex<str> for ops::RangeFrom<usize> {
|
||||||
type Output = str;
|
type Output = str;
|
||||||
#[inline]
|
#[inline]
|
||||||
@ -625,7 +621,6 @@ fn index_mut(self, slice: &mut str) -> &mut Self::Output {
|
|||||||
/// to the ending byte offset of a character (`end + 1` is either a starting
|
/// to the ending byte offset of a character (`end + 1` is either a starting
|
||||||
/// byte offset or equal to `len`), if `begin > end`, or if `end >= len`.
|
/// byte offset or equal to `len`), if `begin > end`, or if `end >= len`.
|
||||||
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl SliceIndex<str> for ops::RangeInclusive<usize> {
|
unsafe impl SliceIndex<str> for ops::RangeInclusive<usize> {
|
||||||
type Output = str;
|
type Output = str;
|
||||||
#[inline]
|
#[inline]
|
||||||
@ -714,7 +709,6 @@ fn index_mut(self, slice: &mut str) -> &mut Self::Output {
|
|||||||
/// (`end + 1` is either a starting byte offset as defined by
|
/// (`end + 1` is either a starting byte offset as defined by
|
||||||
/// `is_char_boundary`, or equal to `len`), or if `end >= len`.
|
/// `is_char_boundary`, or equal to `len`), or if `end >= len`.
|
||||||
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
#[stable(feature = "inclusive_range", since = "1.26.0")]
|
||||||
#[rustc_const_unstable(feature = "const_slice_index", issue = "none")]
|
|
||||||
unsafe impl SliceIndex<str> for ops::RangeToInclusive<usize> {
|
unsafe impl SliceIndex<str> for ops::RangeToInclusive<usize> {
|
||||||
type Output = str;
|
type Output = str;
|
||||||
#[inline]
|
#[inline]
|
||||||
|
@ -213,6 +213,7 @@ pub const fn new(secs: u64, nanos: u32) -> Duration {
|
|||||||
// SAFETY: nanos < NANOS_PER_SEC, therefore nanos is within the valid range
|
// SAFETY: nanos < NANOS_PER_SEC, therefore nanos is within the valid range
|
||||||
Duration { secs, nanos: unsafe { Nanoseconds(nanos) } }
|
Duration { secs, nanos: unsafe { Nanoseconds(nanos) } }
|
||||||
} else {
|
} else {
|
||||||
|
// FIXME(const-hack): use `.expect` once that is possible.
|
||||||
let secs = match secs.checked_add((nanos / NANOS_PER_SEC) as u64) {
|
let secs = match secs.checked_add((nanos / NANOS_PER_SEC) as u64) {
|
||||||
Some(secs) => secs,
|
Some(secs) => secs,
|
||||||
None => panic!("overflow in Duration::new"),
|
None => panic!("overflow in Duration::new"),
|
||||||
@ -768,6 +769,7 @@ pub const fn checked_mul(self, rhs: u32) -> Option<Duration> {
|
|||||||
let total_nanos = self.nanos.0 as u64 * rhs as u64;
|
let total_nanos = self.nanos.0 as u64 * rhs as u64;
|
||||||
let extra_secs = total_nanos / (NANOS_PER_SEC as u64);
|
let extra_secs = total_nanos / (NANOS_PER_SEC as u64);
|
||||||
let nanos = (total_nanos % (NANOS_PER_SEC as u64)) as u32;
|
let nanos = (total_nanos % (NANOS_PER_SEC as u64)) as u32;
|
||||||
|
// FIXME(const-hack): use `and_then` once that is possible.
|
||||||
if let Some(s) = self.secs.checked_mul(rhs as u64) {
|
if let Some(s) = self.secs.checked_mul(rhs as u64) {
|
||||||
if let Some(secs) = s.checked_add(extra_secs) {
|
if let Some(secs) = s.checked_add(extra_secs) {
|
||||||
debug_assert!(nanos < NANOS_PER_SEC);
|
debug_assert!(nanos < NANOS_PER_SEC);
|
||||||
|
@ -18,16 +18,14 @@ const fn bitset_search<
|
|||||||
let bucket_idx = (needle / 64) as usize;
|
let bucket_idx = (needle / 64) as usize;
|
||||||
let chunk_map_idx = bucket_idx / CHUNK_SIZE;
|
let chunk_map_idx = bucket_idx / CHUNK_SIZE;
|
||||||
let chunk_piece = bucket_idx % CHUNK_SIZE;
|
let chunk_piece = bucket_idx % CHUNK_SIZE;
|
||||||
// FIXME: const-hack: Revert to `slice::get` after `const_slice_index`
|
// FIXME(const-hack): Revert to `slice::get` when slice indexing becomes possible in const.
|
||||||
// feature stabilizes.
|
|
||||||
let chunk_idx = if chunk_map_idx < chunk_idx_map.len() {
|
let chunk_idx = if chunk_map_idx < chunk_idx_map.len() {
|
||||||
chunk_idx_map[chunk_map_idx]
|
chunk_idx_map[chunk_map_idx]
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
let idx = bitset_chunk_idx[chunk_idx as usize][chunk_piece] as usize;
|
let idx = bitset_chunk_idx[chunk_idx as usize][chunk_piece] as usize;
|
||||||
// FIXME: const-hack: Revert to `slice::get` after `const_slice_index`
|
// FIXME(const-hack): Revert to `slice::get` when slice indexing becomes possible in const.
|
||||||
// feature stabilizes.
|
|
||||||
let word = if idx < bitset_canonical.len() {
|
let word = if idx < bitset_canonical.len() {
|
||||||
bitset_canonical[idx]
|
bitset_canonical[idx]
|
||||||
} else {
|
} else {
|
||||||
|
@ -16,11 +16,8 @@ fn default() -> MyHasher {
|
|||||||
|
|
||||||
impl Hasher for MyHasher {
|
impl Hasher for MyHasher {
|
||||||
fn write(&mut self, buf: &[u8]) {
|
fn write(&mut self, buf: &[u8]) {
|
||||||
// FIXME(const_trait_impl): change to for loop
|
for byte in buf {
|
||||||
let mut i = 0;
|
self.hash += *byte as u64;
|
||||||
while i < buf.len() {
|
|
||||||
self.hash += buf[i] as u64;
|
|
||||||
i += 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn write_str(&mut self, s: &str) {
|
fn write_str(&mut self, s: &str) {
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
/// This is the const equivalent to `NonZero::new(n).unwrap()`
|
/// This is the const equivalent to `NonZero::new(n).unwrap()`
|
||||||
///
|
///
|
||||||
/// FIXME: This can be removed once `Option::unwrap` is stably const.
|
/// FIXME(const-hack): This can be removed once `Option::unwrap` is stably const.
|
||||||
/// See the `const_option` feature (#67441).
|
/// See the `const_option` feature (#67441).
|
||||||
const fn non_zero_u16(n: u16) -> NonZero<u16> {
|
const fn non_zero_u16(n: u16) -> NonZero<u16> {
|
||||||
match NonZero::new(n) {
|
match NonZero::new(n) {
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
//@ known-bug: #110395
|
//@ known-bug: #110395
|
||||||
|
|
||||||
#![feature(const_slice_index)]
|
|
||||||
|
|
||||||
const A: [(); 5] = [(), (), (), (), ()];
|
const A: [(); 5] = [(), (), (), (), ()];
|
||||||
|
|
||||||
// Since the indexing is on a ZST, the addresses are all fine,
|
// Since the indexing is on a ZST, the addresses are all fine,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
error[E0015]: cannot call non-const fn `core::slice::<impl [()]>::get_unchecked::<std::ops::Range<usize>>` in constants
|
error[E0015]: cannot call non-const fn `core::slice::<impl [()]>::get_unchecked::<std::ops::Range<usize>>` in constants
|
||||||
--> $DIR/ub-slice-get-unchecked.rs:9:29
|
--> $DIR/ub-slice-get-unchecked.rs:7:29
|
||||||
|
|
|
|
||||||
LL | const B: &[()] = unsafe { A.get_unchecked(3..1) };
|
LL | const B: &[()] = unsafe { A.get_unchecked(3..1) };
|
||||||
| ^^^^^^^^^^^^^^^^^^^
|
| ^^^^^^^^^^^^^^^^^^^
|
||||||
|
Loading…
Reference in New Issue
Block a user